{"version":3,"file":"index.4936bf20.js","sources":["../../vite/modulepreload-polyfill","../../src/config.tsx","../../src/utils/sentry.tsx","../../src/styles/chakra/DalmaTheme.ts","../../src/use-intercom/utils.ts","../../src/use-intercom/api.ts","../../src/use-intercom/context.ts","../../src/use-intercom/provider.tsx","../../src/use-intercom/useIntercom.ts","../../src/utils/intercom.tsx","../../src/styles/stitches/theme.tsx","../../src/components/intercom/index.tsx","../../src/components/texts/Texts.tsx","../../src/components/texts/Title.tsx","../../src/styles/CustomIcons.tsx","../../src/components/accordion/OptionsDetails.tsx","../../src/components/buttons/FilesButton.tsx","../../src/configs/Legal.tsx","../../src/components/cards/RefundInformations.tsx","../../src/components/cards/PetGuaranteeCard.tsx","../../src/components/inputs/SelectPet.tsx","../../src/backApi/fetchMySpace.tsx","../../src/backApi/fetchContracts.tsx","../../src/components/01_atoms/icon/icons/_arrows.tsx","../../src/components/01_atoms/icon/icons/_filled.tsx","../../src/components/01_atoms/icon/icons/_outlined.tsx","../../src/components/01_atoms/icon/icons/_other.tsx","../../src/components/01_atoms/icon/index.tsx","../../src/pages/Guarantee/Guarantee.tsx","../../src/hooks/useDevice.ts","../../src/components/04_layouts/modal-layout/index.tsx","../../src/components/01_atoms/outlet/index.tsx","../../src/components/01_atoms/button/_utils.tsx","../../src/components/01_atoms/button/_button.tsx","../../src/components/01_atoms/button/_link-button.tsx","../../src/components/01_atoms/button/_anchor-button.tsx","../../src/components/01_atoms/toast/_toast-factories.tsx","../../src/components/01_atoms/toast/_toasts-rules.tsx","../../src/components/01_atoms/text/index.tsx","../../src/components/02_molecules/referral-modal-v3/referral-modal-v3.styled.ts","../../src/components/02_molecules/sponsorship-modal-200/sponsorship-modal-200.styled.ts","../../src/helpers/index.ts","../../src/queryClient/index.ts","../../src/backApi/getContact.ts","../../src/hooks/data/_use-get-contact.tsx","../../src/backApi/getClaims.ts","../../src/utils/format.tsx","../../src/components/02_molecules/claim/_utils.tsx","../../src/hooks/use-claim-status-sidebar.tsx","../../src/routes.ts","../../src/utils/error.ts","../../src/utils/utils.tsx","../../src/components/03_organisms/claims/_utils.ts","../../src/components/02_molecules/claims-notifications/claims-notification.styled.ts","../../src/components/02_molecules/claims-notifications/claims-notification.tsx","../../src/store/claims/machine.tsx","../../src/hooks/signin/_use-log-out.tsx","../../src/hooks/data/_use-get-contract.tsx","../../src/hooks/use-raf-operation.tsx","../../src/components/03_organisms/raf/_utils.tsx","../../src/components/02_molecules/sponsorship-modal-200/sponsorship-modal-200.tsx","../../src/components/01_atoms/link/index.tsx","../../src/pages/Account/Sponsorship.tsx","../../src/components/buttons/Button.tsx","../../src/pages/Account/LiveChat.tsx","../../src/components/01_atoms/visually-hidden/index.tsx","../../src/components/01_atoms/input/_input.tsx","../../src/styles/stitches/deprecated-theme.tsx","../../src/components/tooltip/index.tsx","../../src/components/cards/SmallInformationsCard.tsx","../../src/components/menus/ProfileMenu.tsx","../../src/backApi/fetchPaymentMethods.tsx","../../src/backApi/fetchProfile.tsx","../../src/hooks/useProfile.ts","../../src/backApi/updateIban.tsx","../../src/components/01_atoms/inline-hint/index.tsx","../../src/utils/regexp.tsx","../../src/pages/Account/Profile.tsx","../../src/components/Icons/InfoIcon.tsx","../../src/components/Banner/index.tsx","../../src/components/cards/AccountPriceCard.tsx","../../src/components/Icons/ChevronIcon.tsx","../../src/components/button.tsx","../../src/components/modal/index.tsx","../../src/components/Icons/FileIcon.tsx","../../src/components/Icons/FileDownloadIcon.tsx","../../src/components/Icons/DownloadIcon.tsx","../../src/components/buttons/FileDownloadButton.tsx","../../src/pages/Account/DocumentsRelatedToContract.tsx","../../src/pages/Account/Contracts.tsx","../../src/components/designElements/Logo.tsx","../../src/components/cards/PriceCard.tsx","../../src/components/cards/InformationsCard.tsx","../../src/backApi/fetchQuoteInfo.tsx","../../src/configs/petTypeList.tsx","../../src/configs/catVarietyList.tsx","../../src/configs/dogVarietyList.tsx","../../src/configs/petVarietyList.tsx","../../src/pages/Error503/dog.png","../../src/pages/Error503/index.tsx","../../src/pages/Redirect/Hyperassur.tsx","../../src/components/texts/NewTitle.tsx","../../src/components/cards/SimpleReferCard.tsx","../../src/utils/tracking.ts","../../src/pages/Login/FinalOverview.tsx","../../src/utils/local-storage.tsx","../../src/hooks/use-banner.tsx","../../src/components/02_molecules/banner/index.tsx","../../src/components/02_molecules/home-header/index.tsx","../../src/components/02_molecules/media-card-sponsorship/media-card-sponsorship.tsx","../../src/components/cards/RefundCard.tsx","../../src/components/02_molecules/inline-alert/index.tsx","../../src/components/02_molecules/unpaid-inline-alerts/index.tsx","../../src/components/01_atoms/skeleton/skeleton.styled.ts","../../src/components/01_atoms/skeleton/skeleton.tsx","../../src/components/02_molecules/claim-loading/claim-loading.tsx","../../src/components/04_layouts/sidesheet-layout/index.tsx","../../src/components/02_molecules/sidesheet-content-header/index.tsx","../../src/components/03_organisms/onboarding/iban.styled.ts","../../src/utils/data.tsx","../../src/store/onboarding/machine.tsx","../../src/hooks/use-refund-sidebar.tsx","../../src/components/03_organisms/onboarding/iban.tsx","../../src/components/03_organisms/iban-sidebar/index.styled.ts","../../src/components/03_organisms/iban-sidebar/index.tsx","../../src/backApi/updatePetUuid.tsx","../../src/components/03_organisms/refund-sidebar/pet-uuid-form/utils.ts","../../src/components/03_organisms/refund-sidebar/pet-uuid-form/index.tsx","../../src/backApi/get-unpaid-status.tsx","../../src/hooks/use-get-unpaid-status.ts","../../src/components/04_layouts/mobile-drawer-layout/index.tsx","../../src/components/02_molecules/alert-drawer/index.tsx","../../src/components/02_molecules/alert-modal/alert-modal.styled.ts","../../src/components/02_molecules/alert-modal/index.tsx","../../src/components/02_molecules/claims-empty-state/index.tsx","../../src/components/02_molecules/tag/index.tsx","../../src/components/02_molecules/claim/index.tsx","../../src/components/02_molecules/claims-list/index.tsx","../../src/components/02_molecules/claims-list-by-year/index.tsx","../../src/components/03_organisms/claims/claims.styled.ts","../../src/components/03_organisms/claims/index.tsx","../../src/components/03_organisms/download-app-drawer/index.styled.ts","../../src/configs/external-links.ts","../../src/components/03_organisms/download-app-drawer/index.tsx","../../src/components/03_organisms/download-app-modal/index.tsx","../../src/components/02_molecules/menu-button/index.tsx","../../src/components/03_organisms/home-navbar/menu-items.tsx","../../src/components/02_molecules/media-card/index.tsx","../../src/hooks/useIsVisible.ts","../../src/components/03_organisms/media-cards/index.tsx","../../src/components/02_molecules/sidesheet-screen-with-image/index.tsx","../../src/hooks/useWebShare.ts","../../src/backApi/updateContact.tsx","../../src/components/03_organisms/onboarding/form.styled.ts","../../src/components/02_molecules/avatar/index.tsx","../../src/components/02_molecules/selectable-card/_alert.tsx","../../src/components/02_molecules/selectable-card/_utils.tsx","../../src/components/02_molecules/selectable-card/_checkbox-card.tsx","../../src/components/02_molecules/selectable-card/_info-bottom-card.tsx","../../src/components/02_molecules/selectable-card/_radio-card.tsx","../../src/components/03_organisms/onboarding/how-did-you-know-dalma.tsx","../../src/components/01_atoms/checkbox/index.tsx","../../src/components/03_organisms/onboarding/vet-clinic.tsx","../../src/components/03_organisms/onboarding/form.tsx","../../src/components/01_atoms/stepper-item/index.tsx","../../src/components/02_molecules/stepper/index.tsx","../../src/components/03_organisms/onboarding/header.styled.ts","../../src/components/03_organisms/onboarding/header.tsx","../../src/components/03_organisms/onboarding/index.styled.ts","../../src/components/03_organisms/onboarding/index.tsx","../../src/components/03_organisms/smart-banner/index.tsx","../../src/backApi/newClaim/utils/generate-checksum.ts","../../src/backApi/newClaim/new-claim-api.ts","../../src/backApi/reopenClaimApi.tsx","../../src/components/01_atoms/spinner/index.tsx","../../src/components/03_organisms/refund-sidebar/documents-form/_import-document.tsx","../../src/components/03_organisms/claim-status-sidebar/content-header/index.tsx","../../src/components/03_organisms/claim-status-sidebar/header/index.tsx","../../src/components/03_organisms/claim-status-sidebar/add-need-info-document-sidebar/index.tsx","../../src/components/02_molecules/step/index.tsx","../../src/components/03_organisms/claim-status-sidebar/claim-status-card/in-analysis-card-section.tsx","../../src/components/03_organisms/claim-status-sidebar/claim-status-card/need-info-card-section.tsx","../../src/components/03_organisms/claim-status-sidebar/claim-status-card/refused-card-section.tsx","../../src/components/01_atoms/progress-bar/index.tsx","../../src/components/02_molecules/legend-item/index.tsx","../../src/components/03_organisms/claim-status-sidebar/claim-status-card/reimbursed-card-section.tsx","../../src/components/03_organisms/claim-status-sidebar/claim-status-card/to-be-completed-card-section.tsx","../../src/components/03_organisms/claim-status-sidebar/claim-status-card/index.tsx","../../src/components/03_organisms/claim-status-sidebar/help-section/index.tsx","../../src/components/03_organisms/claim-status-sidebar/need-info-detail/mobile-drawer.tsx","../../src/components/03_organisms/claim-status-sidebar/need-info-detail/sidebar.tsx","../../src/components/03_organisms/claim-status-sidebar/refused-detail/mobile-drawer.tsx","../../src/components/03_organisms/claim-status-sidebar/refused-detail/sidebar.tsx","../../src/components/03_organisms/claim-status-sidebar/index.tsx","../../src/components/01_atoms/logo/_logo.tsx","../../src/components/01_atoms/logo/_mark.tsx","../../src/components/03_organisms/home-navbar/header.tsx","../../src/components/03_organisms/home-navbar/menu-items-loading.tsx","../../src/components/03_organisms/home-navbar/index.tsx","../../src/components/03_organisms/home-navbar/pet-list/_pet-item.tsx","../../src/components/03_organisms/home-navbar/pet-list/index.tsx","../../src/components/03_organisms/home-navbar/profile-avatar.tsx","../../src/components/02_molecules/referral-modal-v3/referral-modal-v3.tsx","../../src/components/03_organisms/home-navbar/right-sidebar-links.tsx","../../src/components/03_organisms/home-navbar/pet-list-loading.tsx","../../src/components/03_organisms/home-navbar/right-sidebar.tsx","../../src/hooks/use-mobile-menu.tsx","../../src/components/03_organisms/mobile-header/index.tsx","../../src/components/03_organisms/mobile-menu/index.tsx","../../src/components/03_organisms/refund-sidebar/stepper/index.tsx","../../src/components/03_organisms/refund-sidebar/header/index.tsx","../../src/components/03_organisms/refund-sidebar/pet-selection-form/index.tsx","../../src/components/03_organisms/refund-sidebar/consultation-types-form/index.tsx","../../src/components/03_organisms/refund-sidebar/amount-form/_price-input.tsx","../../src/backApi/newClaim/utils/parse-amount.ts","../../src/components/03_organisms/refund-sidebar/amount-form/index.tsx","../../src/backApi/newClaimApi.tsx","../../src/components/03_organisms/refund-sidebar/documents-form/index.tsx","../../src/components/03_organisms/refund-sidebar/init/index.tsx","../../src/components/03_organisms/login/boost-app-download.tsx","../../src/components/02_molecules/causes-date-input/utils.ts","../../src/components/02_molecules/causes-date-input/index.tsx","../../src/components/02_molecules/visit-motives-input/utils.ts","../../src/backApi/getVisitMotives.ts","../../src/hooks/use-visit-motives.ts","../../src/components/02_molecules/visit-motive-item/visit-motive-item.tsx","../../src/components/02_molecules/empty-visit-motive-list/empty-visit-motive-list.tsx","../../src/components/02_molecules/visit-motives-input/visit-motives-input.tsx","../../src/components/03_organisms/refund-sidebar/accident-causes-form/index.tsx","../../src/components/03_organisms/refund-sidebar/disease-causes-form/index.tsx","../../src/components/03_organisms/refund-sidebar/index.tsx","../../src/components/04_layouts/home-layout/index.tsx","../../src/pages/Account/home.tsx","../../src/components/02_molecules/have-an-account/index.tsx","../../src/components/03_organisms/login/referral.tsx","../../src/components/02_molecules/password-input-with-forgot/index.tsx","../../src/backApi/fetchResetPassword.tsx","../../src/hooks/signin/_useLogin.tsx","../../src/hooks/signin/_useSignIn.tsx","../../src/hooks/signin/_useFirstSignin.tsx","../../src/backApi/lead-login.ts","../../src/components/03_organisms/login/signup-form.tsx","../../src/hooks/useRedirectAuthenticatedUser.tsx","../../src/components/04_layouts/login-layout/index.tsx","../../src/pages/Login/sign-in.tsx","../../src/hooks/useChangePassword.ts","../../src/components/02_molecules/password-hint/password-hint.tsx","../../src/components/03_organisms/login/_utils.tsx","../../src/components/03_organisms/login/input-password-with-criterias.tsx","../../src/backApi/fetchStatus.tsx","../../src/hooks/signin/use-forgot-password.tsx","../../src/components/03_organisms/login/change-password-form.tsx","../../src/pages/Login/change-password.tsx","../../src/components/03_organisms/login/first-connection-form.tsx","../../src/pages/Login/first-connection.tsx","../../src/components/03_organisms/login/forgot-password-form.tsx","../../src/pages/Login/forgot-password.tsx","../../src/hooks/useAuth.tsx","../../src/router.tsx","../../src/utils/i18n.ts","../../src/App.tsx","../../src/components/optimize/index.tsx","../../src/components/Sandbox.tsx","../../src/index.tsx"],"sourcesContent":["__VITE_IS_MODERN__&&(function polyfill() {\n const relList = document.createElement('link').relList;\n if (relList && relList.supports && relList.supports('modulepreload')) {\n return;\n }\n for (const link of document.querySelectorAll('link[rel=\"modulepreload\"]')) {\n processPreload(link);\n }\n new MutationObserver((mutations) => {\n for (const mutation of mutations) {\n if (mutation.type !== 'childList') {\n continue;\n }\n for (const node of mutation.addedNodes) {\n if (node.tagName === 'LINK' && node.rel === 'modulepreload')\n processPreload(node);\n }\n }\n }).observe(document, { childList: true, subtree: true });\n function getFetchOpts(script) {\n const fetchOpts = {};\n if (script.integrity)\n fetchOpts.integrity = script.integrity;\n if (script.referrerpolicy)\n fetchOpts.referrerPolicy = script.referrerpolicy;\n if (script.crossorigin === 'use-credentials')\n fetchOpts.credentials = 'include';\n else if (script.crossorigin === 'anonymous')\n fetchOpts.credentials = 'omit';\n else\n fetchOpts.credentials = 'same-origin';\n return fetchOpts;\n }\n function processPreload(link) {\n if (link.ep)\n // ep marker = processed\n return;\n link.ep = true;\n // prepopulate the load record\n const fetchOpts = getFetchOpts(link);\n fetch(link.href, fetchOpts);\n }\n}());","export const SANDBOX = import.meta.env.REACT_APP_PRODUCTION !== \"true\";\nexport const OLD_CLAIM_SERVICE_IS_ONLINE =\n import.meta.env.REACT_APP_OLD_CLAIM_SERVICE_IS_ONLINE === \"true\";\n\nexport const STRIPE_PUB_KEY = SANDBOX\n ? \"pk_test_51II9kbF5i98BakySobr2jd3JWG10uu8F579b9fMS6sgFyOxCVeOluX75YOEeFGH5APnF6kOgvT5mEXSpy9PWPvk300ME6DLYVS\" // sandbox key\n : \"pk_live_51II9kbF5i98BakySdxETLJWq2OZb5hY2DxL0L9eZoRtO9e1YQySiZuxoHPHfuPUSU5TPXekgEFFLF9Ufenda20yy00hcNJo0fE\"; // prod env\n\nconst DOMAIN_URL = SANDBOX ? \"dalma.dev\" : \"dalma.tech\";\n\nconst BACKEND_APPLICATION = SANDBOX ? \"dalma-latest\" : \"dalma\";\n\nexport const INTERCOM_APP_ID = \"zkur88l2\";\n\nconst OLD_CLAIM_SERVICE_BUCKET = SANDBOX ? \"test-dalma-latest-claims\" : \"dalma-claims-prod\";\nconst NEW_CLAIM_SERVICE_BUCKET = SANDBOX ? \"dalma-claims-test\" : \"dalma-claims-prod\";\nconst BUCKET = OLD_CLAIM_SERVICE_IS_ONLINE ? OLD_CLAIM_SERVICE_BUCKET : NEW_CLAIM_SERVICE_BUCKET;\n\nconst config = {\n s3: {\n REGION: \"eu-west-3\",\n BUCKET,\n },\n cognito: SANDBOX\n ? {\n REGION: \"eu-west-3\",\n USER_POOL_ID: \"eu-west-3_rrBYwWxIh\",\n APP_CLIENT_ID: \"2e8ohr287degbgauuopj2k0jcv\",\n IDENTITY_POOL_ID: \"eu-west-3:b0dd8c4f-184f-4a29-b95c-0ef95c64e596\",\n AUTHENTICATION_FLOW_TYPE: \"USER_PASSWORD_AUTH\", // To be changed to 'USER_SRP_AUTH' after user pool migration\n }\n : {\n REGION: \"eu-west-3\",\n USER_POOL_ID: \"eu-west-3_XXxFbmRMC\",\n APP_CLIENT_ID: \"v53kr3ns5ddplrn0ck8i63t0j\",\n IDENTITY_POOL_ID: \"eu-west-3:2dc66ce6-e35d-497a-90c8-044540786664\",\n AUTHENTICATION_FLOW_TYPE: \"USER_PASSWORD_AUTH\", // To be changed to 'USER_SRP_AUTH' after user pool migration\n },\n apiMySpaceGateway: {\n NAME: \"apiMySpaceGateway\",\n REGION: \"eu-west-3\",\n URL: `https://myspace.${DOMAIN_URL}/${BACKEND_APPLICATION}`,\n },\n apiFilesGateway: {\n NAME: \"apiFilesGateway\",\n REGION: \"eu-west-3\",\n URL: `https://file.${DOMAIN_URL}/${SANDBOX ? \"storage-latest\" : \"file-storage\"}`,\n },\n apiClaimsGateway: {\n NAME: \"apiClaimsGateway\",\n REGION: \"eu-west-3\",\n URL: `https://claims.${DOMAIN_URL}/${BACKEND_APPLICATION}`,\n },\n apiOldMySpaceGateway: {\n NAME: \"apiOldMySpaceGateway\",\n REGION: \"eu-west-3\",\n URL: SANDBOX ? \"https://dev.dalma.co/myspace\" : \"https://prod.dalma.co/myspace\",\n },\n apiStripeGateway: {\n NAME: \"apiStripeGateway\",\n REGION: \"eu-west-3\",\n URL: `https://checkout.${DOMAIN_URL}/${BACKEND_APPLICATION}`,\n },\n apiAuthGateway: {\n NAME: \"apiAuthGateway\",\n REGION: \"eu-west-3\",\n URL: `https://auth.${DOMAIN_URL}/${SANDBOX ? \"dalma-latest\" : BACKEND_APPLICATION}`,\n },\n INTERCOM_APP_ID,\n UNPAID_API_URL: SANDBOX\n ? \"https://backoffice.dalma.dev/dalma-bo-latest/unpaid/recovery-invoice\"\n : \"https://backoffice.dalma.tech/dalma-bo/unpaid/recovery-invoice\",\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default config;\n\nconst DOMAIN_SEP = SANDBOX ? \".dev.\" : \".\";\nexport const SIGNUP_DOMAIN = `https://signup${DOMAIN_SEP}dalma.co`;\n","import * as Sentry from \"@sentry/react\";\nimport { Integrations } from \"@sentry/tracing\";\nimport { SANDBOX } from \"src/config\";\n\nSentry.init({\n dsn: \"https://45d4309858be4cf2ab895020dc105f80@o946967.ingest.sentry.io/5896122\",\n release: \"web-reactjs@\" + import.meta.env.REACT_APP_SHA,\n integrations: [new Integrations.BrowserTracing()],\n enabled: import.meta.env.MODE === \"production\",\n environment: SANDBOX ? \"dev\" : \"production\",\n denyUrls: [\n // Ignore errors raised by intercom (this is a third party integration)\n \"https://js.intercomcdn.com/\",\n ],\n\n // Set tracesSampleRate to 1.0 to capture 100% in production\n tracesSampleRate: SANDBOX ? 0 : 1,\n});\n","import { extendTheme, theme as chakraTheme } from \"@chakra-ui/react\";\n\nconst fonts = {\n ...chakraTheme.fonts,\n // We need a sans-serif fallback font here so that Firefox renders select options correctly\n body: \"Grotesk, sans-serif\",\n header: \"Roslindale\",\n mono: \"Grotesk\",\n};\n\nconst colors = {\n // default colors\n transparent: \"transparent\",\n black: \"#000\",\n white: \"#FFF\",\n\n // backgrounds\n background: \"#FAFAFA\",\n secondBackground: \"#FAFAFA\",\n paperBackground: \"#F5F5F5\",\n sidebar: \"white\",\n sidebarCards: \"#DBEBFF\",\n radioCards: \"white\",\n lists: \"white\",\n progressBar: \"#F5F5F5\",\n activeProgressBar: \"#FE6F18\",\n warningBackground: \"#FAE6E7;\",\n heartBackground: \"#FAEBF7\",\n refundState: \"#DDF0EA\",\n inProgressState: \"#DBEBFF\",\n missingInformationState: \"#FAE6E7\",\n\n // button backgrounds\n buttons: \"#FE6F18\",\n backButton: \"#DBEBFF\",\n questionButton: \"#4E68F6\",\n activeButton: \"#FE6F18\",\n disabledButton: \"#DBEBFF\",\n textRadio: \"white\",\n textCheckbox: \"white\",\n radio: \"#F5F5F5\",\n newCareButton: \"#FE6F18\",\n veterinaryChatButton: \"#4E68F6\",\n refundButton: \"#FAF7F0\",\n sterilisationButton: \"#DBEBFF\",\n\n // fonts colors\n backButtonFont: \"#144283\",\n disabledFont: \"#144283\",\n activeFont: \"#FE6F18\",\n activeFontCheckbox: \"#212121\",\n sidebarFont: \"#144283\",\n textfieldLabelFont: \"#9E9E9E\",\n textfieldFont: \"#212121\",\n selectedItemFont: \"#212121\",\n checkboxFont: \"#5E5E5E\",\n radioTextFont: \"#212121\",\n inputFont: \"#9E9E9E\",\n secondTitleFont: \"#616161\",\n\n // borderColors\n borderColor: \"#DDDDDD\",\n activeBorderColor: \"#FE6F18\",\n selectItemBorder: \"#E0E0E0\",\n radioTextBorder: \"#E0E0E0\",\n sidebarButtonBorder: \"#E0E0E0\",\n\n // icons\n backIcon: \"#144283\",\n editIcon: \"#4E68F6\",\n editClearIcon: \"#4E68F6\",\n};\n\nconst borderRadius = {\n none: \"0\",\n button: \"0.5rem\",\n input: \"5rem\",\n card: \"0.5rem\",\n max: 9999,\n};\n\nconst overrides = {\n ...chakraTheme,\n radii: borderRadius,\n colors,\n fonts,\n fontWeights: { normal: 300, medium: 600, bold: 700 },\n fontSizes: {\n xs: \"12px\",\n sm: \"14px\",\n md: \"16px\",\n lg: \"18px\",\n xl: \"20px\",\n \"2xl\": \"24px\",\n \"3xl\": \"28px\",\n \"4xl\": \"32px\",\n \"5xl\": \"36px\",\n \"6xl\": \"48px\",\n \"7xl\": \"64px\",\n },\n};\n\nexport const dalmaTheme = extendTheme(overrides);\n","export const isEmptyObject = (obj: object) =>\n Object.keys(obj).length === 0 && obj.constructor === Object;\n\nexport const isSSR = typeof window === \"undefined\";\n\n/**\n * Removes object entries where the value equals to `undefined`\n *\n * @param obj\n */\nexport const removeUndefined = (obj: any) => {\n Object.keys(obj).forEach((key) => {\n if (obj[key] && typeof obj[key] === \"object\") removeUndefined(obj[key]);\n else if (obj[key] === undefined) delete obj[key];\n });\n return obj;\n};\n","import { IntercomMethod } from \"./types\";\nimport { isSSR } from \"./utils\";\n\n/**\n * Safely exposes `window.Intercom` and passes the arguments to the instance\n *\n * @param method method passed to the `window.Intercom` instance\n * @param args arguments passed to the `window.Intercom` instance\n *\n * @see {@link https://developers.intercom.com/installing-intercom/docs/intercom-javascript}\n */\nconst IntercomAPI = (method: IntercomMethod, ...args: Array) => {\n if (!isSSR && window.Intercom) {\n return window.Intercom.apply(null, [method, ...args]);\n } else {\n console.error(`${method} Intercom instance is not initalized yet`);\n }\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default IntercomAPI;\n","import * as React from \"react\";\n\nimport { IntercomContextValues } from \"./types\";\n\nconst IntercomContext = React.createContext(undefined);\n\n// eslint-disable-next-line import/no-default-export\nexport default IntercomContext;\n","import * as React from \"react\";\n\nimport IntercomAPI from \"./api\";\nimport IntercomContext from \"./context\";\n\nimport {\n IntercomContextValues,\n IntercomProps,\n IntercomProviderProps,\n RawIntercomBootProps,\n} from \"./types\";\nimport { isSSR } from \"./utils\";\n\nexport const IntercomProvider: React.FC = ({\n appId,\n children,\n shouldInitialize = !isSSR,\n apiBase,\n}) => {\n const isBooted = React.useRef(false);\n\n const boot = React.useCallback(\n (props?: IntercomProps) => {\n if (!window.Intercom && !shouldInitialize) {\n return;\n }\n\n if (isBooted.current) {\n return;\n }\n\n const metaData: RawIntercomBootProps = {\n app_id: appId,\n ...(apiBase && { api_base: apiBase }),\n ...props,\n };\n\n window.intercomSettings = metaData;\n IntercomAPI(\"boot\", metaData);\n isBooted.current = true;\n },\n [apiBase, appId, shouldInitialize]\n );\n\n const ensureIntercom = React.useCallback(\n (functionName = \"A function\", callback: (() => void) | (() => string)) => {\n if (!window.Intercom && !shouldInitialize) {\n console.warn(\n \"Intercom instance is not initialized because `shouldInitialize` is set to `false` in `IntercomProvider`\"\n );\n return;\n }\n if (!isBooted.current) {\n console.warn(\n [\n `'${functionName}' was called but Intercom has not booted yet. `,\n `Please call 'boot' before calling '${functionName}' or `,\n `set 'autoBoot' to true in the IntercomProvider.`,\n ].join(\"\")\n );\n return;\n }\n return callback();\n },\n [shouldInitialize]\n );\n\n const shutdown = React.useCallback(() => {\n if (!isBooted.current) return;\n\n IntercomAPI(\"shutdown\");\n isBooted.current = false;\n }, []);\n\n const hardShutdown = React.useCallback(() => {\n if (!isBooted.current) return;\n\n IntercomAPI(\"shutdown\");\n delete window.Intercom;\n delete window.intercomSettings;\n isBooted.current = false;\n }, []);\n\n const refresh = React.useCallback(() => {\n ensureIntercom(\"update\", () => {\n const lastRequestedAt = new Date().getTime();\n IntercomAPI(\"update\", { last_requested_at: lastRequestedAt });\n });\n }, [ensureIntercom]);\n\n const update = React.useCallback(\n (props?: IntercomProps) => {\n ensureIntercom(\"update\", () => {\n if (!props) {\n refresh();\n return;\n }\n const rawProps = props;\n window.intercomSettings = { ...window.intercomSettings, ...rawProps };\n IntercomAPI(\"update\", rawProps);\n });\n },\n [ensureIntercom, refresh]\n );\n\n const hide = React.useCallback(() => {\n ensureIntercom(\"hide\", () => {\n IntercomAPI(\"hide\");\n });\n }, [ensureIntercom]);\n\n const show = React.useCallback(() => {\n ensureIntercom(\"show\", () => IntercomAPI(\"show\"));\n }, [ensureIntercom]);\n\n const showMessages = React.useCallback(() => {\n ensureIntercom(\"showMessages\", () => {\n IntercomAPI(\"showMessages\");\n });\n }, [ensureIntercom]);\n\n const showNewMessages = React.useCallback(\n (message?: string) => {\n ensureIntercom(\"showNewMessage\", () => {\n if (!message) {\n IntercomAPI(\"showNewMessage\");\n } else {\n IntercomAPI(\"showNewMessage\", message);\n }\n });\n },\n [ensureIntercom]\n );\n\n const getVisitorId = React.useCallback(() => {\n return ensureIntercom(\"getVisitorId\", () => {\n return IntercomAPI(\"getVisitorId\");\n }) as string;\n }, [ensureIntercom]);\n\n const startTour = React.useCallback(\n (tourId: number) => {\n ensureIntercom(\"startTour\", () => {\n IntercomAPI(\"startTour\", tourId);\n });\n },\n [ensureIntercom]\n );\n\n const trackEvent = React.useCallback(\n (event: string, metaData?: object) => {\n ensureIntercom(\"trackEvent\", () => {\n if (metaData) {\n IntercomAPI(\"trackEvent\", event, metaData);\n } else {\n IntercomAPI(\"trackEvent\", event);\n }\n });\n },\n [ensureIntercom]\n );\n\n const providerValue = React.useMemo(() => {\n return {\n boot,\n shutdown,\n hardShutdown,\n update,\n hide,\n show,\n showMessages,\n showNewMessages,\n getVisitorId,\n startTour,\n trackEvent,\n };\n }, [\n boot,\n shutdown,\n hardShutdown,\n update,\n hide,\n show,\n showMessages,\n showNewMessages,\n getVisitorId,\n startTour,\n trackEvent,\n ]);\n\n return {children};\n};\n\nexport const useIntercomContext = () => {\n const context = React.useContext(IntercomContext);\n\n if (import.meta.env.MODE !== \"production\") {\n if (context === undefined) {\n throw new Error(\"`useIntercom` must be used within `IntercomProvider`.\");\n }\n }\n\n return context as IntercomContextValues;\n};\n","import { useIntercomContext } from \"./provider\";\n\nexport const useIntercom = () => {\n return useIntercomContext();\n};\n","import { createContext, ReactNode, useContext, useEffect, useReducer, useRef } from \"react\";\nimport { IntercomProvider as Provider } from \"src/use-intercom\";\nimport { INTERCOM_APP_ID } from \"src/config\";\n\nconst Ctx = createContext(false);\n\ntype Props = { children: ReactNode };\n\nexport function IntercomProvider({ children }: Props) {\n const [, forceUpdate] = useReducer(() => ({}), {});\n\n const loadedRef = useRef(false);\n\n useEffect(() => {\n const start = Date.now();\n function cb() {\n if (\"Intercom\" in window) {\n loadedRef.current = true;\n forceUpdate();\n }\n if (!loadedRef.current && Date.now() - start < 30_000) {\n setTimeout(cb, 100);\n }\n }\n\n cb();\n }, []);\n return (\n \n \n {children}\n \n \n );\n}\n\n/**\n * Checks if intercom has loaded every 100ms for 30s\n * @returns {bool} is Intercom loaded\n */\nexport const useIntercomLoaded = () => useContext(Ctx);\n","import { createStitches, globalCss } from \"@stitches/react\";\n\n/* Color styles as RGB values */\nexport const baseColors = Object.freeze({\n neutral000: \"255, 255, 255\",\n neutral100: \"241, 247, 255\",\n neutral200: \"233, 244, 254\",\n neutral300: \"219, 235, 255\",\n neutral400: \"194, 216, 240\",\n neutral500: \"103, 138, 184\",\n neutral600: \"69, 112, 169\",\n neutral700: \"40, 89, 154\",\n neutral800: \"20, 66, 131\",\n neutral900: \"16, 21, 49\",\n neutral999: \"0, 0, 0\",\n blue300: \"219, 235, 255\",\n blue400: \"166, 180, 250\",\n blue500: \"78, 104, 246\",\n blue600: \"71, 95, 229\",\n blue700: \"50, 71, 188\",\n green300: \"221, 240, 234\",\n green400: \"128, 184, 167\",\n green500: \"0, 112, 79\",\n orange300: \"250, 238, 230\",\n orange400: \"255, 183, 139\",\n orange500: \"254, 111, 24\",\n yellow300: \"255, 242, 224\",\n yellow400: \"254, 218, 128\",\n yellow500: \"255, 180, 0\",\n pink300: \"255, 235, 245\",\n pink400: \"250, 198, 227\",\n pink500: \"252, 156, 206\",\n red300: \"250, 234, 235\",\n red400: \"245, 209, 211\",\n red500: \"214, 68, 76\",\n red600: \"185, 43, 51\",\n red700: \"163, 22, 29\",\n grey300: \"241, 241, 243\",\n grey400: \"225, 226, 230\",\n grey500: \"112, 115, 131\",\n grey600: \"121, 121, 121\",\n\n // Color replacing gradients for texts and icons\n green: \"#449CB4\",\n lightBlue: \"#3980EB\",\n blueMuted: \"103, 138, 184\",\n purple: \"#817DEC\",\n orange: \"#DF6B00\",\n red: \"#E44E59\",\n dalmaBlue: \"#0B2AD6\",\n dalmaBlueNoGradient: \"#0B2AD6\",\n yellow: \"#ECCC7E\",\n linkBlue: \"#4E68F6\",\n subtitleColor: \"#C2D8F0\",\n});\n\nconst gradient = Object.freeze({\n // TODO use basecolors\n gradientGreen: \"radial-gradient(113.7% 275.98% at 106.14% 105.19%, #6ED5BE 0%, #449CB4 100%)\",\n gradientLightBlue: \"radial-gradient(113.7% 275.98% at 106.14% 105.19%, #55BAF4 0%, #3980EB 100%)\",\n gradientPurple: \"radial-gradient(113.7% 275.98% at 106.14% 105.19%, #817DEC 0%, #0B1C83 100%)\",\n gradientOrange: \"radial-gradient(113.7% 275.98% at 106.14% 105.19%, #ECB27D 0%, #DF6B00 100%)\",\n gradientRed: \"radial-gradient(113.7% 275.98% at 106.14% 105.19%, #DD8CB3 0%, #E44E59 100%)\",\n gradientDalmaBlue: \"radial-gradient(113.7% 275.98% at 106.14% 105.19%, #4E68F6 0%, #0B2AD6 100%)\",\n gradientYellow: \"radial-gradient(113.7% 275.98% at 106.14% 105.19%, #ECCC7E 0%, #FFB400 100%)\",\n gradientAngular:\n \"conic-gradient(from 90deg at 50% 50%, rgba(81, 177, 243, 0) 0deg, #3E8AED 360deg)\",\n gradientWhite: \"linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, #FFFFFF 100%)\",\n gradientRadialWhite:\n \"conic-gradient(from 90deg at 50% 50%, rgba(255, 255, 255, 0) 0deg, #FFFFFF 360deg)\", // ?? Called Radial but Conic\n});\n\nexport function rgb(color: string) {\n return `rgb(${color})`;\n}\n\nexport function rgba(color: string, opacity: number) {\n return `rgba(${color}, ${opacity})`;\n}\n\n// Root size : 16px\nconst fonts = Object.freeze({\n // Family\n familyTitle: \"Roslindale\",\n familyText: \"Scto Grotesk A\",\n});\n\nconst fontSizes = Object.freeze({\n // Font Sizes\n /** 48px */\n titleDisplay1: \"3rem\",\n /** 32px */\n titleDisplay2: \"2rem\",\n /** 24px */\n titleDisplay3: \"1.5rem\",\n /** 20px */\n titleDisplay4: \"1.25rem\",\n /** 18px */\n titleDisplay5: \"1.12rem\",\n\n /** 36px */\n textDisplay1: \"2.25rem\",\n /** 32px */\n textDisplay2: \"2rem\",\n /** 26px */\n textDisplay3: \"1.62rem\",\n /** 24px */\n textDisplay4: \"1.5rem\",\n /** 18px */\n textDisplay5: \"1.25rem\",\n /** 16px */\n textParagraph1: \"1rem\",\n /** 14px */\n textParagraph2: \"0.88rem\",\n /** 13px */\n textParagraph3: \"0.81rem\",\n /** 12px */\n textCaption1: \"0.75rem\",\n /** 10px */\n textCaption2: \"0.62rem\",\n /** 8px */\n textCaption3: \"0.5rem\",\n\n /** 14px */\n buttonLabel: \"0.88rem\",\n /** 12px */\n buttonLabelSmall: \"0.75rem\",\n});\n\nconst shadows = Object.freeze({\n elevation1Purple: \"0px 16px 32px rgba(138, 151, 221, 0.24)\",\n elevation1Primary: \"0px 16px 32px rgba(83, 138, 244, 0.24)\",\n elevation2Primary: \"0px 16px 32px rgba(83, 138, 244, 0.52)\",\n elevation1Yellow: \"0px 16px 32px rgba(254, 177, 0, 0.24)\",\n elevation1Dark: \"0px 16px 32px rgba(12, 46, 95, 0.24)\",\n elevation1Light: \"0px 0px 32px rgba(255, 255, 255, 0.6)\",\n});\n\nexport const { theme, styled, css, keyframes } = createStitches({\n media: {\n bp1: \"(min-width: 576px)\",\n bp2: \"(min-width: 768px)\",\n bp3: \"(min-width: 1024px)\",\n bp4: \"(min-width: 1440px)\",\n withHover: \"(hover: hover) and (pointer: fine)\",\n },\n theme: {\n colors: {\n backgroundPrimary: rgb(baseColors.neutral000),\n backgroundAccent: gradient.gradientDalmaBlue,\n backgroundAccentNoGradient: baseColors.dalmaBlueNoGradient,\n backgroundSecondaryMobile: rgb(baseColors.neutral000),\n backgroundSecondaryDesktop: rgb(baseColors.neutral000),\n backgroundNeutral: rgb(baseColors.neutral900),\n\n textBaseDefault: rgb(baseColors.neutral900),\n textBaseSubdued: rgb(baseColors.neutral500),\n textBaseDisabled: rgb(baseColors.neutral300),\n textPrimaryDefault: rgb(baseColors.blue500),\n textPrimaryDisabled: rgb(baseColors.blue400),\n textAccent: baseColors.dalmaBlue, //gradient.gradientDalmaBlue,\n textSuccess: rgb(baseColors.green500),\n textSuccesAccent: baseColors.green, //gradient.gradientGreen,\n textSuccessDisabled: rgb(baseColors.green400),\n textCritical: rgb(baseColors.red500),\n textCriticalAccent: baseColors.red, //gradient.gradientRed,\n textCriticalDisabled: rgb(baseColors.red400),\n textProgress: baseColors.lightBlue, //gradient.gradientLightBlue,\n textWarning: baseColors.orange, //gradient.gradientOrange,\n textWarningDisabled: rgb(baseColors.orange400),\n textSecondaryDefault: rgb(baseColors.neutral000),\n textSecondarySubdued: rgb(baseColors.neutral400),\n textSecondaryDisabled: rgba(baseColors.neutral000, 0.3),\n textLinkBlue: baseColors.linkBlue, //gradient.gradientLinkBlue,\n\n iconBaseDefault: rgb(baseColors.neutral900),\n iconBaseSubdued: rgb(baseColors.neutral500),\n iconBaseDisabled: rgb(baseColors.neutral300),\n iconGreyDefault: rgb(baseColors.grey600),\n iconPrimaryDefault: rgb(baseColors.blue500),\n iconPrimaryHovered: rgb(baseColors.neutral600),\n iconPrimaryPressed: rgb(baseColors.neutral700),\n iconPrimaryDisabled: rgb(baseColors.blue400),\n iconPrimaryMuted: rgb(baseColors.blueMuted),\n iconAccent: baseColors.dalmaBlue, //gradient.gradientDalmaBlue,\n iconSecondaryDefault: rgb(baseColors.neutral000),\n iconSecondarySubdued: rgb(baseColors.neutral400),\n iconSecondaryDisabled: rgba(baseColors.neutral000, 0.3),\n iconSuccess: rgb(baseColors.green500),\n iconWarning: baseColors.orange, //gradient.gradientOrange,\n iconCritical: rgb(baseColors.red500),\n iconDecorativeGreen: baseColors.green, //gradient.gradientGreen,\n iconDecorativeLightBlue: baseColors.lightBlue, //gradient.gradientLightBlue,\n iconDecorativeRed: baseColors.red, //gradient.gradientRed,\n iconDecorativePurple: baseColors.purple, //gradient.gradientPurple,\n\n borderBaseDefault: rgb(baseColors.neutral500),\n borderBaseSubdued: rgb(baseColors.neutral300),\n borderBaseDisabled: rgb(baseColors.neutral400),\n borderSecondary: rgb(baseColors.neutral000),\n borderSecondaryPressed: rgb(baseColors.neutral400),\n borderSelected: rgb(baseColors.blue500),\n borderCriticalDefault: rgb(baseColors.red500),\n borderCriticalSubdued: rgb(baseColors.red400),\n borderSuccessDefault: rgb(baseColors.green500),\n borderSuccessSubdued: rgb(baseColors.green400),\n fillBaseAccent: rgb(baseColors.neutral900),\n fillBaseDefault: rgb(baseColors.neutral500),\n fillBaseSubdued: rgb(baseColors.neutral300),\n fillBaseHovered: rgb(baseColors.neutral200),\n fillBasePressed: rgb(baseColors.neutral300),\n fillBaseDisabled: rgb(baseColors.neutral100),\n fillOverlay: rgba(baseColors.neutral800, 0.5),\n fillPrimaryDefault: rgb(baseColors.blue500),\n fillPrimaryHovered: rgb(baseColors.blue600),\n fillPrimaryPressed: rgb(baseColors.blue700),\n fillPrimarySubdued: rgba(baseColors.blue500, 0.2),\n fillPrimaryDisabled: rgba(baseColors.blue500, 0.6),\n fillAccent: gradient.gradientDalmaBlue,\n fillSecondary: rgb(baseColors.neutral000),\n fillSecondarySubdued: rgba(baseColors.neutral000, 0.8),\n fillSecondaryPressed: rgb(baseColors.neutral100),\n fillSuccessAccent: gradient.gradientGreen,\n fillSuccessSubdued: rgb(baseColors.green300),\n fillWarning: gradient.gradientOrange,\n fillWarningSubdued: rgb(baseColors.orange300),\n fillCriticalAccent: gradient.gradientRed,\n fillCriticalSubdued: rgb(baseColors.red300),\n fillDecorativeGreen: gradient.gradientGreen,\n fillDecorativeLightBlue: gradient.gradientLightBlue,\n fillDecorativeRed: gradient.gradientRed,\n fillDecorativePurple: gradient.gradientPurple,\n fillDecorativeYellow: gradient.gradientYellow,\n fillDecorativeWhite: gradient.gradientWhite,\n buttonBackgroundAccentDefault: rgb(baseColors.blue500),\n buttonBackgroundAccentDisabled: rgb(baseColors.blue400),\n buttonBackgroundAccentHovered: rgb(baseColors.blue600),\n buttonBackgroundAccentPressed: rgb(baseColors.blue700),\n buttonBackgroundSecondaryDefault: rgb(baseColors.neutral000),\n buttonBackgroundSecondaryHovered: rgb(baseColors.neutral100),\n buttonBackgroundSecondaryPressed: rgb(baseColors.neutral200),\n buttonBackgroundSecondaryDisabled: rgba(baseColors.neutral000, 0.6),\n buttonBackgroundCriticalDefault: rgb(baseColors.neutral000),\n buttonBackgroundCriticalHovered: rgb(baseColors.red300),\n buttonBackgroundCriticalPressed: rgb(baseColors.red400),\n buttonBackgroundCriticalDisabled: rgba(baseColors.neutral000, 0.6),\n buttonLabelBaseDefault: rgb(baseColors.neutral900),\n buttonLabelBaseHovered: rgb(baseColors.neutral500),\n buttonLabelBasePressed: rgb(baseColors.neutral700),\n buttonLabelBaseDisabled: rgba(baseColors.neutral500, 0.6),\n buttonLabelOnAccentDefault: rgb(baseColors.neutral000),\n buttonLabelOnAccentHovered: rgb(baseColors.neutral100),\n buttonLabelOnAccentDisabled: rgba(baseColors.neutral000, 0.6),\n buttonLabelOnSecondaryDefault: rgb(baseColors.blue500),\n buttonLabelOnSecondaryHovered: rgb(baseColors.neutral500),\n buttonLabelOnSecondaryDisabled: rgba(baseColors.neutral500, 0.6),\n buttonLabelCriticalDefault: rgb(baseColors.red500),\n buttonLabelCriticalHovered: rgb(baseColors.red600),\n buttonLabelCriticalPressed: rgb(baseColors.red700),\n buttonLabelCriticalDisabled: rgb(baseColors.red400),\n buttonIconBaseDefault: rgb(baseColors.neutral900),\n buttonIconBaseHovered: rgb(baseColors.neutral500),\n buttonIconBasePressed: rgb(baseColors.neutral700),\n buttonIconBaseDisabled: rgba(baseColors.neutral500, 0.6),\n buttonIconOnAccentDefault: rgb(baseColors.neutral000),\n buttonIconOnAccentHovered: rgb(baseColors.neutral100),\n buttonIconOnAccentDisabled: rgba(baseColors.neutral000, 0.6),\n buttonIconOnSecondaryDefault: rgb(baseColors.blue500),\n buttonIconOnSecondaryHovered: rgb(baseColors.neutral500),\n buttonIconOnSecondaryDisabled: rgba(baseColors.neutral500, 0.6),\n buttonIconCriticalDefault: rgb(baseColors.red500),\n buttonIconCriticalHovered: rgb(baseColors.red600),\n buttonIconCriticalPressed: rgb(baseColors.red700),\n buttonIconCriticalDisabled: rgb(baseColors.red400),\n buttonIconSpinner: gradient.gradientAngular,\n\n yellowDecorativeHover: baseColors.yellow,\n purpleDecorativeHover: baseColors.purple,\n },\n fontWeights: {\n bold: \"700\",\n medium: \"500\",\n regular: \"400\",\n },\n fonts,\n fontSizes,\n // Root size : 16px\n spacing: {\n /** 0px */\n \"0\": \"0\",\n /** 2px */\n [`spacing2px`]: \".125rem\",\n /** 4px */\n [`spacing4px`]: \".25rem\",\n /** 8px */\n [`spacing8px`]: \".5rem\",\n /** 12px */\n [`spacing12px`]: \".75rem\",\n /** 16px */\n [`spacing16px`]: \"1rem\",\n /** 20px */\n [`spacing20px`]: \"1.25rem\",\n /** 22px */\n [`spacing22px`]: \"1.375rem\",\n /** 24px */\n [`spacing24px`]: \"1.5rem\",\n /** 28px */\n [`spacing28px`]: \"1.75rem\",\n /** 32px */\n [`spacing32px`]: \"2rem\",\n /** 36px */\n [`spacing36px`]: \"2.25rem\",\n /** 40px */\n [`spacing40px`]: \"2.5rem\",\n /** 44px */\n [`spacing44px`]: \"2.75rem\",\n /** 48px */\n [`spacing48px`]: \"3rem\",\n /** 64px */\n [`spacing64px`]: \"4rem\",\n /** 80px */\n [`spacing80px`]: \"5rem\",\n /** 96px */\n [`spacing96px`]: \"6rem\",\n /** 128px */\n [`spacing128px`]: \"8rem\",\n /** 160px */\n [`spacing160px`]: \"10rem\",\n /** 192px */\n [`spacing192px`]: \"12rem\",\n /** 216px */\n [`spacing216px`]: \"13.5rem\",\n /** 224px */\n [`spacing224px`]: \"14rem\",\n /** 256px */\n [`spacing256px`]: \"16rem\",\n },\n elevation: shadows,\n letterSpacings: {\n regular: \"-0.02em\",\n },\n radii: {\n 1: \"0.125rem\",\n 4: \"0.25rem\",\n 7: \"0.4375rem\",\n 8: \"0.5rem\",\n 9: \"0.5625rem\",\n 12: \"0.75rem\",\n 16: \"1rem\",\n 20: \"1.25rem\",\n 24: \"1.5rem\",\n 32: \"2rem\",\n 100: \"6.25rem\",\n },\n boxShadow: {\n hovered: `0px 0px 0px 4px ${rgb(baseColors.neutral200)}`,\n selected: `0px 0px 0px 4px ${rgb(baseColors.blue300)}`,\n criticalSelected: `0px 0px 0px 4px ${rgb(baseColors.red300)}`,\n focus: `0px 0px 0px 2px ${rgb(baseColors.blue500)}`,\n },\n outline: {\n base: `1px solid ${rgb(baseColors.blue300)}`,\n disabled: `1px solid ${rgb(baseColors.blue300)}`,\n hovered: `1px solid ${rgb(baseColors.blue300)}`,\n pressed: `1px solid ${rgb(baseColors.neutral400)}`,\n selected: `2px solid ${rgb(baseColors.blue500)}`,\n critical: `1.5px solid ${rgb(baseColors.red500)}`,\n criticalPressed: `1px solid ${rgb(baseColors.red500)}`,\n criticalHovered: `1px solid ${rgb(baseColors.red400)}`,\n },\n },\n});\n\n// We need to export this like that because of css var using with the theme\nexport const textColors = Object.freeze({\n textWhite: rgb(baseColors.neutral000),\n textBaseDefault: theme.colors.textBaseDefault,\n textBaseSubdued: theme.colors.textBaseSubdued,\n textSubtitleColor: baseColors.subtitleColor,\n textBaseDisabled: theme.colors.textBaseDisabled,\n textPrimaryDefault: theme.colors.textPrimaryDefault,\n textPrimaryDisabled: theme.colors.textPrimaryDisabled,\n textAccent: theme.colors.textAccent,\n textSuccess: theme.colors.textSuccess,\n textSuccesAccent: theme.colors.textSuccesAccent,\n textSuccessDisabled: theme.colors.textSuccessDisabled,\n textCritical: theme.colors.textCritical,\n textCriticalAccent: theme.colors.textCriticalAccent,\n textCriticalDisabled: theme.colors.textCriticalDisabled,\n textProgress: theme.colors.textProgress,\n textWarning: theme.colors.textWarning,\n textWarningDisabled: theme.colors.textWarningDisabled,\n textSecondaryDefault: theme.colors.textSecondaryDefault,\n textSecondarySubdued: theme.colors.textSecondarySubdued,\n textSecondaryDisabled: theme.colors.textSecondaryDisabled,\n textLinkBlue: theme.colors.textLinkBlue,\n});\n\n// We need to export this like that because of css var using with the theme\nexport const buttonLabelColors = Object.freeze({\n buttonLabelBaseDefault: theme.colors.buttonLabelBaseDefault,\n buttonLabelBaseHovered: theme.colors.buttonLabelBaseHovered,\n buttonLabelBasePressed: theme.colors.buttonLabelBasePressed,\n buttonLabelBaseDisabled: theme.colors.buttonLabelBaseDisabled,\n buttonLabelOnAccentDefault: theme.colors.buttonLabelOnAccentDefault,\n buttonLabelOnAccentHovered: theme.colors.buttonLabelOnAccentHovered,\n buttonLabelOnAccentDisabled: theme.colors.buttonLabelOnAccentDisabled,\n buttonLabelOnSecondaryDefault: theme.colors.buttonLabelOnSecondaryDefault,\n buttonLabelOnSecondaryHovered: theme.colors.buttonLabelOnSecondaryHovered,\n buttonLabelOnSecondaryDisabled: theme.colors.buttonLabelOnSecondaryDisabled,\n buttonLabelCriticalDefault: theme.colors.buttonLabelCriticalDefault,\n buttonLabelCriticalHovered: theme.colors.buttonLabelCriticalHovered,\n buttonLabelCriticalPressed: theme.colors.buttonLabelCriticalPressed,\n buttonLabelCriticalDisabled: theme.colors.buttonLabelCriticalDisabled,\n});\n\nexport const iconColors = Object.freeze({\n iconBaseDefault: theme.colors.iconBaseDefault,\n iconBaseSubdued: theme.colors.iconBaseSubdued,\n iconBaseDisabled: theme.colors.iconBaseDisabled,\n iconPrimaryDefault: theme.colors.iconPrimaryDefault,\n iconPrimaryHovered: theme.colors.iconPrimaryHovered,\n iconPrimaryPressed: theme.colors.iconPrimaryPressed,\n iconPrimaryDisabled: theme.colors.iconPrimaryDisabled,\n iconPrimaryMuted: theme.colors.iconPrimaryMuted,\n iconAccent: theme.colors.iconAccent,\n iconSecondaryDefault: theme.colors.iconSecondaryDefault,\n iconSecondarySubdued: theme.colors.iconSecondarySubdued,\n iconSecondaryDisabled: theme.colors.iconSecondaryDisabled,\n iconSuccess: theme.colors.iconSuccess,\n iconWarning: theme.colors.iconWarning,\n iconCritical: theme.colors.iconCritical,\n iconDecorativeGreen: theme.colors.iconDecorativeGreen,\n iconDecorativeLightBlue: theme.colors.iconDecorativeLightBlue,\n iconDecorativeRed: theme.colors.iconDecorativeRed,\n iconDecorativePurple: theme.colors.iconDecorativePurple,\n iconGreyDefault: theme.colors.iconGreyDefault,\n});\n\nexport const backgroundColors = Object.freeze({\n fillBaseAccent: theme.colors.fillBaseAccent,\n fillBaseDefault: theme.colors.fillBaseDefault,\n fillBaseSubdued: theme.colors.fillBaseSubdued,\n fillBaseHovered: theme.colors.fillBaseHovered,\n fillBasePressed: theme.colors.fillBasePressed,\n fillBaseDisabled: theme.colors.fillBaseDisabled,\n fillOverlay: theme.colors.fillOverlay,\n fillPrimaryDefault: theme.colors.fillPrimaryDefault,\n fillPrimaryHovered: theme.colors.fillPrimaryHovered,\n fillPrimaryPressed: theme.colors.fillPrimaryPressed,\n fillPrimarySubdued: theme.colors.fillPrimarySubdued,\n fillPrimaryDisabled: theme.colors.fillPrimaryDisabled,\n fillAccent: theme.colors.fillAccent,\n fillSecondary: theme.colors.fillSecondary,\n fillSecondarySubdued: theme.colors.fillSecondarySubdued,\n fillSecondaryPressed: theme.colors.fillSecondaryPressed,\n fillSuccessAccent: theme.colors.fillSuccessAccent,\n fillSuccessSubdued: theme.colors.fillSuccessSubdued,\n fillWarning: theme.colors.fillWarning,\n fillWarningSubdued: theme.colors.fillWarningSubdued,\n fillCriticalAccent: theme.colors.fillCriticalAccent,\n fillCriticalSubdued: theme.colors.fillCriticalSubdued,\n fillDecorativeGreen: theme.colors.fillDecorativeGreen,\n fillDecorativeLightBlue: theme.colors.fillDecorativeLightBlue,\n fillDecorativeRed: theme.colors.fillDecorativeRed,\n fillDecorativePurple: theme.colors.fillDecorativePurple,\n fillDecorativeYellow: theme.colors.fillDecorativeYellow,\n fillDecorativeWhite: theme.colors.fillDecorativeWhite,\n});\n\n// à voir comment l'intégrer sans casser le reste du site\nexport const globalStyles = globalCss({\n \"#root\": {\n color: textColors.textBaseDefault,\n },\n});\n","import { useIntercom } from \"src/use-intercom\";\n\nimport { styled, theme } from \"src/styles/stitches/theme\";\n\nconst IntercomButton = styled(\"div\", {\n position: \"absolute\",\n bottom: \"calc(100% + 20px)\",\n background: theme.colors.backgroundAccent,\n borderRadius: 9999,\n width: 60,\n height: 60,\n right: 20,\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n fill: \"white\",\n cursor: \"pointer\",\n filter: `drop-shadow(${theme.elevation.elevation1Light})`,\n});\n\nexport function Intercom() {\n const { show } = useIntercom();\n\n return (\n
\n {\n show();\n }}\n >\n \n \n \n \n
\n );\n}\n","import { Text } from \"@chakra-ui/react\";\nimport { WithChildren } from \"src/types\";\n\n/**\n * TODO refactor this component\n * @param {any} props\n * @returns\n */\n\ntype TextsProps = React.ComponentProps & WithChildren<{}>;\n\nexport const Texts = ({\n fontSize = \"md\",\n fontWeight = \"400\",\n color = \"#212121\",\n children,\n ...props\n}: TextsProps) => (\n <>\n \n {children}\n \n \n);\n","import React from \"react\";\nimport { Text, TextProps } from \"@chakra-ui/react\";\n\ntype Props = {\n children: React.ReactNode;\n fontSize?: string | string[];\n fontFamily?: string;\n fontWeight?: string;\n color?: string;\n};\n\nexport function Title({\n children,\n fontSize = \"2xl\",\n fontFamily = \"Roslindale\",\n fontWeight = \"700\",\n color = \"black\",\n ...props\n}: Props & TextProps) {\n return (\n \n {children}\n \n );\n}\n","import PropTypes from \"prop-types\";\n\ntype SVGProps = {\n size: string;\n borderColor?: string;\n borderWidth?: string;\n color?: string;\n};\n\nexport const PawPrint = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n \n \n \n \n );\n};\n\n//OSTHEOPATHIE\nexport const OST = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n );\n};\n\nOST.propTypes = {\n size: PropTypes.string,\n color: PropTypes.string,\n borderColor: PropTypes.string,\n borderWidth: PropTypes.string,\n};\n\nOST.defaultProps = {\n size: null,\n color: \"#616161\",\n borderColor: \"#616161\",\n borderWidth: \"0\",\n};\n\n//EXAMEN / EXAMEN ANNUEL\nexport const EXAM = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n );\n};\n\n//EXAMEN\nexport const EXAMA = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n );\n};\n\n//DETARTRAGE\nexport const DET = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n );\n};\n\n//VETERINAIRE\nexport const VET = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n \n \n \n \n \n );\n};\n\n//Complément alimentaire\nexport const CALIM = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n \n );\n};\n\n//Phytotherapie\nexport const PHYT = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n );\n};\n\n//Hospitalisation\nexport const HOSP = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n );\n};\n\n//Antiparasite\nexport const ANTP = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n );\n};\n\n//Pharmacie\nexport const PHAR = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n );\n};\n\n//Désensibilisation\nexport const DES = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n );\n};\n\n//Dépistage\nexport const DEP = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n \n \n \n \n \n \n );\n};\n\n//Vaccin\nexport const VACC = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n \n \n \n \n \n \n );\n};\n\n//Vermifuge\nexport const VERM = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n );\n};\n\n//Stérilisation\nexport const STER = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n \n \n \n \n \n \n \n \n );\n};\n\n//Ambulance\nexport const AMB = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n );\n};\n\n//Euthanasie\nexport const EUTH = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n Artboard 1\n \n \n \n \n \n );\n};\n\n//Produit hygiène\nexport const HYG = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n \n );\n};\n\n//Homéopathie\nexport const HOM = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n );\n};\n\n//Analyses de laboratoire, examens radiologiques, radiothérapie et radiodiagnostics\nexport const LABO = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n \n \n \n \n \n );\n};\n\n//Séjour en clinique vétérinaire nécéssité par une intervention chirurgicale\nexport const CLINI = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n \n \n );\n};\n\n//Soins et de médicaments prescrits par le docteur vétérinaire\nexport const SOIN = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n );\n};\n\n//Maladies ou accident pré-existants\nexport const EXMALA = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n );\n};\n\n//Maladies d'orignie congénitales ou héréditaire\nexport const MALAHERI = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n \n \n \n \n \n );\n};\n\n//Maladies qui auraient pu être évitées\nexport const MALAEVI = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n \n \n \n \n );\n};\n\n//Tous frais non prescrits par un vétérinaire inscrit à l'Ordre\nexport const EXTEVET = ({\n size = \"\",\n color = \"#616161\",\n borderColor = \"#616161\",\n borderWidth = \"0\",\n}: SVGProps) => {\n return (\n \n \n \n \n \n \n \n \n \n \n );\n};\n\n//Notifications\nexport const NOTIFICATION = () => {\n return (\n \n \n \n \n );\n};\n\nexport const WarningIcon = () => {\n return (\n \n \n \n );\n};\n","/* eslint-disable no-nested-ternary */\nimport { ReactNode, useState } from \"react\";\nimport {\n Flex,\n Accordion,\n AccordionItem,\n AccordionButton,\n AccordionPanel,\n AccordionIcon,\n Divider,\n Switch,\n Center,\n SimpleGrid,\n} from \"@chakra-ui/react\";\n\nimport Lock from \"@iconscout/react-unicons/icons/uil-lock\";\nimport { Texts } from \"../texts/Texts\";\nimport { Title } from \"../texts/Title\";\n\ntype Information = {\n name: string;\n color: string;\n bg: string;\n};\n\ntype Option = {\n icon: ReactNode;\n description: string;\n};\n\ntype Props = {\n bg?: string;\n bgOptionIcons?: string;\n optionIcon?: ReactNode;\n optionDescription?: ReactNode;\n optionTitle?: ReactNode;\n optionPrice?: number | null;\n selected?: boolean;\n disabled?: boolean;\n optionsIncluded?: Array