@agrada_digital/pbm 0.0.89 → 0.0.91

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/dist/index.js CHANGED
@@ -566,7 +566,6 @@ var import_jsx_runtime9 = require("react/jsx-runtime");
566
566
  function Item({ data, onChange, checked }) {
567
567
  const { setAvailableDiscountSelected, state, isAuthenticatedShopper } = usePBMStore();
568
568
  const { setModal } = useModal();
569
- const [openModalAlert, setOpenModalAlert] = (0, import_react3.useState)(false);
570
569
  const ID_INPUT = "unity_quantity_" + data.authorizedQuantity;
571
570
  const decimalDiscount = data.discountPercentual / 100;
572
571
  const unitDiscountValue = data.grossPrice * decimalDiscount;
@@ -596,12 +595,15 @@ function Item({ data, onChange, checked }) {
596
595
  (0, import_react3.useEffect)(() => {
597
596
  updateStorageData();
598
597
  }, [updateStorageData]);
599
- const CheckUserIsAuthenticated = () => {
600
- if (isAuthenticatedShopper) return;
601
- setModal({
602
- id: "ShopperIsNotAuthenticated",
603
- open: true
604
- });
598
+ const handleChange = (e) => {
599
+ if (!isAuthenticatedShopper && state === "isActivated") {
600
+ setModal({
601
+ id: "ShopperIsNotAuthenticated",
602
+ open: true
603
+ });
604
+ return;
605
+ }
606
+ onChange();
605
607
  };
606
608
  return /* @__PURE__ */ (0, import_jsx_runtime9.jsxs)(
607
609
  "label",
@@ -612,7 +614,6 @@ function Item({ data, onChange, checked }) {
612
614
  { "cursor-not-allowed": state === "isPreview", "cursor-pointer": state === "isActivated" }
613
615
  ),
614
616
  id: "label_benefits_" + ID_INPUT,
615
- onClick: CheckUserIsAuthenticated,
616
617
  children: [
617
618
  /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
618
619
  "input",
@@ -622,7 +623,7 @@ function Item({ data, onChange, checked }) {
622
623
  id: ID_INPUT,
623
624
  className: "hidden",
624
625
  checked,
625
- onChange,
626
+ onChange: handleChange,
626
627
  disabled: state === "isPreview"
627
628
  }
628
629
  ),
@@ -804,6 +805,7 @@ function BenefitsTable() {
804
805
  {
805
806
  className: "flex flex-col items-center justify-start w-full gap-4.5",
806
807
  id: "form_benefits_table_pbm",
808
+ onSubmit: (e) => e.preventDefault(),
807
809
  children: [
808
810
  !benefitsItems && /* @__PURE__ */ (0, import_jsx_runtime10.jsx)("p", { className: "text-sm font-semibold text-start text-zinc-900", id: "benefits_empty_pbm", children: "N\xE3o foi poss\xEDvel encontrar benef\xEDcios para esse produto." }),
809
811
  benefitsItems && benefitsItems.map((item, index) => {
@@ -944,7 +946,7 @@ function SecurityNumberInvalid({ textColor }) {
944
946
  var SecurityNumberInvalid_default = SecurityNumberInvalid;
945
947
 
946
948
  // src/PBM.tsx
947
- var import_react6 = require("react");
949
+ var import_react5 = require("react");
948
950
 
949
951
  // src/components/SecurityNumberRegitered/index.tsx
950
952
  var import_jsx_runtime14 = require("react/jsx-runtime");
@@ -1064,9 +1066,6 @@ var Modal = ({ ID }) => {
1064
1066
  };
1065
1067
  var Modal_default = Modal;
1066
1068
 
1067
- // src/hooks/useValidateProduct.tsx
1068
- var import_react5 = require("react");
1069
-
1070
1069
  // src/services/get-list-products.ts
1071
1070
  var import_js_cookie5 = __toESM(require("js-cookie"));
1072
1071
  var import_meta4 = {};
@@ -1090,31 +1089,6 @@ var GetProductsWithBenefits = async () => {
1090
1089
  return dataResponse;
1091
1090
  };
1092
1091
 
1093
- // src/hooks/useValidateProduct.tsx
1094
- function useValidateProduct({ eanProduct }) {
1095
- const [IsValid, setIsValid] = (0, import_react5.useState)(false);
1096
- const [Loading2, setLoading] = (0, import_react5.useState)(true);
1097
- const [Error2, setError] = (0, import_react5.useState)();
1098
- const fetchValidateProduct = (0, import_react5.useCallback)(async () => {
1099
- try {
1100
- const response = await GetProductsWithBenefits();
1101
- if (response.success) {
1102
- const data = response.data;
1103
- const hasProductInList = data.some((product) => product.ean == eanProduct);
1104
- setIsValid(hasProductInList);
1105
- }
1106
- } catch (error) {
1107
- setError(error);
1108
- console.error(error);
1109
- } finally {
1110
- }
1111
- }, []);
1112
- (0, import_react5.useEffect)(() => {
1113
- fetchValidateProduct();
1114
- }, [fetchValidateProduct]);
1115
- return { IsValid, Loading: Loading2, Error: Error2 };
1116
- }
1117
-
1118
1092
  // src/PBM.tsx
1119
1093
  var import_jsx_runtime16 = require("react/jsx-runtime");
1120
1094
  function PBM({
@@ -1127,13 +1101,26 @@ function PBM({
1127
1101
  const formatedOriginalProductPrice = Number(
1128
1102
  String(originalProductPrice).replace(",", ".")
1129
1103
  );
1130
- const [isReady, setIsReady] = (0, import_react6.useState)(false);
1131
- const [loading, setLoading] = (0, import_react6.useState)(false);
1104
+ const [isReady, setIsReady] = (0, import_react5.useState)(false);
1105
+ const [loading, setLoading] = (0, import_react5.useState)(false);
1132
1106
  const { state, setTargetProduct, targetProduct, setIsAuthenticatedShopper, setCustomLoginUrl } = usePBMStore();
1133
- const [EanProductExist, setEanProductExist] = (0, import_react6.useState)(true);
1134
- const { IsValid } = useValidateProduct({ eanProduct });
1107
+ const [EanProductExist, setEanProductExist] = (0, import_react5.useState)(true);
1108
+ const [IsValid, setIsValid] = (0, import_react5.useState)(false);
1109
+ const fetchValidateProduct = (0, import_react5.useCallback)(async () => {
1110
+ try {
1111
+ const response = await GetProductsWithBenefits();
1112
+ if (response.success) {
1113
+ const data = response.data;
1114
+ const hasProductInList = data.some((product) => product.ean == eanProduct);
1115
+ setIsValid(hasProductInList);
1116
+ }
1117
+ } catch (error) {
1118
+ console.error(error);
1119
+ }
1120
+ }, [eanProduct, IsValid]);
1135
1121
  const fetchProductByEan = async () => {
1136
1122
  try {
1123
+ if (!IsValid) return;
1137
1124
  if (!eanProduct) {
1138
1125
  console.error("PBMLOG: Ean is not defined.");
1139
1126
  setEanProductExist(false);
@@ -1161,10 +1148,11 @@ function PBM({
1161
1148
  setIsReady(true);
1162
1149
  }
1163
1150
  };
1164
- const handleAuthorizationRequest = (0, import_react6.useCallback)(async () => {
1151
+ const handleAuthorizationRequest = (0, import_react5.useCallback)(async () => {
1165
1152
  try {
1166
1153
  const response = await GetAuthorization({ clientID });
1167
- if (response.success && IsValid) {
1154
+ if (response.success) {
1155
+ fetchValidateProduct();
1168
1156
  fetchProductByEan();
1169
1157
  } else {
1170
1158
  console.error("PBMLOG: Authorization failed!");
@@ -1173,7 +1161,7 @@ function PBM({
1173
1161
  console.error("Error fetching authorization:", error);
1174
1162
  }
1175
1163
  }, [clientID, IsValid]);
1176
- (0, import_react6.useEffect)(() => {
1164
+ (0, import_react5.useEffect)(() => {
1177
1165
  handleAuthorizationRequest();
1178
1166
  }, [handleAuthorizationRequest]);
1179
1167
  if (!isReady) {
@@ -1204,21 +1192,15 @@ function PBM({
1204
1192
  if (!IsValid) {
1205
1193
  return;
1206
1194
  }
1207
- const RenderStateComponent = () => {
1208
- const StateMap = {
1209
- "isEmpty": /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(Form_default, { setLoading }),
1210
- "isInvalid": /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(SecurityNumberInvalid_default, {}),
1211
- "isRegistered": /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(SecurityNumberRegitered_default, {}),
1212
- "isActivated": /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(BenefitsTable_default, {}),
1213
- "isPreview": /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(BenefitsTable_default, {})
1214
- };
1215
- if (!loading) return StateMap[state];
1216
- else return /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(Loading_default, {});
1217
- };
1218
1195
  return /* @__PURE__ */ (0, import_jsx_runtime16.jsxs)("div", { id: "pbm-library-root", children: [
1219
1196
  /* @__PURE__ */ (0, import_jsx_runtime16.jsxs)(Container_default, { variant: "main", children: [
1220
1197
  /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(Header_default, { originalProductPrice: formatedOriginalProductPrice || 0 }),
1221
- /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(Container_default, { variant: "simple", children: /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(RenderStateComponent, {}) }),
1198
+ /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(Container_default, { variant: "simple", children: loading ? /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(Loading_default, {}) : /* @__PURE__ */ (0, import_jsx_runtime16.jsxs)(import_jsx_runtime16.Fragment, { children: [
1199
+ state === "isEmpty" && /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(Form_default, { setLoading }),
1200
+ state === "isInvalid" && /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(SecurityNumberInvalid_default, {}),
1201
+ state === "isRegistered" && /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(SecurityNumberRegitered_default, {}),
1202
+ (state === "isActivated" || state === "isPreview") && /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(BenefitsTable_default, {})
1203
+ ] }) }),
1222
1204
  /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(Footer_default, {})
1223
1205
  ] }),
1224
1206
  /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(Modal_default, { ID: "ShopperIsNotAuthenticated" })
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.ts","../src/libs/zustand/usePBM.tsx","../src/components/Header/index.tsx","../src/components/UI/Container/index.tsx","../src/components/Footer/index.tsx","../src/schema/validation-schema.ts","../src/utils/format.ts","../src/components/Form/index.tsx","../src/services/benefits-with-document.ts","../src/components/UI/Button/index.tsx","../src/components/UI/Loading/index.tsx","../src/components/BenefitsTable/index.tsx","../src/components/UI/Title/index.tsx","../src/libs/zustand/useModal.tsx","../src/components/BenefitsTable/Item.tsx","../src/components/UI/Icons/index.tsx","../src/services/benefits-without-document.ts","../src/components/UI/Text/index.tsx","../src/components/UI/Link/index.tsx","../src/utils/getParams.ts","../src/components/SecurityNumberInvalid/index.tsx","../src/PBM.tsx","../src/components/SecurityNumberRegitered/index.tsx","../src/services/authorization.ts","../src/services/get-product-by-ean.ts","../src/components/Modal/index.tsx","../src/hooks/useValidateProduct.tsx","../src/services/get-list-products.ts"],"sourcesContent":["// Estilos - importa CSS escopado para evitar conflitos\r\nimport './pbm-scoped.css';\r\n\r\n// Componente Principal\r\nexport { default as PBM } from \"./PBM\";\r\n\r\n// Tipos\r\nexport type { PBMProps } from \"./PBM\";\r\nexport type { PBMStore } from \"./libs/zustand/usePBM\";\r\n\r\n// Hooks\r\nexport { usePBMStore } from \"./libs/zustand/usePBM\"; \r\n","import { createStore, StateCreator, StoreApi } from \"zustand\";\r\nimport { useStore } from \"zustand/react\";\r\nimport { IProduct, usePBMTypes } from \"../../types/globals\";\r\n\r\nexport interface PBMStore extends usePBMTypes {\r\n setSecurityNumber: (securityNumber: string) => void;\r\n setState: (state: usePBMTypes[\"state\"]) => void;\r\n setAvailableDiscountSelected: (\r\n availableDiscount: usePBMTypes[\"availableDiscountSelected\"]\r\n ) => void;\r\n setTargetProduct: (targetProduct: usePBMTypes[\"targetProduct\"]) => void;\r\n setUrlAcceptTerms: (urlAcceptTerms: usePBMTypes[\"urlAcceptTerms\"]) => void;\r\n setUrlRegisterIndustry: (urlRegisterIndustry: usePBMTypes[\"urlRegisterIndustry\"]) => void;\r\n setIsAuthenticatedShopper: (isAuthenticatedShopper: usePBMTypes[\"isAuthenticatedShopper\"]) => void;\r\n setCustomLoginUrl: (customLoginUrl: usePBMTypes[\"customLoginUrl\"]) => void;\r\n setCardID: (cardID: usePBMTypes[\"cardID\"]) => void;\r\n}\r\n\r\n// Tipo apenas com os getters (estado readonly)\r\nexport type PBMStoreReadonly = Omit<PBMStore,\r\n | 'setSecurityNumber'\r\n | 'setState'\r\n | 'setAvailableDiscountSelected'\r\n | 'setTargetProduct'\r\n | 'setUrlAcceptTerms'\r\n | 'setUrlRegisterIndustry'\r\n>;\r\n\r\nconst initialPBMState: usePBMTypes = {\r\n securityNumber: \"\",\r\n cardID: \"\",\r\n state: \"isEmpty\",\r\n availableDiscountSelected: {\r\n quantity: 0,\r\n discount: {\r\n unit: 0,\r\n total: 0,\r\n },\r\n totalPrice: 0,\r\n grossPrice: 0\r\n },\r\n targetProduct: null,\r\n campaign: \"pbm_campaign\",\r\n isAuthenticatedShopper: false,\r\n customLoginUrl: \"/login\"\r\n};\r\n\r\nconst createPBMStore: StateCreator<PBMStore> = (set) => ({\r\n ...initialPBMState,\r\n\r\n setSecurityNumber: (securityNumber: string) => set({ securityNumber }),\r\n setState: (state: usePBMTypes[\"state\"]) => set({ state }),\r\n setTargetProduct: (targetProduct: usePBMTypes[\"targetProduct\"]) =>\r\n set({ targetProduct }),\r\n setAvailableDiscountSelected: (\r\n availableDiscount: usePBMTypes[\"availableDiscountSelected\"]\r\n ) => set({ availableDiscountSelected: availableDiscount }),\r\n setUrlAcceptTerms: (urlAcceptTerms: usePBMTypes[\"urlAcceptTerms\"]) =>\r\n set({ urlAcceptTerms: urlAcceptTerms }),\r\n setUrlRegisterIndustry: (urlRegisterIndustry: usePBMTypes[\"urlRegisterIndustry\"]) =>\r\n set({ urlRegisterIndustry: urlRegisterIndustry }),\r\n setIsAuthenticatedShopper: (isAuthenticatedShopper: usePBMTypes[\"isAuthenticatedShopper\"]) =>\r\n set({ isAuthenticatedShopper: isAuthenticatedShopper }),\r\n setCustomLoginUrl: (customLoginUrl: usePBMTypes[\"customLoginUrl\"]) => set({ customLoginUrl: customLoginUrl }),\r\n setCardID: (cardID: usePBMTypes[\"cardID\"]) => set({ cardID: cardID })\r\n});\r\n\r\n// Store completa (uso interno na biblioteca)\r\nexport const pbmStore: StoreApi<PBMStore> = createStore<PBMStore>(createPBMStore);\r\n\r\n// Cria uma versão somente leitura da store para exposição pública\r\nexport const createReadonlyStore = (): StoreApi<PBMStoreReadonly> => {\r\n return {\r\n getState: () => {\r\n const fullState = pbmStore.getState();\r\n // Remove os setters do estado retornado\r\n const {\r\n setSecurityNumber,\r\n setState,\r\n setAvailableDiscountSelected,\r\n setTargetProduct,\r\n setUrlAcceptTerms,\r\n setUrlRegisterIndustry,\r\n setIsAuthenticatedShopper,\r\n setCustomLoginUrl,\r\n setCardID,\r\n ...readonlyState\r\n } = fullState;\r\n\r\n const { quantity, productId, skuId, discountMax, netPrice, stockBalance, listPrice, price, ...limitedTargetProductData } = fullState.targetProduct as IProduct;\r\n\r\n return { ...readonlyState, targetProduct: limitedTargetProductData } as PBMStoreReadonly;\r\n }\r\n } as StoreApi<PBMStoreReadonly>;\r\n};\r\n\r\n// React hook (usado dentro de componentes React)\r\nexport function usePBMStore(): PBMStore;\r\nexport function usePBMStore<T>(selector: (state: PBMStore) => T): T;\r\nexport function usePBMStore<T>(selector?: (state: PBMStore) => T): PBMStore | T {\r\n if (selector) {\r\n return useStore(pbmStore, selector);\r\n }\r\n return useStore(pbmStore, (state) => state);\r\n}\r\n","import { usePBMStore } from \"../../libs/zustand/usePBM\";\r\n\r\nfunction Header({ originalProductPrice }: { originalProductPrice: number }) {\r\n const { targetProduct } = usePBMStore();\r\n const Price = (targetProduct?.listPrice || originalProductPrice);\r\n const Discount = Price * ((targetProduct?.discountMax || 0) / 100)\r\n\r\n return (\r\n <>\r\n {(targetProduct?.informativeMessage) && <span className=\"absolute w-11/12 -top-6 bg-emerald-500 px-4 py-1 rounded-lg text-sm text-center font-medium text-white\">{targetProduct?.informativeMessage}</span>}\r\n <header\r\n className=\"flex items-center justify-between w-full p-0.5 rounded-xl bg-[#44c2c0]/30 mt-5\"\r\n id=\"header_pbm\"\r\n >\r\n <span\r\n className=\"py-1 px-6 rounded-xl bg-[#44c2c0] shrink-0 text-white text-xl font-bold flex items-center justify-start gap-2 relative\"\r\n data-testid=\"test_id_header_price\"\r\n id=\"header_price\"\r\n >\r\n <section className=\"flex items-center gap-2 justify-center-safe\">\r\n <span className=\"line-through text-sm font-light\">\r\n {Number(Price)?.toLocaleString(\"pt-BR\", {\r\n currency: \"BRL\",\r\n currencyDisplay: \"symbol\",\r\n currencySign: \"standard\",\r\n style: \"currency\",\r\n })}\r\n </span>\r\n {Number(Price - Discount)?.toLocaleString(\"pt-BR\", {\r\n currency: \"BRL\",\r\n currencyDisplay: \"symbol\",\r\n currencySign: \"standard\",\r\n style: \"currency\",\r\n })}\r\n </section>\r\n </span>\r\n <h1 id=\"header_title\" className=\"text-center w-full text-[#339c9b] font-bold text-xs px-4 md:text-sm\">\r\n Desconto de Laboratório\r\n </h1>\r\n </header>\r\n </>\r\n );\r\n}\r\n\r\nexport default Header;\r\n","import classNames from \"classnames\";\r\nimport React from \"react\";\r\n\r\nfunction Container({\r\n children,\r\n variant,\r\n}: {\r\n children: React.ReactNode;\r\n variant: \"simple\" | \"main\";\r\n}) {\r\n return (\r\n <main\r\n className={classNames({\r\n \"border-3 border-[#44c2c0] flex flex-col items-center justify-center min-w-[var(--min-container)] max-w-[var(--max-container)] w-full h-auto rounded-xl p-4 bg-white gap-4 relative\":\r\n variant === \"main\",\r\n \"w-full h-auto relative\": variant === \"simple\",\r\n })}\r\n data-testid=\"test_id_container\"\r\n data-variant={variant}\r\n id=\"container_pbm\"\r\n >\r\n {children}\r\n </main>\r\n );\r\n}\r\n\r\nexport default Container;\r\n","import classNames from \"classnames\";\r\nimport { usePBMStore } from \"../../libs/zustand/usePBM\";\r\n\r\nfunction Footer() {\r\n const { targetProduct, state } = usePBMStore();\r\n\r\n return (\r\n <footer className=\"w-full h-auto relative\" id=\"footer_pbm\">\r\n <section className={classNames(\"flex items-center w-full h-auto gap-4\", { \"justify-center\": targetProduct?.industryLogo, \"justify-start\": !targetProduct?.industryLogo })}>\r\n <section className=\"w-4/5 h-auto\">\r\n <h3 className=\"text-start font-semibold text-sm\">\r\n Economize com o benefício do laboratório.\r\n </h3>\r\n <p className=\"text-start font-normal text-sm\">\r\n Este produto tem preço exclusivo para clientes cadastrados no\r\n programa.\r\n </p>\r\n </section>\r\n {targetProduct?.industryLogo && (\r\n <img\r\n src={targetProduct.industryLogo}\r\n alt=\"parceiro\"\r\n className=\"w-1/5 min-w-20 h-auto aspect-auto rounded-xl\"\r\n loading=\"eager\"\r\n id=\"footer_industry_logo_pbm\"\r\n data-testid=\"footer_industry_logo_pbm\"\r\n />\r\n )}\r\n </section>\r\n </footer>\r\n );\r\n}\r\n\r\nexport default Footer;\r\n","import { z } from \"zod\";\r\n\r\nexport const validationSchema = z.object({\r\n securityNumber: z\r\n .string({\r\n required_error: 'CPF é obrigatório.',\r\n })\r\n .refine((doc) => {\r\n const replacedDoc = doc.replace(/\\D/g, '');\r\n return replacedDoc.length >= 11;\r\n }, 'CPF deve conter no mínimo 11 caracteres.')\r\n .refine((doc) => {\r\n const replacedDoc = doc.replace(/\\D/g, '');\r\n return !!Number(replacedDoc);\r\n }, 'CPF deve conter apenas números.'),\r\n\r\n coupon: z.string({ required_error: 'Cupom / ID do Cartão obrigatório.'}).optional()\r\n});\r\n\r\nexport type validationSchemaType = z.infer<typeof validationSchema>","export const toFormat = (value: string) => {\r\n const cleanedValue = value.replace(/\\D/g, '');\r\n\r\n if (cleanedValue.length <= 11) {\r\n return cleanedValue\r\n .replace(/(\\d{3})(\\d)/, '$1.$2')\r\n .replace(/(\\d{3})(\\d)/, '$1.$2')\r\n .replace(/(\\d{3})(\\d{1,2})/, '$1-$2')\r\n .replace(/(-\\d{2})\\d+?$/, '$1');\r\n }\r\n};","import {\r\n validationSchema,\r\n validationSchemaType,\r\n} from \"../../schema/validation-schema\";\r\nimport { toFormat } from \"../../utils/format\";\r\n\r\nimport classNames from \"classnames\";\r\nimport { zodResolver } from \"@hookform/resolvers/zod\";\r\nimport { useForm } from \"react-hook-form\";\r\n\r\nimport { ArrowRight } from \"lucide-react\";\r\nimport { Dispatch, SetStateAction, useState } from \"react\";\r\n\r\nimport { usePBMStore } from \"../../libs/zustand/usePBM\";\r\nimport { BenefitsWithDocument } from \"../../services/benefits-with-document\";\r\nimport Button from \"../UI/Button\";\r\n\r\ninterface IForm {\r\n setLoading: Dispatch<SetStateAction<boolean>>;\r\n}\r\n\r\nfunction Form({ setLoading }: IForm) {\r\n const { setSecurityNumber, setState, securityNumber, targetProduct, setUrlAcceptTerms, setUrlRegisterIndustry, setCardID } = usePBMStore();\r\n const [showCardIDField, setShowCardIDField] = useState<boolean>(false);\r\n\r\n const {\r\n handleSubmit,\r\n register,\r\n setValue,\r\n clearErrors,\r\n unregister,\r\n formState: { errors },\r\n } = useForm<validationSchemaType>({\r\n resolver: zodResolver(validationSchema),\r\n mode: 'onSubmit',\r\n defaultValues: {\r\n securityNumber: securityNumber || \"\",\r\n coupon: \"\",\r\n },\r\n });\r\n\r\n const onSubmitDefault = async (values: validationSchemaType) => {\r\n if (!showCardIDField) {\r\n setValue(\"coupon\", undefined, { shouldValidate: false });\r\n }\r\n\r\n if (showCardIDField && values.coupon != undefined) {\r\n setCardID(values.coupon);\r\n }\r\n\r\n setLoading(true);\r\n\r\n try {\r\n if (targetProduct === null) {\r\n console.error(\"PBMLOG: Product is not defined!\");\r\n return;\r\n }\r\n\r\n if (!targetProduct.productId) {\r\n console.error(\"PBMLOG: Product ID is not defined!\");\r\n return\r\n }\r\n\r\n if (!targetProduct.listPrice) {\r\n console.error(\"PBMLOG: List Price is not defined!\");\r\n return\r\n }\r\n\r\n const response = await BenefitsWithDocument({\r\n document: values.securityNumber.replace(/\\D/g, ''),\r\n products: [{\r\n productId: targetProduct.productId,\r\n ean: targetProduct.ean,\r\n requestedQuantity: 1,\r\n listPrice: targetProduct.listPrice,\r\n netPrice: targetProduct.netPrice ?? targetProduct.listPrice\r\n }]\r\n });\r\n\r\n if (response.success) {\r\n const status: Record<\"acceptance\" | \"industry registration\" | \"active\", \"isRegistered\" | \"isActivated\" | \"isInvalid\" | \"isEmpty\"> = {\r\n \"acceptance\": \"isInvalid\",\r\n \"industry registration\": \"isRegistered\",\r\n \"active\": \"isActivated\"\r\n }\r\n\r\n setSecurityNumber(values.securityNumber);\r\n setState(status[response.data.product[0].statusCustomer]);\r\n\r\n if (status[response.data.product[0].statusCustomer] === \"isInvalid\") {\r\n setUrlAcceptTerms(response.data.product[0].urlAcceptTerm || undefined)\r\n return;\r\n }\r\n\r\n if (status[response.data.product[0].statusCustomer] === \"isRegistered\") {\r\n setUrlRegisterIndustry(response.data.product[0].informativeLink);\r\n return;\r\n }\r\n }\r\n } catch (error) {\r\n console.error(\"PBMLOG: Error validating document -\", error);\r\n } finally {\r\n setLoading(false);\r\n };\r\n };\r\n\r\n return (\r\n <>\r\n <form\r\n onSubmit={handleSubmit(onSubmitDefault)}\r\n className={classNames(\r\n \"w-full h-auto flex items-center justify-center mb-0 transition-all duration-150\",\r\n { \"mb-4\": errors.securityNumber || (errors.coupon && showCardIDField), \"gap-2\": showCardIDField }\r\n )}\r\n id=\"form_security_number_pbm\"\r\n >\r\n <label\r\n htmlFor=\"cpf\"\r\n className=\"w-4/5 h-auto flex items-start flex-col justify-center relative py-2\"\r\n id=\"label_security_number_pbm\"\r\n >\r\n <input\r\n type=\"text\"\r\n className={classNames(\r\n \"w-full h-10 bg-gray-100 rounded-s-lg text-sm font-semibold focus:outline focus:outline-[#339c9b] focus:bg-white text-zinc-600 placeholder:text-zinc-600 px-4 placeholder:text-sm placeholder:font-semibold\",\r\n { \"outline outline-red-600\": errors.securityNumber, \"rounded-lg\": showCardIDField }\r\n )}\r\n placeholder=\"Digite seu CPF aqui...\"\r\n required\r\n maxLength={14}\r\n {...register(\"securityNumber\", {\r\n onChange: (e) => {\r\n const formatted = toFormat(e.target.value);\r\n setValue(\"securityNumber\", formatted as string, {\r\n shouldValidate: true,\r\n });\r\n },\r\n })}\r\n defaultValue={securityNumber || \"\"}\r\n id=\"input_security_number_pbm\"\r\n />\r\n {errors.securityNumber && (\r\n <span className=\"text-red-400 text-xs font-semibold absolute -bottom-3 left-2 text-nowrap\" id=\"security_number_form_error\">\r\n {errors.securityNumber.message}\r\n </span>\r\n )}\r\n </label>\r\n {showCardIDField && (\r\n <label\r\n htmlFor=\"coupon\"\r\n className=\"w-4/5 h-auto flex items-start flex-col justify-center relative py-2\"\r\n id=\"label_coupon_pbm\"\r\n >\r\n <input\r\n type=\"text\"\r\n className={classNames(\r\n \"w-full h-10 bg-gray-100 rounded-s-lg text-sm font-semibold focus:outline focus:outline-[#339c9b] focus:bg-white text-zinc-600 placeholder:text-zinc-600 px-4 placeholder:text-sm placeholder:font-semibold\",\r\n { \"outline outline-red-600\": errors.coupon, \"rounded-lg\": showCardIDField }\r\n )}\r\n placeholder=\"Cupom / ID do Cartão\"\r\n {...register(\"coupon\", {\r\n required: showCardIDField ? 'Cupom / ID do Cartão obrigatório.' : false,\r\n shouldUnregister: !showCardIDField,\r\n onChange: (e) => {\r\n setValue(\"coupon\", e.target.value, {\r\n shouldValidate: showCardIDField,\r\n });\r\n },\r\n })}\r\n id=\"input_coupon_pbm\"\r\n />\r\n {errors.coupon && (\r\n <span className=\"text-red-400 text-xs font-semibold absolute -bottom-3 left-2 text-nowrap\" id=\"coupon_form_error\">\r\n {errors.coupon.message}\r\n </span>\r\n )}\r\n </label>\r\n )}\r\n <button\r\n type=\"submit\"\r\n className={classNames(\r\n \"bg-emerald-500 w-1/5 h-10 rounded-e-lg flex items-center justify-center cursor-pointer\",\r\n { \"rounded-lg\": showCardIDField }\r\n )}\r\n id=\"button_submit_security_number_pbm\"\r\n >\r\n <ArrowRight size={24} color=\"white\" strokeWidth={2} />\r\n </button>\r\n </form>\r\n <section className=\"flex items-center-safe justify-between\">\r\n <Button\r\n className=\"bg-transparent p-0 pl-2 w-auto h-auto text-zinc-600 underline cursor-pointer hover:text-zinc-900 hover:bg-transparent flex items-center justify-start gap-1\"\r\n onClick={() => {\r\n const newValue = !showCardIDField;\r\n setShowCardIDField(newValue);\r\n if (!newValue) {\r\n // Quando esconder o campo, desregistrar, limpar o valor e os erros\r\n unregister(\"coupon\");\r\n clearErrors(\"coupon\");\r\n }\r\n }}\r\n id=\"check_benefits_button\"\r\n >\r\n <span>{!showCardIDField ? \"Possui Cupom / ID do Cartão?\" : \"Não possui Cupom / ID do Cartão??\"}</span>\r\n <ArrowRight size={16} className={classNames({ \"rotate-0\": !showCardIDField, \"rotate-180\": showCardIDField })} />\r\n </Button>\r\n <Button\r\n className=\"bg-transparent p-0 pl-2 w-auto h-auto text-zinc-600 underline cursor-pointer hover:text-zinc-900 hover:bg-transparent flex items-center justify-start gap-1\"\r\n onClick={() => setState(\"isPreview\")}\r\n id=\"check_benefits_button\"\r\n >\r\n <span>Consultar Benefícios</span>\r\n <ArrowRight size={16} />\r\n </Button>\r\n </section>\r\n </>\r\n );\r\n}\r\n\r\nexport default Form;\r\n","import Cookies from \"js-cookie\";\r\nimport { IRequestDefault } from \"../types/requests\";\r\n\r\nexport interface IProductWithDocumentData {\r\n id: number;\r\n ean: number;\r\n authorizedQuantity: number;\r\n discountValue: string;\r\n discountPercentual: number;\r\n authorizer: string;\r\n industryName: string;\r\n requestCoupon: string;\r\n requestHolderId: string;\r\n comboId: number;\r\n grossPrice: number;\r\n allowsAdhesion: string;\r\n discountMaxNewPatient: number;\r\n informativeMessage: string;\r\n priceWithBenefit: number;\r\n urlAcceptTerm: string;\r\n informativeLink: string;\r\n productId: number;\r\n statusCustomer: \"acceptance\" | \"industry registration\" | \"active\";\r\n}\r\n\r\ninterface IResponseBenefitsWithDocument extends IRequestDefault {\r\n data: { product: IProductWithDocumentData[] };\r\n}\r\n\r\ninterface ProductRequestBody {\r\n productId: number;\r\n ean: string;\r\n requestedQuantity: number;\r\n listPrice: number;\r\n netPrice: number;\r\n}\r\n\r\ninterface IBenefitsWithDocumentParams {\r\n document: string;\r\n products: ProductRequestBody[];\r\n}\r\n\r\nexport const BenefitsWithDocument = async ({ document, products }: IBenefitsWithDocumentParams): Promise<IResponseBenefitsWithDocument> => {\r\n const API_URL = import.meta.env.VITE_API_URL;\r\n\r\n if (!API_URL) {\r\n throw new Error('API URL is not defined in environment variables');\r\n }\r\n\r\n const AUTH_TOKEN = Cookies.get(\"pbm-token\");\r\n\r\n if (!AUTH_TOKEN) {\r\n throw new Error('Token is not defined in cookies or is expired');\r\n }\r\n\r\n const response = await fetch(`${API_URL}/products/benefitByDocument`, {\r\n method: 'POST',\r\n headers: {\r\n Authorization: `Bearer ${AUTH_TOKEN}`,\r\n 'Content-Type': 'application/json',\r\n },\r\n body: JSON.stringify({ consumer: { document }, products })\r\n })\r\n\r\n const dataResponse: IResponseBenefitsWithDocument = await response.json();\r\n\r\n if (!dataResponse.success) {\r\n throw new Error(dataResponse.message || 'Failed to fetch document validation');\r\n }\r\n\r\n return dataResponse;\r\n}","import classNames from \"classnames\";\r\nimport React, { ButtonHTMLAttributes } from \"react\";\r\n\r\ninterface ButtonProps extends ButtonHTMLAttributes<HTMLButtonElement> {\r\n children: React.ReactNode;\r\n}\r\n\r\nfunction Button(props: ButtonProps) {\r\n return (\r\n <button\r\n {...props}\r\n className={classNames(\r\n \"w-3xs cursor-pointer h-10 rounded-lg bg-emerald-500 hover:bg-emerald-400 text-white text-sm font-semibold transition-colors\",\r\n props.className\r\n )}\r\n >\r\n {props.children}\r\n </button>\r\n );\r\n}\r\n\r\nexport default Button;\r\n","interface LoadingProps {\r\n textColor?: string;\r\n}\r\n\r\nfunction Loading({ textColor }: LoadingProps) {\r\n return (\r\n <main className=\"flex items-center justify-center gap-4\" id=\"loading_pbm\">\r\n <div\r\n data-testid=\"test_id_spin\"\r\n className=\"w-8 h-8 border-4 border-t-gray-700 border-gray-300 rounded-full animate-spin\"\r\n id=\"loading_spin\"\r\n ></div>\r\n <p\r\n className={\"text-sm font-semibold text-start text-zinc-900\"}\r\n style={{ color: textColor }}\r\n id=\"loading_label\"\r\n >\r\n Um momento... estamos verificando seus dados.\r\n </p>\r\n </main>\r\n );\r\n}\r\n\r\nexport default Loading;\r\n","import { useEffect, useState } from \"react\";\r\nimport Title from \"../UI/Title\";\r\nimport Item from \"./Item\";\r\nimport { usePBMStore } from \"../../libs/zustand/usePBM\";\r\nimport Button from \"../UI/Button\";\r\nimport { CheckBenefistWithoutDocument } from \"../../services/benefits-without-document\";\r\nimport { IBenefitsItem } from \"../../types/globals\";\r\nimport { BenefitsWithDocument } from \"../../services/benefits-with-document\";\r\n\r\nfunction BenefitsTable() {\r\n const { securityNumber, setState, state, targetProduct, customLoginUrl, isAuthenticatedShopper } = usePBMStore();\r\n const [selectedDiscout, setSelectedDiscount] = useState<string | null>(null);\r\n const [loading, setLoading] = useState<boolean>(true);\r\n const [benefitsItems, setBenefitsItems] = useState<IBenefitsItem[] | undefined>();\r\n\r\n useEffect(() => {\r\n const fetchDicountsWithoutDocument = async () => {\r\n if (!targetProduct?.productId) {\r\n console.error(\"PBMLOG: Product ID is not defined on targetProduct\");\r\n return;\r\n }\r\n\r\n if (!targetProduct.ean) {\r\n console.error(\"PBMLOG: EAN is not defined on targetProduct\");\r\n return;\r\n }\r\n\r\n if (!targetProduct.listPrice) {\r\n console.error(\"PBMLOG: List Price is not defined on targetProduct\");\r\n return;\r\n }\r\n\r\n if (!targetProduct.price) {\r\n console.error(\"PBMLOG: Price is not defined on targetProduct\");\r\n return;\r\n }\r\n\r\n try {\r\n const data = {\r\n productId: Number(targetProduct.productId),\r\n ean: targetProduct.ean,\r\n requestedQuantity: 1,\r\n listPrice: targetProduct.listPrice,\r\n netPrice: targetProduct.price\r\n }\r\n\r\n const response = await CheckBenefistWithoutDocument({ products: [data] });\r\n\r\n if (response.success && response.data) {\r\n setBenefitsItems(response.data)\r\n } else {\r\n setBenefitsItems(undefined)\r\n }\r\n } catch (error) {\r\n setBenefitsItems(undefined)\r\n console.error(error);\r\n } finally {\r\n setLoading(false);\r\n }\r\n }\r\n\r\n const fetchDiscountWithDocument = async () => {\r\n if (!securityNumber) {\r\n console.error(\"PBMLOG: Document is not defined\");\r\n return;\r\n }\r\n\r\n if (!targetProduct?.productId) {\r\n console.error(\"PBMLOG: Product ID is not defined on targetProduct\");\r\n return;\r\n }\r\n\r\n if (!targetProduct.ean) {\r\n console.error(\"PBMLOG: EAN is not defined on targetProduct\");\r\n return;\r\n }\r\n\r\n if (!targetProduct.listPrice) {\r\n console.error(\"PBMLOG: List Price is not defined on targetProduct\");\r\n return;\r\n }\r\n\r\n if (!targetProduct.price) {\r\n console.error(\"PBMLOG: Price is not defined on targetProduct\");\r\n return;\r\n }\r\n\r\n try {\r\n const data = {\r\n productId: Number(targetProduct.productId),\r\n ean: targetProduct.ean,\r\n requestedQuantity: 1,\r\n listPrice: targetProduct.listPrice,\r\n netPrice: targetProduct.price\r\n }\r\n\r\n const response = await BenefitsWithDocument({ document: securityNumber, products: [data] });\r\n\r\n if (response.success && response.data) {\r\n setBenefitsItems(response.data.product)\r\n } else {\r\n setBenefitsItems(undefined)\r\n }\r\n } catch (error) {\r\n setBenefitsItems(undefined)\r\n console.error(error);\r\n } finally {\r\n setLoading(false);\r\n }\r\n }\r\n\r\n state === \"isActivated\" ?\r\n fetchDiscountWithDocument() :\r\n fetchDicountsWithoutDocument();\r\n }, [])\r\n\r\n if (loading) {\r\n return (\r\n <main className=\"flex items-center justify-center gap-4\" id=\"loading_pbm\">\r\n <div\r\n data-testid=\"test_id_spin\"\r\n className=\"w-8 h-8 border-4 border-t-gray-700 border-gray-300 rounded-full animate-spin\"\r\n id=\"loading_spin\"\r\n ></div>\r\n <p\r\n className={\"text-sm font-semibold text-start text-zinc-900\"}\r\n id=\"loading_label\"\r\n >\r\n Buscando beneficios disponíveis...\r\n </p>\r\n </main>\r\n )\r\n }\r\n\r\n return (\r\n <section\r\n className=\"flex items-start justify-center gap-4 w-full h-auto flex-col\"\r\n id=\"benefits_table_pbm\"\r\n >\r\n <Title>Descontos disponíveis:</Title>\r\n\r\n <form\r\n className=\"flex flex-col items-center justify-start w-full gap-4.5\"\r\n id=\"form_benefits_table_pbm\"\r\n >\r\n {!benefitsItems && (\r\n <p className=\"text-sm font-semibold text-start text-zinc-900\" id=\"benefits_empty_pbm\">Não foi possível encontrar benefícios para esse produto.</p>\r\n )}\r\n\r\n {benefitsItems && benefitsItems.map((item, index) => {\r\n const ID_INPUT = \"unity_quantity_\" + item.authorizedQuantity;\r\n\r\n return (\r\n <Item\r\n key={index}\r\n data={item}\r\n checked={selectedDiscout === ID_INPUT}\r\n onChange={() => setSelectedDiscount(ID_INPUT)}\r\n />\r\n );\r\n })}\r\n </form>\r\n\r\n {state === \"isPreview\" && (\r\n <Button\r\n onClick={() => setState(\"isEmpty\")}\r\n className=\"bg-transparent p-0 w-auto h-auto text-zinc-600 cursor-pointer hover:text-zinc-900 hover:bg-transparent text-start\"\r\n id=\"unauthorized_benefits_button\"\r\n >\r\n Atenção: Não é possível utilizar os benefícos sem realizar a consulta\r\n do CPF e o Login, por favor{\" \"}\r\n <span className=\"underline\">\r\n insira seu cpf para utilizar os benefícios\r\n </span>\r\n </Button>\r\n )}\r\n\r\n {state === \"isActivated\" && (\r\n <>\r\n {!isAuthenticatedShopper && <Button\r\n onClick={() => window.location.href = customLoginUrl || \"/login\"}\r\n className=\"bg-transparent p-0 pl-2 w-auto h-auto text-zinc-600 cursor-pointer hover:text-zinc-900 hover:bg-transparent text-start\"\r\n id=\"login\"\r\n >\r\n <span className=\"underline\">Por favor, faça o Login para aproveitar os benefícios!</span>\r\n </Button>}\r\n\r\n <Button\r\n onClick={() => setState(\"isEmpty\")}\r\n className=\"bg-transparent p-0 pl-2 w-auto h-auto text-zinc-600 cursor-pointer hover:text-zinc-900 hover:bg-transparent text-start\"\r\n id=\"change_security_number\"\r\n >\r\n <span className=\"underline\">Deseja editar o cpf digitado?</span>\r\n </Button>\r\n </>\r\n )}\r\n </section>\r\n );\r\n}\r\n\r\nexport default BenefitsTable;\r\n","import classNames from \"classnames\";\r\nimport React, { HTMLAttributes } from \"react\";\r\n\r\ninterface TitleProps extends HTMLAttributes<HTMLTitleElement> {\r\n children: React.ReactNode;\r\n textColor?: string;\r\n textSize?: string;\r\n textAlign?: \"start\" | \"center\" | \"end\";\r\n}\r\n\r\nfunction Title(props: TitleProps) {\r\n return (\r\n <h2\r\n className={classNames(\r\n \"text-start font-semibold text-sm text-zinc-900\",\r\n props.className\r\n )}\r\n style={{ color: props.textColor, fontSize: props.textSize, textAlign: props.textAlign }}\r\n data-testid=\"test_id_title\"\r\n id=\"title_pbm\"\r\n >\r\n {props.children}\r\n </h2>\r\n );\r\n}\r\n\r\nexport default Title;\r\n","import { create, StateCreator } from \"zustand\";\r\nimport { IModal } from \"../../types/globals\";\r\n\r\ninterface ModalDataType {\r\n modal: IModal;\r\n}\r\n\r\nexport interface useModal extends ModalDataType {\r\n setModal: (\r\n modal: useModal[\"modal\"]\r\n ) => void;\r\n}\r\n\r\nconst initialModalState: ModalDataType = {\r\n modal: {\r\n id: \"\",\r\n open: false\r\n },\r\n};\r\n\r\n// ✅ TIPANDO a função corretamente com StateCreator\r\nconst createModalStore: StateCreator<useModal> = (set) => ({\r\n ...initialModalState,\r\n\r\n setModal: (\r\n modal: useModal[\"modal\"]\r\n ) => set({ modal }),\r\n});\r\n\r\n// React hook (usado dentro de componentes React)\r\nexport const useModal = create<useModal>(createModalStore);\r\n","import { usePBMStore } from \"../../libs/zustand/usePBM\";\r\nimport { useModal } from \"../../libs/zustand/useModal\";\r\n\r\nimport { useCallback, useEffect, useState } from \"react\";\r\nimport { IBenefitsItem } from \"../../types/globals\";\r\nimport classNames from \"classnames\";\r\nimport { Icons } from \"../UI/Icons\";\r\n\r\ninterface ItemProps {\r\n data: IBenefitsItem;\r\n onChange: VoidFunction;\r\n checked: boolean;\r\n}\r\n\r\nfunction Item({ data, onChange, checked }: ItemProps) {\r\n const { setAvailableDiscountSelected, state, isAuthenticatedShopper } = usePBMStore();\r\n const { setModal } = useModal();\r\n\r\n const [openModalAlert, setOpenModalAlert] = useState<boolean>(false);\r\n\r\n const ID_INPUT = \"unity_quantity_\" + data.authorizedQuantity;\r\n\r\n const decimalDiscount = data.discountPercentual / 100;\r\n\r\n const unitDiscountValue = data.grossPrice * decimalDiscount;\r\n\r\n\r\n const discountValue = unitDiscountValue * data.authorizedQuantity;\r\n\r\n const totalPriceProductWithDiscountBenefit =\r\n (data.grossPrice * data.authorizedQuantity) - discountValue;\r\n\r\n const updateStorageData = useCallback(() => {\r\n if (checked) {\r\n // Arredonda para 2 casas decimais\r\n const roundToTwoDecimals = (value: number) => Math.round(value * 100) / 100;\r\n\r\n setAvailableDiscountSelected({\r\n discount: {\r\n total: roundToTwoDecimals(discountValue),\r\n unit: roundToTwoDecimals(unitDiscountValue),\r\n },\r\n quantity: data.authorizedQuantity,\r\n totalPrice: roundToTwoDecimals(totalPriceProductWithDiscountBenefit),\r\n grossPrice: data.grossPrice\r\n });\r\n }\r\n }, [\r\n checked,\r\n data.authorizedQuantity,\r\n setAvailableDiscountSelected,\r\n discountValue,\r\n totalPriceProductWithDiscountBenefit,\r\n unitDiscountValue,\r\n ]);\r\n\r\n useEffect(() => {\r\n updateStorageData();\r\n }, [updateStorageData]);\r\n\r\n const CheckUserIsAuthenticated = () => {\r\n if (isAuthenticatedShopper) return;\r\n\r\n setModal({\r\n id: \"ShopperIsNotAuthenticated\",\r\n open: true\r\n });\r\n }\r\n\r\n return (\r\n <label\r\n htmlFor={ID_INPUT}\r\n className={classNames(\r\n \"label_benefits w-full flex items-center justify-start bg-zinc-300/60 border border-zinc-400/50 px-4 py-2 hover:bg-zinc-300 transition-colors rounded-lg gap-1\",\r\n { \"cursor-not-allowed\": state === \"isPreview\", \"cursor-pointer\": state === \"isActivated\" }\r\n )}\r\n id={\"label_benefits_\" + ID_INPUT}\r\n onClick={CheckUserIsAuthenticated}\r\n >\r\n <input\r\n type=\"radio\"\r\n name=\"benefits_discount\"\r\n id={ID_INPUT}\r\n className=\"hidden\"\r\n checked={checked}\r\n onChange={onChange}\r\n disabled={state === \"isPreview\"}\r\n />\r\n\r\n {!checked ? (\r\n <Icons.CheckOFF size={20} />\r\n ) : (\r\n <Icons.CheckON size={20} />\r\n )}\r\n\r\n <span className=\"text-zinc-900 font-semibold text-sm\">\r\n {data.authorizedQuantity}un\r\n </span>\r\n\r\n <section className=\"ml-auto relative gap-2 flex items-center-safe justify-end-safe\">\r\n <span className=\"text-white -top-4 py-0.5 font-semibold text-xs bg-[#32b316] px-2 w-auto text-nowrap rounded-2xl -right-3\">\r\n {discountValue.toLocaleString(\"pt-BR\", {\r\n currency: \"BRL\",\r\n currencyDisplay: \"symbol\",\r\n currencySign: \"standard\",\r\n style: \"currency\",\r\n })}{\" \"}\r\n OFF\r\n </span>\r\n <strong className=\"text-zinc-900 font-semibold text-sm text-center\">\r\n {totalPriceProductWithDiscountBenefit.toLocaleString(\"pt-BR\", {\r\n currency: \"BRL\",\r\n currencyDisplay: \"symbol\",\r\n currencySign: \"standard\",\r\n style: \"currency\",\r\n })}\r\n </strong>\r\n </section>\r\n </label>\r\n );\r\n}\r\n\r\nexport default Item;\r\n","import * as React from \"react\"\r\n\r\nfunction CheckON({ size }: { size: number }) {\r\n return (\r\n <svg\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n data-name=\"Camada 1\"\r\n viewBox=\"0 0 500 500\"\r\n width={size}\r\n height={size}\r\n >\r\n <path\r\n d=\"M421.44 78.56C375.64 32.77 314.76 7.55 250 7.55S124.36 32.77 78.56 78.56C32.77 124.36 7.55 185.24 7.55 250s25.22 125.64 71.01 171.44c45.8 45.79 106.68 71.01 171.44 71.01s125.64-25.22 171.44-71.01c45.79-45.8 71.01-106.68 71.01-171.44s-25.22-125.64-71.01-171.44zm-49.17 121.7L242.88 334.63c-8.98 9.29-23.57 10.17-33.59 2.02l-79.63-64.7c-10.69-8.67-12.33-24.38-3.66-35.07 8.67-10.69 24.38-12.33 35.07-3.65l61.9 50.39L336.5 165.74c4.4-4.75 10.48-7.59 16.95-7.93a24.88 24.88 0 0118.83 7.26c9.72 9.72 9.71 25.48 0 35.19z\"\r\n fill=\"#229b00\"\r\n />\r\n </svg>\r\n )\r\n}\r\nfunction CheckOFF({ size }: { size: number }) {\r\n return (\r\n <svg\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n data-name=\"Camada 1\"\r\n viewBox=\"0 0 500 500\"\r\n width={size}\r\n height={size}\r\n >\r\n <circle cx={250} cy={250} r={237.45} fill=\"#fff\" />\r\n <path\r\n d=\"M250 492.45c-64.76 0-125.64-25.22-171.44-71.01C32.77 375.64 7.55 314.76 7.55 250S32.77 124.36 78.56 78.56C124.36 32.77 185.24 7.55 250 7.55s125.64 25.22 171.44 71.01c45.79 45.79 71.01 106.68 71.01 171.44s-25.22 125.64-71.01 171.44c-45.79 45.79-106.68 71.01-171.44 71.01zm0-474.9C121.83 17.55 17.55 121.83 17.55 250S121.83 482.45 250 482.45 482.45 378.17 482.45 250 378.17 17.55 250 17.55z\"\r\n fill=\"#d8d8d8\"\r\n />\r\n </svg>\r\n )\r\n}\r\n\r\nexport const Icons = {\r\n CheckON,\r\n CheckOFF\r\n}","import Cookies from \"js-cookie\";\r\nimport { IRequestDefault } from \"../types/requests\";\r\n\r\ninterface ICheckBenefitsWithoutDocumentData {\r\n id: number;\r\n ean: number;\r\n authorizedQuantity: number;\r\n discountValue: string;\r\n discountPercentual: number;\r\n authorizer: string;\r\n industryName: string;\r\n requestCoupon: string;\r\n requestHolderId: string;\r\n comboId: number;\r\n grossPrice: number;\r\n allowsAdhesion: string;\r\n discountMaxNewPatient: number;\r\n informativeMessage: string;\r\n priceWithBenefit: number;\r\n}\r\n\r\ninterface ICheckBenefitsWithoutDocumentResponse extends IRequestDefault {\r\n data: ICheckBenefitsWithoutDocumentData[];\r\n}\r\n\r\ninterface IProductsCheckBenefits {\r\n productId: number;\r\n ean: string;\r\n requestedQuantity: number;\r\n listPrice: number;\r\n}\r\n\r\ninterface ICheckBenefistWithoutDocumentParams {\r\n products: IProductsCheckBenefits[];\r\n}\r\n\r\nexport const CheckBenefistWithoutDocument = async ({ products }: ICheckBenefistWithoutDocumentParams): Promise<ICheckBenefitsWithoutDocumentResponse> => {\r\n const API_URL = import.meta.env.VITE_API_URL;\r\n\r\n if (!API_URL) {\r\n throw new Error('API URL is not defined in environment variables');\r\n }\r\n\r\n const AUTH_TOKEN = Cookies.get(\"pbm-token\");\r\n\r\n if (!AUTH_TOKEN) {\r\n throw new Error('Token is not defined in cookies or is expired');\r\n }\r\n\r\n const response = await fetch(`${API_URL}/products/genericBenefit`, {\r\n method: 'POST',\r\n headers: {\r\n Authorization: `Bearer ${AUTH_TOKEN}`,\r\n 'Content-Type': 'application/json',\r\n },\r\n body: JSON.stringify({ products })\r\n })\r\n\r\n const dataResponse: ICheckBenefitsWithoutDocumentResponse = await response.json();\r\n\r\n if (!dataResponse.success) {\r\n throw new Error(dataResponse.message || 'Failed to fetch benefits without document');\r\n }\r\n\r\n return dataResponse;\r\n}","import classNames from \"classnames\";\r\nimport React, { HTMLAttributes } from \"react\";\r\n\r\ninterface TextProps extends HTMLAttributes<HTMLParagraphElement> {\r\n children: React.ReactNode;\r\n textColor?: string;\r\n textSize?: string;\r\n textAlign?: \"start\" | \"center\" | \"end\";\r\n}\r\n\r\nfunction Text(props: TextProps) {\r\n return (\r\n <p\r\n className={classNames(\r\n \"font-normal text-sm text-zinc-900\",\r\n props.textAlign && `text-${props.textAlign}`,\r\n props.className\r\n )}\r\n style={{ color: props.textColor, fontSize: props.textSize, textAlign: props.textAlign }}\r\n data-testid=\"test_id_text\"\r\n id=\"text_pbm\"\r\n >\r\n {props.children}\r\n </p>\r\n );\r\n}\r\n\r\nexport default Text;\r\n","import { ILinkHref } from \"../../../types/globals\";\r\nimport classNames from \"classnames\";\r\nimport React from \"react\";\r\nimport { getParams } from \"../../../utils/getParams\";\r\nimport { usePBMStore } from \"../../../libs/zustand/usePBM\";\r\n\r\ninterface LinkProps {\r\n className?: string;\r\n children: React.ReactNode;\r\n href: ILinkHref | string;\r\n}\r\n\r\nfunction Link(props: LinkProps) {\r\n const { setState } = usePBMStore();\r\n\r\n return (\r\n <a\r\n {...props}\r\n target=\"_blank\"\r\n href={\r\n typeof props.href === \"string\"\r\n ? props.href\r\n : props.href.pathname + getParams(props.href.param)\r\n }\r\n className={classNames(\r\n \"w-3xs cursor-pointer h-10 rounded-lg bg-emerald-500 hover:bg-emerald-400 text-white text-sm font-semibold transition-colors flex items-center justify-center\",\r\n props.className\r\n )}\r\n data-testid=\"test_id_link\"\r\n id=\"link_pbm\"\r\n onClick={() => setState(\"isEmpty\")}\r\n >\r\n {props.children}\r\n </a>\r\n );\r\n}\r\n\r\nexport default Link;\r\n","export const getParams = (\r\n params: { [key: string]: string | number } | undefined\r\n) => {\r\n if (params === undefined) return \"\";\r\n\r\n return (\r\n \"?\" +\r\n Object.keys(params)\r\n .map((paramter) => paramter + \"=\" + params[paramter])\r\n .join(\"&\")\r\n );\r\n};","import Title from \"../UI/Title\";\r\nimport Text from \"../UI/Text\";\r\n// import Button from \"../UI/Button\";\r\n// import Iframe from \"../Iframe\";\r\n\r\n// import { useState } from \"react\";\r\nimport { usePBMStore } from \"../../libs/zustand/usePBM\";\r\nimport Link from \"../UI/Link\";\r\n\r\nfunction SecurityNumberInvalid({ textColor }: { textColor?: string }) {\r\n // const [openModal, setOpenModal] = useState<boolean>(false);\r\n const { urlAcceptTerms } = usePBMStore();\r\n return (\r\n <section\r\n data-testid=\"test_id_invalid\"\r\n className=\"flex items-end justify-center gap-2 w-full h-auto flex-col border-y border-zinc-300 py-6\"\r\n id=\"security_number_invalid_container_pbm\"\r\n >\r\n <Title className=\"w-full\" textColor={textColor}>\r\n CPF não cadastrado.\r\n </Title>\r\n <Text className=\"w-full\" textColor={textColor}>\r\n Conclua seu cadastro para habilitar o benefício. <br />\r\n Ao clicar em “Aceitar os termos”, você irá para uma página externa. Aceite os termos e volte para continuar.\r\n </Text>\r\n {/* <Button\r\n data-testid=\"test_id_openiframe\"\r\n onClick={() => setOpenModal(true)}\r\n id=\"button_accept_terms_pbm\"\r\n >\r\n Aceitar os termos\r\n </Button> */}\r\n\r\n <Link\r\n href={urlAcceptTerms || \"\"}\r\n >\r\n Aceitar os termos\r\n </Link>\r\n\r\n {/* <Iframe\r\n url={urlAcceptTerms || \"\"}\r\n title=\"Aceitar termos PBM\"\r\n openModal={openModal}\r\n setOpenModal={setOpenModal}\r\n /> */}\r\n </section>\r\n );\r\n}\r\n\r\nexport default SecurityNumberInvalid;\r\n","import Header from \"./components/Header\";\nimport Container from \"./components/UI/Container\";\nimport Footer from \"./components/Footer\";\nimport Form from \"./components/Form\";\nimport Loading from \"./components/UI/Loading\";\nimport Button from \"./components/UI/Button\";\nimport BenefitsTable from \"./components/BenefitsTable\";\nimport SecurityNumberInvalid from \"./components/SecurityNumberInvalid\";\n\nimport { ReactElement, useCallback, useEffect, useState } from \"react\";\nimport SecurityNumberRegitered from \"./components/SecurityNumberRegitered\";\nimport { GetAuthorization } from \"./services/authorization\";\nimport { ArrowRight, RefreshCw } from \"lucide-react\";\nimport { usePBMStore } from \"./libs/zustand/usePBM\";\nimport { GetProductByEAN } from \"./services/get-product-by-ean\";\nimport Title from \"./components/UI/Title\";\nimport Text from \"./components/UI/Text\";\nimport Skeleton from '@mui/material/Skeleton';\nimport Modal from \"./components/Modal\";\nimport { StateComponentType } from \"./types/globals\";\nimport { useValidateProduct } from \"./hooks/useValidateProduct\";\n\nexport interface PBMProps {\n originalProductPrice: number | string;\n clientID: string;\n eanProduct: string;\n isAuthenticatedShopper: boolean;\n customLoginUrl?: string;\n}\n\nfunction PBM({\n originalProductPrice,\n clientID,\n eanProduct,\n isAuthenticatedShopper,\n customLoginUrl,\n}: PBMProps) {\n const formatedOriginalProductPrice = Number(\n String(originalProductPrice).replace(',', '.')\n );\n\n const [isReady, setIsReady] = useState<boolean>(false);\n const [loading, setLoading] = useState<boolean>(false);\n const { state, setTargetProduct, targetProduct, setIsAuthenticatedShopper, setCustomLoginUrl } = usePBMStore();\n const [EanProductExist, setEanProductExist] = useState<boolean>(true);\n\n const { IsValid } = useValidateProduct({ eanProduct: eanProduct });\n\n const fetchProductByEan = async () => {\n try {\n if (!eanProduct) {\n console.error(\"PBMLOG: Ean is not defined.\")\n setEanProductExist(false);\n return\n }\n\n const response = await GetProductByEAN({ PRODUCT_EAN: eanProduct });\n\n if (response.success && response.data) {\n setEanProductExist(true);\n\n const { pbm, sku, ...targetProductNewData } = response.data;\n\n setTargetProduct({\n ...targetProduct,\n ...targetProductNewData,\n productId: Number(targetProductNewData.productId),\n informativeMessage: pbm.informativeMessage ?? \"\",\n discountMax: pbm.discountMax ?? 0,\n industryLogo: pbm.imageLink ?? undefined,\n ean: eanProduct\n })\n\n setIsAuthenticatedShopper(isAuthenticatedShopper);\n setCustomLoginUrl(customLoginUrl)\n }\n } catch (error) {\n console.error(error);\n } finally {\n setIsReady(true)\n }\n }\n\n const handleAuthorizationRequest = useCallback(async () => {\n try {\n const response = await GetAuthorization({ clientID: clientID });\n\n if (response.success && IsValid) {\n fetchProductByEan();\n } else {\n console.error(\"PBMLOG: Authorization failed!\");\n }\n } catch (error) {\n console.error(\"Error fetching authorization:\", error);\n }\n }, [clientID, IsValid]);\n\n useEffect(() => {\n handleAuthorizationRequest();\n }, [handleAuthorizationRequest]);\n\n if (!isReady) {\n return (\n <Skeleton variant=\"rectangular\" style={{ borderRadius: \"12px\" }} width={460} height={358} />\n )\n }\n\n if (!EanProductExist) {\n return (\n <div id=\"pbm-library-root\">\n <Container variant=\"main\" >\n <Title>Erro ao Aplicar o Benefício</Title>\n <Text textAlign=\"center\">O produto não foi encontrado no sistema. <br /> Por favor, tente novamente mais tarde ou contate o suporte.</Text>\n <Button\n className=\"bg-transparent p-0 pl-2 w-auto h-auto text-zinc-600 underline cursor-pointer hover:text-zinc-900 hover:bg-transparent flex items-center justify-start gap-1\"\n onClick={() => window.location.reload()}\n id=\"check_benefits_button\"\n >\n <span>Tentar novamente</span>\n <RefreshCw size={16} />\n </Button>\n </Container>\n </div>\n )\n }\n\n if (!IsValid) {\n return;\n }\n\n const RenderStateComponent = () => {\n const StateMap: Record<StateComponentType, ReactElement> = {\n \"isEmpty\": <Form setLoading={setLoading} />,\n \"isInvalid\": <SecurityNumberInvalid />,\n \"isRegistered\": <SecurityNumberRegitered />,\n \"isActivated\": <BenefitsTable />,\n \"isPreview\": <BenefitsTable />\n }\n\n if (!loading) return StateMap[state];\n else return <Loading />\n }\n\n return (\n <div id=\"pbm-library-root\">\n <Container variant=\"main\">\n <Header originalProductPrice={formatedOriginalProductPrice || 0} />\n\n <Container variant=\"simple\">\n <RenderStateComponent />\n </Container>\n\n <Footer />\n </Container>\n\n <Modal ID=\"ShopperIsNotAuthenticated\" />\n </div>\n );\n}\n\nexport default PBM;\n","import Title from \"../UI/Title\";\r\nimport Text from \"../UI/Text\";\r\nimport Link from \"../UI/Link\";\r\nimport { usePBMStore } from \"../../libs/zustand/usePBM\";\r\n\r\nfunction SecurityNumberRegitered({ textColor }: { textColor?: string }) {\r\n const { urlRegisterIndustry } = usePBMStore();\r\n\r\n return (\r\n <section\r\n data-testid=\"test_id_registered\"\r\n className=\"flex items-end justify-center gap-2 w-full h-auto flex-col border-y border-zinc-300 py-6\"\r\n id=\"security_number_registered_container_pbm\"\r\n >\r\n <Title className=\"w-full\" textColor={textColor}>\r\n Ops, seu CPF ainda não está habilitado para este produto.\r\n </Title>\r\n <Text className=\"w-full\" textColor={textColor}>\r\n Para ativar o benefício, clique em “Ativar CPF” e conclua a etapa na página externa. Depois, é só voltar para continuar — vamos aguardar você aqui.\r\n </Text>\r\n <Link\r\n href={urlRegisterIndustry || \"\"}\r\n >\r\n Ativar CPF\r\n </Link>\r\n </section>\r\n );\r\n}\r\n\r\nexport default SecurityNumberRegitered;\r\n","import Cookies from \"js-cookie\";\r\n\r\nexport const GetAuthorization = async ({ clientID }: { clientID: string }) => {\r\n const response = await fetch(\r\n 'https://pbm-auth-serverless.vercel.app/api/auth',\r\n {\r\n method: 'POST',\r\n headers: {\r\n 'Content-Type': 'application/json'\r\n },\r\n credentials: 'include',\r\n body: JSON.stringify({\r\n clientId: clientID\r\n })\r\n }\r\n );\r\n\r\n const data = await response.json();\r\n\r\n if (!data.success) {\r\n throw new Error('Authorization failed');\r\n }\r\n\r\n Cookies.set('pbm-token', data.tokens.token, {\r\n secure: true,\r\n sameSite: 'Strict'\r\n });\r\n\r\n Cookies.set('pbm-token-refresh', data.tokens.refreshToken, {\r\n secure: true,\r\n sameSite: 'Strict'\r\n });\r\n\r\n return data;\r\n};","import Cookies from \"js-cookie\";\r\nimport { IRequestDefault } from \"../types/requests\";\r\n\r\ninterface IPBM {\r\n source: string;\r\n programName: string;\r\n industryName: string;\r\n discountMax: number;\r\n discountMin: number;\r\n informativeMessage: string;\r\n discountMaxNewPatient: number;\r\n discountMinNewPatient: number;\r\n discountFirstBox: number;\r\n suggestedPriceValue: string;\r\n imageLink: string | null;\r\n eanCombos: number | null;\r\n qtyDiscountMax: number;\r\n requestCoupon: string | null;\r\n}\r\n\r\nexport interface IDataRequestListProducts {\r\n productId: string;\r\n productName: string;\r\n sku: string;\r\n skuId: string;\r\n ean: string;\r\n price: number;\r\n listPrice: number;\r\n stockBalance: number;\r\n availabilityText: string;\r\n brandName: string;\r\n categoryName: string;\r\n pbm: IPBM;\r\n}\r\n\r\ninterface IResponseGetProducts extends IRequestDefault {\r\n data: IDataRequestListProducts\r\n}\r\n\r\nexport const GetProductByEAN = async ({ PRODUCT_EAN }: { PRODUCT_EAN: string }): Promise<IResponseGetProducts> => {\r\n const API_URL = import.meta.env.VITE_API_URL;\r\n\r\n const AUTH_TOKEN = Cookies.get(\"pbm-token\");\r\n\r\n if (!AUTH_TOKEN) {\r\n throw new Error('Token is not defined in cookies or is expired');\r\n }\r\n\r\n const response = await fetch(`${API_URL}/products/ean/${PRODUCT_EAN}`, {\r\n method: 'GET',\r\n headers: {\r\n Authorization: `Bearer ${AUTH_TOKEN}`,\r\n 'Content-Type': 'application/json',\r\n },\r\n });\r\n\r\n const dataResponse: IResponseGetProducts = await response.json();\r\n\r\n if (!dataResponse.success) {\r\n throw new Error(dataResponse.message || 'Failed to fetch authorization');\r\n }\r\n\r\n return dataResponse;\r\n}","import Title from '../UI/Title'\r\nimport Text from '../UI/Text'\r\nimport Button from '../UI/Button'\r\nimport Link from '../UI/Link'\r\nimport { usePBMStore } from '../../libs/zustand/usePBM'\r\nimport { useModal } from '../../libs/zustand/useModal'\r\nimport classNames from 'classnames'\r\n\r\nconst Modal = ({ ID }: { ID: string }) => {\r\n const { customLoginUrl } = usePBMStore();\r\n const { modal, setModal } = useModal();\r\n\r\n return (\r\n <main className={classNames(\r\n \"fixed inset-0 flex items-center justify-center z-50 flex-col transition-all shadow bg-black/40\",\r\n {\r\n \"opacity-100 pointer-events-auto\": modal.id === ID && modal.open,\r\n \"opacity-0 pointer-events-none\": modal.id != ID || !modal.open,\r\n }\r\n )}>\r\n <div className='absolute inset-0' onClick={() => setModal({ id: \"\", open: false })}></div>\r\n <section className='z-10 bg-white gap-2 flex-col items-center-safe justify-center-safe p-8 rounded-xl'>\r\n <Title textColor='tomato' textSize='18px' textAlign='center' className='mb-2'>Opa! Parece que você não está Logado</Title>\r\n <Text className='mb-2' textAlign='center'>Para aproveitar os benefícios é necessário realizar o <strong>Login</strong> ou <strong>Cadastro</strong> no site!</Text>\r\n <section className='flex items-center-safe justify-center-safe gap-4'>\r\n <Button className='bg-gray-600 hover:bg-gray-500' onClick={() => setModal({ id: \"\", open: false })}>Seguir sem Benefícios</Button>\r\n <Link href={customLoginUrl || \"/login\"}>Aproveitar Benefícios</Link>\r\n </section>\r\n </section>\r\n </main>\r\n )\r\n}\r\n\r\nexport default Modal;","import { useCallback, useEffect, useState } from \"react\";\r\nimport { GetProductsWithBenefits } from \"../services/get-list-products\";\r\n\r\ntype useValidateProductType = {\r\n eanProduct: string;\r\n}\r\n\r\nexport function useValidateProduct({ eanProduct }: useValidateProductType) {\r\n const [IsValid, setIsValid] = useState<boolean>(false);\r\n const [Loading, setLoading] = useState<boolean>(true);\r\n const [Error, setError] = useState<unknown>()\r\n\r\n const fetchValidateProduct = useCallback(async () => {\r\n try {\r\n const response = await GetProductsWithBenefits();\r\n\r\n if (response.success) {\r\n const data = response.data;\r\n\r\n const hasProductInList = data.some(product => product.ean == eanProduct);\r\n setIsValid(hasProductInList);\r\n }\r\n } catch (error) {\r\n setError(error);\r\n console.error(error);\r\n } finally {\r\n\r\n }\r\n }, [])\r\n\r\n useEffect(() => {\r\n fetchValidateProduct();\r\n }, [fetchValidateProduct]);\r\n\r\n return { IsValid, Loading, Error }\r\n}","import Cookies from \"js-cookie\";\r\nimport { IRequestDefault } from \"../types/requests\";\r\nimport { IProduct, IProductInList } from \"../types/globals\";\r\n\r\ninterface IPagination {\r\n page: number,\r\n limit: number,\r\n total: number,\r\n totalPages: number,\r\n hasNextPage: boolean,\r\n hasPrevPage: boolean\r\n}\r\n\r\ninterface IMessageData {\r\n products: IProduct[],\r\n pagination: IPagination\r\n}\r\n\r\ninterface IResponseGetProducts extends IRequestDefault {\r\n data: IProductInList[]\r\n}\r\n\r\nexport const GetProductsWithBenefits = async (): Promise<IResponseGetProducts> => {\r\n const API_URL = import.meta.env.VITE_API_URL;\r\n\r\n const AUTH_TOKEN = Cookies.get(\"pbm-token\");\r\n\r\n if (!AUTH_TOKEN) {\r\n throw new Error('Token is not defined in cookies or is expired');\r\n }\r\n\r\n const response = await fetch(`${API_URL}/products/list`, {\r\n method: 'GET',\r\n headers: {\r\n Authorization: `Bearer ${AUTH_TOKEN}`,\r\n 'Content-Type': 'application/json',\r\n },\r\n });\r\n\r\n const dataResponse: IResponseGetProducts = await response.json();\r\n\r\n if (!dataResponse.success) {\r\n throw new Error(dataResponse.message || 'Failed to fetch authorization');\r\n }\r\n\r\n return dataResponse;\r\n}"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,qBAAoD;AACpD,mBAAyB;AA2BzB,IAAM,kBAA+B;AAAA,EACnC,gBAAgB;AAAA,EAChB,QAAQ;AAAA,EACR,OAAO;AAAA,EACP,2BAA2B;AAAA,IACzB,UAAU;AAAA,IACV,UAAU;AAAA,MACR,MAAM;AAAA,MACN,OAAO;AAAA,IACT;AAAA,IACA,YAAY;AAAA,IACZ,YAAY;AAAA,EACd;AAAA,EACA,eAAe;AAAA,EACf,UAAU;AAAA,EACV,wBAAwB;AAAA,EACxB,gBAAgB;AAClB;AAEA,IAAM,iBAAyC,CAAC,SAAS;AAAA,EACvD,GAAG;AAAA,EAEH,mBAAmB,CAAC,mBAA2B,IAAI,EAAE,eAAe,CAAC;AAAA,EACrE,UAAU,CAAC,UAAgC,IAAI,EAAE,MAAM,CAAC;AAAA,EACxD,kBAAkB,CAAC,kBACjB,IAAI,EAAE,cAAc,CAAC;AAAA,EACvB,8BAA8B,CAC5B,sBACG,IAAI,EAAE,2BAA2B,kBAAkB,CAAC;AAAA,EACzD,mBAAmB,CAAC,mBAClB,IAAI,EAAE,eAA+B,CAAC;AAAA,EACxC,wBAAwB,CAAC,wBACvB,IAAI,EAAE,oBAAyC,CAAC;AAAA,EAClD,2BAA2B,CAAC,2BAC1B,IAAI,EAAE,uBAA+C,CAAC;AAAA,EACxD,mBAAmB,CAAC,mBAAkD,IAAI,EAAE,eAA+B,CAAC;AAAA,EAC5G,WAAW,CAAC,WAAkC,IAAI,EAAE,OAAe,CAAC;AACtE;AAGO,IAAM,eAA+B,4BAAsB,cAAc;AA+BzE,SAAS,YAAe,UAAiD;AAC9E,MAAI,UAAU;AACZ,eAAO,uBAAS,UAAU,QAAQ;AAAA,EACpC;AACA,aAAO,uBAAS,UAAU,CAAC,UAAU,KAAK;AAC5C;;;AChGI;AANJ,SAAS,OAAO,EAAE,qBAAqB,GAAqC;AAC1E,QAAM,EAAE,cAAc,IAAI,YAAY;AACtC,QAAM,QAAS,eAAe,aAAa;AAC3C,QAAM,WAAW,UAAU,eAAe,eAAe,KAAK;AAE9D,SACE,4EACI;AAAA,mBAAe,sBAAuB,4CAAC,UAAK,WAAU,0GAA0G,yBAAe,oBAAmB;AAAA,IACpM;AAAA,MAAC;AAAA;AAAA,QACC,WAAU;AAAA,QACV,IAAG;AAAA,QAEH;AAAA;AAAA,YAAC;AAAA;AAAA,cACC,WAAU;AAAA,cACV,eAAY;AAAA,cACZ,IAAG;AAAA,cAEH,uDAAC,aAAQ,WAAU,+CACjB;AAAA,4DAAC,UAAK,WAAU,mCACb,iBAAO,KAAK,GAAG,eAAe,SAAS;AAAA,kBACtC,UAAU;AAAA,kBACV,iBAAiB;AAAA,kBACjB,cAAc;AAAA,kBACd,OAAO;AAAA,gBACT,CAAC,GACH;AAAA,gBACC,OAAO,QAAQ,QAAQ,GAAG,eAAe,SAAS;AAAA,kBACjD,UAAU;AAAA,kBACV,iBAAiB;AAAA,kBACjB,cAAc;AAAA,kBACd,OAAO;AAAA,gBACT,CAAC;AAAA,iBACH;AAAA;AAAA,UACF;AAAA,UACA,4CAAC,QAAG,IAAG,gBAAe,WAAU,uEAAsE,wCAEtG;AAAA;AAAA;AAAA,IACF;AAAA,KACF;AAEJ;AAEA,IAAO,iBAAQ;;;AC5Cf,wBAAuB;AAWnB,IAAAA,sBAAA;AARJ,SAAS,UAAU;AAAA,EACjB;AAAA,EACA;AACF,GAGG;AACD,SACE;AAAA,IAAC;AAAA;AAAA,MACC,eAAW,kBAAAC,SAAW;AAAA,QACpB,sLACE,YAAY;AAAA,QACd,0BAA0B,YAAY;AAAA,MACxC,CAAC;AAAA,MACD,eAAY;AAAA,MACZ,gBAAc;AAAA,MACd,IAAG;AAAA,MAEF;AAAA;AAAA,EACH;AAEJ;AAEA,IAAO,oBAAQ;;;AC1Bf,IAAAC,qBAAuB;AASf,IAAAC,sBAAA;AANR,SAAS,SAAS;AAChB,QAAM,EAAE,eAAe,MAAM,IAAI,YAAY;AAE7C,SACE,6CAAC,YAAO,WAAU,0BAAyB,IAAG,cAC5C,wDAAC,aAAQ,eAAW,mBAAAC,SAAW,yCAAyC,EAAE,kBAAkB,eAAe,cAAc,iBAAiB,CAAC,eAAe,aAAa,CAAC,GACtK;AAAA,kDAAC,aAAQ,WAAU,gBACjB;AAAA,mDAAC,QAAG,WAAU,oCAAmC,6DAEjD;AAAA,MACA,6CAAC,OAAE,WAAU,kCAAiC,wFAG9C;AAAA,OACF;AAAA,IACC,eAAe,gBACd;AAAA,MAAC;AAAA;AAAA,QACC,KAAK,cAAc;AAAA,QACnB,KAAI;AAAA,QACJ,WAAU;AAAA,QACV,SAAQ;AAAA,QACR,IAAG;AAAA,QACH,eAAY;AAAA;AAAA,IACd;AAAA,KAEJ,GACF;AAEJ;AAEA,IAAO,iBAAQ;;;ACjCf,iBAAkB;AAEX,IAAM,mBAAmB,aAAE,OAAO;AAAA,EACrC,gBAAgB,aACX,OAAO;AAAA,IACJ,gBAAgB;AAAA,EACpB,CAAC,EACA,OAAO,CAAC,QAAQ;AACb,UAAM,cAAc,IAAI,QAAQ,OAAO,EAAE;AACzC,WAAO,YAAY,UAAU;AAAA,EACjC,GAAG,6CAA0C,EAC5C,OAAO,CAAC,QAAQ;AACb,UAAM,cAAc,IAAI,QAAQ,OAAO,EAAE;AACzC,WAAO,CAAC,CAAC,OAAO,WAAW;AAAA,EAC/B,GAAG,oCAAiC;AAAA,EAExC,QAAQ,aAAE,OAAO,EAAE,gBAAgB,0CAAmC,CAAC,EAAE,SAAS;AACtF,CAAC;;;ACjBM,IAAM,WAAW,CAAC,UAAkB;AACvC,QAAM,eAAe,MAAM,QAAQ,OAAO,EAAE;AAE5C,MAAI,aAAa,UAAU,IAAI;AAC3B,WAAO,aACF,QAAQ,eAAe,OAAO,EAC9B,QAAQ,eAAe,OAAO,EAC9B,QAAQ,oBAAoB,OAAO,EACnC,QAAQ,iBAAiB,IAAI;AAAA,EACtC;AACJ;;;ACJA,IAAAC,qBAAuB;AACvB,IAAAC,cAA4B;AAC5B,6BAAwB;AAExB,0BAA2B;AAC3B,IAAAC,gBAAmD;;;ACXnD,uBAAoB;AAApB;AA0CO,IAAM,uBAAuB,OAAO,EAAE,UAAU,SAAS,MAA2E;AACvI,QAAM,UAAU,YAAY,IAAI;AAEhC,MAAI,CAAC,SAAS;AACV,UAAM,IAAI,MAAM,iDAAiD;AAAA,EACrE;AAEA,QAAM,aAAa,iBAAAC,QAAQ,IAAI,WAAW;AAE1C,MAAI,CAAC,YAAY;AACb,UAAM,IAAI,MAAM,+CAA+C;AAAA,EACnE;AAEA,QAAM,WAAW,MAAM,MAAM,GAAG,OAAO,+BAA+B;AAAA,IAClE,QAAQ;AAAA,IACR,SAAS;AAAA,MACL,eAAe,UAAU,UAAU;AAAA,MACnC,gBAAgB;AAAA,IACpB;AAAA,IACA,MAAM,KAAK,UAAU,EAAE,UAAU,EAAE,SAAS,GAAG,SAAS,CAAC;AAAA,EAC7D,CAAC;AAED,QAAM,eAA8C,MAAM,SAAS,KAAK;AAExE,MAAI,CAAC,aAAa,SAAS;AACvB,UAAM,IAAI,MAAM,aAAa,WAAW,qCAAqC;AAAA,EACjF;AAEA,SAAO;AACX;;;ACvEA,IAAAC,qBAAuB;AASnB,IAAAC,sBAAA;AAFJ,SAAS,OAAO,OAAoB;AAClC,SACE;AAAA,IAAC;AAAA;AAAA,MACE,GAAG;AAAA,MACJ,eAAW,mBAAAC;AAAA,QACT;AAAA,QACA,MAAM;AAAA,MACR;AAAA,MAEC,gBAAM;AAAA;AAAA,EACT;AAEJ;AAEA,IAAO,iBAAQ;;;AFsFX,IAAAC,sBAAA;AAtFJ,SAAS,KAAK,EAAE,WAAW,GAAU;AACnC,QAAM,EAAE,mBAAmB,UAAU,gBAAgB,eAAe,mBAAmB,wBAAwB,UAAU,IAAI,YAAY;AACzI,QAAM,CAAC,iBAAiB,kBAAkB,QAAI,wBAAkB,KAAK;AAErE,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,WAAW,EAAE,OAAO;AAAA,EACtB,QAAI,gCAA8B;AAAA,IAChC,cAAU,yBAAY,gBAAgB;AAAA,IACtC,MAAM;AAAA,IACN,eAAe;AAAA,MACb,gBAAgB,kBAAkB;AAAA,MAClC,QAAQ;AAAA,IACV;AAAA,EACF,CAAC;AAED,QAAM,kBAAkB,OAAO,WAAiC;AAC9D,QAAI,CAAC,iBAAiB;AACpB,eAAS,UAAU,QAAW,EAAE,gBAAgB,MAAM,CAAC;AAAA,IACzD;AAEA,QAAI,mBAAmB,OAAO,UAAU,QAAW;AACjD,gBAAU,OAAO,MAAM;AAAA,IACzB;AAEA,eAAW,IAAI;AAEf,QAAI;AACF,UAAI,kBAAkB,MAAM;AAC1B,gBAAQ,MAAM,iCAAiC;AAC/C;AAAA,MACF;AAEA,UAAI,CAAC,cAAc,WAAW;AAC5B,gBAAQ,MAAM,oCAAoC;AAClD;AAAA,MACF;AAEA,UAAI,CAAC,cAAc,WAAW;AAC5B,gBAAQ,MAAM,oCAAoC;AAClD;AAAA,MACF;AAEA,YAAM,WAAW,MAAM,qBAAqB;AAAA,QAC1C,UAAU,OAAO,eAAe,QAAQ,OAAO,EAAE;AAAA,QACjD,UAAU,CAAC;AAAA,UACT,WAAW,cAAc;AAAA,UACzB,KAAK,cAAc;AAAA,UACnB,mBAAmB;AAAA,UACnB,WAAW,cAAc;AAAA,UACzB,UAAU,cAAc,YAAY,cAAc;AAAA,QACpD,CAAC;AAAA,MACH,CAAC;AAED,UAAI,SAAS,SAAS;AACpB,cAAM,SAA8H;AAAA,UAClI,cAAc;AAAA,UACd,yBAAyB;AAAA,UACzB,UAAU;AAAA,QACZ;AAEA,0BAAkB,OAAO,cAAc;AACvC,iBAAS,OAAO,SAAS,KAAK,QAAQ,CAAC,EAAE,cAAc,CAAC;AAExD,YAAI,OAAO,SAAS,KAAK,QAAQ,CAAC,EAAE,cAAc,MAAM,aAAa;AACnE,4BAAkB,SAAS,KAAK,QAAQ,CAAC,EAAE,iBAAiB,MAAS;AACrE;AAAA,QACF;AAEA,YAAI,OAAO,SAAS,KAAK,QAAQ,CAAC,EAAE,cAAc,MAAM,gBAAgB;AACtE,iCAAuB,SAAS,KAAK,QAAQ,CAAC,EAAE,eAAe;AAC/D;AAAA,QACF;AAAA,MACF;AAAA,IACF,SAAS,OAAO;AACd,cAAQ,MAAM,uCAAuC,KAAK;AAAA,IAC5D,UAAE;AACA,iBAAW,KAAK;AAAA,IAClB;AAAC;AAAA,EACH;AAEA,SACE,8EACE;AAAA;AAAA,MAAC;AAAA;AAAA,QACC,UAAU,aAAa,eAAe;AAAA,QACtC,eAAW,mBAAAC;AAAA,UACT;AAAA,UACA,EAAE,QAAQ,OAAO,kBAAmB,OAAO,UAAU,iBAAkB,SAAS,gBAAgB;AAAA,QAClG;AAAA,QACA,IAAG;AAAA,QAEH;AAAA;AAAA,YAAC;AAAA;AAAA,cACC,SAAQ;AAAA,cACR,WAAU;AAAA,cACV,IAAG;AAAA,cAEH;AAAA;AAAA,kBAAC;AAAA;AAAA,oBACC,MAAK;AAAA,oBACL,eAAW,mBAAAA;AAAA,sBACT;AAAA,sBACA,EAAE,2BAA2B,OAAO,gBAAgB,cAAc,gBAAgB;AAAA,oBACpF;AAAA,oBACA,aAAY;AAAA,oBACZ,UAAQ;AAAA,oBACR,WAAW;AAAA,oBACV,GAAG,SAAS,kBAAkB;AAAA,sBAC7B,UAAU,CAAC,MAAM;AACf,8BAAM,YAAY,SAAS,EAAE,OAAO,KAAK;AACzC,iCAAS,kBAAkB,WAAqB;AAAA,0BAC9C,gBAAgB;AAAA,wBAClB,CAAC;AAAA,sBACH;AAAA,oBACF,CAAC;AAAA,oBACD,cAAc,kBAAkB;AAAA,oBAChC,IAAG;AAAA;AAAA,gBACL;AAAA,gBACC,OAAO,kBACN,6CAAC,UAAK,WAAU,6EAA4E,IAAG,8BAC5F,iBAAO,eAAe,SACzB;AAAA;AAAA;AAAA,UAEJ;AAAA,UACC,mBACC;AAAA,YAAC;AAAA;AAAA,cACC,SAAQ;AAAA,cACR,WAAU;AAAA,cACV,IAAG;AAAA,cAEH;AAAA;AAAA,kBAAC;AAAA;AAAA,oBACC,MAAK;AAAA,oBACL,eAAW,mBAAAA;AAAA,sBACT;AAAA,sBACA,EAAE,2BAA2B,OAAO,QAAQ,cAAc,gBAAgB;AAAA,oBAC5E;AAAA,oBACA,aAAY;AAAA,oBACX,GAAG,SAAS,UAAU;AAAA,sBACrB,UAAU,kBAAkB,4CAAsC;AAAA,sBAClE,kBAAkB,CAAC;AAAA,sBACnB,UAAU,CAAC,MAAM;AACf,iCAAS,UAAU,EAAE,OAAO,OAAO;AAAA,0BACjC,gBAAgB;AAAA,wBAClB,CAAC;AAAA,sBACH;AAAA,oBACF,CAAC;AAAA,oBACD,IAAG;AAAA;AAAA,gBACL;AAAA,gBACC,OAAO,UACN,6CAAC,UAAK,WAAU,6EAA4E,IAAG,qBAC5F,iBAAO,OAAO,SACjB;AAAA;AAAA;AAAA,UAEJ;AAAA,UAEF;AAAA,YAAC;AAAA;AAAA,cACC,MAAK;AAAA,cACL,eAAW,mBAAAA;AAAA,gBACT;AAAA,gBACA,EAAE,cAAc,gBAAgB;AAAA,cAClC;AAAA,cACA,IAAG;AAAA,cAEH,uDAAC,kCAAW,MAAM,IAAI,OAAM,SAAQ,aAAa,GAAG;AAAA;AAAA,UACtD;AAAA;AAAA;AAAA,IACF;AAAA,IACA,8CAAC,aAAQ,WAAU,0CACjB;AAAA;AAAA,QAAC;AAAA;AAAA,UACC,WAAU;AAAA,UACV,SAAS,MAAM;AACb,kBAAM,WAAW,CAAC;AAClB,+BAAmB,QAAQ;AAC3B,gBAAI,CAAC,UAAU;AAEb,yBAAW,QAAQ;AACnB,0BAAY,QAAQ;AAAA,YACtB;AAAA,UACF;AAAA,UACA,IAAG;AAAA,UAEH;AAAA,yDAAC,UAAM,WAAC,kBAAkB,oCAAiC,2CAAoC;AAAA,YAC/F,6CAAC,kCAAW,MAAM,IAAI,eAAW,mBAAAA,SAAW,EAAE,YAAY,CAAC,iBAAiB,cAAc,gBAAgB,CAAC,GAAG;AAAA;AAAA;AAAA,MAChH;AAAA,MACA;AAAA,QAAC;AAAA;AAAA,UACC,WAAU;AAAA,UACV,SAAS,MAAM,SAAS,WAAW;AAAA,UACnC,IAAG;AAAA,UAEH;AAAA,yDAAC,UAAK,qCAAoB;AAAA,YAC1B,6CAAC,kCAAW,MAAM,IAAI;AAAA;AAAA;AAAA,MACxB;AAAA,OACF;AAAA,KACF;AAEJ;AAEA,IAAO,eAAQ;;;AGrNX,IAAAC,sBAAA;AAFJ,SAAS,QAAQ,EAAE,UAAU,GAAiB;AAC5C,SACE,8CAAC,UAAK,WAAU,0CAAyC,IAAG,eAC1D;AAAA;AAAA,MAAC;AAAA;AAAA,QACC,eAAY;AAAA,QACZ,WAAU;AAAA,QACV,IAAG;AAAA;AAAA,IACJ;AAAA,IACD;AAAA,MAAC;AAAA;AAAA,QACC,WAAW;AAAA,QACX,OAAO,EAAE,OAAO,UAAU;AAAA,QAC1B,IAAG;AAAA,QACJ;AAAA;AAAA,IAED;AAAA,KACF;AAEJ;AAEA,IAAO,kBAAQ;;;ACvBf,IAAAC,gBAAoC;;;ACApC,IAAAC,qBAAuB;AAYnB,IAAAC,sBAAA;AAFJ,SAAS,MAAM,OAAmB;AAChC,SACE;AAAA,IAAC;AAAA;AAAA,MACC,eAAW,mBAAAC;AAAA,QACT;AAAA,QACA,MAAM;AAAA,MACR;AAAA,MACA,OAAO,EAAE,OAAO,MAAM,WAAW,UAAU,MAAM,UAAU,WAAW,MAAM,UAAU;AAAA,MACtF,eAAY;AAAA,MACZ,IAAG;AAAA,MAEF,gBAAM;AAAA;AAAA,EACT;AAEJ;AAEA,IAAO,gBAAQ;;;AC1Bf,IAAAC,kBAAqC;AAarC,IAAM,oBAAmC;AAAA,EACrC,OAAO;AAAA,IACH,IAAI;AAAA,IACJ,MAAM;AAAA,EACV;AACJ;AAGA,IAAM,mBAA2C,CAAC,SAAS;AAAA,EACvD,GAAG;AAAA,EAEH,UAAU,CACN,UACC,IAAI,EAAE,MAAM,CAAC;AACtB;AAGO,IAAM,eAAW,wBAAiB,gBAAgB;;;AC3BzD,IAAAC,gBAAiD;AAEjD,IAAAC,qBAAuB;;;ACMX,IAAAC,sBAAA;AATZ,SAAS,QAAQ,EAAE,KAAK,GAAqB;AACzC,SACI;AAAA,IAAC;AAAA;AAAA,MACG,OAAM;AAAA,MACN,aAAU;AAAA,MACV,SAAQ;AAAA,MACR,OAAO;AAAA,MACP,QAAQ;AAAA,MAER;AAAA,QAAC;AAAA;AAAA,UACG,GAAE;AAAA,UACF,MAAK;AAAA;AAAA,MACT;AAAA;AAAA,EACJ;AAER;AACA,SAAS,SAAS,EAAE,KAAK,GAAqB;AAC1C,SACI;AAAA,IAAC;AAAA;AAAA,MACD,OAAM;AAAA,MACN,aAAU;AAAA,MACV,SAAQ;AAAA,MACR,OAAO;AAAA,MACP,QAAQ;AAAA,MAER;AAAA,qDAAC,YAAO,IAAI,KAAK,IAAI,KAAK,GAAG,QAAQ,MAAK,QAAO;AAAA,QACjD;AAAA,UAAC;AAAA;AAAA,YACC,GAAE;AAAA,YACF,MAAK;AAAA;AAAA,QACP;AAAA;AAAA;AAAA,EACF;AAEN;AAEO,IAAM,QAAQ;AAAA,EACjB;AAAA,EACA;AACJ;;;ADwCM,IAAAC,sBAAA;AAjEN,SAAS,KAAK,EAAE,MAAM,UAAU,QAAQ,GAAc;AACpD,QAAM,EAAE,8BAA8B,OAAO,uBAAuB,IAAI,YAAY;AACpF,QAAM,EAAE,SAAS,IAAI,SAAS;AAE9B,QAAM,CAAC,gBAAgB,iBAAiB,QAAI,wBAAkB,KAAK;AAEnE,QAAM,WAAW,oBAAoB,KAAK;AAE1C,QAAM,kBAAkB,KAAK,qBAAqB;AAElD,QAAM,oBAAoB,KAAK,aAAa;AAG5C,QAAM,gBAAgB,oBAAoB,KAAK;AAE/C,QAAM,uCACH,KAAK,aAAa,KAAK,qBAAsB;AAEhD,QAAM,wBAAoB,2BAAY,MAAM;AAC1C,QAAI,SAAS;AAEX,YAAM,qBAAqB,CAAC,UAAkB,KAAK,MAAM,QAAQ,GAAG,IAAI;AAExE,mCAA6B;AAAA,QAC3B,UAAU;AAAA,UACR,OAAO,mBAAmB,aAAa;AAAA,UACvC,MAAM,mBAAmB,iBAAiB;AAAA,QAC5C;AAAA,QACA,UAAU,KAAK;AAAA,QACf,YAAY,mBAAmB,oCAAoC;AAAA,QACnE,YAAY,KAAK;AAAA,MACnB,CAAC;AAAA,IACH;AAAA,EACF,GAAG;AAAA,IACD;AAAA,IACA,KAAK;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,CAAC;AAED,+BAAU,MAAM;AACd,sBAAkB;AAAA,EACpB,GAAG,CAAC,iBAAiB,CAAC;AAEtB,QAAM,2BAA2B,MAAM;AACrC,QAAI,uBAAwB;AAE5B,aAAS;AAAA,MACP,IAAI;AAAA,MACJ,MAAM;AAAA,IACR,CAAC;AAAA,EACH;AAEA,SACE;AAAA,IAAC;AAAA;AAAA,MACC,SAAS;AAAA,MACT,eAAW,mBAAAC;AAAA,QACT;AAAA,QACA,EAAE,sBAAsB,UAAU,aAAa,kBAAkB,UAAU,cAAc;AAAA,MAC3F;AAAA,MACA,IAAI,oBAAoB;AAAA,MACxB,SAAS;AAAA,MAET;AAAA;AAAA,UAAC;AAAA;AAAA,YACC,MAAK;AAAA,YACL,MAAK;AAAA,YACL,IAAI;AAAA,YACJ,WAAU;AAAA,YACV;AAAA,YACA;AAAA,YACA,UAAU,UAAU;AAAA;AAAA,QACtB;AAAA,QAEC,CAAC,UACA,6CAAC,MAAM,UAAN,EAAe,MAAM,IAAI,IAE1B,6CAAC,MAAM,SAAN,EAAc,MAAM,IAAI;AAAA,QAG3B,8CAAC,UAAK,WAAU,uCACb;AAAA,eAAK;AAAA,UAAmB;AAAA,WAC3B;AAAA,QAEA,8CAAC,aAAQ,WAAU,kEACjB;AAAA,wDAAC,UAAK,WAAU,4GACb;AAAA,0BAAc,eAAe,SAAS;AAAA,cACrC,UAAU;AAAA,cACV,iBAAiB;AAAA,cACjB,cAAc;AAAA,cACd,OAAO;AAAA,YACT,CAAC;AAAA,YAAG;AAAA,YAAI;AAAA,aAEV;AAAA,UACA,6CAAC,YAAO,WAAU,mDACf,+CAAqC,eAAe,SAAS;AAAA,YAC5D,UAAU;AAAA,YACV,iBAAiB;AAAA,YACjB,cAAc;AAAA,YACd,OAAO;AAAA,UACT,CAAC,GACH;AAAA,WACF;AAAA;AAAA;AAAA,EACF;AAEJ;AAEA,IAAO,eAAQ;;;AE1Hf,IAAAC,oBAAoB;AAApB,IAAAC,eAAA;AAoCO,IAAM,+BAA+B,OAAO,EAAE,SAAS,MAA2F;AACrJ,QAAM,UAAUA,aAAY,IAAI;AAEhC,MAAI,CAAC,SAAS;AACV,UAAM,IAAI,MAAM,iDAAiD;AAAA,EACrE;AAEA,QAAM,aAAa,kBAAAC,QAAQ,IAAI,WAAW;AAE1C,MAAI,CAAC,YAAY;AACb,UAAM,IAAI,MAAM,+CAA+C;AAAA,EACnE;AAEA,QAAM,WAAW,MAAM,MAAM,GAAG,OAAO,4BAA4B;AAAA,IAC/D,QAAQ;AAAA,IACR,SAAS;AAAA,MACL,eAAe,UAAU,UAAU;AAAA,MACnC,gBAAgB;AAAA,IACpB;AAAA,IACA,MAAM,KAAK,UAAU,EAAE,SAAS,CAAC;AAAA,EACrC,CAAC;AAED,QAAM,eAAsD,MAAM,SAAS,KAAK;AAEhF,MAAI,CAAC,aAAa,SAAS;AACvB,UAAM,IAAI,MAAM,aAAa,WAAW,2CAA2C;AAAA,EACvF;AAEA,SAAO;AACX;;;ALqDM,IAAAC,uBAAA;AA7GN,SAAS,gBAAgB;AACvB,QAAM,EAAE,gBAAgB,UAAU,OAAO,eAAe,gBAAgB,uBAAuB,IAAI,YAAY;AAC/G,QAAM,CAAC,iBAAiB,mBAAmB,QAAI,wBAAwB,IAAI;AAC3E,QAAM,CAAC,SAAS,UAAU,QAAI,wBAAkB,IAAI;AACpD,QAAM,CAAC,eAAe,gBAAgB,QAAI,wBAAsC;AAEhF,+BAAU,MAAM;AACd,UAAM,+BAA+B,YAAY;AAC/C,UAAI,CAAC,eAAe,WAAW;AAC7B,gBAAQ,MAAM,oDAAoD;AAClE;AAAA,MACF;AAEA,UAAI,CAAC,cAAc,KAAK;AACtB,gBAAQ,MAAM,6CAA6C;AAC3D;AAAA,MACF;AAEA,UAAI,CAAC,cAAc,WAAW;AAC5B,gBAAQ,MAAM,oDAAoD;AAClE;AAAA,MACF;AAEA,UAAI,CAAC,cAAc,OAAO;AACxB,gBAAQ,MAAM,+CAA+C;AAC7D;AAAA,MACF;AAEA,UAAI;AACF,cAAM,OAAO;AAAA,UACX,WAAW,OAAO,cAAc,SAAS;AAAA,UACzC,KAAK,cAAc;AAAA,UACnB,mBAAmB;AAAA,UACnB,WAAW,cAAc;AAAA,UACzB,UAAU,cAAc;AAAA,QAC1B;AAEA,cAAM,WAAW,MAAM,6BAA6B,EAAE,UAAU,CAAC,IAAI,EAAE,CAAC;AAExE,YAAI,SAAS,WAAW,SAAS,MAAM;AACrC,2BAAiB,SAAS,IAAI;AAAA,QAChC,OAAO;AACL,2BAAiB,MAAS;AAAA,QAC5B;AAAA,MACF,SAAS,OAAO;AACd,yBAAiB,MAAS;AAC1B,gBAAQ,MAAM,KAAK;AAAA,MACrB,UAAE;AACA,mBAAW,KAAK;AAAA,MAClB;AAAA,IACF;AAEA,UAAM,4BAA4B,YAAY;AAC5C,UAAI,CAAC,gBAAgB;AACnB,gBAAQ,MAAM,iCAAiC;AAC/C;AAAA,MACF;AAEA,UAAI,CAAC,eAAe,WAAW;AAC7B,gBAAQ,MAAM,oDAAoD;AAClE;AAAA,MACF;AAEA,UAAI,CAAC,cAAc,KAAK;AACtB,gBAAQ,MAAM,6CAA6C;AAC3D;AAAA,MACF;AAEA,UAAI,CAAC,cAAc,WAAW;AAC5B,gBAAQ,MAAM,oDAAoD;AAClE;AAAA,MACF;AAEA,UAAI,CAAC,cAAc,OAAO;AACxB,gBAAQ,MAAM,+CAA+C;AAC7D;AAAA,MACF;AAEA,UAAI;AACF,cAAM,OAAO;AAAA,UACX,WAAW,OAAO,cAAc,SAAS;AAAA,UACzC,KAAK,cAAc;AAAA,UACnB,mBAAmB;AAAA,UACnB,WAAW,cAAc;AAAA,UACzB,UAAU,cAAc;AAAA,QAC1B;AAEA,cAAM,WAAW,MAAM,qBAAqB,EAAE,UAAU,gBAAgB,UAAU,CAAC,IAAI,EAAE,CAAC;AAE1F,YAAI,SAAS,WAAW,SAAS,MAAM;AACrC,2BAAiB,SAAS,KAAK,OAAO;AAAA,QACxC,OAAO;AACL,2BAAiB,MAAS;AAAA,QAC5B;AAAA,MACF,SAAS,OAAO;AACd,yBAAiB,MAAS;AAC1B,gBAAQ,MAAM,KAAK;AAAA,MACrB,UAAE;AACA,mBAAW,KAAK;AAAA,MAClB;AAAA,IACF;AAEA,cAAU,gBACR,0BAA0B,IAC1B,6BAA6B;AAAA,EACjC,GAAG,CAAC,CAAC;AAEL,MAAI,SAAS;AACX,WACE,+CAAC,UAAK,WAAU,0CAAyC,IAAG,eAC1D;AAAA;AAAA,QAAC;AAAA;AAAA,UACC,eAAY;AAAA,UACZ,WAAU;AAAA,UACV,IAAG;AAAA;AAAA,MACJ;AAAA,MACD;AAAA,QAAC;AAAA;AAAA,UACC,WAAW;AAAA,UACX,IAAG;AAAA,UACJ;AAAA;AAAA,MAED;AAAA,OACF;AAAA,EAEJ;AAEA,SACE;AAAA,IAAC;AAAA;AAAA,MACC,WAAU;AAAA,MACV,IAAG;AAAA,MAEH;AAAA,sDAAC,iBAAM,uCAAsB;AAAA,QAE7B;AAAA,UAAC;AAAA;AAAA,YACC,WAAU;AAAA,YACV,IAAG;AAAA,YAEF;AAAA,eAAC,iBACA,8CAAC,OAAE,WAAU,kDAAiD,IAAG,sBAAqB,+EAAwD;AAAA,cAG/I,iBAAiB,cAAc,IAAI,CAAC,MAAM,UAAU;AACnD,sBAAM,WAAW,oBAAoB,KAAK;AAE1C,uBACE;AAAA,kBAAC;AAAA;AAAA,oBAEC,MAAM;AAAA,oBACN,SAAS,oBAAoB;AAAA,oBAC7B,UAAU,MAAM,oBAAoB,QAAQ;AAAA;AAAA,kBAHvC;AAAA,gBAIP;AAAA,cAEJ,CAAC;AAAA;AAAA;AAAA,QACH;AAAA,QAEC,UAAU,eACT;AAAA,UAAC;AAAA;AAAA,YACC,SAAS,MAAM,SAAS,SAAS;AAAA,YACjC,WAAU;AAAA,YACV,IAAG;AAAA,YACJ;AAAA;AAAA,cAE6B;AAAA,cAC5B,8CAAC,UAAK,WAAU,aAAY,2DAE5B;AAAA;AAAA;AAAA,QACF;AAAA,QAGD,UAAU,iBACT,gFACG;AAAA,WAAC,0BAA0B;AAAA,YAAC;AAAA;AAAA,cAC3B,SAAS,MAAM,OAAO,SAAS,OAAO,kBAAkB;AAAA,cACxD,WAAU;AAAA,cACV,IAAG;AAAA,cAEH,wDAAC,UAAK,WAAU,aAAY,0EAAsD;AAAA;AAAA,UACpF;AAAA,UAEA;AAAA,YAAC;AAAA;AAAA,cACC,SAAS,MAAM,SAAS,SAAS;AAAA,cACjC,WAAU;AAAA,cACV,IAAG;AAAA,cAEH,wDAAC,UAAK,WAAU,aAAY,2CAA6B;AAAA;AAAA,UAC3D;AAAA,WACF;AAAA;AAAA;AAAA,EAEJ;AAEJ;AAEA,IAAO,wBAAQ;;;AMxMf,IAAAC,qBAAuB;AAYnB,IAAAC,uBAAA;AAFJ,SAAS,KAAK,OAAkB;AAC9B,SACE;AAAA,IAAC;AAAA;AAAA,MACC,eAAW,mBAAAC;AAAA,QACT;AAAA,QACA,MAAM,aAAa,QAAQ,MAAM,SAAS;AAAA,QAC1C,MAAM;AAAA,MACR;AAAA,MACA,OAAO,EAAE,OAAO,MAAM,WAAW,UAAU,MAAM,UAAU,WAAW,MAAM,UAAU;AAAA,MACtF,eAAY;AAAA,MACZ,IAAG;AAAA,MAEF,gBAAM;AAAA;AAAA,EACT;AAEJ;AAEA,IAAO,eAAQ;;;AC1Bf,IAAAC,qBAAuB;;;ACDhB,IAAM,YAAY,CACrB,WACC;AACD,MAAI,WAAW,OAAW,QAAO;AAEjC,SACI,MACA,OAAO,KAAK,MAAM,EACb,IAAI,CAAC,aAAa,WAAW,MAAM,OAAO,QAAQ,CAAC,EACnD,KAAK,GAAG;AAErB;;;ADKI,IAAAC,uBAAA;AAJJ,SAAS,KAAK,OAAkB;AAC9B,QAAM,EAAE,SAAS,IAAI,YAAY;AAEjC,SACE;AAAA,IAAC;AAAA;AAAA,MACE,GAAG;AAAA,MACJ,QAAO;AAAA,MACP,MACE,OAAO,MAAM,SAAS,WAClB,MAAM,OACN,MAAM,KAAK,WAAW,UAAU,MAAM,KAAK,KAAK;AAAA,MAEtD,eAAW,mBAAAC;AAAA,QACT;AAAA,QACA,MAAM;AAAA,MACR;AAAA,MACA,eAAY;AAAA,MACZ,IAAG;AAAA,MACH,SAAS,MAAM,SAAS,SAAS;AAAA,MAEhC,gBAAM;AAAA;AAAA,EACT;AAEJ;AAEA,IAAO,eAAQ;;;AEnBT,IAAAC,uBAAA;AATN,SAAS,sBAAsB,EAAE,UAAU,GAA2B;AAEpE,QAAM,EAAE,eAAe,IAAI,YAAY;AACvC,SACE;AAAA,IAAC;AAAA;AAAA,MACC,eAAY;AAAA,MACZ,WAAU;AAAA,MACV,IAAG;AAAA,MAEH;AAAA,sDAAC,iBAAM,WAAU,UAAS,WAAsB,oCAEhD;AAAA,QACA,+CAAC,gBAAK,WAAU,UAAS,WAAsB;AAAA;AAAA,UACI,8CAAC,QAAG;AAAA,UAAE;AAAA,WAEzD;AAAA,QASA;AAAA,UAAC;AAAA;AAAA,YACC,MAAM,kBAAkB;AAAA,YACzB;AAAA;AAAA,QAED;AAAA;AAAA;AAAA,EAQF;AAEJ;AAEA,IAAO,gCAAQ;;;ACxCf,IAAAC,gBAA+D;;;ACA3D,IAAAC,uBAAA;AAJJ,SAAS,wBAAwB,EAAE,UAAU,GAA2B;AACtE,QAAM,EAAE,oBAAoB,IAAI,YAAY;AAE5C,SACE;AAAA,IAAC;AAAA;AAAA,MACC,eAAY;AAAA,MACZ,WAAU;AAAA,MACV,IAAG;AAAA,MAEH;AAAA,sDAAC,iBAAM,WAAU,UAAS,WAAsB,6EAEhD;AAAA,QACA,8CAAC,gBAAK,WAAU,UAAS,WAAsB,+LAE/C;AAAA,QACA;AAAA,UAAC;AAAA;AAAA,YACC,MAAM,uBAAuB;AAAA,YAC9B;AAAA;AAAA,QAED;AAAA;AAAA;AAAA,EACF;AAEJ;AAEA,IAAO,kCAAQ;;;AC7Bf,IAAAC,oBAAoB;AAEb,IAAM,mBAAmB,OAAO,EAAE,SAAS,MAA4B;AAC1E,QAAM,WAAW,MAAM;AAAA,IACnB;AAAA,IACA;AAAA,MACI,QAAQ;AAAA,MACR,SAAS;AAAA,QACL,gBAAgB;AAAA,MACpB;AAAA,MACA,aAAa;AAAA,MACb,MAAM,KAAK,UAAU;AAAA,QACjB,UAAU;AAAA,MACd,CAAC;AAAA,IACL;AAAA,EACJ;AAEA,QAAM,OAAO,MAAM,SAAS,KAAK;AAEjC,MAAI,CAAC,KAAK,SAAS;AACf,UAAM,IAAI,MAAM,sBAAsB;AAAA,EAC1C;AAEA,oBAAAC,QAAQ,IAAI,aAAa,KAAK,OAAO,OAAO;AAAA,IACxC,QAAQ;AAAA,IACR,UAAU;AAAA,EACd,CAAC;AAED,oBAAAA,QAAQ,IAAI,qBAAqB,KAAK,OAAO,cAAc;AAAA,IACvD,QAAQ;AAAA,IACR,UAAU;AAAA,EACd,CAAC;AAED,SAAO;AACX;;;AFtBA,IAAAC,uBAAsC;;;AGZtC,IAAAC,oBAAoB;AAApB,IAAAC,eAAA;AAuCO,IAAM,kBAAkB,OAAO,EAAE,YAAY,MAA8D;AAC9G,QAAM,UAAUA,aAAY,IAAI;AAEhC,QAAM,aAAa,kBAAAC,QAAQ,IAAI,WAAW;AAE1C,MAAI,CAAC,YAAY;AACb,UAAM,IAAI,MAAM,+CAA+C;AAAA,EACnE;AAEA,QAAM,WAAW,MAAM,MAAM,GAAG,OAAO,iBAAiB,WAAW,IAAI;AAAA,IACnE,QAAQ;AAAA,IACR,SAAS;AAAA,MACL,eAAe,UAAU,UAAU;AAAA,MACnC,gBAAgB;AAAA,IACpB;AAAA,EACJ,CAAC;AAED,QAAM,eAAqC,MAAM,SAAS,KAAK;AAE/D,MAAI,CAAC,aAAa,SAAS;AACvB,UAAM,IAAI,MAAM,aAAa,WAAW,+BAA+B;AAAA,EAC3E;AAEA,SAAO;AACX;;;AH9CA,sBAAqB;;;AIXrB,IAAAC,qBAAuB;AAcX,IAAAC,uBAAA;AAZZ,IAAM,QAAQ,CAAC,EAAE,GAAG,MAAsB;AACtC,QAAM,EAAE,eAAe,IAAI,YAAY;AACvC,QAAM,EAAE,OAAO,SAAS,IAAI,SAAS;AAErC,SACI,+CAAC,UAAK,eAAW,mBAAAC;AAAA,IACb;AAAA,IACA;AAAA,MACI,mCAAmC,MAAM,OAAO,MAAM,MAAM;AAAA,MAC5D,iCAAiC,MAAM,MAAM,MAAM,CAAC,MAAM;AAAA,IAC9D;AAAA,EACJ,GACI;AAAA,kDAAC,SAAI,WAAU,oBAAmB,SAAS,MAAM,SAAS,EAAE,IAAI,IAAI,MAAM,MAAM,CAAC,GAAG;AAAA,IACpF,+CAAC,aAAQ,WAAU,qFACf;AAAA,oDAAC,iBAAM,WAAU,UAAS,UAAS,QAAO,WAAU,UAAS,WAAU,QAAO,2DAAoC;AAAA,MAClH,+CAAC,gBAAK,WAAU,QAAO,WAAU,UAAS;AAAA;AAAA,QAAsD,8CAAC,YAAO,mBAAK;AAAA,QAAS;AAAA,QAAI,8CAAC,YAAO,sBAAQ;AAAA,QAAS;AAAA,SAAS;AAAA,MAC5J,+CAAC,aAAQ,WAAU,oDACf;AAAA,sDAAC,kBAAO,WAAU,iCAAgC,SAAS,MAAM,SAAS,EAAE,IAAI,IAAI,MAAM,MAAM,CAAC,GAAG,sCAAqB;AAAA,QACzH,8CAAC,gBAAK,MAAM,kBAAkB,UAAU,sCAAqB;AAAA,SACjE;AAAA,OACJ;AAAA,KACJ;AAER;AAEA,IAAO,gBAAQ;;;ACjCf,IAAAC,gBAAiD;;;ACAjD,IAAAC,oBAAoB;AAApB,IAAAC,eAAA;AAsBO,IAAM,0BAA0B,YAA2C;AAC9E,QAAM,UAAUA,aAAY,IAAI;AAEhC,QAAM,aAAa,kBAAAC,QAAQ,IAAI,WAAW;AAE1C,MAAI,CAAC,YAAY;AACb,UAAM,IAAI,MAAM,+CAA+C;AAAA,EACnE;AAEA,QAAM,WAAW,MAAM,MAAM,GAAG,OAAO,kBAAkB;AAAA,IACrD,QAAQ;AAAA,IACR,SAAS;AAAA,MACL,eAAe,UAAU,UAAU;AAAA,MACnC,gBAAgB;AAAA,IACpB;AAAA,EACJ,CAAC;AAED,QAAM,eAAqC,MAAM,SAAS,KAAK;AAE/D,MAAI,CAAC,aAAa,SAAS;AACvB,UAAM,IAAI,MAAM,aAAa,WAAW,+BAA+B;AAAA,EAC3E;AAEA,SAAO;AACX;;;ADvCO,SAAS,mBAAmB,EAAE,WAAW,GAA2B;AACvE,QAAM,CAAC,SAAS,UAAU,QAAI,wBAAkB,KAAK;AACrD,QAAM,CAACC,UAAS,UAAU,QAAI,wBAAkB,IAAI;AACpD,QAAM,CAACC,QAAO,QAAQ,QAAI,wBAAkB;AAE5C,QAAM,2BAAuB,2BAAY,YAAY;AACjD,QAAI;AACA,YAAM,WAAW,MAAM,wBAAwB;AAE/C,UAAI,SAAS,SAAS;AAClB,cAAM,OAAO,SAAS;AAEtB,cAAM,mBAAmB,KAAK,KAAK,aAAW,QAAQ,OAAO,UAAU;AACvE,mBAAW,gBAAgB;AAAA,MAC/B;AAAA,IACJ,SAAS,OAAO;AACZ,eAAS,KAAK;AACd,cAAQ,MAAM,KAAK;AAAA,IACvB,UAAE;AAAA,IAEF;AAAA,EACJ,GAAG,CAAC,CAAC;AAEL,+BAAU,MAAM;AACZ,yBAAqB;AAAA,EACzB,GAAG,CAAC,oBAAoB,CAAC;AAEzB,SAAO,EAAE,SAAS,SAAAD,UAAS,OAAAC,OAAM;AACrC;;;ALoEM,IAAAC,uBAAA;AAzEN,SAAS,IAAI;AAAA,EACX;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAAa;AACX,QAAM,+BAA+B;AAAA,IACnC,OAAO,oBAAoB,EAAE,QAAQ,KAAK,GAAG;AAAA,EAC/C;AAEA,QAAM,CAAC,SAAS,UAAU,QAAI,wBAAkB,KAAK;AACrD,QAAM,CAAC,SAAS,UAAU,QAAI,wBAAkB,KAAK;AACrD,QAAM,EAAE,OAAO,kBAAkB,eAAe,2BAA2B,kBAAkB,IAAI,YAAY;AAC7G,QAAM,CAAC,iBAAiB,kBAAkB,QAAI,wBAAkB,IAAI;AAEpE,QAAM,EAAE,QAAQ,IAAI,mBAAmB,EAAE,WAAuB,CAAC;AAEjE,QAAM,oBAAoB,YAAY;AACpC,QAAI;AACF,UAAI,CAAC,YAAY;AACf,gBAAQ,MAAM,6BAA6B;AAC3C,2BAAmB,KAAK;AACxB;AAAA,MACF;AAEA,YAAM,WAAW,MAAM,gBAAgB,EAAE,aAAa,WAAW,CAAC;AAElE,UAAI,SAAS,WAAW,SAAS,MAAM;AACrC,2BAAmB,IAAI;AAEvB,cAAM,EAAE,KAAK,KAAK,GAAG,qBAAqB,IAAI,SAAS;AAEvD,yBAAiB;AAAA,UACf,GAAG;AAAA,UACH,GAAG;AAAA,UACH,WAAW,OAAO,qBAAqB,SAAS;AAAA,UAChD,oBAAoB,IAAI,sBAAsB;AAAA,UAC9C,aAAa,IAAI,eAAe;AAAA,UAChC,cAAc,IAAI,aAAa;AAAA,UAC/B,KAAK;AAAA,QACP,CAAC;AAED,kCAA0B,sBAAsB;AAChD,0BAAkB,cAAc;AAAA,MAClC;AAAA,IACF,SAAS,OAAO;AACd,cAAQ,MAAM,KAAK;AAAA,IACrB,UAAE;AACA,iBAAW,IAAI;AAAA,IACjB;AAAA,EACF;AAEA,QAAM,iCAA6B,2BAAY,YAAY;AACzD,QAAI;AACF,YAAM,WAAW,MAAM,iBAAiB,EAAE,SAAmB,CAAC;AAE9D,UAAI,SAAS,WAAW,SAAS;AAC/B,0BAAkB;AAAA,MACpB,OAAO;AACL,gBAAQ,MAAM,+BAA+B;AAAA,MAC/C;AAAA,IACF,SAAS,OAAO;AACd,cAAQ,MAAM,iCAAiC,KAAK;AAAA,IACtD;AAAA,EACF,GAAG,CAAC,UAAU,OAAO,CAAC;AAEtB,+BAAU,MAAM;AACd,+BAA2B;AAAA,EAC7B,GAAG,CAAC,0BAA0B,CAAC;AAE/B,MAAI,CAAC,SAAS;AACZ,WACE,8CAAC,gBAAAC,SAAA,EAAS,SAAQ,eAAc,OAAO,EAAE,cAAc,OAAO,GAAG,OAAO,KAAK,QAAQ,KAAK;AAAA,EAE9F;AAEA,MAAI,CAAC,iBAAiB;AACpB,WACE,8CAAC,SAAI,IAAG,oBACN,yDAAC,qBAAU,SAAQ,QACjB;AAAA,oDAAC,iBAAM,4CAA2B;AAAA,MAClC,+CAAC,gBAAK,WAAU,UAAS;AAAA;AAAA,QAAyC,8CAAC,QAAG;AAAA,QAAE;AAAA,SAA4D;AAAA,MACpI;AAAA,QAAC;AAAA;AAAA,UACC,WAAU;AAAA,UACV,SAAS,MAAM,OAAO,SAAS,OAAO;AAAA,UACtC,IAAG;AAAA,UAEH;AAAA,0DAAC,UAAK,8BAAgB;AAAA,YACtB,8CAAC,kCAAU,MAAM,IAAI;AAAA;AAAA;AAAA,MACvB;AAAA,OACF,GACF;AAAA,EAEJ;AAEA,MAAI,CAAC,SAAS;AACZ;AAAA,EACF;AAEA,QAAM,uBAAuB,MAAM;AACjC,UAAM,WAAqD;AAAA,MACzD,WAAW,8CAAC,gBAAK,YAAwB;AAAA,MACzC,aAAa,8CAAC,iCAAsB;AAAA,MACpC,gBAAgB,8CAAC,mCAAwB;AAAA,MACzC,eAAe,8CAAC,yBAAc;AAAA,MAC9B,aAAa,8CAAC,yBAAc;AAAA,IAC9B;AAEA,QAAI,CAAC,QAAS,QAAO,SAAS,KAAK;AAAA,QAC9B,QAAO,8CAAC,mBAAQ;AAAA,EACvB;AAEA,SACE,+CAAC,SAAI,IAAG,oBACN;AAAA,mDAAC,qBAAU,SAAQ,QACjB;AAAA,oDAAC,kBAAO,sBAAsB,gCAAgC,GAAG;AAAA,MAEjE,8CAAC,qBAAU,SAAQ,UACjB,wDAAC,wBAAqB,GACxB;AAAA,MAEA,8CAAC,kBAAO;AAAA,OACV;AAAA,IAEA,8CAAC,iBAAM,IAAG,6BAA4B;AAAA,KACxC;AAEJ;AAEA,IAAO,cAAQ;","names":["import_jsx_runtime","classNames","import_classnames","import_jsx_runtime","classNames","import_classnames","import_zod","import_react","Cookies","import_classnames","import_jsx_runtime","classNames","import_jsx_runtime","classNames","import_jsx_runtime","import_react","import_classnames","import_jsx_runtime","classNames","import_zustand","import_react","import_classnames","import_jsx_runtime","import_jsx_runtime","classNames","import_js_cookie","import_meta","Cookies","import_jsx_runtime","import_classnames","import_jsx_runtime","classNames","import_classnames","import_jsx_runtime","classNames","import_jsx_runtime","import_react","import_jsx_runtime","import_js_cookie","Cookies","import_lucide_react","import_js_cookie","import_meta","Cookies","import_classnames","import_jsx_runtime","classNames","import_react","import_js_cookie","import_meta","Cookies","Loading","Error","import_jsx_runtime","Skeleton"]}
1
+ {"version":3,"sources":["../src/index.ts","../src/libs/zustand/usePBM.tsx","../src/components/Header/index.tsx","../src/components/UI/Container/index.tsx","../src/components/Footer/index.tsx","../src/schema/validation-schema.ts","../src/utils/format.ts","../src/components/Form/index.tsx","../src/services/benefits-with-document.ts","../src/components/UI/Button/index.tsx","../src/components/UI/Loading/index.tsx","../src/components/BenefitsTable/index.tsx","../src/components/UI/Title/index.tsx","../src/libs/zustand/useModal.tsx","../src/components/BenefitsTable/Item.tsx","../src/components/UI/Icons/index.tsx","../src/services/benefits-without-document.ts","../src/components/UI/Text/index.tsx","../src/components/UI/Link/index.tsx","../src/utils/getParams.ts","../src/components/SecurityNumberInvalid/index.tsx","../src/PBM.tsx","../src/components/SecurityNumberRegitered/index.tsx","../src/services/authorization.ts","../src/services/get-product-by-ean.ts","../src/components/Modal/index.tsx","../src/services/get-list-products.ts"],"sourcesContent":["// Estilos - importa CSS escopado para evitar conflitos\r\nimport './pbm-scoped.css';\r\n\r\n// Componente Principal\r\nexport { default as PBM } from \"./PBM\";\r\n\r\n// Tipos\r\nexport type { PBMProps } from \"./PBM\";\r\nexport type { PBMStore } from \"./libs/zustand/usePBM\";\r\n\r\n// Hooks\r\nexport { usePBMStore } from \"./libs/zustand/usePBM\"; \r\n","import { createStore, StateCreator, StoreApi } from \"zustand\";\r\nimport { useStore } from \"zustand/react\";\r\nimport { IProduct, usePBMTypes } from \"../../types/globals\";\r\n\r\nexport interface PBMStore extends usePBMTypes {\r\n setSecurityNumber: (securityNumber: string) => void;\r\n setState: (state: usePBMTypes[\"state\"]) => void;\r\n setAvailableDiscountSelected: (\r\n availableDiscount: usePBMTypes[\"availableDiscountSelected\"]\r\n ) => void;\r\n setTargetProduct: (targetProduct: usePBMTypes[\"targetProduct\"]) => void;\r\n setUrlAcceptTerms: (urlAcceptTerms: usePBMTypes[\"urlAcceptTerms\"]) => void;\r\n setUrlRegisterIndustry: (urlRegisterIndustry: usePBMTypes[\"urlRegisterIndustry\"]) => void;\r\n setIsAuthenticatedShopper: (isAuthenticatedShopper: usePBMTypes[\"isAuthenticatedShopper\"]) => void;\r\n setCustomLoginUrl: (customLoginUrl: usePBMTypes[\"customLoginUrl\"]) => void;\r\n setCardID: (cardID: usePBMTypes[\"cardID\"]) => void;\r\n}\r\n\r\n// Tipo apenas com os getters (estado readonly)\r\nexport type PBMStoreReadonly = Omit<PBMStore,\r\n | 'setSecurityNumber'\r\n | 'setState'\r\n | 'setAvailableDiscountSelected'\r\n | 'setTargetProduct'\r\n | 'setUrlAcceptTerms'\r\n | 'setUrlRegisterIndustry'\r\n>;\r\n\r\nconst initialPBMState: usePBMTypes = {\r\n securityNumber: \"\",\r\n cardID: \"\",\r\n state: \"isEmpty\",\r\n availableDiscountSelected: {\r\n quantity: 0,\r\n discount: {\r\n unit: 0,\r\n total: 0,\r\n },\r\n totalPrice: 0,\r\n grossPrice: 0\r\n },\r\n targetProduct: null,\r\n campaign: \"pbm_campaign\",\r\n isAuthenticatedShopper: false,\r\n customLoginUrl: \"/login\"\r\n};\r\n\r\nconst createPBMStore: StateCreator<PBMStore> = (set) => ({\r\n ...initialPBMState,\r\n\r\n setSecurityNumber: (securityNumber: string) => set({ securityNumber }),\r\n setState: (state: usePBMTypes[\"state\"]) => set({ state }),\r\n setTargetProduct: (targetProduct: usePBMTypes[\"targetProduct\"]) =>\r\n set({ targetProduct }),\r\n setAvailableDiscountSelected: (\r\n availableDiscount: usePBMTypes[\"availableDiscountSelected\"]\r\n ) => set({ availableDiscountSelected: availableDiscount }),\r\n setUrlAcceptTerms: (urlAcceptTerms: usePBMTypes[\"urlAcceptTerms\"]) =>\r\n set({ urlAcceptTerms: urlAcceptTerms }),\r\n setUrlRegisterIndustry: (urlRegisterIndustry: usePBMTypes[\"urlRegisterIndustry\"]) =>\r\n set({ urlRegisterIndustry: urlRegisterIndustry }),\r\n setIsAuthenticatedShopper: (isAuthenticatedShopper: usePBMTypes[\"isAuthenticatedShopper\"]) =>\r\n set({ isAuthenticatedShopper: isAuthenticatedShopper }),\r\n setCustomLoginUrl: (customLoginUrl: usePBMTypes[\"customLoginUrl\"]) => set({ customLoginUrl: customLoginUrl }),\r\n setCardID: (cardID: usePBMTypes[\"cardID\"]) => set({ cardID: cardID })\r\n});\r\n\r\n// Store completa (uso interno na biblioteca)\r\nexport const pbmStore: StoreApi<PBMStore> = createStore<PBMStore>(createPBMStore);\r\n\r\n// Cria uma versão somente leitura da store para exposição pública\r\nexport const createReadonlyStore = (): StoreApi<PBMStoreReadonly> => {\r\n return {\r\n getState: () => {\r\n const fullState = pbmStore.getState();\r\n // Remove os setters do estado retornado\r\n const {\r\n setSecurityNumber,\r\n setState,\r\n setAvailableDiscountSelected,\r\n setTargetProduct,\r\n setUrlAcceptTerms,\r\n setUrlRegisterIndustry,\r\n setIsAuthenticatedShopper,\r\n setCustomLoginUrl,\r\n setCardID,\r\n ...readonlyState\r\n } = fullState;\r\n\r\n const { quantity, productId, skuId, discountMax, netPrice, stockBalance, listPrice, price, ...limitedTargetProductData } = fullState.targetProduct as IProduct;\r\n\r\n return { ...readonlyState, targetProduct: limitedTargetProductData } as PBMStoreReadonly;\r\n }\r\n } as StoreApi<PBMStoreReadonly>;\r\n};\r\n\r\n// React hook (usado dentro de componentes React)\r\nexport function usePBMStore(): PBMStore;\r\nexport function usePBMStore<T>(selector: (state: PBMStore) => T): T;\r\nexport function usePBMStore<T>(selector?: (state: PBMStore) => T): PBMStore | T {\r\n if (selector) {\r\n return useStore(pbmStore, selector);\r\n }\r\n return useStore(pbmStore, (state) => state);\r\n}\r\n","import { usePBMStore } from \"../../libs/zustand/usePBM\";\r\n\r\nfunction Header({ originalProductPrice }: { originalProductPrice: number }) {\r\n const { targetProduct } = usePBMStore();\r\n const Price = (targetProduct?.listPrice || originalProductPrice);\r\n const Discount = Price * ((targetProduct?.discountMax || 0) / 100)\r\n\r\n return (\r\n <>\r\n {(targetProduct?.informativeMessage) && <span className=\"absolute w-11/12 -top-6 bg-emerald-500 px-4 py-1 rounded-lg text-sm text-center font-medium text-white\">{targetProduct?.informativeMessage}</span>}\r\n <header\r\n className=\"flex items-center justify-between w-full p-0.5 rounded-xl bg-[#44c2c0]/30 mt-5\"\r\n id=\"header_pbm\"\r\n >\r\n <span\r\n className=\"py-1 px-6 rounded-xl bg-[#44c2c0] shrink-0 text-white text-xl font-bold flex items-center justify-start gap-2 relative\"\r\n data-testid=\"test_id_header_price\"\r\n id=\"header_price\"\r\n >\r\n <section className=\"flex items-center gap-2 justify-center-safe\">\r\n <span className=\"line-through text-sm font-light\">\r\n {Number(Price)?.toLocaleString(\"pt-BR\", {\r\n currency: \"BRL\",\r\n currencyDisplay: \"symbol\",\r\n currencySign: \"standard\",\r\n style: \"currency\",\r\n })}\r\n </span>\r\n {Number(Price - Discount)?.toLocaleString(\"pt-BR\", {\r\n currency: \"BRL\",\r\n currencyDisplay: \"symbol\",\r\n currencySign: \"standard\",\r\n style: \"currency\",\r\n })}\r\n </section>\r\n </span>\r\n <h1 id=\"header_title\" className=\"text-center w-full text-[#339c9b] font-bold text-xs px-4 md:text-sm\">\r\n Desconto de Laboratório\r\n </h1>\r\n </header>\r\n </>\r\n );\r\n}\r\n\r\nexport default Header;\r\n","import classNames from \"classnames\";\r\nimport React from \"react\";\r\n\r\nfunction Container({\r\n children,\r\n variant,\r\n}: {\r\n children: React.ReactNode;\r\n variant: \"simple\" | \"main\";\r\n}) {\r\n return (\r\n <main\r\n className={classNames({\r\n \"border-3 border-[#44c2c0] flex flex-col items-center justify-center min-w-[var(--min-container)] max-w-[var(--max-container)] w-full h-auto rounded-xl p-4 bg-white gap-4 relative\":\r\n variant === \"main\",\r\n \"w-full h-auto relative\": variant === \"simple\",\r\n })}\r\n data-testid=\"test_id_container\"\r\n data-variant={variant}\r\n id=\"container_pbm\"\r\n >\r\n {children}\r\n </main>\r\n );\r\n}\r\n\r\nexport default Container;\r\n","import classNames from \"classnames\";\r\nimport { usePBMStore } from \"../../libs/zustand/usePBM\";\r\n\r\nfunction Footer() {\r\n const { targetProduct, state } = usePBMStore();\r\n\r\n return (\r\n <footer className=\"w-full h-auto relative\" id=\"footer_pbm\">\r\n <section className={classNames(\"flex items-center w-full h-auto gap-4\", { \"justify-center\": targetProduct?.industryLogo, \"justify-start\": !targetProduct?.industryLogo })}>\r\n <section className=\"w-4/5 h-auto\">\r\n <h3 className=\"text-start font-semibold text-sm\">\r\n Economize com o benefício do laboratório.\r\n </h3>\r\n <p className=\"text-start font-normal text-sm\">\r\n Este produto tem preço exclusivo para clientes cadastrados no\r\n programa.\r\n </p>\r\n </section>\r\n {targetProduct?.industryLogo && (\r\n <img\r\n src={targetProduct.industryLogo}\r\n alt=\"parceiro\"\r\n className=\"w-1/5 min-w-20 h-auto aspect-auto rounded-xl\"\r\n loading=\"eager\"\r\n id=\"footer_industry_logo_pbm\"\r\n data-testid=\"footer_industry_logo_pbm\"\r\n />\r\n )}\r\n </section>\r\n </footer>\r\n );\r\n}\r\n\r\nexport default Footer;\r\n","import { z } from \"zod\";\r\n\r\nexport const validationSchema = z.object({\r\n securityNumber: z\r\n .string({\r\n required_error: 'CPF é obrigatório.',\r\n })\r\n .refine((doc) => {\r\n const replacedDoc = doc.replace(/\\D/g, '');\r\n return replacedDoc.length >= 11;\r\n }, 'CPF deve conter no mínimo 11 caracteres.')\r\n .refine((doc) => {\r\n const replacedDoc = doc.replace(/\\D/g, '');\r\n return !!Number(replacedDoc);\r\n }, 'CPF deve conter apenas números.'),\r\n\r\n coupon: z.string({ required_error: 'Cupom / ID do Cartão obrigatório.'}).optional()\r\n});\r\n\r\nexport type validationSchemaType = z.infer<typeof validationSchema>","export const toFormat = (value: string) => {\r\n const cleanedValue = value.replace(/\\D/g, '');\r\n\r\n if (cleanedValue.length <= 11) {\r\n return cleanedValue\r\n .replace(/(\\d{3})(\\d)/, '$1.$2')\r\n .replace(/(\\d{3})(\\d)/, '$1.$2')\r\n .replace(/(\\d{3})(\\d{1,2})/, '$1-$2')\r\n .replace(/(-\\d{2})\\d+?$/, '$1');\r\n }\r\n};","import {\r\n validationSchema,\r\n validationSchemaType,\r\n} from \"../../schema/validation-schema\";\r\nimport { toFormat } from \"../../utils/format\";\r\n\r\nimport classNames from \"classnames\";\r\nimport { zodResolver } from \"@hookform/resolvers/zod\";\r\nimport { useForm } from \"react-hook-form\";\r\n\r\nimport { ArrowRight } from \"lucide-react\";\r\nimport { Dispatch, SetStateAction, useState } from \"react\";\r\n\r\nimport { usePBMStore } from \"../../libs/zustand/usePBM\";\r\nimport { BenefitsWithDocument } from \"../../services/benefits-with-document\";\r\nimport Button from \"../UI/Button\";\r\n\r\ninterface IForm {\r\n setLoading: Dispatch<SetStateAction<boolean>>;\r\n}\r\n\r\nfunction Form({ setLoading }: IForm) {\r\n const { setSecurityNumber, setState, securityNumber, targetProduct, setUrlAcceptTerms, setUrlRegisterIndustry, setCardID } = usePBMStore();\r\n const [showCardIDField, setShowCardIDField] = useState<boolean>(false);\r\n\r\n const {\r\n handleSubmit,\r\n register,\r\n setValue,\r\n clearErrors,\r\n unregister,\r\n formState: { errors },\r\n } = useForm<validationSchemaType>({\r\n resolver: zodResolver(validationSchema),\r\n mode: 'onSubmit',\r\n defaultValues: {\r\n securityNumber: securityNumber || \"\",\r\n coupon: \"\",\r\n },\r\n });\r\n\r\n const onSubmitDefault = async (values: validationSchemaType) => {\r\n if (!showCardIDField) {\r\n setValue(\"coupon\", undefined, { shouldValidate: false });\r\n }\r\n\r\n if (showCardIDField && values.coupon != undefined) {\r\n setCardID(values.coupon);\r\n }\r\n\r\n setLoading(true);\r\n\r\n try {\r\n if (targetProduct === null) {\r\n console.error(\"PBMLOG: Product is not defined!\");\r\n return;\r\n }\r\n\r\n if (!targetProduct.productId) {\r\n console.error(\"PBMLOG: Product ID is not defined!\");\r\n return\r\n }\r\n\r\n if (!targetProduct.listPrice) {\r\n console.error(\"PBMLOG: List Price is not defined!\");\r\n return\r\n }\r\n\r\n const response = await BenefitsWithDocument({\r\n document: values.securityNumber.replace(/\\D/g, ''),\r\n products: [{\r\n productId: targetProduct.productId,\r\n ean: targetProduct.ean,\r\n requestedQuantity: 1,\r\n listPrice: targetProduct.listPrice,\r\n netPrice: targetProduct.netPrice ?? targetProduct.listPrice\r\n }]\r\n });\r\n\r\n if (response.success) {\r\n const status: Record<\"acceptance\" | \"industry registration\" | \"active\", \"isRegistered\" | \"isActivated\" | \"isInvalid\" | \"isEmpty\"> = {\r\n \"acceptance\": \"isInvalid\",\r\n \"industry registration\": \"isRegistered\",\r\n \"active\": \"isActivated\"\r\n }\r\n\r\n setSecurityNumber(values.securityNumber);\r\n setState(status[response.data.product[0].statusCustomer]);\r\n\r\n if (status[response.data.product[0].statusCustomer] === \"isInvalid\") {\r\n setUrlAcceptTerms(response.data.product[0].urlAcceptTerm || undefined)\r\n return;\r\n }\r\n\r\n if (status[response.data.product[0].statusCustomer] === \"isRegistered\") {\r\n setUrlRegisterIndustry(response.data.product[0].informativeLink);\r\n return;\r\n }\r\n }\r\n } catch (error) {\r\n console.error(\"PBMLOG: Error validating document -\", error);\r\n } finally {\r\n setLoading(false);\r\n };\r\n };\r\n\r\n return (\r\n <>\r\n <form\r\n onSubmit={handleSubmit(onSubmitDefault)}\r\n className={classNames(\r\n \"w-full h-auto flex items-center justify-center mb-0 transition-all duration-150\",\r\n { \"mb-4\": errors.securityNumber || (errors.coupon && showCardIDField), \"gap-2\": showCardIDField }\r\n )}\r\n id=\"form_security_number_pbm\"\r\n >\r\n <label\r\n htmlFor=\"cpf\"\r\n className=\"w-4/5 h-auto flex items-start flex-col justify-center relative py-2\"\r\n id=\"label_security_number_pbm\"\r\n >\r\n <input\r\n type=\"text\"\r\n className={classNames(\r\n \"w-full h-10 bg-gray-100 rounded-s-lg text-sm font-semibold focus:outline focus:outline-[#339c9b] focus:bg-white text-zinc-600 placeholder:text-zinc-600 px-4 placeholder:text-sm placeholder:font-semibold\",\r\n { \"outline outline-red-600\": errors.securityNumber, \"rounded-lg\": showCardIDField }\r\n )}\r\n placeholder=\"Digite seu CPF aqui...\"\r\n required\r\n maxLength={14}\r\n {...register(\"securityNumber\", {\r\n onChange: (e) => {\r\n const formatted = toFormat(e.target.value);\r\n setValue(\"securityNumber\", formatted as string, {\r\n shouldValidate: true,\r\n });\r\n },\r\n })}\r\n defaultValue={securityNumber || \"\"}\r\n id=\"input_security_number_pbm\"\r\n />\r\n {errors.securityNumber && (\r\n <span className=\"text-red-400 text-xs font-semibold absolute -bottom-3 left-2 text-nowrap\" id=\"security_number_form_error\">\r\n {errors.securityNumber.message}\r\n </span>\r\n )}\r\n </label>\r\n {showCardIDField && (\r\n <label\r\n htmlFor=\"coupon\"\r\n className=\"w-4/5 h-auto flex items-start flex-col justify-center relative py-2\"\r\n id=\"label_coupon_pbm\"\r\n >\r\n <input\r\n type=\"text\"\r\n className={classNames(\r\n \"w-full h-10 bg-gray-100 rounded-s-lg text-sm font-semibold focus:outline focus:outline-[#339c9b] focus:bg-white text-zinc-600 placeholder:text-zinc-600 px-4 placeholder:text-sm placeholder:font-semibold\",\r\n { \"outline outline-red-600\": errors.coupon, \"rounded-lg\": showCardIDField }\r\n )}\r\n placeholder=\"Cupom / ID do Cartão\"\r\n {...register(\"coupon\", {\r\n required: showCardIDField ? 'Cupom / ID do Cartão obrigatório.' : false,\r\n shouldUnregister: !showCardIDField,\r\n onChange: (e) => {\r\n setValue(\"coupon\", e.target.value, {\r\n shouldValidate: showCardIDField,\r\n });\r\n },\r\n })}\r\n id=\"input_coupon_pbm\"\r\n />\r\n {errors.coupon && (\r\n <span className=\"text-red-400 text-xs font-semibold absolute -bottom-3 left-2 text-nowrap\" id=\"coupon_form_error\">\r\n {errors.coupon.message}\r\n </span>\r\n )}\r\n </label>\r\n )}\r\n <button\r\n type=\"submit\"\r\n className={classNames(\r\n \"bg-emerald-500 w-1/5 h-10 rounded-e-lg flex items-center justify-center cursor-pointer\",\r\n { \"rounded-lg\": showCardIDField }\r\n )}\r\n id=\"button_submit_security_number_pbm\"\r\n >\r\n <ArrowRight size={24} color=\"white\" strokeWidth={2} />\r\n </button>\r\n </form>\r\n <section className=\"flex items-center-safe justify-between\">\r\n <Button\r\n className=\"bg-transparent p-0 pl-2 w-auto h-auto text-zinc-600 underline cursor-pointer hover:text-zinc-900 hover:bg-transparent flex items-center justify-start gap-1\"\r\n onClick={() => {\r\n const newValue = !showCardIDField;\r\n setShowCardIDField(newValue);\r\n if (!newValue) {\r\n // Quando esconder o campo, desregistrar, limpar o valor e os erros\r\n unregister(\"coupon\");\r\n clearErrors(\"coupon\");\r\n }\r\n }}\r\n id=\"check_benefits_button\"\r\n >\r\n <span>{!showCardIDField ? \"Possui Cupom / ID do Cartão?\" : \"Não possui Cupom / ID do Cartão??\"}</span>\r\n <ArrowRight size={16} className={classNames({ \"rotate-0\": !showCardIDField, \"rotate-180\": showCardIDField })} />\r\n </Button>\r\n <Button\r\n className=\"bg-transparent p-0 pl-2 w-auto h-auto text-zinc-600 underline cursor-pointer hover:text-zinc-900 hover:bg-transparent flex items-center justify-start gap-1\"\r\n onClick={() => setState(\"isPreview\")}\r\n id=\"check_benefits_button\"\r\n >\r\n <span>Consultar Benefícios</span>\r\n <ArrowRight size={16} />\r\n </Button>\r\n </section>\r\n </>\r\n );\r\n}\r\n\r\nexport default Form;\r\n","import Cookies from \"js-cookie\";\r\nimport { IRequestDefault } from \"../types/requests\";\r\n\r\nexport interface IProductWithDocumentData {\r\n id: number;\r\n ean: number;\r\n authorizedQuantity: number;\r\n discountValue: string;\r\n discountPercentual: number;\r\n authorizer: string;\r\n industryName: string;\r\n requestCoupon: string;\r\n requestHolderId: string;\r\n comboId: number;\r\n grossPrice: number;\r\n allowsAdhesion: string;\r\n discountMaxNewPatient: number;\r\n informativeMessage: string;\r\n priceWithBenefit: number;\r\n urlAcceptTerm: string;\r\n informativeLink: string;\r\n productId: number;\r\n statusCustomer: \"acceptance\" | \"industry registration\" | \"active\";\r\n}\r\n\r\ninterface IResponseBenefitsWithDocument extends IRequestDefault {\r\n data: { product: IProductWithDocumentData[] };\r\n}\r\n\r\ninterface ProductRequestBody {\r\n productId: number;\r\n ean: string;\r\n requestedQuantity: number;\r\n listPrice: number;\r\n netPrice: number;\r\n}\r\n\r\ninterface IBenefitsWithDocumentParams {\r\n document: string;\r\n products: ProductRequestBody[];\r\n}\r\n\r\nexport const BenefitsWithDocument = async ({ document, products }: IBenefitsWithDocumentParams): Promise<IResponseBenefitsWithDocument> => {\r\n const API_URL = import.meta.env.VITE_API_URL;\r\n\r\n if (!API_URL) {\r\n throw new Error('API URL is not defined in environment variables');\r\n }\r\n\r\n const AUTH_TOKEN = Cookies.get(\"pbm-token\");\r\n\r\n if (!AUTH_TOKEN) {\r\n throw new Error('Token is not defined in cookies or is expired');\r\n }\r\n\r\n const response = await fetch(`${API_URL}/products/benefitByDocument`, {\r\n method: 'POST',\r\n headers: {\r\n Authorization: `Bearer ${AUTH_TOKEN}`,\r\n 'Content-Type': 'application/json',\r\n },\r\n body: JSON.stringify({ consumer: { document }, products })\r\n })\r\n\r\n const dataResponse: IResponseBenefitsWithDocument = await response.json();\r\n\r\n if (!dataResponse.success) {\r\n throw new Error(dataResponse.message || 'Failed to fetch document validation');\r\n }\r\n\r\n return dataResponse;\r\n}","import classNames from \"classnames\";\r\nimport React, { ButtonHTMLAttributes } from \"react\";\r\n\r\ninterface ButtonProps extends ButtonHTMLAttributes<HTMLButtonElement> {\r\n children: React.ReactNode;\r\n}\r\n\r\nfunction Button(props: ButtonProps) {\r\n return (\r\n <button\r\n {...props}\r\n className={classNames(\r\n \"w-3xs cursor-pointer h-10 rounded-lg bg-emerald-500 hover:bg-emerald-400 text-white text-sm font-semibold transition-colors\",\r\n props.className\r\n )}\r\n >\r\n {props.children}\r\n </button>\r\n );\r\n}\r\n\r\nexport default Button;\r\n","interface LoadingProps {\r\n textColor?: string;\r\n}\r\n\r\nfunction Loading({ textColor }: LoadingProps) {\r\n return (\r\n <main className=\"flex items-center justify-center gap-4\" id=\"loading_pbm\">\r\n <div\r\n data-testid=\"test_id_spin\"\r\n className=\"w-8 h-8 border-4 border-t-gray-700 border-gray-300 rounded-full animate-spin\"\r\n id=\"loading_spin\"\r\n ></div>\r\n <p\r\n className={\"text-sm font-semibold text-start text-zinc-900\"}\r\n style={{ color: textColor }}\r\n id=\"loading_label\"\r\n >\r\n Um momento... estamos verificando seus dados.\r\n </p>\r\n </main>\r\n );\r\n}\r\n\r\nexport default Loading;\r\n","import { useEffect, useState } from \"react\";\r\nimport Title from \"../UI/Title\";\r\nimport Item from \"./Item\";\r\nimport { usePBMStore } from \"../../libs/zustand/usePBM\";\r\nimport Button from \"../UI/Button\";\r\nimport { CheckBenefistWithoutDocument } from \"../../services/benefits-without-document\";\r\nimport { IBenefitsItem } from \"../../types/globals\";\r\nimport { BenefitsWithDocument } from \"../../services/benefits-with-document\";\r\n\r\nfunction BenefitsTable() {\r\n const { securityNumber, setState, state, targetProduct, customLoginUrl, isAuthenticatedShopper } = usePBMStore();\r\n const [selectedDiscout, setSelectedDiscount] = useState<string | null>(null);\r\n const [loading, setLoading] = useState<boolean>(true);\r\n const [benefitsItems, setBenefitsItems] = useState<IBenefitsItem[] | undefined>();\r\n\r\n useEffect(() => {\r\n const fetchDicountsWithoutDocument = async () => {\r\n if (!targetProduct?.productId) {\r\n console.error(\"PBMLOG: Product ID is not defined on targetProduct\");\r\n return;\r\n }\r\n\r\n if (!targetProduct.ean) {\r\n console.error(\"PBMLOG: EAN is not defined on targetProduct\");\r\n return;\r\n }\r\n\r\n if (!targetProduct.listPrice) {\r\n console.error(\"PBMLOG: List Price is not defined on targetProduct\");\r\n return;\r\n }\r\n\r\n if (!targetProduct.price) {\r\n console.error(\"PBMLOG: Price is not defined on targetProduct\");\r\n return;\r\n }\r\n\r\n try {\r\n const data = {\r\n productId: Number(targetProduct.productId),\r\n ean: targetProduct.ean,\r\n requestedQuantity: 1,\r\n listPrice: targetProduct.listPrice,\r\n netPrice: targetProduct.price\r\n }\r\n\r\n const response = await CheckBenefistWithoutDocument({ products: [data] });\r\n\r\n if (response.success && response.data) {\r\n setBenefitsItems(response.data)\r\n } else {\r\n setBenefitsItems(undefined)\r\n }\r\n } catch (error) {\r\n setBenefitsItems(undefined)\r\n console.error(error);\r\n } finally {\r\n setLoading(false);\r\n }\r\n }\r\n\r\n const fetchDiscountWithDocument = async () => {\r\n if (!securityNumber) {\r\n console.error(\"PBMLOG: Document is not defined\");\r\n return;\r\n }\r\n\r\n if (!targetProduct?.productId) {\r\n console.error(\"PBMLOG: Product ID is not defined on targetProduct\");\r\n return;\r\n }\r\n\r\n if (!targetProduct.ean) {\r\n console.error(\"PBMLOG: EAN is not defined on targetProduct\");\r\n return;\r\n }\r\n\r\n if (!targetProduct.listPrice) {\r\n console.error(\"PBMLOG: List Price is not defined on targetProduct\");\r\n return;\r\n }\r\n\r\n if (!targetProduct.price) {\r\n console.error(\"PBMLOG: Price is not defined on targetProduct\");\r\n return;\r\n }\r\n\r\n try {\r\n const data = {\r\n productId: Number(targetProduct.productId),\r\n ean: targetProduct.ean,\r\n requestedQuantity: 1,\r\n listPrice: targetProduct.listPrice,\r\n netPrice: targetProduct.price\r\n }\r\n\r\n const response = await BenefitsWithDocument({ document: securityNumber, products: [data] });\r\n\r\n if (response.success && response.data) {\r\n setBenefitsItems(response.data.product)\r\n } else {\r\n setBenefitsItems(undefined)\r\n }\r\n } catch (error) {\r\n setBenefitsItems(undefined)\r\n console.error(error);\r\n } finally {\r\n setLoading(false);\r\n }\r\n }\r\n\r\n state === \"isActivated\" ?\r\n fetchDiscountWithDocument() :\r\n fetchDicountsWithoutDocument();\r\n }, [])\r\n\r\n if (loading) {\r\n return (\r\n <main className=\"flex items-center justify-center gap-4\" id=\"loading_pbm\">\r\n <div\r\n data-testid=\"test_id_spin\"\r\n className=\"w-8 h-8 border-4 border-t-gray-700 border-gray-300 rounded-full animate-spin\"\r\n id=\"loading_spin\"\r\n ></div>\r\n <p\r\n className={\"text-sm font-semibold text-start text-zinc-900\"}\r\n id=\"loading_label\"\r\n >\r\n Buscando beneficios disponíveis...\r\n </p>\r\n </main>\r\n )\r\n }\r\n\r\n return (\r\n <section\r\n className=\"flex items-start justify-center gap-4 w-full h-auto flex-col\"\r\n id=\"benefits_table_pbm\"\r\n >\r\n <Title>Descontos disponíveis:</Title>\r\n\r\n <form\r\n className=\"flex flex-col items-center justify-start w-full gap-4.5\"\r\n id=\"form_benefits_table_pbm\"\r\n onSubmit={(e) => e.preventDefault()}\r\n >\r\n {!benefitsItems && (\r\n <p className=\"text-sm font-semibold text-start text-zinc-900\" id=\"benefits_empty_pbm\">Não foi possível encontrar benefícios para esse produto.</p>\r\n )}\r\n\r\n {benefitsItems && benefitsItems.map((item, index) => {\r\n const ID_INPUT = \"unity_quantity_\" + item.authorizedQuantity;\r\n\r\n return (\r\n <Item\r\n key={index}\r\n data={item}\r\n checked={selectedDiscout === ID_INPUT}\r\n onChange={() => setSelectedDiscount(ID_INPUT)}\r\n />\r\n );\r\n })}\r\n </form>\r\n\r\n {state === \"isPreview\" && (\r\n <Button\r\n onClick={() => setState(\"isEmpty\")}\r\n className=\"bg-transparent p-0 w-auto h-auto text-zinc-600 cursor-pointer hover:text-zinc-900 hover:bg-transparent text-start\"\r\n id=\"unauthorized_benefits_button\"\r\n >\r\n Atenção: Não é possível utilizar os benefícos sem realizar a consulta\r\n do CPF e o Login, por favor{\" \"}\r\n <span className=\"underline\">\r\n insira seu cpf para utilizar os benefícios\r\n </span>\r\n </Button>\r\n )}\r\n\r\n {state === \"isActivated\" && (\r\n <>\r\n {!isAuthenticatedShopper && <Button\r\n onClick={() => window.location.href = customLoginUrl || \"/login\"}\r\n className=\"bg-transparent p-0 pl-2 w-auto h-auto text-zinc-600 cursor-pointer hover:text-zinc-900 hover:bg-transparent text-start\"\r\n id=\"login\"\r\n >\r\n <span className=\"underline\">Por favor, faça o Login para aproveitar os benefícios!</span>\r\n </Button>}\r\n\r\n <Button\r\n onClick={() => setState(\"isEmpty\")}\r\n className=\"bg-transparent p-0 pl-2 w-auto h-auto text-zinc-600 cursor-pointer hover:text-zinc-900 hover:bg-transparent text-start\"\r\n id=\"change_security_number\"\r\n >\r\n <span className=\"underline\">Deseja editar o cpf digitado?</span>\r\n </Button>\r\n </>\r\n )}\r\n </section>\r\n );\r\n}\r\n\r\nexport default BenefitsTable;\r\n","import classNames from \"classnames\";\r\nimport React, { HTMLAttributes } from \"react\";\r\n\r\ninterface TitleProps extends HTMLAttributes<HTMLTitleElement> {\r\n children: React.ReactNode;\r\n textColor?: string;\r\n textSize?: string;\r\n textAlign?: \"start\" | \"center\" | \"end\";\r\n}\r\n\r\nfunction Title(props: TitleProps) {\r\n return (\r\n <h2\r\n className={classNames(\r\n \"text-start font-semibold text-sm text-zinc-900\",\r\n props.className\r\n )}\r\n style={{ color: props.textColor, fontSize: props.textSize, textAlign: props.textAlign }}\r\n data-testid=\"test_id_title\"\r\n id=\"title_pbm\"\r\n >\r\n {props.children}\r\n </h2>\r\n );\r\n}\r\n\r\nexport default Title;\r\n","import { create, StateCreator } from \"zustand\";\r\nimport { IModal } from \"../../types/globals\";\r\n\r\ninterface ModalDataType {\r\n modal: IModal;\r\n}\r\n\r\nexport interface useModal extends ModalDataType {\r\n setModal: (\r\n modal: useModal[\"modal\"]\r\n ) => void;\r\n}\r\n\r\nconst initialModalState: ModalDataType = {\r\n modal: {\r\n id: \"\",\r\n open: false\r\n },\r\n};\r\n\r\n// ✅ TIPANDO a função corretamente com StateCreator\r\nconst createModalStore: StateCreator<useModal> = (set) => ({\r\n ...initialModalState,\r\n\r\n setModal: (\r\n modal: useModal[\"modal\"]\r\n ) => set({ modal }),\r\n});\r\n\r\n// React hook (usado dentro de componentes React)\r\nexport const useModal = create<useModal>(createModalStore);\r\n","import { usePBMStore } from \"../../libs/zustand/usePBM\";\r\nimport { useModal } from \"../../libs/zustand/useModal\";\r\n\r\nimport { FormEvent, useCallback, useEffect } from \"react\";\r\nimport { IBenefitsItem } from \"../../types/globals\";\r\nimport classNames from \"classnames\";\r\nimport { Icons } from \"../UI/Icons\";\r\n\r\ninterface ItemProps {\r\n data: IBenefitsItem;\r\n onChange: VoidFunction;\r\n checked: boolean;\r\n}\r\n\r\nfunction Item({ data, onChange, checked }: ItemProps) {\r\n const { setAvailableDiscountSelected, state, isAuthenticatedShopper } = usePBMStore();\r\n const { setModal } = useModal();\r\n\r\n const ID_INPUT = \"unity_quantity_\" + data.authorizedQuantity;\r\n\r\n const decimalDiscount = data.discountPercentual / 100;\r\n\r\n const unitDiscountValue = data.grossPrice * decimalDiscount;\r\n\r\n\r\n const discountValue = unitDiscountValue * data.authorizedQuantity;\r\n\r\n const totalPriceProductWithDiscountBenefit =\r\n (data.grossPrice * data.authorizedQuantity) - discountValue;\r\n\r\n const updateStorageData = useCallback(() => {\r\n if (checked) {\r\n // Arredonda para 2 casas decimais\r\n const roundToTwoDecimals = (value: number) => Math.round(value * 100) / 100;\r\n\r\n setAvailableDiscountSelected({\r\n discount: {\r\n total: roundToTwoDecimals(discountValue),\r\n unit: roundToTwoDecimals(unitDiscountValue),\r\n },\r\n quantity: data.authorizedQuantity,\r\n totalPrice: roundToTwoDecimals(totalPriceProductWithDiscountBenefit),\r\n grossPrice: data.grossPrice\r\n });\r\n }\r\n }, [\r\n checked,\r\n data.authorizedQuantity,\r\n setAvailableDiscountSelected,\r\n discountValue,\r\n totalPriceProductWithDiscountBenefit,\r\n unitDiscountValue,\r\n ]);\r\n\r\n useEffect(() => {\r\n updateStorageData();\r\n }, [updateStorageData]);\r\n\r\n const handleChange = (e: FormEvent) => {\r\n if (!isAuthenticatedShopper && state === \"isActivated\") {\r\n setModal({\r\n id: \"ShopperIsNotAuthenticated\",\r\n open: true\r\n });\r\n return;\r\n }\r\n\r\n onChange();\r\n }\r\n\r\n return (\r\n <label\r\n htmlFor={ID_INPUT}\r\n className={classNames(\r\n \"label_benefits w-full flex items-center justify-start bg-zinc-300/60 border border-zinc-400/50 px-4 py-2 hover:bg-zinc-300 transition-colors rounded-lg gap-1\",\r\n { \"cursor-not-allowed\": state === \"isPreview\", \"cursor-pointer\": state === \"isActivated\" }\r\n )}\r\n id={\"label_benefits_\" + ID_INPUT}\r\n >\r\n <input\r\n type=\"radio\"\r\n name=\"benefits_discount\"\r\n id={ID_INPUT}\r\n className=\"hidden\"\r\n checked={checked}\r\n onChange={handleChange}\r\n disabled={state === \"isPreview\"}\r\n />\r\n\r\n {!checked ? (\r\n <Icons.CheckOFF size={20} />\r\n ) : (\r\n <Icons.CheckON size={20} />\r\n )}\r\n\r\n <span className=\"text-zinc-900 font-semibold text-sm\">\r\n {data.authorizedQuantity}un\r\n </span>\r\n\r\n <section className=\"ml-auto relative gap-2 flex items-center-safe justify-end-safe\">\r\n <span className=\"text-white -top-4 py-0.5 font-semibold text-xs bg-[#32b316] px-2 w-auto text-nowrap rounded-2xl -right-3\">\r\n {discountValue.toLocaleString(\"pt-BR\", {\r\n currency: \"BRL\",\r\n currencyDisplay: \"symbol\",\r\n currencySign: \"standard\",\r\n style: \"currency\",\r\n })}{\" \"}\r\n OFF\r\n </span>\r\n <strong className=\"text-zinc-900 font-semibold text-sm text-center\">\r\n {totalPriceProductWithDiscountBenefit.toLocaleString(\"pt-BR\", {\r\n currency: \"BRL\",\r\n currencyDisplay: \"symbol\",\r\n currencySign: \"standard\",\r\n style: \"currency\",\r\n })}\r\n </strong>\r\n </section>\r\n </label>\r\n );\r\n}\r\n\r\nexport default Item;\r\n","import * as React from \"react\"\r\n\r\nfunction CheckON({ size }: { size: number }) {\r\n return (\r\n <svg\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n data-name=\"Camada 1\"\r\n viewBox=\"0 0 500 500\"\r\n width={size}\r\n height={size}\r\n >\r\n <path\r\n d=\"M421.44 78.56C375.64 32.77 314.76 7.55 250 7.55S124.36 32.77 78.56 78.56C32.77 124.36 7.55 185.24 7.55 250s25.22 125.64 71.01 171.44c45.8 45.79 106.68 71.01 171.44 71.01s125.64-25.22 171.44-71.01c45.79-45.8 71.01-106.68 71.01-171.44s-25.22-125.64-71.01-171.44zm-49.17 121.7L242.88 334.63c-8.98 9.29-23.57 10.17-33.59 2.02l-79.63-64.7c-10.69-8.67-12.33-24.38-3.66-35.07 8.67-10.69 24.38-12.33 35.07-3.65l61.9 50.39L336.5 165.74c4.4-4.75 10.48-7.59 16.95-7.93a24.88 24.88 0 0118.83 7.26c9.72 9.72 9.71 25.48 0 35.19z\"\r\n fill=\"#229b00\"\r\n />\r\n </svg>\r\n )\r\n}\r\nfunction CheckOFF({ size }: { size: number }) {\r\n return (\r\n <svg\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n data-name=\"Camada 1\"\r\n viewBox=\"0 0 500 500\"\r\n width={size}\r\n height={size}\r\n >\r\n <circle cx={250} cy={250} r={237.45} fill=\"#fff\" />\r\n <path\r\n d=\"M250 492.45c-64.76 0-125.64-25.22-171.44-71.01C32.77 375.64 7.55 314.76 7.55 250S32.77 124.36 78.56 78.56C124.36 32.77 185.24 7.55 250 7.55s125.64 25.22 171.44 71.01c45.79 45.79 71.01 106.68 71.01 171.44s-25.22 125.64-71.01 171.44c-45.79 45.79-106.68 71.01-171.44 71.01zm0-474.9C121.83 17.55 17.55 121.83 17.55 250S121.83 482.45 250 482.45 482.45 378.17 482.45 250 378.17 17.55 250 17.55z\"\r\n fill=\"#d8d8d8\"\r\n />\r\n </svg>\r\n )\r\n}\r\n\r\nexport const Icons = {\r\n CheckON,\r\n CheckOFF\r\n}","import Cookies from \"js-cookie\";\r\nimport { IRequestDefault } from \"../types/requests\";\r\n\r\ninterface ICheckBenefitsWithoutDocumentData {\r\n id: number;\r\n ean: number;\r\n authorizedQuantity: number;\r\n discountValue: string;\r\n discountPercentual: number;\r\n authorizer: string;\r\n industryName: string;\r\n requestCoupon: string;\r\n requestHolderId: string;\r\n comboId: number;\r\n grossPrice: number;\r\n allowsAdhesion: string;\r\n discountMaxNewPatient: number;\r\n informativeMessage: string;\r\n priceWithBenefit: number;\r\n}\r\n\r\ninterface ICheckBenefitsWithoutDocumentResponse extends IRequestDefault {\r\n data: ICheckBenefitsWithoutDocumentData[];\r\n}\r\n\r\ninterface IProductsCheckBenefits {\r\n productId: number;\r\n ean: string;\r\n requestedQuantity: number;\r\n listPrice: number;\r\n}\r\n\r\ninterface ICheckBenefistWithoutDocumentParams {\r\n products: IProductsCheckBenefits[];\r\n}\r\n\r\nexport const CheckBenefistWithoutDocument = async ({ products }: ICheckBenefistWithoutDocumentParams): Promise<ICheckBenefitsWithoutDocumentResponse> => {\r\n const API_URL = import.meta.env.VITE_API_URL;\r\n\r\n if (!API_URL) {\r\n throw new Error('API URL is not defined in environment variables');\r\n }\r\n\r\n const AUTH_TOKEN = Cookies.get(\"pbm-token\");\r\n\r\n if (!AUTH_TOKEN) {\r\n throw new Error('Token is not defined in cookies or is expired');\r\n }\r\n\r\n const response = await fetch(`${API_URL}/products/genericBenefit`, {\r\n method: 'POST',\r\n headers: {\r\n Authorization: `Bearer ${AUTH_TOKEN}`,\r\n 'Content-Type': 'application/json',\r\n },\r\n body: JSON.stringify({ products })\r\n })\r\n\r\n const dataResponse: ICheckBenefitsWithoutDocumentResponse = await response.json();\r\n\r\n if (!dataResponse.success) {\r\n throw new Error(dataResponse.message || 'Failed to fetch benefits without document');\r\n }\r\n\r\n return dataResponse;\r\n}","import classNames from \"classnames\";\r\nimport React, { HTMLAttributes } from \"react\";\r\n\r\ninterface TextProps extends HTMLAttributes<HTMLParagraphElement> {\r\n children: React.ReactNode;\r\n textColor?: string;\r\n textSize?: string;\r\n textAlign?: \"start\" | \"center\" | \"end\";\r\n}\r\n\r\nfunction Text(props: TextProps) {\r\n return (\r\n <p\r\n className={classNames(\r\n \"font-normal text-sm text-zinc-900\",\r\n props.textAlign && `text-${props.textAlign}`,\r\n props.className\r\n )}\r\n style={{ color: props.textColor, fontSize: props.textSize, textAlign: props.textAlign }}\r\n data-testid=\"test_id_text\"\r\n id=\"text_pbm\"\r\n >\r\n {props.children}\r\n </p>\r\n );\r\n}\r\n\r\nexport default Text;\r\n","import { ILinkHref } from \"../../../types/globals\";\r\nimport classNames from \"classnames\";\r\nimport React from \"react\";\r\nimport { getParams } from \"../../../utils/getParams\";\r\nimport { usePBMStore } from \"../../../libs/zustand/usePBM\";\r\n\r\ninterface LinkProps {\r\n className?: string;\r\n children: React.ReactNode;\r\n href: ILinkHref | string;\r\n}\r\n\r\nfunction Link(props: LinkProps) {\r\n const { setState } = usePBMStore();\r\n\r\n return (\r\n <a\r\n {...props}\r\n target=\"_blank\"\r\n href={\r\n typeof props.href === \"string\"\r\n ? props.href\r\n : props.href.pathname + getParams(props.href.param)\r\n }\r\n className={classNames(\r\n \"w-3xs cursor-pointer h-10 rounded-lg bg-emerald-500 hover:bg-emerald-400 text-white text-sm font-semibold transition-colors flex items-center justify-center\",\r\n props.className\r\n )}\r\n data-testid=\"test_id_link\"\r\n id=\"link_pbm\"\r\n onClick={() => setState(\"isEmpty\")}\r\n >\r\n {props.children}\r\n </a>\r\n );\r\n}\r\n\r\nexport default Link;\r\n","export const getParams = (\r\n params: { [key: string]: string | number } | undefined\r\n) => {\r\n if (params === undefined) return \"\";\r\n\r\n return (\r\n \"?\" +\r\n Object.keys(params)\r\n .map((paramter) => paramter + \"=\" + params[paramter])\r\n .join(\"&\")\r\n );\r\n};","import Title from \"../UI/Title\";\r\nimport Text from \"../UI/Text\";\r\n// import Button from \"../UI/Button\";\r\n// import Iframe from \"../Iframe\";\r\n\r\n// import { useState } from \"react\";\r\nimport { usePBMStore } from \"../../libs/zustand/usePBM\";\r\nimport Link from \"../UI/Link\";\r\n\r\nfunction SecurityNumberInvalid({ textColor }: { textColor?: string }) {\r\n // const [openModal, setOpenModal] = useState<boolean>(false);\r\n const { urlAcceptTerms } = usePBMStore();\r\n return (\r\n <section\r\n data-testid=\"test_id_invalid\"\r\n className=\"flex items-end justify-center gap-2 w-full h-auto flex-col border-y border-zinc-300 py-6\"\r\n id=\"security_number_invalid_container_pbm\"\r\n >\r\n <Title className=\"w-full\" textColor={textColor}>\r\n CPF não cadastrado.\r\n </Title>\r\n <Text className=\"w-full\" textColor={textColor}>\r\n Conclua seu cadastro para habilitar o benefício. <br />\r\n Ao clicar em “Aceitar os termos”, você irá para uma página externa. Aceite os termos e volte para continuar.\r\n </Text>\r\n {/* <Button\r\n data-testid=\"test_id_openiframe\"\r\n onClick={() => setOpenModal(true)}\r\n id=\"button_accept_terms_pbm\"\r\n >\r\n Aceitar os termos\r\n </Button> */}\r\n\r\n <Link\r\n href={urlAcceptTerms || \"\"}\r\n >\r\n Aceitar os termos\r\n </Link>\r\n\r\n {/* <Iframe\r\n url={urlAcceptTerms || \"\"}\r\n title=\"Aceitar termos PBM\"\r\n openModal={openModal}\r\n setOpenModal={setOpenModal}\r\n /> */}\r\n </section>\r\n );\r\n}\r\n\r\nexport default SecurityNumberInvalid;\r\n","import Header from \"./components/Header\";\nimport Container from \"./components/UI/Container\";\nimport Footer from \"./components/Footer\";\nimport Form from \"./components/Form\";\nimport Loading from \"./components/UI/Loading\";\nimport Button from \"./components/UI/Button\";\nimport BenefitsTable from \"./components/BenefitsTable\";\nimport SecurityNumberInvalid from \"./components/SecurityNumberInvalid\";\n\nimport { useCallback, useEffect, useState } from \"react\";\nimport SecurityNumberRegitered from \"./components/SecurityNumberRegitered\";\nimport { GetAuthorization } from \"./services/authorization\";\nimport { RefreshCw } from \"lucide-react\";\nimport { usePBMStore } from \"./libs/zustand/usePBM\";\nimport { GetProductByEAN } from \"./services/get-product-by-ean\";\nimport Title from \"./components/UI/Title\";\nimport Text from \"./components/UI/Text\";\nimport Skeleton from '@mui/material/Skeleton';\nimport Modal from \"./components/Modal\";\nimport { GetProductsWithBenefits } from \"./services/get-list-products\";\n\nexport interface PBMProps {\n originalProductPrice: number | string;\n clientID: string;\n eanProduct: string;\n isAuthenticatedShopper: boolean;\n customLoginUrl?: string;\n}\n\nfunction PBM({\n originalProductPrice,\n clientID,\n eanProduct,\n isAuthenticatedShopper,\n customLoginUrl,\n}: PBMProps) {\n const formatedOriginalProductPrice = Number(\n String(originalProductPrice).replace(',', '.')\n );\n\n const [isReady, setIsReady] = useState<boolean>(false);\n const [loading, setLoading] = useState<boolean>(false);\n const { state, setTargetProduct, targetProduct, setIsAuthenticatedShopper, setCustomLoginUrl } = usePBMStore();\n const [EanProductExist, setEanProductExist] = useState<boolean>(true);\n const [IsValid, setIsValid] = useState<boolean>(false);\n\n const fetchValidateProduct = useCallback(async () => {\n try {\n const response = await GetProductsWithBenefits();\n\n if (response.success) {\n const data = response.data;\n\n const hasProductInList = data.some(product => product.ean == eanProduct);\n setIsValid(hasProductInList);\n }\n } catch (error) {\n console.error(error);\n }\n }, [eanProduct, IsValid])\n\n const fetchProductByEan = async () => {\n try {\n if (!IsValid) return;\n\n if (!eanProduct) {\n console.error(\"PBMLOG: Ean is not defined.\")\n setEanProductExist(false);\n return\n }\n\n const response = await GetProductByEAN({ PRODUCT_EAN: eanProduct });\n\n if (response.success && response.data) {\n setEanProductExist(true);\n\n const { pbm, sku, ...targetProductNewData } = response.data;\n\n setTargetProduct({\n ...targetProduct,\n ...targetProductNewData,\n productId: Number(targetProductNewData.productId),\n informativeMessage: pbm.informativeMessage ?? \"\",\n discountMax: pbm.discountMax ?? 0,\n industryLogo: pbm.imageLink ?? undefined,\n ean: eanProduct\n })\n\n setIsAuthenticatedShopper(isAuthenticatedShopper);\n setCustomLoginUrl(customLoginUrl)\n }\n } catch (error) {\n console.error(error);\n } finally {\n setIsReady(true)\n }\n }\n\n const handleAuthorizationRequest = useCallback(async () => {\n try {\n const response = await GetAuthorization({ clientID: clientID });\n\n if (response.success) {\n fetchValidateProduct();\n fetchProductByEan();\n } else {\n console.error(\"PBMLOG: Authorization failed!\");\n }\n } catch (error) {\n console.error(\"Error fetching authorization:\", error);\n }\n }, [clientID, IsValid]);\n\n useEffect(() => {\n handleAuthorizationRequest();\n }, [handleAuthorizationRequest]);\n\n if (!isReady) {\n return (\n <Skeleton variant=\"rectangular\" style={{ borderRadius: \"12px\" }} width={460} height={358} />\n )\n }\n\n if (!EanProductExist) {\n return (\n <div id=\"pbm-library-root\">\n <Container variant=\"main\" >\n <Title>Erro ao Aplicar o Benefício</Title>\n <Text textAlign=\"center\">O produto não foi encontrado no sistema. <br /> Por favor, tente novamente mais tarde ou contate o suporte.</Text>\n <Button\n className=\"bg-transparent p-0 pl-2 w-auto h-auto text-zinc-600 underline cursor-pointer hover:text-zinc-900 hover:bg-transparent flex items-center justify-start gap-1\"\n onClick={() => window.location.reload()}\n id=\"check_benefits_button\"\n >\n <span>Tentar novamente</span>\n <RefreshCw size={16} />\n </Button>\n </Container>\n </div>\n )\n }\n\n if (!IsValid) {\n return;\n }\n\n return (\n <div id=\"pbm-library-root\">\n <Container variant=\"main\">\n <Header originalProductPrice={formatedOriginalProductPrice || 0} />\n\n <Container variant=\"simple\">\n {loading ? (\n <Loading />\n ) : (\n <>\n {state === \"isEmpty\" && <Form setLoading={setLoading} />}\n {state === \"isInvalid\" && <SecurityNumberInvalid />}\n {state === \"isRegistered\" && <SecurityNumberRegitered />}\n {(state === \"isActivated\" || state === \"isPreview\") && <BenefitsTable />}\n </>\n )}\n </Container>\n\n <Footer />\n </Container>\n\n <Modal ID=\"ShopperIsNotAuthenticated\" />\n </div>\n );\n}\n\nexport default PBM;\n","import Title from \"../UI/Title\";\r\nimport Text from \"../UI/Text\";\r\nimport Link from \"../UI/Link\";\r\nimport { usePBMStore } from \"../../libs/zustand/usePBM\";\r\n\r\nfunction SecurityNumberRegitered({ textColor }: { textColor?: string }) {\r\n const { urlRegisterIndustry } = usePBMStore();\r\n\r\n return (\r\n <section\r\n data-testid=\"test_id_registered\"\r\n className=\"flex items-end justify-center gap-2 w-full h-auto flex-col border-y border-zinc-300 py-6\"\r\n id=\"security_number_registered_container_pbm\"\r\n >\r\n <Title className=\"w-full\" textColor={textColor}>\r\n Ops, seu CPF ainda não está habilitado para este produto.\r\n </Title>\r\n <Text className=\"w-full\" textColor={textColor}>\r\n Para ativar o benefício, clique em “Ativar CPF” e conclua a etapa na página externa. Depois, é só voltar para continuar — vamos aguardar você aqui.\r\n </Text>\r\n <Link\r\n href={urlRegisterIndustry || \"\"}\r\n >\r\n Ativar CPF\r\n </Link>\r\n </section>\r\n );\r\n}\r\n\r\nexport default SecurityNumberRegitered;\r\n","import Cookies from \"js-cookie\";\r\n\r\nexport const GetAuthorization = async ({ clientID }: { clientID: string }) => {\r\n const response = await fetch(\r\n 'https://pbm-auth-serverless.vercel.app/api/auth',\r\n {\r\n method: 'POST',\r\n headers: {\r\n 'Content-Type': 'application/json'\r\n },\r\n credentials: 'include',\r\n body: JSON.stringify({\r\n clientId: clientID\r\n })\r\n }\r\n );\r\n\r\n const data = await response.json();\r\n\r\n if (!data.success) {\r\n throw new Error('Authorization failed');\r\n }\r\n\r\n Cookies.set('pbm-token', data.tokens.token, {\r\n secure: true,\r\n sameSite: 'Strict'\r\n });\r\n\r\n Cookies.set('pbm-token-refresh', data.tokens.refreshToken, {\r\n secure: true,\r\n sameSite: 'Strict'\r\n });\r\n\r\n return data;\r\n};","import Cookies from \"js-cookie\";\r\nimport { IRequestDefault } from \"../types/requests\";\r\n\r\ninterface IPBM {\r\n source: string;\r\n programName: string;\r\n industryName: string;\r\n discountMax: number;\r\n discountMin: number;\r\n informativeMessage: string;\r\n discountMaxNewPatient: number;\r\n discountMinNewPatient: number;\r\n discountFirstBox: number;\r\n suggestedPriceValue: string;\r\n imageLink: string | null;\r\n eanCombos: number | null;\r\n qtyDiscountMax: number;\r\n requestCoupon: string | null;\r\n}\r\n\r\nexport interface IDataRequestListProducts {\r\n productId: string;\r\n productName: string;\r\n sku: string;\r\n skuId: string;\r\n ean: string;\r\n price: number;\r\n listPrice: number;\r\n stockBalance: number;\r\n availabilityText: string;\r\n brandName: string;\r\n categoryName: string;\r\n pbm: IPBM;\r\n}\r\n\r\ninterface IResponseGetProducts extends IRequestDefault {\r\n data: IDataRequestListProducts\r\n}\r\n\r\nexport const GetProductByEAN = async ({ PRODUCT_EAN }: { PRODUCT_EAN: string }): Promise<IResponseGetProducts> => {\r\n const API_URL = import.meta.env.VITE_API_URL;\r\n\r\n const AUTH_TOKEN = Cookies.get(\"pbm-token\");\r\n\r\n if (!AUTH_TOKEN) {\r\n throw new Error('Token is not defined in cookies or is expired');\r\n }\r\n\r\n const response = await fetch(`${API_URL}/products/ean/${PRODUCT_EAN}`, {\r\n method: 'GET',\r\n headers: {\r\n Authorization: `Bearer ${AUTH_TOKEN}`,\r\n 'Content-Type': 'application/json',\r\n },\r\n });\r\n\r\n const dataResponse: IResponseGetProducts = await response.json();\r\n\r\n if (!dataResponse.success) {\r\n throw new Error(dataResponse.message || 'Failed to fetch authorization');\r\n }\r\n\r\n return dataResponse;\r\n}","import Title from '../UI/Title'\r\nimport Text from '../UI/Text'\r\nimport Button from '../UI/Button'\r\nimport Link from '../UI/Link'\r\nimport { usePBMStore } from '../../libs/zustand/usePBM'\r\nimport { useModal } from '../../libs/zustand/useModal'\r\nimport classNames from 'classnames'\r\n\r\nconst Modal = ({ ID }: { ID: string }) => {\r\n const { customLoginUrl } = usePBMStore();\r\n const { modal, setModal } = useModal();\r\n\r\n return (\r\n <main className={classNames(\r\n \"fixed inset-0 flex items-center justify-center z-50 flex-col transition-all shadow bg-black/40\",\r\n {\r\n \"opacity-100 pointer-events-auto\": modal.id === ID && modal.open,\r\n \"opacity-0 pointer-events-none\": modal.id != ID || !modal.open,\r\n }\r\n )}>\r\n <div className='absolute inset-0' onClick={() => setModal({ id: \"\", open: false })}></div>\r\n <section className='z-10 bg-white gap-2 flex-col items-center-safe justify-center-safe p-8 rounded-xl'>\r\n <Title textColor='tomato' textSize='18px' textAlign='center' className='mb-2'>Opa! Parece que você não está Logado</Title>\r\n <Text className='mb-2' textAlign='center'>Para aproveitar os benefícios é necessário realizar o <strong>Login</strong> ou <strong>Cadastro</strong> no site!</Text>\r\n <section className='flex items-center-safe justify-center-safe gap-4'>\r\n <Button className='bg-gray-600 hover:bg-gray-500' onClick={() => setModal({ id: \"\", open: false })}>Seguir sem Benefícios</Button>\r\n <Link href={customLoginUrl || \"/login\"}>Aproveitar Benefícios</Link>\r\n </section>\r\n </section>\r\n </main>\r\n )\r\n}\r\n\r\nexport default Modal;","import Cookies from \"js-cookie\";\r\nimport { IRequestDefault } from \"../types/requests\";\r\nimport { IProductInList } from \"../types/globals\";\r\n\r\ninterface IResponseGetProducts extends IRequestDefault {\r\n data: IProductInList[]\r\n}\r\n\r\nexport const GetProductsWithBenefits = async (): Promise<IResponseGetProducts> => {\r\n const API_URL = import.meta.env.VITE_API_URL;\r\n\r\n const AUTH_TOKEN = Cookies.get(\"pbm-token\");\r\n\r\n if (!AUTH_TOKEN) {\r\n throw new Error('Token is not defined in cookies or is expired');\r\n }\r\n\r\n const response = await fetch(`${API_URL}/products/list`, {\r\n method: 'GET',\r\n headers: {\r\n Authorization: `Bearer ${AUTH_TOKEN}`,\r\n 'Content-Type': 'application/json',\r\n },\r\n });\r\n\r\n const dataResponse: IResponseGetProducts = await response.json();\r\n\r\n if (!dataResponse.success) {\r\n throw new Error(dataResponse.message || 'Failed to fetch authorization');\r\n }\r\n\r\n return dataResponse;\r\n}"],"mappings":"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","names":["import_jsx_runtime","classNames","import_classnames","import_jsx_runtime","classNames","import_classnames","import_zod","import_react","Cookies","import_classnames","import_jsx_runtime","classNames","import_jsx_runtime","classNames","import_jsx_runtime","import_react","import_classnames","import_jsx_runtime","classNames","import_zustand","import_react","import_classnames","import_jsx_runtime","import_jsx_runtime","classNames","import_js_cookie","import_meta","Cookies","import_jsx_runtime","import_classnames","import_jsx_runtime","classNames","import_classnames","import_jsx_runtime","classNames","import_jsx_runtime","import_react","import_jsx_runtime","import_js_cookie","Cookies","import_lucide_react","import_js_cookie","import_meta","Cookies","import_classnames","import_jsx_runtime","classNames","import_js_cookie","import_meta","Cookies","import_jsx_runtime","Skeleton"]}