npm-pkg-hook 1.12.7 → 1.12.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.babelrc +0 -0
- package/.env +5 -0
- package/.github/pull_request_template.md +18 -0
- package/.github/workflows/pepeline.yaml +30 -0
- package/dist/index.js +47752 -10080
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +47068 -9612
- package/dist/index.mjs.map +1 -0
- package/eslint.config.mts +153 -0
- package/expire.json +1 -0
- package/jsconfig.json +28 -0
- package/package.json +24 -61
- package/script.txt +7 -0
- package/src/config/client/errors.ts +39 -0
- package/src/config/client/index.ts +1 -0
- package/src/config/content/en.json +5 -0
- package/src/config/content/es.json +5 -0
- package/src/config/content/index.ts +16 -0
- package/src/cookies/index.ts +3 -0
- package/src/hooks/addTenMinutes/index.ts +14 -0
- package/src/hooks/calculateLogLatHaversine/index.ts +41 -0
- package/src/hooks/completeSchedules/index.ts +22 -0
- package/src/hooks/convertToMilitaryTime/index.ts +18 -0
- package/src/hooks/generateStoreURL/index.ts +41 -0
- package/src/hooks/generateTemplate/index.ts +66 -0
- package/src/hooks/getCardType/index.ts +24 -0
- package/src/hooks/getCategoriesWithProduct/helpers/index.ts +7 -0
- package/src/hooks/getCategoriesWithProduct/index.ts +62 -0
- package/src/hooks/getGlobalSession/index.ts +69 -0
- package/src/hooks/getSession/index.ts +72 -0
- package/src/hooks/getTodayTimestamps/index.ts +70 -0
- package/src/hooks/getTotalHours/index.ts +76 -0
- package/src/hooks/handleLogin/index.ts +14 -0
- package/src/hooks/index.ts +153 -0
- package/src/hooks/isTokenExpired/index.ts +17 -0
- package/src/hooks/newMessageSubscription/index.ts +28 -0
- package/src/hooks/newStoreOrderSubscription/index.ts +26 -0
- package/src/hooks/statusOpenStores/helpers/index.ts +124 -0
- package/src/hooks/statusOpenStores/index.ts +221 -0
- package/src/hooks/updateExtProductFoodsOptional/index.ts +49 -0
- package/src/hooks/useAcumulateDate/index.ts +18 -0
- package/src/hooks/useAllStoresPendingToRegister/index.ts +37 -0
- package/src/hooks/useAmountInput/index.ts +127 -0
- package/src/hooks/useAnimationFrame/index.ts +45 -0
- package/src/hooks/useAnimationText/index.ts +31 -0
- package/src/hooks/useAsideCart/helpers/index.ts +22 -0
- package/src/hooks/useAsideCart/index.ts +217 -0
- package/src/hooks/useAsideCart/queries.ts +10 -0
- package/src/hooks/useBanner/index.ts +20 -0
- package/src/hooks/useCart/index.ts +2 -0
- package/src/hooks/useCart/queries.ts +174 -0
- package/src/hooks/useCart/useCart/helpers/index.ts +79 -0
- package/src/hooks/useCart/useCart/index.ts +424 -0
- package/src/hooks/useCart/useGetCart/index.ts +34 -0
- package/src/hooks/useCatWithProduct/index.ts +54 -0
- package/src/hooks/useCatWithProduct/queries.ts +200 -0
- package/src/hooks/useCatWithProduct/types/index.ts +104 -0
- package/src/hooks/useCatWithProductClient/index.ts +57 -0
- package/src/hooks/useCatWithProductClient/queries.ts +56 -0
- package/src/hooks/useCategoriesProduct/index.ts +14 -0
- package/src/hooks/useCategoriesProduct/queries.ts +16 -0
- package/src/hooks/useCategoryInStore/index.ts +167 -0
- package/src/hooks/useCategoryInStore/queries.ts +78 -0
- package/src/hooks/useCategoryStore/index.ts +8 -0
- package/src/hooks/useCategoryStore/queries.ts +16 -0
- package/src/hooks/useChartData/index.ts +171 -0
- package/src/hooks/useChartData/useChartData/index.ts +200 -0
- package/src/hooks/useChartData/useChartDataAllOrders/index.ts +94 -0
- package/src/hooks/useChatRoomSubscription/index.ts +28 -0
- package/src/hooks/useCheckbox/index.ts +115 -0
- package/src/hooks/useCities/index.ts +14 -0
- package/src/hooks/useCities/queries.ts +12 -0
- package/src/hooks/useClients/index.ts +97 -0
- package/src/hooks/useClients/queries.ts +215 -0
- package/src/hooks/useColorByLetters/helpers/alea.ts +73 -0
- package/src/hooks/useColorByLetters/helpers/colors.ts +45 -0
- package/src/hooks/useColorByLetters/helpers/index.ts +22 -0
- package/src/hooks/useColorByLetters/helpers/mersenne_twister.ts +118 -0
- package/src/hooks/useColorByLetters/index.ts +24 -0
- package/src/hooks/useConnection/index.ts +24 -0
- package/src/hooks/useCountries/index.ts +20 -0
- package/src/hooks/useCountries/queries.ts +12 -0
- package/src/hooks/useCreateDeliveryTime/index.ts +51 -0
- package/src/hooks/useCreateOrderStatusType/index.ts +134 -0
- package/src/hooks/useCreateProduct/helpers/index.ts +23 -0
- package/src/hooks/useCreateProduct/helpers/manageCacheDataCatProduct/index.ts +52 -0
- package/src/hooks/useCreateProduct/helpers/useEditImageProduct/index.ts +182 -0
- package/src/hooks/useCreateProduct/index.ts +337 -0
- package/src/hooks/useCreateStorePendingToRegister/index.ts +17 -0
- package/src/hooks/useCreateStorePendingToRegister/queries.ts +10 -0
- package/src/hooks/useDashboardComponents/index.ts +50 -0
- package/src/hooks/useDeleteExtraProductFoods/index.ts +13 -0
- package/src/hooks/useDeleteSubProductOptional/index.ts +32 -0
- package/src/hooks/useDeleteSubProductOptional/queries.ts +10 -0
- package/src/hooks/useDeliveryTime/index.ts +29 -0
- package/src/hooks/useDepartments/index.ts +14 -0
- package/src/hooks/useDepartments/queries.ts +13 -0
- package/src/hooks/useDessert/helpers/index.ts +51 -0
- package/src/hooks/useDessert/index.ts +529 -0
- package/src/hooks/useDessertWithPrice/helpers/index.ts +76 -0
- package/src/hooks/useDessertWithPrice/index.ts +381 -0
- package/src/hooks/useDessertWithPrice/queries.ts +18 -0
- package/src/hooks/useDevWS/index.ts +53 -0
- package/src/hooks/useDevices/index.ts +2 -0
- package/src/hooks/useDevices/queries.ts +28 -0
- package/src/hooks/useDevices/useGetDevices.ts +28 -0
- package/src/hooks/useDevices/useRegisterDevices.ts +75 -0
- package/src/hooks/useDownloadReports/helpers/downloadFileFromResponse.ts +21 -0
- package/src/hooks/useDownloadReports/index.ts +2 -0
- package/src/hooks/useDownloadReports/useDownloadReportByDay/index.ts +105 -0
- package/src/hooks/useDownloadReports/useGetReportByDateRange/index.ts +116 -0
- package/src/hooks/useDrag/index.ts +79 -0
- package/src/hooks/useDropzone/index.ts +94 -0
- package/src/hooks/useDynamicAuth/index.ts +14 -0
- package/src/hooks/useDynamicAuth/queries.ts +24 -0
- package/src/hooks/useEditCategory/index.ts +41 -0
- package/src/hooks/useEditOneExtProductFoodOptional/index.ts +28 -0
- package/src/hooks/useEditOneExtProductFoodOptional/queries.ts +16 -0
- package/src/hooks/useEditSubProductOptional/index.ts +12 -0
- package/src/hooks/useEditSubProductOptional/queries.ts +10 -0
- package/src/hooks/useEmployee/index.ts +18 -0
- package/src/hooks/useEmployee/queries.ts +85 -0
- package/src/hooks/useEmployee/useCreateEmployee.ts +90 -0
- package/src/hooks/useEvent/index.ts +34 -0
- package/src/hooks/useFavoriteStores/index.ts +31 -0
- package/src/hooks/useFavoriteStores/queries.ts +54 -0
- package/src/hooks/useFetchJson/index.ts +25 -0
- package/src/hooks/useFetchMoreInteractions/index.jsx +39 -0
- package/src/hooks/useFilterConfigs/index.ts +173 -0
- package/src/hooks/useFingerprintjs/index.ts +197 -0
- package/src/hooks/useFormTools/index.ts +143 -0
- package/src/hooks/useFormatDate/index.ts +91 -0
- package/src/hooks/useFormatNumberPhone/index.ts +23 -0
- package/src/hooks/useFullScreenMode/index.ts +61 -0
- package/src/hooks/useGenerateNumberArray/index.ts +17 -0
- package/src/hooks/useGetAllLocationUser/index.ts +13 -0
- package/src/hooks/useGetAllLocationUser/queries.ts +44 -0
- package/src/hooks/useGetAllSales/index.ts +26 -0
- package/src/hooks/useGetCookies/index.ts +43 -0
- package/src/hooks/useGetExtProductFoodsSubOptionalAll/index.ts +15 -0
- package/src/hooks/useGetFoodRecomended/index.ts +33 -0
- package/src/hooks/useGetFoodRecomended/queries.ts +47 -0
- package/src/hooks/useGetMessagesToRoom/index.ts +23 -0
- package/src/hooks/useGetMinPrice/index.ts +13 -0
- package/src/hooks/useGetMinPrice/queries.ts +7 -0
- package/src/hooks/useGetOneStoreRating/index.ts +41 -0
- package/src/hooks/useGetOneStoreRating/queries.ts +18 -0
- package/src/hooks/useGetSalesAmountToday/index.ts +31 -0
- package/src/hooks/useGetStoreCookie/index.ts +21 -0
- package/src/hooks/useGoogleLogin/index.ts +169 -0
- package/src/hooks/useGoogleLogin/loadScript.ts +15 -0
- package/src/hooks/useGoogleLogin/removeScript.ts +7 -0
- package/src/hooks/useHover/index.ts +32 -0
- package/src/hooks/useImageOptimization/index.ts +32 -0
- package/src/hooks/useImageUploaderProduct/helper/canvasUtils.ts +146 -0
- package/src/hooks/useImageUploaderProduct/helper/getOrientation.ts +54 -0
- package/src/hooks/useImageUploaderProduct/helper/index.ts +5 -0
- package/src/hooks/useImageUploaderProduct/index.ts +295 -0
- package/src/hooks/useImageWeight/index.ts +55 -0
- package/src/hooks/useImagesStore/index.ts +227 -0
- package/src/hooks/useImagesStore/queries.ts +193 -0
- package/src/hooks/useImagesStore/utils/index.ts +4 -0
- package/src/hooks/useIncomingOrders/index.ts +11 -0
- package/src/hooks/useIncomingOrders/queries.ts +87 -0
- package/src/hooks/useInnerHtml/index.ts +39 -0
- package/src/hooks/useIntersection/index.ts +84 -0
- package/src/hooks/useInventory/index.ts +2 -0
- package/src/hooks/useInventory/queries.ts +58 -0
- package/src/hooks/useInventory/useGetProductsInStock.ts +16 -0
- package/src/hooks/useInventory/useUpdateManageStock.ts +41 -0
- package/src/hooks/useKeypress/index.ts +28 -0
- package/src/hooks/useLazyScript/index.ts +74 -0
- package/src/hooks/useLocalBackendIp/index.ts +34 -0
- package/src/hooks/useLocalSorage/index.ts +36 -0
- package/src/hooks/useLocationManager/index.ts +63 -0
- package/src/hooks/useLocationNavigate/index.ts +54 -0
- package/src/hooks/useLoginEmployeeInStore/index.ts +38 -0
- package/src/hooks/useLogout/helpers/BroadcastChannel.ts +74 -0
- package/src/hooks/useLogout/helpers/apiBaseUrl.ts +12 -0
- package/src/hooks/useLogout/helpers/fetchData.ts +37 -0
- package/src/hooks/useLogout/helpers/getCsrfToken.ts +37 -0
- package/src/hooks/useLogout/helpers/index.ts +65 -0
- package/src/hooks/useLogout/helpers/logger.ts +88 -0
- package/src/hooks/useLogout/helpers/parseUrl.ts +39 -0
- package/src/hooks/useLogout/index.ts +105 -0
- package/src/hooks/useManageNewOrder/helpers/index.ts +45 -0
- package/src/hooks/useManageNewOrder/helpers/mock.ts +0 -0
- package/src/hooks/useManageNewOrder/index.ts +104 -0
- package/src/hooks/useManageQueryParams/index.ts +120 -0
- package/src/hooks/useMobile/index.ts +65 -0
- package/src/hooks/useModules/helpers/index.ts +1 -0
- package/src/hooks/useModules/helpers/validateModules.ts +29 -0
- package/src/hooks/useModules/index.ts +124 -0
- package/src/hooks/useMouse/index.ts +55 -0
- package/src/hooks/useMutateHeight/index.ts +36 -0
- package/src/hooks/useOrderClient/index.ts +5 -0
- package/src/hooks/useOrderStatusTypes/index.ts +2 -0
- package/src/hooks/useOrderStatusTypes/useOrderStatusTypes/index.ts +133 -0
- package/src/hooks/useOrderStatusTypes/useUpdateOrderStatusPriorities/index.ts +99 -0
- package/src/hooks/useOrders/index.ts +3 -0
- package/src/hooks/useOrders/queries.ts +99 -0
- package/src/hooks/useOrders/useChangeOrderState/index.ts +128 -0
- package/src/hooks/useOrders/useOrdersFromStore/index.ts +78 -0
- package/src/hooks/usePWAInstall/index.ts +38 -0
- package/src/hooks/usePaymentMethod/index.ts +3 -0
- package/src/hooks/usePaymentMethod/paymentMethod.gql.ts +62 -0
- package/src/hooks/usePaymentMethod/paymentMethod.types.ts +28 -0
- package/src/hooks/usePaymentMethod/useCreatePaymentMethod/index.ts +25 -0
- package/src/hooks/usePaymentMethod/useGetAllPaymentMethods/index.ts +19 -0
- package/src/hooks/usePaymentMethod/useGetPaymentMethod/index.ts +26 -0
- package/src/hooks/usePortFetcher/index.ts +33 -0
- package/src/hooks/usePrintSaleTicket/index.ts +68 -0
- package/src/hooks/useProductsFood/index.ts +341 -0
- package/src/hooks/useProductsFood/queriesStore.ts +964 -0
- package/src/hooks/useProductsFood/types/index.ts +0 -0
- package/src/hooks/useProductsFood/useEditProduct.ts +49 -0
- package/src/hooks/useProductsFood/usetagsProducts.ts +101 -0
- package/src/hooks/useProviders/index.ts +3 -0
- package/src/hooks/useProviders/queries.ts +31 -0
- package/src/hooks/useProviders/useProvidersCreateStore/index.ts +13 -0
- package/src/hooks/useProviders/useProvidersDataStore/index.ts +25 -0
- package/src/hooks/useProvidersStore/index.ts +25 -0
- package/src/hooks/useProvidersStore/queries.ts +31 -0
- package/src/hooks/usePushNotificationOrder/index.ts +52 -0
- package/src/hooks/usePushNotifications/helpers/index.ts +123 -0
- package/src/hooks/usePushNotifications/index.ts +150 -0
- package/src/hooks/useQueryLocationsMap/index.ts +20 -0
- package/src/hooks/useQueryLocationsMap/queries.ts +40 -0
- package/src/hooks/useRatingArrayData/index.ts +54 -0
- package/src/hooks/useRatingArrayData/queries.ts +19 -0
- package/src/hooks/useReactToPrint/index.txt +1223 -0
- package/src/hooks/useRemoveExtraProductFoodsOptional/index.ts +24 -0
- package/src/hooks/useRemoveExtraProductFoodsOptional/queries.ts +48 -0
- package/src/hooks/useReport/index.ts +48 -0
- package/src/hooks/useReport/queries.ts +72 -0
- package/src/hooks/useRestaurant/helpers/index.ts +28 -0
- package/src/hooks/useRestaurant/helpers/manageStatusOpen.ts +26 -0
- package/src/hooks/useRestaurant/index.ts +71 -0
- package/src/hooks/useRestaurant/queries.ts +81 -0
- package/src/hooks/useRoads/index.ts +20 -0
- package/src/hooks/useRoads/queries.ts +13 -0
- package/src/hooks/useRoles/index.ts +4 -0
- package/src/hooks/useRoles/queries.ts +70 -0
- package/src/hooks/useRoles/useCreateRole.ts +40 -0
- package/src/hooks/useRoles/useGetRoles.ts +37 -0
- package/src/hooks/useRoles/useRemoveRoles.ts +40 -0
- package/src/hooks/useRoles/useUpdateRolesPriority.ts +44 -0
- package/src/hooks/useSales/helpers/add-product.utils.ts +120 -0
- package/src/hooks/useSales/helpers/apply-discount-to-cart.utils.ts +292 -0
- package/src/hooks/useSales/helpers/comment-product.utils.ts +41 -0
- package/src/hooks/useSales/helpers/constants/index.ts +38 -0
- package/src/hooks/useSales/helpers/extras.utils.ts +42 -0
- package/src/hooks/useSales/helpers/filterProductsByCarProId.utils.ts +17 -0
- package/src/hooks/useSales/helpers/increment-product-quantity.utils.ts +76 -0
- package/src/hooks/useSales/helpers/index.ts +3 -0
- package/src/hooks/useSales/helpers/initializer.utils.ts +22 -0
- package/src/hooks/useSales/helpers/isStockInsufficient.ts +3 -0
- package/src/hooks/useSales/helpers/remove-product.utils.test.ts +49 -0
- package/src/hooks/useSales/helpers/remove-product.utils.ts +34 -0
- package/src/hooks/useSales/helpers/resolveProduct.ts +29 -0
- package/src/hooks/useSales/helpers/useAddToCart.ts +64 -0
- package/src/hooks/useSales/index.ts +1418 -0
- package/src/hooks/useSales/queries.ts +532 -0
- package/src/hooks/useSales/types/index.ts +206 -0
- package/src/hooks/useSales/types/use-sales.types.ts +8 -0
- package/src/hooks/useSales/useGetSale.ts +21 -0
- package/src/hooks/useSales/useTotalSales.ts +24 -0
- package/src/hooks/useSaveAvailableProduct/helpers/index.ts +38 -0
- package/src/hooks/useSaveAvailableProduct/index.ts +32 -0
- package/src/hooks/useSaveAvailableProduct/queries.ts +10 -0
- package/src/hooks/useSaveLocation/index.ts +17 -0
- package/src/hooks/useSaveLocation/queries.ts +19 -0
- package/src/hooks/useSchedule/index.ts +35 -0
- package/src/hooks/useSchedule/queries.ts +43 -0
- package/src/hooks/useSchedule/schedule.ts +79 -0
- package/src/hooks/useScheduleData/index.ts +135 -0
- package/src/hooks/useScroll/index.ts +56 -0
- package/src/hooks/useScrollRotate/index.ts +16 -0
- package/src/hooks/useSetImageProducts/index.ts +59 -0
- package/src/hooks/useSetImageProducts/queries.ts +18 -0
- package/src/hooks/useSetSession/index.ts +44 -0
- package/src/hooks/useSetState/index.ts +24 -0
- package/src/hooks/useSetupSchedule/helpers/index.ts +85 -0
- package/src/hooks/useSetupSchedule/index.ts +284 -0
- package/src/hooks/useStatusOpenStore/helpers/index.ts +124 -0
- package/src/hooks/useStatusOpenStore/index.ts +195 -0
- package/src/hooks/useStatusOrdersClient/helpers/index.ts +14 -0
- package/src/hooks/useStatusOrdersClient/index.ts +18 -0
- package/src/hooks/useStatusOrdersClient/queries.ts +80 -0
- package/src/hooks/useStock/index.ts +1 -0
- package/src/hooks/useStock/useStockUpdatedAllSubscription.ts +40 -0
- package/src/hooks/useStockMovements/helpers/index.ts +16 -0
- package/src/hooks/useStockMovements/index.ts +39 -0
- package/src/hooks/useStore/index.ts +83 -0
- package/src/hooks/useStore/queries.ts +163 -0
- package/src/hooks/useStoreCalendar/index.ts +5 -0
- package/src/hooks/useStoreContacts/index.ts +53 -0
- package/src/hooks/useStoreContacts/queries.ts +48 -0
- package/src/hooks/useStoreTable/index.ts +2 -0
- package/src/hooks/useStoreTable/queries.ts +47 -0
- package/src/hooks/useStoreTable/useStoreTableCreate.ts +77 -0
- package/src/hooks/useStoreTable/useStoreTables.ts +15 -0
- package/src/hooks/useSubscriptionValidation/index.ts +112 -0
- package/src/hooks/useTagProducts/index.ts +3 -0
- package/src/hooks/useTagProducts/useDeleteOneTag.ts +106 -0
- package/src/hooks/useTagProducts/useGetAllTags.ts +68 -0
- package/src/hooks/useTagProducts/useRegisterMultipleTags.ts +157 -0
- package/src/hooks/useTheme/index.ts +65 -0
- package/src/hooks/useTimeAgo/useTimeAgo.ts +39 -0
- package/src/hooks/useTokenCards/index.ts +45 -0
- package/src/hooks/useTopProductsMovements/index.ts +27 -0
- package/src/hooks/useTotalAllSales/index.ts +25 -0
- package/src/hooks/useTotalProductsInStock/index.ts +23 -0
- package/src/hooks/useTotalProductsSold/index.ts +23 -0
- package/src/hooks/useTotalProductsSolded/index.ts +20 -0
- package/src/hooks/useUpdateCart/index.ts +131 -0
- package/src/hooks/useUpdateCartCookie/index.ts +60 -0
- package/src/hooks/useUpdateDashboardComponent/index.ts +91 -0
- package/src/hooks/useUpdateExistingOrders/index.ts +85 -0
- package/src/hooks/useUpdateExtProductFoodsSubOptional/index.ts +61 -0
- package/src/hooks/useUpdateModuleOrder/index.ts +37 -0
- package/src/hooks/useUpdateMultipleExtProduct/index.ts +34 -0
- package/src/hooks/useUpdateMultipleExtProduct/queries.ts +33 -0
- package/src/hooks/useUpdateMultipleProducts/index.ts +117 -0
- package/src/hooks/useUpdateMultipleProducts/queries.ts +51 -0
- package/src/hooks/useUploadProducts/helpers/index.ts +1 -0
- package/src/hooks/useUploadProducts/helpers/parseNumber.ts +37 -0
- package/src/hooks/useUploadProducts/helpers/validateProductDataExcel.ts +73 -0
- package/src/hooks/useUploadProducts/index.ts +442 -0
- package/src/hooks/useUpsertGoal/index.ts +68 -0
- package/src/hooks/useUser/index.ts +24 -0
- package/src/hooks/useUser/queries.ts +131 -0
- package/src/hooks/useWeeklyStockMovement/helpers/index.ts +32 -0
- package/src/hooks/useWeeklyStockMovement/index.ts +52 -0
- package/src/hooks/useWindowSize/index.ts +45 -0
- package/src/index.ts +8 -0
- package/src/mock/dessert/index.ts +16 -0
- package/src/mock/index.ts +1 -0
- package/src/security/index.ts +1 -0
- package/src/services/index.ts +1 -0
- package/src/utils/UtilDateRange.ts +56 -0
- package/src/utils/generateCode.ts +222 -0
- package/src/utils/index.ts +2 -0
- package/src/utils/utils.ts +344 -0
- package/tsconfig.eslint.json +16 -0
- package/tsconfig.json +21 -0
- package/tsup.config.ts +24 -0
- package/dist/index.cjs +0 -20089
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
export interface ICatWithProduct {
|
|
2
|
+
max?: number
|
|
3
|
+
min?: number
|
|
4
|
+
search?: string | null
|
|
5
|
+
productName?: string | null
|
|
6
|
+
searchFilter?: {
|
|
7
|
+
gender?: string[]
|
|
8
|
+
desc?: string | null
|
|
9
|
+
speciality?: string[]
|
|
10
|
+
}
|
|
11
|
+
callback?: Function
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
// =====================
|
|
16
|
+
// Query Variables
|
|
17
|
+
// =====================
|
|
18
|
+
|
|
19
|
+
export interface GetCatProductsWithProductVariables {
|
|
20
|
+
search?: string
|
|
21
|
+
productName?: string
|
|
22
|
+
min?: number
|
|
23
|
+
max?: number
|
|
24
|
+
gender?: string[]
|
|
25
|
+
desc?: string[]
|
|
26
|
+
categories?: string[]
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
// =====================
|
|
30
|
+
// Response Types
|
|
31
|
+
// =====================
|
|
32
|
+
|
|
33
|
+
export interface GetCatProductsWithProductResponse {
|
|
34
|
+
getCatProductsWithProduct: {
|
|
35
|
+
totalCount: number
|
|
36
|
+
catProductsWithProduct: CatProductWithProduct[]
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
// =====================
|
|
41
|
+
// Main Entities
|
|
42
|
+
// =====================
|
|
43
|
+
|
|
44
|
+
export interface CatProductWithProduct {
|
|
45
|
+
carProId: string
|
|
46
|
+
pState: number
|
|
47
|
+
ProImage: string | null
|
|
48
|
+
idStore: string
|
|
49
|
+
pName: string
|
|
50
|
+
totalCount: number
|
|
51
|
+
checked?: boolean
|
|
52
|
+
ProDescription?: string | null
|
|
53
|
+
createdAt: string
|
|
54
|
+
updatedAt: string
|
|
55
|
+
productFoodsAll: ProductFood[]
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
export interface ProductFood {
|
|
59
|
+
pId: string
|
|
60
|
+
stock: number
|
|
61
|
+
manageStock: boolean
|
|
62
|
+
sizeId?: string | null
|
|
63
|
+
colorId?: string | null
|
|
64
|
+
carProId: string
|
|
65
|
+
cId?: string | null
|
|
66
|
+
dId?: string | null
|
|
67
|
+
ctId?: string | null
|
|
68
|
+
idStore: string
|
|
69
|
+
caId?: string | null
|
|
70
|
+
fId?: string | null
|
|
71
|
+
pName: string
|
|
72
|
+
ProPrice: number
|
|
73
|
+
ProDescuento?: number | null
|
|
74
|
+
ProUniDisponibles?: number | null
|
|
75
|
+
ProDescription?: string | null
|
|
76
|
+
ProProtegido?: boolean | null
|
|
77
|
+
ProAssurance?: boolean | null
|
|
78
|
+
ProImage?: string | null
|
|
79
|
+
ProStar?: number | null
|
|
80
|
+
ProWidth?: number | null
|
|
81
|
+
ProHeight?: number | null
|
|
82
|
+
ProLength?: number | null
|
|
83
|
+
ProWeight?: number | null
|
|
84
|
+
ProQuantity?: number | null
|
|
85
|
+
ProOutstanding?: boolean | null
|
|
86
|
+
ProDelivery?: boolean | null
|
|
87
|
+
ProVoltaje?: string | null
|
|
88
|
+
pState: number
|
|
89
|
+
sTateLogistic?: number | null
|
|
90
|
+
createdAt: string
|
|
91
|
+
updatedAt: string
|
|
92
|
+
product_availables: ProductAvailable[]
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
export interface ProductAvailable {
|
|
96
|
+
availableProductId: string
|
|
97
|
+
pId: string
|
|
98
|
+
idStore: string
|
|
99
|
+
dayAvailable: string
|
|
100
|
+
startDate: string
|
|
101
|
+
endDate: string
|
|
102
|
+
createdAt: string
|
|
103
|
+
updatedAt: string
|
|
104
|
+
}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { useQuery } from '@apollo/client'
|
|
2
|
+
import { useMemo } from 'react'
|
|
3
|
+
|
|
4
|
+
import { GET_ALL_CATEGORIES_WITH_PRODUCT_CLIENTS } from './queries'
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Custom hook to fetch categories with product data.
|
|
8
|
+
*
|
|
9
|
+
* @param {string} idStore - The ID of the store.
|
|
10
|
+
* @returns {object} - The hook result containing filtered data, loading state, and fetch function.
|
|
11
|
+
*/
|
|
12
|
+
export const useCatWithProductClient = (idStore) => {
|
|
13
|
+
const { data, loading, error, fetchMore } = useQuery(GET_ALL_CATEGORIES_WITH_PRODUCT_CLIENTS, {
|
|
14
|
+
fetchPolicy: 'cache-and-network',
|
|
15
|
+
variables: {
|
|
16
|
+
max: 100,
|
|
17
|
+
idStore,
|
|
18
|
+
search: '',
|
|
19
|
+
gender: [],
|
|
20
|
+
desc: [],
|
|
21
|
+
categories: []
|
|
22
|
+
}
|
|
23
|
+
})
|
|
24
|
+
|
|
25
|
+
const fetchCategories = () => {
|
|
26
|
+
fetchMore({
|
|
27
|
+
variables: {
|
|
28
|
+
max: 100,
|
|
29
|
+
idStore,
|
|
30
|
+
search: '',
|
|
31
|
+
gender: [],
|
|
32
|
+
desc: [],
|
|
33
|
+
categories: []
|
|
34
|
+
},
|
|
35
|
+
updateQuery: (prev, { fetchMoreResult }) => {
|
|
36
|
+
if (!fetchMoreResult) return prev
|
|
37
|
+
return {
|
|
38
|
+
...prev,
|
|
39
|
+
getCatProductsWithProductClient: fetchMoreResult.getCatProductsWithProductClient
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
})
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
// Utiliza useMemo para memorizar el resultado filtrado
|
|
46
|
+
const filteredData = useMemo(() => {
|
|
47
|
+
return data?.getCatProductsWithProductClient?.filter(
|
|
48
|
+
(category) => {return category?.productFoodsAll?.length > 0}
|
|
49
|
+
) || []
|
|
50
|
+
}, [data])
|
|
51
|
+
|
|
52
|
+
return [filteredData, {
|
|
53
|
+
loading,
|
|
54
|
+
error,
|
|
55
|
+
fetchCategories
|
|
56
|
+
}]
|
|
57
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { gql } from '@apollo/client'
|
|
2
|
+
|
|
3
|
+
export const GET_ALL_CATEGORIES_WITH_PRODUCT_CLIENTS = gql`
|
|
4
|
+
query getCatProductsWithProductClient($search: String, $min: Int, $max: Int, $gender: [String], $desc: [String], $categories: [ID], $carProId: ID $idStore: ID ) {
|
|
5
|
+
getCatProductsWithProductClient(search: $search, min: $min, max: $max, gender: $gender, desc: $desc, categories: $categories, carProId: $carProId idStore: $idStore) {
|
|
6
|
+
carProId
|
|
7
|
+
pState
|
|
8
|
+
pState
|
|
9
|
+
ProImage
|
|
10
|
+
idStore
|
|
11
|
+
pName
|
|
12
|
+
ProDescription
|
|
13
|
+
ProImage
|
|
14
|
+
pState
|
|
15
|
+
pDatCre
|
|
16
|
+
pDatMod
|
|
17
|
+
productFoodsAll {
|
|
18
|
+
pId
|
|
19
|
+
sizeId
|
|
20
|
+
stock
|
|
21
|
+
colorId
|
|
22
|
+
carProId
|
|
23
|
+
cId
|
|
24
|
+
dId
|
|
25
|
+
ValueDelivery
|
|
26
|
+
ctId
|
|
27
|
+
idStore
|
|
28
|
+
caId
|
|
29
|
+
fId
|
|
30
|
+
pName
|
|
31
|
+
ProPrice
|
|
32
|
+
ProDescuento
|
|
33
|
+
ProUniDisponibles
|
|
34
|
+
ProDescription
|
|
35
|
+
ProProtegido
|
|
36
|
+
ProAssurance
|
|
37
|
+
ProImage
|
|
38
|
+
ProStar
|
|
39
|
+
ProWidth
|
|
40
|
+
ProHeight
|
|
41
|
+
ProLength
|
|
42
|
+
ProWeight
|
|
43
|
+
ProQuantity
|
|
44
|
+
ProOutstanding
|
|
45
|
+
ProDelivery
|
|
46
|
+
ProVoltaje
|
|
47
|
+
pState
|
|
48
|
+
sTateLogistic
|
|
49
|
+
pDatCre
|
|
50
|
+
pDatMod
|
|
51
|
+
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
`
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { useQuery } from '@apollo/client'
|
|
2
|
+
|
|
3
|
+
import { GET_ULTIMATE_CATEGORY_PRODUCTS } from './queries'
|
|
4
|
+
|
|
5
|
+
export const useCategoriesProduct = () => {
|
|
6
|
+
const {
|
|
7
|
+
data,
|
|
8
|
+
loading,
|
|
9
|
+
error,
|
|
10
|
+
networkStatus
|
|
11
|
+
} = useQuery(GET_ULTIMATE_CATEGORY_PRODUCTS)
|
|
12
|
+
|
|
13
|
+
return [data?.catProductsAll, { loading, error, networkStatus }]
|
|
14
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { gql } from '@apollo/client'
|
|
2
|
+
|
|
3
|
+
export const GET_ULTIMATE_CATEGORY_PRODUCTS = gql`
|
|
4
|
+
query catProductsAll($search: String, $min: Int, $max: Int, $gender: [String], $desc: [String], $categories: [ID], ) {
|
|
5
|
+
catProductsAll(search: $search, min: $min, max: $max, gender: $gender, desc: $desc, categories: $categories,) {
|
|
6
|
+
carProId
|
|
7
|
+
idStore
|
|
8
|
+
pName
|
|
9
|
+
ProDescription
|
|
10
|
+
ProImage
|
|
11
|
+
pState
|
|
12
|
+
createdAt
|
|
13
|
+
updatedAt
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
`
|
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
import { useMutation, useQuery, ApolloError } from '@apollo/client'
|
|
2
|
+
import { useState } from 'react'
|
|
3
|
+
|
|
4
|
+
import {
|
|
5
|
+
DELETE_ONE_CAT_PRODUCTS,
|
|
6
|
+
GET_ULTIMATE_CATEGORY_PRODUCTS,
|
|
7
|
+
UPDATE_CAT_IN_PRODUCT
|
|
8
|
+
} from '../useProductsFood/queriesStore'
|
|
9
|
+
|
|
10
|
+
import { GET_ONE_STORE_IN_CATEGORY } from './queries'
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Generic alert box handler
|
|
14
|
+
*/
|
|
15
|
+
interface AlertBoxPayload {
|
|
16
|
+
title?: string
|
|
17
|
+
message: string
|
|
18
|
+
color: 'error' | 'success' | 'warning' | 'info'
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
type SetAlertBox = (payload: AlertBoxPayload) => void
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* Category entity
|
|
25
|
+
*/
|
|
26
|
+
interface Category {
|
|
27
|
+
idPc: string
|
|
28
|
+
pState: string
|
|
29
|
+
[key: string]: unknown
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
/**
|
|
33
|
+
* Hook params
|
|
34
|
+
*/
|
|
35
|
+
interface UseCategoryInStoreParams {
|
|
36
|
+
catStoreId?: string
|
|
37
|
+
setAlertBox?: SetAlertBox
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
/**
|
|
41
|
+
* Hook return shape
|
|
42
|
+
*/
|
|
43
|
+
interface UseCategoryInStoreResult {
|
|
44
|
+
categories: Category[]
|
|
45
|
+
data: Category[]
|
|
46
|
+
loading: boolean
|
|
47
|
+
error?: ApolloError
|
|
48
|
+
handlerDeleteCategoryInStore: (category?: Category) => Promise<unknown> | void
|
|
49
|
+
handleUpdateCatInProduct: (params: { data?: Array<{ pId: string }> }) => Promise<void>
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
/**
|
|
53
|
+
* Custom hook to manage categories in store
|
|
54
|
+
* @param root0
|
|
55
|
+
* @param root0.catStoreId
|
|
56
|
+
* @param root0.setAlertBox
|
|
57
|
+
*/
|
|
58
|
+
export const useCategoryInStore = ({
|
|
59
|
+
catStoreId,
|
|
60
|
+
setAlertBox = () => {}
|
|
61
|
+
}: UseCategoryInStoreParams = {}): UseCategoryInStoreResult => {
|
|
62
|
+
const [categories, setOneCategoryInStore] = useState<Category[]>([])
|
|
63
|
+
|
|
64
|
+
const [deleteCatOfProducts] = useMutation(DELETE_ONE_CAT_PRODUCTS, {
|
|
65
|
+
onError: (e: ApolloError) => {
|
|
66
|
+
setAlertBox({
|
|
67
|
+
title: '',
|
|
68
|
+
message: e.graphQLErrors?.[0]?.message || 'Unexpected error',
|
|
69
|
+
color: 'error'
|
|
70
|
+
})
|
|
71
|
+
},
|
|
72
|
+
update: (cache) => {
|
|
73
|
+
cache.modify({
|
|
74
|
+
fields: {
|
|
75
|
+
catProductsAll (dataOld = []) {
|
|
76
|
+
return cache.writeQuery({
|
|
77
|
+
query: GET_ULTIMATE_CATEGORY_PRODUCTS,
|
|
78
|
+
data: dataOld
|
|
79
|
+
})
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
})
|
|
83
|
+
}
|
|
84
|
+
})
|
|
85
|
+
|
|
86
|
+
const [updatedCatWithProducts] = useMutation(UPDATE_CAT_IN_PRODUCT, {
|
|
87
|
+
onError: (e: ApolloError) => {
|
|
88
|
+
console.error({
|
|
89
|
+
message: e.graphQLErrors?.[0]?.message || 'Unexpected error',
|
|
90
|
+
color: 'error'
|
|
91
|
+
})
|
|
92
|
+
},
|
|
93
|
+
update: (cache) => {
|
|
94
|
+
cache.modify({
|
|
95
|
+
fields: {
|
|
96
|
+
catProductsAll (dataOld = []) {
|
|
97
|
+
return cache.writeQuery({
|
|
98
|
+
query: GET_ULTIMATE_CATEGORY_PRODUCTS,
|
|
99
|
+
data: dataOld
|
|
100
|
+
})
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
})
|
|
104
|
+
}
|
|
105
|
+
})
|
|
106
|
+
|
|
107
|
+
const { data } = useQuery(GET_ULTIMATE_CATEGORY_PRODUCTS)
|
|
108
|
+
|
|
109
|
+
const { loading, error } = useQuery(GET_ONE_STORE_IN_CATEGORY, {
|
|
110
|
+
variables: {
|
|
111
|
+
catStore: catStoreId
|
|
112
|
+
},
|
|
113
|
+
skip: !catStoreId,
|
|
114
|
+
onError: () => {
|
|
115
|
+
console.warn({ message: 'Failed loading category store', duration: 5000 })
|
|
116
|
+
},
|
|
117
|
+
onCompleted: (response) => {
|
|
118
|
+
if (response?.getOneCatStore) {
|
|
119
|
+
setOneCategoryInStore(response.getOneCatStore)
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
})
|
|
123
|
+
|
|
124
|
+
/**
|
|
125
|
+
* Delete category from products
|
|
126
|
+
* @param category
|
|
127
|
+
*/
|
|
128
|
+
const handlerDeleteCategoryInStore = (category?: Category) => {
|
|
129
|
+
const { pState, idPc } = category || {}
|
|
130
|
+
if (!idPc || !pState) return
|
|
131
|
+
|
|
132
|
+
return deleteCatOfProducts({
|
|
133
|
+
variables: { idPc, pState }
|
|
134
|
+
})
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
/**
|
|
138
|
+
* Update category in products
|
|
139
|
+
* @param root0
|
|
140
|
+
* @param root0.data
|
|
141
|
+
*/
|
|
142
|
+
const handleUpdateCatInProduct = async ({
|
|
143
|
+
data
|
|
144
|
+
}: {
|
|
145
|
+
data?: Array<{ pId: string }>
|
|
146
|
+
}): Promise<void> => {
|
|
147
|
+
if (!data?.length) return
|
|
148
|
+
|
|
149
|
+
await updatedCatWithProducts({
|
|
150
|
+
variables: {
|
|
151
|
+
input: {
|
|
152
|
+
setData: data.map(({ pId }) => {return { idProduct: pId }}),
|
|
153
|
+
idCat: ''
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
})
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
return {
|
|
160
|
+
categories,
|
|
161
|
+
data: data?.catProductsAll ?? [],
|
|
162
|
+
loading,
|
|
163
|
+
error,
|
|
164
|
+
handlerDeleteCategoryInStore,
|
|
165
|
+
handleUpdateCatInProduct
|
|
166
|
+
}
|
|
167
|
+
}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { gql } from '@apollo/client'
|
|
2
|
+
|
|
3
|
+
export const GET_ONE_STORE_IN_CATEGORY = gql`
|
|
4
|
+
query getOneCatStore($catStore: ID){
|
|
5
|
+
getOneCatStore(catStore: $catStore){
|
|
6
|
+
catStore
|
|
7
|
+
idUser
|
|
8
|
+
cName
|
|
9
|
+
cState
|
|
10
|
+
createdAt
|
|
11
|
+
cPathImage
|
|
12
|
+
updatedAt
|
|
13
|
+
csDescription
|
|
14
|
+
getAllStore {
|
|
15
|
+
idStore
|
|
16
|
+
cId
|
|
17
|
+
id
|
|
18
|
+
dId
|
|
19
|
+
ctId
|
|
20
|
+
catStore
|
|
21
|
+
neighborhoodStore
|
|
22
|
+
Viaprincipal
|
|
23
|
+
storeOwner
|
|
24
|
+
storeName
|
|
25
|
+
emailStore
|
|
26
|
+
storePhone
|
|
27
|
+
socialRaz
|
|
28
|
+
Image
|
|
29
|
+
banner
|
|
30
|
+
documentIdentifier
|
|
31
|
+
uPhoNum
|
|
32
|
+
ULocation
|
|
33
|
+
upLat
|
|
34
|
+
upLon
|
|
35
|
+
uState
|
|
36
|
+
siteWeb
|
|
37
|
+
description
|
|
38
|
+
NitStore
|
|
39
|
+
typeRegiments
|
|
40
|
+
typeContribute
|
|
41
|
+
secVia
|
|
42
|
+
addressStore
|
|
43
|
+
createdAt
|
|
44
|
+
pais {
|
|
45
|
+
cId
|
|
46
|
+
cName
|
|
47
|
+
cCalCod
|
|
48
|
+
cState
|
|
49
|
+
cDatCre
|
|
50
|
+
cDatMod
|
|
51
|
+
}
|
|
52
|
+
city {
|
|
53
|
+
ctId
|
|
54
|
+
dId
|
|
55
|
+
cName
|
|
56
|
+
cState
|
|
57
|
+
cDatCre
|
|
58
|
+
cDatMod
|
|
59
|
+
}
|
|
60
|
+
department {
|
|
61
|
+
dId
|
|
62
|
+
cId
|
|
63
|
+
dName
|
|
64
|
+
dState
|
|
65
|
+
dDatCre
|
|
66
|
+
dDatMod
|
|
67
|
+
}
|
|
68
|
+
getAllRatingStar {
|
|
69
|
+
rSId
|
|
70
|
+
rScore
|
|
71
|
+
idStore
|
|
72
|
+
createAt
|
|
73
|
+
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
`
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
import { useQuery } from '@apollo/client'
|
|
2
|
+
import { useState } from 'react'
|
|
3
|
+
|
|
4
|
+
import { SPANISH_MONTHS } from '../../utils/index'
|
|
5
|
+
import { GET_ALL_SALES } from '../useReport/queries'
|
|
6
|
+
export * from './useChartDataAllOrders'
|
|
7
|
+
|
|
8
|
+
export const useChartData = ({ year }) => {
|
|
9
|
+
const { data, loading } = useQuery(GET_ALL_SALES)
|
|
10
|
+
const [chartType, setChartType] = useState('line')
|
|
11
|
+
const [chartTypeYear, setChartTypeYear] = useState(new Date().getFullYear())
|
|
12
|
+
const [asFilter, setFilter] = useState(false)
|
|
13
|
+
const [newResult, setNewResult] = useState([])
|
|
14
|
+
const result = []
|
|
15
|
+
const sumByMonth = {}
|
|
16
|
+
|
|
17
|
+
data?.getAllSalesStore?.forEach(function (value) {
|
|
18
|
+
const month = new Date(value.pDatCre).getMonth()
|
|
19
|
+
const year = new Date(value.pDatCre).getFullYear()
|
|
20
|
+
const key = `${month}-${year}`
|
|
21
|
+
|
|
22
|
+
if (!sumByMonth[key]) {
|
|
23
|
+
sumByMonth[key] = {
|
|
24
|
+
Mes: month,
|
|
25
|
+
Year: year,
|
|
26
|
+
totalProductsPrice: 0
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
result.push(sumByMonth[key])
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
sumByMonth[key].totalProductsPrice += value.totalProductsPrice
|
|
33
|
+
})
|
|
34
|
+
|
|
35
|
+
const allMonths = Array.from({ length: 12 }, (_, i) => { return i })
|
|
36
|
+
const missingMonths = allMonths.filter(month => { return !result.some(data => { return data.Mes === month }) })
|
|
37
|
+
|
|
38
|
+
for (const element of missingMonths) {
|
|
39
|
+
result.push({
|
|
40
|
+
Mes: element,
|
|
41
|
+
totalProductsPrice: 0,
|
|
42
|
+
Year: ''
|
|
43
|
+
})
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
result.sort((a, b) => { return a.Mes - b.Mes })
|
|
47
|
+
|
|
48
|
+
const labelTitle = `Ventas por meses del año ${asFilter ? chartTypeYear : ''}`
|
|
49
|
+
// Resultado:
|
|
50
|
+
const dataChart = {
|
|
51
|
+
labels: asFilter
|
|
52
|
+
? newResult.map(data => {
|
|
53
|
+
return SPANISH_MONTHS[data.Mes]
|
|
54
|
+
})
|
|
55
|
+
: result.map(data => {
|
|
56
|
+
return SPANISH_MONTHS[data.Mes]
|
|
57
|
+
}),
|
|
58
|
+
datasets: [
|
|
59
|
+
{
|
|
60
|
+
label: labelTitle,
|
|
61
|
+
data: asFilter ? newResult.map(data => { return data?.totalProductsPrice }) : result.map(data => { return data?.totalProductsPrice }),
|
|
62
|
+
backgroundColor: [
|
|
63
|
+
'rgba(255, 99, 132, 0.2)',
|
|
64
|
+
'rgba(54, 162, 235, 0.2)',
|
|
65
|
+
'rgba(255, 206, 86, 0.2)',
|
|
66
|
+
'rgba(75, 192, 192, 0.2)',
|
|
67
|
+
'rgba(153, 102, 255, 0.2)',
|
|
68
|
+
'rgba(255, 159, 64, 0.2)'
|
|
69
|
+
],
|
|
70
|
+
borderColor: chartType === 'bar'
|
|
71
|
+
? [
|
|
72
|
+
'rgba(255, 99, 132, 1)',
|
|
73
|
+
'rgba(54, 162, 235, 1)',
|
|
74
|
+
'rgba(255, 206, 86, 1)',
|
|
75
|
+
'rgba(75, 192, 192, 1)',
|
|
76
|
+
'rgba(153, 102, 255, 1)',
|
|
77
|
+
'rgba(255, 159, 64, 1)'
|
|
78
|
+
]
|
|
79
|
+
: 'rgb(255 0 0)',
|
|
80
|
+
tension: 0.6,
|
|
81
|
+
fill: false,
|
|
82
|
+
borderWidth: 1,
|
|
83
|
+
barPercentage: 1,
|
|
84
|
+
barThickness: 50,
|
|
85
|
+
minBarLength: 3
|
|
86
|
+
}
|
|
87
|
+
]
|
|
88
|
+
}
|
|
89
|
+
const options = {
|
|
90
|
+
interaction: {
|
|
91
|
+
mode: 'index',
|
|
92
|
+
intersect: false
|
|
93
|
+
},
|
|
94
|
+
scales: {
|
|
95
|
+
x: {
|
|
96
|
+
stacked: true
|
|
97
|
+
},
|
|
98
|
+
y: {
|
|
99
|
+
stacked: true
|
|
100
|
+
}
|
|
101
|
+
},
|
|
102
|
+
plugins: {
|
|
103
|
+
title: {
|
|
104
|
+
display: true,
|
|
105
|
+
text: labelTitle
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
const groupedData = {}
|
|
110
|
+
|
|
111
|
+
Boolean(data?.getAllSalesStore?.length) && data?.getAllSalesStore?.forEach((item) => {
|
|
112
|
+
const year = new Date(item.pDatCre).getFullYear()
|
|
113
|
+
if (!groupedData[year]) {
|
|
114
|
+
groupedData[year] = []
|
|
115
|
+
}
|
|
116
|
+
groupedData[year].push(item)
|
|
117
|
+
})
|
|
118
|
+
const years = []
|
|
119
|
+
|
|
120
|
+
Boolean(data?.getAllSalesStore?.length) && data?.getAllSalesStore?.forEach((item) => {
|
|
121
|
+
const y = new Date(item.pDatCre).getFullYear()
|
|
122
|
+
if (!years.includes(y)) {
|
|
123
|
+
years.push(y)
|
|
124
|
+
}
|
|
125
|
+
})
|
|
126
|
+
const handleChangeYear = (value) => {
|
|
127
|
+
setFilter(true)
|
|
128
|
+
const currentYear = parseInt(value)
|
|
129
|
+
setChartTypeYear(currentYear || '')
|
|
130
|
+
if (result?.length > 0) {
|
|
131
|
+
const filterToYear = result.filter((elem) => {
|
|
132
|
+
return elem?.Year === currentYear
|
|
133
|
+
})
|
|
134
|
+
const missingNewMonths = allMonths.filter(month => { return !filterToYear.some(data => { return data.Mes === month }) })
|
|
135
|
+
for (const element of missingNewMonths) {
|
|
136
|
+
filterToYear.push({
|
|
137
|
+
Mes: element,
|
|
138
|
+
totalProductsPrice: 0,
|
|
139
|
+
Year: ''
|
|
140
|
+
})
|
|
141
|
+
}
|
|
142
|
+
filterToYear.sort((a, b) => { return a.Mes - b.Mes })
|
|
143
|
+
setNewResult(filterToYear)
|
|
144
|
+
return filterToYear
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
const cleanFilter = () => {
|
|
148
|
+
setFilter(false)
|
|
149
|
+
setChartTypeYear(new Date().getFullYear())
|
|
150
|
+
}
|
|
151
|
+
const sortYear = () => {
|
|
152
|
+
return years.sort((a, b) => { return b - a })
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
const organiceYears = sortYear()
|
|
156
|
+
return {
|
|
157
|
+
handleChangeYear,
|
|
158
|
+
setFilter,
|
|
159
|
+
cleanFilter,
|
|
160
|
+
setChartType,
|
|
161
|
+
years: organiceYears,
|
|
162
|
+
asFilter,
|
|
163
|
+
chartTypeYear,
|
|
164
|
+
options,
|
|
165
|
+
chartType,
|
|
166
|
+
labelTitle,
|
|
167
|
+
result,
|
|
168
|
+
dataChart,
|
|
169
|
+
loading
|
|
170
|
+
}
|
|
171
|
+
}
|