main
Last change
on this file since 057453c was 057453c, checked in by Naum Shapkarovski <naumshapkarovski@…>, 6 weeks ago |
feat: implement employees
|
-
Property mode
set to
100644
|
File size:
1.2 KB
|
Rev | Line | |
---|
[5d6f37a] | 1 | import { useMemo } from 'react';
|
---|
| 2 | // types
|
---|
[057453c] | 3 | import { Customer } from 'src/schemas';
|
---|
[5d6f37a] | 4 | // db
|
---|
| 5 | import { endpoints, fetcher } from 'src/utils/axios';
|
---|
| 6 | import axios from 'src/utils/axios';
|
---|
| 7 | // swr
|
---|
| 8 | import useSWR, { mutate } from 'swr';
|
---|
| 9 |
|
---|
| 10 | export function useGetCustomers() {
|
---|
| 11 | const collectionName = endpoints.customer;
|
---|
| 12 |
|
---|
| 13 | const { data, isLoading, error, isValidating } = useSWR(collectionName, fetcher<Customer[]>, {
|
---|
| 14 | revalidateOnFocus: false,
|
---|
| 15 | });
|
---|
| 16 |
|
---|
| 17 | const memoizedValue = useMemo(
|
---|
| 18 | () => ({
|
---|
| 19 | customers: data || [],
|
---|
| 20 | customersLoading: isLoading,
|
---|
| 21 | customersError: error,
|
---|
| 22 | customersValidating: isValidating,
|
---|
| 23 | customersEmpty: !isLoading && !data?.length,
|
---|
| 24 | }),
|
---|
| 25 | [data, error, isLoading, isValidating]
|
---|
| 26 | );
|
---|
| 27 |
|
---|
| 28 | return memoizedValue;
|
---|
| 29 | }
|
---|
| 30 |
|
---|
| 31 | export async function createCustomer(customerData: Partial<Customer>): Promise<Customer> {
|
---|
| 32 | try {
|
---|
| 33 | const response = await axios.post<Customer>(endpoints.customer, customerData);
|
---|
| 34 |
|
---|
| 35 | // Mutate the SWR cache to include the new customer
|
---|
| 36 | await mutate<Customer[]>(endpoints.customer, (currentData = []) => [
|
---|
| 37 | ...currentData,
|
---|
| 38 | response.data,
|
---|
| 39 | ]);
|
---|
| 40 |
|
---|
| 41 | return response.data;
|
---|
| 42 | } catch (error) {
|
---|
| 43 | throw error;
|
---|
| 44 | }
|
---|
| 45 | }
|
---|
Note:
See
TracBrowser
for help on using the repository browser.