mirror of
https://github.com/bigcapitalhq/bigcapital.git
synced 2026-02-19 14:20:31 +00:00
feat: Typing the bank rules hooks
This commit is contained in:
@@ -10,7 +10,7 @@ import {
|
|||||||
import { MatchTransaction, MatchTransactionProps } from './MatchTransaction';
|
import { MatchTransaction, MatchTransactionProps } from './MatchTransaction';
|
||||||
import styles from './CategorizeTransactionAside.module.scss';
|
import styles from './CategorizeTransactionAside.module.scss';
|
||||||
import { FastField, FastFieldProps, Form, Formik } from 'formik';
|
import { FastField, FastFieldProps, Form, Formik } from 'formik';
|
||||||
import { useMatchTransaction } from '@/hooks/query/bank-rules';
|
import { useMatchUncategorizedTransaction } from '@/hooks/query/bank-rules';
|
||||||
import { MatchingTransactionFormValues } from './types';
|
import { MatchingTransactionFormValues } from './types';
|
||||||
import { transformToReq, useGetPendingAmountMatched } from './utils';
|
import { transformToReq, useGetPendingAmountMatched } from './utils';
|
||||||
import { useCategorizeTransactionTabsBoot } from './CategorizeTransactionTabsBoot';
|
import { useCategorizeTransactionTabsBoot } from './CategorizeTransactionTabsBoot';
|
||||||
@@ -25,7 +25,7 @@ const initialValues = {
|
|||||||
|
|
||||||
export function MatchingBankTransaction() {
|
export function MatchingBankTransaction() {
|
||||||
const { uncategorizedTransactionId } = useCategorizeTransactionTabsBoot();
|
const { uncategorizedTransactionId } = useCategorizeTransactionTabsBoot();
|
||||||
const { mutateAsync: matchTransaction } = useMatchTransaction();
|
const { mutateAsync: matchTransaction } = useMatchUncategorizedTransaction();
|
||||||
|
|
||||||
// Handles the form submitting.
|
// Handles the form submitting.
|
||||||
const handleSubmit = (values: MatchingTransactionFormValues) => {
|
const handleSubmit = (values: MatchingTransactionFormValues) => {
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
import { defaultTo } from 'lodash';
|
import { defaultTo } from 'lodash';
|
||||||
import React, { createContext } from 'react';
|
import React, { createContext } from 'react';
|
||||||
import { useMatchingTransactions } from '@/hooks/query/bank-rules';
|
import { useGetBankTransactionsMatches } from '@/hooks/query/bank-rules';
|
||||||
|
|
||||||
interface MatchingTransactionBootValues {
|
interface MatchingTransactionBootValues {
|
||||||
isMatchingTransactionsLoading: boolean;
|
isMatchingTransactionsLoading: boolean;
|
||||||
@@ -26,7 +26,7 @@ function MatchingTransactionBoot({
|
|||||||
const {
|
const {
|
||||||
data: matchingTransactions,
|
data: matchingTransactions,
|
||||||
isLoading: isMatchingTransactionsLoading,
|
isLoading: isMatchingTransactionsLoading,
|
||||||
} = useMatchingTransactions(uncategorizedTransactionId);
|
} = useGetBankTransactionsMatches(uncategorizedTransactionId);
|
||||||
|
|
||||||
const provider = {
|
const provider = {
|
||||||
isMatchingTransactionsLoading,
|
isMatchingTransactionsLoading,
|
||||||
|
|||||||
@@ -1,7 +1,10 @@
|
|||||||
// @ts-nocheck
|
// @ts-nocheck
|
||||||
import {
|
import {
|
||||||
UseMutateFunction,
|
QueryClient,
|
||||||
|
UseMutationOptions,
|
||||||
UseMutationResult,
|
UseMutationResult,
|
||||||
|
UseQueryOptions,
|
||||||
|
UseQueryResult,
|
||||||
useInfiniteQuery,
|
useInfiniteQuery,
|
||||||
useMutation,
|
useMutation,
|
||||||
useQuery,
|
useQuery,
|
||||||
@@ -9,38 +12,96 @@ import {
|
|||||||
} from 'react-query';
|
} from 'react-query';
|
||||||
import useApiRequest from '../useRequest';
|
import useApiRequest from '../useRequest';
|
||||||
import { transformToCamelCase } from '@/utils';
|
import { transformToCamelCase } from '@/utils';
|
||||||
|
import t from './types';
|
||||||
|
|
||||||
|
const QUERY_KEY = {
|
||||||
|
BANK_RULES: 'BANK_RULE',
|
||||||
|
BANK_TRANSACTION_MATCHES: 'BANK_TRANSACTION_MATCHES',
|
||||||
|
EXCLUDED_BANK_TRANSACTIONS_INFINITY: 'EXCLUDED_BANK_TRANSACTIONS_INFINITY',
|
||||||
|
RECOGNIZED_BANK_TRANSACTIONS_INFINITY:
|
||||||
|
'RECOGNIZED_BANK_TRANSACTIONS_INFINITY',
|
||||||
|
};
|
||||||
|
|
||||||
|
const commonInvalidateQueries = (query: QueryClient) => {
|
||||||
|
query.invalidateQueries(QUERY_KEY.BANK_RULES);
|
||||||
|
query.invalidateQueries(QUERY_KEY.RECOGNIZED_BANK_TRANSACTIONS_INFINITY);
|
||||||
|
};
|
||||||
|
|
||||||
|
interface CreateBankRuleValues {
|
||||||
|
value: any;
|
||||||
|
}
|
||||||
|
interface CreateBankRuleResponse {}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
* Creates a new bank rule.
|
||||||
|
* @param {UseMutationOptions<CreateBankRuleValues, Error, CreateBankRuleValues>} options -
|
||||||
|
* @returns {UseMutationResult<CreateBankRuleValues, Error, CreateBankRuleValues>}
|
||||||
*/
|
*/
|
||||||
export function useCreateBankRule(props) {
|
export function useCreateBankRule(
|
||||||
|
options?: UseMutationOptions<
|
||||||
|
CreateBankRuleValues,
|
||||||
|
Error,
|
||||||
|
CreateBankRuleValues
|
||||||
|
>,
|
||||||
|
): UseMutationResult<CreateBankRuleValues, Error, CreateBankRuleValues> {
|
||||||
const queryClient = useQueryClient();
|
const queryClient = useQueryClient();
|
||||||
const apiRequest = useApiRequest();
|
const apiRequest = useApiRequest();
|
||||||
|
|
||||||
return useMutation((values) => apiRequest.post(`/banking/rules`, values), {
|
return useMutation<CreateBankRuleValues, Error, CreateBankRuleValues>(
|
||||||
onSuccess: (res, id) => {
|
(values) =>
|
||||||
// Invalidate queries.
|
apiRequest.post(`/banking/rules`, values).then((res) => res.data),
|
||||||
},
|
|
||||||
...props,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
export function useEditBankRule(props) {
|
|
||||||
const queryClient = useQueryClient();
|
|
||||||
const apiRequest = useApiRequest();
|
|
||||||
|
|
||||||
return useMutation(
|
|
||||||
([id, values]) => apiRequest.post(`/banking/rules/${id}`, values),
|
|
||||||
{
|
{
|
||||||
onSuccess: (res, id) => {
|
...options,
|
||||||
// Invalidate queries.
|
onSuccess: () => {
|
||||||
|
commonInvalidateQueries(queryClient);
|
||||||
},
|
},
|
||||||
...props,
|
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function useDeleteBankRule(props) {
|
interface EditBankRuleValues {
|
||||||
|
id: number;
|
||||||
|
value: any;
|
||||||
|
}
|
||||||
|
interface EditBankRuleResponse {}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Edits the given bank rule.
|
||||||
|
* @param {UseMutationOptions<EditBankRuleResponse, Error, EditBankRuleValues>} options -
|
||||||
|
* @returns
|
||||||
|
*/
|
||||||
|
export function useEditBankRule(
|
||||||
|
options?: UseMutationOptions<EditBankRuleResponse, Error, EditBankRuleValues>,
|
||||||
|
): UseMutationResult<EditBankRuleResponse, Error, EditBankRuleValues> {
|
||||||
|
const queryClient = useQueryClient();
|
||||||
|
const apiRequest = useApiRequest();
|
||||||
|
|
||||||
|
return useMutation<EditBankRuleResponse, Error, EditBankRuleValues>(
|
||||||
|
({ id, value }) => apiRequest.post(`/banking/rules/${id}`, values),
|
||||||
|
{
|
||||||
|
...options,
|
||||||
|
onSuccess: () => {
|
||||||
|
commonInvalidateQueries(queryClient);
|
||||||
|
},
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
interface DeleteBankRuleResponse {}
|
||||||
|
type DeleteBankRuleValue = number;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Deletes the given bank rule.
|
||||||
|
* @param {UseMutationOptions<DeleteBankRuleResponse, Error, DeleteBankRuleValue>} options
|
||||||
|
* @returns {UseMutationResult<DeleteBankRuleResponse, Error, DeleteBankRuleValue}
|
||||||
|
*/
|
||||||
|
export function useDeleteBankRule(
|
||||||
|
options?: UseMutationOptions<
|
||||||
|
DeleteBankRuleResponse,
|
||||||
|
Error,
|
||||||
|
DeleteBankRuleValue
|
||||||
|
>,
|
||||||
|
): UseMutationResult<DeleteBankRuleResponse, Error, DeleteBankRuleValue> {
|
||||||
const queryClient = useQueryClient();
|
const queryClient = useQueryClient();
|
||||||
const apiRequest = useApiRequest();
|
const apiRequest = useApiRequest();
|
||||||
|
|
||||||
@@ -48,67 +109,110 @@ export function useDeleteBankRule(props) {
|
|||||||
(id: number) => apiRequest.delete(`/banking/rules/${id}`),
|
(id: number) => apiRequest.delete(`/banking/rules/${id}`),
|
||||||
{
|
{
|
||||||
onSuccess: (res, id) => {
|
onSuccess: (res, id) => {
|
||||||
// Invalidate queries.
|
commonInvalidateQueries(queryClient);
|
||||||
},
|
},
|
||||||
...props,
|
...options,
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
interface BankRulesResponse {}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
* Retrieves all bank rules.
|
||||||
* @returns
|
* @param {UseQueryOptions<BankRulesResponse, Error>} params -
|
||||||
|
* @returns {UseQueryResult<BankRulesResponse, Error>}
|
||||||
*/
|
*/
|
||||||
export function useBankRules() {
|
export function useBankRules(
|
||||||
|
options?: UseQueryOptions<BankRulesResponse, Error>,
|
||||||
|
): UseQueryResult<BankRulesResponse, Error> {
|
||||||
const apiRequest = useApiRequest();
|
const apiRequest = useApiRequest();
|
||||||
|
|
||||||
return useQuery(['BANK_RULEs'], () =>
|
return useQuery<BankRulesResponse, Error>(
|
||||||
apiRequest.get('/banking/rules').then((res) => res.data.bank_rules),
|
[QUERY_KEY.BANK_RULES],
|
||||||
|
() => apiRequest.get('/banking/rules').then((res) => res.data.bank_rules),
|
||||||
|
{ ...options },
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
interface GetBankRuleRes {}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
* Retrieve the given bank rule.
|
||||||
* @returns
|
* @param {number} bankRuleId -
|
||||||
|
* @param {UseQueryOptions<GetBankRuleRes, Error>} options -
|
||||||
|
* @returns {UseQueryResult<GetBankRuleRes, Error>}
|
||||||
*/
|
*/
|
||||||
export function useBankRule(bankRuleId: number, props) {
|
export function useBankRule(
|
||||||
|
bankRuleId: number,
|
||||||
|
options?: UseQueryOptions<GetBankRuleRes, Error>,
|
||||||
|
): UseQueryResult<GetBankRuleRes, Error> {
|
||||||
const apiRequest = useApiRequest();
|
const apiRequest = useApiRequest();
|
||||||
|
|
||||||
return useQuery(
|
return useQuery<GetBankRuleRes, Error>(
|
||||||
['BANK_RULEs', bankRuleId],
|
[QUERY_KEY.BANK_RULES, bankRuleId],
|
||||||
() =>
|
() =>
|
||||||
apiRequest
|
apiRequest
|
||||||
.get(`/banking/rules/${bankRuleId}`)
|
.get(`/banking/rules/${bankRuleId}`)
|
||||||
.then((res) => res.data.bank_rule),
|
.then((res) => res.data.bank_rule),
|
||||||
props,
|
{ ...options },
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type GetBankTransactionsMatchesValue = number;
|
||||||
|
interface GetBankTransactionsMatchesResponse {
|
||||||
|
perfectMatches: Array<any>;
|
||||||
|
possibleMatches: Array<any>;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
* Retrieves the bank transactions matches.
|
||||||
* @returns
|
* @param {UseQueryOptions<GetBankTransactionsMatchesResponse, Error>} params -
|
||||||
|
* @returns {UseQueryResult<GetBankTransactionsMatchesResponse, Error>}
|
||||||
*/
|
*/
|
||||||
export function useMatchingTransactions(
|
export function useGetBankTransactionsMatches(
|
||||||
uncategorizedTransactionId: number,
|
uncategorizedTransactionId: number,
|
||||||
props?: any,
|
options?: UseQueryOptions<GetBankTransactionsMatchesResponse, Error>,
|
||||||
) {
|
): UseQueryResult<GetBankTransactionsMatchesResponse, Error> {
|
||||||
const apiRequest = useApiRequest();
|
const apiRequest = useApiRequest();
|
||||||
|
|
||||||
return useQuery<any>(
|
return useQuery<GetBankTransactionsMatchesResponse, Error>(
|
||||||
['MATCHING_TRANSACTION', uncategorizedTransactionId],
|
[QUERY_KEY.BANK_TRANSACTION_MATCHES, uncategorizedTransactionId],
|
||||||
() =>
|
() =>
|
||||||
apiRequest
|
apiRequest
|
||||||
.get(`/cashflow/transactions/${uncategorizedTransactionId}/matches`)
|
.get(`/cashflow/transactions/${uncategorizedTransactionId}/matches`)
|
||||||
.then((res) => transformToCamelCase(res.data)),
|
.then((res) => transformToCamelCase(res.data)),
|
||||||
props,
|
options,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function useExcludeUncategorizedTransaction(props) {
|
type ExcludeUncategorizedTransactionValue = number;
|
||||||
|
|
||||||
|
interface ExcludeUncategorizedTransactionRes {}
|
||||||
|
/**
|
||||||
|
* Excludes the given uncategorized transaction.
|
||||||
|
* @param {UseMutationOptions<ExcludeUncategorizedTransactionRes, Error, ExcludeUncategorizedTransactionValue>}
|
||||||
|
* @returns {UseMutationResult<ExcludeUncategorizedTransactionRes, Error, ExcludeUncategorizedTransactionValue> }
|
||||||
|
*/
|
||||||
|
export function useExcludeUncategorizedTransaction(
|
||||||
|
options?: UseMutationOptions<
|
||||||
|
ExcludeUncategorizedTransactionRes,
|
||||||
|
Error,
|
||||||
|
ExcludeUncategorizedTransactionValue
|
||||||
|
>,
|
||||||
|
): UseMutationResult<
|
||||||
|
ExcludeUncategorizedTransactionRes,
|
||||||
|
Error,
|
||||||
|
ExcludeUncategorizedTransactionValue
|
||||||
|
> {
|
||||||
const queryClient = useQueryClient();
|
const queryClient = useQueryClient();
|
||||||
const apiRequest = useApiRequest();
|
const apiRequest = useApiRequest();
|
||||||
|
|
||||||
return useMutation(
|
return useMutation<
|
||||||
|
ExcludeUncategorizedTransactionRes,
|
||||||
|
Error,
|
||||||
|
ExcludeUncategorizedTransactionValue
|
||||||
|
>(
|
||||||
(uncategorizedTransactionId: number) =>
|
(uncategorizedTransactionId: number) =>
|
||||||
apiRequest.put(
|
apiRequest.put(
|
||||||
`/cashflow/transactions/${uncategorizedTransactionId}/exclude`,
|
`/cashflow/transactions/${uncategorizedTransactionId}/exclude`,
|
||||||
@@ -116,17 +220,43 @@ export function useExcludeUncategorizedTransaction(props) {
|
|||||||
{
|
{
|
||||||
onSuccess: (res, id) => {
|
onSuccess: (res, id) => {
|
||||||
// Invalidate queries.
|
// Invalidate queries.
|
||||||
|
queryClient.invalidateQueries(
|
||||||
|
QUERY_KEY.EXCLUDED_BANK_TRANSACTIONS_INFINITY,
|
||||||
|
);
|
||||||
},
|
},
|
||||||
...props,
|
...options,
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function useUnexcludeUncategorizedTransaction(props) {
|
type ExcludeBankTransactionValue = number;
|
||||||
|
|
||||||
|
interface ExcludeBankTransactionResponse {}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Excludes the uncategorized bank transaction.
|
||||||
|
* @param {UseMutationResult<ExcludeBankTransactionResponse, Error, ExcludeBankTransactionValue>} options
|
||||||
|
* @returns {UseMutationResult<ExcludeBankTransactionResponse, Error, ExcludeBankTransactionValue>}
|
||||||
|
*/
|
||||||
|
export function useUnexcludeUncategorizedTransaction(
|
||||||
|
options?: UseMutationOptions<
|
||||||
|
ExcludeBankTransactionResponse,
|
||||||
|
Error,
|
||||||
|
ExcludeBankTransactionValue
|
||||||
|
>,
|
||||||
|
): UseMutationResult<
|
||||||
|
ExcludeBankTransactionResponse,
|
||||||
|
Error,
|
||||||
|
ExcludeBankTransactionValue
|
||||||
|
> {
|
||||||
const queryClient = useQueryClient();
|
const queryClient = useQueryClient();
|
||||||
const apiRequest = useApiRequest();
|
const apiRequest = useApiRequest();
|
||||||
|
|
||||||
return useMutation(
|
return useMutation<
|
||||||
|
ExcludeBankTransactionResponse,
|
||||||
|
Error,
|
||||||
|
ExcludeBankTransactionValue
|
||||||
|
>(
|
||||||
(uncategorizedTransactionId: number) =>
|
(uncategorizedTransactionId: number) =>
|
||||||
apiRequest.put(
|
apiRequest.put(
|
||||||
`/cashflow/transactions/${uncategorizedTransactionId}/unexclude`,
|
`/cashflow/transactions/${uncategorizedTransactionId}/unexclude`,
|
||||||
@@ -134,8 +264,11 @@ export function useUnexcludeUncategorizedTransaction(props) {
|
|||||||
{
|
{
|
||||||
onSuccess: (res, id) => {
|
onSuccess: (res, id) => {
|
||||||
// Invalidate queries.
|
// Invalidate queries.
|
||||||
|
queryClient.invalidateQueries(
|
||||||
|
QUERY_KEY.EXCLUDED_BANK_TRANSACTIONS_INFINITY,
|
||||||
|
);
|
||||||
},
|
},
|
||||||
...props,
|
...options,
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@@ -144,23 +277,39 @@ interface MatchUncategorizedTransactionValues {
|
|||||||
id: number;
|
id: number;
|
||||||
value: any;
|
value: any;
|
||||||
}
|
}
|
||||||
|
interface MatchUncategorizedTransactionRes {}
|
||||||
|
|
||||||
export function useMatchTransaction(
|
/**
|
||||||
props?: any,
|
* Matchess the given uncateogrized transaction.
|
||||||
): UseMutationResult<MatchUncategorizedTransactionValues> {
|
* @param props
|
||||||
|
* @returns
|
||||||
|
*/
|
||||||
|
export function useMatchUncategorizedTransaction(
|
||||||
|
props?: UseMutationOptions<
|
||||||
|
MatchUncategorizedTransactionRes,
|
||||||
|
Error,
|
||||||
|
MatchUncategorizedTransactionValues
|
||||||
|
>,
|
||||||
|
): UseMutationResult<
|
||||||
|
MatchUncategorizedTransactionRes,
|
||||||
|
Error,
|
||||||
|
MatchUncategorizedTransactionValues
|
||||||
|
> {
|
||||||
const queryClient = useQueryClient();
|
const queryClient = useQueryClient();
|
||||||
const apiRequest = useApiRequest();
|
const apiRequest = useApiRequest();
|
||||||
|
|
||||||
return useMutation<MatchUncategorizedTransactionValues>(
|
return useMutation<
|
||||||
([uncategorizedTransactionId, values]) =>
|
MatchUncategorizedTransactionRes,
|
||||||
apiRequest.post(`/banking/matches/${uncategorizedTransactionId}`, values),
|
Error,
|
||||||
{
|
MatchUncategorizedTransactionValues
|
||||||
onSuccess: (res, id) => {
|
>(({ id, value }) => apiRequest.post(`/banking/matches/${id}`, value), {
|
||||||
// Invalidate queries.
|
onSuccess: (res, id) => {
|
||||||
},
|
queryClient.invalidateQueries(
|
||||||
...props,
|
t.CASHFLOW_ACCOUNT_UNCATEGORIZED_TRANSACTIONS_INFINITY,
|
||||||
|
);
|
||||||
},
|
},
|
||||||
);
|
...props,
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -174,7 +323,7 @@ export function useRecognizedBankTransactionsInfinity(
|
|||||||
const apiRequest = useApiRequest();
|
const apiRequest = useApiRequest();
|
||||||
|
|
||||||
return useInfiniteQuery(
|
return useInfiniteQuery(
|
||||||
['RECOGNIZED_BANK_TRANSACTIONS_INFINITY', query],
|
[QUERY_KEY.RECOGNIZED_BANK_TRANSACTIONS_INFINITY, query],
|
||||||
async ({ pageParam = 1 }) => {
|
async ({ pageParam = 1 }) => {
|
||||||
const response = await apiRequest.http({
|
const response = await apiRequest.http({
|
||||||
...axios,
|
...axios,
|
||||||
@@ -206,7 +355,7 @@ export function useExcludedBankTransactionsInfinity(
|
|||||||
const apiRequest = useApiRequest();
|
const apiRequest = useApiRequest();
|
||||||
|
|
||||||
return useInfiniteQuery(
|
return useInfiniteQuery(
|
||||||
['EXCLUDED_BANK_TRANSACTIONS_INFINITY', query],
|
[QUERY_KEY.EXCLUDED_BANK_TRANSACTIONS_INFINITY, query],
|
||||||
async ({ pageParam = 1 }) => {
|
async ({ pageParam = 1 }) => {
|
||||||
const response = await apiRequest.http({
|
const response = await apiRequest.http({
|
||||||
...axios,
|
...axios,
|
||||||
|
|||||||
Reference in New Issue
Block a user