@mmb-digital/design-system-web 0.1.342-alpha.0 → 0.1.343
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.cjs.js → index.cjs} +1 -1
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.ts +99 -99
- package/dist/{index.esm.js → index.js} +1 -1
- package/dist/index.js.map +1 -0
- package/package.json +10 -3
- package/dist/index.cjs.js.map +0 -1
- package/dist/index.esm.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.cjs","sources":["../src/contexts/mediaType/MediaTypeContext.ts","../src/contexts/mediaType/MediaTypeProvider.tsx","../src/types.ts","../src/contexts/mediaType/useMediaType.ts","../src/contexts/colorScheme/ColorSchemeContext.ts","../src/contexts/colorScheme/ColorSchemeProvider.tsx","../src/contexts/colorScheme/useColorScheme.ts","../src/contexts/designSystemMessages/DesignSystemMessagesContext.ts","../src/contexts/designSystemMessages/DesignSystemMessagesProvider.tsx","../src/contexts/designSystemPropDefaults/DesignSystemPropDefaultsContext.ts","../src/contexts/designSystemPropDefaults/DesignSystemPropDefaultsProvider.tsx","../src/contexts/designSystem/DesignSystemProvider.tsx","../src/utils/getClampedFontSize.ts","../src/utils/getColor.ts","../src/utils/isRenderable.ts","../src/utils/mergeRefs.ts","../src/utils/pxToRem.ts","../src/utils/renderReactNodeArray.tsx","../node_modules/@emotion/memoize/dist/emotion-memoize.esm.js","../node_modules/@emotion/is-prop-valid/dist/emotion-is-prop-valid.esm.js","../src/utils/styled.ts","../src/utils/useChooseColor.ts","../src/contexts/designSystem/useDesignSystem.ts","../src/contexts/fieldLabelStore.tsx","../src/contexts/fieldConfig.tsx","../src/contexts/designSystemMessages/useDesignSystemMessages.ts","../src/contexts/designSystemPropDefaults/useDesignSystemPropDefaults.ts","../src/components/accordion/types.ts","../src/components/iconSystem/svg/arrowDown/IconSystemArrowDownBig.tsx","../src/components/iconSystem/svg/arrowDown/IconSystemArrowDownSmall.tsx","../src/components/iconSystem/svg/arrowLeft/IconSystemArrowLeftBig.tsx","../src/components/iconSystem/svg/arrowLeft/IconSystemArrowLeftSmall.tsx","../src/components/iconSystem/svg/arrowRight/IconSystemArrowRightBig.tsx","../src/components/iconSystem/svg/arrowRight/IconSystemArrowRightSmall.tsx","../src/components/iconSystem/svg/arrowUp/IconSystemArrowUpBig.tsx","../src/components/iconSystem/svg/arrowUp/IconSystemArrowUpSmall.tsx","../src/components/iconSystem/svg/arrowUpRight/IconSystemArrowUpRightBig.tsx","../src/components/iconSystem/svg/arrowUpRight/IconSystemArrowUpRightSmall.tsx","../src/components/iconSystem/svg/bank/IconSystemBankBig.tsx","../src/components/iconSystem/svg/bank/IconSystemBankSmall.tsx","../src/components/iconSystem/svg/checkmark/IconSystemCheckmarkBig.tsx","../src/components/iconSystem/svg/checkmark/IconSystemCheckmarkSmall.tsx","../src/components/iconSystem/svg/chevronDown/IconSystemChevronDownBig.tsx","../src/components/iconSystem/svg/chevronDown/IconSystemChevronDownSmall.tsx","../src/components/iconSystem/svg/chevronLeft/IconSystemChevronLeftBig.tsx","../src/components/iconSystem/svg/chevronLeft/IconSystemChevronLeftSmall.tsx","../src/components/iconSystem/svg/chevronRight/IconSystemChevronRightBig.tsx","../src/components/iconSystem/svg/chevronRight/IconSystemChevronRightSmall.tsx","../src/components/iconSystem/svg/chevronUp/IconSystemChevronUpBig.tsx","../src/components/iconSystem/svg/chevronUp/IconSystemChevronUpSmall.tsx","../src/components/iconSystem/svg/close/IconSystemCloseBig.tsx","../src/components/iconSystem/svg/close/IconSystemCloseSmall.tsx","../src/components/iconSystem/svg/crosshair/IconSystemCrosshairBig.tsx","../src/components/iconSystem/svg/crosshair/IconSystemCrosshairSmall.tsx","../src/components/iconSystem/svg/event/IconSystemEventBig.tsx","../src/components/iconSystem/svg/event/IconSystemEventSmall.tsx","../src/components/iconSystem/svg/fileText/IconSystemFileTextBig.tsx","../src/components/iconSystem/svg/fileText/IconSystemFileTextSmall.tsx","../src/components/iconSystem/svg/logout/IconSystemLogoutBig.tsx","../src/components/iconSystem/svg/logout/IconSystemLogoutSmall.tsx","../src/components/iconSystem/svg/map/IconSystemMapBig.tsx","../src/components/iconSystem/svg/map/IconSystemMapSmall.tsx","../src/components/iconSystem/svg/minus/IconSystemMinusBig.tsx","../src/components/iconSystem/svg/minus/IconSystemMinusSmall.tsx","../src/components/iconSystem/svg/pin/IconSystemPinBig.tsx","../src/components/iconSystem/svg/pin/IconSystemPinSmall.tsx","../src/components/iconSystem/svg/refresh/IconSystemRefreshBig.tsx","../src/components/iconSystem/svg/refresh/IconSystemRefreshSmall.tsx","../src/components/iconSystem/svg/search/IconSystemSearchBig.tsx","../src/components/iconSystem/svg/search/IconSystemSearchSmall.tsx","../src/components/iconSystem/svg/share/IconSystemShareBig.tsx","../src/components/iconSystem/svg/share/IconSystemShareSmall.tsx","../src/components/iconSystem/svg/spinner/IconSystemSpinnerBig.tsx","../src/components/iconSystem/svg/spinner/IconSystemSpinnerSmall.tsx","../src/components/iconSystem/svg/trash/IconSystemTrashBig.tsx","../src/components/iconSystem/svg/trash/IconSystemTrashSmall.tsx","../src/components/iconSystem/svg/unorderedList/IconSystemUnorderedListBig.tsx","../src/components/iconSystem/svg/unorderedList/IconSystemUnorderedListSmall.tsx","../src/components/iconSystem/svg/calendar/IconSystemCalendarBig.tsx","../src/components/iconSystem/svg/calendar/IconSystemCalendarSmall.tsx","../src/components/iconSystem/svg/chevronRightCircle/IconChevronRightCircleBig.tsx","../src/components/iconSystem/svg/chevronRightCircle/IconChevronRightCircleSmall.tsx","../src/components/iconSystem/svg/clock/IconSystemClockBig.tsx","../src/components/iconSystem/svg/clock/IconSystemClockSmall.tsx","../src/components/iconSystem/svg/closeCircle/IconSystemCloseCircleBig.tsx","../src/components/iconSystem/svg/closeCircle/IconSystemCloseCircleSmall.tsx","../src/components/iconSystem/svg/download/IconSystemDownloadBig.tsx","../src/components/iconSystem/svg/download/IconSystemDownloadSmall.tsx","../src/components/iconSystem/svg/eyeClosed/IconSystemEyeClosedBig.tsx","../src/components/iconSystem/svg/eyeClosed/IconSystemEyeClosedSmall.tsx","../src/components/iconSystem/svg/eyeOpen/IconSystemEyeOpenBig.tsx","../src/components/iconSystem/svg/eyeOpen/IconSystemEyeOpenSmall.tsx","../src/components/iconSystem/svg/mail/IconSystemMailBig.tsx","../src/components/iconSystem/svg/mail/IconSystemMailSmall.tsx","../src/components/iconSystem/svg/menu/IconSystemMenuBig.tsx","../src/components/iconSystem/svg/menu/IconSystemMenuSmall.tsx","../src/components/iconSystem/svg/plus/IconSystemPlusBig.tsx","../src/components/iconSystem/svg/plus/IconSystemPlusSmall.tsx","../src/components/iconSystem/svg/plusCircle/IconSystemPlusCircleBig.tsx","../src/components/iconSystem/svg/plusCircle/IconSystemPlusCircleSmall.tsx","../src/components/iconSystem/svg/uploadCloud/IconSystemUploadCloudBig.tsx","../src/components/iconSystem/svg/uploadCloud/IconSystemUploadCloudSmall.tsx","../src/components/iconSystem/types.ts","../src/components/iconSystem/IconSystem.style.ts","../src/components/iconSystem/IconSystem.tsx","../src/theme/spacing.ts","../src/theme/whiteSpace.ts","../src/theme/fontWeight.ts","../src/theme/figma/mmb_variables-25-12-09.ts","../src/theme/theme.ts","../src/theme/overflow.ts","../src/theme/borderRadius.ts","../src/theme/flexWrap.ts","../src/theme/textDecoration.ts","../src/components/spanButton/SpanButton.style.ts","../src/components/spanButton/SpanButton.tsx","../src/components/typography/types.ts","../src/components/typography/Typography.style.ts","../src/components/typography/Typography.tsx","../src/components/accordion/accordionItem/AccordionItem.style.ts","../src/components/accordion/accordionItem/AccordionItem.tsx","../src/components/accordion/accordionContent/AccordionContent.style.ts","../src/components/accordion/accordionContent/AccordionContent.tsx","../src/components/accordion/accordionKeyValue/AccordionKeyValue.style.ts","../src/components/visuallyHidden/VisuallyHidden.style.ts","../src/components/visuallyHidden/VisuallyHidden.tsx","../src/components/button/types.ts","../src/components/button/Button.style.ts","../src/components/button/Button.tsx","../src/components/buttonsLayout/types.ts","../src/components/buttonsLayout/ButtonsLayout.style.ts","../src/components/calculatorResult/description/CalculatorResultDescription.tsx","../src/components/modal/Modal.domFunctions.ts","../src/components/modal/modalCloseButton/ModalCloseButton.style.ts","../src/components/modal/modalCloseButton/ModalCloseButton.tsx","../src/components/modal/modalOverlay/ModalOverlay.style.ts","../src/components/modal/modalOverlay/ModalOverlay.tsx","../src/components/modal/types.ts","../src/components/modal/Modal.style.ts","../src/components/modal/Modal.tsx","../src/components/modal/useModalFocusTrap.ts","../src/components/calculatorResult/modal/CalculatorResultModal.style.ts","../src/components/calculatorResult/modal/CalculatorResultModal.tsx","../src/components/calculatorResult/types.ts","../src/components/stack/types.tsx","../src/components/stack/Stack.style.ts","../src/components/stack/Stack.tsx","../src/components/formattedMessage/formattedMessage/FormattedMessage.tsx","../src/components/formattedMessage/formattedHtmlMessage/FormattedHtmlMessage.tsx","../src/components/formattedMessage/isMessageDisplayable/isMessageDisplayable.ts","../src/components/formattedMessage/isMessageDisplayable/isMessageDisplayableConfig.ts","../src/components/formattedMessage/isMessageDisplayable/useIsMessageDisplayable.ts","../src/components/iconProduct/svg/bill/IconBillBig.tsx","../src/components/iconProduct/svg/bill/IconBillSmall.tsx","../src/components/iconProduct/svg/check/IconCheckBig.tsx","../src/components/iconProduct/svg/check/IconCheckSmall.tsx","../src/components/iconProduct/svg/graphIncrease/IconGraphIncreaseBig.tsx","../src/components/iconProduct/svg/graphIncrease/IconGraphIncreaseSmall.tsx","../src/components/iconProduct/svg/information/IconProductInformationBig.tsx","../src/components/iconProduct/svg/information/IconProductInformationSmall.tsx","../src/components/iconProduct/svg/loginPassword/IconLoginPasswordBig.tsx","../src/components/iconProduct/svg/loginPassword/IconLoginPasswordSmall.tsx","../src/components/iconProduct/svg/moneyBag/IconMoneyBagBig.tsx","../src/components/iconProduct/svg/moneyBag/IconMoneyBagSmall.tsx","../src/components/iconProduct/svg/passwordLock/IconProductPasswordLockBig.tsx","../src/components/iconProduct/svg/passwordLock/IconProductPasswordLockSmall.tsx","../src/components/iconProduct/svg/people/IconPeopleBig.tsx","../src/components/iconProduct/svg/people/IconPeopleSmall.tsx","../src/components/iconProduct/svg/piggyBank/IconPiggyBankBig.tsx","../src/components/iconProduct/svg/piggyBank/IconPiggyBankSmall.tsx","../src/components/iconProduct/svg/reward/IconProductRewardBig.tsx","../src/components/iconProduct/svg/reward/IconProductRewardSmall.tsx","../src/components/iconProduct/svg/user/IconUserBig.tsx","../src/components/iconProduct/svg/user/IconUserSmall.tsx","../src/components/iconProduct/svg/userAddPlus/IconUserAddPlusBig.tsx","../src/components/iconProduct/svg/userAddPlus/IconUserAddPlusSmall.tsx","../src/components/iconProduct/svg/warningCircle/IconProductWarningCircleBig.tsx","../src/components/iconProduct/svg/warningCircle/IconProductWarningCircleSmall.tsx","../src/components/iconProduct/svg/warningTriangle/IconProductWarningTriangleBig.tsx","../src/components/iconProduct/svg/warningTriangle/IconProductWarningTriangleSmall.tsx","../src/components/iconProduct/svg/atm/IconAtmBig.tsx","../src/components/iconProduct/svg/atm/IconAtmSmall.tsx","../src/components/iconProduct/svg/bank/IconBankBig.tsx","../src/components/iconProduct/svg/bank/IconBankSmall.tsx","../src/components/iconProduct/svg/billingPayment/IconBillingPaymentBig.tsx","../src/components/iconProduct/svg/billingPayment/IconBillingPaymentSmall.tsx","../src/components/iconProduct/svg/coinsStack/IconCoinsStackBig.tsx","../src/components/iconProduct/svg/coinsStack/IconCoinsStackSmall.tsx","../src/components/iconProduct/svg/creditCard/IconCreditCardBig.tsx","../src/components/iconProduct/svg/creditCard/IconCreditCardSmall.tsx","../src/components/iconProduct/svg/helpChat/IconHelpChatBig.tsx","../src/components/iconProduct/svg/helpChat/IconHelpChatSmall.tsx","../src/components/iconProduct/svg/houseRefresh/IconHouseRefreshBig.tsx","../src/components/iconProduct/svg/houseRefresh/IconHouseRefreshSmall.tsx","../src/components/iconProduct/svg/mailCheck/IconMailCheckBig.tsx","../src/components/iconProduct/svg/mailCheck/IconMailCheckSmall.tsx","../src/components/iconProduct/svg/mobilePhone/IconMobilePhoneBig.tsx","../src/components/iconProduct/svg/mobilePhone/IconMobilePhoneSmall.tsx","../src/components/iconProduct/svg/moneta/IconMonetaBig.tsx","../src/components/iconProduct/svg/moneta/IconMonetaSmall.tsx","../src/components/iconProduct/svg/shieldCheck/IconShieldCheckBig.tsx","../src/components/iconProduct/svg/shieldCheck/IconShieldCheckSmall.tsx","../src/components/iconProduct/svg/suitcase/IconSuitcaseBig.tsx","../src/components/iconProduct/svg/suitcase/IconSuitcaseSmall.tsx","../src/components/iconProduct/svg/wallet/IconWalletBig.tsx","../src/components/iconProduct/svg/wallet/IconWalletSmall.tsx","../src/components/iconProduct/types.ts","../src/components/iconProduct/constants.ts","../src/components/iconProduct/IconProduct.style.ts","../src/components/iconProduct/IconProduct.tsx","../src/components/tooltip/types.ts","../src/components/tooltip/floatingElement/TooltipFloatingElement.style.ts","../src/components/tooltip/floatingElement/TooltipFloatingElement.tsx","../src/components/tooltip/general/TooltipGeneral.style.ts","../src/components/tooltip/general/TooltipGeneral.tsx","../src/constants.ts","../src/components/tooltip/info/TooltipInfo.style.ts","../src/components/tooltip/info/TooltipInfo.tsx","../src/components/tooltip/infoConditional/TooltipInfoConditional.tsx","../src/components/tooltip/util.ts","../src/components/calculatorResult/CalculatorResult.style.ts","../src/components/checkboxField/checkboxControl/CheckboxControl.style.ts","../src/components/checkboxField/checkboxControl/CheckboxControl.tsx","../src/components/checkboxField/checkboxControl/svgHandler.ts","../src/hooks/useUniqueIdIfIsUndefined.ts","../src/components/checkboxField/types.ts","../src/components/checkboxField/checkbox/Checkbox.style.ts","../src/components/checkboxField/checkbox/Checkbox.tsx","../src/components/checkboxField/CheckboxField.tsx","../src/components/circularProgressBar/CircularProgressBar.style.ts","../src/components/circularProgressBar/CircularProgressBar.tsx","../src/components/comboBoxField/types.ts","../src/components/inputBase/useAddonWidth.ts","../src/components/inputBase/InputBase.style.ts","../src/components/inputBase/InputBase.tsx","../src/formatters.tsx","../src/components/comboBoxField/comboBoxControl/ComboBoxControl.style.ts","../src/components/comboBoxField/comboBoxControl/ComboBoxControl.tsx","../src/components/comboBoxField/comboBoxControl/useComboBoxFormatter.tsx","../src/components/fieldWrapper/types.ts","../src/components/inputLabel/types.ts","../src/components/inputLabel/InputLabel.style.ts","../src/components/inputLabel/InputLabel.tsx","../src/components/fieldWrapper/FieldWrapper.style.ts","../src/components/fieldWrapper/FieldWrapper.tsx","../src/components/fieldWrapper/withFieldWrapper.tsx","../src/components/comboBoxField/comboBox/ComboBox.tsx","../src/components/selectField/types.ts","../src/components/selectField/selectControl/DropdownIndicator.tsx","../src/components/selectField/selectControl/SelectControl.style.ts","../src/components/selectField/selectControl/SelectControl.tsx","../src/components/selectField/selectControl/useSelectFormatter.tsx","../src/components/selectField/select/Select.tsx","../src/components/datePickerField/customHeader/CustomHeader.style.ts","../src/components/datePickerField/customHeader/CustomHeader.tsx","../src/components/datePickerField/datePickerControl/InputBaseWithInnerRef.tsx","../src/components/datePickerField/datePickerControl/DatePickerControl.style.ts","../src/components/datePickerField/datePickerControl/DatePickerControl.tsx","../src/components/datePickerField/constants.ts","../src/components/datePickerField/datePicker/DatePicker.tsx","../src/components/emailInputField/emailInput/EmailInput.tsx","../src/components/errorBox/errorBoxListItem/ErrorBoxListItem.style.ts","../src/components/errorBox/errorBoxListItem/ErrorBoxListItem.tsx","../src/components/errorBox/errorBoxList/ErrorBoxList.style.ts","../src/components/errorBox/errorBoxList/ErrorBoxList.tsx","../src/components/errorBox/ErrorBox.style.ts","../src/components/errorBox/ErrorBox.tsx","../src/components/fileInputField/types.ts","../src/components/fileInputField/utils.ts","../src/components/fileInputField/fileInput/Dropzone.style.ts","../src/components/fileInputField/fileInput/Dropzone.tsx","../src/components/fileInputField/fileInput/fileList/ErrorRow.style.ts","../src/components/fileInputField/fileInput/fileList/ErrorRow.tsx","../src/components/fileInputField/fileInput/fileList/FileRow.style.ts","../src/components/fileInputField/fileInput/fileList/FileRow.tsx","../src/components/fileInputField/fileInput/fileList/FileList.tsx","../src/components/fileInputField/fileInput/FileInputControl.style.ts","../src/components/fileInputField/fileInput/FileInputControl.tsx","../src/components/fileInputField/fileInput/FileInput.tsx","../src/components/formattedAmount/types.ts","../src/components/formattedAmount/utils.ts","../src/components/formattedAmount/reactIntl/useFormatAmount.ts","../src/components/formattedAmount/nextIntl/useFormatAmount.ts","../src/components/formattedAmount/BaseFormattedAmount.tsx","../src/components/formattedPercentage/useFormatPercentage.ts","../src/components/formattedPercentage/FormattedPercentage.tsx","../src/components/formattedPercentage/index.ts","../src/components/infobox/types.ts","../src/components/infobox/Infobox.style.ts","../src/components/infobox/Infobox.tsx","../src/form/contexts.ts","../src/form/useFormContext.ts","../src/components/formSuccessOutcome/FormSuccessOutcome.style.tsx","../src/components/iconFlag/types.ts","../src/components/iconFlag/svg/IconFlagCz.tsx","../src/components/iconFlag/svg/IconFlagEu.tsx","../src/components/iconFlag/svg/IconFlagHr.tsx","../src/components/iconFlag/svg/IconFlagUsa.tsx","../src/components/iconFlag/IconFlag.style.ts","../src/components/loader/types.ts","../src/components/loader/LoaderSvg.tsx","../src/components/loader/Loader.tsx","../src/components/loaderOverlayBox/LoaderOverlayBox.style.ts","../src/components/maskedInputField/maskedInput/MaskedInputBase.tsx","../src/components/maskedInputField/maskedInput/MaskedInput.tsx","../src/components/maskedInputField/MaskedInputField.tsx","../src/components/numberInputField/mask.ts","../src/components/numberInputField/numberInput/NumberInput.tsx","../src/components/numberInputField/NumberInputField.tsx","../src/components/paper/types.ts","../src/components/paper/Paper.style.ts","../src/components/paper/Paper.tsx","../src/components/phoneInputField/phoneInput/PhoneInput.tsx","../src/components/phoneInputField/PhoneInputField.tsx","../src/components/progressPaper/progressStepper/ProgressStepper.style.ts","../src/components/progressPaper/progressStepper/ProgressStepper.tsx","../src/components/progressPaper/ProgressPaper.style.ts","../src/components/progressPaper/ProgressPaper.tsx","../src/components/radioButtonField/radioButton/RadioButton.style.ts","../src/components/radioButtonField/radioButton/RadioButton.tsx","../src/components/radioButtonGroupField/types.ts","../src/components/radioButtonGroupField/radioButtonGroupControl/RadioButtonGroupControl.style.ts","../src/components/radioButtonGroupField/radioButtonGroupControl/RadioButtonGroupControl.tsx","../src/components/radioButtonGroupField/radioButtonGroup/RadioButtonGroup.tsx","../src/components/radioButtonGroupField/RadioButtonGroupField.tsx","../src/components/radioField/radioControl/radioControlSvgHandler.ts","../src/components/radioField/radioControl/RadioControl.style.ts","../src/components/radioField/radioControl/RadioControl.tsx","../src/components/radioField/types.ts","../src/components/radioField/radio/Radio.style.ts","../src/components/radioField/radio/Radio.tsx","../src/components/radioGroupField/types.ts","../src/components/radioGroupField/radioGroupControl/RadioGroupControl.style.ts","../src/components/radioGroupField/radioGroupControl/RadioGroupControl.tsx","../src/components/radioGroupField/radioGroup/RadioGroup.tsx","../src/components/radioGroupField/RadioGroupField.tsx","../src/components/searchInput/SearchInput.tsx","../src/components/sliderInputField/types.ts","../src/components/sliderInputField/utils/clampSliderSteps.ts","../src/components/sliderInputField/utils/getValueBySliderValueVisuallySameStepSize.ts","../src/components/sliderInputField/utils/sliderFunctionVisuallyLinearByValue.ts","../src/components/sliderInputField/utils/sliderFunctionVisuallySameStepSize.ts","../src/components/sliderInputField/utils/getSliderMax.ts","../src/components/sliderInputField/utils/getSliderValueByValue.ts","../src/components/sliderInputField/slider/Slider.style.tsx","../src/components/sliderInputField/slider/Slider.tsx","../src/components/sliderInputField/utils/getSliderHandleBackgroundSvgBase64.ts","../src/components/sliderInputField/utils/getSliderHandleBackgroundSvg.ts","../src/components/sliderInputField/utils/getSliderInputMaskedValue.ts","../src/components/sliderInputField/utils/getSliderInputUnmaskedValue.ts","../src/components/sliderInputField/sliderInput/SliderInput.style.ts","../src/components/sliderInputField/sliderInput/SliderInput.tsx","../src/components/sliderInputField/utils/getRoundedValueBySteps.ts","../src/components/stepper/types.ts","../src/components/stepper/stepperItem/StepperItem.style.ts","../src/components/stepper/stepperItem/StepperItem.tsx","../src/components/stepper/Stepper.style.ts","../src/components/storeButton/types.ts","../src/components/storeButton/assets/AndroidSvg.tsx","../src/components/storeButton/assets/AppleSvg.tsx","../src/components/storeButton/StoreButton.style.ts","../src/components/table/types.ts","../src/components/table/table/Table.style.ts","../src/components/table/tableData/TableData.style.ts","../src/components/table/tableHead/TableHead.style.ts","../src/components/table/tableHeadData/TableHeadData.style.ts","../src/components/table/tableRow/TableRow.style.ts","../src/components/tag/types.ts","../src/components/tag/Tag.style.ts","../src/components/tag/Tag.tsx","../src/components/tabs/types.ts","../src/components/tabs/tabsItem/TabsItem.style.ts","../src/components/tabs/tabsItem/TabsItem.tsx","../src/components/tabs/Tabs.style.ts","../src/components/tabs/Tabs.tsx","../src/components/textAreaField/textArea/TextArea.style.ts","../src/components/textAreaField/textArea/TextArea.tsx","../src/components/textInputField/textInput/TextInput.tsx","../src/components/toggle/Toggle.style.ts","../src/components/trailingTextInput/TrailingTextInput.tsx","../src/form/errors.ts","../src/form/types.ts","../src/form/useForm.ts","../src/components/accordion/Accordion.tsx","../src/components/accordion/accordionKeyValue/AccordionKeyValue.tsx","../src/components/buttonsLayout/ButtonsLayout.tsx","../src/components/calculatorResult/CalculatorResult.tsx","../src/components/comboBoxField/ComboBoxField.tsx","../src/components/datePickerField/DatePickerField.tsx","../src/components/emailInputField/EmailInputField.tsx","../src/components/fileInputField/FileInputField.tsx","../src/form/FormConfigProvider.tsx","../src/components/formErrorOutcome/FormErrorOutcome.tsx","../src/components/formErrorSummary/FormErrorSummary.tsx","../src/form/useSubmitErrors.ts","../src/form/FormProvider.tsx","../src/components/formSuccessOutcome/FormSuccessOutcome.tsx","../src/components/formattedAmount/reactIntl/FormattedAmount.tsx","../src/components/iconFlag/IconFlag.tsx","../src/components/loaderOverlayBox/LoaderOverlayBox.tsx","../src/components/formattedAmount/nextIntl/FormattedAmount.tsx","../src/components/radioButtonField/RadioButtonField.tsx","../src/components/radioField/RadioField.tsx","../src/components/selectField/SelectField.tsx","../src/components/sliderInputField/SliderInputField.tsx","../src/components/stepper/Stepper.tsx","../src/components/storeButton/StoreButton.tsx","../src/components/table/table/Table.tsx","../src/components/table/tableBody/TableBody.tsx","../src/components/table/tableData/TableData.tsx","../src/components/table/tableHead/TableHead.tsx","../src/components/table/tableHeadData/TableHeadData.tsx","../src/components/table/tableRow/TableRow.tsx","../src/components/textAreaField/TextAreaField.tsx","../src/components/textInputField/TextInputField.tsx","../src/components/toggle/Toggle.tsx","../src/components/tooltip/infoDisplayableCheck/TooltipInfoDisplayableCheck.tsx","../src/components/tooltip/useCreateTooltipInfoDescriptor/useCreateTooltipInfoDescriptor.tsx","../src/components/formSuccessOutcome/useFormSuccessOutcomeManager.ts","../src/components/formattedMessage/getFormattedHtmlMessageIfDisplayable/useGetFormattedHtmlMessageIfDisplayable.tsx"],"sourcesContent":["import { createContext } from 'react';\r\n\r\nimport { type MediaType } from '@/types';\r\n\r\nexport interface MediaTypeContextValue {\r\n\tmediaType?: MediaType;\r\n}\r\n\r\nconst defaultValue: MediaTypeContextValue = {\r\n\tmediaType: undefined,\r\n};\r\n\r\nexport const MediaTypeContext = createContext<MediaTypeContextValue>(defaultValue);\r\n","import { type ReactNode, useMemo, type FC } from 'react';\r\n\r\nimport { MediaTypeContext, type MediaTypeContextValue } from '@/contexts/mediaType/MediaTypeContext';\r\nimport { type MediaType } from '@/types';\r\n\r\nexport interface MediaTypeProviderProps {\r\n\tchildren: ReactNode;\r\n\tmediaType: MediaType;\r\n}\r\n\r\nexport const MediaTypeProvider: FC<MediaTypeProviderProps> = (props) => {\r\n\tconst { children, mediaType } = props;\r\n\r\n\tconst value = useMemo<MediaTypeContextValue>(() => {\r\n\t\treturn {\r\n\t\t\tmediaType: mediaType,\r\n\t\t};\r\n\t}, [mediaType]);\r\n\r\n\treturn <MediaTypeContext.Provider value={value}>{children}</MediaTypeContext.Provider>;\r\n};\r\n","import { type Property } from 'csstype';\r\nimport { type ChangeEvent, type ElementType, type FocusEvent, type HTMLInputAutoCompleteAttribute, type ReactNode } from 'react';\r\nimport { type MessageDescriptor } from 'react-intl';\r\n\r\nimport { type MessageValues, type PrimitiveMessageValues } from '@/components/formattedMessage';\r\nimport { type TooltipInfoDescriptor } from '@/components/tooltip';\r\nimport { type DesignSystemBaseProps } from '@/contexts';\r\n\r\nexport interface SsrProps {\r\n\tsuppressHydrationWarning?: boolean;\r\n}\r\n\r\nexport interface MessageDescriptorWithPrimitiveValues extends MessageDescriptor {\r\n\t/**\r\n\t * Since `FormattedHtmlMessage` uses `dangerouslySetInnerHTML` under the hood and sometimes\r\n\t * includes user input, we need to escape the `values` prop to prevent XSS vulnerabilities.\r\n\t *\r\n\t * In case we need to display HTML content (and we're sure it's safe), the `htmlValues` prop\r\n\t * should be used instead.\r\n\t */\r\n\thtmlValues?: PrimitiveMessageValues;\r\n\tvalues?: PrimitiveMessageValues;\r\n}\r\n\r\nexport interface MessageDescriptorWithValues extends MessageDescriptor {\r\n\tvalues?: MessageValues;\r\n}\r\n\r\nexport interface FieldControlProps extends DesignSystemBaseProps {\r\n\tdescribedBy?: string;\r\n\tid?: string;\r\n\tinvalid?: boolean;\r\n\tlabelledBy?: string;\r\n\tname?: string;\r\n\trequired?: boolean;\r\n}\r\n\r\nexport enum InputSize {\r\n\tmd = 'md',\r\n\txl = 'xl',\r\n}\r\n\r\nexport enum InputTextAlign {\r\n\tcenter = 'center',\r\n\tleft = 'left',\r\n\tright = 'right',\r\n}\r\n\r\nexport enum MediaType {\r\n\tdesktop = 'desktop',\r\n\tmobile = 'mobile',\r\n\ttablet = 'tablet',\r\n}\r\n\r\nexport enum ColorScheme {\r\n\tdark = 'dark',\r\n\tlight = 'light',\r\n}\r\n\r\nexport interface ColorObject<Dark extends string = string, Light extends string = string> {\r\n\tdark: Dark;\r\n\tlight: Light;\r\n}\r\n\r\n// TODO: This interface should be removed in favour of `InputBaseProps` and `withFieldWrapper` usage.\r\nexport interface InputProps extends FieldControlProps {\r\n\tariaLabel?: string;\r\n\tautoComplete?: HTMLInputAutoCompleteAttribute;\r\n\tbutton?: ReactNode;\r\n\tcolorInput?: Property.Color | undefined;\r\n\tdisabled?: boolean;\r\n\thalfWidth?: boolean;\r\n\tmaxLength?: number;\r\n\tname: string;\r\n\tonBlur?: ((event: FocusEvent<HTMLInputElement>) => void) | undefined;\r\n\tonChange?: ((event: ChangeEvent<HTMLInputElement>) => void) | undefined;\r\n\tprefix?: ReactNode;\r\n\tsize: InputSize;\r\n\tsuffix?: ReactNode;\r\n\tvalue?: string;\r\n}\r\n\r\nexport enum FieldOptionality {\r\n\toptional = 'optional',\r\n\toptionalWithoutLabelSuffix = 'optionalWithoutLabelSuffix',\r\n\trequired = 'required',\r\n}\r\n\r\nexport interface InputLabelPassthroughProps {\r\n\tlabel?: ReactNode;\r\n\tlabelAs?: ElementType;\r\n\t// TODO: Deprecate/remove in favour of `hiddenHintText`. Even components such as `Radio` should\r\n\t// use the name `hiddenHintText` despite not having any `hintText` prop.\r\n\r\n\t/**\r\n\t * Visually hidden text for screen readers providing additional info, such as the availability of a tooltip.\r\n\t * Prefer using `hiddenHintText` in `FieldWrapper` where possible.\r\n\t */\r\n\tlabelHiddenText?: string;\r\n\tlabelId?: string;\r\n\tlabelSuffix?: ReactNode;\r\n\ttooltip?: TooltipInfoDescriptor;\r\n}\r\n\r\nexport enum LabelTooltipPosition {\r\n\tinline = 'inline',\r\n\trightCenter = 'rightCenter',\r\n}\r\n","import { useContext } from 'react';\r\n\r\nimport { MediaTypeContext } from '@/contexts/mediaType/MediaTypeContext';\r\nimport { MediaType } from '@/types';\r\n\r\nconst fallbackMediaType = MediaType.desktop;\r\n\r\nexport type UseMediaTypeParam = MediaType | { mediaType?: MediaType | undefined };\r\nexport interface UseMediaTypeOptions {\r\n\tdefaultMediaType?: MediaType;\r\n}\r\n\r\n/**\r\n * priorities:\r\n *\r\n * 1. value passed to the hook\r\n * 2. value passed from the nearest provider\r\n * 3. defaultValue passed in the options object to the hook\r\n * 4. fallbackMediaType\r\n */\r\nexport const useMediaType = (param?: UseMediaTypeParam, options?: UseMediaTypeOptions): MediaType => {\r\n\tconst context = useContext(MediaTypeContext);\r\n\r\n\tconst paramMediaType = typeof param === 'string' ? param : param?.mediaType;\r\n\tconst defaultMediaType = options?.defaultMediaType;\r\n\r\n\tif (paramMediaType !== undefined) {\r\n\t\treturn paramMediaType;\r\n\t}\r\n\r\n\t// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\r\n\tconst contextMediaType = context?.mediaType;\r\n\r\n\tif (contextMediaType === undefined) {\r\n\t\treturn defaultMediaType === undefined ? fallbackMediaType : defaultMediaType;\r\n\t}\r\n\r\n\treturn contextMediaType;\r\n};\r\n","import { createContext } from 'react';\r\n\r\nimport { type ColorScheme } from '@/types';\r\n\r\nexport interface ColorSchemeContextValue {\r\n\tcolorScheme?: ColorScheme;\r\n}\r\n\r\nconst defaultValue: ColorSchemeContextValue = {\r\n\tcolorScheme: undefined,\r\n};\r\n\r\nexport const ColorSchemeContext = createContext<ColorSchemeContextValue>(defaultValue);\r\n","import { type ReactNode, useMemo, type FC } from 'react';\r\n\r\nimport { ColorSchemeContext, type ColorSchemeContextValue } from '@/contexts/colorScheme/ColorSchemeContext';\r\nimport { type ColorScheme } from '@/types';\r\n\r\nexport interface ColorSchemeProviderProps {\r\n\tchildren: ReactNode;\r\n\tcolorScheme: ColorScheme;\r\n}\r\n\r\nexport const ColorSchemeProvider: FC<ColorSchemeProviderProps> = (props) => {\r\n\tconst { children, colorScheme } = props;\r\n\r\n\tconst value = useMemo<ColorSchemeContextValue>(() => {\r\n\t\treturn {\r\n\t\t\tcolorScheme: colorScheme,\r\n\t\t};\r\n\t}, [colorScheme]);\r\n\r\n\treturn <ColorSchemeContext.Provider value={value}>{children}</ColorSchemeContext.Provider>;\r\n};\r\n","import { useContext } from 'react';\r\n\r\nimport { ColorSchemeContext } from '@/contexts/colorScheme/ColorSchemeContext';\r\nimport { ColorScheme } from '@/types';\r\n\r\nconst fallbackColorScheme = ColorScheme.light;\r\n\r\nexport type UseColorSchemeParam = ColorScheme | { colorScheme?: ColorScheme | undefined };\r\nexport interface UseColorSchemeOptions {\r\n\tdefaultColorScheme?: ColorScheme;\r\n}\r\n\r\n/**\r\n * priorities:\r\n *\r\n * 1. value passed to the hook\r\n * 2. value passed from the nearest provider\r\n * 3. defaultValue passed in the options object to the hook\r\n * 4. fallbackColorScheme\r\n */\r\nexport const useColorScheme = (param?: UseColorSchemeParam, options?: UseColorSchemeOptions): ColorScheme => {\r\n\tconst context = useContext(ColorSchemeContext);\r\n\r\n\tconst paramColorScheme = typeof param === 'string' ? param : param?.colorScheme;\r\n\tconst defaultColorScheme = options?.defaultColorScheme;\r\n\r\n\tif (paramColorScheme !== undefined) {\r\n\t\treturn paramColorScheme;\r\n\t}\r\n\r\n\t// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\r\n\tconst contextColorScheme = context?.colorScheme;\r\n\r\n\tif (contextColorScheme === undefined) {\r\n\t\treturn defaultColorScheme === undefined ? fallbackColorScheme : defaultColorScheme;\r\n\t}\r\n\r\n\treturn contextColorScheme;\r\n};\r\n","import { createContext, type ReactNode } from 'react';\r\n\r\nimport { type TooltipInfoDescriptor } from '@/components/tooltip';\r\n\r\n// NOTE: All root properties should be required, otherwise the provider breaks.\r\nexport interface DesignSystemFullMessages {\r\n\tbutton: {\r\n\t\tbusyGeneric?: ReactNode;\r\n\t\tbusySubmit?: ReactNode;\r\n\t};\r\n\tfieldWrapper: {\r\n\t\tgetTooltipTriggerAriaLabel?: (tooltip: TooltipInfoDescriptor, label: ReactNode) => string;\r\n\t\toptionalLabelSuffix?: ReactNode;\r\n\t\ttooltipHiddenHintText?: ReactNode;\r\n\t};\r\n\tformErrorSummary: {\r\n\t\ttitle: ReactNode;\r\n\t};\r\n}\r\n\r\nexport type DesignSystemPartialMessages = {\r\n\t[K in keyof DesignSystemFullMessages]?: Partial<{\r\n\t\t[P in keyof NonNullable<DesignSystemFullMessages[K]>]?: NonNullable<DesignSystemFullMessages[K]>[P];\r\n\t}>;\r\n};\r\n\r\nexport const fullMessages: DesignSystemFullMessages = {\r\n\tbutton: {},\r\n\tformErrorSummary: {\r\n\t\ttitle: 'Vyskytl se problém s odesláním',\r\n\t},\r\n\tfieldWrapper: {},\r\n};\r\n\r\nexport const DesignSystemMessagesContext = createContext<DesignSystemFullMessages>(fullMessages);\r\n","import { type ReactNode, useMemo } from 'react';\r\n\r\nimport { type DesignSystemFullMessages, DesignSystemMessagesContext, type DesignSystemPartialMessages, fullMessages } from './DesignSystemMessagesContext';\r\n\r\nexport interface DesignSystemMessagesProviderProps {\r\n\tchildren: ReactNode;\r\n\tmessages: DesignSystemPartialMessages;\r\n}\r\n\r\nexport const DesignSystemMessagesProvider = (props: DesignSystemMessagesProviderProps) => {\r\n\tconst { children, messages: messagesProp } = props;\r\n\r\n\tconst contextValue = useMemo(\r\n\t\t() =>\r\n\t\t\tObject.fromEntries(\r\n\t\t\t\tObject.entries(fullMessages).map(([componentName, messages]) => [\r\n\t\t\t\t\tcomponentName,\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t...messages,\r\n\t\t\t\t\t\t...(messagesProp[componentName as keyof DesignSystemFullMessages] ?? {}),\r\n\t\t\t\t\t},\r\n\t\t\t\t]),\r\n\t\t\t) as DesignSystemFullMessages,\r\n\t\t[messagesProp],\r\n\t);\r\n\r\n\treturn <DesignSystemMessagesContext.Provider value={contextValue}>{children}</DesignSystemMessagesContext.Provider>;\r\n};\r\n","import { createContext } from 'react';\r\n\r\nexport interface DesignSystemFullPropDefaults {\r\n\tbutton: {\r\n\t\tbusyDelay: number;\r\n\t};\r\n}\r\n\r\nexport type DesignSystemPartialPropDefaults = {\r\n\t[K in keyof DesignSystemFullPropDefaults]?: Partial<{\r\n\t\t[P in keyof DesignSystemFullPropDefaults[K]]?: DesignSystemFullPropDefaults[K][P];\r\n\t}>;\r\n};\r\n\r\nexport const fullPropDefaults: DesignSystemFullPropDefaults = {\r\n\tbutton: {\r\n\t\tbusyDelay: 1000,\r\n\t},\r\n};\r\n\r\nexport const DesignSystemPropDefaultsContext = createContext<DesignSystemFullPropDefaults>(fullPropDefaults);\r\n","import { type ReactNode, useMemo } from 'react';\r\n\r\nimport {\r\n\tDesignSystemPropDefaultsContext,\r\n\tfullPropDefaults,\r\n\ttype DesignSystemFullPropDefaults,\r\n\ttype DesignSystemPartialPropDefaults,\r\n} from './DesignSystemPropDefaultsContext';\r\n\r\nexport interface DesignSystemPropDefaultsProviderProps {\r\n\tchildren: ReactNode;\r\n\tdefaults: DesignSystemPartialPropDefaults;\r\n}\r\n\r\nexport const DesignSystemPropDefaultsProvider = (props: DesignSystemPropDefaultsProviderProps) => {\r\n\tconst { children, defaults: defaultsProp } = props;\r\n\r\n\tconst contextValue = useMemo(\r\n\t\t() =>\r\n\t\t\tObject.fromEntries(\r\n\t\t\t\tObject.entries(fullPropDefaults).map(([componentName, defaults]) => [\r\n\t\t\t\t\tcomponentName,\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t...defaults,\r\n\t\t\t\t\t\t...(defaultsProp[componentName as keyof DesignSystemFullPropDefaults] ?? {}),\r\n\t\t\t\t\t},\r\n\t\t\t\t]),\r\n\t\t\t) as DesignSystemFullPropDefaults,\r\n\t\t[defaultsProp],\r\n\t);\r\n\r\n\treturn <DesignSystemPropDefaultsContext.Provider value={contextValue}>{children}</DesignSystemPropDefaultsContext.Provider>;\r\n};\r\n","import { type ReactNode } from 'react';\r\n\r\nimport { ColorSchemeProvider } from '@/contexts/colorScheme/ColorSchemeProvider';\r\nimport { MediaTypeProvider } from '@/contexts/mediaType/MediaTypeProvider';\r\nimport { type ColorScheme, type MediaType } from '@/types';\r\n\r\nimport { type DesignSystemPartialMessages } from '../designSystemMessages/DesignSystemMessagesContext';\r\nimport { DesignSystemMessagesProvider } from '../designSystemMessages/DesignSystemMessagesProvider';\r\nimport { type DesignSystemPartialPropDefaults } from '../designSystemPropDefaults/DesignSystemPropDefaultsContext';\r\nimport { DesignSystemPropDefaultsProvider } from '../designSystemPropDefaults/DesignSystemPropDefaultsProvider';\r\n\r\nexport interface DesignSystemProviderProps {\r\n\tchildren: ReactNode;\r\n\tcolorScheme?: ColorScheme;\r\n\tmediaType?: MediaType;\r\n\tmessages?: DesignSystemPartialMessages;\r\n\tpropDefaults?: DesignSystemPartialPropDefaults;\r\n}\r\n\r\n/**\r\n * It is recommended to use this provider only once in a component tree, ideally near the root.\r\n * It is possible to override every provider for a subpart of the component tree.\r\n */\r\nexport const DesignSystemProvider = (props: DesignSystemProviderProps) => {\r\n\tconst { children, colorScheme, mediaType, messages, propDefaults } = props;\r\n\r\n\tlet node: ReactNode = children;\r\n\r\n\tif (colorScheme !== undefined) {\r\n\t\tnode = <ColorSchemeProvider colorScheme={colorScheme}>{node}</ColorSchemeProvider>;\r\n\t}\r\n\r\n\tif (mediaType !== undefined) {\r\n\t\tnode = <MediaTypeProvider mediaType={mediaType}>{node}</MediaTypeProvider>;\r\n\t}\r\n\r\n\tif (messages !== undefined) {\r\n\t\tnode = <DesignSystemMessagesProvider messages={messages}>{node}</DesignSystemMessagesProvider>;\r\n\t}\r\n\r\n\tif (propDefaults !== undefined) {\r\n\t\tnode = <DesignSystemPropDefaultsProvider defaults={propDefaults}>{node}</DesignSystemPropDefaultsProvider>;\r\n\t}\r\n\r\n\treturn node;\r\n};\r\n","export const getClampedFontSize = (fontSize: string) => {\r\n\treturn `\r\n\t\tclamp(${fontSize}, 0.96875 * ${fontSize} + 0.15625vw, 1.125 * ${fontSize});\r\n\t`;\r\n};\r\n","import { ColorScheme, type ColorObject } from '@/types';\r\n\r\nexport type GetColor = <Dark extends string = string, Light extends string = string>(\r\n\tcolorScheme: ColorScheme,\r\n\tcolorSchemeObject: ColorObject<Dark, Light>,\r\n) => Dark | Light;\r\n\r\nexport const getColor: GetColor = (colorScheme, colorSchemeObject) => {\r\n\tswitch (colorScheme) {\r\n\t\tcase ColorScheme.light:\r\n\t\t\treturn colorSchemeObject.light;\r\n\t\tcase ColorScheme.dark:\r\n\t\t\treturn colorSchemeObject.dark;\r\n\t\tdefault:\r\n\t\t\tthrow new Error('unexpected value in enum ColorScheme getColor');\r\n\t}\r\n};\r\n","import { type ReactNode } from 'react';\r\n\r\n// NOTE: Use this function exclusively for deciding whether to render e.g. a wrapper around a `ReactNode`.\r\n// We use JSX rules to avoid bikeshedding over empty strings etc.\r\n// https://legacy.reactjs.org/docs/jsx-in-depth.html#booleans-null-and-undefined-are-ignored\r\nexport const isRenderable = (node: ReactNode): node is Exclude<ReactNode, boolean | null | undefined> =>\r\n\t!(typeof node === 'boolean' || node === null || node === undefined);\r\n","import { type Ref } from 'react';\r\n\r\n// NOTE: Stolen from https://github.com/wojtekmaj/merge-refs\r\nexport const mergeRefs = <T>(...refs: (Ref<T> | undefined)[]): Ref<T> => {\r\n\tconst filteredRefs = refs.filter(Boolean);\r\n\r\n\tif (filteredRefs.length <= 1) {\r\n\t\treturn filteredRefs[0] ?? null;\r\n\t}\r\n\r\n\treturn (element) => {\r\n\t\tfor (const ref of filteredRefs) {\r\n\t\t\tif (typeof ref === 'function') {\r\n\t\t\t\tref(element);\r\n\t\t\t} else if (ref) {\r\n\t\t\t\tref.current = element;\r\n\t\t\t}\r\n\t\t}\r\n\t};\r\n};\r\n","const formatNumber = (number: number): string => {\r\n\treturn Number(number.toFixed(6)).toString();\r\n};\r\n\r\nexport const pxToRem = (px: number | string, base = 16): string => {\r\n\tlet value: number | undefined = undefined;\r\n\r\n\tif (typeof px === 'number') {\r\n\t\tvalue = px;\r\n\t}\r\n\tif (typeof px === 'string') {\r\n\t\tconst match = /^(-?\\d+(?:\\.\\d+)?)(px)?$/i.exec(px.trim());\r\n\t\tif (match !== null) {\r\n\t\t\tvalue = Number.parseFloat(match[1]);\r\n\t\t}\r\n\t}\r\n\r\n\tif (!Number.isFinite(value) || value === undefined) {\r\n\t\treturn '0rem';\r\n\t}\r\n\r\n\tconst rem = value / base;\r\n\r\n\treturn `${formatNumber(rem)}rem`;\r\n};\r\n","import { Fragment, type ReactElement, type ReactNode } from 'react';\r\n\r\nimport { isRenderable } from './isRenderable';\r\n\r\nexport const renderReactNodeArray = (items: ReactNode[], separator?: ReactNode) => {\r\n\tconst renderableItems = items.filter(isRenderable);\r\n\tconst separatorRenderable = isRenderable(separator);\r\n\r\n\tconst result: ReactElement[] = [];\r\n\r\n\trenderableItems.forEach((item, index) => {\r\n\t\tresult.push(<Fragment key={`item-${index}`}>{item}</Fragment>);\r\n\r\n\t\tif (separatorRenderable && index < renderableItems.length - 1) {\r\n\t\t\tresult.push(<Fragment key={`sep-${index}`}>{separator}</Fragment>);\r\n\t\t}\r\n\t});\r\n\r\n\tif (result.length === 0) {\r\n\t\treturn null;\r\n\t}\r\n\r\n\treturn result;\r\n};\r\n","function memoize(fn) {\n var cache = Object.create(null);\n return function (arg) {\n if (cache[arg] === undefined) cache[arg] = fn(arg);\n return cache[arg];\n };\n}\n\nexport { memoize as default };\n","import memoize from '@emotion/memoize';\n\n// eslint-disable-next-line no-undef\nvar reactPropsRegex = /^((children|dangerouslySetInnerHTML|key|ref|autoFocus|defaultValue|defaultChecked|innerHTML|suppressContentEditableWarning|suppressHydrationWarning|valueLink|abbr|accept|acceptCharset|accessKey|action|allow|allowUserMedia|allowPaymentRequest|allowFullScreen|allowTransparency|alt|async|autoComplete|autoPlay|capture|cellPadding|cellSpacing|challenge|charSet|checked|cite|classID|className|cols|colSpan|content|contentEditable|contextMenu|controls|controlsList|coords|crossOrigin|data|dateTime|decoding|default|defer|dir|disabled|disablePictureInPicture|disableRemotePlayback|download|draggable|encType|enterKeyHint|fetchpriority|fetchPriority|form|formAction|formEncType|formMethod|formNoValidate|formTarget|frameBorder|headers|height|hidden|high|href|hrefLang|htmlFor|httpEquiv|id|inputMode|integrity|is|keyParams|keyType|kind|label|lang|list|loading|loop|low|marginHeight|marginWidth|max|maxLength|media|mediaGroup|method|min|minLength|multiple|muted|name|nonce|noValidate|open|optimum|pattern|placeholder|playsInline|popover|popoverTarget|popoverTargetAction|poster|preload|profile|radioGroup|readOnly|referrerPolicy|rel|required|reversed|role|rows|rowSpan|sandbox|scope|scoped|scrolling|seamless|selected|shape|size|sizes|slot|span|spellCheck|src|srcDoc|srcLang|srcSet|start|step|style|summary|tabIndex|target|title|translate|type|useMap|value|width|wmode|wrap|about|datatype|inlist|prefix|property|resource|typeof|vocab|autoCapitalize|autoCorrect|autoSave|color|incremental|fallback|inert|itemProp|itemScope|itemType|itemID|itemRef|on|option|results|security|unselectable|accentHeight|accumulate|additive|alignmentBaseline|allowReorder|alphabetic|amplitude|arabicForm|ascent|attributeName|attributeType|autoReverse|azimuth|baseFrequency|baselineShift|baseProfile|bbox|begin|bias|by|calcMode|capHeight|clip|clipPathUnits|clipPath|clipRule|colorInterpolation|colorInterpolationFilters|colorProfile|colorRendering|contentScriptType|contentStyleType|cursor|cx|cy|d|decelerate|descent|diffuseConstant|direction|display|divisor|dominantBaseline|dur|dx|dy|edgeMode|elevation|enableBackground|end|exponent|externalResourcesRequired|fill|fillOpacity|fillRule|filter|filterRes|filterUnits|floodColor|floodOpacity|focusable|fontFamily|fontSize|fontSizeAdjust|fontStretch|fontStyle|fontVariant|fontWeight|format|from|fr|fx|fy|g1|g2|glyphName|glyphOrientationHorizontal|glyphOrientationVertical|glyphRef|gradientTransform|gradientUnits|hanging|horizAdvX|horizOriginX|ideographic|imageRendering|in|in2|intercept|k|k1|k2|k3|k4|kernelMatrix|kernelUnitLength|kerning|keyPoints|keySplines|keyTimes|lengthAdjust|letterSpacing|lightingColor|limitingConeAngle|local|markerEnd|markerMid|markerStart|markerHeight|markerUnits|markerWidth|mask|maskContentUnits|maskUnits|mathematical|mode|numOctaves|offset|opacity|operator|order|orient|orientation|origin|overflow|overlinePosition|overlineThickness|panose1|paintOrder|pathLength|patternContentUnits|patternTransform|patternUnits|pointerEvents|points|pointsAtX|pointsAtY|pointsAtZ|preserveAlpha|preserveAspectRatio|primitiveUnits|r|radius|refX|refY|renderingIntent|repeatCount|repeatDur|requiredExtensions|requiredFeatures|restart|result|rotate|rx|ry|scale|seed|shapeRendering|slope|spacing|specularConstant|specularExponent|speed|spreadMethod|startOffset|stdDeviation|stemh|stemv|stitchTiles|stopColor|stopOpacity|strikethroughPosition|strikethroughThickness|string|stroke|strokeDasharray|strokeDashoffset|strokeLinecap|strokeLinejoin|strokeMiterlimit|strokeOpacity|strokeWidth|surfaceScale|systemLanguage|tableValues|targetX|targetY|textAnchor|textDecoration|textRendering|textLength|to|transform|u1|u2|underlinePosition|underlineThickness|unicode|unicodeBidi|unicodeRange|unitsPerEm|vAlphabetic|vHanging|vIdeographic|vMathematical|values|vectorEffect|version|vertAdvY|vertOriginX|vertOriginY|viewBox|viewTarget|visibility|widths|wordSpacing|writingMode|x|xHeight|x1|x2|xChannelSelector|xlinkActuate|xlinkArcrole|xlinkHref|xlinkRole|xlinkShow|xlinkTitle|xlinkType|xmlBase|xmlns|xmlnsXlink|xmlLang|xmlSpace|y|y1|y2|yChannelSelector|z|zoomAndPan|for|class|autofocus)|(([Dd][Aa][Tt][Aa]|[Aa][Rr][Ii][Aa]|x)-.*))$/; // https://esbench.com/bench/5bfee68a4cd7e6009ef61d23\n\nvar isPropValid = /* #__PURE__ */memoize(function (prop) {\n return reactPropsRegex.test(prop) || prop.charCodeAt(0) === 111\n /* o */\n && prop.charCodeAt(1) === 110\n /* n */\n && prop.charCodeAt(2) < 91;\n}\n/* Z+1 */\n);\n\nexport { isPropValid as default };\n","import isPropValid from '@emotion/is-prop-valid';\r\nimport emotionStyled from '@emotion/styled';\r\n\r\nconst isDomTag = (tag: unknown) => typeof tag === 'string';\r\n\r\nconst customShouldForwardProp = (prop: string, tag: unknown) => {\r\n\tif (isDomTag(tag)) {\r\n\t\treturn isPropValid(prop) && !prop.startsWith('$');\r\n\t}\r\n\r\n\treturn prop !== 'as' && !prop.startsWith('$');\r\n};\r\n\r\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\r\nconst baseStyled = (tag: any, options?: any) => {\r\n\t// eslint-disable-next-line @typescript-eslint/no-unsafe-argument\r\n\treturn emotionStyled(tag, {\r\n\t\tshouldForwardProp: (prop: string) => customShouldForwardProp(prop, tag),\r\n\t\t...options,\r\n\t});\r\n};\r\n\r\nexport const styled = new Proxy(baseStyled, {\r\n\tget: (v, tag: string) => baseStyled(tag),\r\n}) as typeof emotionStyled;\r\n","import { useCallback } from 'react';\r\n\r\nimport { type ColorObject, type ColorScheme } from '@/types';\r\n\r\nimport { getColor } from './getColor';\r\n\r\nexport type ChooseColor = <Dark extends string = string, Light extends string = string>(colorSchemeObject: ColorObject<Dark, Light>) => Dark | Light;\r\n\r\nexport const useChooseColor = (colorScheme: ColorScheme) => {\r\n\tconst callback = useCallback<ChooseColor>(\r\n\t\t(colorSchemeObject) => {\r\n\t\t\treturn getColor(colorScheme, colorSchemeObject);\r\n\t\t},\r\n\t\t[colorScheme],\r\n\t);\r\n\r\n\treturn callback;\r\n};\r\n","import { useColorScheme, type UseColorSchemeOptions } from '@/contexts/colorScheme/useColorScheme';\r\nimport { useMediaType, type UseMediaTypeOptions } from '@/contexts/mediaType/useMediaType';\r\nimport { type ColorScheme, type MediaType } from '@/types';\r\nimport { useChooseColor } from '@/utils';\r\n\r\nexport interface UseDesignSystemParam {\r\n\tcolorScheme?: ColorScheme | undefined;\r\n\tmediaType?: MediaType | undefined;\r\n}\r\nexport interface UseDesignSystemOptions extends UseColorSchemeOptions, UseMediaTypeOptions {}\r\n\r\nexport const useDesignSystem = (param?: UseDesignSystemParam, options?: UseDesignSystemOptions) => {\r\n\tconst colorScheme = useColorScheme(param?.colorScheme, options);\r\n\tconst mediaType = useMediaType(param?.mediaType, options);\r\n\r\n\tconst chooseColor = useChooseColor(colorScheme);\r\n\r\n\treturn {\r\n\t\tcolorScheme: colorScheme,\r\n\t\tmediaType: mediaType,\r\n\t\tchooseColor: chooseColor,\r\n\t};\r\n};\r\n","import { createContext, type ReactNode, useContext, useMemo, useRef } from 'react';\r\n\r\nexport interface FieldLabelStoreContextValue {\r\n\tlabels: Record<string, ReactNode>;\r\n\tregisterLabel: (name: string, label: ReactNode) => void;\r\n}\r\n\r\nconst FieldLabelStoreContext = createContext<FieldLabelStoreContextValue>({\r\n\tlabels: {},\r\n\t// eslint-disable-next-line @typescript-eslint/no-empty-function\r\n\tregisterLabel: () => {},\r\n});\r\n\r\nexport interface FieldLabelStoreProviderProps {\r\n\tchildren: ReactNode;\r\n}\r\n\r\n/**\r\n * The purpose of this provider is to make labels passed to `FieldWrapper` accessible elsewhere,\r\n * e.g. in a validation error summary.\r\n *\r\n * Field labels can be registered via the `useRegisterFieldLabel` hook, and consumed via the `useFieldLabels` hook.\r\n **/\r\nexport const FieldLabelStoreProvider = (props: FieldLabelStoreProviderProps) => {\r\n\tconst { children } = props;\r\n\tconst labelsRef = useRef<Record<string, ReactNode>>({});\r\n\r\n\tconst contextValue = useMemo<FieldLabelStoreContextValue>(\r\n\t\t() => ({\r\n\t\t\tlabels: labelsRef.current,\r\n\t\t\tregisterLabel: (name, label) => {\r\n\t\t\t\tlabelsRef.current[name] = label;\r\n\t\t\t},\r\n\t\t}),\r\n\t\t[],\r\n\t);\r\n\r\n\treturn <FieldLabelStoreContext.Provider value={contextValue}>{children}</FieldLabelStoreContext.Provider>;\r\n};\r\n\r\nexport const useFieldLabels = () => useContext(FieldLabelStoreContext).labels;\r\n\r\nexport const useRegisterFieldLabel = () => useContext(FieldLabelStoreContext).registerLabel;\r\n","import { createContext, type ReactNode, useContext, useMemo } from 'react';\r\n\r\nexport interface FieldConfig {\r\n\toptionalLabelSuffix?: ReactNode;\r\n}\r\n\r\nconst FieldConfigContext = createContext<FieldConfig>({});\r\n\r\nexport interface FieldConfigProviderProps extends FieldConfig {\r\n\tchildren: ReactNode;\r\n}\r\n\r\n/**\r\n * Should only be used once in the root application wrapper.\r\n *\r\n * @deprecated Use `DesignSystemProvider` with the `messages` prop instead.\r\n */\r\nexport const FieldConfigProvider = (props: FieldConfigProviderProps) => {\r\n\tconst { children, optionalLabelSuffix } = props;\r\n\r\n\tconst config = useMemo<FieldConfig>(\r\n\t\t() => ({\r\n\t\t\toptionalLabelSuffix: optionalLabelSuffix,\r\n\t\t}),\r\n\t\t[optionalLabelSuffix],\r\n\t);\r\n\r\n\treturn <FieldConfigContext.Provider value={config}>{children}</FieldConfigContext.Provider>;\r\n};\r\n\r\nexport const useFieldConfig = () => useContext(FieldConfigContext);\r\n","import { useContext } from 'react';\r\n\r\nimport { DesignSystemMessagesContext } from './DesignSystemMessagesContext';\r\n\r\nexport const useDesignSystemMessages = () => useContext(DesignSystemMessagesContext);\r\n","import { useContext } from 'react';\r\n\r\nimport { DesignSystemPropDefaultsContext } from './DesignSystemPropDefaultsContext';\r\n\r\nexport const useDesignSystemPropDefaults = () => useContext(DesignSystemPropDefaultsContext);\r\n","import { type ReactNode } from 'react';\r\n\r\nexport interface AccordionItemType {\r\n\tcloseActionAriaLabel?: string;\r\n\tcontent: ReactNode;\r\n\tdescription?: ReactNode;\r\n\ticon?: ReactNode;\r\n\tid: string;\r\n\tisOpen?: boolean;\r\n\tlabel: ReactNode;\r\n\tonClick?: () => void;\r\n\topenActionAriaLabel?: string;\r\n}\r\n\r\nexport enum AccordionVariant {\r\n\tdefault = 'default',\r\n\ttable = 'table',\r\n}\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemArrowDownBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M17.25 13.75L12 19.25L6.75 13.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 18.25V4.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemArrowDownSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.5 9.16669L8 12.8334L4.5 9.16669\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 12.1667V3.16669\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemArrowLeftBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<g transform=\"rotate(180 12 12)\">\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M13.75 6.75L19.25 12L13.75 17.25\"\r\n\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t\t/>\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M19 12H4.75\"\r\n\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t\t/>\r\n\t\t\t</g>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemArrowLeftSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<g transform=\"rotate(180 8 8)\">\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M9.16667 4.5L12.8333 8L9.16667 11.5\"\r\n\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\t/>\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M12.6667 8H3.16667\"\r\n\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\t/>\r\n\t\t\t</g>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemArrowRightBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M13.75 6.75L19.25 12L13.75 17.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M19 12H4.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemArrowRightSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.16667 4.5L12.8333 8L9.16667 11.5\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.6667 8H3.16667\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemArrowUpBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M17.25 10.25L12 4.75L6.75 10.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 19.25V5.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemArrowUpSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.5 6.83335L8 3.16669L4.5 6.83335\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 12.8333V3.83331\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemArrowUpRightBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M17.25 15.25V6.75H8.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M17 7L6.75 17.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemArrowUpRightSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.5 10.1667V4.5H5.83333\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.3333 4.66669L4.5 11.5\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemBankBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M18.25 11.5V19.25M5.75 19.25V11.5M9.75 19.25V11.5M14.25 19.25V11.5\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 4.75L19.25 11.25H4.75L12 4.75Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.75 19.25H19.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemBankSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.1667 7.66663V12.8333M3.83334 12.8333V7.66663M6.5 12.8333V7.66663M9.5 12.8333V7.66663\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 3.16663L12.8333 7.49996H3.16666L8 3.16663Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.16666 12.8334H12.8333\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemCheckmarkBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.75 12.75L10 15.25L16.25 8.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemCheckmarkSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.16667 8.49998L6.66667 10.1666L10.8333 5.83331\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemChevronDownBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M15.25 10.75L12 14.25L8.75 10.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemChevronDownSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10.1667 7.16669L8 9.50002L5.83333 7.16669\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemChevronLeftBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M13.25 8.75L9.75 12L13.25 15.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemChevronLeftSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.83333 5.83325L6.5 7.99992L8.83333 10.1666\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemChevronRightBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10.75 8.75L14.25 12L10.75 15.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemChevronRightSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.16666 5.83331L9.5 7.99998L7.16666 10.1666\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemChevronUpBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M15.25 14.25L12 10.75L8.75 14.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemChevronUpSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10.1667 9.50002L8 7.16669L5.83333 9.50002\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemCloseBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M17.25 6.75L6.75 17.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.75 6.75L17.25 17.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemCloseSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.5 4.5L4.5 11.5\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.5 4.5L11.5 11.5\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemCrosshairBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M18.25 12C18.25 15.4518 15.4518 18.25 12 18.25C8.54822 18.25 5.75 15.4518 5.75 12C5.75 8.54822 8.54822 5.75 12 5.75C15.4518 5.75 18.25 8.54822 18.25 12Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 4.75V9.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M19.25 12H14.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 14.75V19.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.25 12H4.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemCrosshairSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.1667 8.00004C12.1667 10.3012 10.3012 12.1667 8 12.1667C5.69882 12.1667 3.83334 10.3012 3.83334 8.00004C3.83334 5.69885 5.69882 3.83337 8 3.83337C10.3012 3.83337 12.1667 5.69885 12.1667 8.00004Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 3.16663V6.16663\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.8333 8H9.83334\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 9.83337V12.8334\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.16666 8H3.16666\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemEventBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.75 8.75C4.75 7.64543 5.64543 6.75 6.75 6.75H17.25C18.3546 6.75 19.25 7.64543 19.25 8.75V17.25C19.25 18.3546 18.3546 19.25 17.25 19.25H6.75C5.64543 19.25 4.75 18.3546 4.75 17.25V8.75Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 4.75V8.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M16 4.75V8.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.75 10.75H16.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemEventSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.16666 5.83333C3.16666 5.09695 3.76362 4.5 4.5 4.5H11.5C12.2364 4.5 12.8333 5.09695 12.8333 5.83333V11.5C12.8333 12.2364 12.2364 12.8333 11.5 12.8333H4.5C3.76362 12.8333 3.16666 12.2364 3.16666 11.5V5.83333Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.33333 3.16669V5.50002\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10.6667 3.16669V5.50002\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.16667 7.16669H10.8333\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '../../types';\r\n\r\nexport const IconSystemFileTextBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.75 4.75H7.75C6.64543 4.75 5.75 5.64543 5.75 6.75V17.25C5.75 18.3546 6.64543 19.25 7.75 19.25H16.25C17.3546 19.25 18.25 18.3546 18.25 17.25V10.25M12.75 4.75V8.25C12.75 9.35457 13.6454 10.25 14.75 10.25H18.25M12.75 4.75L18.25 10.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.75 15.75H15.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.75 12.75H11.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '../../types';\r\n\r\nexport const IconSystemFileTextSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.5 3.16669H5.16667C4.43029 3.16669 3.83334 3.76364 3.83334 4.50002V11.5C3.83334 12.2364 4.43029 12.8334 5.16667 12.8334H10.8333C11.5697 12.8334 12.1667 12.2364 12.1667 11.5V6.83335M8.5 3.16669V5.50002C8.5 6.2364 9.09694 6.83335 9.83334 6.83335H12.1667M8.5 3.16669L12.1667 6.83335\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.83334 10.5H10.1667\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.83334 8.5H7.5\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemLogoutBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.6573 16.3966C11.6828 18.0628 12.9273 19.5 14.7944 19.5L16.3629 19.5C18.0955 19.5 19.5 18.1105 19.5 16.3966C19.5 16.3966 19.5 9.31748 19.5 7.60345C19.5 5.88941 18.0955 4.5 16.3629 4.5C14.6303 4.5 16.7607 4.5 14.7944 4.5C12.828 4.5 11.6573 5.73989 11.6573 7.60345\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.50002 12L14 12\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 8.74988L4.5 11.9999L8 15.2499\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemLogoutSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.00697 10.931C8.02321 12.0418 8.81556 13 10.0042 13L11.0028 13C12.1058 13 13 12.0737 13 10.931C13 10.931 13 6.21165 13 5.06897C13 3.92628 12.1058 3 11.0028 3C9.89973 3 11.256 3 10.0042 3C8.75232 3 8.00702 3.8266 8.00697 5.06897\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.00001 8L9.33334 8\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.33333 5.83325L2.99999 7.99992L5.33333 10.1666\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemMapBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.75 6.75L9.25 4.75V17.25L4.75 19.25V6.75Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.75 6.75L19.25 4.75V17.25L14.75 19.25V6.75Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.75 6.75L9.25 4.75V17.25L14.75 19.25V6.75Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemMapSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.16667 4.49996L6.16667 3.16663V11.5L3.16667 12.8333V4.49996Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.83333 4.49996L12.8333 3.16663V11.5L9.83333 12.8333V4.49996Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.83333 4.49996L6.16667 3.16663V11.5L9.83333 12.8333V4.49996Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemMinusBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.75 12C4.75 7.99594 7.99594 4.75 12 4.75C16.0041 4.75 19.25 7.99594 19.25 12C19.25 16.0041 16.0041 19.25 12 19.25C7.99594 19.25 4.75 16.0041 4.75 12Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M15.25 12H8.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemMinusSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.16667 7.99999C3.16667 5.33062 5.33063 3.16666 8 3.16666C10.6694 3.16666 12.8333 5.33062 12.8333 7.99999C12.8333 10.6694 10.6694 12.8333 8 12.8333C5.33063 12.8333 3.16667 10.6694 3.16667 7.99999Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10.1667 8H5.83333\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemPinBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M18.25 11C18.25 15 12 19.25 12 19.25C12 19.25 5.75 15 5.75 11C5.75 7.5 8.68629 4.75 12 4.75C15.3137 4.75 18.25 7.5 18.25 11Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 13.25C13.2426 13.25 14.25 12.2426 14.25 11C14.25 9.75736 13.2426 8.75 12 8.75C10.7574 8.75 9.75 9.75736 9.75 11C9.75 12.2426 10.7574 13.25 12 13.25Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemPinSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.1667 7.33329C12.1667 9.99996 8 12.8333 8 12.8333C8 12.8333 3.83333 9.99996 3.83333 7.33329C3.83333 4.99996 5.79086 3.16663 8 3.16663C10.2091 3.16663 12.1667 4.99996 12.1667 7.33329Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 8.83337C8.82843 8.83337 9.5 8.1618 9.5 7.33337C9.5 6.50495 8.82843 5.83337 8 5.83337C7.17157 5.83337 6.5 6.50495 6.5 7.33337C6.5 8.1618 7.17157 8.83337 8 8.83337Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemRefreshBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.25 14.75L8.75 17M8.75 17L11.25 19.25M8.75 17H13.25C16.5637 17 19.25 14.3137 19.25 11V10.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M15.25 7H10.75C7.43629 7 4.75 9.68629 4.75 13V13.25M15.25 7L12.75 9.25M15.25 7L12.75 4.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemRefreshSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.5 9.83329L5.83333 11.3333M5.83333 11.3333L7.5 12.8333M5.83333 11.3333H8.83333C11.0425 11.3333 12.8333 9.54243 12.8333 7.33329V7.16663\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10.1667 4.66663H7.16667C4.95753 4.66663 3.16667 6.45749 3.16667 8.66663V8.83329M10.1667 4.66663L8.5 6.16663M10.1667 4.66663L8.5 3.16663\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemSearchBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M19.25 19.25L15.5 15.5M4.75 11C4.75 7.54822 7.54822 4.75 11 4.75C14.4518 4.75 17.25 7.54822 17.25 11C17.25 14.4518 14.4518 17.25 11 17.25C7.54822 17.25 4.75 14.4518 4.75 11Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemSearchSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.8333 12.8333L10.3333 10.3333M3.16667 7.33332C3.16667 5.03214 5.03215 3.16666 7.33333 3.16666C9.63453 3.16666 11.5 5.03214 11.5 7.33332C11.5 9.63452 9.63453 11.5 7.33333 11.5C5.03215 11.5 3.16667 9.63452 3.16667 7.33332Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemShareBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.25 4.75H6.75C5.64543 4.75 4.75 5.64543 4.75 6.75V17.25C4.75 18.3546 5.64543 19.25 6.75 19.25H17.25C18.3546 19.25 19.25 18.3546 19.25 17.25V14.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M19.25 9.25V4.75H14.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M19 5L11.75 12.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemShareSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.16666 3.16663H4.5C3.76362 3.16663 3.16666 3.76358 3.16666 4.49996V11.5C3.16666 12.2364 3.76362 12.8333 4.5 12.8333H11.5C12.2364 12.8333 12.8333 12.2364 12.8333 11.5V9.83329\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.8333 6.16663V3.16663H9.83334\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.6667 3.33337L7.83334 8.16671\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemSpinnerBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M19.25 12C19.25 12.9521 19.0625 13.8948 18.6981 14.7745C18.3338 15.6541 17.7997 16.4533 17.1265 17.1265C16.4533 17.7997 15.6541 18.3338 14.7745 18.6981C13.8948 19.0625 12.9521 19.25 12 19.25C11.0479 19.25 10.1052 19.0625 9.22554 18.6981C8.34593 18.3338 7.5467 17.7997 6.87348 17.1265C6.20025 16.4533 5.66622 15.6541 5.30187 14.7745C4.93753 13.8948 4.75 12.9521 4.75 12C4.75 10.0772 5.51384 8.23311 6.87348 6.87348C8.23311 5.51384 10.0772 4.75 12 4.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemSpinnerSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M19.25 12C19.25 12.9521 19.0625 13.8948 18.6981 14.7745C18.3338 15.6541 17.7997 16.4533 17.1265 17.1265C16.4533 17.7997 15.6541 18.3338 14.7745 18.6981C13.8948 19.0625 12.9521 19.25 12 19.25C11.0479 19.25 10.1052 19.0625 9.22554 18.6981C8.34593 18.3338 7.5467 17.7997 6.87348 17.1265C6.20025 16.4533 5.66622 15.6541 5.30187 14.7745C4.93753 13.8948 4.75 12.9521 4.75 12C4.75 10.0772 5.51384 8.23311 6.87348 6.87348C8.23311 5.51384 10.0772 4.75 12 4.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '../../types';\r\n\r\nexport const IconSystemTrashBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.75 7.75L6.59115 17.4233C6.68102 18.4568 7.54622 19.25 8.58363 19.25H14.4164C15.4538 19.25 16.319 18.4568 16.4088 17.4233L17.25 7.75H5.75Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.75 10.75V16.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M13.25 10.75V16.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.75 7.75V6.75C8.75 5.64543 9.64543 4.75 10.75 4.75H12.25C13.3546 4.75 14.25 5.64543 14.25 6.75V7.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.75 7.75H18.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '../../types';\r\n\r\nexport const IconSystemTrashSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.83333 5.16669L4.3941 11.6156C4.45401 12.3046 5.03081 12.8334 5.72242 12.8334H9.61093C10.3025 12.8334 10.8793 12.3046 10.9392 11.6156L11.5 5.16669H3.83333Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.5 7.16669V10.8334\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.83333 7.16669V10.8334\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.83333 5.16669V4.50002C5.83333 3.76364 6.43029 3.16669 7.16667 3.16669H8.16667C8.90307 3.16669 9.5 3.76364 9.5 4.50002V5.16669\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.16667 5.16669H12.1667\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemUnorderedListBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.5 6C6.5 6.27614 6.27614 6.5 6 6.5C5.72386 6.5 5.5 6.27614 5.5 6C5.5 5.72386 5.72386 5.5 6 5.5C6.27614 5.5 6.5 5.72386 6.5 6Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.5 12C6.5 12.2761 6.27614 12.5 6 12.5C5.72386 12.5 5.5 12.2761 5.5 12C5.5 11.7239 5.72386 11.5 6 11.5C6.27614 11.5 6.5 11.7239 6.5 12Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.5 18C6.5 18.2761 6.27614 18.5 6 18.5C5.72386 18.5 5.5 18.2761 5.5 18C5.5 17.7239 5.72386 17.5 6 17.5C6.27614 17.5 6.5 17.7239 6.5 18Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.75 6H18.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.75 12H18.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.75 18H18.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemUnorderedListSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.33334 3.99996C4.33334 4.18405 4.1841 4.33329 4.00001 4.33329C3.81591 4.33329 3.66667 4.18405 3.66667 3.99996C3.66667 3.81587 3.81591 3.66663 4.00001 3.66663C4.1841 3.66663 4.33334 3.81587 4.33334 3.99996Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"0.666667\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.33334 7.99996C4.33334 8.18403 4.1841 8.33329 4.00001 8.33329C3.81591 8.33329 3.66667 8.18403 3.66667 7.99996C3.66667 7.81589 3.81591 7.66663 4.00001 7.66663C4.1841 7.66663 4.33334 7.81589 4.33334 7.99996Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"0.666667\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.33334 12C4.33334 12.184 4.1841 12.3333 4.00001 12.3333C3.81591 12.3333 3.66667 12.184 3.66667 12C3.66667 11.8159 3.81591 11.6666 4.00001 11.6666C4.1841 11.6666 4.33334 11.8159 4.33334 12Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"0.666667\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.5 4H12.1667\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.5 8H12.1667\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.5 12H12.1667\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '../../types';\r\n\r\nexport const IconSystemCalendarBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.75 8.75C4.75 7.64543 5.64543 6.75 6.75 6.75H17.25C18.3546 6.75 19.25 7.64543 19.25 8.75V17.25C19.25 18.3546 18.3546 19.25 17.25 19.25H6.75C5.64543 19.25 4.75 18.3546 4.75 17.25V8.75Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 4.75V8.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M16 4.75V8.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.75 10.75H16.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '../../types';\r\n\r\nexport const IconSystemCalendarSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.16666 5.83333C3.16666 5.09695 3.76362 4.5 4.5 4.5H11.5C12.2364 4.5 12.8333 5.09695 12.8333 5.83333V11.5C12.8333 12.2364 12.2364 12.8333 11.5 12.8333H4.5C3.76362 12.8333 3.16666 12.2364 3.16666 11.5V5.83333Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.33333 3.16669V5.50002\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10.6667 3.16669V5.50002\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.16667 7.16669H10.8333\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconChevronRightCircleBig = (props: IconProductSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10.75 15.25L14.25 12L10.75 8.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 19.25C16.0041 19.25 19.25 16.0041 19.25 12C19.25 7.99594 16.0041 4.75 12 4.75C7.99594 4.75 4.75 7.99594 4.75 12C4.75 16.0041 7.99594 19.25 12 19.25Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconChevronRightCircleSmall = (props: IconProductSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.16667 10.1666L9.5 7.99992L7.16667 5.83325\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.00001 12.8334C10.6694 12.8334 12.8333 10.6695 12.8333 8.00008C12.8333 5.33071 10.6694 3.16675 8.00001 3.16675C5.33063 3.16675 3.16667 5.33071 3.16667 8.00008C3.16667 10.6695 5.33063 12.8334 8.00001 12.8334Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '../../types';\r\n\r\nexport const IconSystemClockBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 19.25C16.0041 19.25 19.25 16.0041 19.25 12C19.25 7.99594 16.0041 4.75 12 4.75C7.99594 4.75 4.75 7.99594 4.75 12C4.75 16.0041 7.99594 19.25 12 19.25Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 8V12L14 14\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '../../types';\r\n\r\nexport const IconSystemClockSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 12.8334C10.6694 12.8334 12.8333 10.6694 12.8333 8.00002C12.8333 5.33064 10.6694 3.16669 8 3.16669C5.33062 3.16669 3.16666 5.33064 3.16666 8.00002C3.16666 10.6694 5.33062 12.8334 8 12.8334Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 5.33331V7.99998L9.33333 9.33331\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '../../types';\r\n\r\nexport const IconSystemCloseCircleBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.75 12C4.75 7.99594 7.99594 4.75 12 4.75C16.0041 4.75 19.25 7.99594 19.25 12C19.25 16.0041 16.0041 19.25 12 19.25C7.99594 19.25 4.75 16.0041 4.75 12Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.75 9.75L14.25 14.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.25 9.75L9.75 14.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '../../types';\r\n\r\nexport const IconSystemCloseCircleSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.16667 8.00008C3.16667 5.33071 5.33063 3.16675 8.00001 3.16675C10.6694 3.16675 12.8333 5.33071 12.8333 8.00008C12.8333 10.6695 10.6694 12.8334 8.00001 12.8334C5.33063 12.8334 3.16667 10.6695 3.16667 8.00008Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.5 6.5L9.5 9.5\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.5 6.5L6.5 9.5\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '../../types';\r\n\r\nexport const IconSystemDownloadBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.75 14.75V16.25C4.75 17.9069 6.09315 19.25 7.75 19.25H16.25C17.9069 19.25 19.25 17.9069 19.25 16.25V14.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 14.25V4.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.75 10.75L12 14.25L15.25 10.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '../../types';\r\n\r\nexport const IconSystemDownloadSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.16666 9.83331V10.8333C3.16666 11.9379 4.0621 12.8333 5.16666 12.8333H10.8333C11.9379 12.8333 12.8333 11.9379 12.8333 10.8333V9.83331\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 9.50002V3.16669\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.83333 7.16669L7.99999 9.50002L10.1667 7.16669\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemEyeClosedBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.875 6.25c.44.899.625 1.675.625 2 0 1-1.75 6.25-7.25 6.25a7.6 7.6 0 0 1-2-.256m-3-1.725C1.612 10.919 1 8.84 1 8.25 1 7.25 2.75 2 8.25 2c1.795 0 3.19.559 4.256 1.347M15.5 1 1 15.5\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.659 9.841a2.25 2.25 0 0 1 3.182-3.182\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemEyeClosedSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.875 6.25c.44.899.625 1.675.625 2 0 1-1.75 6.25-7.25 6.25a7.6 7.6 0 0 1-2-.256m-3-1.725C1.612 10.919 1 8.84 1 8.25 1 7.25 2.75 2 8.25 2c1.795 0 3.19.559 4.256 1.347M15.5 1 1 15.5\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.659 9.841a2.25 2.25 0 0 1 3.182-3.182\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemEyeOpenBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M15.5 8.25c0 1-1.75 6.25-7.25 6.25S1 9.25 1 8.25 2.75 2 8.25 2s7.25 5.25 7.25 6.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.25 10.5a2.25 2.25 0 1 0 0-4.5 2.25 2.25 0 0 0 0 4.5\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemEyeOpenSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M15.5 8.25c0 1-1.75 6.25-7.25 6.25S1 9.25 1 8.25 2.75 2 8.25 2s7.25 5.25 7.25 6.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.25 10.5a2.25 2.25 0 1 0 0-4.5 2.25 2.25 0 0 0 0 4.5\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '../../types';\r\n\r\nexport const IconSystemMailBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.75 7.75C4.75 6.64543 5.64543 5.75 6.75 5.75H17.25C18.3546 5.75 19.25 6.64543 19.25 7.75V16.25C19.25 17.3546 18.3546 18.25 17.25 18.25H6.75C5.64543 18.25 4.75 17.3546 4.75 16.25V7.75Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.5 6.5L12 12.25L18.5 6.5\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '../../types';\r\n\r\nexport const IconSystemMailSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.16667 5.16665C3.16667 4.43027 3.76363 3.83331 4.50001 3.83331H11.5C12.2364 3.83331 12.8333 4.43027 12.8333 5.16665V10.8333C12.8333 11.5697 12.2364 12.1666 11.5 12.1666H4.50001C3.76363 12.1666 3.16667 11.5697 3.16667 10.8333V5.16665Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.66667 4.33331L8.00001 8.16665L12.3333 4.33331\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '../../types';\r\n\r\nexport const IconSystemMenuBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.75 5.75H19.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.75 18.25H19.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.75 12H19.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '../../types';\r\n\r\nexport const IconSystemMenuSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.16667 3.83325H12.8333\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.16667 12.1667H12.8333\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.16667 8H12.8333\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemPlusBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 5.75V18.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M18.25 12H5.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemPlusSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 3.83334V12.1667\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.1667 8H3.83333\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemPlusCircleBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.75 12C4.75 7.99594 7.99594 4.75 12 4.75C16.0041 4.75 19.25 7.99594 19.25 12C19.25 16.0041 16.0041 19.25 12 19.25C7.99594 19.25 4.75 16.0041 4.75 12Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 8.75003V15.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M15.25 12H8.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '@/components/iconSystem/types';\r\n\r\nexport const IconSystemPlusCircleSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.16666 7.99999C3.16666 5.33062 5.33062 3.16666 8 3.16666C10.6694 3.16666 12.8333 5.33062 12.8333 7.99999C12.8333 10.6694 10.6694 12.8333 8 12.8333C5.33062 12.8333 3.16666 10.6694 3.16666 7.99999Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 5.83334V10.1667\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10.1667 8H5.83334\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '../../types';\r\n\r\nexport const IconSystemUploadCloudBig = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.25 14.25C6.25 14.25 4.75 14 4.75 12C4.75 10.2869 6.07542 8.88339 7.75672 8.75897C7.88168 6.5239 9.73368 4.75 12 4.75C14.2663 4.75 16.1183 6.5239 16.2433 8.75897C17.9246 8.88339 19.25 10.2869 19.25 12C19.25 14 17.75 14.25 17.75 14.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.25 15.25L12 12.75L9.75 15.25\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 19.25V13.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconSystemSvgProps } from '../../types';\r\n\r\nexport const IconSystemUploadCloudSmall = (props: IconSystemSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.16667 9.49999C4.16667 9.49999 3.16667 9.33332 3.16667 7.99999C3.16667 6.85792 4.05029 5.92225 5.17115 5.8393C5.25446 4.34926 6.48913 3.16666 8.00001 3.16666C9.51087 3.16666 10.7455 4.34926 10.8289 5.8393C11.9497 5.92225 12.8333 6.85792 12.8333 7.99999C12.8333 9.33332 11.8333 9.49999 11.8333 9.49999\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.5 10.1667L8 8.5L6.5 10.1667\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 12.8333V9.16666\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","export enum IconSystemType {\r\n\tarrowDown = 'arrowDown',\r\n\tarrowLeft = 'arrowLeft',\r\n\tarrowRight = 'arrowRight',\r\n\tarrowUp = 'arrowUp',\r\n\tarrowUpRight = 'arrowUpRight',\r\n\tbank = 'bank',\r\n\tcalendar = 'calendar',\r\n\tcheckmark = 'checkmark',\r\n\tchevronDown = 'chevronDown',\r\n\tchevronLeft = 'chevronLeft',\r\n\tchevronRight = 'chevronRight',\r\n\tchevronRightCircle = 'chevronRightCircle',\r\n\tchevronUp = 'chevronUp',\r\n\tclock = 'clock',\r\n\tclose = 'close',\r\n\tcloseCircle = 'closeCircle',\r\n\tcrosshair = 'crosshair',\r\n\tdownload = 'download',\r\n\tevent = 'event',\r\n\teyeClosed = 'eyeClosed',\r\n\teyeOpen = 'eyeOpen',\r\n\tfileText = 'fileText',\r\n\tlogout = 'logout',\r\n\tmail = 'mail',\r\n\tmap = 'map',\r\n\tmenu = 'menu',\r\n\tminus = 'minus',\r\n\tpin = 'pin',\r\n\tplus = 'plus',\r\n\tplusCircle = 'plusCircle',\r\n\trefresh = 'refresh',\r\n\tsearch = 'search',\r\n\tshare = 'share',\r\n\tspinner = 'spinner',\r\n\ttrash = 'trash',\r\n\tunorderedList = 'unorderedList',\r\n\tuploadCloud = 'uploadCloud',\r\n}\r\n\r\nexport enum IconSystemSize {\r\n\tbig = 'big',\r\n\tsmall = 'small',\r\n}\r\n\r\nexport interface IconSystemSvgProps {\r\n\tfill: string;\r\n\tstroke: string;\r\n}\r\n","import { styled } from '@/utils';\r\n\r\nimport { IconSystemSize } from './types';\r\n\r\nconst sizeBig = '1.5rem';\r\nconst sizeSmall = '1.25rem';\r\n\r\ninterface WrapperProps {\r\n\t$size: IconSystemSize;\r\n}\r\n\r\nexport const Wrapper = styled.span<WrapperProps>`\r\n\tdisplay: inline-flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\r\n\twidth: ${({ $size }) => {\r\n\t\tswitch ($size) {\r\n\t\t\tcase IconSystemSize.big:\r\n\t\t\t\treturn sizeBig;\r\n\t\t\tcase IconSystemSize.small:\r\n\t\t\t\treturn sizeSmall;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new TypeError('unexpected value of enum IconSystemSize in iconSystem.style.ts width');\r\n\t\t}\r\n\t}};\r\n\theight: ${({ $size }) => {\r\n\t\tswitch ($size) {\r\n\t\t\tcase IconSystemSize.big:\r\n\t\t\t\treturn sizeBig;\r\n\t\t\tcase IconSystemSize.small:\r\n\t\t\t\treturn sizeSmall;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new TypeError('unexpected value of enum IconSystemSize in iconSystem.style.ts height');\r\n\t\t}\r\n\t}};\r\n\r\n\t/*\r\n\t Ensures that SVG width and height properly within the wrapper. \r\n\t Without this, every icon component would need to define these styles separately, which could easily be forgotten. \r\n\t*/\r\n\t> svg {\r\n\t\twidth: 100%;\r\n\t\theight: 100%;\r\n\t}\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\n\r\nimport { IconSystemArrowDownBig } from '@/components/iconSystem/svg/arrowDown/IconSystemArrowDownBig';\r\nimport { IconSystemArrowDownSmall } from '@/components/iconSystem/svg/arrowDown/IconSystemArrowDownSmall';\r\nimport { IconSystemArrowLeftBig } from '@/components/iconSystem/svg/arrowLeft/IconSystemArrowLeftBig';\r\nimport { IconSystemArrowLeftSmall } from '@/components/iconSystem/svg/arrowLeft/IconSystemArrowLeftSmall';\r\nimport { IconSystemArrowRightBig } from '@/components/iconSystem/svg/arrowRight/IconSystemArrowRightBig';\r\nimport { IconSystemArrowRightSmall } from '@/components/iconSystem/svg/arrowRight/IconSystemArrowRightSmall';\r\nimport { IconSystemArrowUpBig } from '@/components/iconSystem/svg/arrowUp/IconSystemArrowUpBig';\r\nimport { IconSystemArrowUpSmall } from '@/components/iconSystem/svg/arrowUp/IconSystemArrowUpSmall';\r\nimport { IconSystemArrowUpRightBig } from '@/components/iconSystem/svg/arrowUpRight/IconSystemArrowUpRightBig';\r\nimport { IconSystemArrowUpRightSmall } from '@/components/iconSystem/svg/arrowUpRight/IconSystemArrowUpRightSmall';\r\nimport { IconSystemBankBig } from '@/components/iconSystem/svg/bank/IconSystemBankBig';\r\nimport { IconSystemBankSmall } from '@/components/iconSystem/svg/bank/IconSystemBankSmall';\r\nimport { IconSystemCheckmarkBig } from '@/components/iconSystem/svg/checkmark/IconSystemCheckmarkBig';\r\nimport { IconSystemCheckmarkSmall } from '@/components/iconSystem/svg/checkmark/IconSystemCheckmarkSmall';\r\nimport { IconSystemChevronDownBig } from '@/components/iconSystem/svg/chevronDown/IconSystemChevronDownBig';\r\nimport { IconSystemChevronDownSmall } from '@/components/iconSystem/svg/chevronDown/IconSystemChevronDownSmall';\r\nimport { IconSystemChevronLeftBig } from '@/components/iconSystem/svg/chevronLeft/IconSystemChevronLeftBig';\r\nimport { IconSystemChevronLeftSmall } from '@/components/iconSystem/svg/chevronLeft/IconSystemChevronLeftSmall';\r\nimport { IconSystemChevronRightBig } from '@/components/iconSystem/svg/chevronRight/IconSystemChevronRightBig';\r\nimport { IconSystemChevronRightSmall } from '@/components/iconSystem/svg/chevronRight/IconSystemChevronRightSmall';\r\nimport { IconSystemChevronUpBig } from '@/components/iconSystem/svg/chevronUp/IconSystemChevronUpBig';\r\nimport { IconSystemChevronUpSmall } from '@/components/iconSystem/svg/chevronUp/IconSystemChevronUpSmall';\r\nimport { IconSystemCloseBig } from '@/components/iconSystem/svg/close/IconSystemCloseBig';\r\nimport { IconSystemCloseSmall } from '@/components/iconSystem/svg/close/IconSystemCloseSmall';\r\nimport { IconSystemCrosshairBig } from '@/components/iconSystem/svg/crosshair/IconSystemCrosshairBig';\r\nimport { IconSystemCrosshairSmall } from '@/components/iconSystem/svg/crosshair/IconSystemCrosshairSmall';\r\nimport { IconSystemEventBig } from '@/components/iconSystem/svg/event/IconSystemEventBig';\r\nimport { IconSystemEventSmall } from '@/components/iconSystem/svg/event/IconSystemEventSmall';\r\nimport { IconSystemFileTextBig } from '@/components/iconSystem/svg/fileText/IconSystemFileTextBig';\r\nimport { IconSystemFileTextSmall } from '@/components/iconSystem/svg/fileText/IconSystemFileTextSmall';\r\nimport { IconSystemLogoutBig } from '@/components/iconSystem/svg/logout/IconSystemLogoutBig';\r\nimport { IconSystemLogoutSmall } from '@/components/iconSystem/svg/logout/IconSystemLogoutSmall';\r\nimport { IconSystemMapBig } from '@/components/iconSystem/svg/map/IconSystemMapBig';\r\nimport { IconSystemMapSmall } from '@/components/iconSystem/svg/map/IconSystemMapSmall';\r\nimport { IconSystemMinusBig } from '@/components/iconSystem/svg/minus/IconSystemMinusBig';\r\nimport { IconSystemMinusSmall } from '@/components/iconSystem/svg/minus/IconSystemMinusSmall';\r\nimport { IconSystemPinBig } from '@/components/iconSystem/svg/pin/IconSystemPinBig';\r\nimport { IconSystemPinSmall } from '@/components/iconSystem/svg/pin/IconSystemPinSmall';\r\nimport { IconSystemRefreshBig } from '@/components/iconSystem/svg/refresh/IconSystemRefreshBig';\r\nimport { IconSystemRefreshSmall } from '@/components/iconSystem/svg/refresh/IconSystemRefreshSmall';\r\nimport { IconSystemSearchBig } from '@/components/iconSystem/svg/search/IconSystemSearchBig';\r\nimport { IconSystemSearchSmall } from '@/components/iconSystem/svg/search/IconSystemSearchSmall';\r\nimport { IconSystemShareBig } from '@/components/iconSystem/svg/share/IconSystemShareBig';\r\nimport { IconSystemShareSmall } from '@/components/iconSystem/svg/share/IconSystemShareSmall';\r\nimport { IconSystemSpinnerBig } from '@/components/iconSystem/svg/spinner/IconSystemSpinnerBig';\r\nimport { IconSystemSpinnerSmall } from '@/components/iconSystem/svg/spinner/IconSystemSpinnerSmall';\r\nimport { IconSystemTrashBig } from '@/components/iconSystem/svg/trash/IconSystemTrashBig';\r\nimport { IconSystemTrashSmall } from '@/components/iconSystem/svg/trash/IconSystemTrashSmall';\r\nimport { IconSystemUnorderedListBig } from '@/components/iconSystem/svg/unorderedList/IconSystemUnorderedListBig';\r\nimport { IconSystemUnorderedListSmall } from '@/components/iconSystem/svg/unorderedList/IconSystemUnorderedListSmall';\r\nimport { useDesignSystem } from '@/contexts';\r\nimport { type ColorScheme } from '@/types';\r\n\r\nimport { IconSystemCalendarBig } from './svg/calendar/IconSystemCalendarBig';\r\nimport { IconSystemCalendarSmall } from './svg/calendar/IconSystemCalendarSmall';\r\nimport { IconChevronRightCircleBig } from './svg/chevronRightCircle/IconChevronRightCircleBig';\r\nimport { IconChevronRightCircleSmall } from './svg/chevronRightCircle/IconChevronRightCircleSmall';\r\nimport { IconSystemClockBig } from './svg/clock/IconSystemClockBig';\r\nimport { IconSystemClockSmall } from './svg/clock/IconSystemClockSmall';\r\nimport { IconSystemCloseCircleBig } from './svg/closeCircle/IconSystemCloseCircleBig';\r\nimport { IconSystemCloseCircleSmall } from './svg/closeCircle/IconSystemCloseCircleSmall';\r\nimport { IconSystemDownloadBig } from './svg/download/IconSystemDownloadBig';\r\nimport { IconSystemDownloadSmall } from './svg/download/IconSystemDownloadSmall';\r\nimport { IconSystemEyeClosedBig } from './svg/eyeClosed/IconSystemEyeClosedBig';\r\nimport { IconSystemEyeClosedSmall } from './svg/eyeClosed/IconSystemEyeClosedSmall';\r\nimport { IconSystemEyeOpenBig } from './svg/eyeOpen/IconSystemEyeOpenBig';\r\nimport { IconSystemEyeOpenSmall } from './svg/eyeOpen/IconSystemEyeOpenSmall';\r\nimport { IconSystemMailBig } from './svg/mail/IconSystemMailBig';\r\nimport { IconSystemMailSmall } from './svg/mail/IconSystemMailSmall';\r\nimport { IconSystemMenuBig } from './svg/menu/IconSystemMenuBig';\r\nimport { IconSystemMenuSmall } from './svg/menu/IconSystemMenuSmall';\r\nimport { IconSystemPlusBig } from './svg/plus/IconSystemPlusBig';\r\nimport { IconSystemPlusSmall } from './svg/plus/IconSystemPlusSmall';\r\nimport { IconSystemPlusCircleBig } from './svg/plusCircle/IconSystemPlusCircleBig';\r\nimport { IconSystemPlusCircleSmall } from './svg/plusCircle/IconSystemPlusCircleSmall';\r\nimport { IconSystemUploadCloudBig } from './svg/uploadCloud/IconSystemUploadCloudBig';\r\nimport { IconSystemUploadCloudSmall } from './svg/uploadCloud/IconSystemUploadCloudSmall';\r\nimport { IconSystemSize, IconSystemType } from './types';\r\n\r\nimport { Wrapper } from './IconSystem.style';\r\n\r\nexport interface IconSystemProps {\r\n\tariaHidden?: boolean;\r\n\tcolorScheme?: ColorScheme;\r\n\tfill?: string;\r\n\tsize: IconSystemSize;\r\n\tstroke?: string;\r\n\ttype: IconSystemType;\r\n}\r\n\r\nexport const IconSystem = (props: IconSystemProps) => {\r\n\tconst { ariaHidden = false, fill: fillFromProps, size, stroke: strokeFromProps, type } = props;\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor } = useDesignSystem(props);\r\n\r\n\tconst stroke = strokeFromProps === undefined ? chooseColor(theme.colors.icon.neutral) : strokeFromProps;\r\n\tconst fill = fillFromProps === undefined ? chooseColor(theme.colors.bg.neutral.white) : fillFromProps;\r\n\r\n\treturn (\r\n\t\t<Wrapper\r\n\t\t\t$size={size}\r\n\t\t\taria-hidden={ariaHidden}\r\n\t\t>\r\n\t\t\t{(() => {\r\n\t\t\t\tswitch (true) {\r\n\t\t\t\t\tcase type === IconSystemType.arrowDown && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemArrowDownBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.arrowDown && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemArrowDownSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.arrowUp && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemArrowUpBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.arrowUp && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemArrowUpSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.arrowUpRight && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemArrowUpRightBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.arrowUpRight && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemArrowUpRightSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.arrowRight && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemArrowRightBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.arrowRight && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemArrowRightSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.arrowLeft && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemArrowLeftBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.arrowLeft && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemArrowLeftSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.bank && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemBankBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.bank && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemBankSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.checkmark && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemCheckmarkBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.checkmark && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemCheckmarkSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.chevronDown && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemChevronDownBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.chevronDown && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemChevronDownSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.chevronUp && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemChevronUpBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.chevronUp && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemChevronUpSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.chevronRight && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemChevronRightBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.chevronRight && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemChevronRightSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.chevronLeft && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemChevronLeftBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.chevronLeft && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemChevronLeftSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.close && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemCloseBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.close && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemCloseSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.plus && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemPlusBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.plus && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemPlusSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.plusCircle && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemPlusCircleBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.plusCircle && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemPlusCircleSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.minus && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemMinusBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.minus && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemMinusSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.search && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemSearchSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.search && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemSearchBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.pin && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemPinSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.pin && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemPinBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.crosshair && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemCrosshairSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.crosshair && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemCrosshairBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.unorderedList && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemUnorderedListSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.unorderedList && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemUnorderedListBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.map && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemMapSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.map && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemMapBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.event && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemEventSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.event && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemEventBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.refresh && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemRefreshSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.refresh && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemRefreshBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.share && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemShareSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.share && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemShareBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.logout && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemLogoutSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.logout && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemLogoutBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.spinner && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemSpinnerSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.spinner && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemSpinnerBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.fileText && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemFileTextSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.fileText && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemFileTextBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.trash && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemTrashSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.trash && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemTrashBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.uploadCloud && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemUploadCloudSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.uploadCloud && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemUploadCloudBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.chevronRightCircle && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconChevronRightCircleBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.chevronRightCircle && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconChevronRightCircleSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.download && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemDownloadBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.download && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemDownloadSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.closeCircle && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemCloseCircleBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.closeCircle && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemCloseCircleSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.calendar && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemCalendarBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.calendar && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemCalendarSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.clock && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemClockBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.clock && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemClockSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.menu && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemMenuBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.menu && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemMenuSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.mail && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemMailBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.mail && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemMailSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.eyeOpen && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemEyeOpenBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.eyeOpen && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemEyeOpenSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.eyeClosed && size === IconSystemSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemEyeClosedBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconSystemType.eyeClosed && size === IconSystemSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSystemEyeClosedSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tdefault:\r\n\t\t\t\t\t\tthrow new Error('unexpected enum value IconSystemType and IconSystemSize in IconSystem');\r\n\t\t\t\t}\r\n\t\t\t})()}\r\n\t\t</Wrapper>\r\n\t);\r\n};\r\n","import { type Theme } from '@emotion/react';\r\n\r\n/* eslint-disable perfectionist/sort-enums */\r\nexport enum Spacing {\r\n\tnone = 'none',\r\n\r\n\txxs = 'xxs',\r\n\txs = 'xs',\r\n\tsm = 'sm',\r\n\tmd = 'md',\r\n\tlg = 'lg',\r\n\txl = 'xl',\r\n\txxl = 'xxl',\r\n\txxxl = 'xxxl',\r\n\txxxxl = 'xxxxl',\r\n\txxxxxl = 'xxxxxl',\r\n}\r\n/* eslint-enable perfectionist/sort-enums */\r\n\r\nexport const resolveSpacingValue = (theme: Theme, spacing: Spacing) => {\r\n\tif (spacing === Spacing.none) {\r\n\t\treturn '0';\r\n\t}\r\n\r\n\treturn theme.spacing[spacing];\r\n};\r\n","export enum WhiteSpace {\r\n\tinherit = 'inherit',\r\n\tnormal = 'normal',\r\n\tnowrap = 'nowrap',\r\n}\r\n\r\nexport const resolveWhiteSpaceValue = (whiteSpace: WhiteSpace) => {\r\n\treturn whiteSpace.toString();\r\n};\r\n","import { type Theme } from '@emotion/react';\r\n\r\n/* eslint-disable perfectionist/sort-enums */\r\nexport enum FontWeight {\r\n\tthin100 = 'thin',\r\n\textraLight200 = 'extraLight',\r\n\tlight300 = 'light',\r\n\tregular400 = 'regular',\r\n\tmedium500 = 'medium',\r\n\tsemiBold600 = 'semiBold',\r\n\tbold700 = 'bold',\r\n\textraBold800 = 'extraBold',\r\n\theavy900 = 'heavy',\r\n\tultra950 = 'ultra',\r\n}\r\n/* eslint-enable perfectionist/sort-enums */\r\n\r\nexport const resolveFontWeightValue = (theme: Theme, fontWeight: FontWeight) => {\r\n\treturn theme.font.weight[fontWeight];\r\n};\r\n","/* eslint-disable @typescript-eslint/naming-convention */\r\nexport const variables = {\r\n\ttokens: {\r\n\t\tlight: {\r\n\t\t\tcolor: {\r\n\t\t\t\tfg: {\r\n\t\t\t\t\tneutral: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#01194c',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tsubtle: {\r\n\t\t\t\t\t\t\tvalue: '#56647b',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tsubtlest: {\r\n\t\t\t\t\t\t\tvalue: '#6c7d98',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tdisabled: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#8a97ad',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tinverse: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#ffffff',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tlink: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#1c65fd',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\thover: {\r\n\t\t\t\t\t\t\tvalue: '#024be3',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tpressed: {\r\n\t\t\t\t\t\t\tvalue: '#023ab1',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tsuccess: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#1c6c13',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\twarning: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#b17902',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\terror: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#ca2e21',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tinfo: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#1c65fd',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tpromo: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#85703d',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tbrand: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#1c65fd',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tbold: {\r\n\t\t\t\t\t\t\tvalue: '#024be3',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\taccent: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#de31b9',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tbold: {\r\n\t\t\t\t\t\t\tvalue: '#bd1e9b',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t},\r\n\t\t\t\tbg: {\r\n\t\t\t\t\tneutral: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#a8b2c2',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tsubtle: {\r\n\t\t\t\t\t\t\tvalue: '#c6ccd7',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tsubtlest: {\r\n\t\t\t\t\t\t\tvalue: '#e4e7ec',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\twhite: {\r\n\t\t\t\t\t\t\tvalue: '#ffffff',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tdisabled: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#e4e7ec',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tpromo: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#fbf9f4',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tbold: {\r\n\t\t\t\t\t\t\tvalue: '#a58b4b',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\terror: {\r\n\t\t\t\t\t\tbold: {\r\n\t\t\t\t\t\t\tvalue: '#dc3628',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#fff8f7',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\twarning: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#fff9db',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tbold: {\r\n\t\t\t\t\t\t\tvalue: '#fae9a3',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tinverse: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#171b21',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tsuccess: {\r\n\t\t\t\t\t\tbold: {\r\n\t\t\t\t\t\t\tvalue: '#2e9721',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#e9fff4',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tinfo: {\r\n\t\t\t\t\t\tbold: {\r\n\t\t\t\t\t\t\tvalue: '#1c65fd',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#f0f5ff',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\taccent: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#fef6fc',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tbrand: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#f0f5ff',\r\n\t\t\t\t\t\t\thover: {\r\n\t\t\t\t\t\t\t\tvalue: '#d7e4ff',\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\tpressed: {\r\n\t\t\t\t\t\t\t\tvalue: '#d7e4ff',\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tsemibold: {\r\n\t\t\t\t\t\t\tvalue: '#d7e4ff',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tbold: {\r\n\t\t\t\t\t\t\tvalue: '#1c65fd',\r\n\t\t\t\t\t\t\thover: {\r\n\t\t\t\t\t\t\t\tvalue: '#024be3',\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\tpressed: {\r\n\t\t\t\t\t\t\t\tvalue: '#023ab1',\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t},\r\n\t\t\t\tsurface: {\r\n\t\t\t\t\toverlay: {\r\n\t\t\t\t\t\tvalue: '#f0f5ff',\r\n\t\t\t\t\t},\r\n\t\t\t\t\trisen: {\r\n\t\t\t\t\t\tvalue: '#ffffff',\r\n\t\t\t\t\t},\r\n\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\tvalue: '#fafcff',\r\n\t\t\t\t\t},\r\n\t\t\t\t\tsunken: {\r\n\t\t\t\t\t\tvalue: '#c6ccd7',\r\n\t\t\t\t\t},\r\n\t\t\t\t},\r\n\t\t\t\tborder: {\r\n\t\t\t\t\tneutral: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#56647b',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tsubtle: {\r\n\t\t\t\t\t\t\tvalue: '#a8b2c2',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tsubtlest: {\r\n\t\t\t\t\t\t\tvalue: '#e4e7ec',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tdisabled: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#c6ccd7',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tsuccess: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#2e9721',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\twarning: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#b17902',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\terror: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#ca2e21',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tpromo: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#a58b4b',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tbrand: {\r\n\t\t\t\t\t\tbold: {\r\n\t\t\t\t\t\t\tvalue: '#024be3',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#1c65fd',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tsubtle: {\r\n\t\t\t\t\t\t\tvalue: '#81a9fe',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tsubtlest: {\r\n\t\t\t\t\t\t\tvalue: '#d7e4ff',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tinverse: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#fafcff',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\taccent: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#fae0f5',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t},\r\n\t\t\t\ticon: {\r\n\t\t\t\t\tbackground: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#ffffff',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tbrand: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#1c65fd',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tneutral: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#56647b',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tinverse: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#ffffff',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tdisabled: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#c6ccd7',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\terror: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#dc3628',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\tlayout: {\r\n\t\t\t\tspacing: {\r\n\t\t\t\t\t'spacer-1-(xxs)': {\r\n\t\t\t\t\t\tvalue: '4px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\t'spacer-2-(xs)': {\r\n\t\t\t\t\t\tvalue: '8px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\t'spacer-3-(sm)': {\r\n\t\t\t\t\t\tvalue: '12px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\t'spacer-4-(md)': {\r\n\t\t\t\t\t\tvalue: '16px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\t'spacer-5-(lg)': {\r\n\t\t\t\t\t\tvalue: '24px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\t'spacer-6-(xl)': {\r\n\t\t\t\t\t\tvalue: '32px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\t'spacer-7-(2xl)': {\r\n\t\t\t\t\t\tvalue: '40px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\t'spacer-8-(3xl)': {\r\n\t\t\t\t\t\tvalue: '48px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\t'spacer-9-(4xl)': {\r\n\t\t\t\t\t\tvalue: '56px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\t'spacer-10-(5xl)': {\r\n\t\t\t\t\t\tvalue: '64px',\r\n\t\t\t\t\t},\r\n\t\t\t\t},\r\n\t\t\t\tbreakpoint: {\r\n\t\t\t\t\txs: {\r\n\t\t\t\t\t\tvalue: '375px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\tsm: {\r\n\t\t\t\t\t\tvalue: '576px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\tmd: {\r\n\t\t\t\t\t\tvalue: '768px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\tlg: {\r\n\t\t\t\t\t\tvalue: '992px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\txl: {\r\n\t\t\t\t\t\tvalue: '1280px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\t'2xl': {\r\n\t\t\t\t\t\tvalue: '1920px',\r\n\t\t\t\t\t},\r\n\t\t\t\t},\r\n\t\t\t\tcontainer: {\r\n\t\t\t\t\txl: {\r\n\t\t\t\t\t\tvalue: '1200px',\r\n\t\t\t\t\t},\r\n\t\t\t\t},\r\n\t\t\t\t'border-radius': {\r\n\t\t\t\t\txxs: {\r\n\t\t\t\t\t\tvalue: '4px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\txs: {\r\n\t\t\t\t\t\tvalue: '8px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\tsm: {\r\n\t\t\t\t\t\tvalue: '12px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\tmd: {\r\n\t\t\t\t\t\tvalue: '16px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\tlg: {\r\n\t\t\t\t\t\tvalue: '24px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\txl: {\r\n\t\t\t\t\t\tvalue: '32px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\tfull: {\r\n\t\t\t\t\t\tvalue: '9999px',\r\n\t\t\t\t\t},\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t},\r\n\t\tdark: {\r\n\t\t\tcolor: {\r\n\t\t\t\tfg: {\r\n\t\t\t\t\tneutral: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#ffffff',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tsubtle: {\r\n\t\t\t\t\t\t\tvalue: '#a8b2c2',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tsubtlest: {\r\n\t\t\t\t\t\t\tvalue: '#6c7d98',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tdisabled: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#6c7d98',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tinverse: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#171b21',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tlink: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#4e86fe',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\thover: {\r\n\t\t\t\t\t\t\tvalue: '#81a9fe',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tpressed: {\r\n\t\t\t\t\t\t\tvalue: '#b3ccfe',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tsuccess: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#99e5b3',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\twarning: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#fae9a3',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\terror: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#f5aea8',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tinfo: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#4e86fe',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tpromo: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#a58b4b',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tbrand: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#1c65fd',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tbold: {\r\n\t\t\t\t\t\t\tvalue: '#4e86fe',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\taccent: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#de31b9',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tbold: {\r\n\t\t\t\t\t\t\tvalue: '#e55cc8',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t},\r\n\t\t\t\tbg: {\r\n\t\t\t\t\tneutral: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#56647b',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tsubtle: {\r\n\t\t\t\t\t\t\tvalue: '#414c5d',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tsubtlest: {\r\n\t\t\t\t\t\t\tvalue: '#171b21',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\twhite: {\r\n\t\t\t\t\t\t\tvalue: '#ffffff',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tdisabled: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#414c5d',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tpromo: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#62532d',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tbold: {\r\n\t\t\t\t\t\t\tvalue: '#a58b4b',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\terror: {\r\n\t\t\t\t\t\tbold: {\r\n\t\t\t\t\t\t\tvalue: '#f5aea8',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#a0271c',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\twarning: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#fffcee',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tbold: {\r\n\t\t\t\t\t\t\tvalue: '#b17902',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tinverse: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#fafcff',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tsuccess: {\r\n\t\t\t\t\t\tbold: {\r\n\t\t\t\t\t\t\tvalue: '#99e5b3',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#1d5a16',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tinfo: {\r\n\t\t\t\t\t\tbold: {\r\n\t\t\t\t\t\t\tvalue: '#4e86fe',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#01194c',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\taccent: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#651053',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tbrand: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#01194c',\r\n\t\t\t\t\t\t\thover: {\r\n\t\t\t\t\t\t\t\tvalue: '#023ab1',\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\tpressed: {\r\n\t\t\t\t\t\t\t\tvalue: '#023ab1',\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tsemibold: {\r\n\t\t\t\t\t\t\tvalue: '#012a7e',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tbold: {\r\n\t\t\t\t\t\t\tvalue: '#1c65fd',\r\n\t\t\t\t\t\t\thover: {\r\n\t\t\t\t\t\t\t\tvalue: '#024be3',\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\tpressed: {\r\n\t\t\t\t\t\t\t\tvalue: '#023ab1',\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t},\r\n\t\t\t\tsurface: {\r\n\t\t\t\t\toverlay: {\r\n\t\t\t\t\t\tvalue: '#171b21',\r\n\t\t\t\t\t},\r\n\t\t\t\t\trisen: {\r\n\t\t\t\t\t\tvalue: '#2c333f',\r\n\t\t\t\t\t},\r\n\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\tvalue: '#171b21',\r\n\t\t\t\t\t},\r\n\t\t\t\t\tsunken: {\r\n\t\t\t\t\t\tvalue: '#56647b',\r\n\t\t\t\t\t},\r\n\t\t\t\t},\r\n\t\t\t\tborder: {\r\n\t\t\t\t\tneutral: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#c6ccd7',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tsubtle: {\r\n\t\t\t\t\t\t\tvalue: '#6c7d98',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tsubtlest: {\r\n\t\t\t\t\t\t\tvalue: '#56647b',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tdisabled: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#56647b',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tsuccess: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#2e9721',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\twarning: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#b17902',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\terror: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#dc3628',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tpromo: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#a58b4b',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tbrand: {\r\n\t\t\t\t\t\tbold: {\r\n\t\t\t\t\t\t\tvalue: '#b3ccfe',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#1c65fd',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tsubtle: {\r\n\t\t\t\t\t\t\tvalue: '#1c65fd',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tsubtlest: {\r\n\t\t\t\t\t\t\tvalue: '#023ab1',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tinverse: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#2c333f',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\taccent: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#911777',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t},\r\n\t\t\t\ticon: {\r\n\t\t\t\t\tbackground: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: 'rgba(255, 255, 255, 0.0000)',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tbrand: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#a8b2c2',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tneutral: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#a8b2c2',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tinverse: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#000000',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\tdisabled: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#ffffff',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\terror: {\r\n\t\t\t\t\t\tdefault: {\r\n\t\t\t\t\t\t\tvalue: '#dc3628',\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\tlayout: {\r\n\t\t\t\tspacing: {\r\n\t\t\t\t\t'spacer-1-(xxs)': {\r\n\t\t\t\t\t\tvalue: '4px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\t'spacer-2-(xs)': {\r\n\t\t\t\t\t\tvalue: '8px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\t'spacer-3-(sm)': {\r\n\t\t\t\t\t\tvalue: '12px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\t'spacer-4-(md)': {\r\n\t\t\t\t\t\tvalue: '16px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\t'spacer-5-(lg)': {\r\n\t\t\t\t\t\tvalue: '24px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\t'spacer-6-(xl)': {\r\n\t\t\t\t\t\tvalue: '32px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\t'spacer-7-(2xl)': {\r\n\t\t\t\t\t\tvalue: '40px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\t'spacer-8-(3xl)': {\r\n\t\t\t\t\t\tvalue: '48px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\t'spacer-9-(4xl)': {\r\n\t\t\t\t\t\tvalue: '56px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\t'spacer-10-(5xl)': {\r\n\t\t\t\t\t\tvalue: '64px',\r\n\t\t\t\t\t},\r\n\t\t\t\t},\r\n\t\t\t\tbreakpoint: {\r\n\t\t\t\t\txs: {\r\n\t\t\t\t\t\tvalue: '375px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\tsm: {\r\n\t\t\t\t\t\tvalue: '576px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\tmd: {\r\n\t\t\t\t\t\tvalue: '768px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\tlg: {\r\n\t\t\t\t\t\tvalue: '992px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\txl: {\r\n\t\t\t\t\t\tvalue: '1280px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\t'2xl': {\r\n\t\t\t\t\t\tvalue: '1920px',\r\n\t\t\t\t\t},\r\n\t\t\t\t},\r\n\t\t\t\tcontainer: {\r\n\t\t\t\t\txl: {\r\n\t\t\t\t\t\tvalue: '1200px',\r\n\t\t\t\t\t},\r\n\t\t\t\t},\r\n\t\t\t\t'border-radius': {\r\n\t\t\t\t\txxs: {\r\n\t\t\t\t\t\tvalue: '4px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\txs: {\r\n\t\t\t\t\t\tvalue: '8px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\tsm: {\r\n\t\t\t\t\t\tvalue: '12px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\tmd: {\r\n\t\t\t\t\t\tvalue: '16px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\tlg: {\r\n\t\t\t\t\t\tvalue: '24px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\txl: {\r\n\t\t\t\t\t\tvalue: '32px',\r\n\t\t\t\t\t},\r\n\t\t\t\t\tfull: {\r\n\t\t\t\t\t\tvalue: '9999px',\r\n\t\t\t\t\t},\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t},\r\n\t},\r\n\t_primitives: {\r\n\t\tcolors: {\r\n\t\t\tgold: {\r\n\t\t\t\t'500': {\r\n\t\t\t\t\tvalue: '#a58b4b',\r\n\t\t\t\t},\r\n\t\t\t\t'600': {\r\n\t\t\t\t\tvalue: '#85703d',\r\n\t\t\t\t},\r\n\t\t\t\t'700': {\r\n\t\t\t\t\tvalue: '#776437',\r\n\t\t\t\t},\r\n\t\t\t\t'800': {\r\n\t\t\t\t\tvalue: '#62532d',\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\tpink: {\r\n\t\t\t\t'100': {\r\n\t\t\t\t\tvalue: '#fef6fc',\r\n\t\t\t\t},\r\n\t\t\t\t'200': {\r\n\t\t\t\t\tvalue: '#fae0f5',\r\n\t\t\t\t},\r\n\t\t\t\t'300': {\r\n\t\t\t\t\tvalue: '#f3b4e6',\r\n\t\t\t\t},\r\n\t\t\t\t'400': {\r\n\t\t\t\t\tvalue: '#ec88d7',\r\n\t\t\t\t},\r\n\t\t\t\t'500': {\r\n\t\t\t\t\tvalue: '#e55cc8',\r\n\t\t\t\t},\r\n\t\t\t\t'600': {\r\n\t\t\t\t\tvalue: '#de31b9',\r\n\t\t\t\t},\r\n\t\t\t\t'700': {\r\n\t\t\t\t\tvalue: '#bd1e9b',\r\n\t\t\t\t},\r\n\t\t\t\t'800': {\r\n\t\t\t\t\tvalue: '#911777',\r\n\t\t\t\t},\r\n\t\t\t\t'900': {\r\n\t\t\t\t\tvalue: '#651053',\r\n\t\t\t\t},\r\n\t\t\t\t'1000': {\r\n\t\t\t\t\tvalue: '#39092f',\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\tgrey: {\r\n\t\t\t\t'100': {\r\n\t\t\t\t\tvalue: '#fafcff',\r\n\t\t\t\t},\r\n\t\t\t\t'200': {\r\n\t\t\t\t\tvalue: '#e4e7ec',\r\n\t\t\t\t},\r\n\t\t\t\t'300': {\r\n\t\t\t\t\tvalue: '#c6ccd7',\r\n\t\t\t\t},\r\n\t\t\t\t'400': {\r\n\t\t\t\t\tvalue: '#a8b2c2',\r\n\t\t\t\t},\r\n\t\t\t\t'500': {\r\n\t\t\t\t\tvalue: '#8a97ad',\r\n\t\t\t\t},\r\n\t\t\t\t'600': {\r\n\t\t\t\t\tvalue: '#6c7d98',\r\n\t\t\t\t},\r\n\t\t\t\t'700': {\r\n\t\t\t\t\tvalue: '#56647b',\r\n\t\t\t\t},\r\n\t\t\t\t'800': {\r\n\t\t\t\t\tvalue: '#414c5d',\r\n\t\t\t\t},\r\n\t\t\t\t'900': {\r\n\t\t\t\t\tvalue: '#2c333f',\r\n\t\t\t\t},\r\n\t\t\t\t'1000': {\r\n\t\t\t\t\tvalue: '#171b21',\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\tblack: {\r\n\t\t\t\tvalue: '#000000',\r\n\t\t\t},\r\n\t\t\twhite: {\r\n\t\t\t\tvalue: '#ffffff',\r\n\t\t\t},\r\n\t\t\tyellow: {\r\n\t\t\t\t'100': {\r\n\t\t\t\t\tvalue: '#fffcee',\r\n\t\t\t\t},\r\n\t\t\t\t'200': {\r\n\t\t\t\t\tvalue: '#fff9db',\r\n\t\t\t\t},\r\n\t\t\t\t'300': {\r\n\t\t\t\t\tvalue: '#fdf6d8',\r\n\t\t\t\t},\r\n\t\t\t\t'400': {\r\n\t\t\t\t\tvalue: '#fae9a3',\r\n\t\t\t\t},\r\n\t\t\t\t'500': {\r\n\t\t\t\t\tvalue: '#d7b45b',\r\n\t\t\t\t},\r\n\t\t\t\t'600': {\r\n\t\t\t\t\tvalue: '#b17902',\r\n\t\t\t\t},\r\n\t\t\t\t'700': {\r\n\t\t\t\t\tvalue: '#ab6802',\r\n\t\t\t\t},\r\n\t\t\t\t'800': {\r\n\t\t\t\t\tvalue: '#885202',\r\n\t\t\t\t},\r\n\t\t\t\t'900': {\r\n\t\t\t\t\tvalue: '#704300',\r\n\t\t\t\t},\r\n\t\t\t\t'1000': {\r\n\t\t\t\t\tvalue: '#3d2500',\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\ttransparent: {\r\n\t\t\t\tvalue: 'rgba(255, 255, 255, 0.0000)',\r\n\t\t\t},\r\n\t\t\tgreen: {\r\n\t\t\t\t'100': {\r\n\t\t\t\t\tvalue: '#f7fffb',\r\n\t\t\t\t},\r\n\t\t\t\t'200': {\r\n\t\t\t\t\tvalue: '#e9fff4',\r\n\t\t\t\t},\r\n\t\t\t\t'300': {\r\n\t\t\t\t\tvalue: '#def7e6',\r\n\t\t\t\t},\r\n\t\t\t\t'400': {\r\n\t\t\t\t\tvalue: '#99e5b3',\r\n\t\t\t\t},\r\n\t\t\t\t'500': {\r\n\t\t\t\t\tvalue: '#6cd07b',\r\n\t\t\t\t},\r\n\t\t\t\t'600': {\r\n\t\t\t\t\tvalue: '#2e9721',\r\n\t\t\t\t},\r\n\t\t\t\t'700': {\r\n\t\t\t\t\tvalue: '#258a19',\r\n\t\t\t\t},\r\n\t\t\t\t'800': {\r\n\t\t\t\t\tvalue: '#1c6c13',\r\n\t\t\t\t},\r\n\t\t\t\t'900': {\r\n\t\t\t\t\tvalue: '#1d5a16',\r\n\t\t\t\t},\r\n\t\t\t\t'1000': {\r\n\t\t\t\t\tvalue: '#10310c',\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\tred: {\r\n\t\t\t\t'100': {\r\n\t\t\t\t\tvalue: '#fff8f7',\r\n\t\t\t\t},\r\n\t\t\t\t'200': {\r\n\t\t\t\t\tvalue: '#ffebe9',\r\n\t\t\t\t},\r\n\t\t\t\t'300': {\r\n\t\t\t\t\tvalue: '#fbddda',\r\n\t\t\t\t},\r\n\t\t\t\t'400': {\r\n\t\t\t\t\tvalue: '#f5aea8',\r\n\t\t\t\t},\r\n\t\t\t\t'500': {\r\n\t\t\t\t\tvalue: '#eb827a',\r\n\t\t\t\t},\r\n\t\t\t\t'600': {\r\n\t\t\t\t\tvalue: '#dc3628',\r\n\t\t\t\t},\r\n\t\t\t\t'700': {\r\n\t\t\t\t\tvalue: '#ca2e21',\r\n\t\t\t\t},\r\n\t\t\t\t'800': {\r\n\t\t\t\t\tvalue: '#b92518',\r\n\t\t\t\t},\r\n\t\t\t\t'900': {\r\n\t\t\t\t\tvalue: '#a0271c',\r\n\t\t\t\t},\r\n\t\t\t\t'1000': {\r\n\t\t\t\t\tvalue: '#57150f',\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\tblue: {\r\n\t\t\t\t'100': {\r\n\t\t\t\t\tvalue: '#f0f5ff',\r\n\t\t\t\t},\r\n\t\t\t\t'200': {\r\n\t\t\t\t\tvalue: '#d7e4ff',\r\n\t\t\t\t},\r\n\t\t\t\t'300': {\r\n\t\t\t\t\tvalue: '#b3ccfe',\r\n\t\t\t\t},\r\n\t\t\t\t'400': {\r\n\t\t\t\t\tvalue: '#81a9fe',\r\n\t\t\t\t},\r\n\t\t\t\t'500': {\r\n\t\t\t\t\tvalue: '#4e86fe',\r\n\t\t\t\t},\r\n\t\t\t\t'600': {\r\n\t\t\t\t\tvalue: '#1c65fd',\r\n\t\t\t\t},\r\n\t\t\t\t'700': {\r\n\t\t\t\t\tvalue: '#024be3',\r\n\t\t\t\t},\r\n\t\t\t\t'800': {\r\n\t\t\t\t\tvalue: '#023ab1',\r\n\t\t\t\t},\r\n\t\t\t\t'900': {\r\n\t\t\t\t\tvalue: '#012a7e',\r\n\t\t\t\t},\r\n\t\t\t\t'1000': {\r\n\t\t\t\t\tvalue: '#01194c',\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t},\r\n\t},\r\n} as const;\r\n","import { variables } from './figma/mmb_variables-25-12-09';\r\n\r\nexport const theme = {\r\n\t// PALETTE\r\n\tpalette: {\r\n\t\tgold500: variables._primitives.colors.gold['500'].value,\r\n\t\tgold600: variables._primitives.colors.gold['600'].value,\r\n\t\tgold700: variables._primitives.colors.gold['700'].value,\r\n\t\tgold800: variables._primitives.colors.gold['800'].value,\r\n\t\tpink100: variables._primitives.colors.pink['100'].value,\r\n\t\tpink200: variables._primitives.colors.pink['200'].value,\r\n\t\tpink300: variables._primitives.colors.pink['300'].value,\r\n\t\tpink400: variables._primitives.colors.pink['400'].value,\r\n\t\tpink500: variables._primitives.colors.pink['500'].value,\r\n\t\tpink600: variables._primitives.colors.pink['600'].value,\r\n\t\tpink700: variables._primitives.colors.pink['700'].value,\r\n\t\tpink800: variables._primitives.colors.pink['800'].value,\r\n\t\tpink900: variables._primitives.colors.pink['900'].value,\r\n\t\tpink1000: variables._primitives.colors.pink['1000'].value,\r\n\t\tgrey100: variables._primitives.colors.grey['100'].value,\r\n\t\tgrey200: variables._primitives.colors.grey['200'].value,\r\n\t\tgrey300: variables._primitives.colors.grey['300'].value,\r\n\t\tgrey400: variables._primitives.colors.grey['400'].value,\r\n\t\tgrey500: variables._primitives.colors.grey['500'].value,\r\n\t\tgrey600: variables._primitives.colors.grey['600'].value,\r\n\t\tgrey700: variables._primitives.colors.grey['700'].value,\r\n\t\tgrey800: variables._primitives.colors.grey['800'].value,\r\n\t\tgrey900: variables._primitives.colors.grey['900'].value,\r\n\t\tgrey1000: variables._primitives.colors.grey['1000'].value,\r\n\t\tblack: variables._primitives.colors.black.value,\r\n\t\twhite: variables._primitives.colors.white.value,\r\n\t\ttransparent: variables._primitives.colors.transparent.value,\r\n\t\tyellow100: variables._primitives.colors.yellow['100'].value,\r\n\t\tyellow200: variables._primitives.colors.yellow['200'].value,\r\n\t\tyellow300: variables._primitives.colors.yellow['300'].value,\r\n\t\tyellow400: variables._primitives.colors.yellow['400'].value,\r\n\t\tyellow500: variables._primitives.colors.yellow['500'].value,\r\n\t\tyellow600: variables._primitives.colors.yellow['600'].value,\r\n\t\tyellow700: variables._primitives.colors.yellow['700'].value,\r\n\t\tyellow800: variables._primitives.colors.yellow['800'].value,\r\n\t\tyellow900: variables._primitives.colors.yellow['900'].value,\r\n\t\tyellow1000: variables._primitives.colors.yellow['1000'].value,\r\n\t\tgreen100: variables._primitives.colors.green['100'].value,\r\n\t\tgreen200: variables._primitives.colors.green['200'].value,\r\n\t\tgreen300: variables._primitives.colors.green['300'].value,\r\n\t\tgreen400: variables._primitives.colors.green['400'].value,\r\n\t\tgreen500: variables._primitives.colors.green['500'].value,\r\n\t\tgreen600: variables._primitives.colors.green['600'].value,\r\n\t\tgreen700: variables._primitives.colors.green['700'].value,\r\n\t\tgreen800: variables._primitives.colors.green['800'].value,\r\n\t\tgreen900: variables._primitives.colors.green['900'].value,\r\n\t\tgreen1000: variables._primitives.colors.green['1000'].value,\r\n\t\tred100: variables._primitives.colors.red['100'].value,\r\n\t\tred200: variables._primitives.colors.red['200'].value,\r\n\t\tred300: variables._primitives.colors.red['300'].value,\r\n\t\tred400: variables._primitives.colors.red['400'].value,\r\n\t\tred500: variables._primitives.colors.red['500'].value,\r\n\t\tred600: variables._primitives.colors.red['600'].value,\r\n\t\tred700: variables._primitives.colors.red['700'].value,\r\n\t\tred800: variables._primitives.colors.red['800'].value,\r\n\t\tred900: variables._primitives.colors.red['900'].value,\r\n\t\tred1000: variables._primitives.colors.red['1000'].value,\r\n\t\tblue100: variables._primitives.colors.blue['100'].value,\r\n\t\tblue200: variables._primitives.colors.blue['200'].value,\r\n\t\tblue300: variables._primitives.colors.blue['300'].value,\r\n\t\tblue400: variables._primitives.colors.blue['400'].value,\r\n\t\tblue500: variables._primitives.colors.blue['500'].value,\r\n\t\tblue600: variables._primitives.colors.blue['600'].value,\r\n\t\tblue700: variables._primitives.colors.blue['700'].value,\r\n\t\tblue800: variables._primitives.colors.blue['800'].value,\r\n\t\tblue900: variables._primitives.colors.blue['900'].value,\r\n\t\tblue1000: variables._primitives.colors.blue['1000'].value,\r\n\t},\r\n\r\n\t// COLORS\r\n\tcolors: {\r\n\t\tfg: {\r\n\t\t\tneutral: {\r\n\t\t\t\tdefault: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.fg.neutral.default.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.fg.neutral.default.value,\r\n\t\t\t\t},\r\n\t\t\t\tsubtle: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.fg.neutral.subtle.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.fg.neutral.subtle.value,\r\n\t\t\t\t},\r\n\t\t\t\tsubtlest: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.fg.neutral.subtlest.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.fg.neutral.subtlest.value,\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\tdisabled: {\r\n\t\t\t\tlight: variables.tokens.light.color.fg.disabled.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.fg.disabled.default.value,\r\n\t\t\t},\r\n\t\t\tinverse: {\r\n\t\t\t\tlight: variables.tokens.light.color.fg.inverse.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.fg.inverse.default.value,\r\n\t\t\t},\r\n\t\t\tlink: {\r\n\t\t\t\tdefault: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.fg.link.default.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.fg.link.default.value,\r\n\t\t\t\t},\r\n\t\t\t\thover: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.fg.link.hover.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.fg.link.hover.value,\r\n\t\t\t\t},\r\n\t\t\t\tpressed: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.fg.link.pressed.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.fg.link.pressed.value,\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\tsuccess: {\r\n\t\t\t\tlight: variables.tokens.light.color.fg.success.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.fg.success.default.value,\r\n\t\t\t},\r\n\t\t\twarning: {\r\n\t\t\t\tlight: variables.tokens.light.color.fg.warning.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.fg.warning.default.value,\r\n\t\t\t},\r\n\t\t\terror: {\r\n\t\t\t\tlight: variables.tokens.light.color.fg.error.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.fg.error.default.value,\r\n\t\t\t},\r\n\t\t\tinfo: {\r\n\t\t\t\tlight: variables.tokens.light.color.fg.info.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.fg.info.default.value,\r\n\t\t\t},\r\n\t\t\tpromo: {\r\n\t\t\t\tlight: variables.tokens.light.color.fg.promo.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.fg.promo.default.value,\r\n\t\t\t},\r\n\t\t\tbrand: {\r\n\t\t\t\tdefault: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.fg.brand.default.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.fg.brand.default.value,\r\n\t\t\t\t},\r\n\t\t\t\tbold: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.fg.brand.bold.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.fg.brand.bold.value,\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\taccent: {\r\n\t\t\t\tdefault: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.fg.accent.default.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.fg.accent.default.value,\r\n\t\t\t\t},\r\n\t\t\t\tbold: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.fg.accent.bold.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.fg.accent.bold.value,\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t},\r\n\t\tbg: {\r\n\t\t\tneutral: {\r\n\t\t\t\tdefault: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.bg.neutral.default.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.bg.neutral.default.value,\r\n\t\t\t\t},\r\n\t\t\t\tsubtle: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.bg.neutral.subtle.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.bg.neutral.subtle.value,\r\n\t\t\t\t},\r\n\t\t\t\tsubtlest: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.bg.neutral.subtlest.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.bg.neutral.subtlest.value,\r\n\t\t\t\t},\r\n\t\t\t\twhite: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.bg.neutral.white.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.bg.neutral.white.value,\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\tdisabled: {\r\n\t\t\t\tlight: variables.tokens.light.color.bg.disabled.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.bg.disabled.default.value,\r\n\t\t\t},\r\n\t\t\tpromo: {\r\n\t\t\t\tdefault: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.bg.promo.default.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.bg.promo.default.value,\r\n\t\t\t\t},\r\n\t\t\t\tbold: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.bg.promo.bold.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.bg.promo.bold.value,\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\terror: {\r\n\t\t\t\tdefault: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.bg.error.default.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.bg.error.default.value,\r\n\t\t\t\t},\r\n\t\t\t\tbold: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.bg.error.bold.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.bg.error.bold.value,\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\twarning: {\r\n\t\t\t\tdefault: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.bg.warning.default.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.bg.warning.default.value,\r\n\t\t\t\t},\r\n\t\t\t\tbold: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.bg.warning.bold.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.bg.warning.bold.value,\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\tinverse: {\r\n\t\t\t\tlight: variables.tokens.light.color.bg.inverse.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.bg.inverse.default.value,\r\n\t\t\t},\r\n\t\t\tsuccess: {\r\n\t\t\t\tdefault: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.bg.success.default.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.bg.success.default.value,\r\n\t\t\t\t},\r\n\t\t\t\tbold: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.bg.success.bold.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.bg.success.bold.value,\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\tinfo: {\r\n\t\t\t\tdefault: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.bg.info.default.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.bg.info.default.value,\r\n\t\t\t\t},\r\n\t\t\t\tbold: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.bg.info.bold.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.bg.info.bold.value,\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\taccent: {\r\n\t\t\t\tlight: variables.tokens.light.color.bg.accent.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.bg.accent.default.value,\r\n\t\t\t},\r\n\t\t\tbrand: {\r\n\t\t\t\tdefault: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.bg.brand.default.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.bg.brand.default.value,\r\n\t\t\t\t\thover: {\r\n\t\t\t\t\t\tlight: variables.tokens.light.color.bg.brand.default.hover.value,\r\n\t\t\t\t\t\tdark: variables.tokens.dark.color.bg.brand.default.hover.value,\r\n\t\t\t\t\t},\r\n\t\t\t\t\tpressed: {\r\n\t\t\t\t\t\tlight: variables.tokens.light.color.bg.brand.default.pressed.value,\r\n\t\t\t\t\t\tdark: variables.tokens.dark.color.bg.brand.default.pressed.value,\r\n\t\t\t\t\t},\r\n\t\t\t\t},\r\n\t\t\t\tbold: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.bg.brand.bold.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.bg.brand.bold.value,\r\n\t\t\t\t\thover: {\r\n\t\t\t\t\t\tlight: variables.tokens.light.color.bg.brand.bold.hover.value,\r\n\t\t\t\t\t\tdark: variables.tokens.dark.color.bg.brand.bold.hover.value,\r\n\t\t\t\t\t},\r\n\t\t\t\t\tpressed: {\r\n\t\t\t\t\t\tlight: variables.tokens.light.color.bg.brand.bold.pressed.value,\r\n\t\t\t\t\t\tdark: variables.tokens.dark.color.bg.brand.bold.pressed.value,\r\n\t\t\t\t\t},\r\n\t\t\t\t},\r\n\t\t\t\tsemibold: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.bg.brand.semibold.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.bg.brand.semibold.value,\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t},\r\n\t\tsurface: {\r\n\t\t\toverlay: {\r\n\t\t\t\tlight: 'rgba(240, 245, 255, .75)',\r\n\t\t\t\tdark: 'rgba(23, 27, 33, .75)',\r\n\t\t\t},\r\n\t\t\trisen: {\r\n\t\t\t\tlight: variables.tokens.light.color.surface.risen.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.surface.risen.value,\r\n\t\t\t},\r\n\t\t\tdefault: {\r\n\t\t\t\tlight: variables.tokens.light.color.surface.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.surface.default.value,\r\n\t\t\t},\r\n\t\t\tsunken: {\r\n\t\t\t\tlight: variables.tokens.light.color.surface.sunken.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.surface.sunken.value,\r\n\t\t\t},\r\n\t\t},\r\n\t\tborder: {\r\n\t\t\tneutral: {\r\n\t\t\t\tdefault: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.border.neutral.default.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.border.neutral.default.value,\r\n\t\t\t\t},\r\n\t\t\t\tsubtle: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.border.neutral.subtle.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.border.neutral.subtle.value,\r\n\t\t\t\t},\r\n\t\t\t\tsubtlest: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.border.neutral.subtlest.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.border.neutral.subtlest.value,\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\tdisabled: {\r\n\t\t\t\tlight: variables.tokens.light.color.border.disabled.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.border.disabled.default.value,\r\n\t\t\t},\r\n\t\t\tsuccess: {\r\n\t\t\t\tlight: variables.tokens.light.color.border.success.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.border.success.default.value,\r\n\t\t\t},\r\n\t\t\twarning: {\r\n\t\t\t\tlight: variables.tokens.light.color.border.warning.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.border.warning.default.value,\r\n\t\t\t},\r\n\t\t\terror: {\r\n\t\t\t\tlight: variables.tokens.light.color.border.error.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.border.error.default.value,\r\n\t\t\t},\r\n\t\t\tpromo: {\r\n\t\t\t\tlight: variables.tokens.light.color.border.promo.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.border.promo.default.value,\r\n\t\t\t},\r\n\t\t\tbrand: {\r\n\t\t\t\tbold: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.border.brand.bold.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.border.brand.bold.value,\r\n\t\t\t\t},\r\n\t\t\t\tdefault: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.border.brand.default.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.border.brand.default.value,\r\n\t\t\t\t},\r\n\t\t\t\tsubtle: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.border.brand.subtle.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.border.brand.subtle.value,\r\n\t\t\t\t},\r\n\t\t\t\tsubtlest: {\r\n\t\t\t\t\tlight: variables.tokens.light.color.border.brand.subtlest.value,\r\n\t\t\t\t\tdark: variables.tokens.dark.color.border.brand.subtlest.value,\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\tinverse: {\r\n\t\t\t\tlight: variables.tokens.light.color.border.inverse.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.border.inverse.default.value,\r\n\t\t\t},\r\n\t\t\taccent: {\r\n\t\t\t\tlight: variables.tokens.light.color.border.accent.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.border.accent.default.value,\r\n\t\t\t},\r\n\t\t},\r\n\t\ticon: {\r\n\t\t\tbg: {\r\n\t\t\t\tlight: variables.tokens.light.color.icon.background.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.icon.background.default.value,\r\n\t\t\t},\r\n\t\t\tbrand: {\r\n\t\t\t\tlight: variables.tokens.light.color.icon.brand.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.icon.brand.default.value,\r\n\t\t\t},\r\n\t\t\tneutral: {\r\n\t\t\t\tlight: variables.tokens.light.color.icon.neutral.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.icon.neutral.default.value,\r\n\t\t\t},\r\n\t\t\tinverse: {\r\n\t\t\t\tlight: variables.tokens.light.color.icon.inverse.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.icon.inverse.default.value,\r\n\t\t\t},\r\n\t\t\tdisabled: {\r\n\t\t\t\tlight: variables.tokens.light.color.icon.disabled.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.icon.disabled.default.value,\r\n\t\t\t},\r\n\t\t\terror: {\r\n\t\t\t\tlight: variables.tokens.light.color.icon.error.default.value,\r\n\t\t\t\tdark: variables.tokens.dark.color.icon.error.default.value,\r\n\t\t\t},\r\n\t\t},\r\n\t\tshadow: {\r\n\t\t\tcards: '0px 1px 40px 0px rgba(0, 0, 0, 0.05)',\r\n\t\t\tultraStrongBlueLg: '0px 4px 25px 0px rgba(28, 101, 253, 0.08), 0px 4px 4px 0px rgba(28, 101, 253, 0.04)',\r\n\t\t\tstrongBlueMd: '0px 4px 4px 0px rgba(28, 101, 253, 0.02), 0px 4px 25px 0px rgba(28, 101, 253, 0.06)',\r\n\t\t},\r\n\t\tfocus: {\r\n\t\t\tlight: variables.tokens.light.color.border.brand.bold.value,\r\n\t\t\tdark: variables.tokens.dark.color.border.brand.bold.value,\r\n\t\t},\r\n\t},\r\n\r\n\t// FONT\r\n\tfont: {\r\n\t\tsize: {\r\n\t\t\theading: {\r\n\t\t\t\th1: {\r\n\t\t\t\t\tdesktop: '4rem', // 64px\r\n\t\t\t\t\tmobile: '2rem', // 32px\r\n\t\t\t\t},\r\n\t\t\t\th2: {\r\n\t\t\t\t\tdesktop: '2.625rem', // 42px\r\n\t\t\t\t\tmobile: '2rem', // 32px\r\n\t\t\t\t},\r\n\t\t\t\th3: {\r\n\t\t\t\t\tdesktop: '2rem', // 32px\r\n\t\t\t\t\tmobile: '1.5rem', // 24px\r\n\t\t\t\t},\r\n\t\t\t\th4: {\r\n\t\t\t\t\tdesktop: '1.5rem', // 24px\r\n\t\t\t\t\tmobile: '1.125rem', // 18px\r\n\t\t\t\t},\r\n\t\t\t\th5: {\r\n\t\t\t\t\tdesktop: '1.125rem', // 18px\r\n\t\t\t\t\tmobile: '1.125rem', // 18px\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\tbody: {\r\n\t\t\t\txs: '0.75rem', // 12px\r\n\t\t\t\tsm: '0.875rem', // 14px\r\n\t\t\t\tmd: '1rem', // 16px\r\n\t\t\t\tlg: '1.125rem', // 18px\r\n\t\t\t},\r\n\t\t},\r\n\t\tlineHeight: {\r\n\t\t\theading: {\r\n\t\t\t\th1: {\r\n\t\t\t\t\tdesktop: '4.375rem', // 70px\r\n\t\t\t\t\tmobile: '2.5rem', // 40px\r\n\t\t\t\t},\r\n\t\t\t\th2: {\r\n\t\t\t\t\tdesktop: '3.375rem', // 54px\r\n\t\t\t\t\tmobile: '2.5rem', // 40px\r\n\t\t\t\t},\r\n\t\t\t\th3: {\r\n\t\t\t\t\tdesktop: '2.5rem', // 40px\r\n\t\t\t\t\tmobile: '2rem', // 32px\r\n\t\t\t\t},\r\n\t\t\t\th4: {\r\n\t\t\t\t\tdesktop: '2rem', // 32px\r\n\t\t\t\t\tmobile: '1.5rem', // 24px\r\n\t\t\t\t},\r\n\t\t\t\th5: {\r\n\t\t\t\t\tdesktop: '1.5rem', // 24px\r\n\t\t\t\t\tmobile: '1.5rem', // 24px\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\tbody: {\r\n\t\t\t\tlg: '1.75rem', // 28px\r\n\t\t\t\tmd: '1.5rem', // 24px\r\n\t\t\t\tsm: '1.25rem', // 20px\r\n\t\t\t\txs: '1rem', // 16px\r\n\t\t\t},\r\n\t\t},\r\n\t\tweight: {\r\n\t\t\tthin: 100,\r\n\t\t\textraLight: 200,\r\n\t\t\tlight: 300,\r\n\t\t\tregular: 400,\r\n\t\t\tmedium: 500,\r\n\t\t\tsemiBold: 600,\r\n\t\t\tbold: 700,\r\n\t\t\textraBold: 800,\r\n\t\t\theavy: 900,\r\n\t\t\tultra: 950,\r\n\t\t},\r\n\t\tletterSpacing: {\r\n\t\t\theading: {\r\n\t\t\t\th1: {\r\n\t\t\t\t\tdesktop: '-1.28px',\r\n\t\t\t\t\tmobile: '-1px',\r\n\t\t\t\t},\r\n\t\t\t\th2: {\r\n\t\t\t\t\tdesktop: '-1px',\r\n\t\t\t\t\tmobile: '-1px',\r\n\t\t\t\t},\r\n\t\t\t\th3: {\r\n\t\t\t\t\tdesktop: '-1px',\r\n\t\t\t\t\tmobile: '0',\r\n\t\t\t\t},\r\n\t\t\t\th4: {\r\n\t\t\t\t\tdesktop: '0',\r\n\t\t\t\t\tmobile: '0',\r\n\t\t\t\t},\r\n\t\t\t\th5: {\r\n\t\t\t\t\tdesktop: '0',\r\n\t\t\t\t\tmobile: '0',\r\n\t\t\t\t},\r\n\t\t\t},\r\n\t\t\tbody: {\r\n\t\t\t\tlg: '0',\r\n\t\t\t\tmd: '0',\r\n\t\t\t\tsm: '-0.2px',\r\n\t\t\t\txs: '-0.2px',\r\n\t\t\t},\r\n\t\t},\r\n\t\tfamily: {\r\n\t\t\tmain: 'Inter, sans-serif',\r\n\t\t\theading: \"'Plus Jakarta Sans', sans-serif\",\r\n\t\t},\r\n\t},\r\n\r\n\t// LAYOUT\r\n\tspacing: {\r\n\t\txxs: variables.tokens.light.layout.spacing['spacer-1-(xxs)'].value,\r\n\t\txs: variables.tokens.light.layout.spacing['spacer-2-(xs)'].value,\r\n\t\tsm: variables.tokens.light.layout.spacing['spacer-3-(sm)'].value,\r\n\t\tmd: variables.tokens.light.layout.spacing['spacer-4-(md)'].value,\r\n\t\tlg: variables.tokens.light.layout.spacing['spacer-5-(lg)'].value,\r\n\t\txl: variables.tokens.light.layout.spacing['spacer-6-(xl)'].value,\r\n\t\txxl: variables.tokens.light.layout.spacing['spacer-7-(2xl)'].value,\r\n\t\txxxl: variables.tokens.light.layout.spacing['spacer-8-(3xl)'].value,\r\n\t\txxxxl: variables.tokens.light.layout.spacing['spacer-9-(4xl)'].value,\r\n\t\txxxxxl: variables.tokens.light.layout.spacing['spacer-10-(5xl)'].value,\r\n\t},\r\n\tborderRadius: {\r\n\t\txxs: variables.tokens.light.layout['border-radius'].xxs.value,\r\n\t\txs: variables.tokens.light.layout['border-radius'].xs.value,\r\n\t\tsm: variables.tokens.light.layout['border-radius'].sm.value,\r\n\t\tmd: variables.tokens.light.layout['border-radius'].md.value,\r\n\t\tlg: variables.tokens.light.layout['border-radius'].lg.value,\r\n\t\txl: variables.tokens.light.layout['border-radius'].xl.value,\r\n\t\tfull: variables.tokens.light.layout['border-radius'].full.value,\r\n\t},\r\n\tshadow: {\r\n\t\tbox: {\r\n\t\t\tsm: '0px 0px 8px 0px rgba(28, 101, 253, 0.06), 0px 1px 1px 0px rgba(28, 101, 253, 0.02)',\r\n\t\t\t// Strong Blue\r\n\t\t\tmd: '0px 4px 25px 0px rgba(28, 101, 253, 0.06), 0px 4px 4px 0px rgba(28, 101, 253, 0.02)',\r\n\t\t\t// Ultra Strong Blue\r\n\t\t\tlg: '0px 4px 25px 0px rgba(28, 101, 253, 0.08), 0px 4px 4px 0px rgba(28, 101, 253, 0.04)',\r\n\t\t\t// Chatbot, not currently listed in the \"Box Shadow\" Figma page, but the variable exists nonetheless.\r\n\t\t\txl: '-23px 132px 38px 0px rgba(28, 101, 253, 0.00), -15px 84px 34px 0px rgba(28, 101, 253, 0.01), -8px 48px 29px 0px rgba(28, 101, 253, 0.05), -4px 21px 21px 0px rgba(28, 101, 253, 0.09), -1px 5px 12px 0px rgba(28, 101, 253, 0.10)',\r\n\t\t},\r\n\t\tborder: {\r\n\t\t\tsm: '0px 1px 2px 0px rgba(16, 24, 40, 0.06), 0px 1px 3px 0px rgba(16, 24, 40, 0.10)',\r\n\t\t},\r\n\t},\r\n\tcontainer: {\r\n\t\txl: variables.tokens.light.layout.container.xl.value,\r\n\t},\r\n\tbreakpoints: {\r\n\t\t// mobile\r\n\t\txs: variables.tokens.light.layout.breakpoint.xs.value,\r\n\t\tsm: variables.tokens.light.layout.breakpoint.sm.value,\r\n\t\t// tablet\r\n\t\tmd: variables.tokens.light.layout.breakpoint.md.value,\r\n\t\t// desktop\r\n\t\tlg: variables.tokens.light.layout.breakpoint.lg.value,\r\n\t\txl: variables.tokens.light.layout.breakpoint.xl.value,\r\n\t\txxl: variables.tokens.light.layout.breakpoint['2xl'].value,\r\n\t},\r\n\t// https://getbootstrap.com/docs/5.0/layout/z-index/\r\n\tzIndex: {\r\n\t\tdropdown: 1000,\r\n\t\tsticky: 1020,\r\n\t\tfixed: 1030,\r\n\t\tmodalBackdrop: 1040,\r\n\t\toffcanvas: 1050,\r\n\t\tmodal: 1060,\r\n\t\tpopover: 1070,\r\n\t\ttooltip: 1080,\r\n\t},\r\n} as const;\r\n\r\nexport type Theme = typeof theme;\r\n","export enum Overflow {\r\n\tauto = 'auto',\r\n\tclip = 'clip',\r\n\thidden = 'hidden',\r\n\tinherit = 'inherit',\r\n\tvisible = 'visible',\r\n}\r\n\r\nexport const resolveOverflowValue = (overflow: Overflow) => {\r\n\treturn overflow.toString();\r\n};\r\n","import { type Theme } from '@emotion/react';\r\n\r\n/* eslint-disable perfectionist/sort-enums */\r\nexport enum BorderRadius {\r\n\tnone = 'none',\r\n\r\n\txxs = 'xxs',\r\n\txs = 'xs',\r\n\tsm = 'sm',\r\n\tmd = 'md',\r\n\tlg = 'lg',\r\n\txl = 'xl',\r\n\r\n\tfull = 'full',\r\n}\r\n/* eslint-enable perfectionist/sort-enums */\r\n\r\nexport const resolveBorderRadiusValue = (theme: Theme, borderRadius: BorderRadius) => {\r\n\tif (borderRadius === BorderRadius.none) {\r\n\t\treturn '0';\r\n\t}\r\n\r\n\treturn theme.borderRadius[borderRadius];\r\n};\r\n","export enum FlexWrap {\r\n\tnoWrap = 'noWrap',\r\n\twrap = 'wrap',\r\n\twrapReverse = 'wrapReverse',\r\n}\r\n\r\nexport const resolveFlexWrapValue = (flexWrap: FlexWrap) => {\r\n\treturn flexWrap.toString();\r\n};\r\n","import { css } from '@emotion/react';\r\n\r\nexport enum TextDecoration {\r\n\tnoneImportant = 'noneImportant',\r\n\tunderline = 'underline',\r\n}\r\n\r\nexport const resolveTextDecorationValue = (textDecoration: TextDecoration) => {\r\n\tswitch (textDecoration) {\r\n\t\tcase TextDecoration.noneImportant:\r\n\t\t\treturn `none !important`;\r\n\t\tcase TextDecoration.underline:\r\n\t\t\treturn `underline`;\r\n\t\tdefault:\r\n\t\t\tthrow new Error('unexpected TextDecoration enum value in resolveTextDecorationValue');\r\n\t}\r\n};\r\n\r\nexport const getTextDecorationStyle = (textDecoration?: TextDecoration) => {\r\n\tif (textDecoration === undefined) {\r\n\t\treturn '';\r\n\t}\r\n\r\n\treturn css`\r\n\t\ttext-decoration: ${resolveTextDecorationValue(textDecoration)};\r\n\t`;\r\n};\r\n","import { type BorderRadius, resolveBorderRadiusValue } from '@/theme/borderRadius';\r\nimport { type ChooseColor, styled } from '@/utils';\r\n\r\ninterface SpanButtonStyledProps {\r\n\t$borderRadius: BorderRadius;\r\n\t$chooseColor: ChooseColor;\r\n\t$disabled: boolean;\r\n}\r\n\r\nexport const SpanButtonStyled = styled.button<SpanButtonStyledProps>`\r\n\tall: unset;\r\n\tdisplay: inline-flex;\r\n\tfont: inherit;\r\n\tcolor: inherit;\r\n\tcursor: ${({ $disabled }) => ($disabled ? 'default' : 'pointer')};\r\n\tborder-radius: ${({ $borderRadius, theme }) => resolveBorderRadiusValue(theme, $borderRadius)};\r\n\r\n\t&:focus-visible {\r\n\t\toutline-width: 3px;\r\n\t\toutline-style: solid;\r\n\t\toutline-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.border.brand.bold)};\r\n\t\toutline-offset: 3px;\r\n\t}\r\n`;\r\n","import { type AriaAttributes, type MouseEvent, type ReactNode, type TouchEvent } from 'react';\r\n\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { BorderRadius } from '@/theme';\r\n\r\nimport { SpanButtonStyled } from './SpanButton.style';\r\n\r\nexport interface SpanButtonProps extends DesignSystemBaseProps, AriaAttributes {\r\n\tborderRadius?: BorderRadius;\r\n\tchildren?: ReactNode;\r\n\tclassName?: string;\r\n\tdisabled?: boolean;\r\n\tid?: string;\r\n\tonClick?: (event: MouseEvent<HTMLButtonElement>) => void;\r\n\tonMouseDown?: (event: MouseEvent<HTMLButtonElement>) => void;\r\n\tonMouseUp?: (event: MouseEvent<HTMLButtonElement>) => void;\r\n\tonTouchStart?: (event: TouchEvent<HTMLButtonElement>) => void;\r\n}\r\n\r\nexport const SpanButton = (props: SpanButtonProps) => {\r\n\tconst {\r\n\t\tborderRadius = BorderRadius.none,\r\n\t\tchildren,\r\n\t\tclassName,\r\n\t\tcolorScheme, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\tdisabled = false,\r\n\t\tid,\r\n\t\tmediaType, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\tonClick,\r\n\t\tonMouseDown,\r\n\t\tonMouseUp,\r\n\t\tonTouchStart,\r\n\t\t...restProps\r\n\t} = props;\r\n\r\n\tconst { chooseColor } = useDesignSystem(props);\r\n\r\n\treturn (\r\n\t\t<SpanButtonStyled\r\n\t\t\t{...restProps}\r\n\t\t\t$borderRadius={borderRadius}\r\n\t\t\t$chooseColor={chooseColor}\r\n\t\t\t$disabled={disabled}\r\n\t\t\tclassName={className}\r\n\t\t\tdisabled={disabled}\r\n\t\t\tid={id}\r\n\t\t\ttype={'button'}\r\n\t\t\tonClick={onClick}\r\n\t\t\tonMouseDown={onMouseDown}\r\n\t\t\tonMouseUp={onMouseUp}\r\n\t\t\tonTouchStart={onTouchStart}\r\n\t\t>\r\n\t\t\t{children}\r\n\t\t</SpanButtonStyled>\r\n\t);\r\n};\r\n","/* eslint-disable perfectionist/sort-enums */\r\nexport enum TypographyVariant {\r\n\ttextXs = 'textXs',\r\n\ttextSm = 'textSm',\r\n\ttextMd = 'textMd',\r\n\ttextLg = 'textLg',\r\n\th1 = 'h1',\r\n\th2 = 'h2',\r\n\th3 = 'h3',\r\n\th4 = 'h4',\r\n\th5 = 'h5',\r\n}\r\n/* eslint-enable perfectionist/sort-enums */\r\n\r\nexport enum TypographyTextAlign {\r\n\tcenter = 'center',\r\n\tleft = 'left',\r\n\tright = 'right',\r\n}\r\n","import { css } from '@emotion/react';\r\n\r\nimport { type FontWeight, type TextDecoration, type WhiteSpace, getTextDecorationStyle, resolveFontWeightValue, resolveWhiteSpaceValue } from '@/theme';\r\nimport { getClampedFontSize, styled } from '@/utils';\r\n\r\nimport { type TypographyTextAlign, TypographyVariant } from './types';\r\n\r\ninterface TypographyStyledProps {\r\n\t$color?: string;\r\n\t$decoration?: TextDecoration;\r\n\t$fullWidth: boolean;\r\n\t$textAlign: TypographyTextAlign;\r\n\t$variant: TypographyVariant;\r\n\t$weight: FontWeight;\r\n\t$whiteSpace: WhiteSpace;\r\n}\r\n\r\nexport const TypographyStyled = styled.span<TypographyStyledProps>`\r\n\t/* common styles */\r\n\tmargin: 0;\r\n\tfont-weight: ${({ $weight, theme }) => resolveFontWeightValue(theme, $weight)};\r\n\tcolor: ${({ $color }) => $color};\r\n\ttext-align: ${({ $textAlign }) => $textAlign};\r\n\twhite-space: ${({ $whiteSpace }) => resolveWhiteSpaceValue($whiteSpace)};\r\n\r\n\t${({ $fullWidth }) =>\r\n\t\t$fullWidth &&\r\n\t\tcss`\r\n\t\t\tdisplay: block;\r\n\t\t\twidth: 100%;\r\n\t\t`};\r\n\r\n\t${({ $decoration }) => getTextDecorationStyle($decoration)};\r\n\r\n\t/* variant specific styles */\r\n\t${({ $variant, theme }) => {\r\n\t\tswitch ($variant) {\r\n\t\t\tcase TypographyVariant.h1:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tfont-family: ${theme.font.family.heading};\r\n\t\t\t\t\tfont-size: ${theme.font.size.heading.h1.mobile};\r\n\t\t\t\t\tline-height: ${theme.font.lineHeight.heading.h1.mobile};\r\n\t\t\t\t\tletter-spacing: ${theme.font.letterSpacing.heading.h1.mobile};\r\n\r\n\t\t\t\t\t@media (min-width: ${theme.breakpoints.lg}) {\r\n\t\t\t\t\t\tfont-size: ${theme.font.size.heading.h1.desktop};\r\n\t\t\t\t\t\tline-height: ${theme.font.lineHeight.heading.h1.desktop};\r\n\t\t\t\t\t\tletter-spacing: ${theme.font.letterSpacing.heading.h1.desktop};\r\n\t\t\t\t\t}\r\n\t\t\t\t`;\r\n\t\t\tcase TypographyVariant.h2:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tfont-family: ${theme.font.family.heading};\r\n\t\t\t\t\tfont-size: ${theme.font.size.heading.h2.mobile};\r\n\t\t\t\t\tline-height: ${theme.font.lineHeight.heading.h2.mobile};\r\n\t\t\t\t\tletter-spacing: ${theme.font.letterSpacing.heading.h2.mobile};\r\n\r\n\t\t\t\t\t@media (min-width: ${theme.breakpoints.lg}) {\r\n\t\t\t\t\t\tfont-size: ${theme.font.size.heading.h2.desktop};\r\n\t\t\t\t\t\tline-height: ${theme.font.lineHeight.heading.h2.desktop};\r\n\t\t\t\t\t\tletter-spacing: ${theme.font.letterSpacing.heading.h2.desktop};\r\n\t\t\t\t\t}\r\n\t\t\t\t`;\r\n\t\t\tcase TypographyVariant.h3:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tfont-family: ${theme.font.family.heading};\r\n\t\t\t\t\tfont-size: ${theme.font.size.heading.h3.mobile};\r\n\t\t\t\t\tline-height: ${theme.font.lineHeight.heading.h3.mobile};\r\n\t\t\t\t\tletter-spacing: ${theme.font.letterSpacing.heading.h3.mobile};\r\n\r\n\t\t\t\t\t@media (min-width: ${theme.breakpoints.lg}) {\r\n\t\t\t\t\t\tfont-size: ${theme.font.size.heading.h3.desktop};\r\n\t\t\t\t\t\tline-height: ${theme.font.lineHeight.heading.h3.desktop};\r\n\t\t\t\t\t\tletter-spacing: ${theme.font.letterSpacing.heading.h3.desktop};\r\n\t\t\t\t\t}\r\n\t\t\t\t`;\r\n\t\t\tcase TypographyVariant.h4:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tfont-family: ${theme.font.family.heading};\r\n\t\t\t\t\tfont-size: ${theme.font.size.heading.h4.mobile};\r\n\t\t\t\t\tline-height: ${theme.font.lineHeight.heading.h4.mobile};\r\n\t\t\t\t\tletter-spacing: ${theme.font.letterSpacing.heading.h4.mobile};\r\n\r\n\t\t\t\t\t@media (min-width: ${theme.breakpoints.lg}) {\r\n\t\t\t\t\t\tfont-size: ${theme.font.size.heading.h4.desktop};\r\n\t\t\t\t\t\tline-height: ${theme.font.lineHeight.heading.h4.desktop};\r\n\t\t\t\t\t\tletter-spacing: ${theme.font.letterSpacing.heading.h4.desktop};\r\n\t\t\t\t\t}\r\n\t\t\t\t`;\r\n\t\t\tcase TypographyVariant.h5:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tfont-family: ${theme.font.family.heading};\r\n\t\t\t\t\tfont-size: ${theme.font.size.heading.h5.mobile};\r\n\t\t\t\t\tline-height: ${theme.font.lineHeight.heading.h5.mobile};\r\n\t\t\t\t\tletter-spacing: ${theme.font.letterSpacing.heading.h5.mobile};\r\n\r\n\t\t\t\t\t@media (min-width: ${theme.breakpoints.lg}) {\r\n\t\t\t\t\t\tfont-size: ${theme.font.size.heading.h5.desktop};\r\n\t\t\t\t\t\tline-height: ${theme.font.lineHeight.heading.h5.desktop};\r\n\t\t\t\t\t\tletter-spacing: ${theme.font.letterSpacing.heading.h5.desktop};\r\n\t\t\t\t\t}\r\n\t\t\t\t`;\r\n\t\t\tcase TypographyVariant.textLg:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tfont-family: ${theme.font.family.main};\r\n\t\t\t\t\tfont-size: ${getClampedFontSize(theme.font.size.body.lg)};\r\n\t\t\t\t\tline-height: ${theme.font.lineHeight.body.lg};\r\n\t\t\t\t\tletter-spacing: ${theme.font.letterSpacing.body.lg};\r\n\t\t\t\t`;\r\n\t\t\tcase TypographyVariant.textMd:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tfont-family: ${theme.font.family.main};\r\n\t\t\t\t\tfont-size: ${getClampedFontSize(theme.font.size.body.md)};\r\n\t\t\t\t\tline-height: ${theme.font.lineHeight.body.md};\r\n\t\t\t\t\tletter-spacing: ${theme.font.letterSpacing.body.md};\r\n\t\t\t\t`;\r\n\t\t\tcase TypographyVariant.textSm:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tfont-family: ${theme.font.family.main};\r\n\t\t\t\t\tfont-size: ${getClampedFontSize(theme.font.size.body.sm)};\r\n\t\t\t\t\tline-height: ${theme.font.lineHeight.body.sm};\r\n\t\t\t\t\tletter-spacing: ${theme.font.letterSpacing.body.sm};\r\n\t\t\t\t`;\r\n\t\t\tcase TypographyVariant.textXs:\r\n\t\t\tdefault:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tfont-family: ${theme.font.family.main};\r\n\t\t\t\t\tfont-size: ${getClampedFontSize(theme.font.size.body.xs)};\r\n\t\t\t\t\tline-height: ${theme.font.lineHeight.body.xs};\r\n\t\t\t\t\tletter-spacing: ${theme.font.letterSpacing.body.xs};\r\n\t\t\t\t`;\r\n\t\t}\r\n\t}}\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { type AriaAttributes, type AriaRole, type ElementType, forwardRef, type MouseEvent, type ReactNode } from 'react';\r\n\r\nimport { TypographyVariant } from '@/components/typography/types';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { FontWeight, type TextDecoration, WhiteSpace } from '@/theme';\r\nimport { type ColorObject, type SsrProps } from '@/types';\r\n\r\nimport { TypographyTextAlign } from './types';\r\n\r\nimport { TypographyStyled } from './Typography.style';\r\n\r\nconst getAs = (variant: TypographyVariant, originalAs?: ElementType) => {\r\n\tif (originalAs !== undefined) {\r\n\t\treturn originalAs;\r\n\t}\r\n\r\n\tswitch (variant) {\r\n\t\tcase TypographyVariant.h1:\r\n\t\t\treturn 'h1';\r\n\t\tcase TypographyVariant.h2:\r\n\t\t\treturn 'h2';\r\n\t\tcase TypographyVariant.h3:\r\n\t\t\treturn 'h3';\r\n\t\tcase TypographyVariant.h4:\r\n\t\t\treturn 'h4';\r\n\t\tcase TypographyVariant.h5:\r\n\t\t\treturn 'h5';\r\n\t\tdefault:\r\n\t\t\treturn undefined;\r\n\t}\r\n};\r\n\r\nexport interface TypographyProps extends DesignSystemBaseProps, SsrProps, AriaAttributes {\r\n\tas?: ElementType;\r\n\tchildren: ReactNode;\r\n\tclassName?: string;\r\n\tcolor?: ColorObject | string;\r\n\tdecoration?: TextDecoration;\r\n\tfullWidth?: boolean;\r\n\tid?: string;\r\n\tonClick?: ((event: MouseEvent<HTMLElement>) => void) | undefined;\r\n\trole?: AriaRole;\r\n\ttabIndex?: number;\r\n\ttextAlign?: TypographyTextAlign;\r\n\tvariant?: TypographyVariant;\r\n\tweight?: FontWeight;\r\n\twhiteSpace?: WhiteSpace;\r\n}\r\n\r\nexport const Typography = forwardRef<HTMLElement, TypographyProps>((props, ref) => {\r\n\tconst theme = useTheme();\r\n\r\n\tconst {\r\n\t\tas,\r\n\t\tchildren,\r\n\t\tclassName,\r\n\t\tcolor: colorProp = theme.colors.fg.neutral.subtle,\r\n\t\tcolorScheme: colorSchemeProp, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\tdecoration,\r\n\t\tfullWidth = false,\r\n\t\tid,\r\n\t\tmediaType: mediaTypeProp, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\tonClick,\r\n\t\trole,\r\n\t\tsuppressHydrationWarning,\r\n\t\ttabIndex,\r\n\t\ttextAlign = TypographyTextAlign.left,\r\n\t\tvariant = TypographyVariant.textMd,\r\n\t\tweight = FontWeight.regular400,\r\n\t\twhiteSpace = WhiteSpace.inherit,\r\n\t\t...otherProps\r\n\t} = props;\r\n\r\n\tconst { chooseColor } = useDesignSystem(props);\r\n\r\n\tconst color = typeof colorProp === 'string' ? colorProp : chooseColor(colorProp);\r\n\r\n\treturn (\r\n\t\t<TypographyStyled\r\n\t\t\t$color={color}\r\n\t\t\t$decoration={decoration}\r\n\t\t\t$fullWidth={fullWidth}\r\n\t\t\t$textAlign={textAlign}\r\n\t\t\t$variant={variant}\r\n\t\t\t$weight={weight}\r\n\t\t\t$whiteSpace={whiteSpace}\r\n\t\t\tas={getAs(variant, as)}\r\n\t\t\tclassName={className}\r\n\t\t\tid={id}\r\n\t\t\tref={ref}\r\n\t\t\trole={role}\r\n\t\t\tsuppressHydrationWarning={suppressHydrationWarning}\r\n\t\t\ttabIndex={tabIndex}\r\n\t\t\tonClick={onClick}\r\n\t\t\t{...otherProps}\r\n\t\t>\r\n\t\t\t{children}\r\n\t\t</TypographyStyled>\r\n\t);\r\n});\r\n\r\nTypography.displayName = 'Typography';\r\n","import { css } from '@emotion/react';\r\n\r\nimport { styled, type ChooseColor } from '@/utils';\r\n\r\nimport { AccordionVariant } from '../types';\r\n\r\ninterface WrapperProps {\r\n\t$chooseColor: ChooseColor;\r\n\t$isOpen: boolean;\r\n\t$variant: AccordionVariant;\r\n}\r\n\r\nexport const Wrapper = styled.div<WrapperProps>`\r\n\twidth: 100%;\r\n\toverflow: hidden;\r\n\tborder-bottom: 1px solid ${({ $chooseColor, theme }) => $chooseColor(theme.colors.border.neutral.subtlest)};\r\n\r\n\t${({ $isOpen, $variant, theme }) =>\r\n\t\t$isOpen &&\r\n\t\t$variant === AccordionVariant.default &&\r\n\t\tcss`\r\n\t\t\tbackground: ${theme.palette.white};\r\n\t\t\tborder-radius: ${theme.borderRadius.sm};\r\n\t\t\tbox-shadow: ${theme.shadow.box.md};\r\n\t\t`}\r\n`;\r\n\r\ninterface ItemContainerProps {\r\n\t$variant: AccordionVariant;\r\n}\r\n\r\nexport const ItemContainer = styled.div<ItemContainerProps>`\r\n\twidth: 100%;\r\n\theight: ${({ $variant }) => ($variant === AccordionVariant.default ? 'auto' : '52px')};\r\n\tcursor: pointer;\r\n\tbackground: transparent;\r\n\tborder: none;\r\n`;\r\n\r\ninterface ItemProps {\r\n\t$variant: AccordionVariant;\r\n}\r\n\r\nexport const Item = styled.div<ItemProps>`\r\n\tbox-sizing: border-box;\r\n\tdisplay: flex;\r\n\tflex-direction: row;\r\n\tjustify-content: space-between;\r\n\twidth: 100%;\r\n\theight: 100%;\r\n\r\n\t${({ $variant, theme }) =>\r\n\t\t$variant === AccordionVariant.default\r\n\t\t\t? css`\r\n\t\t\t\t\tpadding: ${theme.spacing.lg};\r\n\t\t\t\t`\r\n\t\t\t: css`\r\n\t\t\t\t\tpadding: ${theme.spacing.xs} ${theme.spacing.md};\r\n\t\t\t\t`}\r\n`;\r\n\r\nexport const IconLabelWrapper = styled.span`\r\n\tdisplay: flex;\r\n\tflex-direction: row;\r\n\tgap: ${({ theme }) => theme.spacing.xs};\r\n\talign-items: center;\r\n`;\r\n\r\nexport const DescriptionIconWrapper = styled.span`\r\n\tdisplay: flex;\r\n\tflex-direction: row;\r\n\tgap: ${({ theme }) => theme.spacing.xl};\r\n\talign-items: center;\r\n`;\r\n\r\ninterface ContainerProps {\r\n\t$isOpen: boolean;\r\n\t$variant: AccordionVariant;\r\n}\r\n\r\nexport const Container = styled.div<ContainerProps>`\r\n\tdisplay: block;\r\n\twidth: 100%;\r\n\r\n\t${({ $variant, theme }) =>\r\n\t\t$variant === AccordionVariant.default &&\r\n\t\tcss`\r\n\t\t\tpadding: 0 ${theme.spacing.lg} ${theme.spacing.lg};\r\n\t\t`}\r\n\r\n\t${({ $isOpen }) =>\r\n\t\t$isOpen\r\n\t\t\t? css`\r\n\t\t\t\t\theight: fit-content;\r\n\t\t\t\t`\r\n\t\t\t: css`\r\n\t\t\t\t\tdisplay: none;\r\n\t\t\t\t\theight: 0;\r\n\t\t\t\t`}\r\n\r\n\ttransition: height 0.7s ease-in-out;\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { useId } from 'react';\r\n\r\nimport { type AccordionItemType, AccordionVariant } from '@/components/accordion/types';\r\nimport { IconSystem, IconSystemSize, IconSystemType } from '@/components/iconSystem';\r\nimport { SpanButton } from '@/components/spanButton';\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { BorderRadius, FontWeight } from '@/theme';\r\n\r\nimport { Container, DescriptionIconWrapper, IconLabelWrapper, Item, ItemContainer, Wrapper } from './AccordionItem.style';\r\n\r\nexport interface AccordionItemProps extends AccordionItemType, DesignSystemBaseProps {\r\n\tvariant: AccordionVariant;\r\n}\r\n\r\nexport const AccordionItem = (props: AccordionItemProps) => {\r\n\tconst { closeActionAriaLabel, content, description, icon, isOpen = false, label, onClick, openActionAriaLabel, variant } = props;\r\n\r\n\tconst { chooseColor } = useDesignSystem(props);\r\n\tconst theme = useTheme();\r\n\r\n\tconst contentWrapperId = useId();\r\n\tconst itemContainerId = useId();\r\n\r\n\treturn (\r\n\t\t<Wrapper\r\n\t\t\t$chooseColor={chooseColor}\r\n\t\t\t$isOpen={isOpen}\r\n\t\t\t$variant={variant}\r\n\t\t>\r\n\t\t\t<ItemContainer\r\n\t\t\t\t$variant={variant}\r\n\t\t\t\tid={itemContainerId}\r\n\t\t\t\tonClick={onClick}\r\n\t\t\t>\r\n\t\t\t\t<Item $variant={variant}>\r\n\t\t\t\t\t<IconLabelWrapper>\r\n\t\t\t\t\t\t{icon}\r\n\r\n\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\tcolor={chooseColor(theme.colors.fg.neutral.default)}\r\n\t\t\t\t\t\t\tvariant={variant === AccordionVariant.default ? TypographyVariant.textLg : TypographyVariant.textSm}\r\n\t\t\t\t\t\t\tweight={FontWeight.medium500}\r\n\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t{label}\r\n\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t</IconLabelWrapper>\r\n\r\n\t\t\t\t\t<DescriptionIconWrapper>\r\n\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\tcolor={chooseColor(theme.colors.fg.neutral.subtle)}\r\n\t\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\t\tweight={FontWeight.medium500}\r\n\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t{description}\r\n\t\t\t\t\t\t</Typography>\r\n\r\n\t\t\t\t\t\t<SpanButton\r\n\t\t\t\t\t\t\taria-controls={contentWrapperId}\r\n\t\t\t\t\t\t\taria-expanded={isOpen}\r\n\t\t\t\t\t\t\taria-label={isOpen ? closeActionAriaLabel : openActionAriaLabel}\r\n\t\t\t\t\t\t\taria-labelledby={itemContainerId}\r\n\t\t\t\t\t\t\tborderRadius={BorderRadius.full}\r\n\t\t\t\t\t\t\tonClick={\r\n\t\t\t\t\t\t\t\tonClick === undefined\r\n\t\t\t\t\t\t\t\t\t? undefined\r\n\t\t\t\t\t\t\t\t\t: (event) => {\r\n\t\t\t\t\t\t\t\t\t\t\tevent.stopPropagation();\r\n\t\t\t\t\t\t\t\t\t\t\tonClick();\r\n\t\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t<IconSystem\r\n\t\t\t\t\t\t\t\tsize={variant === AccordionVariant.default ? IconSystemSize.big : IconSystemSize.small}\r\n\t\t\t\t\t\t\t\ttype={isOpen ? IconSystemType.minus : IconSystemType.plusCircle}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t</SpanButton>\r\n\t\t\t\t\t</DescriptionIconWrapper>\r\n\t\t\t\t</Item>\r\n\t\t\t</ItemContainer>\r\n\r\n\t\t\t<Container\r\n\t\t\t\t$isOpen={isOpen}\r\n\t\t\t\t$variant={variant}\r\n\t\t\t\tid={contentWrapperId}\r\n\t\t\t>\r\n\t\t\t\t{content}\r\n\t\t\t</Container>\r\n\t\t</Wrapper>\r\n\t);\r\n};\r\n","import { styled, type ChooseColor } from '@/utils';\r\n\r\ninterface WrapperProps {\r\n\t$chooseColor: ChooseColor;\r\n}\r\n\r\nexport const Item = styled.div<WrapperProps>`\r\n\tbox-sizing: border-box;\r\n\tdisplay: flex;\r\n\tflex-direction: row;\r\n\tjustify-content: space-between;\r\n\twidth: 100%;\r\n\theight: 100%;\r\n\tpadding: ${({ theme }) => theme.spacing.md} ${({ theme }) => theme.spacing.md};\r\n\tborder-bottom: 1px solid ${({ $chooseColor, theme }) => $chooseColor(theme.colors.border.neutral.subtlest)};\r\n`;\r\n","import { type ReactNode } from 'react';\r\n\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\n\r\nimport { Item } from './AccordionContent.style';\r\n\r\nexport interface AccordionContentType extends DesignSystemBaseProps {\r\n\tchildren: ReactNode;\r\n}\r\n\r\nexport const AccordionContent = (props: AccordionContentType) => {\r\n\tconst { children } = props;\r\n\r\n\tconst { chooseColor } = useDesignSystem(props);\r\n\r\n\treturn <Item $chooseColor={chooseColor}>{children}</Item>;\r\n};\r\n","import { styled } from '@/utils';\r\n\r\nexport const LabelWrapper = styled.span`\r\n\tdisplay: flex;\r\n\tflex-direction: row;\r\n\tgap: ${({ theme }) => theme.spacing.xs};\r\n\talign-items: center;\r\n`;\r\n\r\nexport const DescriptionIconWrapper = styled.span`\r\n\tdisplay: flex;\r\n\tflex-direction: row;\r\n\tgap: ${({ theme }) => theme.spacing.xl};\r\n\talign-items: center;\r\n`;\r\n","import { styled } from '@/utils';\r\n\r\nexport const VisuallyHiddenStyled = styled.span`\r\n\tposition: absolute;\r\n\twidth: 1px;\r\n\theight: 1px;\r\n\tpadding: 0;\r\n\tmargin: -1px;\r\n\toverflow: hidden;\r\n\twhite-space: nowrap;\r\n\tborder: 0;\r\n\t/* stylelint-disable-next-line property-no-deprecated */\r\n\tclip: rect(0 0 0 0);\r\n\tclip-path: inset(100%);\r\n`;\r\n","import { type AriaAttributes, type AriaRole, type ElementType, type ReactNode } from 'react';\r\n\r\nimport { VisuallyHiddenStyled } from './VisuallyHidden.style';\r\n\r\nexport interface VisuallyHiddenProps extends AriaAttributes {\r\n\tas?: ElementType;\r\n\tchildren: ReactNode;\r\n\tid?: string;\r\n\trole?: AriaRole;\r\n}\r\n\r\nexport const VisuallyHidden = (props: VisuallyHiddenProps) => {\r\n\treturn <VisuallyHiddenStyled {...props} />;\r\n};\r\n","// TODO: Rename to `ButtonVariant` or `ButtonHierarchy` as per Figma.\r\n/* eslint-disable perfectionist/sort-enums */\r\nexport enum ButtonStyle {\r\n\tprimary = 'primary',\r\n\tsecondary = 'secondary',\r\n\ttertiary = 'tertiary',\r\n\tlink = 'link',\r\n}\r\n/* eslint-enable perfectionist/sort-enums */\r\n\r\n/* eslint-disable perfectionist/sort-enums */\r\nexport enum ButtonSize {\r\n\txs = 'xs',\r\n\tsm = 'sm',\r\n\tmd = 'md',\r\n\txl = 'xl',\r\n\txxl = 'xxl',\r\n}\r\n/* eslint-enable perfectionist/sort-enums */\r\n\r\nexport enum ButtonType {\r\n\tanchor = 'anchor',\r\n\tbutton = 'button',\r\n\treset = 'reset',\r\n\tsubmit = 'submit',\r\n}\r\n\r\nexport enum ButtonContentAlign {\r\n\tcenter = 'center',\r\n\tleft = 'left',\r\n\tright = 'right',\r\n}\r\n","import { css } from '@emotion/react';\r\nimport { type AnchorHTMLAttributes } from 'react';\r\n\r\nimport { pxToRem, styled, type ChooseColor } from '@/utils';\r\n\r\nimport { ButtonContentAlign, ButtonSize, ButtonStyle, ButtonType } from './types';\r\n\r\ninterface ButtonStyledProps extends AnchorHTMLAttributes<HTMLAnchorElement> {\r\n\t$buttonStyle: ButtonStyle;\r\n\t$chooseColor: ChooseColor;\r\n\t$contentAlign: ButtonContentAlign;\r\n\t$disabled: boolean;\r\n\t$fullWidth: boolean;\r\n\t$size: ButtonSize;\r\n\t$type: ButtonType;\r\n}\r\n\r\nexport const ButtonStyled = styled.button<ButtonStyledProps>`\r\n\t/* common styles */\r\n\tposition: relative;\r\n\tbox-sizing: border-box;\r\n\tdisplay: flex;\r\n\tflex-shrink: 0;\r\n\talign-items: center;\r\n\tjustify-content: ${({ $contentAlign }) => {\r\n\t\tswitch ($contentAlign) {\r\n\t\t\tcase ButtonContentAlign.left:\r\n\t\t\t\treturn 'flex-start';\r\n\t\t\tcase ButtonContentAlign.center:\r\n\t\t\t\treturn 'center';\r\n\t\t\tcase ButtonContentAlign.right:\r\n\t\t\t\treturn 'flex-end';\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('Invalid ButtonContentAlign enum value');\r\n\t\t}\r\n\t}};\r\n\r\n\twidth: ${({ $fullWidth, $type }) => {\r\n\t\tif ($fullWidth === true) {\r\n\t\t\treturn '100%';\r\n\t\t}\r\n\t\tif ($type === ButtonType.anchor) {\r\n\t\t\treturn 'fit-content';\r\n\t\t}\r\n\r\n\t\treturn 'initial';\r\n\t}};\r\n\tmargin: 0;\r\n\r\n\tfont-family: ${({ theme }) => theme.font.family.main};\r\n\ttext-decoration: none !important;\r\n\tcursor: ${({ $disabled }) => ($disabled ? 'auto' : 'pointer')};\r\n\toutline: none;\r\n\tborder: none;\r\n\ttransition-timing-function: ease-in-out;\r\n\ttransition-timing-function: cubic-bezier(0.42, 0, 0.58, 1);\r\n\ttransition-duration: 0.2s;\r\n\ttransition-property: color, background-color, box-shadow;\r\n\r\n\t&:focus-visible {\r\n\t\toutline-width: 3px;\r\n\t\toutline-style: solid;\r\n\t\toutline-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.border.brand.bold)};\r\n\t\toutline-offset: 3px;\r\n\t}\r\n\r\n\t&:hover {\r\n\t\ttext-decoration: none !important;\r\n\t}\r\n\r\n\t/* buttonStyle specific styles */\r\n\t${({ $buttonStyle, $chooseColor, theme }) => {\r\n\t\tswitch ($buttonStyle) {\r\n\t\t\tcase ButtonStyle.primary:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tcolor: ${theme.palette.white} !important;\r\n\t\t\t\t\tbackground-color: ${$chooseColor(theme.colors.bg.brand.bold)};\r\n\t\t\t\t\tbox-shadow: 0 0 0 1px ${$chooseColor(theme.colors.border.brand.bold)};\r\n\r\n\t\t\t\t\t&:disabled {\r\n\t\t\t\t\t\tcolor: ${$chooseColor(theme.colors.fg.disabled)} !important;\r\n\t\t\t\t\t\tbackground-color: ${$chooseColor(theme.colors.bg.disabled)};\r\n\t\t\t\t\t\tbox-shadow: 0 0 0 1px ${$chooseColor(theme.colors.bg.disabled)};\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\t&:hover:not([disabled], [aria-disabled='true'], [data-busy='true']) {\r\n\t\t\t\t\t\tcolor: ${theme.palette.white} !important;\r\n\t\t\t\t\t\tbackground-color: ${$chooseColor(theme.colors.bg.brand.bold.hover)};\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\t&:active:not([disabled], [aria-disabled='true'], [data-busy='true']) {\r\n\t\t\t\t\t\tbackground-color: ${$chooseColor(theme.colors.bg.brand.bold.pressed)};\r\n\t\t\t\t\t}\r\n\t\t\t\t`;\r\n\t\t\tcase ButtonStyle.secondary:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tcolor: ${$chooseColor(theme.colors.fg.neutral.subtle)} !important;\r\n\t\t\t\t\tbackground-color: transparent;\r\n\t\t\t\t\tbox-shadow: 0 0 0 1px ${$chooseColor(theme.colors.border.neutral.subtle)};\r\n\r\n\t\t\t\t\t&:disabled {\r\n\t\t\t\t\t\tcolor: ${$chooseColor(theme.colors.fg.disabled)} !important;\r\n\t\t\t\t\t\tbackground-color: transparent;\r\n\t\t\t\t\t\tbox-shadow: 0 0 0 1px solid ${$chooseColor(theme.colors.bg.disabled)};\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\t&:hover:not([disabled], [aria-disabled='true'], [data-busy='true']) {\r\n\t\t\t\t\t\tcolor: ${$chooseColor(theme.colors.fg.brand.bold)} !important;\r\n\t\t\t\t\t\tbackground-color: ${$chooseColor(theme.colors.bg.brand.default)};\r\n\t\t\t\t\t\tbox-shadow: 0 0 0 2px ${$chooseColor(theme.colors.border.brand.subtle)};\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\t&:active:not([disabled], [aria-disabled='true'], [data-busy='true']) {\r\n\t\t\t\t\t\tcolor: ${$chooseColor(theme.colors.fg.brand.bold)} !important;\r\n\t\t\t\t\t\tbackground-color: ${$chooseColor(theme.colors.bg.brand.default.pressed)};\r\n\t\t\t\t\t\tbox-shadow: 0 0 0 2px ${$chooseColor(theme.colors.border.brand.subtle)};\r\n\t\t\t\t\t}\r\n\t\t\t\t`;\r\n\t\t\tcase ButtonStyle.tertiary:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tcolor: ${$chooseColor(theme.colors.fg.neutral.subtle)} !important;\r\n\t\t\t\t\tbackground-color: transparent;\r\n\r\n\t\t\t\t\t&:disabled {\r\n\t\t\t\t\t\tcolor: ${$chooseColor(theme.colors.fg.disabled)} !important;\r\n\t\t\t\t\t\tbackground-color: transparent;\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\t&:hover:not([disabled], [aria-disabled='true'], [data-busy='true']) {\r\n\t\t\t\t\t\tcolor: ${$chooseColor(theme.colors.fg.brand.bold)} !important;\r\n\t\t\t\t\t\tbackground-color: ${$chooseColor(theme.colors.bg.brand.default)};\r\n\t\t\t\t\t\tbox-shadow: 0 0 0 2px ${$chooseColor(theme.colors.border.brand.subtle)};\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\t&:active:not([disabled], [aria-disabled='true'], [data-busy='true']) {\r\n\t\t\t\t\t\tcolor: ${$chooseColor(theme.colors.fg.brand.bold)} !important;\r\n\t\t\t\t\t\tbackground-color: ${$chooseColor(theme.colors.bg.brand.default.pressed)};\r\n\t\t\t\t\t\tbox-shadow: 0 0 0 2px ${$chooseColor(theme.colors.bg.brand.default.pressed)};\r\n\t\t\t\t\t}\r\n\t\t\t\t`;\r\n\t\t\tcase ButtonStyle.link:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tcolor: ${$chooseColor(theme.colors.fg.neutral.subtle)} !important;\r\n\t\t\t\t\tbackground-color: transparent;\r\n\r\n\t\t\t\t\t&:disabled {\r\n\t\t\t\t\t\tcolor: ${$chooseColor(theme.colors.fg.disabled)} !important;\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\t&:hover:not([disabled], [aria-disabled='true'], [data-busy='true']) {\r\n\t\t\t\t\t\tcolor: ${$chooseColor(theme.colors.fg.neutral.default)} !important;\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\t&:active:not([disabled], [aria-disabled='true'], [data-busy='true']) {\r\n\t\t\t\t\t\tcolor: ${$chooseColor(theme.colors.fg.brand.default)} !important;\r\n\t\t\t\t\t}\r\n\t\t\t\t`;\r\n\t\t\tdefault:\r\n\t\t\t\treturn '';\r\n\t\t}\r\n\t}}\r\n\r\n\t/* size specific styles, ButtonStyle.link is sized differently as per Figma */\r\n\t${({ $buttonStyle, $size, theme }) => {\r\n\t\tif ($buttonStyle === ButtonStyle.link) {\r\n\t\t\tswitch ($size) {\r\n\t\t\t\tcase ButtonSize.xs:\r\n\t\t\t\t\treturn css`\r\n\t\t\t\t\t\tgap: ${theme.spacing.xxs};\r\n\t\t\t\t\t\tmin-height: ${pxToRem(16)};\r\n\t\t\t\t\t\tpadding: 0;\r\n\t\t\t\t\t\tborder-radius: ${theme.borderRadius.xs};\r\n\t\t\t\t\t`;\r\n\t\t\t\tcase ButtonSize.sm:\r\n\t\t\t\t\treturn css`\r\n\t\t\t\t\t\tgap: ${theme.spacing.xxs};\r\n\t\t\t\t\t\tmin-height: ${pxToRem(20)};\r\n\t\t\t\t\t\tpadding: 0;\r\n\t\t\t\t\t\tborder-radius: ${theme.borderRadius.xs};\r\n\t\t\t\t\t`;\r\n\t\t\t\tcase ButtonSize.md:\r\n\t\t\t\t\treturn css`\r\n\t\t\t\t\t\tgap: ${theme.spacing.xxs};\r\n\t\t\t\t\t\tmin-height: ${pxToRem(24)};\r\n\t\t\t\t\t\tpadding: 0;\r\n\t\t\t\t\t\tborder-radius: ${theme.borderRadius.xs};\r\n\t\t\t\t\t`;\r\n\t\t\t\tcase ButtonSize.xl:\r\n\t\t\t\t\treturn css`\r\n\t\t\t\t\t\tgap: ${theme.spacing.xs};\r\n\t\t\t\t\t\tmin-height: ${pxToRem(28)};\r\n\t\t\t\t\t\tpadding: 0;\r\n\t\t\t\t\t\tborder-radius: ${theme.borderRadius.xs};\r\n\t\t\t\t\t`;\r\n\t\t\t\tcase ButtonSize.xxl:\r\n\t\t\t\t\tthrow new Error('ButtonStyle.link does not support ButtonSize.xxl');\r\n\t\t\t\tdefault:\r\n\t\t\t\t\treturn '';\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tswitch ($size) {\r\n\t\t\tcase ButtonSize.xs:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tgap: ${theme.spacing.xxs};\r\n\t\t\t\t\tmin-height: ${pxToRem(32)};\r\n\t\t\t\t\tpadding: ${theme.spacing.xxs} ${theme.spacing.xs};\r\n\t\t\t\t\tborder-radius: ${theme.borderRadius.xxs};\r\n\t\t\t\t`;\r\n\t\t\tcase ButtonSize.sm:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tgap: ${theme.spacing.xxs};\r\n\t\t\t\t\tmin-height: ${pxToRem(32)};\r\n\t\t\t\t\tpadding: ${theme.spacing.xxs} ${theme.spacing.xs};\r\n\t\t\t\t\tborder-radius: ${theme.borderRadius.xs};\r\n\t\t\t\t`;\r\n\t\t\tcase ButtonSize.md:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tgap: ${theme.spacing.xxs};\r\n\t\t\t\t\tmin-height: ${pxToRem(40)};\r\n\t\t\t\t\tpadding: ${theme.spacing.xs} ${theme.spacing.sm};\r\n\t\t\t\t\tborder-radius: ${theme.borderRadius.xs};\r\n\t\t\t\t`;\r\n\t\t\tcase ButtonSize.xl:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tgap: ${theme.spacing.xs};\r\n\t\t\t\t\tmin-height: ${pxToRem(48)};\r\n\t\t\t\t\tpadding: ${theme.spacing.sm};\r\n\t\t\t\t\tborder-radius: ${theme.borderRadius.xs};\r\n\t\t\t\t`;\r\n\t\t\tcase ButtonSize.xxl:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tgap: ${theme.spacing.sm};\r\n\t\t\t\t\tmin-height: ${pxToRem(56)};\r\n\t\t\t\t\tpadding: ${theme.spacing.md} ${theme.spacing.xl};\r\n\t\t\t\t\tborder-radius: ${theme.borderRadius.sm};\r\n\t\t\t\t`;\r\n\t\t\tdefault:\r\n\t\t\t\treturn '';\r\n\t\t}\r\n\t}}\r\n`;\r\n\r\nexport const IconWrapper = styled.div`\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\theight: 100%;\r\n`;\r\n\r\nexport const SpinnerWrapper = styled.span`\r\n\tdisplay: flex;\r\n\tanimation: rotation 1s linear infinite;\r\n\r\n\t@keyframes rotation {\r\n\t\t0% {\r\n\t\t\ttransform: rotate(0deg);\r\n\t\t}\r\n\r\n\t\t100% {\r\n\t\t\ttransform: rotate(360deg);\r\n\t\t}\r\n\t}\r\n`;\r\n","import { useMergeRefs } from '@floating-ui/react';\r\nimport {\r\n\ttype AriaAttributes,\r\n\ttype AriaRole,\r\n\ttype ElementType,\r\n\ttype HTMLAttributeAnchorTarget,\r\n\ttype MouseEvent,\r\n\ttype ReactNode,\r\n\ttype RefObject,\r\n\tuseCallback,\r\n\tuseEffect,\r\n\tuseMemo,\r\n\tuseRef,\r\n\tuseState,\r\n} from 'react';\r\n\r\nimport { IconSystem, IconSystemSize, IconSystemType } from '@/components/iconSystem';\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { type DesignSystemBaseProps, useDesignSystem, useDesignSystemMessages, useDesignSystemPropDefaults } from '@/contexts';\r\nimport { FontWeight } from '@/theme';\r\nimport { type SsrProps } from '@/types';\r\nimport { isRenderable } from '@/utils';\r\n\r\nimport { VisuallyHidden } from '../visuallyHidden';\r\nimport { ButtonContentAlign, ButtonSize, type ButtonStyle, ButtonType } from './types';\r\n\r\nimport { ButtonStyled, IconWrapper, SpinnerWrapper } from './Button.style';\r\n\r\nexport interface ButtonProps extends SsrProps, DesignSystemBaseProps, AriaAttributes {\r\n\tariaDisabled?: boolean;\r\n\tariaLabel?: string;\r\n\tas?: ElementType;\r\n\t/**\r\n\t * Whether the button is in a busy/loading state. Displays a spinner and `busyMessage` after `busyDelay` ms,\r\n\t * and disables interaction immediately.\r\n\t *\r\n\t * Accessibility handled as per https://adrianroselli.com/2021/01/multi-function-button.html\r\n\t */\r\n\tbusy?: boolean;\r\n\tbusyDelay?: number;\r\n\tbusyMessage?: ReactNode;\r\n\tbuttonStyle: ButtonStyle;\r\n\tchildren?: ReactNode;\r\n\tclassName?: string;\r\n\t/**\r\n\t * Alignment of button content (children, icons, busy loader, ...).\r\n\t * Only relevant when `fullWidth` is true.\r\n\t * @default ButtonContentAlign.center\r\n\t */\r\n\tcontentAlign?: ButtonContentAlign;\r\n\tdisabled?: boolean;\r\n\tdownload?: boolean | string;\r\n\tfullWidth?: boolean;\r\n\thref?: string;\r\n\thtmlRef?: RefObject<HTMLAnchorElement | HTMLButtonElement | null>;\r\n\ticonLeft?: ReactNode;\r\n\ticonRight?: ReactNode;\r\n\ticonSystemLeft?: IconSystemType;\r\n\ticonSystemRight?: IconSystemType;\r\n\t/** @deprecated Use `busy` instead. */\r\n\tisLoading?: boolean;\r\n\tonClick?: (event: MouseEvent<HTMLAnchorElement | HTMLButtonElement>) => void;\r\n\trel?: string;\r\n\trole?: AriaRole;\r\n\tsize?: ButtonSize;\r\n\ttarget?: HTMLAttributeAnchorTarget;\r\n\ttype: ButtonType;\r\n}\r\n\r\nexport const Button = (props: ButtonProps) => {\r\n\tconst {\r\n\t\t'aria-disabled': ariaDisabledAttribute,\r\n\t\t'aria-label': ariaLabelAttribute,\r\n\t\tariaDisabled: ariaDisabledProp,\r\n\t\tariaLabel: ariaLabelProp,\r\n\t\tas,\r\n\t\tbusy: busyProp,\r\n\t\tbusyDelay: busyDelayProp,\r\n\t\tbusyMessage: busyMessageProp,\r\n\t\tbuttonStyle,\r\n\t\tchildren,\r\n\t\tclassName,\r\n\t\tcolorScheme: colorSchemeProp, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\tcontentAlign = ButtonContentAlign.center,\r\n\t\tdisabled = false,\r\n\t\tdownload,\r\n\t\tfullWidth = false,\r\n\t\thref,\r\n\t\thtmlRef,\r\n\t\ticonLeft,\r\n\t\ticonRight,\r\n\t\ticonSystemLeft,\r\n\t\ticonSystemRight,\r\n\t\tisLoading,\r\n\t\tmediaType: mediaTypeProp, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\tonClick,\r\n\t\trel,\r\n\t\trole,\r\n\t\tsize = ButtonSize.md,\r\n\t\tsuppressHydrationWarning,\r\n\t\ttarget,\r\n\t\ttype,\r\n\t\t...otherProps\r\n\t} = props;\r\n\r\n\tconst { chooseColor, colorScheme, mediaType } = useDesignSystem(props);\r\n\tconst designSystemMessages = useDesignSystemMessages();\r\n\tconst designSystemPropDefaults = useDesignSystemPropDefaults();\r\n\r\n\tconst localRef = useRef<HTMLAnchorElement | HTMLButtonElement>(null);\r\n\tconst mergedRef = useMergeRefs([htmlRef, localRef]);\r\n\r\n\tconst busy = busyProp ?? isLoading ?? false;\r\n\tconst busyMessage =\r\n\t\tbusyMessageProp ?? (type === ButtonType.submit ? designSystemMessages.button.busySubmit : designSystemMessages.button.busyGeneric) ?? children;\r\n\tconst busyDelay = busyDelayProp ?? designSystemPropDefaults.button.busyDelay;\r\n\tconst [busyDelayed, setBusyDelayed] = useState(busy);\r\n\tconst busyTimeoutId = useRef<number | undefined>(undefined);\r\n\r\n\tuseEffect(() => {\r\n\t\tif (busy) {\r\n\t\t\tif (busyTimeoutId.current !== undefined) {\r\n\t\t\t\twindow.clearTimeout(busyTimeoutId.current);\r\n\t\t\t}\r\n\r\n\t\t\tbusyTimeoutId.current = window.setTimeout(() => {\r\n\t\t\t\tsetBusyDelayed(true);\r\n\t\t\t}, busyDelay);\r\n\t\t} else {\r\n\t\t\tif (busyTimeoutId.current !== undefined) {\r\n\t\t\t\twindow.clearTimeout(busyTimeoutId.current);\r\n\t\t\t\tbusyTimeoutId.current = undefined;\r\n\t\t\t}\r\n\r\n\t\t\tsetBusyDelayed(false);\r\n\t\t}\r\n\r\n\t\treturn () => {\r\n\t\t\tif (busyTimeoutId.current !== undefined) {\r\n\t\t\t\twindow.clearTimeout(busyTimeoutId.current);\r\n\t\t\t\tbusyTimeoutId.current = undefined;\r\n\t\t\t}\r\n\t\t};\r\n\t}, [busy, busyDelay]);\r\n\r\n\tconst typographyVariant = useMemo<TypographyVariant>(() => {\r\n\t\tswitch (size) {\r\n\t\t\tcase ButtonSize.xs:\r\n\t\t\t\treturn TypographyVariant.textXs;\r\n\t\t\tcase ButtonSize.sm:\r\n\t\t\tcase ButtonSize.md:\r\n\t\t\t\treturn TypographyVariant.textSm;\r\n\t\t\tcase ButtonSize.xl:\r\n\t\t\t\treturn TypographyVariant.textMd;\r\n\t\t\tcase ButtonSize.xxl:\r\n\t\t\t\treturn TypographyVariant.textLg;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected enum value of ButtonSize in button.tsx');\r\n\t\t}\r\n\t}, [size]);\r\n\r\n\tconst iconSystemSize = useMemo<IconSystemSize>(() => {\r\n\t\tswitch (size) {\r\n\t\t\tcase ButtonSize.xs:\r\n\t\t\t\treturn IconSystemSize.small;\r\n\t\t\tcase ButtonSize.sm:\r\n\t\t\tcase ButtonSize.md:\r\n\t\t\tcase ButtonSize.xl:\r\n\t\t\tcase ButtonSize.xxl:\r\n\t\t\t\treturn IconSystemSize.big;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected enum value of ButtonSize in button.tsx');\r\n\t\t}\r\n\t}, [size]);\r\n\r\n\tconst handleClick = useCallback(\r\n\t\t(event: MouseEvent<HTMLAnchorElement | HTMLButtonElement>) => {\r\n\t\t\tif (busy || ariaDisabledProp === true || ariaDisabledAttribute === true || ariaDisabledAttribute === 'true') {\r\n\t\t\t\tevent.preventDefault();\r\n\t\t\t} else {\r\n\t\t\t\tonClick?.(event);\r\n\t\t\t}\r\n\t\t},\r\n\t\t[ariaDisabledAttribute, ariaDisabledProp, busy, onClick],\r\n\t);\r\n\r\n\treturn (\r\n\t\t<>\r\n\t\t\t<VisuallyHidden role=\"status\">{busyDelayed && busyMessage}</VisuallyHidden>\r\n\r\n\t\t\t<ButtonStyled\r\n\t\t\t\t$buttonStyle={buttonStyle}\r\n\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t$contentAlign={contentAlign}\r\n\t\t\t\t$disabled={disabled}\r\n\t\t\t\t$fullWidth={fullWidth}\r\n\t\t\t\t$size={size}\r\n\t\t\t\t$type={type}\r\n\t\t\t\taria-disabled={ariaDisabledAttribute ?? ariaDisabledProp}\r\n\t\t\t\taria-label={ariaLabelAttribute ?? ariaLabelProp}\r\n\t\t\t\tas={as ?? (type === ButtonType.anchor ? 'a' : undefined)}\r\n\t\t\t\tclassName={className}\r\n\t\t\t\tdata-busy={busy}\r\n\t\t\t\tdisabled={disabled}\r\n\t\t\t\tdownload={download}\r\n\t\t\t\thref={href}\r\n\t\t\t\tref={mergedRef}\r\n\t\t\t\trel={rel}\r\n\t\t\t\trole={role}\r\n\t\t\t\tsuppressHydrationWarning={suppressHydrationWarning}\r\n\t\t\t\ttarget={target}\r\n\t\t\t\ttype={type === ButtonType.button || type === ButtonType.submit || type === ButtonType.reset ? type : undefined}\r\n\t\t\t\tonClick={handleClick}\r\n\t\t\t\t{...otherProps}\r\n\t\t\t>\r\n\t\t\t\t{busyDelayed && (\r\n\t\t\t\t\t<SpinnerWrapper>\r\n\t\t\t\t\t\t<IconSystem\r\n\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\tsize={IconSystemSize.big}\r\n\t\t\t\t\t\t\tstroke=\"currentColor\"\r\n\t\t\t\t\t\t\ttype={IconSystemType.spinner}\r\n\t\t\t\t\t\t/>\r\n\t\t\t\t\t</SpinnerWrapper>\r\n\t\t\t\t)}\r\n\t\t\t\t{iconLeft !== undefined && <IconWrapper>{iconLeft}</IconWrapper>}\r\n\t\t\t\t{iconSystemLeft !== undefined && (\r\n\t\t\t\t\t<IconSystem\r\n\t\t\t\t\t\tariaHidden={true}\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\tsize={iconSystemSize}\r\n\t\t\t\t\t\tstroke=\"currentColor\"\r\n\t\t\t\t\t\ttype={iconSystemLeft}\r\n\t\t\t\t\t/>\r\n\t\t\t\t)}\r\n\t\t\t\t{isRenderable(children) && (\r\n\t\t\t\t\t<Typography\r\n\t\t\t\t\t\tcolor={'inherit'}\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\tmediaType={mediaType}\r\n\t\t\t\t\t\tvariant={typographyVariant}\r\n\t\t\t\t\t\tweight={FontWeight.medium500}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t{busyDelayed ? busyMessage : children}\r\n\t\t\t\t\t</Typography>\r\n\t\t\t\t)}\r\n\t\t\t\t{iconRight !== undefined && <IconWrapper>{iconRight}</IconWrapper>}\r\n\t\t\t\t{iconSystemRight !== undefined && (\r\n\t\t\t\t\t<IconSystem\r\n\t\t\t\t\t\tariaHidden={true}\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\tsize={iconSystemSize}\r\n\t\t\t\t\t\tstroke=\"currentColor\"\r\n\t\t\t\t\t\ttype={iconSystemRight}\r\n\t\t\t\t\t/>\r\n\t\t\t\t)}\r\n\t\t\t</ButtonStyled>\r\n\t\t</>\r\n\t);\r\n};\r\n","export enum ButtonsLayoutAlign {\r\n\tcenter = 'center',\r\n\tend = 'end',\r\n\t/* When set to Direction: column, spaceBetween works like center */\r\n\tspaceBetween = 'spaceBetween',\r\n\tstart = 'start',\r\n\tstretch = 'stretch',\r\n}\r\n\r\nexport enum ButtonsLayoutDirection {\r\n\tcolumn = 'column',\r\n\tcolumnReverse = 'columnReverse',\r\n\trow = 'row',\r\n\trowReverse = 'rowReverse',\r\n}\r\n","import { css } from '@emotion/react';\r\n\r\nimport { resolveSpacingValue, type Spacing } from '@/theme';\r\nimport { type FlexWrap, resolveFlexWrapValue } from '@/theme/flexWrap';\r\nimport { styled } from '@/utils';\r\n\r\nimport { ButtonsLayoutAlign, ButtonsLayoutDirection } from './types';\r\n\r\nexport interface ButtonsLayoutStyledProps {\r\n\t$align: ButtonsLayoutAlign;\r\n\t$direction: ButtonsLayoutDirection;\r\n\t$gap: Spacing;\r\n\t$wrap: FlexWrap;\r\n}\r\n\r\nexport const ButtonsLayoutStyled = styled.div<ButtonsLayoutStyledProps>`\r\n\tdisplay: flex;\r\n\tflex-wrap: ${({ $wrap }) => resolveFlexWrapValue($wrap)};\r\n\tgap: ${({ $gap, theme }) => resolveSpacingValue(theme, $gap)};\r\n\twidth: 100%;\r\n\r\n\t${({ $direction }) => {\r\n\t\tswitch ($direction) {\r\n\t\t\tcase ButtonsLayoutDirection.row:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tflex-direction: row;\r\n\t\t\t\t\talign-items: center;\r\n\t\t\t\t`;\r\n\t\t\tcase ButtonsLayoutDirection.rowReverse:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tflex-direction: row-reverse;\r\n\t\t\t\t\talign-items: center;\r\n\t\t\t\t`;\r\n\t\t\tcase ButtonsLayoutDirection.column:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tflex-direction: column;\r\n\t\t\t\t`;\r\n\t\t\tcase ButtonsLayoutDirection.columnReverse:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tflex-direction: column-reverse;\r\n\t\t\t\t`;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('Unexpected enum values ButtonsLayoutDirection in ButtonsLayout.style.ts');\r\n\t\t}\r\n\t}}\r\n\r\n\t${({ $align, $direction }) => {\r\n\t\tif (($direction === ButtonsLayoutDirection.column || $direction === ButtonsLayoutDirection.columnReverse) && $align === ButtonsLayoutAlign.stretch) {\r\n\t\t\treturn css`\r\n\t\t\t\talign-items: stretch;\r\n\t\t\t`;\r\n\t\t}\r\n\t\tif (($direction === ButtonsLayoutDirection.column || $direction === ButtonsLayoutDirection.columnReverse) && $align === ButtonsLayoutAlign.center) {\r\n\t\t\treturn css`\r\n\t\t\t\talign-items: center;\r\n\t\t\t`;\r\n\t\t}\r\n\t\tif (($direction === ButtonsLayoutDirection.column || $direction === ButtonsLayoutDirection.columnReverse) && $align === ButtonsLayoutAlign.spaceBetween) {\r\n\t\t\treturn css`\r\n\t\t\t\talign-items: center;\r\n\t\t\t`;\r\n\t\t}\r\n\t\tif (($direction === ButtonsLayoutDirection.column || $direction === ButtonsLayoutDirection.columnReverse) && $align === ButtonsLayoutAlign.start) {\r\n\t\t\treturn css`\r\n\t\t\t\talign-items: start;\r\n\t\t\t`;\r\n\t\t}\r\n\t\tif (($direction === ButtonsLayoutDirection.column || $direction === ButtonsLayoutDirection.columnReverse) && $align === ButtonsLayoutAlign.end) {\r\n\t\t\treturn css`\r\n\t\t\t\talign-items: end;\r\n\t\t\t`;\r\n\t\t}\r\n\r\n\t\tif (($direction === ButtonsLayoutDirection.row || $direction === ButtonsLayoutDirection.rowReverse) && $align === ButtonsLayoutAlign.stretch) {\r\n\t\t\treturn css`\r\n\t\t\t\ta,\r\n\t\t\t\tbutton {\r\n\t\t\t\t\tflex-grow: 1;\r\n\t\t\t\t\tflex-basis: 0;\r\n\t\t\t\t}\r\n\t\t\t`;\r\n\t\t}\r\n\t\tif (($direction === ButtonsLayoutDirection.row || $direction === ButtonsLayoutDirection.rowReverse) && $align === ButtonsLayoutAlign.center) {\r\n\t\t\treturn css`\r\n\t\t\t\tjustify-content: center;\r\n\t\t\t`;\r\n\t\t}\r\n\t\tif (($direction === ButtonsLayoutDirection.row || $direction === ButtonsLayoutDirection.rowReverse) && $align === ButtonsLayoutAlign.spaceBetween) {\r\n\t\t\treturn css`\r\n\t\t\t\tjustify-content: space-between;\r\n\t\t\t`;\r\n\t\t}\r\n\t\tif (($direction === ButtonsLayoutDirection.row || $direction === ButtonsLayoutDirection.rowReverse) && $align === ButtonsLayoutAlign.start) {\r\n\t\t\treturn css`\r\n\t\t\t\tjustify-content: start;\r\n\t\t\t`;\r\n\t\t}\r\n\t\tif (($direction === ButtonsLayoutDirection.row || $direction === ButtonsLayoutDirection.rowReverse) && $align === ButtonsLayoutAlign.end) {\r\n\t\t\treturn css`\r\n\t\t\t\tjustify-content: end;\r\n\t\t\t`;\r\n\t\t}\r\n\t}};\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { type ReactElement } from 'react';\r\n\r\nimport { Typography, TypographyTextAlign, TypographyVariant } from '@/components/typography';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\n\r\nexport interface CalculatorResultDescriptionProps extends DesignSystemBaseProps {\r\n\tdescription?: ReactElement | string;\r\n}\r\n\r\nexport const CalculatorResultDescription = (props: CalculatorResultDescriptionProps) => {\r\n\tconst { description } = props;\r\n\r\n\tconst { colorScheme } = useDesignSystem(props);\r\n\r\n\tconst theme = useTheme();\r\n\r\n\treturn (\r\n\t\t<Typography\r\n\t\t\tcolor={theme.colors.fg.neutral.subtle}\r\n\t\t\tcolorScheme={colorScheme}\r\n\t\t\tfullWidth={true}\r\n\t\t\ttextAlign={TypographyTextAlign.center}\r\n\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t>\r\n\t\t\t{description}\r\n\t\t</Typography>\r\n\t);\r\n};\r\n","export const getOrCreateModalContainer = (modalRootElement: Element | string): Element => {\r\n\tif (modalRootElement instanceof Element) {\r\n\t\treturn modalRootElement;\r\n\t}\r\n\r\n\tlet modalContainer = window.document.getElementById(modalRootElement);\r\n\r\n\tif (modalContainer === null) {\r\n\t\tmodalContainer = createModalContainer(modalRootElement);\r\n\t\tconst modalCreatedEvent = new CustomEvent('react.modal.created');\r\n\t\twindow.document.dispatchEvent(modalCreatedEvent);\r\n\t}\r\n\r\n\treturn modalContainer;\r\n};\r\n\r\nconst createModalContainer = (modalContainerId: string) => {\r\n\tconst modalContainer = document.createElement('div');\r\n\r\n\tmodalContainer.id = modalContainerId;\r\n\r\n\twindow.document.body.appendChild(modalContainer);\r\n\r\n\treturn modalContainer;\r\n};\r\n\r\nexport const queryInitialFocusElement = (scope: Element): HTMLElement | null => {\r\n\tconst selectors = [\r\n\t\t'a[href]',\r\n\t\t'area[href]',\r\n\t\t// NOTE: We never want to focus the close button first, we'd rather just focus the modal itself.\r\n\t\t'button:not([disabled]):not([data-closebutton=\"true\"])',\r\n\t\t'textarea:not([disabled])',\r\n\t\t'input:not([disabled])',\r\n\t\t'select:not([disabled])',\r\n\t\t// NOTE: The `Modal` itself is actually focusable, but we treat it as the lowest priority.\r\n\t\t'[tabindex]:not([aria-modal=\"true\"])',\r\n\t];\r\n\r\n\treturn scope.querySelector<HTMLElement>(selectors.join(',')) ?? scope.querySelector<HTMLElement>('[aria-modal=\"true\"]');\r\n};\r\n\r\nexport const queryFocusableElements = (scope: Element): HTMLElement[] => {\r\n\tconst selectors = [\r\n\t\t'a[href]',\r\n\t\t'area[href]',\r\n\t\t'button:not([disabled])',\r\n\t\t'textarea:not([disabled])',\r\n\t\t'input:not([disabled])',\r\n\t\t'select:not([disabled])',\r\n\t\t'[tabindex]:not([tabindex=\"-1\"])',\r\n\t];\r\n\r\n\tconst focusableElements = scope.querySelectorAll<HTMLElement>(selectors.join(','));\r\n\r\n\treturn [...focusableElements];\r\n};\r\n","import { styled, type ChooseColor } from '@/utils';\r\n\r\nexport const modalCloseButtonDimensions = '1.5rem';\r\n\r\ninterface ButtonStyledProps {\r\n\t$chooseColor: ChooseColor;\r\n}\r\n\r\nexport const ButtonStyled = styled.button<ButtonStyledProps>`\r\n\tbox-sizing: content-box;\r\n\tdisplay: flex;\r\n\twidth: ${modalCloseButtonDimensions};\r\n\theight: ${modalCloseButtonDimensions};\r\n\tpadding: ${({ theme }) => theme.spacing.xs};\r\n\tline-height: normal;\r\n\tcursor: pointer;\r\n\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.surface.risen)};\r\n\tborder-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.border.neutral.subtle)};\r\n\tborder-style: solid;\r\n\tborder-width: 1px;\r\n\tborder-radius: ${({ theme }) => theme.borderRadius.xs};\r\n\r\n\t&:focus-visible {\r\n\t\toutline-width: 3px;\r\n\t\toutline-style: solid;\r\n\t\toutline-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.focus)};\r\n\t\toutline-offset: 2px;\r\n\t}\r\n`;\r\n","import { IconSystem, IconSystemSize, IconSystemType } from '@/components/iconSystem';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\n\r\nimport { ButtonStyled } from './ModalCloseButton.style';\r\n\r\nexport interface ModalCloseButtonProps extends DesignSystemBaseProps {\r\n\tariaLabel?: string;\r\n\tonClick: () => void;\r\n}\r\n\r\nexport const ModalCloseButton = (props: ModalCloseButtonProps) => {\r\n\tconst { ariaLabel, onClick } = props;\r\n\r\n\tconst { chooseColor, colorScheme } = useDesignSystem(props);\r\n\r\n\treturn (\r\n\t\t<ButtonStyled\r\n\t\t\t$chooseColor={chooseColor}\r\n\t\t\taria-label={ariaLabel}\r\n\t\t\tdata-closebutton={true}\r\n\t\t\ttype={'button'}\r\n\t\t\tonClick={onClick}\r\n\t\t>\r\n\t\t\t<IconSystem\r\n\t\t\t\tariaHidden={true}\r\n\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\tsize={IconSystemSize.big}\r\n\t\t\t\ttype={IconSystemType.close}\r\n\t\t\t/>\r\n\t\t</ButtonStyled>\r\n\t);\r\n};\r\n","import { styled, type ChooseColor } from '@/utils';\r\n\r\ninterface OverlayProps {\r\n\t$chooseColor: ChooseColor;\r\n}\r\n\r\nexport const Overlay = styled.div<OverlayProps>`\r\n\tposition: fixed;\r\n\ttop: 0;\r\n\tright: 0;\r\n\tbottom: 0;\r\n\tleft: 0;\r\n\tz-index: ${(props) => props.theme.zIndex.modalBackdrop};\r\n\toverflow-y: scroll;\r\n\toutline: none;\r\n\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.surface.overlay)};\r\n\tbackdrop-filter: blur(4px);\r\n\t-webkit-overflow-scrolling: touch;\r\n`;\r\n","import { type MouseEvent } from 'react';\r\n\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\n\r\nimport { Overlay } from './ModalOverlay.style';\r\n\r\nexport interface ModalOverlayProps extends DesignSystemBaseProps {\r\n\tonClick: (event: MouseEvent<HTMLElement>) => void;\r\n}\r\n\r\nexport const ModalOverlay = (props: ModalOverlayProps) => {\r\n\tconst { onClick } = props;\r\n\r\n\tconst { chooseColor } = useDesignSystem(props);\r\n\r\n\treturn (\r\n\t\t<Overlay\r\n\t\t\t$chooseColor={chooseColor}\r\n\t\t\tonClick={onClick}\r\n\t\t/>\r\n\t);\r\n};\r\n","export type ModalOnClose = (reasonForClosing: ReasonForClosing) => void;\r\n\r\nexport enum ModalWidthType {\r\n\tdefault = 'default',\r\n\tnarrow = 'narrow',\r\n\tnarrowOnDesktopAndTablet = 'narrowOnDesktopAndTablet',\r\n}\r\n\r\nexport enum ModalVerticalPosition {\r\n\tcenterOnTablet = 'centerOnTablet',\r\n\tdefault = 'default',\r\n}\r\n\r\nexport enum ReasonForClosing {\r\n\tcloseButton = 'closeButton',\r\n\tesc = 'esc',\r\n\toverlay = 'overlay',\r\n}\r\n","import { css } from '@emotion/react';\r\n\r\nimport { styled, type ChooseColor } from '@/utils';\r\n\r\nimport { ModalVerticalPosition, ModalWidthType } from './types';\r\n\r\nimport { modalCloseButtonDimensions } from '@/components/modal/modalCloseButton/ModalCloseButton.style';\r\n\r\n// this is for hack to see the shadows of element that is at the bottom in modal (for example Button). And at the same time to make scrollbar (if is visible) have a visually acceptable position.\r\nconst verticalPaddingOffset = '8px';\r\n\r\ninterface WrapperProps {\r\n\t$chooseColor: ChooseColor;\r\n\t$verticalPosition?: ModalVerticalPosition;\r\n\t$widthType: ModalWidthType;\r\n\t$withoutPadding?: boolean;\r\n}\r\n\r\nexport const Wrapper = styled.div<WrapperProps>`\r\n\tposition: fixed;\r\n\tright: 0;\r\n\tbottom: 0;\r\n\tleft: 0;\r\n\tz-index: ${(props) => props.theme.zIndex.modal};\r\n\tbox-sizing: border-box;\r\n\tdisplay: flex;\r\n\twidth: 100%;\r\n\tmax-height: calc(95dvh - (${modalCloseButtonDimensions} / 2));\r\n\tpadding-top: ${({ $withoutPadding, theme }) => ($withoutPadding === true ? 0 : `calc(${theme.spacing.xl} - ${verticalPaddingOffset})`)};\r\n\tpadding-bottom: ${({ $withoutPadding, theme }) => ($withoutPadding === true ? 0 : `calc(${theme.spacing.xl} - ${verticalPaddingOffset})`)};\r\n\toverflow: visible;\r\n\toutline: 0;\r\n\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.surface.risen)};\r\n\tborder-width: 0;\r\n\tborder-radius: ${({ theme }) => theme.borderRadius.lg};\r\n\tbox-shadow: ${({ theme }) => theme.shadow.box.md};\r\n\r\n\t@media (min-width: ${({ theme }) => theme.breakpoints.lg}) {\r\n\t\ttop: 50%;\r\n\t\tbottom: auto;\r\n\t\tmargin: 0 auto;\r\n\t\ttransform: translate(0, -50%);\r\n\r\n\t\t${({ $widthType }) => {\r\n\t\t\tswitch ($widthType) {\r\n\t\t\t\tcase ModalWidthType.default:\r\n\t\t\t\t\treturn css`\r\n\t\t\t\t\t\tmax-width: 60rem;\r\n\t\t\t\t\t`;\r\n\t\t\t\tcase ModalWidthType.narrow:\r\n\t\t\t\tcase ModalWidthType.narrowOnDesktopAndTablet:\r\n\t\t\t\t\treturn css`\r\n\t\t\t\t\t\tmax-width: 36rem;\r\n\t\t\t\t\t`;\r\n\t\t\t\tdefault:\r\n\t\t\t\t\tthrow new Error('unexpected enum values ModalWidthType in modal.style.ts 1');\r\n\t\t\t}\r\n\t\t}}\r\n\t}\r\n\r\n\t@media (min-width: ${({ theme }) => theme.breakpoints.md}) {\r\n\t\t${({ $widthType }) => {\r\n\t\t\tswitch ($widthType) {\r\n\t\t\t\tcase ModalWidthType.default:\r\n\t\t\t\tcase ModalWidthType.narrow:\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase ModalWidthType.narrowOnDesktopAndTablet:\r\n\t\t\t\t\treturn css`\r\n\t\t\t\t\t\tmax-width: 36rem;\r\n\t\t\t\t\t\tmargin: 0 auto;\r\n\t\t\t\t\t`;\r\n\t\t\t\tdefault:\r\n\t\t\t\t\tthrow new Error('unexpected enum values ModalWidthType in modal.style.ts 2');\r\n\t\t\t}\r\n\t\t}};\r\n\r\n\t\t${({ $verticalPosition }) => {\r\n\t\t\tswitch ($verticalPosition) {\r\n\t\t\t\tcase ModalVerticalPosition.default:\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase ModalVerticalPosition.centerOnTablet:\r\n\t\t\t\t\treturn css`\r\n\t\t\t\t\t\ttop: 50%;\r\n\t\t\t\t\t\tbottom: auto;\r\n\t\t\t\t\t\ttransform: translate(0, -50%);\r\n\t\t\t\t\t`;\r\n\t\t\t\tdefault:\r\n\t\t\t\t\tthrow new Error('unexpected enum values ModalVerticalPosition in modal.style.ts');\r\n\t\t\t}\r\n\t\t}};\r\n\t}\r\n`;\r\n\r\ninterface ModalBoxProps {\r\n\t$withoutPadding?: boolean;\r\n}\r\n\r\nexport const Box = styled.div<ModalBoxProps>`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\trow-gap: ${({ theme }) => theme.spacing.lg};\r\n\twidth: 100%;\r\n\tpadding-top: ${({ $withoutPadding }) => ($withoutPadding === true ? 0 : verticalPaddingOffset)};\r\n\tpadding-right: ${({ $withoutPadding, theme }) => ($withoutPadding === true ? 0 : theme.spacing.lg)};\r\n\tpadding-bottom: ${({ $withoutPadding }) => ($withoutPadding === true ? 0 : verticalPaddingOffset)};\r\n\tpadding-left: ${({ $withoutPadding, theme }) => ($withoutPadding === true ? 0 : theme.spacing.lg)};\r\n\toverflow: auto;\r\n\r\n\t@media (min-width: ${({ theme }) => theme.breakpoints.lg}) {\r\n\t\tpadding-right: ${({ $withoutPadding, theme }) => ($withoutPadding === true ? 0 : theme.spacing.xl)};\r\n\t\tpadding-left: ${({ $withoutPadding, theme }) => ($withoutPadding === true ? 0 : theme.spacing.xl)};\r\n\t}\r\n`;\r\n\r\nexport const CloseButtonWrapper = styled.div`\r\n\tposition: absolute;\r\n\ttop: 0;\r\n\tright: 0;\r\n\tz-index: 1;\r\n\ttransform: translate(-50%, -50%);\r\n\r\n\t@media (min-width: ${({ theme }) => theme.breakpoints.lg}) {\r\n\t\ttransform: translate(36%, -36%);\r\n\t}\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { type ReactNode, useId } from 'react';\r\nimport { createPortal } from 'react-dom';\r\n\r\nimport { getOrCreateModalContainer } from '@/components/modal/Modal.domFunctions';\r\nimport { Typography, TypographyTextAlign, TypographyVariant } from '@/components/typography';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { isRenderable } from '@/utils';\r\n\r\nimport { ModalCloseButton } from './modalCloseButton/ModalCloseButton';\r\nimport { ModalOverlay } from './modalOverlay/ModalOverlay';\r\nimport { type ModalOnClose, ModalVerticalPosition, ModalWidthType, ReasonForClosing } from './types';\r\nimport { useModalFocusTrap } from './useModalFocusTrap';\r\n\r\nimport { Box, CloseButtonWrapper, Wrapper } from './Modal.style';\r\n\r\nconst defaultModalRootElement = 'react-modal-container';\r\n\r\nexport interface ModalProps extends DesignSystemBaseProps {\r\n\tchildren: ReactNode;\r\n\tclassName?: string;\r\n\tcloseButtonAriaLabel?: string;\r\n\thideCloseButton: boolean;\r\n\tid?: string;\r\n\tisOpen: boolean;\r\n\tonClose: ModalOnClose;\r\n\t/** When a string is passed, `Modal` will search for an element with such `id`, otherwise create one. */\r\n\trootElement?: Element | string;\r\n\ttitle?: ReactNode;\r\n\tverticalPosition?: ModalVerticalPosition;\r\n\twidthType?: ModalWidthType;\r\n\twithoutPadding?: boolean;\r\n}\r\n\r\nexport const Modal = (props: ModalProps) => {\r\n\tconst {\r\n\t\tchildren,\r\n\t\tclassName,\r\n\t\tcloseButtonAriaLabel,\r\n\t\thideCloseButton,\r\n\t\tid: idProp,\r\n\t\tisOpen,\r\n\t\tonClose,\r\n\t\trootElement: modalRootElementProp = defaultModalRootElement,\r\n\t\ttitle,\r\n\t\tverticalPosition = ModalVerticalPosition.default,\r\n\t\twidthType = ModalWidthType.default,\r\n\t\twithoutPadding,\r\n\t} = props;\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor, colorScheme } = useDesignSystem(props);\r\n\r\n\tconst modalRootElement = getOrCreateModalContainer(modalRootElementProp);\r\n\r\n\tconst generatedId = useId();\r\n\tconst wrapperId = idProp ?? generatedId;\r\n\tconst titleId = `${wrapperId}-title`;\r\n\r\n\tuseModalFocusTrap({\r\n\t\tonClose: onClose,\r\n\t\tisOpen: isOpen,\r\n\t\tmodalRootElement: modalRootElement,\r\n\t});\r\n\r\n\tif (!isOpen) {\r\n\t\treturn null;\r\n\t}\r\n\r\n\treturn createPortal(\r\n\t\t<>\r\n\t\t\t<ModalOverlay\r\n\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\tonClick={() => {\r\n\t\t\t\t\tonClose(ReasonForClosing.overlay);\r\n\t\t\t\t}}\r\n\t\t\t/>\r\n\r\n\t\t\t<Wrapper\r\n\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t$verticalPosition={verticalPosition}\r\n\t\t\t\t$widthType={widthType}\r\n\t\t\t\t$withoutPadding={withoutPadding}\r\n\t\t\t\taria-labelledby={isRenderable(title) ? titleId : undefined}\r\n\t\t\t\taria-modal={true}\r\n\t\t\t\tclassName={className}\r\n\t\t\t\tid={wrapperId}\r\n\t\t\t\trole=\"dialog\"\r\n\t\t\t\ttabIndex={-1}\r\n\t\t\t>\r\n\t\t\t\t<Box $withoutPadding={withoutPadding}>\r\n\t\t\t\t\t{isRenderable(title) && (\r\n\t\t\t\t\t\t<div>\r\n\t\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\t\tas=\"h2\"\r\n\t\t\t\t\t\t\t\tcolor={theme.colors.fg.neutral.default}\r\n\t\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\t\tid={titleId}\r\n\t\t\t\t\t\t\t\ttextAlign={TypographyTextAlign.left}\r\n\t\t\t\t\t\t\t\tvariant={TypographyVariant.h3}\r\n\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t{title}\r\n\t\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t)}\r\n\t\t\t\t\t<div>\r\n\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\tcolor={theme.colors.fg.neutral.subtle}\r\n\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\tvariant={TypographyVariant.textMd}\r\n\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t{children}\r\n\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</Box>\r\n\t\t\t\t{!hideCloseButton && (\r\n\t\t\t\t\t<CloseButtonWrapper>\r\n\t\t\t\t\t\t<ModalCloseButton\r\n\t\t\t\t\t\t\tariaLabel={closeButtonAriaLabel}\r\n\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\tonClick={() => {\r\n\t\t\t\t\t\t\t\tonClose(ReasonForClosing.closeButton);\r\n\t\t\t\t\t\t\t}}\r\n\t\t\t\t\t\t/>\r\n\t\t\t\t\t</CloseButtonWrapper>\r\n\t\t\t\t)}\r\n\t\t\t</Wrapper>\r\n\t\t</>,\r\n\t\tmodalRootElement,\r\n\t);\r\n};\r\n","import { useEffect, useRef } from 'react';\r\n\r\nimport { queryFocusableElements, queryInitialFocusElement } from './Modal.domFunctions';\r\nimport { type ModalOnClose, ReasonForClosing } from './types';\r\n\r\ninterface UseModalFocusTrapParam {\r\n\tisOpen: boolean;\r\n\tmodalRootElement: Element;\r\n\tonClose: ModalOnClose;\r\n}\r\n\r\nexport const useModalFocusTrap = (param: UseModalFocusTrapParam) => {\r\n\tconst { isOpen, modalRootElement, onClose } = param;\r\n\r\n\t// before the modal window was opened\r\n\tconst previousActiveElementRef = useRef<HTMLElement | null>(null);\r\n\r\n\tuseEffect(() => {\r\n\t\tif (!isOpen) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tpreviousActiveElementRef.current = document.activeElement as HTMLElement | null;\r\n\r\n\t\tconst initialFocusElement = queryInitialFocusElement(modalRootElement);\r\n\t\tconst focusableElements = queryFocusableElements(modalRootElement);\r\n\t\tconst firstFocusableElement = focusableElements.at(0);\r\n\t\tconst lastFocusableElement = focusableElements.at(-1);\r\n\r\n\t\tconst handleKeyDown = (event: KeyboardEvent): void => {\r\n\t\t\tswitch (event.key) {\r\n\t\t\t\tcase 'Escape':\r\n\t\t\t\t\tonClose(ReasonForClosing.esc);\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase 'Tab':\r\n\t\t\t\t\t// NOTE: The current focus may be e.g. a paragraph of text, or even the modal wrapper itself.\r\n\t\t\t\t\tif (!event.shiftKey && (document.activeElement === lastFocusableElement || !focusableElements.includes(document.activeElement as HTMLElement))) {\r\n\t\t\t\t\t\tevent.preventDefault();\r\n\t\t\t\t\t\tfirstFocusableElement?.focus();\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\tif (event.shiftKey && (document.activeElement === firstFocusableElement || !focusableElements.includes(document.activeElement as HTMLElement))) {\r\n\t\t\t\t\t\tevent.preventDefault();\r\n\t\t\t\t\t\tlastFocusableElement?.focus();\r\n\t\t\t\t\t}\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tdefault:\r\n\t\t\t\t\tbreak;\r\n\t\t\t}\r\n\t\t};\r\n\r\n\t\tinitialFocusElement?.focus();\r\n\t\tdocument.addEventListener('keydown', handleKeyDown);\r\n\r\n\t\treturn () => {\r\n\t\t\tpreviousActiveElementRef.current?.focus();\r\n\t\t\tdocument.removeEventListener('keydown', handleKeyDown);\r\n\t\t};\r\n\t}, [isOpen, modalRootElement, onClose]);\r\n};\r\n","import { styled } from '@/utils';\r\n\r\nexport const ModalTextWrapper = styled.div`\r\n\tdisplay: flex;\r\n\tflex-direction: row;\r\n\tjustify-content: center;\r\n`;\r\n\r\nexport const ModalTextWrapperIn = styled.span`\r\n\tposition: relative;\r\n\tdisplay: inline;\r\n\tflex-direction: row;\r\n\tjustify-content: center;\r\n`;\r\n\r\nexport const ModalTextIconWrapper = styled.span`\r\n\tposition: relative;\r\n\tdisplay: inline-block;\r\n\twidth: 24px;\r\n`;\r\n\r\nexport const ModalTextIconWrapperIn = styled.span`\r\n\tposition: absolute;\r\n\tbottom: -11px;\r\n\tleft: 0;\r\n`;\r\n","import { useBoolean } from 'usehooks-ts';\r\n\r\nimport { type CalculatorResultModalDescriptor } from '@/components/calculatorResult/types';\r\nimport { IconSystem, IconSystemSize, IconSystemType } from '@/components/iconSystem';\r\nimport { Modal } from '@/components/modal';\r\nimport { SpanButton } from '@/components/spanButton';\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { FontWeight } from '@/theme';\r\nimport { ColorScheme } from '@/types';\r\n\r\nimport { ModalTextIconWrapper, ModalTextIconWrapperIn, ModalTextWrapper, ModalTextWrapperIn } from './CalculatorResultModal.style';\r\n\r\nexport interface CalculatorResultModalProps extends DesignSystemBaseProps, CalculatorResultModalDescriptor {}\r\n\r\nexport const CalculatorResultModal = (props: CalculatorResultModalProps) => {\r\n\tconst { content, modalCloseButtonAriaLabel, triggerText } = props;\r\n\r\n\tconst { colorScheme, mediaType } = useDesignSystem(props);\r\n\r\n\tconst { setFalse: closeModal, setTrue: openModal, value: isModalOpen } = useBoolean(false);\r\n\r\n\treturn (\r\n\t\t<>\r\n\t\t\t<Modal\r\n\t\t\t\tcloseButtonAriaLabel={modalCloseButtonAriaLabel}\r\n\t\t\t\tcolorScheme={ColorScheme.light}\r\n\t\t\t\thideCloseButton={false}\r\n\t\t\t\tisOpen={isModalOpen}\r\n\t\t\t\tmediaType={mediaType}\r\n\t\t\t\tonClose={closeModal}\r\n\t\t\t>\r\n\t\t\t\t{content}\r\n\t\t\t</Modal>\r\n\t\t\t<ModalTextWrapper>\r\n\t\t\t\t<ModalTextWrapperIn>\r\n\t\t\t\t\t<SpanButton onClick={openModal}>\r\n\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\t\tweight={FontWeight.medium500}\r\n\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t{triggerText}\r\n\t\t\t\t\t\t\t<ModalTextIconWrapper>\r\n\t\t\t\t\t\t\t\t<ModalTextIconWrapperIn>\r\n\t\t\t\t\t\t\t\t\t<IconSystem\r\n\t\t\t\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\t\t\t\tsize={IconSystemSize.big}\r\n\t\t\t\t\t\t\t\t\t\ttype={IconSystemType.chevronRight}\r\n\t\t\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t\t\t</ModalTextIconWrapperIn>\r\n\t\t\t\t\t\t\t</ModalTextIconWrapper>\r\n\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t</SpanButton>\r\n\t\t\t\t</ModalTextWrapperIn>\r\n\t\t\t</ModalTextWrapper>\r\n\t\t</>\r\n\t);\r\n};\r\n","import { type ReactElement } from 'react';\r\n\r\nimport { type TooltipInfoDescriptor } from '@/components/tooltip';\r\n\r\nexport interface CalculatorResultHeader {\r\n\tbottom?: ReactElement | string | undefined;\r\n\tmain?: ReactElement | string | undefined;\r\n\ttop?: ReactElement | string | undefined;\r\n\t/** Visually hidden text for screen readers, providing additional info, such as the availability of help under tooltip button. */\r\n\ttopHiddenText?: string;\r\n\ttopTooltip?: TooltipInfoDescriptor;\r\n}\r\n\r\nexport interface CalculatorResultBodyItem {\r\n\tleft: {\r\n\t\telement: ReactElement | string;\r\n\t\t/** Visually hidden text for screen readers, providing additional info, such as the availability of help under tooltip button. */\r\n\t\thiddenText?: string;\r\n\t\ttooltip?: TooltipInfoDescriptor;\r\n\t};\r\n\tright: {\r\n\t\telement: ReactElement | string;\r\n\t};\r\n}\r\n\r\nexport interface CalculatorResultMain {\r\n\telement: ReactElement | string;\r\n\ttopSeparator?: boolean;\r\n}\r\n\r\nexport interface CalculatorResultModalDescriptor {\r\n\tcontent: ReactElement | string;\r\n\tmodalCloseButtonAriaLabel?: string;\r\n\ttriggerText: ReactElement | string;\r\n}\r\n\r\nexport enum CalculatorResultInfoPosition {\r\n\tinBox = 'inBox',\r\n\tunderBox = 'underBox',\r\n}\r\n","export enum StackDirection {\r\n\tcolumn = 'column',\r\n\tcolumnReverse = 'columnReverse',\r\n\trow = 'row',\r\n\trowReverse = 'rowReverse',\r\n}\r\n","import { css } from '@emotion/react';\r\n\r\nimport { type FlexWrap, resolveFlexWrapValue, resolveSpacingValue, type Spacing } from '@/theme';\r\nimport { styled } from '@/utils';\r\n\r\nimport { StackDirection } from './types';\r\n\r\ninterface StackStyledProps {\r\n\t$direction: StackDirection;\r\n\t$fullWidth: boolean;\r\n\t$gap: Spacing;\r\n\t$wrap: FlexWrap;\r\n}\r\n\r\nexport const StackStyled = styled.div<StackStyledProps>`\r\n\tdisplay: flex;\r\n\tflex-direction: ${({ $direction }) => {\r\n\t\tswitch ($direction) {\r\n\t\t\tcase StackDirection.row:\r\n\t\t\t\treturn 'row';\r\n\t\t\tcase StackDirection.rowReverse:\r\n\t\t\t\treturn 'row-reverse';\r\n\t\t\tcase StackDirection.column:\r\n\t\t\t\treturn 'column';\r\n\t\t\tcase StackDirection.columnReverse:\r\n\t\t\t\treturn 'column-reverse';\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected value of enum StackDirection in stack.styles.ts');\r\n\t\t}\r\n\t}};\r\n\tflex-wrap: ${({ $wrap }) => resolveFlexWrapValue($wrap)};\r\n\tgap: ${({ $gap, theme }) => resolveSpacingValue(theme, $gap)};\r\n\t${({ $fullWidth }) => {\r\n\t\treturn (\r\n\t\t\t$fullWidth &&\r\n\t\t\tcss`\r\n\t\t\t\twidth: 100%;\r\n\t\t\t`\r\n\t\t);\r\n\t}}\r\n`;\r\n","import { type AriaAttributes, type AriaRole, type ElementType, forwardRef, type ReactNode } from 'react';\r\n\r\nimport { FlexWrap, Spacing } from '@/theme';\r\n\r\nimport { StackDirection } from './types';\r\n\r\nimport { StackStyled } from './Stack.style';\r\n\r\nexport interface StackProps extends AriaAttributes {\r\n\tas?: ElementType;\r\n\tchildren?: ReactNode;\r\n\tclassName?: string;\r\n\tdirection?: StackDirection;\r\n\tfullWidth?: boolean;\r\n\tgap?: Spacing;\r\n\tid?: string;\r\n\trole?: AriaRole;\r\n\ttabIndex?: number;\r\n\twrap?: FlexWrap;\r\n}\r\n\r\nexport const Stack = forwardRef<HTMLDivElement, StackProps>((props, ref) => {\r\n\tconst {\r\n\t\tas,\r\n\t\tchildren,\r\n\t\tclassName,\r\n\t\tdirection = StackDirection.column,\r\n\t\tfullWidth = false,\r\n\t\tgap = Spacing.md,\r\n\t\tid,\r\n\t\trole,\r\n\t\ttabIndex,\r\n\t\twrap = FlexWrap.noWrap,\r\n\t\t...otherProps\r\n\t} = props;\r\n\r\n\treturn (\r\n\t\t<StackStyled\r\n\t\t\t$direction={direction}\r\n\t\t\t$fullWidth={fullWidth}\r\n\t\t\t$gap={gap}\r\n\t\t\t$wrap={wrap}\r\n\t\t\tas={as}\r\n\t\t\tclassName={className}\r\n\t\t\tid={id}\r\n\t\t\tref={ref}\r\n\t\t\trole={role}\r\n\t\t\ttabIndex={tabIndex}\r\n\t\t\t{...otherProps}\r\n\t\t>\r\n\t\t\t{children}\r\n\t\t</StackStyled>\r\n\t);\r\n});\r\n\r\nStack.displayName = 'Stack';\r\n","import { type MessageDescriptor, FormattedMessage as ReactIntlFormattedMessage } from 'react-intl';\r\n\r\nimport { type MessageValues } from '../types';\r\n\r\nexport interface FormattedMessageProps extends MessageDescriptor {\r\n\tvalues?: MessageValues;\r\n}\r\n\r\nexport const FormattedMessage = (props: FormattedMessageProps) => {\r\n\tconst { defaultMessage, description, id, values } = props;\r\n\r\n\treturn (\r\n\t\t<ReactIntlFormattedMessage\r\n\t\t\tdefaultMessage={defaultMessage}\r\n\t\t\tdescription={description}\r\n\t\t\tid={id}\r\n\t\t\tvalues={values}\r\n\t\t>\r\n\t\t\t{(txt) => <span data-message-id={id}>{txt}</span>}\r\n\t\t</ReactIntlFormattedMessage>\r\n\t);\r\n};\r\n","import { escape, mapValues } from 'lodash';\r\nimport { type MessageDescriptor, useIntl } from 'react-intl';\r\n\r\nimport { type MessageDescriptorWithPrimitiveValues } from '@/types';\r\n\r\nimport { type PrimitiveMessageValues } from '../types';\r\n\r\nexport interface FormattedHtmlMessageProps extends MessageDescriptorWithPrimitiveValues {}\r\n\r\nexport const FormattedHtmlMessage = (props: FormattedHtmlMessageProps) => {\r\n\tconst { defaultMessage, description, htmlValues, id, values: valuesProp } = props;\r\n\tconst intl = useIntl();\r\n\r\n\tconst messageDescriptor: MessageDescriptor = {\r\n\t\tdefaultMessage: defaultMessage,\r\n\t\tdescription: description,\r\n\t\tid: id,\r\n\t};\r\n\r\n\tconst messageValues: PrimitiveMessageValues | undefined =\r\n\t\tvaluesProp || htmlValues\r\n\t\t\t? {\r\n\t\t\t\t\t...mapValues(valuesProp, escape),\r\n\t\t\t\t\t...htmlValues,\r\n\t\t\t\t}\r\n\t\t\t: undefined;\r\n\r\n\treturn (\r\n\t\t<span\r\n\t\t\tdangerouslySetInnerHTML={{ __html: intl.formatMessage(messageDescriptor, messageValues, { ignoreTag: true }) }}\r\n\t\t\tdata-message-id={id}\r\n\t\t/>\r\n\t);\r\n};\r\n","import { type IsMessageDisplayableFunction } from '../types';\r\nimport { getTranslationNotDisplayString } from './isMessageDisplayableConfig';\r\n\r\nconst isTranslationNotDisplayString = (value: unknown): boolean => {\r\n\tif (typeof value !== 'string') {\r\n\t\treturn false;\r\n\t}\r\n\r\n\treturn value.toLowerCase() === getTranslationNotDisplayString().toLowerCase();\r\n};\r\n\r\nexport const isMessageDisplayable: IsMessageDisplayableFunction = (t, messageDescriptor): boolean => {\r\n\treturn !isTranslationNotDisplayString(t(messageDescriptor));\r\n};\r\n","export const getTranslationNotDisplayString = () => 'n/a';\r\n","import { useCallback } from 'react';\r\nimport { useIntl } from 'react-intl';\r\n\r\nimport { type IsMessageDisplayableHookReturnFunction } from '../types';\r\nimport { isMessageDisplayable } from './isMessageDisplayable';\r\n\r\nexport const useIsMessageDisplayable = (): IsMessageDisplayableHookReturnFunction => {\r\n\tconst { formatMessage: t } = useIntl();\r\n\r\n\tconst callback = useCallback<IsMessageDisplayableHookReturnFunction>(\r\n\t\t(messageDescriptor) => {\r\n\t\t\treturn isMessageDisplayable(t, messageDescriptor);\r\n\t\t},\r\n\t\t[t],\r\n\t);\r\n\r\n\treturn callback;\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconBillBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 10.2858C13.4202 10.2858 14.5714 9.13454 14.5714 7.71437C14.5714 6.29421 13.4202 5.14294 12 5.14294C10.5799 5.14294 9.42859 6.29421 9.42859 7.71437C9.42859 9.13454 10.5799 10.2858 12 10.2858Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\td=\"M21.4286 0.857178H2.57143C1.62466 0.857178 0.857147 1.62469 0.857147 2.57146V12.8572C0.857147 13.8039 1.62466 14.5715 2.57143 14.5715H21.4286C22.3754 14.5715 23.1429 13.8039 23.1429 12.8572V2.57146C23.1429 1.62469 22.3754 0.857178 21.4286 0.857178ZM9.42858 7.71432C9.42858 9.13449 10.5798 10.2857 12 10.2857C13.4202 10.2857 14.5714 9.13449 14.5714 7.71432C14.5714 6.29416 13.4202 5.14289 12 5.14289C10.5798 5.14289 9.42858 6.29416 9.42858 7.71432Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 10.2858C13.4202 10.2858 14.5714 9.13454 14.5714 7.71437C14.5714 6.29421 13.4202 5.14294 12 5.14294C10.5799 5.14294 9.42859 6.29421 9.42859 7.71437C9.42859 9.13454 10.5799 10.2858 12 10.2858Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M2.57143 0.857178H21.4286C22.3754 0.857178 23.1429 1.62469 23.1429 2.57146V12.8572C23.1429 13.8039 22.3754 14.5715 21.4286 14.5715H2.57143C1.62466 14.5715 0.857147 13.8039 0.857147 12.8572V2.57146C0.857147 1.62469 1.62466 0.857178 2.57143 0.857178Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M21.4286 18.8572H2.57144\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M19.7143 23.1429H4.28571\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.75697 8.14291C4.52028 8.14291 4.3284 7.95103 4.3284 7.71434C4.3284 7.47765 4.52028 7.28577 4.75697 7.28577\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.75705 8.14291C4.99374 8.14291 5.18562 7.95103 5.18562 7.71434C5.18562 7.47765 4.99374 7.28577 4.75705 7.28577\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M19.243 8.14291C19.0063 8.14291 18.8145 7.95103 18.8145 7.71434C18.8145 7.47765 19.0063 7.28577 19.243 7.28577\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M19.243 8.14291C19.4798 8.14291 19.6716 7.95103 19.6716 7.71434C19.6716 7.47765 19.4798 7.28577 19.243 7.28577\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconBillSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.99999 6.85728C8.94677 6.85728 9.71428 6.08977 9.71428 5.143C9.71428 4.19622 8.94677 3.42871 7.99999 3.42871C7.05321 3.42871 6.28571 4.19622 6.28571 5.143C6.28571 6.08977 7.05321 6.85728 7.99999 6.85728Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\td=\"M14.2857 0.571533H1.71427C1.08309 0.571533 0.571411 1.08321 0.571411 1.71439V8.57153C0.571411 9.20271 1.08309 9.71439 1.71427 9.71439H14.2857C14.9169 9.71439 15.4286 9.20271 15.4286 8.57153V1.71439C15.4286 1.08321 14.9169 0.571533 14.2857 0.571533ZM6.2857 5.14296C6.2857 6.08974 7.05321 6.85725 7.99998 6.85725C8.94676 6.85725 9.71427 6.08974 9.71427 5.14296C9.71427 4.19618 8.94676 3.42868 7.99998 3.42868C7.05321 3.42868 6.2857 4.19618 6.2857 5.14296Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.99999 6.85728C8.94677 6.85728 9.71428 6.08977 9.71428 5.143C9.71428 4.19622 8.94677 3.42871 7.99999 3.42871C7.05321 3.42871 6.28571 4.19622 6.28571 5.143C6.28571 6.08977 7.05321 6.85728 7.99999 6.85728Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M1.71427 0.571533H14.2857C14.9169 0.571533 15.4286 1.08321 15.4286 1.71439V8.57153C15.4286 9.20271 14.9169 9.71439 14.2857 9.71439H1.71427C1.08309 9.71439 0.571411 9.20271 0.571411 8.57153V1.71439C0.571411 1.08321 1.08309 0.571533 1.71427 0.571533Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.2857 12.5715H1.71426\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M13.1428 15.4287H2.85712\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.1713 5.42861C3.01351 5.42861 2.88559 5.30069 2.88559 5.14289C2.88559 4.9851 3.01351 4.85718 3.1713 4.85718\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.17136 5.42861C3.32915 5.42861 3.45707 5.30069 3.45707 5.14289C3.45707 4.9851 3.32915 4.85718 3.17136 4.85718\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.8287 5.42861C12.6709 5.42861 12.543 5.30069 12.543 5.14289C12.543 4.9851 12.6709 4.85718 12.8287 4.85718\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.8287 5.42861C12.9865 5.42861 13.1144 5.30069 13.1144 5.14289C13.1144 4.9851 12.9865 4.85718 12.8287 4.85718\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconCheckBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 22.4463C17.7695 22.4463 22.4464 17.7694 22.4464 11.9999C22.4464 6.23049 17.7695 1.55347 12 1.55347C6.23059 1.55347 1.55356 6.23049 1.55356 11.9999C1.55356 17.7694 6.23059 22.4463 12 22.4463Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 22.4463C17.7695 22.4463 22.4464 17.7694 22.4464 11.9999C22.4464 6.23049 17.7695 1.55347 12 1.55347C6.23059 1.55347 1.55356 6.23049 1.55356 11.9999C1.55356 17.7694 6.23059 22.4463 12 22.4463Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M16.688 8.38379L10.2594 16.4195L7.04514 14.0088\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconCheckSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.99999 14.9642C11.8463 14.9642 14.9643 11.8463 14.9643 7.99993C14.9643 4.15366 11.8463 1.03564 7.99999 1.03564C4.15372 1.03564 1.03571 4.15366 1.03571 7.99993C1.03571 11.8463 4.15372 14.9642 7.99999 14.9642Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.99999 14.9642C11.8463 14.9642 14.9643 11.8463 14.9643 7.99993C14.9643 4.15366 11.8463 1.03564 7.99999 1.03564C4.15372 1.03564 1.03571 4.15366 1.03571 7.99993C1.03571 11.8463 4.15372 14.9642 7.99999 14.9642Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.1253 5.58911L6.83963 10.9463L4.69678 9.33911\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconGraphIncreaseBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10.3544 9.87939L5.6543 16.3828V21.6437H21.6426V5.45703L17.19 12.7327L10.3544 9.87939Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.65625 16.338L10.3552 9.84244L17.22 12.7447L21.6425 5.41992\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M2.35693 2.35742V21.6431H21.6426\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconGraphIncreaseSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10.3544 9.87939L5.6543 16.3828V21.6437H21.6426V5.45703L17.19 12.7327L10.3544 9.87939Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.65625 16.338L10.3552 9.84244L17.22 12.7447L21.6425 5.41992\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M2.35693 2.35742V21.6431H21.6426\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconProductInformationBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 22.4464C17.7695 22.4464 22.4464 17.7695 22.4464 12C22.4464 6.23059 17.7695 1.55356 12 1.55356C6.23059 1.55356 1.55356 6.23059 1.55356 12C1.55356 17.7695 6.23059 22.4464 12 22.4464Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 22.4464C17.7695 22.4464 22.4464 17.7695 22.4464 12C22.4464 6.23059 17.7695 1.55356 12 1.55356C6.23059 1.55356 1.55356 6.23059 1.55356 12C1.55356 17.7695 6.23059 22.4464 12 22.4464Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.58926 16.8214H14.4107\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 16.8214V11.1964H10.3929\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 7.58034C11.7781 7.58034 11.5982 7.40045 11.5982 7.17855C11.5982 6.95665 11.7781 6.77676 12 6.77676\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 7.58034C12.2219 7.58034 12.4018 7.40045 12.4018 7.17855C12.4018 6.95665 12.2219 6.77676 12 6.77676\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconProductInformationSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.99999 14.9643C11.8463 14.9643 14.9643 11.8464 14.9643 8.00005C14.9643 4.15378 11.8463 1.03577 7.99999 1.03577C4.15372 1.03577 1.03571 4.15378 1.03571 8.00005C1.03571 11.8464 4.15372 14.9643 7.99999 14.9643Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.99999 14.9643C11.8463 14.9643 14.9643 11.8464 14.9643 8.00005C14.9643 4.15378 11.8463 1.03577 7.99999 1.03577C4.15372 1.03577 1.03571 4.15378 1.03571 8.00005C1.03571 11.8464 4.15372 14.9643 7.99999 14.9643Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.39285 11.2144H9.60714\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.99999 11.2144V7.46436H6.92856\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 5.05366C7.85207 5.05366 7.73215 4.93373 7.73215 4.7858C7.73215 4.63787 7.85207 4.51794 8 4.51794\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 5.05366C8.14793 5.05366 8.26786 4.93373 8.26786 4.7858C8.26786 4.63787 8.14793 4.51794 8 4.51794\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconLoginPasswordBig = (props: IconProductSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M1.55356 3.16064V20.8392\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.97321 14.0088L11.5982 9.99097\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.78571 8.78564V15.2142\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.97321 9.99097L11.5982 14.0088\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M16.8214 14.0088L22.4464 9.99097\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M19.6339 8.78564V15.2142\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M16.8214 9.99097L22.4464 14.0088\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconLoginPasswordSmall = (props: IconProductSvgProps) => {\r\n\tconst { stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M1.55356 3.16064V20.8392\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.97321 14.0088L11.5982 9.99097\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.78571 8.78564V15.2142\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.97321 9.99097L11.5982 14.0088\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M16.8214 14.0088L22.4464 9.99097\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M19.6339 8.78564V15.2142\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M16.8214 9.99097L22.4464 14.0088\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconMoneyBagBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.5 3H14.5C14.8978 3 15.2794 3.15804 15.5607 3.43934C15.842 3.72064 16 4.10218 16 4.5C16 5.42826 15.6313 6.3185 14.9749 6.97487C14.3185 7.63125 13.4283 8 12.5 8H11.5C10.5717 8 9.6815 7.63125 9.02513 6.97487C8.36875 6.3185 8 5.42826 8 4.5C8 4.10218 8.15804 3.72064 8.43934 3.43934C8.72064 3.15804 9.10218 3 9.5 3Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4 17V16C4 13.8783 4.84285 11.8434 6.34315 10.3431C7.84344 8.84285 9.87827 8 12 8C14.1217 8 16.1566 8.84285 17.6569 10.3431C19.1571 11.8434 20 13.8783 20 16V17C20 18.0609 19.5786 19.0783 18.8284 19.8284C18.0783 20.5786 17.0609 21 16 21H8C6.93913 21 5.92172 20.5786 5.17157 19.8284C4.42143 19.0783 4 18.0609 4 17Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconMoneyBagSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"18\"\r\n\t\t\tviewBox=\"0 0 16 18\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.91406 1.5H10.0807C10.4122 1.5 10.7302 1.6317 10.9646 1.86612C11.199 2.10054 11.3307 2.41848 11.3307 2.75C11.3307 3.52355 11.0234 4.26541 10.4765 4.81239C9.92948 5.35938 9.18761 5.66667 8.41406 5.66667H7.58073C6.80718 5.66667 6.06532 5.35938 5.51833 4.81239C4.97135 4.26541 4.66406 3.52355 4.66406 2.75C4.66406 2.41848 4.79576 2.10054 5.03018 1.86612C5.2646 1.6317 5.58254 1.5 5.91406 1.5Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M1.33203 13.1665V12.3332C1.33203 10.5651 2.03441 8.86937 3.28465 7.61913C4.5349 6.36888 6.23059 5.6665 7.9987 5.6665C9.76681 5.6665 11.4625 6.36888 12.7127 7.61913C13.963 8.86937 14.6654 10.5651 14.6654 12.3332V13.1665C14.6654 14.0506 14.3142 14.8984 13.6891 15.5235C13.0639 16.1486 12.2161 16.4998 11.332 16.4998H4.66536C3.78131 16.4998 2.93346 16.1486 2.30834 15.5235C1.68322 14.8984 1.33203 14.0506 1.33203 13.1665Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconProductPasswordLockBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\td=\"M3.1607 3.16064C2.2731 3.16064 1.55356 3.88019 1.55356 4.76779V11.1964C1.55356 12.084 2.2731 12.8035 3.1607 12.8035H12.8177C13.0237 9.88442 15.457 7.58029 18.4286 7.58029C18.7015 7.58029 18.9697 7.59972 19.2321 7.63724V4.76779C19.2321 3.88019 18.5126 3.16064 17.625 3.16064H3.1607Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.37499 8.38389C6.15309 8.38389 5.97321 8.20401 5.97321 7.98211C5.97321 7.76021 6.15309 7.58032 6.37499 7.58032\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.375 8.38389C6.5969 8.38389 6.77679 8.20401 6.77679 7.98211C6.77679 7.76021 6.5969 7.58032 6.375 7.58032\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.4107 8.38389C14.1888 8.38389 14.0089 8.20401 14.0089 7.98211C14.0089 7.76021 14.1888 7.58032 14.4107 7.58032\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.4107 8.38389C14.6326 8.38389 14.8125 8.20401 14.8125 7.98211C14.8125 7.76021 14.6326 7.58032 14.4107 7.58032\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10.3928 8.38389C10.1709 8.38389 9.99106 8.20401 9.99106 7.98211C9.99106 7.76021 10.1709 7.58032 10.3928 7.58032\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10.3929 8.38389C10.6148 8.38389 10.7946 8.20401 10.7946 7.98211C10.7946 7.76021 10.6148 7.58032 10.3929 7.58032\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.4107 20.0355V16.0177C14.4107 15.5739 14.7705 15.2141 15.2143 15.2141H21.6428C22.0866 15.2141 22.4464 15.5739 22.4464 16.0177V20.0355C22.4464 20.4793 22.0866 20.8391 21.6428 20.8391H15.2143C14.7705 20.8391 14.4107 20.4793 14.4107 20.0355Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M15.6161 15.2143V13.2053C15.6161 11.652 16.8753 10.3928 18.4286 10.3928C19.9819 10.3928 21.2411 11.652 21.2411 13.2053V15.2143\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.4107 20.0355V16.0177C14.4107 15.5739 14.7705 15.2141 15.2143 15.2141H21.6428C22.0866 15.2141 22.4464 15.5739 22.4464 16.0177V20.0355C22.4464 20.4793 22.0866 20.8391 21.6428 20.8391H15.2143C14.7705 20.8391 14.4107 20.4793 14.4107 20.0355Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M19.2321 7.02783V4.76779C19.2321 3.88019 18.5126 3.16064 17.625 3.16064H3.1607C2.2731 3.16064 1.55356 3.88019 1.55356 4.76779V11.1964C1.55356 12.084 2.2731 12.8035 3.1607 12.8035H12.2009\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconProductPasswordLockSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 24 20\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\td=\"M3.1607 1.16064C2.2731 1.16064 1.55356 1.88019 1.55356 2.76779V9.19636C1.55356 10.084 2.2731 10.8035 3.1607 10.8035H12.8177C13.0237 7.88442 15.457 5.58029 18.4286 5.58029C18.7015 5.58029 18.9697 5.59972 19.2321 5.63724V2.76779C19.2321 1.88019 18.5126 1.16064 17.625 1.16064H3.1607Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.37499 6.38389C6.15309 6.38389 5.97321 6.20401 5.97321 5.98211C5.97321 5.76021 6.15309 5.58032 6.37499 5.58032\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.375 6.38389C6.5969 6.38389 6.77679 6.20401 6.77679 5.98211C6.77679 5.76021 6.5969 5.58032 6.375 5.58032\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.4107 6.38389C14.1888 6.38389 14.0089 6.20401 14.0089 5.98211C14.0089 5.76021 14.1888 5.58032 14.4107 5.58032\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.4107 6.38389C14.6326 6.38389 14.8125 6.20401 14.8125 5.98211C14.8125 5.76021 14.6326 5.58032 14.4107 5.58032\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10.3928 6.38389C10.1709 6.38389 9.99106 6.20401 9.99106 5.98211C9.99106 5.76021 10.1709 5.58032 10.3928 5.58032\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10.3929 6.38389C10.6148 6.38389 10.7946 6.20401 10.7946 5.98211C10.7946 5.76021 10.6148 5.58032 10.3929 5.58032\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.4107 18.0355V14.0177C14.4107 13.5739 14.7705 13.2141 15.2143 13.2141H21.6428C22.0866 13.2141 22.4464 13.5739 22.4464 14.0177V18.0355C22.4464 18.4793 22.0866 18.8391 21.6428 18.8391H15.2143C14.7705 18.8391 14.4107 18.4793 14.4107 18.0355Z\"\r\n\t\t\t\tfill=\"white\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M15.6161 13.2143V11.2053C15.6161 9.65202 16.8753 8.39282 18.4286 8.39282C19.9819 8.39282 21.2411 9.65202 21.2411 11.2053V13.2143\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.4107 18.0355V14.0177C14.4107 13.5739 14.7705 13.2141 15.2143 13.2141H21.6428C22.0866 13.2141 22.4464 13.5739 22.4464 14.0177V18.0355C22.4464 18.4793 22.0866 18.8391 21.6428 18.8391H15.2143C14.7705 18.8391 14.4107 18.4793 14.4107 18.0355Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M19.2321 5.02783V2.76779C19.2321 1.88019 18.5126 1.16064 17.625 1.16064H3.1607C2.2731 1.16064 1.55356 1.88019 1.55356 2.76779V9.19636C1.55356 10.084 2.2731 10.8035 3.1607 10.8035H12.2009\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconPeopleBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.9997 16.8213C9.33686 16.8213 7.17822 18.9798 7.17822 21.6427H16.8211C16.8211 18.9798 14.6624 16.8213 11.9997 16.8213Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.36315 9.59332C6.98838 10.3137 6.77658 11.1324 6.77658 12.0006C6.77658 12.8701 6.98907 13.6901 7.36497 14.4113H2.35693C2.35693 11.7485 4.51557 9.58984 7.17836 9.58984C7.24024 9.58984 7.30184 9.59102 7.36315 9.59332Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M16.6366 9.59332C16.6979 9.59102 16.7595 9.58984 16.8213 9.58984C19.4842 9.58984 21.6428 11.7485 21.6428 14.4113H16.6348C17.0107 13.6901 17.2231 12.8701 17.2231 12.0006C17.2231 11.1324 17.0113 10.3137 16.6366 9.59332Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.76758 4.76814C4.76758 5.08472 4.82993 5.3982 4.95108 5.69068C5.07223 5.98316 5.2498 6.24891 5.47366 6.47277C5.69752 6.69662 5.96327 6.8742 6.25575 6.99535C6.54823 7.1165 6.86171 7.17885 7.17829 7.17885C7.49487 7.17885 7.80835 7.1165 8.10083 6.99535C8.39331 6.8742 8.65907 6.69662 8.88292 6.47277C9.10678 6.24891 9.28435 5.98316 9.4055 5.69068C9.52665 5.3982 9.58901 5.08472 9.58901 4.76814C9.58901 4.45156 9.52665 4.13808 9.4055 3.8456C9.28435 3.55311 9.10678 3.28736 8.88292 3.0635C8.65907 2.83965 8.39331 2.66208 8.10083 2.54093C7.80835 2.41978 7.49487 2.35742 7.17829 2.35742C6.86171 2.35742 6.54823 2.41978 6.25575 2.54093C5.96327 2.66208 5.69752 2.83965 5.47366 3.0635C5.2498 3.28736 5.07223 3.55311 4.95108 3.8456C4.82993 4.13808 4.76758 4.45156 4.76758 4.76814Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.4106 4.76814C14.4106 5.08472 14.473 5.3982 14.5941 5.69068C14.7153 5.98316 14.8929 6.24891 15.1167 6.47277C15.3406 6.69662 15.6063 6.8742 15.8988 6.99535C16.1913 7.1165 16.5048 7.17885 16.8214 7.17885C17.1379 7.17885 17.4514 7.1165 17.7439 6.99535C18.0364 6.8742 18.3021 6.69662 18.526 6.47277C18.7498 6.24891 18.9274 5.98316 19.0486 5.69068C19.1697 5.3982 19.2321 5.08472 19.2321 4.76814C19.2321 4.12877 18.9781 3.5156 18.526 3.0635C18.0739 2.61141 17.4607 2.35742 16.8214 2.35742C16.182 2.35742 15.5688 2.61141 15.1167 3.0635C14.6646 3.5156 14.4106 4.12877 14.4106 4.76814Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.58887 12.0006C9.58887 12.6399 9.84285 13.2531 10.2949 13.7052C10.747 14.1573 11.3602 14.4113 11.9996 14.4113C12.6389 14.4113 13.2521 14.1573 13.7042 13.7052C14.1563 13.2531 14.4103 12.6399 14.4103 12.0006C14.4103 11.3612 14.1563 10.748 13.7042 10.2959C13.2521 9.84383 12.6389 9.58984 11.9996 9.58984C11.3602 9.58984 10.747 9.84383 10.2949 10.2959C9.84285 10.748 9.58887 11.3612 9.58887 12.0006Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.76758 4.76814C4.76758 5.08472 4.82993 5.3982 4.95108 5.69068C5.07223 5.98316 5.2498 6.24891 5.47366 6.47277C5.69752 6.69662 5.96327 6.8742 6.25575 6.99535C6.54823 7.1165 6.86171 7.17885 7.17829 7.17885C7.49487 7.17885 7.80835 7.1165 8.10083 6.99535C8.39331 6.8742 8.65907 6.69662 8.88292 6.47277C9.10678 6.24891 9.28435 5.98316 9.4055 5.69068C9.52665 5.3982 9.58901 5.08472 9.58901 4.76814C9.58901 4.45156 9.52665 4.13808 9.4055 3.8456C9.28435 3.55311 9.10678 3.28736 8.88292 3.0635C8.65907 2.83965 8.39331 2.66208 8.10083 2.54093C7.80835 2.41978 7.49487 2.35742 7.17829 2.35742C6.86171 2.35742 6.54823 2.41978 6.25575 2.54093C5.96327 2.66208 5.69752 2.83965 5.47366 3.0635C5.2498 3.28736 5.07223 3.55311 4.95108 3.8456C4.82993 4.13808 4.76758 4.45156 4.76758 4.76814Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.4106 4.76814C14.4106 5.08472 14.473 5.3982 14.5941 5.69068C14.7153 5.98316 14.8929 6.24891 15.1167 6.47277C15.3406 6.69662 15.6063 6.8742 15.8988 6.99535C16.1913 7.1165 16.5048 7.17885 16.8214 7.17885C17.1379 7.17885 17.4514 7.1165 17.7439 6.99535C18.0364 6.8742 18.3021 6.69662 18.526 6.47277C18.7498 6.24891 18.9274 5.98316 19.0486 5.69068C19.1697 5.3982 19.2321 5.08472 19.2321 4.76814C19.2321 4.12877 18.9781 3.5156 18.526 3.0635C18.0739 2.61141 17.4607 2.35742 16.8214 2.35742C16.182 2.35742 15.5688 2.61141 15.1167 3.0635C14.6646 3.5156 14.4106 4.12877 14.4106 4.76814Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.58887 12.0006C9.58887 12.6399 9.84285 13.2531 10.2949 13.7052C10.747 14.1573 11.3602 14.4113 11.9996 14.4113C12.6389 14.4113 13.2521 14.1573 13.7042 13.7052C14.1563 13.2531 14.4103 12.6399 14.4103 12.0006C14.4103 11.3612 14.1563 10.748 13.7042 10.2959C13.2521 9.84383 12.6389 9.58984 11.9996 9.58984C11.3602 9.58984 10.747 9.84383 10.2949 10.2959C9.84285 10.748 9.58887 11.3612 9.58887 12.0006Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M2.35693 14.4113C2.35693 11.7485 4.51557 9.58984 7.17836 9.58984\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M21.6427 14.4113C21.6427 11.7485 19.4842 9.58984 16.8213 9.58984\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M16.8211 21.6427C16.8211 18.9798 14.6624 16.8213 11.9997 16.8213C9.33686 16.8213 7.17822 18.9798 7.17822 21.6427\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconPeopleSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.9998 11.2142C6.2246 11.2142 4.7855 12.6532 4.7855 14.4285H11.2141C11.2141 12.6532 9.7749 11.2142 7.9998 11.2142Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.9088 6.3955C4.6589 6.8758 4.5177 7.4216 4.5177 8.0004C4.5177 8.5801 4.6594 9.1267 4.9100 9.6075H1.5713C1.5713 7.8323 3.0104 6.3932 4.7856 6.3932C4.8268 6.3932 4.8679 6.3940 4.9088 6.3955Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.0911 6.3955C11.1319 6.3940 11.1730 6.3932 11.2142 6.3932C12.9895 6.3932 14.4285 7.8323 14.4285 9.6075H11.0899C11.3405 9.1267 11.4821 8.5801 11.4821 8.0004C11.4821 7.4216 11.3409 6.8758 11.0911 6.3955Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.1784 3.1788C3.1784 3.3898 3.2200 3.5988 3.3007 3.7938C3.3815 3.9888 3.4999 4.1659 3.6491 4.3152C3.7984 4.4644 3.9755 4.5828 4.1705 4.6636C4.3655 4.7443 4.5745 4.7859 4.7855 4.7859C4.9966 4.7859 5.2056 4.7443 5.4006 4.6636C5.5955 4.5828 5.7727 4.4644 5.9219 4.3152C6.0712 4.1659 6.1896 3.9888 6.2703 3.7938C6.3511 3.5988 6.3927 3.3898 6.3927 3.1788C6.3927 2.9677 6.3511 2.7587 6.2703 2.5637C6.1896 2.3687 6.0712 2.1916 5.9219 2.0423C5.7727 1.8931 5.5955 1.7747 5.4006 1.6940C5.2056 1.6132 4.9966 1.5716 4.7855 1.5716C4.5745 1.5716 4.3655 1.6132 4.1705 1.6940C3.9755 1.7747 3.7984 1.8931 3.6491 2.0423C3.4999 2.1916 3.3815 2.3687 3.3007 2.5637C3.2200 2.7587 3.1784 2.9677 3.1784 3.1788Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.6071 3.1788C9.6071 3.3898 9.6487 3.5988 9.7294 3.7938C9.8102 3.9888 9.9286 4.1659 10.0778 4.3152C10.2271 4.4644 10.4042 4.5828 10.5992 4.6636C10.7942 4.7443 11.0032 4.7859 11.2143 4.7859C11.4253 4.7859 11.6343 4.7443 11.8293 4.6636C12.0243 4.5828 12.2014 4.4644 12.3507 4.3152C12.4999 4.1659 12.6183 3.9888 12.6991 3.7938C12.7798 3.5988 12.8214 3.3898 12.8214 3.1788C12.8214 2.7525 12.6521 2.3437 12.3507 2.0423C12.0493 1.7409 11.6405 1.5716 11.2143 1.5716C10.788 1.5716 10.3792 1.7409 10.0778 2.0423C9.7764 2.3437 9.6071 2.7525 9.6071 3.1788Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.3926 8.0004C6.3926 8.4266 6.5619 8.8354 6.8633 9.1368C7.1647 9.4382 7.5735 9.6075 7.9997 9.6075C8.4259 9.6075 8.8347 9.4382 9.1361 9.1368C9.4375 8.8354 9.6069 8.4266 9.6069 8.0004C9.6069 7.5741 9.4375 7.1653 9.1361 6.8639C8.8347 6.5625 8.4259 6.3932 7.9997 6.3932C7.5735 6.3932 7.1647 6.5625 6.8633 6.8639C6.5619 7.1653 6.3926 7.5741 6.3926 8.0004Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.1784 3.1788C3.1784 3.3898 3.2200 3.5988 3.3007 3.7938C3.3815 3.9888 3.4999 4.1659 3.6491 4.3152C3.7984 4.4644 3.9755 4.5828 4.1705 4.6636C4.3655 4.7443 4.5745 4.7859 4.7855 4.7859C4.9966 4.7859 5.2056 4.7443 5.4006 4.6636C5.5955 4.5828 5.7727 4.4644 5.9219 4.3152C6.0712 4.1659 6.1896 3.9888 6.2703 3.7938C6.3511 3.5988 6.3927 3.3898 6.3927 3.1788C6.3927 2.9677 6.3511 2.7587 6.2703 2.5637C6.1896 2.3687 6.0712 2.1916 5.9219 2.0423C5.7727 1.8931 5.5955 1.7747 5.4006 1.6940C5.2056 1.6132 4.9966 1.5716 4.7855 1.5716C4.5745 1.5716 4.3655 1.6132 4.1705 1.6940C3.9755 1.7747 3.7984 1.8931 3.6491 2.0423C3.4999 2.1916 3.3815 2.3687 3.3007 2.5637C3.2200 2.7587 3.1784 2.9677 3.1784 3.1788Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.6071 3.1788C9.6071 3.3898 9.6487 3.5988 9.7294 3.7938C9.8102 3.9888 9.9286 4.1659 10.0778 4.3152C10.2271 4.4644 10.4042 4.5828 10.5992 4.6636C10.7942 4.7443 11.0032 4.7859 11.2143 4.7859C11.4253 4.7859 11.6343 4.7443 11.8293 4.6636C12.0243 4.5828 12.2014 4.4644 12.3507 4.3152C12.4999 4.1659 12.6183 3.9888 12.6991 3.7938C12.7798 3.5988 12.8214 3.3898 12.8214 3.1788C12.8214 2.7525 12.6521 2.3437 12.3507 2.0423C12.0493 1.7409 11.6405 1.5716 11.2143 1.5716C10.788 1.5716 10.3792 1.7409 10.0778 2.0423C9.7764 2.3437 9.6071 2.7525 9.6071 3.1788Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.3926 8.0004C6.3926 8.4266 6.5619 8.8354 6.8633 9.1368C7.1647 9.4382 7.5735 9.6075 7.9997 9.6075C8.4259 9.6075 8.8347 9.4382 9.1361 9.1368C9.4375 8.8354 9.6069 8.4266 9.6069 8.0004C9.6069 7.5741 9.4375 7.1653 9.1361 6.8639C8.8347 6.5625 8.4259 6.3932 7.9997 6.3932C7.5735 6.3932 7.1647 6.5625 6.8633 6.8639C6.5619 7.1653 6.3926 7.5741 6.3926 8.0004Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M1.5713 9.6075C1.5713 7.8323 3.0104 6.3932 4.7856 6.3932\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.4285 9.6075C14.4285 7.8323 12.9895 6.3932 11.2142 6.3932\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.2141 14.4285C11.2141 12.6532 9.7749 11.2142 7.9998 11.2142C6.2246 11.2142 4.7855 12.6532 4.7855 14.4285\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconPiggyBankBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M18.0497 2.39293V5.87442C20.6723 6.96717 21.1445 8.83189 21.1445 11.2685L22.6133 12.475V16.1993C21.7476 18.0615 20.1478 19.0319 18.0497 19.7751V21.4275C18.0497 21.891 17.6739 22.2668 17.2105 22.2668H14.2731C13.8095 22.2668 13.4338 21.891 13.4338 21.4275V19.7751H8.16201V21.2962C8.16201 21.7599 7.78625 22.1355 7.32273 22.1355H4.35894C3.89537 22.1355 3.51959 21.7607 3.51964 21.2971C3.51976 20.2804 3.51987 18.6602 3.51954 18.3237C3.51945 18.2456 3.36491 17.8167 3.16541 17.1524C2.58122 15.2066 1.61153 11.923 3.00621 8.83189C4.17542 6.24053 7.00627 4.26373 13.1189 4.60669C13.9966 2.28807 16.3185 1.68289 17.5042 1.73648C17.8418 1.75173 18.0497 2.0551 18.0497 2.39293Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M1.75412 4.80298C2.18004 5.94436 2.98966 6.80825 3.81614 7.41989\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.5812 8.47827H8.46747\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M16.7562 10.9992C16.5244 10.9992 16.3366 10.8113 16.3366 10.5796C16.3366 10.3478 16.5244 10.1599 16.7562 10.1599\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M16.7563 10.9992C16.988 10.9992 17.1759 10.8113 17.1759 10.5796C17.1759 10.3478 16.988 10.1599 16.7563 10.1599\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M18.0497 2.39293V5.87442C20.6723 6.96717 21.1445 8.83189 21.1445 11.2685L22.6133 12.475V16.1993C21.7476 18.0615 20.1478 19.0319 18.0497 19.7751V21.4275C18.0497 21.891 17.6739 22.2668 17.2105 22.2668H14.2731C13.8095 22.2668 13.4338 21.891 13.4338 21.4275V19.7751H8.16201V21.2962C8.16201 21.7599 7.78625 22.1355 7.32273 22.1355H4.35894C3.89537 22.1355 3.51959 21.7607 3.51964 21.2971C3.51976 20.2804 3.51987 18.6602 3.51954 18.3237C3.51945 18.2456 3.36491 17.8167 3.16541 17.1524C2.58122 15.2066 1.61153 11.923 3.00621 8.83189C4.17542 6.24053 7.00627 4.26373 13.1189 4.60669C13.9966 2.28807 16.3185 1.68289 17.5042 1.73648C17.8418 1.75173 18.0497 2.0551 18.0497 2.39293Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconPiggyBankSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.0331 1.59528V3.91628C13.7815 4.64478 14.0963 5.88793 14.0963 7.51234L15.0755 8.31665V10.7995C14.4984 12.041 13.4318 12.6879 12.0331 13.1834V14.285C12.0331 14.594 11.7826 14.8445 11.4736 14.8445H9.51537C9.20634 14.8445 8.95585 14.594 8.95585 14.285V13.1834H5.44133V14.1975C5.44133 14.5066 5.19082 14.757 4.88181 14.757H2.90595C2.5969 14.757 2.34638 14.5071 2.34641 14.1981C2.34649 13.5202 2.34657 12.4401 2.34635 12.2158C2.34629 12.1637 2.24326 11.8778 2.11026 11.4349C1.7208 10.1378 1.07434 7.94867 2.00413 5.88793C2.7836 4.16035 4.67083 2.84249 8.7459 3.07113C9.33105 1.52538 10.879 1.12193 11.6695 1.15765C11.8945 1.16782 12.0331 1.37007 12.0331 1.59528Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M1.1694 3.2019C1.45335 3.96282 1.9931 4.53875 2.54408 4.94651\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.72077 5.6521H5.64496\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.1708 7.33272C11.0163 7.33272 10.8911 7.20746 10.8911 7.05296C10.8911 6.89845 11.0163 6.77319 11.1708 6.77319\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.1709 7.33272C11.3254 7.33272 11.4506 7.20746 11.4506 7.05296C11.4506 6.89845 11.3254 6.77319 11.1709 6.77319\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.0331 1.59528V3.91628C13.7815 4.64478 14.0963 5.88793 14.0963 7.51234L15.0755 8.31665V10.7995C14.4984 12.041 13.4318 12.6879 12.0331 13.1834V14.285C12.0331 14.594 11.7826 14.8445 11.4736 14.8445H9.51537C9.20634 14.8445 8.95585 14.594 8.95585 14.285V13.1834H5.44133V14.1975C5.44133 14.5066 5.19082 14.757 4.88181 14.757H2.90595C2.5969 14.757 2.34638 14.5071 2.34641 14.1981C2.34649 13.5202 2.34657 12.4401 2.34635 12.2158C2.34629 12.1637 2.24326 11.8778 2.11026 11.4349C1.7208 10.1378 1.07434 7.94867 2.00413 5.88793C2.7836 4.16035 4.67083 2.84249 8.7459 3.07113C9.33105 1.52538 10.879 1.12193 11.6695 1.15765C11.8945 1.16782 12.0331 1.37007 12.0331 1.59528Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconProductRewardBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<g clipPath=\"url(#clip0_16048_4730)\">\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M5.08736 18.8694L1.08984 19.9407L4.78945 13.5327L9.36845 17.3072L6.15849 22.8669L5.08736 18.8694Z\"\r\n\t\t\t\t\tfill={fill}\r\n\t\t\t\t/>\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M18.9139 18.8694L22.9114 19.9407L19.2118 13.5327L14.6328 17.3072L17.8428 22.8669L18.9139 18.8694Z\"\r\n\t\t\t\t\tfill={fill}\r\n\t\t\t\t/>\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M19.235 13.5723L22.9119 19.9409L18.9144 18.8696L17.8433 22.8672L14.6562 17.347\"\r\n\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t\t/>\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M20.3143 9.45208C20.3143 14.0467 16.5897 17.7714 11.995 17.7714C7.40045 17.7714 3.67578 14.0467 3.67578 9.45208C3.67578 4.85748 7.40045 1.13281 11.995 1.13281C16.5897 1.13281 20.3143 4.85748 20.3143 9.45208Z\"\r\n\t\t\t\t\tfill={fill}\r\n\t\t\t\t/>\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M20.3143 9.45208C20.3143 14.0467 16.5897 17.7714 11.995 17.7714C7.40045 17.7714 3.67578 14.0467 3.67578 9.45208C3.67578 4.85748 7.40045 1.13281 11.995 1.13281C16.5897 1.13281 20.3143 4.85748 20.3143 9.45208Z\"\r\n\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t\t/>\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M12.3377 4.93533L13.4837 7.24058C13.5093 7.29889 13.5499 7.34935 13.6014 7.3868C13.6529 7.42427 13.7135 7.44738 13.7768 7.45379L16.3219 7.84022C16.3947 7.84968 16.4633 7.87968 16.5196 7.92668C16.576 7.97368 16.6178 8.03575 16.6401 8.10565C16.6625 8.17553 16.6645 8.25034 16.6459 8.32133C16.6273 8.3923 16.5889 8.45652 16.5351 8.50647L14.6563 10.2921C14.6283 10.3455 14.6136 10.4049 14.6136 10.4653C14.6136 10.5256 14.6283 10.5851 14.6563 10.6385L15.0161 13.1703C15.0314 13.2435 15.0252 13.3195 14.9982 13.3893C14.9712 13.459 14.9245 13.5194 14.8639 13.5631C14.8032 13.6068 14.7312 13.632 14.6565 13.6356C14.5818 13.6392 14.5077 13.6211 14.4431 13.5834L12.1778 12.3841C12.1192 12.3576 12.0556 12.3439 11.9912 12.3439C11.9269 12.3439 11.8633 12.3576 11.8047 12.3841L9.53943 13.5834C9.47483 13.6211 9.40071 13.6392 9.32603 13.6356C9.25135 13.632 9.1793 13.6068 9.11866 13.5631C9.05799 13.5194 9.01133 13.459 8.9843 13.3893C8.9573 13.3195 8.95109 13.2435 8.96643 13.1703L9.39283 10.6385C9.41118 10.5797 9.41469 10.5174 9.40306 10.4569C9.39144 10.3965 9.36504 10.3398 9.32621 10.2921L7.44737 8.49315C7.39753 8.44267 7.36255 8.37944 7.34625 8.3104C7.32997 8.24136 7.33301 8.16917 7.35503 8.10172C7.37704 8.03429 7.41721 7.97422 7.47109 7.92809C7.52499 7.88196 7.59054 7.85156 7.66057 7.84022L10.2057 7.46712C10.269 7.46071 10.3296 7.43759 10.3811 7.40013C10.4326 7.36268 10.4732 7.31222 10.4988 7.25391L11.6448 4.94866C11.6755 4.8834 11.7238 4.82802 11.7843 4.78879C11.8448 4.74955 11.915 4.72803 11.9871 4.72663C12.0592 4.72524 12.1302 4.74406 12.1922 4.78094C12.2542 4.81781 12.3046 4.87129 12.3377 4.93533Z\"\r\n\t\t\t\t\tfill={fill}\r\n\t\t\t\t/>\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M12.3377 4.93533L13.4837 7.24058C13.5093 7.29889 13.5499 7.34935 13.6014 7.3868C13.6529 7.42427 13.7135 7.44738 13.7768 7.45379L16.3219 7.84022C16.3947 7.84968 16.4633 7.87968 16.5196 7.92668C16.576 7.97368 16.6178 8.03575 16.6401 8.10565C16.6625 8.17553 16.6645 8.25034 16.6459 8.32133C16.6273 8.3923 16.5889 8.45652 16.5351 8.50647L14.6563 10.2921C14.6283 10.3455 14.6136 10.4049 14.6136 10.4653C14.6136 10.5256 14.6283 10.5851 14.6563 10.6385L15.0161 13.1703C15.0314 13.2435 15.0252 13.3195 14.9982 13.3893C14.9712 13.459 14.9245 13.5194 14.8639 13.5631C14.8032 13.6068 14.7312 13.632 14.6565 13.6356C14.5818 13.6392 14.5077 13.6211 14.4431 13.5834L12.1778 12.3841C12.1192 12.3576 12.0556 12.3439 11.9912 12.3439C11.9269 12.3439 11.8633 12.3576 11.8047 12.3841L9.53943 13.5834C9.47483 13.6211 9.40071 13.6392 9.32603 13.6356C9.25135 13.632 9.1793 13.6068 9.11866 13.5631C9.05799 13.5194 9.01133 13.459 8.9843 13.3893C8.9573 13.3195 8.95109 13.2435 8.96643 13.1703L9.39283 10.6385C9.41118 10.5797 9.41469 10.5174 9.40306 10.4569C9.39144 10.3965 9.36504 10.3398 9.32621 10.2921L7.44737 8.49315C7.39753 8.44267 7.36255 8.37944 7.34625 8.3104C7.32997 8.24136 7.33301 8.16917 7.35503 8.10172C7.37704 8.03429 7.41721 7.97422 7.47109 7.92809C7.52499 7.88196 7.59054 7.85156 7.66057 7.84022L10.2057 7.46712C10.269 7.46071 10.3296 7.43759 10.3811 7.40013C10.4326 7.36268 10.4732 7.31222 10.4988 7.25391L11.6448 4.94866C11.6755 4.8834 11.7238 4.82802 11.7843 4.78879C11.8448 4.74955 11.915 4.72803 11.9871 4.72663C12.0592 4.72524 12.1302 4.74406 12.1922 4.78094C12.2542 4.81781 12.3046 4.87129 12.3377 4.93533Z\"\r\n\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t\t/>\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M4.76886 13.5679L1.08984 19.9401L5.08735 18.869L6.15848 22.8665L9.34891 17.3405\"\r\n\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t\t/>\r\n\t\t\t</g>\r\n\t\t\t<defs>\r\n\t\t\t\t<clipPath id=\"clip0_16048_4730\">\r\n\t\t\t\t\t<rect\r\n\t\t\t\t\t\tfill=\"white\"\r\n\t\t\t\t\t\theight=\"24\"\r\n\t\t\t\t\t\twidth=\"24\"\r\n\t\t\t\t\t/>\r\n\t\t\t\t</clipPath>\r\n\t\t\t</defs>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconProductRewardSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.39114 12.5795L0.726135 13.2937L3.19254 9.02173L6.24521 11.538L4.10523 15.2445L3.39114 12.5795Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.6087 12.5795L15.2737 13.2937L12.8073 9.02173L9.75464 11.538L11.8946 15.2445L12.6087 12.5795Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.8224 9.0481L15.2737 13.2939L12.6087 12.5797L11.8946 15.2447L9.7699 11.5646\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M13.543 6.30131C13.543 9.36439 11.0599 11.8475 7.99683 11.8475C4.93376 11.8475 2.45065 9.36439 2.45065 6.30131C2.45065 3.23824 4.93376 0.755127 7.99683 0.755127C11.0599 0.755127 13.543 3.23824 13.543 6.30131Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M13.543 6.30131C13.543 9.36439 11.0599 11.8475 7.99683 11.8475C4.93376 11.8475 2.45065 9.36439 2.45065 6.30131C2.45065 3.23824 4.93376 0.755127 7.99683 0.755127C11.0599 0.755127 13.543 3.23824 13.543 6.30131Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.22379 3.29006L8.98778 4.82689C9.00486 4.86577 9.03195 4.89941 9.06628 4.92437C9.10062 4.94935 9.14096 4.96476 9.18321 4.96903L10.88 5.22665C10.9285 5.23296 10.9742 5.25296 11.0117 5.28429C11.0493 5.31562 11.0772 5.35701 11.0921 5.4036C11.107 5.45019 11.1083 5.50007 11.0959 5.54739C11.0835 5.5947 11.0579 5.63752 11.0221 5.67082L9.76952 6.86121C9.75085 6.89684 9.74109 6.93646 9.74109 6.97669C9.74109 7.01692 9.75085 7.05655 9.76952 7.09218L10.0094 8.78004C10.0196 8.82882 10.0155 8.87953 9.99745 8.92601C9.97944 8.97249 9.94834 9.01275 9.90789 9.0419C9.86746 9.07105 9.81943 9.08784 9.76965 9.09024C9.71985 9.09264 9.67043 9.08055 9.62738 9.05543L8.11719 8.25591C8.07812 8.23825 8.03572 8.22912 7.99282 8.22912C7.94994 8.22912 7.90754 8.23825 7.86846 8.25591L6.35827 9.05543C6.31521 9.08055 6.2658 9.09264 6.21601 9.09024C6.16622 9.08784 6.11819 9.07105 6.07776 9.0419C6.03732 9.01275 6.00621 8.97249 5.98819 8.92601C5.97019 8.87953 5.96605 8.82882 5.97628 8.78004L6.26055 7.09218C6.27278 7.053 6.27512 7.01141 6.26736 6.97111C6.25962 6.93081 6.24202 6.89306 6.21613 6.86121L4.96357 5.66194C4.93035 5.62829 4.90703 5.58613 4.89616 5.5401C4.88531 5.49408 4.88733 5.44595 4.90201 5.40098C4.91668 5.35603 4.94346 5.31598 4.97938 5.28523C5.01532 5.25448 5.05901 5.23421 5.1057 5.22665L6.80245 4.97792C6.84468 4.97364 6.88503 4.95823 6.91936 4.93326C6.95371 4.90829 6.9808 4.87465 6.99788 4.83578L7.76185 3.29894C7.7823 3.25543 7.8145 3.21852 7.85483 3.19237C7.89516 3.1662 7.94201 3.15186 7.99007 3.15093C8.03812 3.15 8.08548 3.16254 8.12679 3.18713C8.1681 3.21171 8.20169 3.24737 8.22379 3.29006Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.22379 3.29006L8.98778 4.82689C9.00486 4.86577 9.03195 4.89941 9.06628 4.92437C9.10062 4.94935 9.14096 4.96476 9.18321 4.96903L10.88 5.22665C10.9285 5.23296 10.9742 5.25296 11.0117 5.28429C11.0493 5.31562 11.0772 5.35701 11.0921 5.4036C11.107 5.45019 11.1083 5.50007 11.0959 5.54739C11.0835 5.5947 11.0579 5.63752 11.0221 5.67082L9.76952 6.86121C9.75085 6.89684 9.74109 6.93646 9.74109 6.97669C9.74109 7.01692 9.75085 7.05655 9.76952 7.09218L10.0094 8.78004C10.0196 8.82882 10.0155 8.87953 9.99745 8.92601C9.97944 8.97249 9.94834 9.01275 9.90789 9.0419C9.86746 9.07105 9.81943 9.08784 9.76965 9.09024C9.71985 9.09264 9.67043 9.08055 9.62738 9.05543L8.11719 8.25591C8.07812 8.23825 8.03572 8.22912 7.99282 8.22912C7.94994 8.22912 7.90754 8.23825 7.86846 8.25591L6.35827 9.05543C6.31521 9.08055 6.2658 9.09264 6.21601 9.09024C6.16622 9.08784 6.11819 9.07105 6.07776 9.0419C6.03732 9.01275 6.00621 8.97249 5.98819 8.92601C5.97019 8.87953 5.96605 8.82882 5.97628 8.78004L6.26055 7.09218C6.27278 7.053 6.27512 7.01141 6.26736 6.97111C6.25962 6.93081 6.24202 6.89306 6.21613 6.86121L4.96357 5.66194C4.93035 5.62829 4.90703 5.58613 4.89616 5.5401C4.88531 5.49408 4.88733 5.44595 4.90201 5.40098C4.91668 5.35603 4.94346 5.31598 4.97938 5.28523C5.01532 5.25448 5.05901 5.23421 5.1057 5.22665L6.80245 4.97792C6.84468 4.97364 6.88503 4.95823 6.91936 4.93326C6.95371 4.90829 6.9808 4.87465 6.99788 4.83578L7.76185 3.29894C7.7823 3.25543 7.8145 3.21852 7.85483 3.19237C7.89516 3.1662 7.94201 3.15186 7.99007 3.15093C8.03812 3.15 8.08548 3.16254 8.12679 3.18713C8.1681 3.21171 8.20169 3.24737 8.22379 3.29006Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.17881 9.04517L0.726135 13.2933L3.39114 12.5793L4.10523 15.2443L6.23218 11.5602\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconUserBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 11.9999C14.7811 11.9999 17.0357 9.74532 17.0357 6.96418C17.0357 4.18304 14.7811 1.92847 12 1.92847C9.21887 1.92847 6.96429 4.18304 6.96429 6.96418C6.96429 9.74532 9.21887 11.9999 12 11.9999Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.9998 15.3569C7.46103 15.3569 3.56956 18.1283 1.92529 22.0712H22.0743C20.4301 18.1283 16.5386 15.3569 11.9998 15.3569Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 11.9999C14.7811 11.9999 17.0357 9.74532 17.0357 6.96418C17.0357 4.18304 14.7811 1.92847 12 1.92847C9.21887 1.92847 6.96429 4.18304 6.96429 6.96418C6.96429 9.74532 9.21887 11.9999 12 11.9999Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.9998 15.3569C7.46103 15.3569 3.56956 18.1283 1.92529 22.0712H22.0743C20.4301 18.1283 16.5386 15.3569 11.9998 15.3569Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconUserSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 7.99993C9.85409 7.99993 11.3571 6.49688 11.3571 4.64279C11.3571 2.78869 9.85409 1.28564 8 1.28564C6.1459 1.28564 4.64285 2.78869 4.64285 4.64279C4.64285 6.49688 6.1459 7.99993 8 7.99993Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.99988 10.238C4.97403 10.238 2.37972 12.0856 1.28354 14.7142H14.7162C13.6201 12.0856 11.0257 10.238 7.99988 10.238Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 7.99993C9.85409 7.99993 11.3571 6.49688 11.3571 4.64279C11.3571 2.78869 9.85409 1.28564 8 1.28564C6.1459 1.28564 4.64285 2.78869 4.64285 4.64279C4.64285 6.49688 6.1459 7.99993 8 7.99993Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.99988 10.238C4.97403 10.238 2.37972 12.0856 1.28354 14.7142H14.7162C13.6201 12.0856 11.0257 10.238 7.99988 10.238Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconUserAddPlusBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.78571 9.58918C11.0047 9.58918 12.8036 7.79032 12.8036 5.57132C12.8036 3.35233 11.0047 1.55347 8.78571 1.55347C6.56671 1.55347 4.76785 3.35233 4.76785 5.57132C4.76785 7.79032 6.56671 9.58918 8.78571 9.58918Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.78571 9.58918C11.0047 9.58918 12.8036 7.79032 12.8036 5.57132C12.8036 3.35233 11.0047 1.55347 8.78571 1.55347C6.56671 1.55347 4.76785 3.35233 4.76785 5.57132C4.76785 7.79032 6.56671 9.58918 8.78571 9.58918Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\td=\"M14.1763 15.2142C12.8521 13.7346 10.9276 12.8035 8.7857 12.8035C4.7915 12.8035 1.55356 16.0414 1.55356 20.0356V20.8392H13.6071C12.0538 20.8392 10.7946 19.58 10.7946 18.0267C10.7946 16.4734 12.0538 15.2142 13.6071 15.2142H14.1763Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M18.0268 13.6069V22.4462\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M13.6071 18.0266H22.4464\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.5982 20.8392H1.55356V20.0356C1.55356 16.0414 4.7915 12.8035 8.7857 12.8035C10.5745 12.8035 12.2116 13.4529 13.4741 14.5288\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconUserAddPlusSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.85713 6.39279C7.33646 6.39279 8.5357 5.19355 8.5357 3.71422C8.5357 2.23488 7.33646 1.03564 5.85713 1.03564C4.3778 1.03564 3.17856 2.23488 3.17856 3.71422C3.17856 5.19355 4.3778 6.39279 5.85713 6.39279Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.85713 6.39279C7.33646 6.39279 8.5357 5.19355 8.5357 3.71422C8.5357 2.23488 7.33646 1.03564 5.85713 1.03564C4.3778 1.03564 3.17856 2.23488 3.17856 3.71422C3.17856 5.19355 4.3778 6.39279 5.85713 6.39279Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\td=\"M9.45088 10.1428C8.56804 9.15641 7.28508 8.53564 5.85713 8.53564C3.19433 8.53564 1.03571 10.6943 1.03571 13.3571V13.8928H9.07142C8.03588 13.8928 7.19642 13.0533 7.19642 12.0178C7.19642 10.9823 8.03588 10.1428 9.07142 10.1428H9.45088Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.0179 9.07129V14.9641\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.07141 12.0178H14.9643\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.73213 13.8928H1.03571V13.3571C1.03571 10.6943 3.19433 8.53564 5.85713 8.53564C7.04967 8.53564 8.14107 8.9686 8.98275 9.68589\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconProductWarningCircleBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 22.9107C18.0259 22.9107 22.9107 18.0259 22.9107 11.9999C22.9107 5.97413 18.0259 1.08923 12 1.08923C5.97419 1.08923 1.08929 5.97413 1.08929 11.9999C1.08929 18.0259 5.97419 22.9107 12 22.9107Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 22.9107C18.0259 22.9107 22.9107 18.0259 22.9107 11.9999C22.9107 5.97413 18.0259 1.08923 12 1.08923C5.97419 1.08923 1.08929 5.97413 1.08929 11.9999C1.08929 18.0259 5.97419 22.9107 12 22.9107Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 6.96423V12.4196\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 17.0357C11.7682 17.0357 11.5804 16.8478 11.5804 16.6161C11.5804 16.3843 11.7682 16.1964 12 16.1964\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 17.0357C12.2318 17.0357 12.4196 16.8478 12.4196 16.6161C12.4196 16.3843 12.2318 16.1964 12 16.1964\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconProductWarningCircleSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.00001 15.2737C12.0173 15.2737 15.2738 12.0172 15.2738 7.99988C15.2738 3.98267 12.0173 0.726074 8.00001 0.726074C3.98279 0.726074 0.726196 3.98267 0.726196 7.99988C0.726196 12.0172 3.98279 15.2737 8.00001 15.2737Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.00001 15.2737C12.0173 15.2737 15.2738 12.0172 15.2738 7.99988C15.2738 3.98267 12.0173 0.726074 8.00001 0.726074C3.98279 0.726074 0.726196 3.98267 0.726196 7.99988C0.726196 12.0172 3.98279 15.2737 8.00001 15.2737Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 4.64282V8.27973\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.00001 11.3569C7.8455 11.3569 7.72025 11.2316 7.72025 11.0771C7.72025 10.9226 7.8455 10.7974 8.00001 10.7974\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 11.3569C8.15451 11.3569 8.27976 11.2316 8.27976 11.0771C8.27976 10.9226 8.15451 10.7974 8 10.7974\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconProductWarningTriangleBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10.5501 3.57497L1.72255 18.7079C1.06978 19.827 1.87696 21.2323 3.17247 21.2323H20.8276C22.1231 21.2323 22.9302 19.827 22.2774 18.7079L13.4499 3.57497C12.8022 2.46459 11.1978 2.46459 10.5501 3.57497Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10.5501 3.57497L1.72255 18.7079C1.06978 19.827 1.87696 21.2323 3.17247 21.2323H20.8276C22.1231 21.2323 22.9302 19.827 22.2774 18.7079L13.4499 3.57497C12.8022 2.46459 11.1978 2.46459 10.5501 3.57497Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 8.64307V14.0984\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 17.8752C11.7682 17.8752 11.5804 17.6873 11.5804 17.4555C11.5804 17.2237 11.7682 17.0359 12 17.0359\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 17.8752C12.2318 17.8752 12.4196 17.6873 12.4196 17.4555C12.4196 17.2237 12.2318 17.0359 12 17.0359\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconProductWarningTriangleSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"14\"\r\n\t\t\tviewBox=\"0 0 16 14\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.03338 1.38325L1.14836 11.4718C0.713177 12.2179 1.25129 13.1548 2.11497 13.1548H13.8851C14.7487 13.1548 15.2868 12.2179 14.8516 11.4718L8.96661 1.38325C8.53479 0.643001 7.4652 0.643001 7.03338 1.38325Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.03338 1.38325L1.14836 11.4718C0.713177 12.2179 1.25129 13.1548 2.11497 13.1548H13.8851C14.7487 13.1548 15.2868 12.2179 14.8516 11.4718L8.96661 1.38325C8.53479 0.643001 7.4652 0.643001 7.03338 1.38325Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 4.76196V8.39887\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.00001 10.9167C7.8455 10.9167 7.72025 10.7915 7.72025 10.6369C7.72025 10.4824 7.8455 10.3572 8.00001 10.3572\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8 10.9167C8.15451 10.9167 8.27976 10.7915 8.27976 10.6369C8.27976 10.4824 8.15451 10.3572 8 10.3572\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconAtmBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M16.6144 5.28564H7.38225C6.91873 5.28564 6.54297 5.66141 6.54297 6.12493V21.8615C6.54297 22.325 6.91873 22.7008 7.38225 22.7008H16.6144C17.0779 22.7008 17.4537 22.325 17.4537 21.8615V6.12493C17.4537 5.66141 17.0779 5.28564 16.6144 5.28564Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.9967 16.0914C13.1555 16.0914 14.0949 15.1521 14.0949 13.9932C14.0949 12.8344 13.1555 11.895 11.9967 11.895C10.8378 11.895 9.89844 12.8344 9.89844 13.9932C9.89844 15.1521 10.8378 16.0914 11.9967 16.0914Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M16.6144 5.28564H7.38225C6.91873 5.28564 6.54297 5.66141 6.54297 6.12493V21.8615C6.54297 22.325 6.91873 22.7008 7.38225 22.7008H16.6144C17.0779 22.7008 17.4537 22.325 17.4537 21.8615V6.12493C17.4537 5.66141 17.0779 5.28564 16.6144 5.28564Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.9967 16.0914C13.1555 16.0914 14.0949 15.1521 14.0949 13.9932C14.0949 12.8344 13.1555 11.895 11.9967 11.895C10.8378 11.895 9.89844 12.8344 9.89844 13.9932C9.89844 15.1521 10.8378 16.0914 11.9967 16.0914Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.44721 7.94329H2.04796C1.82803 7.94329 1.61712 7.85486 1.46162 7.69748C1.30611 7.54008 1.21875 7.3266 1.21875 7.104V2.06829C1.21875 1.8457 1.30611 1.63222 1.46162 1.47483C1.61712 1.31743 1.82803 1.229 2.04796 1.229H21.9487C22.1686 1.229 22.3794 1.31743 22.5351 1.47483C22.6905 1.63222 22.7779 1.8457 22.7779 2.06829V7.104C22.7779 7.3266 22.6905 7.54008 22.5351 7.69748C22.3794 7.85486 22.1686 7.94329 21.9487 7.94329H20.5495\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.9989 8.99533C11.883 8.99533 11.7891 8.90139 11.7891 8.78551C11.7891 8.66963 11.883 8.57568 11.9989 8.57568\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 8.99533C12.1159 8.99533 12.2098 8.90139 12.2098 8.78551C12.2098 8.66963 12.1159 8.57568 12 8.57568\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.9989 19.5031C11.883 19.5031 11.7891 19.4091 11.7891 19.2933C11.7891 19.1773 11.883 19.0835 11.9989 19.0835\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 19.5031C12.1159 19.5031 12.2098 19.4091 12.2098 19.2933C12.2098 19.1773 12.1159 19.0835 12 19.0835\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconAtmSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.0774 3.52393H4.92259C4.61358 3.52393 4.36307 3.77444 4.36307 4.08345V14.5745C4.36307 14.8835 4.61358 15.134 4.92259 15.134H11.0774C11.3863 15.134 11.6369 14.8835 11.6369 14.5745V4.08345C11.6369 3.77444 11.3863 3.52393 11.0774 3.52393Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.99998 10.7278C8.77252 10.7278 9.39878 10.1015 9.39878 9.32899C9.39878 8.55644 8.77252 7.93018 7.99998 7.93018C7.22743 7.93018 6.60117 8.55644 6.60117 9.32899C6.60117 10.1015 7.22743 10.7278 7.99998 10.7278Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.0774 3.52393H4.92259C4.61358 3.52393 4.36307 3.77444 4.36307 4.08345V14.5745C4.36307 14.8835 4.61358 15.134 4.92259 15.134H11.0774C11.3863 15.134 11.6369 14.8835 11.6369 14.5745V4.08345C11.6369 3.77444 11.3863 3.52393 11.0774 3.52393Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.99998 10.7278C8.77252 10.7278 9.39878 10.1015 9.39878 9.32899C9.39878 8.55644 8.77252 7.93018 7.99998 7.93018C7.22743 7.93018 6.60117 8.55644 6.60117 9.32899C6.60117 10.1015 7.22743 10.7278 7.99998 10.7278Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M2.29924 5.29552H1.3664C1.21979 5.29552 1.07918 5.23657 0.975509 5.13165C0.871839 5.02672 0.813599 4.8844 0.813599 4.736V1.37886C0.813599 1.23047 0.871839 1.08815 0.975509 0.983217C1.07918 0.878285 1.21979 0.819336 1.3664 0.819336H14.6336C14.7802 0.819336 14.9207 0.878285 15.0245 0.983217C15.1281 1.08815 15.1864 1.23047 15.1864 1.37886V4.736C15.1864 4.8844 15.1281 5.02672 15.0245 5.13165C14.9207 5.23657 14.7802 5.29552 14.6336 5.29552H13.7007\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.99999 5.99705C7.92273 5.99705 7.86011 5.93443 7.86011 5.85717C7.86011 5.77992 7.92273 5.71729 7.99999 5.71729\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.00003 5.99705C8.07729 5.99705 8.13991 5.93443 8.13991 5.85717C8.13991 5.77992 8.07729 5.71729 8.00003 5.71729\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.00005 13.0022C7.9228 13.0022 7.86017 12.9395 7.86017 12.8623C7.86017 12.785 7.9228 12.7224 8.00005 12.7224\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.00009 13.0022C8.07735 13.0022 8.13997 12.9395 8.13997 12.8623C8.13997 12.785 8.07735 12.7224 8.00009 12.7224\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconBankBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.60938 18.7141V9.48193H20.3951V18.7141H3.60938Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M21.9208 9.48189H2.08012C1.14012 9.48189 0.737262 8.45796 1.47583 7.97117L11.3962 1.47511C11.5793 1.36736 11.788 1.31055 12.0005 1.31055C12.213 1.31055 12.4216 1.36736 12.6048 1.47511L22.5251 7.97117C23.2637 8.45796 22.8608 9.48189 21.9208 9.48189Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M22.072 18.7139H1.92913C1.46561 18.7139 1.08984 19.0897 1.08984 19.5532V22.071C1.08984 22.5345 1.46561 22.9103 1.92913 22.9103H22.072C22.5354 22.9103 22.9113 22.5345 22.9113 22.071V19.5532C22.9113 19.0897 22.5354 18.7139 22.072 18.7139Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M21.9208 9.48189H2.08011C1.14012 9.48189 0.737262 8.45796 1.47583 7.97117L11.3962 1.47511C11.5793 1.36736 11.788 1.31055 12.0005 1.31055C12.213 1.31055 12.4216 1.36736 12.6048 1.47511L22.5251 7.97117C23.2637 8.45796 22.8608 9.48189 21.9208 9.48189Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M22.072 18.7139H1.92913C1.46561 18.7139 1.08984 19.0897 1.08984 19.5532V22.071C1.08984 22.5345 1.46561 22.9103 1.92913 22.9103H22.072C22.5354 22.9103 22.9113 22.5345 22.9113 22.071V19.5532C22.9113 19.0897 22.5354 18.7139 22.072 18.7139Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.60938 9.48193V18.7141\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.20312 9.48193V18.7141\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.7969 9.48193V18.7141\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M20.3945 9.48193V18.7141\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconBankSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M2.40479 12.4761V6.32129H13.5953V12.4761H2.40479Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.6136 6.32134H1.38643C0.759764 6.32134 0.491192 5.63872 0.983573 5.3142L7.59714 0.983486C7.71924 0.911656 7.85834 0.873779 8 0.873779C8.14166 0.873779 8.28076 0.911656 8.40286 0.983486L15.0164 5.3142C15.5088 5.63872 15.2402 6.32134 14.6136 6.32134Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.7143 12.4761H1.28572C0.976704 12.4761 0.726196 12.7266 0.726196 13.0356V14.7142C0.726196 15.0231 0.976704 15.2737 1.28572 15.2737H14.7143C15.0233 15.2737 15.2738 15.0231 15.2738 14.7142V13.0356C15.2738 12.7266 15.0233 12.4761 14.7143 12.4761Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.6136 6.32134H1.38646C0.759795 6.32134 0.491223 5.63872 0.983604 5.3142L7.59717 0.983486C7.71928 0.911656 7.85837 0.873779 8.00003 0.873779C8.1417 0.873779 8.28079 0.911656 8.40289 0.983486L15.0165 5.3142C15.5088 5.63872 15.2403 6.32134 14.6136 6.32134Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.7143 12.4761H1.28572C0.976704 12.4761 0.726196 12.7266 0.726196 13.0356V14.7142C0.726196 15.0231 0.976704 15.2737 1.28572 15.2737H14.7143C15.0233 15.2737 15.2738 15.0231 15.2738 14.7142V13.0356C15.2738 12.7266 15.0233 12.4761 14.7143 12.4761Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M2.40479 6.32129V12.4761\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.13492 6.32129V12.4761\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.86511 6.32129V12.4761\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M13.5952 6.32129V12.4761\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconBillingPaymentBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M16.8214 3.16064H3.16072C2.27312 3.16064 1.55357 3.85962 1.55357 4.72187V15.2601C1.55357 16.1224 2.27312 16.8214 3.16072 16.8214H16.8214C17.7091 16.8214 18.4286 16.1224 18.4286 15.2601V4.72187C18.4286 3.85962 17.7091 3.16064 16.8214 3.16064Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.99108 12C11.1006 12 12 11.1006 12 9.99111C12 8.8816 11.1006 7.98218 9.99108 7.98218C8.88157 7.98218 7.98215 8.8816 7.98215 9.99111C7.98215 11.1006 8.88157 12 9.99108 12Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M16.8214 3.16064H3.16072C2.27312 3.16064 1.55357 3.85962 1.55357 4.72187V15.2601C1.55357 16.1224 2.27312 16.8214 3.16072 16.8214H16.8214C17.7091 16.8214 18.4286 16.1224 18.4286 15.2601V4.72187C18.4286 3.85962 17.7091 3.16064 16.8214 3.16064Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.375 20.8392H20.8393C21.2655 20.8392 21.6744 20.6698 21.9757 20.3685C22.277 20.0671 22.4464 19.6583 22.4464 19.2321V8.78564\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.80788 10.3927C4.58599 10.3927 4.4061 10.2128 4.4061 9.9909C4.4061 9.769 4.58599 9.58911 4.80788 9.58911\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.80794 10.3927C5.02984 10.3927 5.20972 10.2128 5.20972 9.9909C5.20972 9.769 5.02984 9.58911 4.80794 9.58911\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M15.1743 10.3927C14.9524 10.3927 14.7725 10.2128 14.7725 9.9909C14.7725 9.769 14.9524 9.58911 15.1743 9.58911\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M15.1743 10.3927C15.3962 10.3927 15.5761 10.2128 15.5761 9.9909C15.5761 9.769 15.3962 9.58911 15.1743 9.58911\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.99108 12C11.1006 12 12 11.1006 12 9.99111C12 8.8816 11.1006 7.98218 9.99108 7.98218C8.88157 7.98218 7.98215 8.8816 7.98215 9.99111C7.98215 11.1006 8.88157 12 9.99108 12Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconBillingPaymentSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"14\"\r\n\t\t\tviewBox=\"0 0 16 14\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.2308 1H2.07692C1.48215 1 1 1.46838 1 2.04616V9.10769C1 9.68547 1.48215 10.1538 2.07692 10.1538H11.2308C11.8256 10.1538 12.3077 9.68547 12.3077 9.10769V2.04616C12.3077 1.46838 11.8256 1 11.2308 1Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.65386 6.92308C7.39733 6.92308 8.00002 6.32039 8.00002 5.57693C8.00002 4.83346 7.39733 4.23077 6.65386 4.23077C5.9104 4.23077 5.30771 4.83346 5.30771 5.57693C5.30771 6.32039 5.9104 6.92308 6.65386 6.92308Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.2308 1H2.07692C1.48215 1 1 1.46838 1 2.04616V9.10769C1 9.68547 1.48215 10.1538 2.07692 10.1538H11.2308C11.8256 10.1538 12.3077 9.68547 12.3077 9.10769V2.04616C12.3077 1.46838 11.8256 1 11.2308 1Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.00513\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M4.23077 12.8461H13.9231C14.2087 12.8461 14.4827 12.7326 14.6846 12.5307C14.8865 12.3288 15 12.0548 15 11.7692V4.76923\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.00513\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.18067 5.84614C3.03198 5.84614 2.91144 5.7256 2.91144 5.57691C2.91144 5.42822 3.03198 5.30768 3.18067 5.30768\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.00513\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.18069 5.84614C3.32939 5.84614 3.44993 5.7256 3.44993 5.57691C3.44993 5.42822 3.32939 5.30768 3.18069 5.30768\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.00513\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10.127 5.84614C9.97833 5.84614 9.85779 5.7256 9.85779 5.57691C9.85779 5.42822 9.97833 5.30768 10.127 5.30768\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.00513\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10.127 5.84614C10.2757 5.84614 10.3963 5.7256 10.3963 5.57691C10.3963 5.42822 10.2757 5.30768 10.127 5.30768\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.00513\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.65386 6.92308C7.39733 6.92308 8.00002 6.32039 8.00002 5.57693C8.00002 4.83346 7.39733 4.23077 6.65386 4.23077C5.9104 4.23077 5.30771 4.83346 5.30771 5.57693C5.30771 6.32039 5.9104 6.92308 6.65386 6.92308Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.00513\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconCoinsStackBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\td=\"M5.618 7.672a5.2 5.2 0 0 1 .895-1.273c.698-.734 1.576-1.266 2.445-1.653 1.746-.776 3.96-1.184 6.256-1.184l.267.002c-1.08-1.171-3.67-1.996-6.695-1.996-3.994 0-7.232 1.439-7.232 3.214 0 1.27 1.658 2.368 4.064 2.89\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\td=\"M5.625 7.66c-2.41-.522-4.071-1.62-4.071-2.892v9.643c0 1.186 1.448 2.228 3.616 2.785V9.589c0-.725.18-1.371.455-1.93\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M15.214 12.802c3.995 0 7.232-1.44 7.232-3.215s-3.238-3.214-7.232-3.214-7.232 1.44-7.232 3.214c0 1.776 3.238 3.215 7.232 3.215\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M15.214 12.803c3.995 0 7.232-1.439 7.232-3.214v9.643c0 1.768-3.214 3.214-7.232 3.214S7.982 21 7.982 19.232V9.589c0 1.775 3.238 3.214 7.232 3.214\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.982 9.59v9.642c0 1.768 3.214 3.214 7.232 3.214s7.232-1.446 7.232-3.214V9.589\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M22.446 14.41c0 1.768-3.214 3.215-7.232 3.215s-7.232-1.447-7.232-3.214M4.894 7.477c-2.009-.57-3.34-1.57-3.34-2.71 0-1.774 3.238-3.214 7.232-3.214 2.694 0 5.044.655 6.288 1.626m.14 9.625c3.995 0 7.232-1.44 7.232-3.215s-3.238-3.214-7.232-3.214-7.232 1.44-7.232 3.214 3.238 3.215 7.232 3.215\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M1.554 4.768v9.643c0 1.115 1.278 2.102 3.23 2.679\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M1.554 9.59c0 1.104 1.256 2.084 3.18 2.663\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconCoinsStackSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"20\"\r\n\t\t\tviewBox=\"0 0 20 20\"\r\n\t\t\twidth=\"20\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\td=\"M5.746 7.115c.161-.33.373-.614.596-.849.466-.489 1.05-.844 1.63-1.102 1.164-.517 2.64-.789 4.17-.789l.179.001c-.72-.78-2.447-1.33-4.464-1.33-2.663 0-4.821.959-4.821 2.142 0 .847 1.105 1.58 2.71 1.927\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\td=\"M5.75 7.106c-1.607-.347-2.714-1.08-2.714-1.928v6.429c0 .791.965 1.486 2.41 1.857V8.393c0-.484.12-.914.304-1.287\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.143 10.534c2.663 0 4.821-.96 4.821-2.143S14.806 6.25 12.143 6.25 7.32 7.208 7.32 8.39c0 1.184 2.159 2.143 4.822 2.143\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.143 10.536c2.663 0 4.821-.96 4.821-2.143v6.428c0 1.179-2.143 2.143-4.821 2.143S7.32 16 7.32 14.821V8.393c0 1.183 2.159 2.143 4.822 2.143\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7.321 8.393v6.428c0 1.179 2.143 2.143 4.822 2.143 2.678 0 4.821-.964 4.821-2.143V8.393\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M16.964 11.607c0 1.179-2.143 2.143-4.821 2.143s-4.822-.964-4.822-2.143M5.263 6.985c-1.34-.38-2.227-1.048-2.227-1.807 0-1.183 2.158-2.142 4.821-2.142 1.796 0 3.363.436 4.193 1.083m.093 6.417c2.663 0 4.821-.96 4.821-2.143 0-1.184-2.158-2.143-4.821-2.143S7.32 7.21 7.32 8.393s2.159 2.143 4.822 2.143\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.036 5.178v6.429c0 .743.852 1.402 2.154 1.786\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3.036 8.393c0 .737.837 1.39 2.12 1.776\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconCreditCardBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M22.9107 18.2946V9.90173H1.08929V18.2946C1.08929 19.2217 1.84082 19.9732 2.76787 19.9732H21.2322C22.1592 19.9732 22.9107 19.2217 22.9107 18.2946Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\td=\"M2.76787 4.02673H21.2322C22.1592 4.02673 22.9107 4.77826 22.9107 5.7053V9.90173H1.08929V5.7053C1.08929 4.77826 1.84082 4.02673 2.76787 4.02673Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M21.2322 4.02673H2.76787C1.84082 4.02673 1.08929 4.77826 1.08929 5.7053V18.2946C1.08929 19.2217 1.84082 19.9732 2.76787 19.9732H21.2322C22.1592 19.9732 22.9107 19.2217 22.9107 18.2946V5.7053C22.9107 4.77826 22.1592 4.02673 21.2322 4.02673Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M1.08929 9.90173H22.9107\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M16.1964 15.7767H18.7143\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconCreditCardSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"12\"\r\n\t\t\tviewBox=\"0 0 16 12\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M15.2738 10.1966V4.60132H0.726196V10.1966C0.726196 10.8146 1.22721 11.3156 1.84524 11.3156H14.1548C14.7728 11.3156 15.2738 10.8146 15.2738 10.1966Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\td=\"M1.84524 0.68457H14.1548C14.7728 0.68457 15.2738 1.18559 15.2738 1.80362V4.60124H0.726196V1.80362C0.726196 1.18559 1.22721 0.68457 1.84524 0.68457Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.1548 0.68457H1.84524C1.22721 0.68457 0.726196 1.18559 0.726196 1.80362V10.1965C0.726196 10.8145 1.22721 11.3155 1.84524 11.3155H14.1548C14.7728 11.3155 15.2738 10.8145 15.2738 10.1965V1.80362C15.2738 1.18559 14.7728 0.68457 14.1548 0.68457Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M0.726196 4.60132H15.2738\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10.7976 8.51782H12.4762\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconHelpChatBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.0006 22.9108C18.0265 22.9108 22.9113 18.026 22.9113 12.0001C22.9113 5.97425 18.0265 1.08936 12.0006 1.08936C5.97474 1.08936 1.08984 5.97425 1.08984 12.0001C1.08984 14.2842 1.7917 16.4043 2.9915 18.1566L1.08984 22.9108L7.04033 21.7207C8.52848 22.4816 10.2144 22.9108 12.0006 22.9108Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.0006 22.9108C18.0265 22.9108 22.9113 18.026 22.9113 12.0001C22.9113 5.97425 18.0265 1.08936 12.0006 1.08936C5.97474 1.08936 1.08984 5.97425 1.08984 12.0001C1.08984 14.2842 1.7917 16.4043 2.9915 18.1566L1.08984 22.9108L7.04033 21.7207C8.52848 22.4816 10.2144 22.9108 12.0006 22.9108Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12.0017 17.4555C11.7699 17.4555 11.582 17.2677 11.582 17.0359C11.582 16.8041 11.7699 16.6162 12.0017 16.6162\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 17.4555C12.2318 17.4555 12.4196 17.2677 12.4196 17.0359C12.4196 16.8041 12.2318 16.6162 12 16.6162\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M9.0625 9.48242C9.0625 7.86008 10.3777 6.54492 12 6.54492C13.6223 6.54492 14.9375 7.86008 14.9375 9.48242C14.9375 11.1048 13.6223 12.4199 12 12.4199V14.0985\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconHelpChatSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.00001 15.2737C12.0173 15.2737 15.2738 12.0172 15.2738 7.99988C15.2738 3.98267 12.0173 0.726074 8.00001 0.726074C3.98279 0.726074 0.726196 3.98267 0.726196 7.99988C0.726196 9.52261 1.1941 10.936 1.99397 12.1042L0.726196 15.2737L4.69319 14.4803C5.68529 14.9876 6.80924 15.2737 8.00001 15.2737Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.00001 15.2737C12.0173 15.2737 15.2738 12.0172 15.2738 7.99988C15.2738 3.98267 12.0173 0.726074 8.00001 0.726074C3.98279 0.726074 0.726196 3.98267 0.726196 7.99988C0.726196 9.52261 1.1941 10.936 1.99397 12.1042L0.726196 15.2737L4.69319 14.4803C5.68529 14.9876 6.80924 15.2737 8.00001 15.2737Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.00001 11.6367C7.8455 11.6367 7.72025 11.5115 7.72025 11.3569C7.72025 11.2024 7.8455 11.0771 8.00001 11.0771\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M8.00003 11.6367C8.15454 11.6367 8.27979 11.5115 8.27979 11.3569C8.27979 11.2024 8.15454 11.0771 8.00003 11.0771\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M6.04169 6.32137C6.04169 5.23981 6.91846 4.36304 8.00002 4.36304C9.08158 4.36304 9.95835 5.23981 9.95835 6.32137C9.95835 7.40293 9.08158 8.2797 8.00002 8.2797V9.39875\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { useId } from 'react';\r\n\r\nimport { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconHouseRefreshBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\tconst id = useId();\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<g clipPath={`url(#${id})`}>\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M20.805 6.375A10.44 10.44 0 0 0 12 1.553C6.23 1.553 1.554 6.23 1.554 12m1.642 5.625A10.44 10.44 0 0 0 12 22.446c5.77 0 10.446-4.677 10.446-10.446\"\r\n\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t\t/>\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M20.84 2.357v4.018h-4.02M3.16 21.643v-4.018h4.02\"\r\n\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t\t/>\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M8.786 15.625V10L12 6.786 15.214 10v5.625z\"\r\n\t\t\t\t\tfill={fill}\r\n\t\t\t\t/>\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M16.821 11.607 12 6.786l-4.821 4.821\"\r\n\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t\t/>\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M8.786 10v5.625h6.428V10M12 15.625v-2.41\"\r\n\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t\t/>\r\n\t\t\t</g>\r\n\t\t\t<defs>\r\n\t\t\t\t<clipPath id={id}>\r\n\t\t\t\t\t<path\r\n\t\t\t\t\t\td=\"M0 0h24v24H0z\"\r\n\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t/>\r\n\t\t\t\t</clipPath>\r\n\t\t\t</defs>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { useId } from 'react';\r\n\r\nimport { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconHouseRefreshSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\tconst id = useId();\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<g clipPath={`url(#${id})`}>\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M20.805 6.375A10.44 10.44 0 0 0 12 1.553C6.23 1.553 1.554 6.23 1.554 12m1.642 5.625A10.44 10.44 0 0 0 12 22.446c5.77 0 10.446-4.677 10.446-10.446\"\r\n\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t\t/>\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M20.84 2.357v4.018h-4.02M3.16 21.643v-4.018h4.02\"\r\n\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t\t/>\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M8.786 15.625V10L12 6.786 15.214 10v5.625z\"\r\n\t\t\t\t\tfill={fill}\r\n\t\t\t\t/>\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M16.821 11.607 12 6.786l-4.821 4.821\"\r\n\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t\t/>\r\n\t\t\t\t<path\r\n\t\t\t\t\td=\"M8.786 10v5.625h6.428V10M12 15.625v-2.41\"\r\n\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t\t/>\r\n\t\t\t</g>\r\n\t\t\t<defs>\r\n\t\t\t\t<clipPath id={id}>\r\n\t\t\t\t\t<path\r\n\t\t\t\t\t\td=\"M0 0h24v24H0z\"\r\n\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t/>\r\n\t\t\t\t</clipPath>\r\n\t\t\t</defs>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconMailCheckBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\td=\"M21.2321 12.1063C21.0057 12.264 20.7981 12.4565 20.6169 12.6829L17.806 16.1965H2.76785C2.32266 16.1965 1.89572 16.0196 1.58092 15.7049C1.26613 15.3901 1.08928 14.9631 1.08928 14.5179V2.76793C1.08928 2.32274 1.26613 1.89579 1.58092 1.581C1.89572 1.2662 2.32266 1.08936 2.76785 1.08936H19.5536C19.9987 1.08936 20.4258 1.2662 20.7405 1.581C21.0552 1.89579 21.2321 2.32274 21.2321 2.76793V12.1063Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M1.08928 3.60718L11.1607 10.3215L21.2321 3.60718\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M22.9107 14.5178L16.1964 22.9107L12.8393 20.3928\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M17.0357 16.1965H2.76785C1.8408 16.1965 1.08928 15.445 1.08928 14.5179V2.76793C1.08928 1.84088 1.8408 1.08936 2.76785 1.08936H19.5536C20.4806 1.08936 21.2321 1.84088 21.2321 2.76793V11.1608\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconMailCheckSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\td=\"M14.1548 8.07071C14.0038 8.17584 13.8654 8.30416 13.7446 8.4551L11.8707 10.7975H1.84524C1.54845 10.7975 1.26382 10.6796 1.05396 10.4697C0.844096 10.2599 0.726196 9.97525 0.726196 9.67846V1.84512C0.726196 1.54833 0.844096 1.2637 1.05396 1.05384C1.26382 0.843974 1.54845 0.726074 1.84524 0.726074H13.0357C13.3325 0.726074 13.6172 0.843974 13.827 1.05384C14.0368 1.2637 14.1548 1.54833 14.1548 1.84512V8.07071Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M0.726196 2.40479L7.44048 6.88098L14.1548 2.40479\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M15.2738 9.67847L10.7976 15.2737L8.55952 13.5951\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.3571 10.7975H1.84524C1.22721 10.7975 0.726196 10.2965 0.726196 9.67846V1.84512C0.726196 1.22709 1.22721 0.726074 1.84524 0.726074H13.0357C13.6538 0.726074 14.1548 1.22709 14.1548 1.84512V7.44036\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconMobilePhoneBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M18 0.857178H6.00001C5.54535 0.857178 5.10931 1.03779 4.78782 1.35928C4.46633 1.68077 4.28572 2.11681 4.28572 2.57146V21.4286C4.28572 21.8833 4.46633 22.3193 4.78782 22.6408C5.10931 22.9623 5.54535 23.1429 6.00001 23.1429H18C18.4547 23.1429 18.8907 22.9623 19.2122 22.6408C19.5337 22.3193 19.7143 21.8833 19.7143 21.4286V2.57146C19.7143 2.34634 19.67 2.12342 19.5838 1.91543C19.4976 1.70745 19.3714 1.51847 19.2122 1.35928C19.053 1.20009 18.864 1.07382 18.656 0.98767C18.448 0.901519 18.2251 0.857178 18 0.857178Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M18 0.857178H6.00001C5.54535 0.857178 5.10931 1.03779 4.78782 1.35928C4.46633 1.68077 4.28572 2.11681 4.28572 2.57146V21.4286C4.28572 21.8833 4.46633 22.3193 4.78782 22.6408C5.10931 22.9623 5.54535 23.1429 6.00001 23.1429H18C18.4547 23.1429 18.8907 22.9623 19.2122 22.6408C19.5337 22.3193 19.7143 21.8833 19.7143 21.4286V2.57146C19.7143 2.34634 19.67 2.12342 19.5838 1.91543C19.4976 1.70745 19.3714 1.51847 19.2122 1.35928C19.053 1.20009 18.864 1.07382 18.656 0.98767C18.448 0.901519 18.2251 0.857178 18 0.857178Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.1429 18.8572H12.8572\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconMobilePhoneSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 12 16\"\r\n\t\t\twidth=\"12\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10 0.571533H2C1.6969 0.571533 1.40621 0.691941 1.19188 0.906268C0.977555 1.1206 0.857147 1.41129 0.857147 1.71439V14.2858C0.857147 14.5889 0.977555 14.8796 1.19188 15.0939C1.40621 15.3083 1.6969 15.4287 2 15.4287H10C10.3031 15.4287 10.5938 15.3083 10.8081 15.0939C11.0225 14.8796 11.1429 14.5889 11.1429 14.2858V1.71439C11.1429 1.56431 11.1133 1.4157 11.0559 1.27704C10.9984 1.13838 10.9143 1.01239 10.8081 0.906268C10.702 0.800144 10.576 0.715962 10.4374 0.658528C10.2987 0.601094 10.1501 0.571533 10 0.571533Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M10 0.571533H2C1.6969 0.571533 1.40621 0.691941 1.19188 0.906268C0.977555 1.1206 0.857147 1.41129 0.857147 1.71439V14.2858C0.857147 14.5889 0.977555 14.8796 1.19188 15.0939C1.40621 15.3083 1.6969 15.4287 2 15.4287H10C10.3031 15.4287 10.5938 15.3083 10.8081 15.0939C11.0225 14.8796 11.1429 14.5889 11.1429 14.2858V1.71439C11.1429 1.56431 11.1133 1.4157 11.0559 1.27704C10.9984 1.13838 10.9143 1.01239 10.8081 0.906268C10.702 0.800144 10.576 0.715962 10.4374 0.658528C10.2987 0.601094 10.1501 0.571533 10 0.571533Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M5.42857 12.5715H6.57143\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconMonetaBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.6505 12L21.1747 1.50114L21.1747 22.4988L11.6505 12Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M3 2V22L12 12L3 2Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M12 12L3 2V22L12 12ZM12 12L21 2V22L16.5 17L14.25 14.5\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconMonetaSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 14 16\"\r\n\t\t\twidth=\"14\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M1 1V15L7 8L1 1Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M7 8L1 1V15L7 8ZM7 8L13 1V15L10 11.5L8.5 9.75\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconShieldCheckBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M20.0357 2.35718H3.96429C3.0767 2.35718 2.35715 3.07673 2.35715 3.96432V8.26413C2.35715 14.3343 6.24139 19.7233 12 21.6429C17.7586 19.7233 21.6429 14.3343 21.6429 8.26413V3.96432C21.6429 3.07673 20.9233 2.35718 20.0357 2.35718Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M20.0357 2.35718H3.96429C3.0767 2.35718 2.35715 3.07673 2.35715 3.96432V8.26413C2.35715 14.3343 6.24139 19.7233 12 21.6429C17.7586 19.7233 21.6429 14.3343 21.6429 8.26413V3.96432C21.6429 3.07673 20.9233 2.35718 20.0357 2.35718Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M16.8214 7.17871L10.3929 14.4109L7.17859 12.0001\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconShieldCheckSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"20\"\r\n\t\t\tviewBox=\"0 0 20 20\"\r\n\t\t\twidth=\"20\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M15.3572 3.57153H4.64287C4.05114 3.57153 3.57144 4.05123 3.57144 4.64296V7.5095C3.57144 11.5563 6.16093 15.149 10 16.4287C13.839 15.149 16.4286 11.5563 16.4286 7.5095V4.64296C16.4286 4.05123 15.9489 3.57153 15.3572 3.57153Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M15.3572 3.57153H4.64287C4.05114 3.57153 3.57144 4.05123 3.57144 4.64296V7.5095C3.57144 11.5563 6.16093 15.149 10 16.4287C13.839 15.149 16.4286 11.5563 16.4286 7.5095V4.64296C16.4286 4.05123 15.9489 3.57153 15.3572 3.57153Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M13.2143 6.78589L8.92859 11.6073L6.78574 10.0002\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconSuitcaseBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M21.4269 6H2.56975C1.62298 6 0.855469 6.76752 0.855469 7.71429V21.4286C0.855469 22.3754 1.62298 23.1429 2.56975 23.1429H21.4269C22.3737 23.1429 23.1412 22.3754 23.1412 21.4286V7.71429C23.1412 6.76752 22.3737 6 21.4269 6Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M21.4269 6H2.56975C1.62298 6 0.855469 6.76752 0.855469 7.71429V21.4286C0.855469 22.3754 1.62298 23.1429 2.56975 23.1429H21.4269C22.3737 23.1429 23.1412 22.3754 23.1412 21.4286V7.71429C23.1412 6.76752 22.3737 6 21.4269 6Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M17.1412 5.99979V2.57122C17.1412 2.11656 16.9606 1.68053 16.6391 1.35904C16.3176 1.03755 15.8816 0.856934 15.4269 0.856934H8.56975C8.11509 0.856934 7.67906 1.03755 7.35757 1.35904C7.03609 1.68053 6.85547 2.11656 6.85547 2.57122V5.99979\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconSuitcaseSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"16\"\r\n\t\t\tviewBox=\"0 0 16 16\"\r\n\t\t\twidth=\"16\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.2857 4H1.71427C1.08309 4 0.571411 4.51168 0.571411 5.14286V14.2857C0.571411 14.9169 1.08309 15.4286 1.71427 15.4286H14.2857C14.9169 15.4286 15.4286 14.9169 15.4286 14.2857V5.14286C15.4286 4.51168 14.9169 4 14.2857 4Z\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M14.2857 4H1.71427C1.08309 4 0.571411 4.51168 0.571411 5.14286V14.2857C0.571411 14.9169 1.08309 15.4286 1.71427 15.4286H14.2857C14.9169 15.4286 15.4286 14.9169 15.4286 14.2857V5.14286C15.4286 4.51168 14.9169 4 14.2857 4Z\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M11.4286 3.99986V1.71415C11.4286 1.41104 11.3081 1.12035 11.0938 0.906024C10.8795 0.691697 10.5888 0.571289 10.2857 0.571289H5.71427C5.41116 0.571289 5.12047 0.691697 4.90614 0.906024C4.69182 1.12035 4.57141 1.41104 4.57141 1.71415V3.99986\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconWalletBig = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M22.071 12.84h-5.875a.84.84 0 0 0-.839.839v3.357c0 .463.376.84.84.84h5.874a.84.84 0 0 0 .84-.84v-3.357a.84.84 0 0 0-.84-.84\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\td=\"M1.09 8.643v12.59a1.68 1.68 0 0 0 1.678 1.678h15.946a1.68 1.68 0 0 0 1.679-1.679v-3.357h-4.197a.84.84 0 0 1-.839-.84V13.68a.84.84 0 0 1 .84-.84h4.196V9.482a1.68 1.68 0 0 0-1.679-1.678h-1.678V3.607H6.125a5.036 5.036 0 0 0-5.036 5.036\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M22.071 12.84h-5.875a.84.84 0 0 0-.839.839v3.357c0 .463.376.84.84.84h5.874a.84.84 0 0 0 .84-.84v-3.357a.84.84 0 0 0-.84-.84\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M20.393 17.875v3.357a1.68 1.68 0 0 1-1.679 1.679H2.768a1.68 1.68 0 0 1-1.679-1.679V8.642a5.036 5.036 0 0 1 5.036-5.035h10.91v4.197\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M20.393 12.84V9.481a1.68 1.68 0 0 0-1.679-1.678H6.125\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t\tstrokeWidth=\"1.5\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { type IconProductSvgProps } from '@/components/iconProduct/types';\r\n\r\nexport const IconWalletSmall = (props: IconProductSvgProps) => {\r\n\tconst { fill, stroke } = props;\r\n\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"20\"\r\n\t\t\tviewBox=\"0 0 20 20\"\r\n\t\t\twidth=\"20\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\td=\"M16.714 10.56h-3.916a.56.56 0 0 0-.56.56v2.237c0 .31.25.56.56.56h3.916a.56.56 0 0 0 .56-.56V11.12a.56.56 0 0 0-.56-.56\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\td=\"M2.726 7.762v8.393a1.12 1.12 0 0 0 1.12 1.119h10.63a1.12 1.12 0 0 0 1.12-1.12v-2.237h-2.798a.56.56 0 0 1-.56-.56V11.12c0-.309.25-.56.56-.56h2.797V8.322a1.12 1.12 0 0 0-1.119-1.119h-1.119V4.405H6.083a3.357 3.357 0 0 0-3.357 3.357\"\r\n\t\t\t\tfill={fill}\r\n\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M16.714 10.56h-3.916a.56.56 0 0 0-.56.56v2.237c0 .31.25.56.56.56h3.916a.56.56 0 0 0 .56-.56V11.12a.56.56 0 0 0-.56-.56\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M15.595 13.917v2.238a1.12 1.12 0 0 1-1.119 1.119H3.846a1.12 1.12 0 0 1-1.12-1.12V7.763a3.357 3.357 0 0 1 3.357-3.357h7.274v2.797\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t\t<path\r\n\t\t\t\td=\"M15.595 10.56V8.32a1.12 1.12 0 0 0-1.119-1.119H6.083\"\r\n\t\t\t\tstroke={stroke}\r\n\t\t\t\tstrokeLinecap=\"round\"\r\n\t\t\t\tstrokeLinejoin=\"round\"\r\n\t\t\t/>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","export enum IconProductType {\r\n\tatm = 'atm',\r\n\tbank = 'bank',\r\n\tbill = 'bill',\r\n\tbillingPayment = 'billingPayment',\r\n\tcheck = 'check',\r\n\tcoinsStack = 'coinsStack',\r\n\tcreditCard = 'creditCard',\r\n\tgraphIncrease = 'graphIncrease',\r\n\thelpChat = 'helpChat',\r\n\thouseRefresh = 'houseRefresh',\r\n\tinformation = 'information',\r\n\tloginPassword = 'loginPassword',\r\n\tmailCheck = 'mailCheck',\r\n\tmobilePhone = 'mobilePhone',\r\n\tmoneta = 'moneta',\r\n\tmoneyBag = 'moneyBag',\r\n\tpasswordLock = 'passwordLock',\r\n\tpeople = 'people',\r\n\tpiggyBank = 'piggyBank',\r\n\treward = 'reward',\r\n\tshieldCheck = 'shieldCheck',\r\n\tsuitcase = 'suitcase',\r\n\tuser = 'user',\r\n\tuserAddPlus = 'userAddPlus',\r\n\twallet = 'wallet',\r\n\twarningCircle = 'warningCircle',\r\n\twarningTriangle = 'warningTriangle',\r\n}\r\n\r\nexport enum IconProductSize {\r\n\tbig = 'big',\r\n\tsmall = 'small',\r\n}\r\n\r\nexport enum IconProductVariant {\r\n\tactive = 'active',\r\n\tdefault = 'default',\r\n}\r\n\r\nexport enum IconProductHighlightType {\r\n\tdefault = 'default',\r\n\tdefaultInverse = 'defaultInverse',\r\n}\r\n\r\nexport interface IconProductSvgProps {\r\n\tfill: string;\r\n\tstroke: string;\r\n}\r\n","export const iconProductSizeBig = '1.5rem';\r\nexport const iconProductSizeSmall = '1rem';\r\n","import { css } from '@emotion/react';\r\n\r\nimport { iconProductSizeBig, iconProductSizeSmall } from '@/components/iconProduct/constants';\r\nimport { styled, type ChooseColor } from '@/utils';\r\n\r\nimport { IconProductHighlightType, IconProductSize } from './types';\r\n\r\ninterface WrapperProps {\r\n\t$chooseColor: ChooseColor;\r\n\t$highlightType?: IconProductHighlightType;\r\n\t$size: IconProductSize;\r\n}\r\n\r\nconst getWrapperSize = (size: IconProductSize, hasHighlight: boolean): string => {\r\n\tswitch (true) {\r\n\t\tcase !hasHighlight && size === IconProductSize.big:\r\n\t\t\treturn iconProductSizeBig;\r\n\t\tcase !hasHighlight && size === IconProductSize.small:\r\n\t\t\treturn iconProductSizeSmall;\r\n\t\tcase hasHighlight:\r\n\t\t\treturn '3rem';\r\n\t\tdefault:\r\n\t\t\tthrow new TypeError('unexpected value of enum IconProductSize in iconProduct.style.ts getWrapperSize');\r\n\t}\r\n};\r\n\r\nconst getSvgSize = (size: IconProductSize): string => {\r\n\tswitch (size) {\r\n\t\tcase IconProductSize.big:\r\n\t\t\treturn iconProductSizeBig;\r\n\t\tcase IconProductSize.small:\r\n\t\t\treturn iconProductSizeSmall;\r\n\t\tdefault:\r\n\t\t\tthrow new TypeError('unexpected value of enum IconProductSize in iconProduct.style.ts getSvgSize');\r\n\t}\r\n};\r\n\r\nexport const Wrapper = styled.span<WrapperProps>`\r\n\tdisplay: inline-flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\r\n\t${({ $highlightType, $size }) => {\r\n\t\tconst size = getWrapperSize($size, $highlightType !== undefined);\r\n\r\n\t\treturn css`\r\n\t\t\twidth: ${size};\r\n\t\t\tmin-width: ${size};\r\n\t\t\theight: ${size};\r\n\t\t\tmin-height: ${size};\r\n\t\t`;\r\n\t}}\r\n\r\n\t${({ $chooseColor, $highlightType, theme }) => {\r\n\t\tif ($highlightType === undefined) {\r\n\t\t\treturn '';\r\n\t\t}\r\n\r\n\t\tlet backgroundColor: string;\r\n\t\tlet borderColor: string;\r\n\r\n\t\tswitch ($highlightType) {\r\n\t\t\tcase IconProductHighlightType.default:\r\n\t\t\t\tbackgroundColor = $chooseColor(theme.colors.bg.brand.default);\r\n\t\t\t\tborderColor = $chooseColor(theme.colors.border.brand.subtlest);\r\n\t\t\t\tbreak;\r\n\t\t\tcase IconProductHighlightType.defaultInverse:\r\n\t\t\t\tbackgroundColor = $chooseColor(theme.colors.surface.risen);\r\n\t\t\t\tborderColor = $chooseColor(theme.colors.border.brand.subtlest);\r\n\t\t\t\tbreak;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new TypeError('unexpected value of enum IconProductHighlightType in iconProduct.style.ts');\r\n\t\t}\r\n\r\n\t\treturn css`\r\n\t\t\tbackground-color: ${backgroundColor};\r\n\t\t\tborder-color: ${borderColor};\r\n\t\t\tborder-style: solid;\r\n\t\t\tborder-width: 1px;\r\n\t\t\tborder-radius: ${theme.borderRadius.full};\r\n\t\t`;\r\n\t}}\r\n\r\n\t/*\r\n\t Ensures that SVG width and height properly within the wrapper. \r\n\t Without this, every icon component would need to define these styles separately, which could easily be forgotten. \r\n\t*/\r\n\t> svg {\r\n\t\twidth: ${({ $size }) => getSvgSize($size)};\r\n\t\theight: ${({ $size }) => getSvgSize($size)};\r\n\t}\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { useMemo } from 'react';\r\n\r\nimport { IconBillBig } from '@/components/iconProduct/svg/bill/IconBillBig';\r\nimport { IconBillSmall } from '@/components/iconProduct/svg/bill/IconBillSmall';\r\nimport { IconCheckBig } from '@/components/iconProduct/svg/check/IconCheckBig';\r\nimport { IconCheckSmall } from '@/components/iconProduct/svg/check/IconCheckSmall';\r\nimport { IconGraphIncreaseBig } from '@/components/iconProduct/svg/graphIncrease/IconGraphIncreaseBig';\r\nimport { IconGraphIncreaseSmall } from '@/components/iconProduct/svg/graphIncrease/IconGraphIncreaseSmall';\r\nimport { IconProductInformationBig } from '@/components/iconProduct/svg/information/IconProductInformationBig';\r\nimport { IconProductInformationSmall } from '@/components/iconProduct/svg/information/IconProductInformationSmall';\r\nimport { IconLoginPasswordBig } from '@/components/iconProduct/svg/loginPassword/IconLoginPasswordBig';\r\nimport { IconLoginPasswordSmall } from '@/components/iconProduct/svg/loginPassword/IconLoginPasswordSmall';\r\nimport { IconMoneyBagBig } from '@/components/iconProduct/svg/moneyBag/IconMoneyBagBig';\r\nimport { IconMoneyBagSmall } from '@/components/iconProduct/svg/moneyBag/IconMoneyBagSmall';\r\nimport { IconProductPasswordLockBig } from '@/components/iconProduct/svg/passwordLock/IconProductPasswordLockBig';\r\nimport { IconProductPasswordLockSmall } from '@/components/iconProduct/svg/passwordLock/IconProductPasswordLockSmall';\r\nimport { IconPeopleBig } from '@/components/iconProduct/svg/people/IconPeopleBig';\r\nimport { IconPeopleSmall } from '@/components/iconProduct/svg/people/IconPeopleSmall';\r\nimport { IconPiggyBankBig } from '@/components/iconProduct/svg/piggyBank/IconPiggyBankBig';\r\nimport { IconPiggyBankSmall } from '@/components/iconProduct/svg/piggyBank/IconPiggyBankSmall';\r\nimport { IconProductRewardBig } from '@/components/iconProduct/svg/reward/IconProductRewardBig';\r\nimport { IconProductRewardSmall } from '@/components/iconProduct/svg/reward/IconProductRewardSmall';\r\nimport { IconUserBig } from '@/components/iconProduct/svg/user/IconUserBig';\r\nimport { IconUserSmall } from '@/components/iconProduct/svg/user/IconUserSmall';\r\nimport { IconUserAddPlusBig } from '@/components/iconProduct/svg/userAddPlus/IconUserAddPlusBig';\r\nimport { IconUserAddPlusSmall } from '@/components/iconProduct/svg/userAddPlus/IconUserAddPlusSmall';\r\nimport { IconProductWarningCircleBig } from '@/components/iconProduct/svg/warningCircle/IconProductWarningCircleBig';\r\nimport { IconProductWarningCircleSmall } from '@/components/iconProduct/svg/warningCircle/IconProductWarningCircleSmall';\r\nimport { IconProductWarningTriangleBig } from '@/components/iconProduct/svg/warningTriangle/IconProductWarningTriangleBig';\r\nimport { IconProductWarningTriangleSmall } from '@/components/iconProduct/svg/warningTriangle/IconProductWarningTriangleSmall';\r\nimport { useDesignSystem } from '@/contexts';\r\nimport { ColorScheme } from '@/types';\r\n\r\nimport { IconAtmBig } from './svg/atm/IconAtmBig';\r\nimport { IconAtmSmall } from './svg/atm/IconAtmSmall';\r\nimport { IconBankBig } from './svg/bank/IconBankBig';\r\nimport { IconBankSmall } from './svg/bank/IconBankSmall';\r\nimport { IconBillingPaymentBig } from './svg/billingPayment/IconBillingPaymentBig';\r\nimport { IconBillingPaymentSmall } from './svg/billingPayment/IconBillingPaymentSmall';\r\nimport { IconCoinsStackBig } from './svg/coinsStack/IconCoinsStackBig';\r\nimport { IconCoinsStackSmall } from './svg/coinsStack/IconCoinsStackSmall';\r\nimport { IconCreditCardBig } from './svg/creditCard/IconCreditCardBig';\r\nimport { IconCreditCardSmall } from './svg/creditCard/IconCreditCardSmall';\r\nimport { IconHelpChatBig } from './svg/helpChat/IconHelpChatBig';\r\nimport { IconHelpChatSmall } from './svg/helpChat/IconHelpChatSmall';\r\nimport { IconHouseRefreshBig } from './svg/houseRefresh/IconHouseRefreshBig';\r\nimport { IconHouseRefreshSmall } from './svg/houseRefresh/IconHouseRefreshSmall';\r\nimport { IconMailCheckBig } from './svg/mailCheck/IconMailCheckBig';\r\nimport { IconMailCheckSmall } from './svg/mailCheck/IconMailCheckSmall';\r\nimport { IconMobilePhoneBig } from './svg/mobilePhone/IconMobilePhoneBig';\r\nimport { IconMobilePhoneSmall } from './svg/mobilePhone/IconMobilePhoneSmall';\r\nimport { IconMonetaBig } from './svg/moneta/IconMonetaBig';\r\nimport { IconMonetaSmall } from './svg/moneta/IconMonetaSmall';\r\nimport { IconShieldCheckBig } from './svg/shieldCheck/IconShieldCheckBig';\r\nimport { IconShieldCheckSmall } from './svg/shieldCheck/IconShieldCheckSmall';\r\nimport { IconSuitcaseBig } from './svg/suitcase/IconSuitcaseBig';\r\nimport { IconSuitcaseSmall } from './svg/suitcase/IconSuitcaseSmall';\r\nimport { IconWalletBig } from './svg/wallet/IconWalletBig';\r\nimport { IconWalletSmall } from './svg/wallet/IconWalletSmall';\r\nimport { IconProductSize, IconProductType, IconProductVariant, type IconProductHighlightType } from './types';\r\n\r\nimport { Wrapper } from './IconProduct.style';\r\n\r\nexport interface IconProductProps {\r\n\tcolorScheme?: ColorScheme;\r\n\tfill?: string;\r\n\thighlightType?: IconProductHighlightType;\r\n\tsize: IconProductSize;\r\n\tstroke?: string;\r\n\ttype: IconProductType;\r\n\tvariant?: IconProductVariant | undefined;\r\n}\r\n\r\nexport const IconProduct = (props: IconProductProps) => {\r\n\tconst { fill: fillFromProps, highlightType, size, stroke: strokeFromProps, type, variant = IconProductVariant.default } = props;\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor, colorScheme } = useDesignSystem(props);\r\n\r\n\tconst fill = useMemo<string>(() => {\r\n\t\tswitch (true) {\r\n\t\t\tcase fillFromProps !== undefined:\r\n\t\t\t\treturn fillFromProps;\r\n\t\t\tcase variant === IconProductVariant.default && colorScheme === ColorScheme.light:\r\n\t\t\t\treturn theme.palette.white;\r\n\t\t\tcase variant === IconProductVariant.active && colorScheme === ColorScheme.light:\r\n\t\t\t\treturn theme.palette.blue200;\r\n\t\t\tcase variant === IconProductVariant.default && colorScheme === ColorScheme.dark:\r\n\t\t\tcase variant === IconProductVariant.active && colorScheme === ColorScheme.dark:\r\n\t\t\t\treturn 'none';\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new TypeError('unexpected enum value IconProductVariant in IconProduct fill');\r\n\t\t}\r\n\t}, [colorScheme, fillFromProps, theme.palette.blue200, theme.palette.white, variant]);\r\n\r\n\tconst stroke = useMemo<string>(() => {\r\n\t\tswitch (true) {\r\n\t\t\tcase strokeFromProps !== undefined:\r\n\t\t\t\treturn strokeFromProps;\r\n\t\t\tcase variant === IconProductVariant.default && colorScheme === ColorScheme.light:\r\n\t\t\tcase variant === IconProductVariant.active && colorScheme === ColorScheme.light:\r\n\t\t\t\treturn theme.palette.blue600;\r\n\t\t\tcase variant === IconProductVariant.default && colorScheme === ColorScheme.dark:\r\n\t\t\t\treturn theme.palette.grey400;\r\n\t\t\tcase variant === IconProductVariant.active && colorScheme === ColorScheme.dark:\r\n\t\t\t\treturn theme.palette.white;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new TypeError('unexpected enum value IconProductVariant in IconProduct stroke');\r\n\t\t}\r\n\t}, [colorScheme, strokeFromProps, theme.palette.blue600, theme.palette.grey400, theme.palette.white, variant]);\r\n\r\n\treturn (\r\n\t\t<Wrapper\r\n\t\t\t$chooseColor={chooseColor}\r\n\t\t\t$highlightType={highlightType}\r\n\t\t\t$size={size}\r\n\t\t>\r\n\t\t\t{(() => {\r\n\t\t\t\tswitch (true) {\r\n\t\t\t\t\tcase type === IconProductType.information && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconProductInformationBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.information && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconProductInformationSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.reward && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconProductRewardBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.reward && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconProductRewardSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.warningTriangle && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconProductWarningTriangleBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.warningTriangle && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconProductWarningTriangleSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.passwordLock && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconProductPasswordLockBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.passwordLock && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconProductPasswordLockSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.people && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconPeopleBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.people && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconPeopleSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.warningCircle && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconProductWarningCircleBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.warningCircle && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconProductWarningCircleSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.creditCard && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconCreditCardBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.creditCard && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconCreditCardSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.billingPayment && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconBillingPaymentBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.billingPayment && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconBillingPaymentSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.mobilePhone && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconMobilePhoneBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.mobilePhone && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconMobilePhoneSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.suitcase && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSuitcaseBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.suitcase && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconSuitcaseSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.bank && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconBankBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.bank && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconBankSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.atm && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconAtmBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.atm && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconAtmSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.moneta && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconMonetaBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.moneta && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconMonetaSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.helpChat && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconHelpChatBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.helpChat && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconHelpChatSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.mailCheck && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconMailCheckBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.mailCheck && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconMailCheckSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.check && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconCheckBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.check && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconCheckSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.bill && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconBillBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.bill && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconBillSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.piggyBank && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconPiggyBankBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.piggyBank && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconPiggyBankSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.user && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconUserBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.user && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconUserSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.userAddPlus && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconUserAddPlusBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.userAddPlus && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconUserAddPlusSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.moneyBag && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconMoneyBagBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.moneyBag && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconMoneyBagSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.loginPassword && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconLoginPasswordBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.loginPassword && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconLoginPasswordSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.shieldCheck && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconShieldCheckBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.shieldCheck && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconShieldCheckSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.wallet && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconWalletBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.wallet && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconWalletSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.coinsStack && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconCoinsStackBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.coinsStack && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconCoinsStackSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.graphIncrease && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconGraphIncreaseBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.graphIncrease && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconGraphIncreaseSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.houseRefresh && size === IconProductSize.big:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconHouseRefreshBig\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase type === IconProductType.houseRefresh && size === IconProductSize.small:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<IconHouseRefreshSmall\r\n\t\t\t\t\t\t\t\tfill={fill}\r\n\t\t\t\t\t\t\t\tstroke={stroke}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tdefault:\r\n\t\t\t\t\t\tthrow new Error('unexpected enum value IconProductType and IconProductSize in IconProduct');\r\n\t\t\t\t}\r\n\t\t\t})()}\r\n\t\t</Wrapper>\r\n\t);\r\n};\r\n","import { type HTMLProps, type ReactElement } from 'react';\r\n\r\n// NOTE: This approach is necessary so we can pass custom event handlers to the parent element without overwriting\r\n// the event handlers required by Floating UI.\r\nexport type TooltipRenderParent = (getParentProps: (userProps?: HTMLProps<Element>) => Record<string, unknown>) => ReactElement;\r\n\r\nexport enum TooltipPlacement {\r\n\tbottom = 'bottom',\r\n\tleft = 'left',\r\n\tright = 'right',\r\n\ttop = 'top',\r\n}\r\n\r\nexport interface TooltipDescriptor {\r\n\tbody: ReactElement | string;\r\n\tcloseButtonAriaLabel?: string;\r\n\ttitle?: ReactElement | string;\r\n\twidth?: TooltipWidth;\r\n}\r\n\r\nexport interface TooltipInfoDescriptor extends TooltipDescriptor {\r\n\ttriggerAriaLabel?: string;\r\n}\r\n\r\nexport enum TooltipInfoDisplayMethod {\r\n\tonlyTooltip = 'onlyTooltip',\r\n\twithNbsp = 'withNbsp',\r\n}\r\n\r\nexport interface TooltipDelays {\r\n\t/** ms */\r\n\tcloseDelay?: number;\r\n\t/** ms */\r\n\topenDelay?: number;\r\n}\r\n\r\nexport interface BaseTooltipInfoProps {\r\n\ttriggerAriaLabel?: string;\r\n}\r\n\r\nexport enum TooltipCloseReason {\r\n\tcloseButtonClick = 'closeButtonClick',\r\n\tcloseButtonKeyPress = 'closeButtonKeyPress',\r\n\tfocusLost = 'focusLost',\r\n}\r\n\r\nexport enum TooltipWidth {\r\n\tlg = 'lg',\r\n\tmd = 'md',\r\n}\r\n","import { css, type Theme } from '@emotion/react';\r\n\r\nimport { TooltipWidth } from '@/components/tooltip/types';\r\nimport { styled, type ChooseColor } from '@/utils';\r\n\r\nconst wrapperPadding = (theme: Theme) => css`\r\n\t${theme.spacing.sm}\r\n`;\r\n\r\ninterface WrapperProps {\r\n\t$chooseColor: ChooseColor;\r\n}\r\n\r\ninterface WrapperProps {\r\n\t$width: TooltipWidth;\r\n}\r\nexport const Wrapper = styled.div<WrapperProps>`\r\n\tposition: relative;\r\n\tz-index: 10;\r\n\tdisplay: block;\r\n\twidth: max-content;\r\n\tmax-width: ${({ $width }) => {\r\n\t\tswitch ($width) {\r\n\t\t\tcase TooltipWidth.md:\r\n\t\t\t\treturn '266px';\r\n\t\t\tcase TooltipWidth.lg:\r\n\t\t\t\treturn '296px';\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected value of enum TooltipWidth in tooltipFloatingElement.style.ts');\r\n\t\t}\r\n\t}};\r\n\tpadding: ${({ theme }) => wrapperPadding(theme)};\r\n\twhite-space: normal;\r\n\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.surface.risen)}!important;\r\n\tborder-radius: ${({ theme }) => theme.borderRadius.xs};\r\n\tbox-shadow: ${({ theme }) => theme.shadow.box.md};\r\n`;\r\n\r\nexport const TitleWrapper = styled.div`\r\n\tmargin-bottom: ${({ theme }) => theme.spacing.xxs};\r\n`;\r\n\r\nexport const BodyWrapper = styled.div`\r\n\ttext-align: left;\r\n\r\n\tul {\r\n\t\tpadding-left: 20px;\r\n\t\tmargin: 0;\r\n\t}\r\n`;\r\n\r\ninterface CloseButtonProps {\r\n\t$chooseColor: ChooseColor;\r\n}\r\n\r\nexport const CloseButton = styled.button<CloseButtonProps>`\r\n\tall: unset;\r\n\tposition: relative;\r\n\ttop: -${({ theme }) => wrapperPadding(theme)};\r\n\tright: -${({ theme }) => wrapperPadding(theme)};\r\n\tfloat: right;\r\n\tdisplay: flex;\r\n\tpadding: ${({ theme }) => wrapperPadding(theme)};\r\n\tcursor: pointer;\r\n\r\n\t&:focus-visible {\r\n\t\toutline-width: 3px;\r\n\t\toutline-style: solid;\r\n\t\toutline-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.focus)};\r\n\t\toutline-offset: -6px;\r\n\t\tborder-radius: ${(props) => props.theme.borderRadius.sm};\r\n\t}\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { type CSSProperties, type ReactNode, useState } from 'react';\r\n\r\nimport { IconSystemSize, IconSystemType } from '@/components/iconSystem';\r\nimport { IconSystem } from '@/components/iconSystem/index';\r\nimport { TooltipCloseReason, TooltipWidth } from '@/components/tooltip/types';\r\nimport { Typography } from '@/components/typography';\r\nimport { TypographyVariant } from '@/components/typography/types';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { FontWeight } from '@/theme';\r\n\r\nimport { BodyWrapper, CloseButton, TitleWrapper, Wrapper } from './TooltipFloatingElement.style';\r\n\r\nexport interface TooltipFloatingElementProps extends DesignSystemBaseProps {\r\n\tchildren: ReactNode;\r\n\tcloseButtonAriaLabel?: string;\r\n\tonClose: (closeReason: TooltipCloseReason) => void;\r\n\tstyle?: CSSProperties | undefined;\r\n\ttitle?: ReactNode;\r\n\twidth?: TooltipWidth;\r\n}\r\n\r\nexport const TooltipFloatingElement = (props: TooltipFloatingElementProps) => {\r\n\tconst { children, closeButtonAriaLabel, onClose, style, title, width = TooltipWidth.md } = props;\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor, colorScheme } = useDesignSystem(props);\r\n\r\n\t/** nextCloseReason` temporarily stores the reason for closing the tooltip, which is passed to the `onClose` callback. */\r\n\tconst [nextCloseReason, setNextCloseReason] = useState<TooltipCloseReason | undefined>(undefined);\r\n\r\n\treturn (\r\n\t\t<Wrapper\r\n\t\t\t$chooseColor={chooseColor}\r\n\t\t\t$width={width}\r\n\t\t\tstyle={style}\r\n\t\t>\r\n\t\t\t<CloseButton\r\n\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\taria-label={closeButtonAriaLabel}\r\n\t\t\t\tonClick={(event) => {\r\n\t\t\t\t\tevent.preventDefault();\r\n\t\t\t\t\tif (nextCloseReason === undefined) {\r\n\t\t\t\t\t\tthrow new Error('TooltipFloatingElement: nextCloseReason must be set before calling onClose');\r\n\t\t\t\t\t}\r\n\t\t\t\t\tonClose(nextCloseReason);\r\n\t\t\t\t\tsetNextCloseReason(undefined);\r\n\t\t\t\t}}\r\n\t\t\t\tonKeyDown={() => {\r\n\t\t\t\t\tsetNextCloseReason(TooltipCloseReason.closeButtonKeyPress);\r\n\t\t\t\t}}\r\n\t\t\t\tonMouseDown={() => {\r\n\t\t\t\t\tsetNextCloseReason(TooltipCloseReason.closeButtonClick);\r\n\t\t\t\t}}\r\n\t\t\t>\r\n\t\t\t\t<IconSystem\r\n\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\tsize={IconSystemSize.small}\r\n\t\t\t\t\ttype={IconSystemType.close}\r\n\t\t\t\t/>\r\n\t\t\t</CloseButton>\r\n\t\t\t<TitleWrapper>\r\n\t\t\t\t<Typography\r\n\t\t\t\t\tcolor={theme.colors.fg.neutral.default}\r\n\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\tweight={FontWeight.medium500}\r\n\t\t\t\t>\r\n\t\t\t\t\t{title}\r\n\t\t\t\t</Typography>\r\n\t\t\t</TitleWrapper>\r\n\t\t\t<BodyWrapper>\r\n\t\t\t\t<Typography\r\n\t\t\t\t\tcolor={theme.colors.fg.neutral.subtle}\r\n\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\tvariant={TypographyVariant.textXs}\r\n\t\t\t\t>\r\n\t\t\t\t\t{children}\r\n\t\t\t\t</Typography>\r\n\t\t\t</BodyWrapper>\r\n\t\t</Wrapper>\r\n\t);\r\n};\r\n","import { FloatingArrow } from '@floating-ui/react';\r\n\r\nimport { styled, type ChooseColor } from '@/utils';\r\n\r\ninterface ArrowProps {\r\n\t$chooseColor: ChooseColor;\r\n}\r\n\r\nexport const Arrow = styled(FloatingArrow)<ArrowProps>`\r\n\tfill: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.surface.risen)};\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport {\r\n\tarrow,\r\n\tautoUpdate,\r\n\tflip,\r\n\tFloatingPortal,\r\n\toffset,\r\n\tsafePolygon,\r\n\tshift,\r\n\tuseClick,\r\n\tuseDismiss,\r\n\tuseFloating,\r\n\tuseHover,\r\n\tuseInteractions,\r\n\tuseRole,\r\n\tuseTransitionStyles,\r\n} from '@floating-ui/react';\r\nimport { type FocusEventHandler, useCallback, useEffect, useRef, useState, type MutableRefObject } from 'react';\r\n\r\nimport { TooltipFloatingElement } from '@/components/tooltip/floatingElement/TooltipFloatingElement';\r\nimport { TooltipCloseReason, type TooltipDelays, type TooltipDescriptor, type TooltipPlacement, type TooltipRenderParent } from '@/components/tooltip/types';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\n\r\nimport { Arrow } from './TooltipGeneral.style';\r\n\r\nexport interface TooltipGeneralProps extends DesignSystemBaseProps, TooltipDelays {\r\n\tfloatingElement: TooltipDescriptor;\r\n\tonClose?: ((closeReason: TooltipCloseReason) => void) | undefined;\r\n\tonOpen?: (() => void) | undefined;\r\n\tplacement?: TooltipPlacement | undefined;\r\n\tportalRootElement?: HTMLElement | MutableRefObject<HTMLElement | null> | null;\r\n\trenderParent: TooltipRenderParent;\r\n}\r\n\r\nconst initialCloseReason = 'initialCloseReason';\r\n\r\nexport const TooltipGeneral = (props: TooltipGeneralProps) => {\r\n\tconst { closeDelay = 500, floatingElement, onClose, onOpen, openDelay = 200, placement, portalRootElement, renderParent } = props;\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor, colorScheme } = useDesignSystem(props);\r\n\r\n\tconst [closeReason, setCloseReason] = useState<TooltipCloseReason | typeof initialCloseReason | undefined>(initialCloseReason);\r\n\r\n\tconst isOpen = closeReason === undefined;\r\n\t// helper variable to eliminate the onClose call after the first component render\r\n\tconst zeroClosing = useRef<boolean>(false);\r\n\tuseEffect(() => {\r\n\t\tif (isOpen && onOpen !== undefined) {\r\n\t\t\tonOpen();\r\n\t\t}\r\n\t\tif (zeroClosing.current && !isOpen && onClose !== undefined) {\r\n\t\t\tif (closeReason === initialCloseReason) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t\tonClose(closeReason);\r\n\t\t}\r\n\t\tif (!zeroClosing.current) {\r\n\t\t\tzeroClosing.current = true;\r\n\t\t}\r\n\t}, [closeReason, isOpen, onClose, onOpen]);\r\n\r\n\tconst arrowRef = useRef(null);\r\n\r\n\tconst {\r\n\t\tcontext,\r\n\t\tfloatingStyles,\r\n\t\trefs: { floating: floatingRef, setFloating: setFloatingRef, setReference: setReferenceRef },\r\n\t} = useFloating({\r\n\t\topen: isOpen,\r\n\t\tonOpenChange: (value) => {\r\n\t\t\tsetCloseReason(value ? undefined : TooltipCloseReason.closeButtonClick);\r\n\t\t},\r\n\t\tplacement: placement,\r\n\t\tmiddleware: [\r\n\t\t\toffset(12),\r\n\t\t\tflip(),\r\n\t\t\tshift(),\r\n\t\t\tarrow({\r\n\t\t\t\telement: arrowRef,\r\n\t\t\t}),\r\n\t\t],\r\n\t\twhileElementsMounted: autoUpdate,\r\n\t});\r\n\r\n\tconst hover = useHover(context, {\r\n\t\tmove: false,\r\n\t\tmouseOnly: true,\r\n\t\tdelay: {\r\n\t\t\topen: openDelay,\r\n\t\t\tclose: closeDelay,\r\n\t\t},\r\n\t\thandleClose: safePolygon({\r\n\t\t\tbuffer: 1,\r\n\t\t\tblockPointerEvents: true,\r\n\t\t\trequireIntent: false,\r\n\t\t}),\r\n\t});\r\n\r\n\tconst click = useClick(context);\r\n\tconst dismiss = useDismiss(context);\r\n\tconst role = useRole(context, { role: 'tooltip' });\r\n\r\n\tconst { getFloatingProps, getReferenceProps } = useInteractions([hover, click, dismiss, role]);\r\n\r\n\tconst { styles: transitionStyles } = useTransitionStyles(context, {\r\n\t\tinitial: {\r\n\t\t\topacity: 0,\r\n\t\t\ttransform: 'scale(0.8)',\r\n\t\t},\r\n\t\tduration: {\r\n\t\t\topen: 100,\r\n\t\t},\r\n\t});\r\n\r\n\tconst handleFloatingWrapperBlur = useCallback<FocusEventHandler<HTMLDivElement>>(\r\n\t\t(event) => {\r\n\t\t\tif (floatingRef.current === null) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\r\n\t\t\tconst nextFocusedElement = event.relatedTarget as HTMLElement | null;\r\n\t\t\tif (nextFocusedElement === null) {\r\n\t\t\t\tsetCloseReason(TooltipCloseReason.focusLost);\r\n\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t\tif (!floatingRef.current.contains(nextFocusedElement)) {\r\n\t\t\t\tsetCloseReason(TooltipCloseReason.focusLost);\r\n\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t},\r\n\t\t[floatingRef],\r\n\t);\r\n\r\n\treturn (\r\n\t\t<>\r\n\t\t\t{renderParent((userProps) => getReferenceProps({ ref: setReferenceRef, 'aria-expanded': isOpen, ...userProps }))}\r\n\t\t\t{isOpen && (\r\n\t\t\t\t<FloatingPortal root={portalRootElement}>\r\n\t\t\t\t\t<div\r\n\t\t\t\t\t\t{...getFloatingProps({\r\n\t\t\t\t\t\t\tonBlur: handleFloatingWrapperBlur,\r\n\t\t\t\t\t\t\tref: setFloatingRef,\r\n\t\t\t\t\t\t\t// NOTE: `tooltip` role shouldn't ever receive focus.\r\n\t\t\t\t\t\t\trole: 'dialog',\r\n\t\t\t\t\t\t\tstyle: {\r\n\t\t\t\t\t\t\t\t...floatingStyles,\r\n\t\t\t\t\t\t\t\tzIndex: theme.zIndex.tooltip,\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t})}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t<TooltipFloatingElement\r\n\t\t\t\t\t\t\tcloseButtonAriaLabel={floatingElement.closeButtonAriaLabel}\r\n\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\tstyle={transitionStyles}\r\n\t\t\t\t\t\t\ttitle={floatingElement.title}\r\n\t\t\t\t\t\t\twidth={floatingElement.width}\r\n\t\t\t\t\t\t\tonClose={(closeReasonParam) => {\r\n\t\t\t\t\t\t\t\tsetCloseReason(closeReasonParam);\r\n\t\t\t\t\t\t\t}}\r\n\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t<Arrow\r\n\t\t\t\t\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t\t\t\t\tcontext={context}\r\n\t\t\t\t\t\t\t\theight={8}\r\n\t\t\t\t\t\t\t\tref={arrowRef}\r\n\t\t\t\t\t\t\t\tstyle={{}}\r\n\t\t\t\t\t\t\t\ttipRadius={2}\r\n\t\t\t\t\t\t\t\twidth={14}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t\t{floatingElement.body}\r\n\t\t\t\t\t\t</TooltipFloatingElement>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</FloatingPortal>\r\n\t\t\t)}\r\n\t\t</>\r\n\t);\r\n};\r\n","/* The class names are required for Liferay compatibility */\r\nexport const liferayClassNames = {\r\n\ttooltipInfoButton: 'dswTooltipInfoButton',\r\n\tlabel: 'dswLabel',\r\n};\r\n\r\nexport const htmlNbsp = '\\u00A0'; // \r\n","import { iconProductSizeSmall } from '@/components/iconProduct/constants';\r\nimport { styled, type ChooseColor } from '@/utils';\r\n\r\ninterface WrapperProps {\r\n\t$chooseColor: ChooseColor;\r\n}\r\n\r\nexport const Wrapper = styled.button<WrapperProps>`\r\n\tall: unset;\r\n\tdisplay: inline-block;\r\n\twidth: ${iconProductSizeSmall};\r\n\theight: ${iconProductSizeSmall};\r\n\tfont: inherit;\r\n\tvertical-align: text-top;\r\n\tcolor: inherit;\r\n\toutline: none;\r\n\r\n\t&:focus-visible {\r\n\t\toutline-width: 3px;\r\n\t\toutline-style: solid;\r\n\t\toutline-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.focus)};\r\n\t\toutline-offset: 2px;\r\n\t\tborder-radius: 50%;\r\n\t}\r\n`;\r\n","import { type MutableRefObject, useCallback, useRef } from 'react';\r\nimport { useBoolean } from 'usehooks-ts';\r\n\r\nimport { IconProductSize, IconProductType } from '@/components/iconProduct';\r\nimport { IconProduct } from '@/components/iconProduct/IconProduct';\r\nimport { IconProductVariant } from '@/components/iconProduct/index';\r\nimport { TooltipGeneral } from '@/components/tooltip/general/TooltipGeneral';\r\nimport { type BaseTooltipInfoProps, TooltipCloseReason, type TooltipDelays, type TooltipDescriptor, TooltipPlacement } from '@/components/tooltip/types';\r\nimport { liferayClassNames } from '@/constants';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { mergeRefs } from '@/utils';\r\n\r\nimport { Wrapper } from './TooltipInfo.style';\r\n\r\nexport interface TooltipInfoProps extends DesignSystemBaseProps, TooltipDelays, BaseTooltipInfoProps {\r\n\tfloatingElement: TooltipDescriptor;\r\n}\r\n\r\nexport const TooltipInfo = (props: TooltipInfoProps) => {\r\n\tconst { closeDelay = 500, floatingElement, openDelay = 200, triggerAriaLabel } = props;\r\n\r\n\tconst { chooseColor, colorScheme } = useDesignSystem(props);\r\n\r\n\tconst { setFalse: setClose, setTrue: setOpen, value: isOpen } = useBoolean(false);\r\n\tconst { setFalse: unsetHover, setTrue: setHover, value: isHover } = useBoolean(false);\r\n\r\n\tconst portalRootElementRef = useRef<HTMLDivElement>(null);\r\n\tconst wrapperRef = useRef<HTMLButtonElement | null>(null);\r\n\r\n\tconst handleTooltipGeneralClose = useCallback(\r\n\t\t(closeReason: TooltipCloseReason) => {\r\n\t\t\tsetClose();\r\n\t\t\t// NOTE: Scrolling on a touch device doesn't dispatch any events on the wrapper element,\r\n\t\t\t// but the menu closes correctly, so we just rely on that to unset the hovering state.\r\n\t\t\tunsetHover();\r\n\r\n\t\t\tif (closeReason === TooltipCloseReason.closeButtonKeyPress) {\r\n\t\t\t\twrapperRef.current?.focus();\r\n\t\t\t}\r\n\t\t},\r\n\t\t[setClose, unsetHover],\r\n\t);\r\n\r\n\treturn (\r\n\t\t<TooltipGeneral\r\n\t\t\tcloseDelay={closeDelay}\r\n\t\t\tcolorScheme={colorScheme}\r\n\t\t\tfloatingElement={floatingElement}\r\n\t\t\topenDelay={openDelay}\r\n\t\t\tplacement={TooltipPlacement.top}\r\n\t\t\tportalRootElement={portalRootElementRef}\r\n\t\t\trenderParent={(getParentProps) => {\r\n\t\t\t\tconst wrapperProps = getParentProps({\r\n\t\t\t\t\tonMouseEnter: setHover,\r\n\t\t\t\t\tonMouseLeave: unsetHover,\r\n\t\t\t\t});\r\n\t\t\t\tconst ref = mergeRefs(wrapperRef, wrapperProps.ref as MutableRefObject<HTMLButtonElement> | undefined);\r\n\r\n\t\t\t\treturn (\r\n\t\t\t\t\t<Wrapper\r\n\t\t\t\t\t\t{...wrapperProps}\r\n\t\t\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t\t\taria-label={triggerAriaLabel}\r\n\t\t\t\t\t\tclassName={liferayClassNames.tooltipInfoButton}\r\n\t\t\t\t\t\tref={ref}\r\n\t\t\t\t\t\ttype={'button'}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t<IconProduct\r\n\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\tsize={IconProductSize.small}\r\n\t\t\t\t\t\t\ttype={IconProductType.information}\r\n\t\t\t\t\t\t\tvariant={isOpen || isHover ? IconProductVariant.active : IconProductVariant.default}\r\n\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t<span ref={portalRootElementRef} />\r\n\t\t\t\t\t</Wrapper>\r\n\t\t\t\t);\r\n\t\t\t}}\r\n\t\t\tonClose={handleTooltipGeneralClose}\r\n\t\t\tonOpen={setOpen}\r\n\t\t/>\r\n\t);\r\n};\r\n","import { TooltipInfo } from '@/components/tooltip/info/TooltipInfo';\r\nimport { TooltipInfoDisplayMethod, type BaseTooltipInfoProps, type TooltipDescriptor } from '@/components/tooltip/types';\r\nimport { htmlNbsp } from '@/constants';\r\nimport { type DesignSystemBaseProps } from '@/contexts';\r\n\r\nexport interface TooltipInfoConditionalProps extends DesignSystemBaseProps, BaseTooltipInfoProps {\r\n\tdisplayMethod: TooltipInfoDisplayMethod;\r\n\tfloatingElement?: Partial<TooltipDescriptor>;\r\n}\r\n\r\nexport const TooltipInfoConditional = (props: TooltipInfoConditionalProps) => {\r\n\tconst { displayMethod, floatingElement, ...restProps } = props;\r\n\r\n\tif (floatingElement?.body === undefined) {\r\n\t\treturn null;\r\n\t}\r\n\r\n\tconst { body } = floatingElement;\r\n\r\n\treturn (\r\n\t\t<>\r\n\t\t\t{displayMethod === TooltipInfoDisplayMethod.withNbsp && htmlNbsp}\r\n\r\n\t\t\t<TooltipInfo\r\n\t\t\t\t{...restProps}\r\n\t\t\t\tfloatingElement={{\r\n\t\t\t\t\t...floatingElement,\r\n\t\t\t\t\tbody: body,\r\n\t\t\t\t}}\r\n\t\t\t/>\r\n\t\t</>\r\n\t);\r\n};\r\n","import { type TooltipInfoProps } from '@/components/tooltip/info/TooltipInfo';\r\nimport { type TooltipInfoDescriptor } from '@/components/tooltip/types';\r\n\r\ntype TooltipInfoDescriptorPropsSubset = Pick<TooltipInfoProps, 'floatingElement' | 'triggerAriaLabel'>;\r\n\r\nexport const mapTooltipInfoDescriptorToPropsSubset = <T extends TooltipInfoDescriptor | undefined>(\r\n\ttooltipInfoDescriptor: T,\r\n): T extends undefined ? undefined : TooltipInfoDescriptorPropsSubset => {\r\n\tif (tooltipInfoDescriptor === undefined) {\r\n\t\treturn undefined as T extends undefined ? undefined : TooltipInfoDescriptorPropsSubset;\r\n\t}\r\n\r\n\tconst { body, closeButtonAriaLabel, title, triggerAriaLabel, width } = tooltipInfoDescriptor;\r\n\r\n\treturn {\r\n\t\tfloatingElement: {\r\n\t\t\tbody: body,\r\n\t\t\ttitle: title,\r\n\t\t\tcloseButtonAriaLabel: closeButtonAriaLabel,\r\n\t\t\twidth: width,\r\n\t\t},\r\n\t\ttriggerAriaLabel: triggerAriaLabel,\r\n\t} as T extends undefined ? undefined : TooltipInfoDescriptorPropsSubset;\r\n};\r\n","import { MediaType } from '@/types';\r\nimport { styled, type ChooseColor } from '@/utils';\r\n\r\ninterface BaseProps {\r\n\t$chooseColor: ChooseColor;\r\n}\r\n\r\ninterface WrapperProps {\r\n\t$isDescriptionVisible: boolean;\r\n\t$mediaType: MediaType;\r\n}\r\n\r\nexport const Wrapper = styled.div<WrapperProps>`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\trow-gap: ${({ $isDescriptionVisible, $mediaType, theme }) => {\r\n\t\tswitch (true) {\r\n\t\t\tcase $mediaType === MediaType.desktop && !$isDescriptionVisible:\r\n\t\t\t\treturn theme.spacing.xxl;\r\n\t\t\tcase $mediaType === MediaType.mobile || $isDescriptionVisible:\r\n\t\t\t\treturn theme.spacing.sm;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected enum value MediaType in calculatorResultBox.style.ts Wrapper row-gap');\r\n\t\t}\r\n\t}};\r\n`;\r\n\r\ninterface BorderGradientWrapperProps extends BaseProps {}\r\n\r\nexport const BorderGradientWrapper = styled.div<BorderGradientWrapperProps>`\r\n\tpadding-top: 3px;\r\n\tpadding-bottom: 3px;\r\n\tbackground: ${({ theme }) => `linear-gradient(225deg, ${theme.palette.pink600} 10.24%, ${theme.palette.blue600} 100%)`};\r\n\tborder-radius: ${({ theme }) => theme.borderRadius.md};\r\n`;\r\n\r\ninterface ResultProps extends BaseProps {}\r\n\r\nexport const Result = styled.div<ResultProps>`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\trow-gap: ${({ theme }) => theme.spacing.xl};\r\n\tpadding: ${({ theme }) => theme.spacing.md};\r\n\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.surface.risen)};\r\n\tborder-radius: ${({ theme }) => theme.borderRadius.md};\r\n\r\n\t@media (min-width: ${({ theme }) => theme.breakpoints.sm}) {\r\n\t\tpadding: ${({ theme }) => theme.spacing.xl};\r\n\t}\r\n`;\r\n\r\ninterface TopWrapperProps extends BaseProps {}\r\n\r\nexport const TopWrapper = styled.div<TopWrapperProps>`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\trow-gap: ${({ theme }) => theme.spacing.lg};\r\n`;\r\n\r\ninterface HeaderWrapperProps extends BaseProps {}\r\n\r\nexport const HeaderWrapper = styled.div<HeaderWrapperProps>`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\trow-gap: ${({ theme }) => theme.spacing.xs};\r\n`;\r\n\r\ninterface HeaderTopWrapperProps extends BaseProps {}\r\n\r\nexport const HeaderTopWrapper = styled.div<HeaderTopWrapperProps>``;\r\n\r\ninterface HeaderMainWrapperProps extends BaseProps {}\r\n\r\nexport const HeaderMainWrapper = styled.div<HeaderMainWrapperProps>``;\r\n\r\ninterface HeaderBottomWrapperProps extends BaseProps {}\r\n\r\nexport const HeaderBottomWrapper = styled.div<HeaderBottomWrapperProps>``;\r\n\r\ninterface HrProps extends BaseProps {}\r\n\r\nexport const Hr = styled.div<HrProps>`\r\n\twidth: 100%;\r\n\theight: 0;\r\n\tpadding: 0;\r\n\tpadding-bottom: ${({ theme }) => theme.spacing.xs};\r\n\tborder-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.border.neutral.subtlest)};\r\n\tborder-style: solid;\r\n\tborder-width: 0;\r\n\tborder-top-width: 1px;\r\n`;\r\n\r\ninterface BodyItemsWrapperProps extends BaseProps {}\r\n\r\nexport const BodyItemsWrapper = styled.div<BodyItemsWrapperProps>`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\trow-gap: ${({ theme }) => theme.spacing.sm};\r\n`;\r\n\r\ninterface BodyItemWrapperProps extends BaseProps {}\r\n\r\nexport const BodyItemWrapper = styled.div<BodyItemWrapperProps>`\r\n\tdisplay: flex;\r\n\tflex: 1;\r\n\tflex-direction: row;\r\n\tcolumn-gap: ${({ theme }) => theme.spacing.md};\r\n`;\r\n\r\ninterface BodyItemLeftWrapperProps extends BaseProps {}\r\n\r\nexport const BodyItemLeftWrapper = styled.div<BodyItemLeftWrapperProps>`\r\n\tdisplay: flex;\r\n\tflex: fit-content;\r\n\talign-items: center;\r\n`;\r\n\r\ninterface BodyItemRightWrapperProps extends BaseProps {}\r\n\r\nexport const BodyItemRightWrapper = styled.div<BodyItemRightWrapperProps>`\r\n\tdisplay: flex;\r\n\tflex-basis: fit-content;\r\n\talign-items: center;\r\n`;\r\n\r\ninterface MainWrapperProps extends BaseProps {}\r\n\r\nexport const MainWrapper = styled.div<MainWrapperProps>`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\trow-gap: ${({ theme }) => theme.spacing.lg};\r\n`;\r\n","import { css } from '@emotion/react';\r\n\r\nimport { styled, type ChooseColor } from '@/utils';\r\n\r\nexport const checkboxSize = '1.5rem';\r\n\r\nexport const LabelStyled = styled.label`\r\n\tdisplay: flex;\r\n\tmargin: 0;\r\n`;\r\n\r\ninterface CheckboxStyledProps {\r\n\t$checkBackground: string;\r\n\t$chooseColor: ChooseColor;\r\n\t$focused: boolean;\r\n\t$invalid: boolean;\r\n}\r\n\r\nexport const CheckboxStyled = styled.input<CheckboxStyledProps>`\r\n\tposition: absolute;\r\n\twidth: 0;\r\n\theight: 0;\r\n\tpadding: 0;\r\n\tmargin: 0;\r\n\tcursor: pointer;\r\n\toutline: none;\r\n\tborder-width: 0;\r\n\tbox-shadow: none;\r\n\topacity: 0;\r\n\r\n\t${({ $chooseColor, $focused, $invalid, theme }) => {\r\n\t\tconst focusStyle = css`\r\n\t\t\toutline-width: 3px;\r\n\t\t\toutline-style: solid;\r\n\t\t\toutline-color: ${$invalid ? $chooseColor(theme.colors.fg.error) : $chooseColor(theme.colors.focus)};\r\n\t\t\toutline-offset: 2px;\r\n\t\t`;\r\n\r\n\t\treturn css`\r\n\t\t\t${$focused &&\r\n\t\t\tcss`\r\n\t\t\t\t& + span {\r\n\t\t\t\t\t${focusStyle}\r\n\t\t\t\t}\r\n\t\t\t`}\r\n\r\n\t\t\t&:focus-visible + span {\r\n\t\t\t\t${focusStyle}\r\n\t\t\t}\r\n\t\t`;\r\n\t}}\r\n\r\n\t&:not(:disabled):hover + span {\r\n\t\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.bg.brand.default)};\r\n\t\tborder-color: ${({ $chooseColor, $invalid, theme }) => ($invalid ? $chooseColor(theme.colors.fg.error) : $chooseColor(theme.colors.border.brand.bold))};\r\n\t}\r\n\r\n\t/* stylelint-disable-next-line no-descending-specificity */\r\n\t&:checked + span {\r\n\t\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.bg.brand.default)};\r\n\t\tbackground-image: url('data:image/svg+xml;base64,${({ $checkBackground }) => $checkBackground}');\r\n\t\tbackground-position: center;\r\n\t\tborder-color: ${({ $chooseColor, $invalid, theme }) => ($invalid ? $chooseColor(theme.colors.fg.error) : $chooseColor(theme.colors.border.brand.bold))};\r\n\t}\r\n\r\n\t/* stylelint-disable-next-line no-descending-specificity */\r\n\t&:disabled + span {\r\n\t\tcursor: auto;\r\n\t\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.bg.disabled)};\r\n\t\tborder-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.border.neutral.subtle)};\r\n\t}\r\n`;\r\n\r\ninterface SpanStyledProps {\r\n\t$chooseColor: ChooseColor;\r\n\t$invalid: boolean;\r\n}\r\n\r\nexport const SpanStyled = styled.span<SpanStyledProps>`\r\n\tbox-sizing: border-box;\r\n\tdisplay: inline-block;\r\n\twidth: ${checkboxSize};\r\n\theight: ${checkboxSize};\r\n\tmargin: 0;\r\n\tcursor: pointer;\r\n\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.bg.neutral.white)};\r\n\tbackground-repeat: no-repeat;\r\n\tbackground-position: center;\r\n\tborder-color: ${({ $chooseColor, $invalid, theme }) => ($invalid ? $chooseColor(theme.colors.fg.error) : $chooseColor(theme.colors.border.neutral.default))};\r\n\tborder-style: solid;\r\n\tborder-width: 1px;\r\n\tborder-radius: ${({ theme }) => theme.borderRadius.xxs};\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { forwardRef, useEffect, useMemo, useRef, type FocusEvent, type ChangeEvent } from 'react';\r\n\r\nimport { useDesignSystem } from '@/contexts';\r\nimport { type ColorScheme } from '@/types';\r\n\r\nimport { getCheckboxBaseCheckBase64 } from './svgHandler';\r\n\r\nimport { CheckboxStyled, LabelStyled, SpanStyled } from './CheckboxControl.style';\r\n\r\nexport interface CheckboxControlProps {\r\n\tariaLabel?: string;\r\n\tchecked?: boolean;\r\n\tcolorScheme?: ColorScheme;\r\n\tdisabled?: boolean;\r\n\tfocused?: boolean;\r\n\tid?: string;\r\n\tinvalid?: boolean;\r\n\tname: string;\r\n\tonBlur?: (event: FocusEvent<HTMLInputElement>) => void;\r\n\tonChange?: (event: ChangeEvent<HTMLInputElement>) => void;\r\n\tvalue?: string;\r\n}\r\n\r\nexport const CheckboxControl = forwardRef<HTMLInputElement, CheckboxControlProps>((props, ref) => {\r\n\tconst { ariaLabel, checked, disabled = false, focused = false, id, invalid = false, name, onBlur, onChange, value } = props;\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor } = useDesignSystem(props);\r\n\r\n\tconst localRef = useRef<HTMLInputElement>(null);\r\n\r\n\tuseEffect(() => {\r\n\t\tif (ref !== null) {\r\n\t\t\tif (typeof ref === 'function') {\r\n\t\t\t\tref(localRef.current);\r\n\t\t\t} else {\r\n\t\t\t\tref.current = localRef.current;\r\n\t\t\t}\r\n\t\t}\r\n\t}, [ref]);\r\n\r\n\tuseEffect(() => {\r\n\t\tif (localRef.current === null) {\r\n\t\t\tthrow new Error('CheckboxBase unexpected error: localRef.current is null');\r\n\t\t}\r\n\t}, []);\r\n\r\n\tconst checkBackground = useMemo(() => {\r\n\t\treturn getCheckboxBaseCheckBase64(disabled ? chooseColor(theme.colors.icon.neutral) : chooseColor(theme.colors.icon.brand));\r\n\t}, [disabled, theme, chooseColor]);\r\n\r\n\treturn (\r\n\t\t<LabelStyled>\r\n\t\t\t<CheckboxStyled\r\n\t\t\t\t$checkBackground={checkBackground}\r\n\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t$focused={focused}\r\n\t\t\t\t$invalid={invalid}\r\n\t\t\t\taria-label={ariaLabel}\r\n\t\t\t\tchecked={checked}\r\n\t\t\t\tdisabled={disabled}\r\n\t\t\t\tid={id}\r\n\t\t\t\tname={name}\r\n\t\t\t\tref={localRef}\r\n\t\t\t\ttype={'checkbox'}\r\n\t\t\t\tvalue={value}\r\n\t\t\t\tonBlur={onBlur}\r\n\t\t\t\tonChange={onChange}\r\n\t\t\t/>\r\n\t\t\t{/* style in firefox doesn't work without this extra span */}\r\n\t\t\t<SpanStyled\r\n\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t$invalid={invalid}\r\n\t\t\t/>\r\n\t\t</LabelStyled>\r\n\t);\r\n});\r\n\r\nCheckboxControl.displayName = 'CheckboxControl';\r\n","import { encode as encodeBase64 } from 'base-64';\r\n\r\nexport const getCheckboxBaseCheck = (color: string) => {\r\n\treturn `\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"1.5rem\" height=\"1.5rem\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n <path d=\"M7.75 12.75L10 15.25L16.25 8.75\" stroke=\"${color}\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>`;\r\n};\r\n\r\nexport const getCheckboxBaseCheckBase64 = (color: string) => {\r\n\treturn encodeBase64(getCheckboxBaseCheck(color));\r\n};\r\n","import { useId } from 'react';\r\n\r\nexport const useUniqueIdIfIsUndefined = (idParam: string | undefined) => {\r\n\t// id must exist because of the connection between the label and the radio (html label as a wrapper component has problems with tooltip)\r\n\tconst reactUniqueId = useId();\r\n\r\n\treturn idParam === undefined ? reactUniqueId : idParam;\r\n};\r\n","export enum CheckboxPosition {\r\n\tleft = 'left',\r\n\tright = 'right',\r\n}\r\n","import { css } from '@emotion/react';\r\n\r\nimport { iconProductSizeSmall } from '@/components/iconProduct/constants';\r\nimport { LabelTooltipPosition } from '@/types';\r\nimport { styled } from '@/utils';\r\n\r\nimport { CheckboxPosition } from '../types';\r\n\r\nimport { checkboxSize } from '../checkboxControl/CheckboxControl.style';\r\n\r\nexport const Wrapper = styled.div`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\trow-gap: ${({ theme }) => theme.spacing.xs};\r\n`;\r\n\r\ninterface ControlAndLabelWrapperProps {\r\n\t$position: CheckboxPosition;\r\n}\r\n\r\nexport const ControlAndLabelWrapper = styled.div<ControlAndLabelWrapperProps>`\r\n\tdisplay: flex;\r\n\tflex-direction: ${({ $position }) => {\r\n\t\tswitch ($position) {\r\n\t\t\tcase CheckboxPosition.left:\r\n\t\t\t\treturn 'row';\r\n\t\t\tcase CheckboxPosition.right:\r\n\t\t\t\treturn 'row-reverse';\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected enum values CheckboxPosition in checkbox.style.ts');\r\n\t\t}\r\n\t}};\r\n\tcolumn-gap: ${({ theme }) => theme.spacing.sm};\r\n\talign-items: start;\r\n\tjustify-content: left;\r\n`;\r\n\r\ninterface LabelAndTooltipWrapperProps {\r\n\t$tooltipPosition: LabelTooltipPosition;\r\n}\r\n\r\n// NOTE: When the checkbox label is multiline, the checkbox should be aligned with the first line of the label.\r\nexport const LabelAndTooltipWrapper = styled.div<LabelAndTooltipWrapperProps>`\r\n\tposition: relative;\r\n\ttop: calc((${checkboxSize} - 1lh) / 2);\r\n\r\n\t${(props) =>\r\n\t\tprops.$tooltipPosition === LabelTooltipPosition.rightCenter &&\r\n\t\tcss`\r\n\t\t\tdisplay: flex;\r\n\t\t\tgap: ${props.theme.spacing.xxs};\r\n\t\t\talign-items: center;\r\n\t\t`}\r\n`;\r\n\r\ninterface LabelStyledProps {\r\n\t$tooltipPosition: LabelTooltipPosition;\r\n}\r\n\r\nexport const LabelStyled = styled.label<LabelStyledProps>`\r\n\tposition: relative;\r\n\tdisplay: inline;\r\n\tmargin: 0;\r\n`;\r\n\r\ninterface TooltipWrapperProps {\r\n\t$tooltipPosition: LabelTooltipPosition;\r\n}\r\n\r\nexport const TooltipWrapper = styled.span<TooltipWrapperProps>`\r\n\tdisplay: inline-flex;\r\n\r\n\t${(props) =>\r\n\t\tprops.$tooltipPosition === LabelTooltipPosition.inline &&\r\n\t\tcss`\r\n\t\t\tposition: relative;\r\n\t\t\ttop: calc((1lh - ${iconProductSizeSmall}) / 2);\r\n\t\t\tvertical-align: top;\r\n\t\t`}\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { forwardRef, type ReactNode, useMemo } from 'react';\r\n\r\nimport { CheckboxControl, type CheckboxControlProps } from '@/components/checkboxField/checkboxControl/CheckboxControl';\r\nimport { TooltipInfo } from '@/components/tooltip';\r\nimport { mapTooltipInfoDescriptorToPropsSubset } from '@/components/tooltip/util';\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { VisuallyHidden } from '@/components/visuallyHidden';\r\nimport { liferayClassNames } from '@/constants';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { useUniqueIdIfIsUndefined } from '@/hooks/useUniqueIdIfIsUndefined';\r\nimport { FontWeight } from '@/theme';\r\nimport { type InputLabelPassthroughProps, LabelTooltipPosition } from '@/types';\r\nimport { isRenderable } from '@/utils';\r\n\r\nimport { CheckboxPosition } from '../types';\r\n\r\nimport { ControlAndLabelWrapper, LabelAndTooltipWrapper, LabelStyled, TooltipWrapper, Wrapper } from './Checkbox.style';\r\n\r\nexport interface CheckboxProps extends CheckboxControlProps, InputLabelPassthroughProps, DesignSystemBaseProps {\r\n\terrorMessage?: ReactNode;\r\n\tlabelColor?: string;\r\n\tposition?: CheckboxPosition;\r\n\ttooltipPosition?: LabelTooltipPosition;\r\n}\r\n\r\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>((props, ref) => {\r\n\tconst {\r\n\t\terrorMessage,\r\n\t\tid: idProp,\r\n\t\tinvalid = false,\r\n\t\tlabel,\r\n\t\tlabelAs,\r\n\t\tlabelColor: labelColorProp,\r\n\t\tlabelHiddenText,\r\n\t\tlabelId,\r\n\t\tlabelSuffix,\r\n\t\tposition = CheckboxPosition.left,\r\n\t\ttooltip,\r\n\t\ttooltipPosition = LabelTooltipPosition.inline,\r\n\t\t...otherProps\r\n\t} = props;\r\n\r\n\tconst { chooseColor, colorScheme } = useDesignSystem(props);\r\n\tconst theme = useTheme();\r\n\r\n\tconst id = useUniqueIdIfIsUndefined(idProp);\r\n\r\n\tconst labelColor = useMemo(() => {\r\n\t\tif (invalid) {\r\n\t\t\treturn chooseColor(theme.colors.fg.error);\r\n\t\t}\r\n\r\n\t\treturn labelColorProp === undefined ? chooseColor(theme.colors.fg.neutral.subtle) : labelColorProp;\r\n\t}, [invalid, labelColorProp, chooseColor, theme.colors.fg.neutral.subtle, theme.colors.fg.error]);\r\n\r\n\treturn (\r\n\t\t<Wrapper>\r\n\t\t\t<ControlAndLabelWrapper $position={position}>\r\n\t\t\t\t<CheckboxControl\r\n\t\t\t\t\t{...otherProps}\r\n\t\t\t\t\tid={id}\r\n\t\t\t\t\tinvalid={invalid}\r\n\t\t\t\t\tref={ref}\r\n\t\t\t\t/>\r\n\t\t\t\t{isRenderable(label) && (\r\n\t\t\t\t\t<Typography\r\n\t\t\t\t\t\tcolor={labelColor}\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t<LabelAndTooltipWrapper $tooltipPosition={tooltipPosition}>\r\n\t\t\t\t\t\t\t<LabelStyled\r\n\t\t\t\t\t\t\t\t$tooltipPosition={tooltipPosition}\r\n\t\t\t\t\t\t\t\tas={labelAs}\r\n\t\t\t\t\t\t\t\tclassName={liferayClassNames.label}\r\n\t\t\t\t\t\t\t\thtmlFor={labelAs === 'label' || labelAs === undefined ? id : undefined}\r\n\t\t\t\t\t\t\t\tid={labelId}\r\n\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t{label}\r\n\t\t\t\t\t\t\t\t{isRenderable(labelSuffix) && (\r\n\t\t\t\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\t\t\t\tcolor={theme.colors.fg.neutral.subtle}\r\n\t\t\t\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t\t\t{' '}\r\n\t\t\t\t\t\t\t\t\t\t{labelSuffix}\r\n\t\t\t\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t\t\t\t)}\r\n\t\t\t\t\t\t\t\t{labelHiddenText !== undefined && (\r\n\t\t\t\t\t\t\t\t\t<>\r\n\t\t\t\t\t\t\t\t\t\t{' '}\r\n\t\t\t\t\t\t\t\t\t\t<VisuallyHidden>{labelHiddenText}</VisuallyHidden>\r\n\t\t\t\t\t\t\t\t\t</>\r\n\t\t\t\t\t\t\t\t)}\r\n\t\t\t\t\t\t\t</LabelStyled>\r\n\r\n\t\t\t\t\t\t\t{tooltip !== undefined && (\r\n\t\t\t\t\t\t\t\t<>\r\n\t\t\t\t\t\t\t\t\t{tooltipPosition === LabelTooltipPosition.inline && ' '}\r\n\t\t\t\t\t\t\t\t\t<TooltipWrapper $tooltipPosition={tooltipPosition}>\r\n\t\t\t\t\t\t\t\t\t\t<TooltipInfo\r\n\t\t\t\t\t\t\t\t\t\t\t{...mapTooltipInfoDescriptorToPropsSubset(tooltip)}\r\n\t\t\t\t\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t\t\t\t</TooltipWrapper>\r\n\t\t\t\t\t\t\t\t</>\r\n\t\t\t\t\t\t\t)}\r\n\t\t\t\t\t\t</LabelAndTooltipWrapper>\r\n\t\t\t\t\t</Typography>\r\n\t\t\t\t)}\r\n\t\t\t</ControlAndLabelWrapper>\r\n\t\t\t{errorMessage !== undefined && (\r\n\t\t\t\t<Typography\r\n\t\t\t\t\tcolor={chooseColor(theme.colors.fg.error)}\r\n\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t>\r\n\t\t\t\t\t{errorMessage}\r\n\t\t\t\t</Typography>\r\n\t\t\t)}\r\n\t\t</Wrapper>\r\n\t);\r\n});\r\n\r\nCheckbox.displayName = 'Checkbox';\r\n","import { type ChangeEvent, useCallback } from 'react';\r\nimport { type RegisterOptions, useController } from 'react-hook-form';\r\n\r\nimport { Checkbox, type CheckboxProps } from './checkbox/Checkbox';\r\n\r\nexport interface CheckboxFieldProps extends Omit<CheckboxProps, 'onChange' | 'value'> {\r\n\toptions?: RegisterOptions;\r\n}\r\n\r\nexport const CheckboxField = (props: CheckboxFieldProps) => {\r\n\tconst { name, options, ...otherProps } = props;\r\n\tconst {\r\n\t\tfield: {\r\n\t\t\tonBlur,\r\n\t\t\tonChange,\r\n\t\t\tref,\r\n\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\r\n\t\t\tvalue,\r\n\t\t},\r\n\t\tfieldState: { error },\r\n\t} = useController({ name: name, rules: options });\r\n\r\n\t// NOTE: Ensures that validations are triggered immediately after changing value.\r\n\t// Using onblur validations with checkboxes is confusing otherwise.\r\n\tconst handleChange = useCallback(\r\n\t\t(event: ChangeEvent<HTMLInputElement>) => {\r\n\t\t\tonChange(event);\r\n\t\t\tonBlur();\r\n\t\t},\r\n\t\t[onBlur, onChange],\r\n\t);\r\n\r\n\treturn (\r\n\t\t<Checkbox\r\n\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\r\n\t\t\tchecked={value}\r\n\t\t\terrorMessage={error?.message}\r\n\t\t\tinvalid={Boolean(error)}\r\n\t\t\tname={name}\r\n\t\t\tref={ref}\r\n\t\t\tonBlur={onBlur}\r\n\t\t\tonChange={handleChange}\r\n\t\t\t{...otherProps}\r\n\t\t/>\r\n\t);\r\n};\r\n","import { iconProductSizeBig } from '@/components/iconProduct/constants';\r\nimport { styled, type ChooseColor } from '@/utils';\r\n\r\ninterface WrapperProps {\r\n\t$chooseColor: ChooseColor;\r\n\t$size: number;\r\n}\r\nexport const Wrapper = styled.div<WrapperProps>`\r\n\tposition: relative;\r\n\twidth: ${({ $size }) => $size}px;\r\n\theight: ${({ $size }) => $size}px;\r\n\tfont-size: initial; /* fix for nwp */\r\n\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.surface.risen)};\r\n\tborder-radius: 100%;\r\n`;\r\n\r\nexport const IconWrapper = styled.div`\r\n\tposition: absolute;\r\n\ttop: 50%;\r\n\tleft: 50%;\r\n\twidth: ${iconProductSizeBig};\r\n\theight: ${iconProductSizeBig};\r\n\ttransform: translate(-50%, -50%);\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { useId } from 'react';\r\n\r\nimport { IconProduct, IconProductSize, type IconProductType } from '@/components/iconProduct';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\n\r\nimport { IconWrapper, Wrapper } from './CircularProgressBar.style';\r\n\r\nconst size = 48;\r\nconst strokeWidth = 3;\r\n\r\nexport interface CircularProgressBarProps extends DesignSystemBaseProps {\r\n\ticonProduct: IconProductType;\r\n\tprogress: number;\r\n}\r\n\r\nexport const CircularProgressBar = (props: CircularProgressBarProps) => {\r\n\tconst { iconProduct, progress } = props;\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor, colorScheme } = useDesignSystem(props);\r\n\r\n\tconst radius = (size - strokeWidth) / 2;\r\n\tconst circumference = 2 * Math.PI * radius;\r\n\tconst offset = circumference - (progress / 100) * circumference;\r\n\r\n\tconst gradientId = useId();\r\n\r\n\treturn (\r\n\t\t<Wrapper\r\n\t\t\t$chooseColor={chooseColor}\r\n\t\t\t$size={size}\r\n\t\t>\r\n\t\t\t<svg\r\n\t\t\t\theight={size}\r\n\t\t\t\twidth={size}\r\n\t\t\t>\r\n\t\t\t\t<linearGradient\r\n\t\t\t\t\tgradientUnits={'userSpaceOnUse'}\r\n\t\t\t\t\tid={gradientId}\r\n\t\t\t\t\tx1={'24'}\r\n\t\t\t\t\tx2={'24'}\r\n\t\t\t\t\ty1={'48.3'}\r\n\t\t\t\t\ty2={'0'}\r\n\t\t\t\t>\r\n\t\t\t\t\t<stop\r\n\t\t\t\t\t\toffset={'0.108022'}\r\n\t\t\t\t\t\tstopColor={theme.palette.pink700}\r\n\t\t\t\t\t/>\r\n\t\t\t\t\t<stop\r\n\t\t\t\t\t\toffset={'1'}\r\n\t\t\t\t\t\tstopColor={theme.palette.blue600}\r\n\t\t\t\t\t/>\r\n\t\t\t\t</linearGradient>\r\n\r\n\t\t\t\t<circle\r\n\t\t\t\t\tcx={size / 2}\r\n\t\t\t\t\tcy={size / 2}\r\n\t\t\t\t\tfill={'none'}\r\n\t\t\t\t\tr={radius}\r\n\t\t\t\t\tstroke={`url(#${gradientId})`}\r\n\t\t\t\t\tstrokeDasharray={circumference}\r\n\t\t\t\t\tstrokeDashoffset={offset}\r\n\t\t\t\t\tstrokeLinecap={'round'}\r\n\t\t\t\t\tstrokeWidth={strokeWidth}\r\n\t\t\t\t\tstyle={{ transition: 'stroke-dashoffset 0.5s ease' }}\r\n\t\t\t\t\ttransform={`rotate(-90 ${size / 2} ${size / 2})`}\r\n\t\t\t\t/>\r\n\t\t\t</svg>\r\n\r\n\t\t\t<IconWrapper>\r\n\t\t\t\t<IconProduct\r\n\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\tsize={IconProductSize.big}\r\n\t\t\t\t\ttype={iconProduct}\r\n\t\t\t\t/>\r\n\t\t\t</IconWrapper>\r\n\t\t</Wrapper>\r\n\t);\r\n};\r\n","export type ComboBoxItem = boolean | number | object | string | null;\r\n\r\nexport enum ComboBoxItemOrderSource {\r\n\tformatter = 'formatter',\r\n\tvalue = 'value',\r\n}\r\n\r\nexport interface ComboBoxItemOrder {\r\n\tcompareFn?: (a: unknown, b: unknown) => number;\r\n\tsource: ComboBoxItemOrderSource;\r\n}\r\n\r\nexport enum ComboBoxValueType {\r\n\tcustom = 'custom',\r\n\titem = 'item',\r\n}\r\n\r\nexport type ComboBoxValue<TItem> =\r\n\t| {\r\n\t\t\tinput: string;\r\n\t\t\ttype: ComboBoxValueType.custom;\r\n\t }\r\n\t| {\r\n\t\t\titem: TItem;\r\n\t\t\ttype: ComboBoxValueType.item;\r\n\t }\r\n\t| null;\r\n","import { type ReactNode, type RefObject, useCallback, useEffect, useLayoutEffect, useRef, useState } from 'react';\r\nimport { useDebounceCallback, useResizeObserver } from 'usehooks-ts';\r\n\r\nconst debounceDelay = 500;\r\n\r\nexport const useAddonWidth = (addon: ReactNode, inputRef: RefObject<HTMLInputElement | null>) => {\r\n\tconst wrapperRef = useRef<HTMLDivElement>(null);\r\n\r\n\tconst [currentWidth, setCurrentWidth] = useState<number | undefined>(undefined);\r\n\tconst previousWidthRef = useRef<number | undefined>(undefined);\r\n\r\n\tconst addonDefined = Boolean(addon) || addon === 0;\r\n\r\n\tconst updateWidth = useCallback(() => {\r\n\t\tif (wrapperRef.current) {\r\n\t\t\tsetCurrentWidth((previousWidth) => {\r\n\t\t\t\tpreviousWidthRef.current = previousWidth;\r\n\r\n\t\t\t\treturn wrapperRef.current?.offsetWidth;\r\n\t\t\t});\r\n\t\t} else {\r\n\t\t\tsetCurrentWidth(undefined);\r\n\t\t}\r\n\t}, []);\r\n\r\n\tconst updateWidthDebounced = useDebounceCallback(updateWidth, debounceDelay, { maxWait: debounceDelay });\r\n\r\n\tuseLayoutEffect(() => {\r\n\t\tupdateWidth();\r\n\t}, [addonDefined, updateWidth]);\r\n\r\n\tuseEffect(() => {\r\n\t\tinputRef.current?.addEventListener('focus', updateWidth);\r\n\r\n\t\tconst element = inputRef.current;\r\n\r\n\t\treturn () => {\r\n\t\t\telement?.removeEventListener('focus', updateWidth);\r\n\t\t};\r\n\t}, [inputRef, updateWidth]);\r\n\r\n\tuseEffect(() => {\r\n\t\tif (addonDefined) {\r\n\t\t\twindow.addEventListener('resize', updateWidthDebounced);\r\n\t\t}\r\n\r\n\t\treturn () => {\r\n\t\t\tif (addonDefined) {\r\n\t\t\t\twindow.removeEventListener('resize', updateWidthDebounced);\r\n\t\t\t}\r\n\t\t};\r\n\t}, [addonDefined, updateWidthDebounced]);\r\n\r\n\tconst resizeObserverHandler = useCallback(() => {\r\n\t\tupdateWidth();\r\n\t}, [updateWidth]);\r\n\r\n\tuseResizeObserver({\r\n\t\tonResize: resizeObserverHandler,\r\n\t\tref: wrapperRef as RefObject<HTMLElement>,\r\n\t});\r\n\r\n\tconst previousWidth = previousWidthRef.current;\r\n\tconst resolvedWidth = addonDefined && currentWidth === 0 && previousWidth !== undefined && previousWidth > 0 ? previousWidth : currentWidth;\r\n\r\n\treturn {\r\n\t\twidth: resolvedWidth,\r\n\t\twrapperRef: wrapperRef,\r\n\t};\r\n};\r\n","import { css, type Theme } from '@emotion/react';\r\nimport { type Property } from 'csstype';\r\n\r\nimport { type FontWeight, resolveFontWeightValue } from '@/theme';\r\nimport { type ColorScheme, InputSize, type InputTextAlign } from '@/types';\r\nimport { type ChooseColor, getClampedFontSize, styled } from '@/utils';\r\n\r\nconst getInputSizeValue = (size: InputSize) => {\r\n\tswitch (size) {\r\n\t\tcase InputSize.md:\r\n\t\t\treturn '2.5rem';\r\n\t\tcase InputSize.xl:\r\n\t\t\treturn '3rem';\r\n\t\tdefault:\r\n\t\t\tthrow new Error('unexpected enum value InputSize in inputBase.style.ts');\r\n\t}\r\n};\r\n\r\ninterface WrapperProps {\r\n\t$halfWidth?: boolean;\r\n\t$size: InputSize;\r\n}\r\n\r\nexport const Wrapper = styled.div<WrapperProps>`\r\n\tposition: relative;\r\n\twidth: 100%;\r\n\tmax-height: ${(props) => getInputSizeValue(props.$size)};\r\n\tline-height: ${(props) => getInputSizeValue(props.$size)};\r\n\r\n\t${({ $halfWidth = false, theme }) =>\r\n\t\t$halfWidth &&\r\n\t\tcss`\r\n\t\t\t@media (min-width: ${theme.breakpoints.sm}) {\r\n\t\t\t\twidth: 50%;\r\n\t\t\t}\r\n\t\t`}\r\n`;\r\n\r\nconst fontStyles = (theme: Theme) => css`\r\n\tfont-family: ${theme.font.family.main};\r\n\tfont-size: ${getClampedFontSize(theme.font.size.body.md)};\r\n\tline-height: inherit;\r\n`;\r\n\r\nconst getPrefixSideInputPaddingValue = (theme: Theme, prefixWidth: number | undefined, hasThickBorder = false) =>\r\n\tprefixWidth === undefined ? 'initial' : `calc(${prefixWidth - (hasThickBorder ? 1 : 0)}px + ${theme.spacing.md})`;\r\n\r\nconst getSuffixSideInputPaddingValue = (theme: Theme, suffixWidth: number | undefined, hasThickBorder = false) =>\r\n\tsuffixWidth === undefined ? 'initial' : `calc(${suffixWidth - (hasThickBorder ? 4 : 3)}px + ${theme.spacing.md})`;\r\n\r\nconst getButtonSideInputPaddingValue = (theme: Theme, buttonWidth: number | undefined, hasThickBorder = false) =>\r\n\tbuttonWidth === undefined ? 'initial' : `calc(${buttonWidth - (hasThickBorder ? 4 : 3)}px + ${theme.spacing.md})`;\r\n\r\ninterface InputBaseStyledProps {\r\n\t$buttonWidth: number | undefined;\r\n\t$chooseColor: ChooseColor;\r\n\t$colorInput: Property.Color | undefined;\r\n\t$colorScheme: ColorScheme;\r\n\t$hasIcon: boolean;\r\n\t$invalid: boolean;\r\n\t$prefixWidth: number | undefined;\r\n\t$size: InputSize;\r\n\t$suffixWidth: number | undefined;\r\n\t$textAlign: InputTextAlign | undefined;\r\n\t$weight: FontWeight;\r\n}\r\n\r\nexport const InputBaseStyled = styled.input<InputBaseStyledProps>`\r\n\t${({ theme }) => fontStyles(theme)};\r\n\tbox-sizing: border-box;\r\n\twidth: 100%;\r\n\theight: ${(props) => getInputSizeValue(props.$size)};\r\n\tpadding: ${({ theme }) => theme.spacing.xs} ${({ theme }) => theme.spacing.sm};\r\n\tfont-weight: ${({ $weight, theme }) => resolveFontWeightValue(theme, $weight)};\r\n\tcolor: ${({ $chooseColor, $colorInput, theme }) => ($colorInput === undefined ? $chooseColor(theme.colors.fg.neutral.default) : $colorInput)};\r\n\ttext-align: ${({ $textAlign }) => $textAlign};\r\n\tletter-spacing: ${({ theme }) => theme.font.letterSpacing.body.md};\r\n\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.surface.risen)};\r\n\tborder: 1px solid ${({ $chooseColor, theme }) => $chooseColor(theme.colors.border.neutral.default)};\r\n\tborder-radius: ${({ theme }) => theme.borderRadius.xs};\r\n\r\n\t::placeholder {\r\n\t\tcolor: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.fg.neutral.subtle)};\r\n\t}\r\n\r\n\t&:disabled {\r\n\t\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.bg.disabled)};\r\n\t\tborder: 1px solid ${({ $chooseColor, theme }) => $chooseColor(theme.colors.border.disabled)};\r\n\t}\r\n\r\n\t&:focus-visible {\r\n\t\toutline-width: 3px;\r\n\t\toutline-style: solid;\r\n\t\toutline-color: ${({ $chooseColor, $invalid, theme }) => ($invalid ? $chooseColor(theme.colors.fg.error) : $chooseColor(theme.colors.focus))};\r\n\t\toutline-offset: 2px;\r\n\t}\r\n\r\n\t&:active {\r\n\t\tpadding: ${({ theme }) => Number.parseInt(theme.spacing.xs) - 1}px ${({ theme }) => Number.parseInt(theme.spacing.sm) - 1}px;\r\n\r\n\t\t${({ $hasIcon, theme }) =>\r\n\t\t\t$hasIcon &&\r\n\t\t\tcss`\r\n\t\t\t\tpadding-left: ${Number.parseInt(theme.spacing.xxl) - 1}px;\r\n\t\t\t`};\r\n\r\n\t\t${({ $prefixWidth, theme }) =>\r\n\t\t\tBoolean($prefixWidth) &&\r\n\t\t\tcss`\r\n\t\t\t\tpadding-left: ${getPrefixSideInputPaddingValue(theme, $prefixWidth, true)};\r\n\t\t\t`};\r\n\r\n\t\t${({ $suffixWidth, theme }) =>\r\n\t\t\tBoolean($suffixWidth) &&\r\n\t\t\tcss`\r\n\t\t\t\tpadding-right: ${getSuffixSideInputPaddingValue(theme, $suffixWidth, true)};\r\n\t\t\t`};\r\n\r\n\t\t${({ $buttonWidth, theme }) =>\r\n\t\t\tBoolean($buttonWidth) &&\r\n\t\t\tcss`\r\n\t\t\t\tpadding-right: ${getButtonSideInputPaddingValue(theme, $buttonWidth, true)};\r\n\t\t\t`};\r\n\r\n\t\tborder: 2px solid ${({ $chooseColor, theme }) => $chooseColor(theme.colors.border.brand.default)};\r\n\t}\r\n\r\n\t&:focus:not(:focus-visible) {\r\n\t\toutline: none;\r\n\t}\r\n\r\n\t${({ $chooseColor, $invalid, theme }) =>\r\n\t\t$invalid === true &&\r\n\t\tcss`\r\n\t\t\tpadding: ${Number.parseInt(theme.spacing.xs) - 1}px ${Number.parseInt(theme.spacing.sm) - 1}px;\r\n\t\t\tborder: 2px solid ${$chooseColor(theme.colors.fg.error)};\r\n\t\t`};\r\n\r\n\t${({ $hasIcon, theme }) =>\r\n\t\t$hasIcon &&\r\n\t\tcss`\r\n\t\t\tpadding-left: ${theme.spacing.xxl};\r\n\t\t`};\r\n\r\n\t${({ $hasIcon, $invalid, theme }) =>\r\n\t\t$hasIcon &&\r\n\t\t$invalid === true &&\r\n\t\tcss`\r\n\t\t\tpadding-left: ${Number.parseInt(theme.spacing.xxl) - 1}px;\r\n\t\t`};\r\n\r\n\t${({ $invalid, $prefixWidth, theme }) =>\r\n\t\tBoolean($prefixWidth) &&\r\n\t\tcss`\r\n\t\t\tpadding-left: ${getPrefixSideInputPaddingValue(theme, $prefixWidth, $invalid)};\r\n\t\t`};\r\n\r\n\t${({ $invalid, $suffixWidth, theme }) =>\r\n\t\tBoolean($suffixWidth) &&\r\n\t\tcss`\r\n\t\t\tpadding-right: ${getSuffixSideInputPaddingValue(theme, $suffixWidth, $invalid)};\r\n\t\t`};\r\n\r\n\t${({ $buttonWidth, $invalid, theme }) =>\r\n\t\tBoolean($buttonWidth) &&\r\n\t\tcss`\r\n\t\t\tpadding-right: ${getButtonSideInputPaddingValue(theme, $buttonWidth, $invalid)};\r\n\t\t`};\r\n`;\r\n\r\nexport const IconWrapper = styled.div`\r\n\tposition: absolute;\r\n\ttop: 50%;\r\n\tleft: 0;\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\tmargin-left: ${(props) => props.theme.spacing.sm};\r\n\ttransform: translateY(-50%);\r\n`;\r\n\r\ninterface PrefixWrapperProps {\r\n\t$chooseColor: ChooseColor;\r\n\t$prefixColor?: Property.Color;\r\n}\r\n\r\nexport const PrefixWrapper = styled.div<PrefixWrapperProps>`\r\n\tposition: absolute;\r\n\ttop: 0;\r\n\tleft: 0;\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\theight: 100%;\r\n\tmargin-left: ${({ theme }) => theme.spacing.sm};\r\n\t${({ theme }) => fontStyles(theme)};\r\n\tcolor: ${({ $chooseColor, $prefixColor, theme }) => ($prefixColor === undefined ? $chooseColor(theme.colors.fg.neutral.default) : $prefixColor)};\r\n`;\r\n\r\nexport const ButtonWrapper = styled.div`\r\n\tposition: absolute;\r\n\ttop: 0;\r\n\tright: 0;\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: flex-start;\r\n\twidth: fit-content;\r\n\theight: 100%;\r\n\tmargin-right: 4px;\r\n\t${({ theme }) => fontStyles(theme)};\r\n`;\r\n\r\ninterface SuffixWrapperProps {\r\n\t$chooseColor: ChooseColor;\r\n}\r\n\r\nexport const SuffixWrapper = styled.div<SuffixWrapperProps>`\r\n\tposition: absolute;\r\n\ttop: 0;\r\n\tright: 0;\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\theight: 100%;\r\n\r\n\t/* cannot use theme spacing here for proper alignment */\r\n\tmargin-right: 10px;\r\n\t${({ theme }) => fontStyles(theme)};\r\n\tcolor: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.fg.neutral.default)};\r\n\r\n\t::placeholder {\r\n\t\tcolor: ${({ theme }) => theme.palette.grey700};\r\n\t}\r\n`;\r\n","import { useMergeRefs } from '@floating-ui/react';\r\nimport { type Property } from 'csstype';\r\nimport {\r\n\ttype AriaAttributes,\r\n\tforwardRef,\r\n\ttype HTMLAttributes,\r\n\ttype HTMLInputAutoCompleteAttribute,\r\n\ttype HTMLInputTypeAttribute,\r\n\ttype KeyboardEventHandler,\r\n\ttype MouseEventHandler,\r\n\ttype ReactNode,\r\n\ttype RefAttributes,\r\n\tuseCallback,\r\n\tuseRef,\r\n\ttype FocusEvent,\r\n\ttype ChangeEvent,\r\n\ttype ClipboardEvent,\r\n} from 'react';\r\n\r\nimport { IconSystem, IconSystemSize, type IconSystemType } from '@/components/iconSystem';\r\nimport { useDesignSystem } from '@/contexts';\r\nimport { FontWeight } from '@/theme';\r\nimport { type FieldControlProps, InputSize, type InputTextAlign } from '@/types';\r\nimport { isRenderable } from '@/utils';\r\n\r\nimport { useAddonWidth } from './useAddonWidth';\r\n\r\nimport { ButtonWrapper, IconWrapper, InputBaseStyled, PrefixWrapper, SuffixWrapper, Wrapper } from './InputBase.style';\r\n\r\nexport interface InputBaseProps\r\n\textends\r\n\t\tRefAttributes<HTMLInputElement>,\r\n\t\tFieldControlProps,\r\n\t\tPick<\r\n\t\t\tAriaAttributes,\r\n\t\t\t| 'aria-activedescendant'\r\n\t\t\t| 'aria-autocomplete'\r\n\t\t\t| 'aria-controls'\r\n\t\t\t| 'aria-describedby'\r\n\t\t\t| 'aria-expanded'\r\n\t\t\t| 'aria-invalid'\r\n\t\t\t| 'aria-label'\r\n\t\t\t| 'aria-labelledby'\r\n\t\t\t| 'aria-required'\r\n\t\t> {\r\n\tariaLabel?: string;\r\n\tautoComplete?: HTMLInputAutoCompleteAttribute;\r\n\tbutton?: ReactNode;\r\n\tcolorInput?: Property.Color | undefined;\r\n\tdisabled?: boolean;\r\n\thalfWidth?: boolean;\r\n\ticon?: ReactNode;\r\n\ticonSystem?: IconSystemType;\r\n\tid?: string | undefined;\r\n\tisPastingDisabled?: boolean;\r\n\tmaxLength?: number;\r\n\tname: string;\r\n\tonBlur?: ((event: FocusEvent<HTMLInputElement>) => void) | undefined;\r\n\tonChange?: ((event: ChangeEvent<HTMLInputElement>) => void) | undefined;\r\n\tonClick?: MouseEventHandler;\r\n\tonFocus?: ((event: ChangeEvent<HTMLInputElement>) => void) | undefined;\r\n\tonKeyDown?: KeyboardEventHandler;\r\n\tplaceholder?: string;\r\n\tprefix?: ReactNode;\r\n\tprefixColor?: Property.Color;\r\n\trole?: HTMLAttributes<HTMLInputElement>['role'];\r\n\tsize?: InputSize;\r\n\tsuffix?: ReactNode;\r\n\ttextAlign?: InputTextAlign;\r\n\ttype?: HTMLInputTypeAttribute;\r\n\tvalue?: string;\r\n\tweight?: FontWeight;\r\n}\r\n\r\nexport const InputBase = forwardRef<HTMLInputElement, InputBaseProps>((props, forwardedRef) => {\r\n\tconst {\r\n\t\t'aria-describedby': ariaDescribedByAttribute,\r\n\t\t'aria-invalid': ariaInvalidAttribute,\r\n\t\t'aria-label': ariaLabelAttribute,\r\n\t\t'aria-labelledby': ariaLabelledByAttribute,\r\n\t\t'aria-required': ariaRequiredAttribute,\r\n\t\tariaLabel,\r\n\t\tbutton,\r\n\t\tcolorInput,\r\n\t\tcolorScheme: colorSchemeProp, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\tdescribedBy,\r\n\t\tdisabled,\r\n\t\thalfWidth,\r\n\t\ticon,\r\n\t\ticonSystem,\r\n\t\tid,\r\n\t\tinvalid = false,\r\n\t\tisPastingDisabled = false,\r\n\t\tlabelledBy,\r\n\t\tmaxLength,\r\n\t\tmediaType: mediaTypeProp, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\tname,\r\n\t\tonBlur,\r\n\t\tonChange,\r\n\t\tonClick,\r\n\t\tonFocus,\r\n\t\tonKeyDown,\r\n\t\tplaceholder,\r\n\t\tprefix,\r\n\t\tprefixColor,\r\n\t\trequired,\r\n\t\tsize = InputSize.md,\r\n\t\tsuffix,\r\n\t\ttextAlign,\r\n\t\ttype,\r\n\t\tvalue,\r\n\t\tweight = FontWeight.regular400,\r\n\t\t...otherProps\r\n\t} = props;\r\n\r\n\tconst { chooseColor, colorScheme } = useDesignSystem(props);\r\n\r\n\tconst inputRef = useRef<HTMLInputElement>(null);\r\n\tconst mergedRef = useMergeRefs([forwardedRef, inputRef]);\r\n\r\n\tconst { width: prefixWidth, wrapperRef: prefixWrapperRef } = useAddonWidth(prefix, inputRef);\r\n\tconst { width: suffixWidth, wrapperRef: suffixWrapperRef } = useAddonWidth(suffix, inputRef);\r\n\tconst { width: buttonWidth, wrapperRef: buttonWrapperRef } = useAddonWidth(button, inputRef);\r\n\r\n\tconst handlePaste = useCallback(\r\n\t\t(event: ClipboardEvent<HTMLInputElement>) => {\r\n\t\t\tif (isPastingDisabled) {\r\n\t\t\t\tevent.preventDefault();\r\n\t\t\t}\r\n\t\t},\r\n\t\t[isPastingDisabled],\r\n\t);\r\n\r\n\treturn (\r\n\t\t<Wrapper\r\n\t\t\t$halfWidth={halfWidth}\r\n\t\t\t$size={size}\r\n\t\t>\r\n\t\t\t{icon !== undefined && <IconWrapper>{icon}</IconWrapper>}\r\n\t\t\t{iconSystem !== undefined && (\r\n\t\t\t\t<IconWrapper>\r\n\t\t\t\t\t<IconSystem\r\n\t\t\t\t\t\tsize={IconSystemSize.big}\r\n\t\t\t\t\t\ttype={iconSystem}\r\n\t\t\t\t\t/>\r\n\t\t\t\t</IconWrapper>\r\n\t\t\t)}\r\n\r\n\t\t\t{isRenderable(prefix) && (\r\n\t\t\t\t<PrefixWrapper\r\n\t\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t\t$prefixColor={prefixColor}\r\n\t\t\t\t\tref={prefixWrapperRef}\r\n\t\t\t\t>\r\n\t\t\t\t\t{prefix}\r\n\t\t\t\t</PrefixWrapper>\r\n\t\t\t)}\r\n\r\n\t\t\t<InputBaseStyled\r\n\t\t\t\t$buttonWidth={buttonWidth}\r\n\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t$colorInput={colorInput}\r\n\t\t\t\t$colorScheme={colorScheme}\r\n\t\t\t\t$hasIcon={icon !== undefined || iconSystem !== undefined}\r\n\t\t\t\t$invalid={invalid}\r\n\t\t\t\t$prefixWidth={prefixWidth}\r\n\t\t\t\t$size={size}\r\n\t\t\t\t$suffixWidth={suffixWidth}\r\n\t\t\t\t$textAlign={textAlign}\r\n\t\t\t\t$weight={weight}\r\n\t\t\t\taria-describedby={ariaDescribedByAttribute === undefined ? describedBy : ariaDescribedByAttribute}\r\n\t\t\t\taria-invalid={ariaInvalidAttribute === undefined ? invalid : ariaInvalidAttribute}\r\n\t\t\t\taria-label={ariaLabelAttribute === undefined ? ariaLabel : ariaLabelAttribute}\r\n\t\t\t\taria-labelledby={ariaLabelledByAttribute === undefined ? labelledBy : ariaLabelledByAttribute}\r\n\t\t\t\taria-required={ariaRequiredAttribute === undefined ? required : ariaRequiredAttribute}\r\n\t\t\t\tdisabled={disabled}\r\n\t\t\t\tid={id}\r\n\t\t\t\tmaxLength={maxLength}\r\n\t\t\t\tname={name}\r\n\t\t\t\tplaceholder={placeholder}\r\n\t\t\t\tref={mergedRef}\r\n\t\t\t\ttype={type}\r\n\t\t\t\tvalue={value}\r\n\t\t\t\tonBlur={onBlur}\r\n\t\t\t\tonChange={onChange}\r\n\t\t\t\tonClick={onClick}\r\n\t\t\t\tonFocus={onFocus}\r\n\t\t\t\tonKeyDown={onKeyDown}\r\n\t\t\t\tonPaste={handlePaste}\r\n\t\t\t\t{...otherProps}\r\n\t\t\t/>\r\n\r\n\t\t\t{isRenderable(suffix) && (\r\n\t\t\t\t<SuffixWrapper\r\n\t\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t\tref={suffixWrapperRef}\r\n\t\t\t\t>\r\n\t\t\t\t\t{suffix}\r\n\t\t\t\t</SuffixWrapper>\r\n\t\t\t)}\r\n\r\n\t\t\t{isRenderable(button) && <ButtonWrapper ref={buttonWrapperRef}>{button}</ButtonWrapper>}\r\n\t\t</Wrapper>\r\n\t);\r\n});\r\n\r\nInputBase.displayName = 'InputBase';\r\n","import { makeFormatter } from 'afformative';\r\nimport { type ReactNode, useMemo } from 'react';\r\nimport { useIntl } from 'react-intl';\r\n\r\nimport { FormattedHtmlMessage } from '@/components/formattedMessage';\r\nimport { type MessageDescriptorWithPrimitiveValues } from '@/types';\r\n\r\n// eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-return\r\nexport const identityFormatter = makeFormatter<any, any>((value) => value);\r\n\r\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\r\nexport const jsonFormatter = makeFormatter<any, string>((value) => JSON.stringify(value));\r\n\r\n// eslint-disable-next-line @typescript-eslint/no-unnecessary-type-constraint\r\nexport const useMessageFormatter = <TInput extends unknown>(getMessage: (value: TInput) => MessageDescriptorWithPrimitiveValues | string) => {\r\n\tconst intl = useIntl();\r\n\r\n\treturn useMemo(\r\n\t\t() =>\r\n\t\t\tmakeFormatter<TInput, ReactNode, string>((value, suggestions) => {\r\n\t\t\t\tconst message = getMessage(value);\r\n\r\n\t\t\t\tif (typeof message === 'string') {\r\n\t\t\t\t\treturn message;\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (suggestions.includes('primitive')) {\r\n\t\t\t\t\treturn intl.formatMessage(message, { ...message.values, ...message.htmlValues });\r\n\t\t\t\t}\r\n\r\n\t\t\t\treturn (\r\n\t\t\t\t\t<FormattedHtmlMessage\r\n\t\t\t\t\t\t{...message}\r\n\t\t\t\t\t\thtmlValues={message.htmlValues}\r\n\t\t\t\t\t\tvalues={message.values}\r\n\t\t\t\t\t/>\r\n\t\t\t\t);\r\n\t\t\t}),\r\n\t\t[getMessage, intl],\r\n\t);\r\n};\r\n","import { styled, type ChooseColor } from '@/utils';\r\n\r\nexport const ComboBoxWrapper = styled.div`\r\n\tposition: relative;\r\n\twidth: 100%;\r\n`;\r\n\r\nexport interface MenuWrapperProps {\r\n\t$chooseColor: ChooseColor;\r\n\t$isOpen: boolean;\r\n}\r\n\r\nexport const MenuWrapper = styled.div<MenuWrapperProps>`\r\n\tposition: absolute;\r\n\ttop: 100%;\r\n\tz-index: 1;\r\n\tvisibility: ${({ $isOpen }) => ($isOpen ? 'visible' : 'hidden')};\r\n\twidth: 100%;\r\n\tmargin-top: ${({ theme }) => theme.spacing.xs};\r\n\tmargin-bottom: ${({ theme }) => theme.spacing.xs};\r\n\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.surface.risen)};\r\n\tborder-radius: ${({ theme }) => theme.borderRadius.xs};\r\n\tbox-shadow:\r\n\t\t0 4px 4px 0 rgb(28 101 253 / 2%),\r\n\t\t0 4px 25px 0 rgb(28 101 253 / 20%);\r\n`;\r\n\r\nexport const Menu = styled.ul`\r\n\tposition: relative;\r\n\tbox-sizing: border-box;\r\n\tmax-height: 300px;\r\n\tpadding: 0;\r\n\tpadding-top: ${({ theme }) => theme.spacing.sm};\r\n\tpadding-bottom: ${({ theme }) => theme.spacing.sm};\r\n\tmargin: 0;\r\n\toverflow-y: auto;\r\n\tlist-style-type: none;\r\n`;\r\n\r\nexport interface MenuItemProps {\r\n\t$chooseColor: ChooseColor;\r\n\t$highlighted: boolean;\r\n\t$selected: boolean;\r\n}\r\n\r\nexport const MenuItem = styled.li<MenuItemProps>`\r\n\tbox-sizing: border-box;\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\twidth: 100%;\r\n\tpadding: ${({ theme }) => theme.spacing.xs} ${({ theme }) => theme.spacing.sm};\r\n\tfont-size: inherit;\r\n\tcursor: pointer;\r\n\tuser-select: none;\r\n\tbackground-color: ${({ $chooseColor, $highlighted, $selected, theme }) => {\r\n\t\tif ($selected) {\r\n\t\t\treturn $chooseColor(theme.colors.bg.brand.bold);\r\n\t\t}\r\n\t\tif ($highlighted) {\r\n\t\t\treturn $chooseColor(theme.colors.bg.brand.default);\r\n\t\t}\r\n\r\n\t\treturn 'transparent';\r\n\t}};\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { type Formatter } from 'afformative';\r\nimport { useCombobox } from 'downshift';\r\nimport { partition } from 'lodash';\r\nimport { type ForwardedRef, forwardRef, type ReactElement, type ReactNode, type RefAttributes, useCallback, useMemo } from 'react';\r\n\r\nimport { useComboBoxFormatter } from '@/components/comboBoxField/comboBoxControl/useComboBoxFormatter';\r\nimport { type ComboBoxItem, type ComboBoxItemOrder, ComboBoxItemOrderSource, type ComboBoxValue, ComboBoxValueType } from '@/components/comboBoxField/types';\r\nimport { InputBase, type InputBaseProps } from '@/components/inputBase';\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { useDesignSystem } from '@/contexts';\r\nimport { identityFormatter } from '@/formatters';\r\nimport { FontWeight } from '@/theme';\r\nimport { type FieldControlProps, InputSize, InputTextAlign } from '@/types';\r\n\r\nimport { ComboBoxWrapper, Menu, MenuItem, MenuWrapper } from './ComboBoxControl.style';\r\n\r\nconst defaultCompareFn = (a: unknown, b: unknown) => String(a).localeCompare(String(b));\r\n\r\nexport interface ComboBoxControlProps<TItem extends ComboBoxItem>\r\n\textends\r\n\t\tOmit<FieldControlProps, 'name'>,\r\n\t\tPick<InputBaseProps, 'ariaLabel' | 'disabled' | 'icon' | 'isPastingDisabled' | 'maxLength' | 'name' | 'onFocus' | 'placeholder' | 'required'> {\r\n\tformatter?: Formatter<TItem, ReactNode, number | string>;\r\n\tgetItemKey?: (item: TItem | null) => number | string;\r\n\tinputPrefix?: ReactNode;\r\n\tinputSize?: InputSize;\r\n\tinputSuffix?: ReactNode;\r\n\tinputTextAlign?: InputTextAlign;\r\n\tinputWeight?: FontWeight;\r\n\titemOrder?: ComboBoxItemOrder;\r\n\titems: TItem[];\r\n\tonBlur?: () => void;\r\n\tonChange: (value: ComboBoxValue<TItem>) => void;\r\n\tshouldHighlightFirstItem?: boolean;\r\n\tvalue: ComboBoxValue<TItem>;\r\n}\r\n\r\nconst UntypedComboBoxControl = forwardRef(<TItem extends ComboBoxItem>(props: ComboBoxControlProps<TItem>, ref: ForwardedRef<HTMLInputElement>) => {\r\n\tconst {\r\n\t\tariaLabel,\r\n\t\tdescribedBy,\r\n\t\tdisabled = false,\r\n\t\tformatter: formatterProp = identityFormatter,\r\n\t\tgetItemKey,\r\n\t\ticon,\r\n\t\tid,\r\n\t\tinputPrefix,\r\n\t\tinputSize = InputSize.md,\r\n\t\tinputSuffix,\r\n\t\tinputTextAlign = InputTextAlign.left,\r\n\t\tinputWeight = FontWeight.regular400,\r\n\t\tinvalid = false,\r\n\t\tisPastingDisabled = false,\r\n\t\titemOrder,\r\n\t\titems: itemsProp,\r\n\t\tlabelledBy,\r\n\t\tmaxLength,\r\n\t\tname,\r\n\t\tonBlur,\r\n\t\tonChange,\r\n\t\tonFocus,\r\n\t\tplaceholder,\r\n\t\trequired,\r\n\t\tshouldHighlightFirstItem = false,\r\n\t\tvalue,\r\n\t} = props;\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor, colorScheme, mediaType } = useDesignSystem(props);\r\n\r\n\tconst itemFormatter = useComboBoxFormatter(formatterProp);\r\n\r\n\tconst itemToString = useCallback(\r\n\t\t(downshiftItem: ComboBoxValue<TItem>) => {\r\n\t\t\tif (downshiftItem === null) {\r\n\t\t\t\treturn '';\r\n\t\t\t}\r\n\r\n\t\t\tif (downshiftItem.type === ComboBoxValueType.custom) {\r\n\t\t\t\treturn downshiftItem.input;\r\n\t\t\t}\r\n\r\n\t\t\treturn String(itemFormatter.formatAsPrimitive(downshiftItem.item));\r\n\t\t},\r\n\t\t[itemFormatter],\r\n\t);\r\n\r\n\tconst itemOrderSource = itemOrder?.source;\r\n\tconst itemOrderCompareFn = itemOrder?.compareFn === undefined ? defaultCompareFn : itemOrder.compareFn;\r\n\r\n\tconst wrappedItems = useMemo(() => {\r\n\t\tconst wrappedItemsProp = itemsProp.map((item) => ({\r\n\t\t\titem: item,\r\n\t\t\ttype: ComboBoxValueType.item as const,\r\n\t\t}));\r\n\r\n\t\tif (itemOrderSource === undefined) {\r\n\t\t\treturn wrappedItemsProp;\r\n\t\t}\r\n\r\n\t\tconst [nilItems, otherItems] = partition(wrappedItemsProp, (wrappedItem) => wrappedItem.item === null);\r\n\r\n\t\tswitch (itemOrderSource) {\r\n\t\t\tcase ComboBoxItemOrderSource.formatter:\r\n\t\t\t\treturn [\r\n\t\t\t\t\t...nilItems,\r\n\t\t\t\t\t...Array.from(otherItems).sort((a, b) =>\r\n\t\t\t\t\t\titemOrderCompareFn(itemFormatter.formatAsPrimitive(a.item, ['comparable']), itemFormatter.formatAsPrimitive(b.item, ['comparable'])),\r\n\t\t\t\t\t),\r\n\t\t\t\t];\r\n\r\n\t\t\tcase ComboBoxItemOrderSource.value:\r\n\t\t\t\treturn [...nilItems, ...Array.from(otherItems).sort((a, b) => itemOrderCompareFn(a.item, b.item))];\r\n\r\n\t\t\tdefault:\r\n\t\t\t\treturn wrappedItemsProp;\r\n\t\t}\r\n\t}, [itemFormatter, itemOrderCompareFn, itemOrderSource, itemsProp]);\r\n\r\n\tconst resolveNextSelectedItem = useCallback(\r\n\t\t(inputValueParam: string, highlightedIndexParam = -1): ComboBoxValue<TItem> => {\r\n\t\t\tif (highlightedIndexParam > -1) {\r\n\t\t\t\treturn wrappedItems[highlightedIndexParam];\r\n\t\t\t}\r\n\r\n\t\t\tif (inputValueParam === '') {\r\n\t\t\t\treturn null;\r\n\t\t\t}\r\n\r\n\t\t\tconst matchedItem = wrappedItems.find((wrappedItem) => itemToString(wrappedItem) === inputValueParam);\r\n\r\n\t\t\tif (matchedItem !== undefined) {\r\n\t\t\t\treturn matchedItem;\r\n\t\t\t}\r\n\r\n\t\t\treturn {\r\n\t\t\t\tinput: inputValueParam,\r\n\t\t\t\ttype: ComboBoxValueType.custom as const,\r\n\t\t\t};\r\n\t\t},\r\n\t\t[itemToString, wrappedItems],\r\n\t);\r\n\r\n\tconst { closeMenu, getInputProps, getItemProps, getMenuProps, highlightedIndex, inputValue, isOpen, selectItem } = useCombobox<ComboBoxValue<TItem>>({\r\n\t\tid: id,\r\n\t\titems: wrappedItems,\r\n\t\titemToString: itemToString,\r\n\t\tlabelId: labelledBy,\r\n\t\tselectedItem: value,\r\n\t\tonSelectedItemChange: ({ selectedItem }) => onChange(selectedItem ?? null),\r\n\t\tdefaultHighlightedIndex: shouldHighlightFirstItem ? 0 : undefined,\r\n\t\tonStateChange: ({ inputValue: nextInputValue, type }) => {\r\n\t\t\tif (type === useCombobox.stateChangeTypes.InputChange) {\r\n\t\t\t\tif (nextInputValue === '') {\r\n\t\t\t\t\tonChange(null);\r\n\t\t\t\t} else {\r\n\t\t\t\t\tonChange({\r\n\t\t\t\t\t\tinput: nextInputValue ?? '',\r\n\t\t\t\t\t\ttype: ComboBoxValueType.custom,\r\n\t\t\t\t\t});\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t\t// HACK: React Hook Form triggers validations on blur, but when the input's blur event fires, the form value\r\n\t\t\t// isn't updated yet, causing validations to happen with stale data, so we also trigger it here again.\r\n\t\t\t// `onBlur` will be called twice, hopefully this won't cause any issues.\r\n\t\t\tif (type === useCombobox.stateChangeTypes.InputBlur) {\r\n\t\t\t\tonBlur?.();\r\n\t\t\t}\r\n\t\t},\r\n\t\tstateReducer: (state, actionAndChanges) => {\r\n\t\t\tconst { changes, type } = actionAndChanges;\r\n\r\n\t\t\tswitch (type) {\r\n\t\t\t\tcase useCombobox.stateChangeTypes.InputClick: {\r\n\t\t\t\t\treturn {\r\n\t\t\t\t\t\t...changes,\r\n\t\t\t\t\t\tisOpen: true,\r\n\t\t\t\t\t};\r\n\t\t\t\t}\r\n\r\n\t\t\t\tcase useCombobox.stateChangeTypes.InputBlur: {\r\n\t\t\t\t\tconst nextSelectedItem = resolveNextSelectedItem(state.inputValue);\r\n\r\n\t\t\t\t\treturn {\r\n\t\t\t\t\t\t...changes,\r\n\t\t\t\t\t\tselectedItem: nextSelectedItem,\r\n\t\t\t\t\t\tinputValue: nextSelectedItem === null ? '' : state.inputValue,\r\n\t\t\t\t\t};\r\n\t\t\t\t}\r\n\r\n\t\t\t\tdefault:\r\n\t\t\t\t\treturn changes;\r\n\t\t\t}\r\n\t\t},\r\n\r\n\t\t// HACK: Downshift isn't happy when the property exists, but is undefined.\r\n\t\t...(getItemKey && {\r\n\t\t\titemToKey: (downshiftItem) => {\r\n\t\t\t\tif (downshiftItem === null) {\r\n\t\t\t\t\treturn 'null';\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (downshiftItem.type === ComboBoxValueType.custom) {\r\n\t\t\t\t\treturn `custom:${downshiftItem.input}`;\r\n\t\t\t\t}\r\n\r\n\t\t\t\treturn getItemKey(downshiftItem.item);\r\n\t\t\t},\r\n\t\t}),\r\n\t});\r\n\r\n\tconst inputProps = getInputProps({\r\n\t\t'aria-describedby': describedBy,\r\n\t\t'aria-label': ariaLabel,\r\n\t\t'aria-labelledby': labelledBy,\r\n\t\tdisabled: disabled,\r\n\t\tid: id,\r\n\t\tmaxLength: maxLength,\r\n\t\tname: name,\r\n\t\tplaceholder: placeholder,\r\n\t\tref: ref,\r\n\t\trequired: required,\r\n\t\tonBlur: onBlur,\r\n\t\tonFocus: onFocus,\r\n\t\tonKeyDown: (event) => {\r\n\t\t\t// HACK: This is necessary so that upon pressing tab, the next element is always focused\r\n\t\t\t// (regardless of whether some item is highlighted or what input is typed in).\r\n\t\t\tif (event.key === 'Tab' && isOpen) {\r\n\t\t\t\tconst nextSelectedItem = resolveNextSelectedItem(inputValue, highlightedIndex);\r\n\r\n\t\t\t\t// Also updates/resets the input value.\r\n\t\t\t\tselectItem(nextSelectedItem);\r\n\r\n\t\t\t\tif (nextSelectedItem !== value) {\r\n\t\t\t\t\tonChange(nextSelectedItem);\r\n\t\t\t\t}\r\n\r\n\t\t\t\tcloseMenu();\r\n\t\t\t}\r\n\t\t},\r\n\t});\r\n\r\n\tconst menuProps = getMenuProps();\r\n\r\n\treturn (\r\n\t\t<ComboBoxWrapper>\r\n\t\t\t<InputBase\r\n\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\ticon={icon}\r\n\t\t\t\tinvalid={invalid}\r\n\t\t\t\tisPastingDisabled={isPastingDisabled}\r\n\t\t\t\tmediaType={mediaType}\r\n\t\t\t\tprefix={inputPrefix}\r\n\t\t\t\tsize={inputSize}\r\n\t\t\t\tsuffix={inputSuffix}\r\n\t\t\t\ttextAlign={inputTextAlign}\r\n\t\t\t\tweight={inputWeight}\r\n\t\t\t\t{...inputProps}\r\n\t\t\t/>\r\n\t\t\t<MenuWrapper\r\n\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t$isOpen={isOpen && wrappedItems.length > 0}\r\n\t\t\t>\r\n\t\t\t\t<Menu {...menuProps}>\r\n\t\t\t\t\t{isOpen &&\r\n\t\t\t\t\t\twrappedItems.map((wrappedItem, itemIndex) => {\r\n\t\t\t\t\t\t\tconst isSelected = value?.type === ComboBoxValueType.item && value.item === wrappedItem.item;\r\n\r\n\t\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t\t<MenuItem\r\n\t\t\t\t\t\t\t\t\tkey={getItemKey?.(wrappedItem.item) ?? `index-${itemIndex}`}\r\n\t\t\t\t\t\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t\t\t\t\t\t$highlighted={itemIndex === highlightedIndex}\r\n\t\t\t\t\t\t\t\t\t$selected={isSelected}\r\n\t\t\t\t\t\t\t\t\t{...getItemProps({ item: wrappedItem, index: itemIndex })}\r\n\t\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\t\t\t\tcolor={isSelected ? theme.palette.white : theme.colors.fg.neutral.subtle}\r\n\t\t\t\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\t\t\t\t\tweight={FontWeight.medium500}\r\n\t\t\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t\t\t{itemFormatter.format(wrappedItem.item)}\r\n\t\t\t\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t\t\t\t</MenuItem>\r\n\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t})}\r\n\t\t\t\t</Menu>\r\n\t\t\t</MenuWrapper>\r\n\t\t</ComboBoxWrapper>\r\n\t);\r\n});\r\n\r\nUntypedComboBoxControl.displayName = 'ComboBoxControl';\r\n\r\nexport const ComboBoxControl = UntypedComboBoxControl as <TItem extends ComboBoxItem>(\r\n\tprops: ComboBoxControlProps<TItem> & RefAttributes<HTMLDivElement>,\r\n) => ReactElement;\r\n","import { type Formatter } from 'afformative';\r\nimport { type ReactElement, useMemo } from 'react';\r\n\r\nexport const useComboBoxFormatter = <TInput, TOutput, TPrimitiveOutput>(formatter: Formatter<TInput, TOutput, TPrimitiveOutput>) => {\r\n\treturn useMemo(\r\n\t\t() =>\r\n\t\t\tformatter.wrap<TInput | null | undefined, ReactElement | TOutput, TPrimitiveOutput | string>((delegate, value) => {\r\n\t\t\t\tif (value === null || value === undefined) {\r\n\t\t\t\t\treturn '';\r\n\t\t\t\t}\r\n\r\n\t\t\t\tconst formattedValue = delegate(value);\r\n\r\n\t\t\t\tif (formattedValue === null || formattedValue === undefined || formattedValue === '') {\r\n\t\t\t\t\treturn '';\r\n\t\t\t\t}\r\n\r\n\t\t\t\treturn formattedValue;\r\n\t\t\t}),\r\n\t\t[formatter],\r\n\t);\r\n};\r\n","export enum FieldWrapperLayout {\r\n\thorizontal = 'horizontal',\r\n\tvertical = 'vertical',\r\n}\r\n","/* eslint-disable perfectionist/sort-enums */\r\nexport enum InputLabelSize {\r\n\txs = 'xs',\r\n\tsm = 'sm',\r\n\tmd = 'md',\r\n\tlg = 'lg',\r\n}\r\n/* eslint-enable perfectionist/sort-enums */\r\n","import { styled } from '@/utils';\r\n\r\nexport const Label = styled.label`\r\n\tdisplay: inline;\r\n\tmargin-bottom: 0;\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { type ElementType, type ReactNode, useMemo } from 'react';\r\n\r\nimport { InputLabelSize } from '@/components/inputLabel/types';\r\nimport { TooltipInfo, type TooltipInfoDescriptor } from '@/components/tooltip';\r\nimport { mapTooltipInfoDescriptorToPropsSubset } from '@/components/tooltip/util';\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { VisuallyHidden } from '@/components/visuallyHidden';\r\nimport { liferayClassNames } from '@/constants';\r\nimport { type DesignSystemBaseProps, useColorScheme } from '@/contexts';\r\nimport { FontWeight } from '@/theme';\r\nimport { isRenderable } from '@/utils';\r\n\r\nimport { Label } from './InputLabel.style';\r\n\r\nexport interface InputLabelProps extends DesignSystemBaseProps {\r\n\tas?: ElementType;\r\n\t/** Visually hidden text for screen readers, providing additional info, such as the availability of help under tooltip button. */\r\n\thiddenText?: string;\r\n\tid?: string;\r\n\tinvalid?: boolean;\r\n\tlabel?: ReactNode;\r\n\tlabelId?: string;\r\n\tsize?: InputLabelSize;\r\n\tsuffix?: ReactNode;\r\n\ttooltip?: TooltipInfoDescriptor;\r\n}\r\n\r\nexport const InputLabel = (props: InputLabelProps) => {\r\n\tconst { as, hiddenText, id, invalid = false, label, labelId, size = InputLabelSize.sm, suffix, tooltip } = props;\r\n\r\n\tconst colorScheme = useColorScheme(props);\r\n\tconst theme = useTheme();\r\n\r\n\tconst typographyVariant = useMemo<TypographyVariant>(() => {\r\n\t\tswitch (size) {\r\n\t\t\tcase InputLabelSize.xs:\r\n\t\t\t\treturn TypographyVariant.textXs;\r\n\t\t\tcase InputLabelSize.sm:\r\n\t\t\t\treturn TypographyVariant.textSm;\r\n\t\t\tcase InputLabelSize.md:\r\n\t\t\t\treturn TypographyVariant.textMd;\r\n\t\t\tcase InputLabelSize.lg:\r\n\t\t\t\treturn TypographyVariant.textLg;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected value of InputLabelSize enum in inputLabel.tsx');\r\n\t\t}\r\n\t}, [size]);\r\n\r\n\treturn (\r\n\t\t<div>\r\n\t\t\t<Label\r\n\t\t\t\tas={as}\r\n\t\t\t\tclassName={liferayClassNames.label}\r\n\t\t\t\thtmlFor={as === 'label' || as === undefined ? id : undefined}\r\n\t\t\t\tid={labelId}\r\n\t\t\t>\r\n\t\t\t\t<Typography\r\n\t\t\t\t\tcolor={invalid ? theme.colors.fg.error : theme.colors.fg.neutral.default}\r\n\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\tvariant={typographyVariant}\r\n\t\t\t\t\tweight={FontWeight.medium500}\r\n\t\t\t\t>\r\n\t\t\t\t\t{label}\r\n\t\t\t\t\t{isRenderable(suffix) && (\r\n\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\tcolor={theme.colors.fg.neutral.subtle}\r\n\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\tvariant={typographyVariant}\r\n\t\t\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t{' '}\r\n\t\t\t\t\t\t\t{suffix}\r\n\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t)}\r\n\t\t\t\t</Typography>\r\n\t\t\t\t{hiddenText !== undefined && (\r\n\t\t\t\t\t<>\r\n\t\t\t\t\t\t{/* The space before {hiddenText} is intentional for accessibility/readability */}\r\n\t\t\t\t\t\t<VisuallyHidden> {hiddenText}</VisuallyHidden>\r\n\t\t\t\t\t</>\r\n\t\t\t\t)}\r\n\t\t\t</Label>\r\n\r\n\t\t\t{tooltip !== undefined && (\r\n\t\t\t\t<>\r\n\t\t\t\t\t \r\n\t\t\t\t\t<TooltipInfo\r\n\t\t\t\t\t\t{...mapTooltipInfoDescriptorToPropsSubset(tooltip)}\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t/>\r\n\t\t\t\t</>\r\n\t\t\t)}\r\n\t\t</div>\r\n\t);\r\n};\r\n","import { css } from '@emotion/react';\r\nimport { type Property } from 'csstype';\r\n\r\nimport { FieldWrapperLayout } from '@/components/fieldWrapper/types';\r\nimport { styled } from '@/utils';\r\n\r\ninterface WrapperProps {\r\n\t$layout: FieldWrapperLayout;\r\n}\r\n\r\nexport const Wrapper = styled.div<WrapperProps>`\r\n\tdisplay: flex;\r\n\tflex-direction: ${({ $layout }) => {\r\n\t\tswitch ($layout) {\r\n\t\t\tcase FieldWrapperLayout.vertical:\r\n\t\t\t\treturn 'column';\r\n\t\t\tcase FieldWrapperLayout.horizontal:\r\n\t\t\t\treturn 'row';\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected value of enum FieldWrapperLayout fieldWrapper.styles.ts Wrapper flex-direction');\r\n\t\t}\r\n\t}};\r\n\tgap: ${({ theme }) => theme.spacing.xs};\r\n\talign-items: ${({ $layout }) => {\r\n\t\tswitch ($layout) {\r\n\t\t\tcase FieldWrapperLayout.vertical:\r\n\t\t\t\treturn 'flex-start';\r\n\t\t\tcase FieldWrapperLayout.horizontal:\r\n\t\t\t\treturn 'center';\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected value of enum FieldWrapperLayout fieldWrapper.styles.ts Wrapper flex-direction');\r\n\t\t}\r\n\t}};\r\n`;\r\n\r\ninterface LabelAndHintWrapperProps {\r\n\t$layout: FieldWrapperLayout;\r\n}\r\n\r\nexport const LabelAndHintWrapper = styled.div<LabelAndHintWrapperProps>`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\tgap: ${(props) => props.theme.spacing.xxs};\r\n\talign-items: flex-start;\r\n\r\n\t${(props) =>\r\n\t\tprops.$layout === FieldWrapperLayout.horizontal &&\r\n\t\tcss`\r\n\t\t\tflex: 1;\r\n\t\t`}\r\n`;\r\n\r\ninterface ControlSectionProps {\r\n\t$width?: Property.Width;\r\n}\r\n\r\nexport const ControlSection = styled.div<ControlSectionProps>`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\tgap: ${({ theme }) => theme.spacing.xs};\r\n\talign-items: stretch;\r\n\twidth: ${(props) => props.$width ?? 'auto'};\r\n\r\n\t@media (min-width: ${(props) => props.theme.breakpoints.sm}) {\r\n\t\talign-items: flex-start;\r\n\t}\r\n`;\r\n\r\nexport const HintTextWrapper = styled.span`\r\n\ta,\r\n\t* a {\r\n\t\tcolor: inherit;\r\n\t}\r\n`;\r\n\r\nexport const ControlAndAddonsWrapper = styled.div`\r\n\tdisplay: flex;\r\n\tgap: ${(props) => props.theme.spacing.sm};\r\n\talign-items: center;\r\n\twidth: 100%;\r\n`;\r\n\r\ninterface ControlWrapperProps {\r\n\t$mobileWidth?: Property.Width;\r\n\t$width?: Property.Width;\r\n}\r\n\r\nexport const ControlWrapper = styled.div<ControlWrapperProps>`\r\n\tflex-grow: 1;\r\n\tmax-width: ${(props) => props.$mobileWidth};\r\n\r\n\t@media (min-width: ${(props) => props.theme.breakpoints.sm}) {\r\n\t\tmax-width: ${(props) => props.$width};\r\n\t}\r\n`;\r\n\r\ninterface ValidationOutputAndNoteWrapperProps {\r\n\t$onlyNote: boolean;\r\n}\r\n\r\nexport const ValidationOutputAndNoteWrapper = styled.div<ValidationOutputAndNoteWrapperProps>`\r\n\tdisplay: flex;\r\n\tflex-direction: row;\r\n\tjustify-content: ${({ $onlyNote }) => ($onlyNote ? 'flex-end' : 'space-between')};\r\n\twidth: 100%;\r\n`;\r\n\r\nexport const ValidationOutputWrapper = styled.div`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { type Property } from 'csstype';\r\nimport { Fragment, type ReactNode, useEffect, useId, useMemo, type Key } from 'react';\r\n\r\nimport { FieldWrapperLayout } from '@/components/fieldWrapper/types';\r\nimport { InputLabel } from '@/components/inputLabel';\r\nimport { type TooltipInfoDescriptor } from '@/components/tooltip';\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { VisuallyHidden } from '@/components/visuallyHidden';\r\nimport { type DesignSystemBaseProps, useColorScheme, useDesignSystemMessages, useFieldConfig, useRegisterFieldLabel } from '@/contexts';\r\nimport { FontWeight } from '@/theme';\r\nimport { type FieldControlProps, FieldOptionality, type InputLabelPassthroughProps } from '@/types';\r\nimport { isRenderable, renderReactNodeArray } from '@/utils';\r\n\r\nimport {\r\n\tControlAndAddonsWrapper,\r\n\tControlSection,\r\n\tControlWrapper,\r\n\tHintTextWrapper,\r\n\tLabelAndHintWrapper,\r\n\tValidationOutputAndNoteWrapper,\r\n\tValidationOutputWrapper,\r\n\tWrapper,\r\n} from '@/components/fieldWrapper/FieldWrapper.style';\r\n\r\nexport type FieldWrapperControlProps = Required<Pick<FieldControlProps, 'describedBy' | 'id' | 'invalid' | 'labelledBy' | 'required'>>;\r\n\r\n// NOTE: In the future, we may want to extend this enum to support other types of addons, such as\r\n// having a show/hide password button inside of an input.\r\nexport enum FieldAddonPosition {\r\n\tafterControl = 'afterControl',\r\n\tbeforeControl = 'beforeControl',\r\n\tbelowControl = 'belowControl',\r\n\tbottom = 'bottom',\r\n}\r\n\r\nexport interface FieldAddon {\r\n\tchildren: ReactNode;\r\n\tkey: Key;\r\n\tposition: FieldAddonPosition;\r\n}\r\n\r\nexport interface FieldWrapperProps extends DesignSystemBaseProps, InputLabelPassthroughProps {\r\n\taddons?: FieldAddon[];\r\n\tchildren?: ReactNode | ((controlProps: FieldWrapperControlProps) => ReactNode);\r\n\tcontrolId?: string;\r\n\tcontrolMobileWidth?: Property.Width;\r\n\t/** `controlSection` represents the right section in horizontal layout. */\r\n\tcontrolSectionWidth?: Property.Width;\r\n\tcontrolWidth?: Property.Width;\r\n\terrorMessage?: ReactNode;\r\n\t/** Visually hidden text for screen readers providing additional info, such as the availability of a tooltip. */\r\n\thiddenHintText?: ReactNode;\r\n\thintText?: ReactNode;\r\n\t/** @default isRenderable(errorMessage) */\r\n\tinvalid?: boolean;\r\n\tlayout?: FieldWrapperLayout;\r\n\t/** Necessary for registration of `label` to `FieldLabelStore`. */\r\n\tname?: string;\r\n\tnote?: ReactNode;\r\n\t/** @default FieldOptionality.required */\r\n\toptionality?: FieldOptionality;\r\n\tsuccessMessage?: ReactNode;\r\n}\r\n\r\nexport const FieldWrapper = (props: FieldWrapperProps) => {\r\n\tconst {\r\n\t\taddons,\r\n\t\tchildren,\r\n\t\tcontrolMobileWidth = '100%',\r\n\t\tcontrolWidth = '100%',\r\n\t\terrorMessage,\r\n\t\thiddenHintText: hiddenHintTextProp,\r\n\t\thintText,\r\n\t\tinvalid: invalidProp = false,\r\n\t\tlabel,\r\n\t\tlabelAs,\r\n\t\tlabelHiddenText,\r\n\t\tlabelSuffix: labelSuffixProp,\r\n\t\tlayout = FieldWrapperLayout.vertical,\r\n\t\tname,\r\n\t\tnote,\r\n\t\toptionality = FieldOptionality.required,\r\n\t\tsuccessMessage,\r\n\t\ttooltip: tooltipProp,\r\n\t} = props;\r\n\r\n\tconst controlSectionWidth = props.controlSectionWidth ?? '100%';\r\n\tconst invalid = invalidProp || isRenderable(errorMessage);\r\n\tconst fieldConfig = useFieldConfig();\r\n\tconst designSystemMessages = useDesignSystemMessages();\r\n\tconst optionalLabelSuffix = designSystemMessages.fieldWrapper.optionalLabelSuffix ?? fieldConfig.optionalLabelSuffix;\r\n\tconst labelSuffix = labelSuffixProp ?? (optionality === FieldOptionality.optional ? optionalLabelSuffix : undefined);\r\n\r\n\tconst tooltip = useMemo(\r\n\t\t(): TooltipInfoDescriptor | undefined =>\r\n\t\t\ttooltipProp\r\n\t\t\t\t? {\r\n\t\t\t\t\t\t...tooltipProp,\r\n\t\t\t\t\t\ttriggerAriaLabel: tooltipProp.triggerAriaLabel ?? designSystemMessages.fieldWrapper.getTooltipTriggerAriaLabel?.(tooltipProp, label),\r\n\t\t\t\t\t}\r\n\t\t\t\t: undefined,\r\n\t\t[designSystemMessages, label, tooltipProp],\r\n\t);\r\n\r\n\tconst hiddenHintText = renderReactNodeArray(\r\n\t\t[hiddenHintTextProp, tooltip !== undefined ? designSystemMessages.fieldWrapper.tooltipHiddenHintText : null],\r\n\t\t' ',\r\n\t);\r\n\r\n\tconst uniqueId = useId();\r\n\tconst controlId = props.controlId ?? `control-${uniqueId}`;\r\n\tconst labelId = props.labelId ?? `label-${uniqueId}`;\r\n\tconst validationOutputId = isRenderable(errorMessage) || isRenderable(successMessage) ? `validation-output-${uniqueId}` : '';\r\n\tconst hintTextId = isRenderable(hintText) || isRenderable(hiddenHintText) ? `hint-text-${uniqueId}` : '';\r\n\r\n\tconst theme = useTheme();\r\n\tconst colorScheme = useColorScheme(props);\r\n\tconst registerFieldLabel = useRegisterFieldLabel();\r\n\r\n\tuseEffect(() => {\r\n\t\tif (name !== undefined) {\r\n\t\t\tregisterFieldLabel(name, label);\r\n\t\t}\r\n\t}, [label, name, registerFieldLabel]);\r\n\r\n\treturn (\r\n\t\t<Wrapper $layout={layout}>\r\n\t\t\t{(isRenderable(label) || isRenderable(hintText)) && (\r\n\t\t\t\t<LabelAndHintWrapper $layout={layout}>\r\n\t\t\t\t\t{isRenderable(label) && (\r\n\t\t\t\t\t\t<InputLabel\r\n\t\t\t\t\t\t\tas={labelAs}\r\n\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\thiddenText={labelHiddenText}\r\n\t\t\t\t\t\t\tid={controlId}\r\n\t\t\t\t\t\t\tinvalid={invalid}\r\n\t\t\t\t\t\t\tlabel={label}\r\n\t\t\t\t\t\t\tlabelId={labelId}\r\n\t\t\t\t\t\t\tsuffix={labelSuffix}\r\n\t\t\t\t\t\t\ttooltip={tooltip}\r\n\t\t\t\t\t\t/>\r\n\t\t\t\t\t)}\r\n\r\n\t\t\t\t\t{(isRenderable(hintText) || isRenderable(hiddenHintText)) && (\r\n\t\t\t\t\t\t<HintTextWrapper id={hintTextId}>\r\n\t\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\t\tcolor={theme.colors.fg.neutral.subtle}\r\n\t\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t{isRenderable(hintText) && hintText}\r\n\t\t\t\t\t\t\t\t{isRenderable(hintText) && isRenderable(hiddenHintText) && ' '}\r\n\t\t\t\t\t\t\t\t{isRenderable(hiddenHintText) && <VisuallyHidden>{hiddenHintText}</VisuallyHidden>}\r\n\t\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t\t</HintTextWrapper>\r\n\t\t\t\t\t)}\r\n\t\t\t\t</LabelAndHintWrapper>\r\n\t\t\t)}\r\n\r\n\t\t\t<ControlSection $width={controlSectionWidth}>\r\n\t\t\t\t<ControlAndAddonsWrapper>\r\n\t\t\t\t\t{addons\r\n\t\t\t\t\t\t?.filter((addon) => addon.position === FieldAddonPosition.beforeControl)\r\n\t\t\t\t\t\t.map((addon) => (\r\n\t\t\t\t\t\t\t<Fragment key={addon.key}>{addon.children}</Fragment>\r\n\t\t\t\t\t\t))}\r\n\r\n\t\t\t\t\t<ControlWrapper\r\n\t\t\t\t\t\t$mobileWidth={controlMobileWidth}\r\n\t\t\t\t\t\t$width={controlWidth}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t{typeof children === 'function'\r\n\t\t\t\t\t\t\t? children({\r\n\t\t\t\t\t\t\t\t\tdescribedBy: `${validationOutputId} ${hintTextId}`.trim(),\r\n\t\t\t\t\t\t\t\t\tid: controlId,\r\n\t\t\t\t\t\t\t\t\tinvalid: invalid,\r\n\t\t\t\t\t\t\t\t\tlabelledBy: labelId,\r\n\t\t\t\t\t\t\t\t\trequired: optionality === FieldOptionality.required,\r\n\t\t\t\t\t\t\t\t})\r\n\t\t\t\t\t\t\t: children}\r\n\t\t\t\t\t</ControlWrapper>\r\n\r\n\t\t\t\t\t{addons\r\n\t\t\t\t\t\t?.filter((addon) => addon.position === FieldAddonPosition.afterControl)\r\n\t\t\t\t\t\t.map((addon) => (\r\n\t\t\t\t\t\t\t<Fragment key={addon.key}>{addon.children}</Fragment>\r\n\t\t\t\t\t\t))}\r\n\t\t\t\t</ControlAndAddonsWrapper>\r\n\r\n\t\t\t\t{addons\r\n\t\t\t\t\t?.filter((addon) => addon.position === FieldAddonPosition.belowControl)\r\n\t\t\t\t\t.map((addon) => (\r\n\t\t\t\t\t\t<Fragment key={addon.key}>{addon.children}</Fragment>\r\n\t\t\t\t\t))}\r\n\r\n\t\t\t\t{(isRenderable(errorMessage) || isRenderable(successMessage) || isRenderable(note)) && (\r\n\t\t\t\t\t<ValidationOutputAndNoteWrapper $onlyNote={!isRenderable(errorMessage) && !isRenderable(successMessage) && isRenderable(note)}>\r\n\t\t\t\t\t\t{(isRenderable(errorMessage) || isRenderable(successMessage)) && (\r\n\t\t\t\t\t\t\t<ValidationOutputWrapper id={validationOutputId}>\r\n\t\t\t\t\t\t\t\t{isRenderable(errorMessage) && (\r\n\t\t\t\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\t\t\t\tcolor={theme.colors.fg.error}\r\n\t\t\t\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t\t\t{errorMessage}\r\n\t\t\t\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t\t\t\t)}\r\n\r\n\t\t\t\t\t\t\t\t{isRenderable(successMessage) && (\r\n\t\t\t\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\t\t\t\tcolor={theme.colors.fg.success}\r\n\t\t\t\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t\t\t{successMessage}\r\n\t\t\t\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t\t\t\t)}\r\n\t\t\t\t\t\t\t</ValidationOutputWrapper>\r\n\t\t\t\t\t\t)}\r\n\r\n\t\t\t\t\t\t{isRenderable(note) && (\r\n\t\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\t\tcolor={theme.colors.fg.neutral.subtle}\r\n\t\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t{note}\r\n\t\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t\t)}\r\n\t\t\t\t\t</ValidationOutputAndNoteWrapper>\r\n\t\t\t\t)}\r\n\r\n\t\t\t\t{addons\r\n\t\t\t\t\t?.filter((addon) => addon.position === FieldAddonPosition.bottom)\r\n\t\t\t\t\t.map((addon) => (\r\n\t\t\t\t\t\t<Fragment key={addon.key}>{addon.children}</Fragment>\r\n\t\t\t\t\t))}\r\n\t\t\t</ControlSection>\r\n\t\t</Wrapper>\r\n\t);\r\n};\r\n","import { type ComponentType, forwardRef } from 'react';\r\n\r\nimport { FieldWrapper, type FieldWrapperProps } from '@/components/fieldWrapper/FieldWrapper';\r\nimport { type FieldControlProps } from '@/types';\r\n\r\nconst joinIdReferenceLists = (lists: (string | undefined)[]) => lists.filter(Boolean).join(' ');\r\n\r\n// NOTE: `id` is omitted as it is deprecated in `FieldWrapperProps` but present in `FieldControlProps`.\r\ntype WithFieldWrapperProps = Omit<FieldWrapperProps, 'children' | 'controlId' | 'id'>;\r\n\r\n// TODO: Use `OmitFieldWrapperSpecificProps` in all usages of `TProps`. Buggy until we upgrade TypeScript in all projects.\r\nexport const withFieldWrapper = <TProps extends FieldControlProps, TElement extends HTMLElement>(FieldControl: ComponentType<TProps>) => {\r\n\tconst WithFieldWrapper = forwardRef<TElement, TProps & WithFieldWrapperProps>((props, ref) => {\r\n\t\tconst {\r\n\t\t\taddons,\r\n\t\t\tcolorScheme,\r\n\t\t\tcontrolMobileWidth,\r\n\t\t\tcontrolSectionWidth,\r\n\t\t\tcontrolWidth,\r\n\t\t\tdescribedBy: describedByProp,\r\n\t\t\terrorMessage,\r\n\t\t\thiddenHintText,\r\n\t\t\thintText,\r\n\t\t\tid: controlId,\r\n\t\t\tinvalid,\r\n\t\t\tlabel,\r\n\t\t\tlabelAs,\r\n\t\t\tlabelHiddenText,\r\n\t\t\tlabelId,\r\n\t\t\tlabelledBy: labelledByProp,\r\n\t\t\tlabelSuffix,\r\n\t\t\tlayout,\r\n\t\t\tmediaType,\r\n\t\t\tname,\r\n\t\t\tnote,\r\n\t\t\toptionality,\r\n\t\t\trequired: requiredProp,\r\n\t\t\tsuccessMessage,\r\n\t\t\ttooltip,\r\n\t\t\t...otherProps\r\n\t\t} = props;\r\n\r\n\t\treturn (\r\n\t\t\t<FieldWrapper\r\n\t\t\t\taddons={addons}\r\n\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\tcontrolId={controlId}\r\n\t\t\t\tcontrolMobileWidth={controlMobileWidth}\r\n\t\t\t\tcontrolSectionWidth={controlSectionWidth}\r\n\t\t\t\tcontrolWidth={controlWidth}\r\n\t\t\t\terrorMessage={errorMessage}\r\n\t\t\t\thiddenHintText={hiddenHintText}\r\n\t\t\t\thintText={hintText}\r\n\t\t\t\tinvalid={invalid}\r\n\t\t\t\tlabel={label}\r\n\t\t\t\tlabelAs={labelAs}\r\n\t\t\t\tlabelHiddenText={labelHiddenText}\r\n\t\t\t\tlabelId={labelId}\r\n\t\t\t\tlabelSuffix={labelSuffix}\r\n\t\t\t\tlayout={layout}\r\n\t\t\t\tmediaType={mediaType}\r\n\t\t\t\tname={name}\r\n\t\t\t\tnote={note}\r\n\t\t\t\toptionality={optionality}\r\n\t\t\t\tsuccessMessage={successMessage}\r\n\t\t\t\ttooltip={tooltip}\r\n\t\t\t>\r\n\t\t\t\t{({ describedBy, id, invalid, labelledBy, required }) => (\r\n\t\t\t\t\t<FieldControl\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\tdescribedBy={joinIdReferenceLists([describedByProp, describedBy])}\r\n\t\t\t\t\t\tid={id}\r\n\t\t\t\t\t\tinvalid={invalid}\r\n\t\t\t\t\t\tlabelledBy={joinIdReferenceLists([labelledByProp, labelledBy])}\r\n\t\t\t\t\t\tmediaType={mediaType}\r\n\t\t\t\t\t\tname={name}\r\n\t\t\t\t\t\tref={ref}\r\n\t\t\t\t\t\trequired={requiredProp ?? required}\r\n\t\t\t\t\t\t// NOTE: We don't want to spread all props here, since `FieldControl` might forward them to the underlying DOM element.\r\n\t\t\t\t\t\t{...(otherProps as unknown as TProps)}\r\n\t\t\t\t\t/>\r\n\t\t\t\t)}\r\n\t\t\t</FieldWrapper>\r\n\t\t);\r\n\t});\r\n\r\n\tWithFieldWrapper.displayName = `withFieldWrapper(${FieldControl.displayName ?? FieldControl.name})`;\r\n\r\n\treturn WithFieldWrapper;\r\n};\r\n","import { type ReactElement, type RefAttributes } from 'react';\r\n\r\nimport { ComboBoxControl, type ComboBoxControlProps } from '@/components/comboBoxField/comboBoxControl/ComboBoxControl';\r\nimport { type ComboBoxItem } from '@/components/comboBoxField/types';\r\nimport { type FieldWrapperProps, withFieldWrapper } from '@/components/fieldWrapper';\r\n\r\nconst UntypedComboBox = withFieldWrapper<ComboBoxProps<ComboBoxItem>, HTMLDivElement>(ComboBoxControl);\r\n\r\nexport type ComboBoxProps<TItem extends ComboBoxItem> = ComboBoxControlProps<TItem> & Omit<FieldWrapperProps, 'children'>;\r\n\r\nexport const ComboBox = UntypedComboBox as <TItem extends ComboBoxItem>(props: ComboBoxProps<TItem> & RefAttributes<HTMLDivElement>) => ReactElement;\r\n","export enum SelectVariant {\r\n\tinputLike = 'inputLike',\r\n\ttext = 'text',\r\n}\r\n\r\nexport enum SelectItemOrderSource {\r\n\tformatter = 'formatter',\r\n\tvalue = 'value',\r\n}\r\n\r\nexport interface SelectItemOrder {\r\n\tcompareFn?: (a: unknown, b: unknown) => number;\r\n\tsource: SelectItemOrderSource;\r\n}\r\n\r\nexport type SelectItem = boolean | number | object | string | null;\r\n","import { styled } from '@/utils';\r\n\r\nimport { SelectVariant } from '../types';\r\n\r\nconst DownChevron = () => (\r\n\t<svg\r\n\t\taria-hidden=\"true\"\r\n\t\tfocusable=\"false\"\r\n\t\theight={14}\r\n\t\tstyle={{\r\n\t\t\tdisplay: 'inline-block',\r\n\t\t\tfill: 'currentColor',\r\n\t\t\tlineHeight: 1,\r\n\t\t\tstroke: 'currentColor',\r\n\t\t\tstrokeWidth: 0,\r\n\t\t}}\r\n\t\tviewBox=\"0 0 20 20\"\r\n\t\twidth={14}\r\n\t>\r\n\t\t<path d=\"M4.516 7.548c0.436-0.446 1.043-0.481 1.576 0l3.908 3.747 3.908-3.747c0.533-0.481 1.141-0.446 1.574 0 0.436 0.445 0.408 1.197 0 1.615-0.406 0.418-4.695 4.502-4.695 4.502-0.217 0.223-0.502 0.335-0.787 0.335s-0.57-0.112-0.789-0.335c0 0-4.287-4.084-4.695-4.502s-0.436-1.17 0-1.615z\" />\r\n\t</svg>\r\n);\r\n\r\ninterface DropdownIndicatorStyledProps {\r\n\t$open: boolean;\r\n\t$variant: SelectVariant;\r\n}\r\n\r\nconst DropdownIndicatorStyled = styled.div<DropdownIndicatorStyledProps>`\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tpadding: 0 ${(props) => (props.$variant === SelectVariant.inputLike ? props.theme.spacing.sm : props.theme.spacing.xxs)};\r\n\tcolor: ${(props) => props.theme.colors.fg.neutral.subtle.light};\r\n\ttransform: ${(props) => (props.$open ? 'rotate(-180deg)' : 'none')};\r\n\ttransition: all 0.15s ease-in-out;\r\n`;\r\n\r\ninterface DropdownIndicatorProps {\r\n\topen: boolean;\r\n\tvariant: SelectVariant;\r\n}\r\n\r\nexport const DropdownIndicator = (props: DropdownIndicatorProps) => {\r\n\tconst { open, variant } = props;\r\n\r\n\treturn (\r\n\t\t<DropdownIndicatorStyled\r\n\t\t\t$open={open}\r\n\t\t\t$variant={variant}\r\n\t\t>\r\n\t\t\t<DownChevron />\r\n\t\t</DropdownIndicatorStyled>\r\n\t);\r\n};\r\n","import { css, type Theme } from '@emotion/react';\r\n\r\nimport { styled } from '@/utils';\r\n\r\nimport { SelectVariant } from '../types';\r\n\r\ninterface SelectWrapperProps {\r\n\t$variant: SelectVariant;\r\n}\r\n\r\nexport const SelectWrapper = styled.div<SelectWrapperProps>`\r\n\tposition: relative;\r\n\twidth: ${(props) => (props.$variant === SelectVariant.text ? 'max-content' : '100%')};\r\n`;\r\n\r\ninterface ToggleButtonProps {\r\n\t$disabled: boolean;\r\n\t$hasIcon: boolean;\r\n\t$invalid: boolean;\r\n\t$open: boolean;\r\n\t$variant: SelectVariant;\r\n}\r\n\r\nconst getToggleButtonBorderColor = (theme: Theme, props: ToggleButtonProps): string => {\r\n\tconst { $disabled, $invalid } = props;\r\n\r\n\tif ($invalid) {\r\n\t\treturn theme.colors.border.error.light;\r\n\t}\r\n\r\n\tif ($disabled) {\r\n\t\treturn theme.colors.border.neutral.default.light;\r\n\t}\r\n\r\n\treturn theme.colors.border.neutral.default.light;\r\n};\r\n\r\nconst focusOutlineCss = (props: ToggleButtonProps & { theme: Theme }) => css`\r\n\toutline-width: 3px;\r\n\toutline-style: solid;\r\n\toutline-color: ${props.$invalid ? props.theme.colors.fg.error.light : props.theme.colors.focus.light};\r\n\toutline-offset: 2px;\r\n`;\r\n\r\nexport const ToggleButton = styled.div<ToggleButtonProps>`\r\n\tposition: relative;\r\n\tdisplay: flex;\r\n\tflex-wrap: nowrap;\r\n\talign-items: center;\r\n\tjustify-content: space-between;\r\n\tborder-radius: ${(props) => props.theme.borderRadius.xs};\r\n\r\n\t${(props) => {\r\n\t\tswitch (props.$variant) {\r\n\t\t\tcase SelectVariant.inputLike:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\t/* TODO: Reuse this from InputBase styles. */\r\n\t\t\t\t\tmin-height: 40px;\r\n\t\t\t\t\tpadding-left: ${props.$hasIcon ? props.theme.spacing.xxl : props.theme.spacing.md};\r\n\t\t\t\t\tbackground-color: ${props.$disabled ? props.theme.colors.bg.disabled.light : props.theme.palette.white};\r\n\t\t\t\t\tbox-shadow: inset 0 0 0 ${props.$invalid && !props.$open ? '2px' : '1px'} ${getToggleButtonBorderColor(props.theme, props)};\r\n\t\t\t\t`;\r\n\t\t\tcase SelectVariant.text:\r\n\t\t\t\treturn css``;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('Unexpected enum SelectVariant in SelectControl.style.ts');\r\n\t\t}\r\n\t}}\r\n\r\n\t${(props) => props.$open && focusOutlineCss(props)}\r\n\r\n\t&:focus, &:focus-visible {\r\n\t\t${(props) => focusOutlineCss(props)}\r\n\t}\r\n`;\r\n\r\nexport const ToggleButtonValue = styled.div`\r\n\toverflow: hidden;\r\n\ttext-overflow: ellipsis;\r\n\twhite-space: nowrap;\r\n`;\r\n\r\nexport const IconWrapper = styled.div`\r\n\tposition: absolute;\r\n\ttop: 50%;\r\n\tleft: 0;\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\tmargin-left: ${(props) => props.theme.spacing.sm};\r\n\ttransform: translateY(-50%);\r\n`;\r\n\r\nexport interface MenuWrapperProps {\r\n\t$open: boolean;\r\n}\r\n\r\nexport const MenuWrapper = styled.div<MenuWrapperProps>`\r\n\tz-index: 1;\r\n\twidth: 100%;\r\n\tmin-width: 200px;\r\n\tbackground-color: ${(props) => props.theme.palette.white};\r\n\tborder-radius: ${(props) => props.theme.borderRadius.xxs};\r\n\r\n\t/* NOTE: This is just copied over from react-select for visual consistency with the old Select. */\r\n\tbox-shadow:\r\n\t\trgb(0 0 0 / 10%) 0 0 0 1px,\r\n\t\trgb(0 0 0 / 10%) 0 4px 11px;\r\n\r\n\t${({ $open }) =>\r\n\t\t!$open &&\r\n\t\tcss`\r\n\t\t\tvisibility: hidden;\r\n\t\t`}\r\n`;\r\n\r\nexport const Menu = styled.ul`\r\n\tposition: relative;\r\n\tbox-sizing: border-box;\r\n\tmax-height: 300px;\r\n\tpadding: 0;\r\n\tpadding-top: ${(props) => props.theme.spacing.xxs};\r\n\tpadding-bottom: ${(props) => props.theme.spacing.xxs};\r\n\tmargin: 0;\r\n\toverflow-y: auto;\r\n\tlist-style-type: none;\r\n`;\r\n\r\nexport interface MenuItemProps {\r\n\t$highlighted: boolean;\r\n\t$selected: boolean;\r\n}\r\n\r\nexport const MenuItem = styled.li<MenuItemProps>`\r\n\tbox-sizing: border-box;\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\twidth: 100%;\r\n\tpadding: ${(props) => props.theme.spacing.xs} ${(props) => props.theme.spacing.sm};\r\n\tfont-size: inherit;\r\n\tcursor: pointer;\r\n\tuser-select: none;\r\n\tbackground-color: transparent;\r\n\r\n\t${(props) =>\r\n\t\tprops.$highlighted &&\r\n\t\tcss`\r\n\t\t\tbackground-color: ${props.theme.colors.bg.brand.default.light};\r\n\t\t`}\r\n\r\n\t${(props) =>\r\n\t\tprops.$selected &&\r\n\t\tcss`\r\n\t\t\tbackground-color: ${props.theme.colors.bg.brand.bold.light};\r\n\t\t`}\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { autoUpdate, flip, offset, shift, useFloating, useMergeRefs } from '@floating-ui/react';\r\nimport { type Formatter } from 'afformative';\r\nimport { useSelect } from 'downshift';\r\nimport { partition } from 'lodash';\r\nimport { type FocusEventHandler, type ForwardedRef, forwardRef, type ReactElement, type ReactNode, type RefAttributes, useCallback, useMemo } from 'react';\r\n\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { identityFormatter } from '@/formatters';\r\nimport { FontWeight, TextDecoration } from '@/theme';\r\nimport { type FieldControlProps } from '@/types';\r\n\r\nimport { IconSystem, IconSystemSize, type IconSystemType } from '../../iconSystem';\r\nimport { type SelectItem, type SelectItemOrder, SelectItemOrderSource, SelectVariant } from '../types';\r\nimport { DropdownIndicator } from './DropdownIndicator';\r\nimport { useSelectFormatter } from './useSelectFormatter';\r\n\r\nimport { IconWrapper, Menu, MenuItem, MenuWrapper, SelectWrapper, ToggleButton, ToggleButtonValue } from './SelectControl.style';\r\n\r\nconst defaultCompareFn = (a: unknown, b: unknown) => String(a).localeCompare(String(b));\r\n\r\nexport interface SelectControlProps<TItem extends SelectItem> extends FieldControlProps, DesignSystemBaseProps {\r\n\tariaLabel?: string;\r\n\tdisabled?: boolean;\r\n\tformatter?: Formatter<TItem, ReactNode, number | string>;\r\n\tgetItemKey?: (item: TItem | null) => number | string;\r\n\ticonSystem?: IconSystemType;\r\n\tid?: string;\r\n\titemOrder?: SelectItemOrder;\r\n\titems: TItem[];\r\n\tnilMessage?: string;\r\n\tonBlur?: FocusEventHandler<HTMLDivElement>;\r\n\tonChange: (item: TItem | null) => void;\r\n\tvalue: TItem | null;\r\n\tvariant?: SelectVariant;\r\n}\r\n\r\nconst UntypedSelectControl = forwardRef(<TItem extends SelectItem>(props: SelectControlProps<TItem>, ref: ForwardedRef<HTMLDivElement>) => {\r\n\tconst {\r\n\t\tariaLabel,\r\n\t\tdescribedBy,\r\n\t\tdisabled = false,\r\n\t\tformatter: formatterProp = identityFormatter,\r\n\t\tgetItemKey,\r\n\t\ticonSystem,\r\n\t\tid,\r\n\t\tinvalid = false,\r\n\t\titemOrder,\r\n\t\titems: itemsProp,\r\n\t\tlabelledBy,\r\n\t\tname,\r\n\t\tnilMessage = '',\r\n\t\tonBlur,\r\n\t\tonChange,\r\n\t\trequired,\r\n\t\tvalue,\r\n\t\tvariant = SelectVariant.inputLike,\r\n\t} = props;\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor } = useDesignSystem(props);\r\n\r\n\tconst formatter = useSelectFormatter(formatterProp, nilMessage);\r\n\tconst itemToString = useCallback((item: TItem | null) => String(formatter.formatAsPrimitive(item)), [formatter]);\r\n\r\n\tconst itemOrderSource = itemOrder?.source;\r\n\tconst itemOrderCompareFn = itemOrder?.compareFn ?? defaultCompareFn;\r\n\r\n\tconst items = useMemo(() => {\r\n\t\tif (itemOrderSource === undefined) {\r\n\t\t\treturn itemsProp;\r\n\t\t}\r\n\r\n\t\tconst [nilItems, otherItems] = partition(itemsProp, (item) => item === null);\r\n\r\n\t\tswitch (itemOrderSource) {\r\n\t\t\tcase SelectItemOrderSource.formatter:\r\n\t\t\t\treturn [\r\n\t\t\t\t\t...nilItems,\r\n\t\t\t\t\t...Array.from(otherItems).sort((a, b) =>\r\n\t\t\t\t\t\titemOrderCompareFn(formatter.formatAsPrimitive(a, ['comparable']), formatter.formatAsPrimitive(b, ['comparable'])),\r\n\t\t\t\t\t),\r\n\t\t\t\t];\r\n\r\n\t\t\tcase SelectItemOrderSource.value:\r\n\t\t\t\treturn [...nilItems, ...Array.from(otherItems).sort((a, b) => itemOrderCompareFn(a, b))];\r\n\r\n\t\t\tdefault:\r\n\t\t\t\treturn itemsProp;\r\n\t\t}\r\n\t}, [formatter, itemOrderCompareFn, itemOrderSource, itemsProp]);\r\n\r\n\tconst {\r\n\t\tgetItemProps,\r\n\t\tgetMenuProps,\r\n\t\tgetToggleButtonProps,\r\n\t\thighlightedIndex,\r\n\t\tisOpen: open,\r\n\t} = useSelect({\r\n\t\tid: id,\r\n\t\titems: items,\r\n\t\titemToString: itemToString,\r\n\t\tlabelId: labelledBy,\r\n\t\tonSelectedItemChange: ({ selectedItem }) => onChange(selectedItem),\r\n\t\tselectedItem: value,\r\n\r\n\t\t// HACK: Downshift isn't happy when the property exists, but is undefined.\r\n\t\t...(getItemKey && {\r\n\t\t\titemToKey: getItemKey,\r\n\t\t}),\r\n\t});\r\n\r\n\tconst { floatingStyles, refs } = useFloating({\r\n\t\topen: open,\r\n\t\tmiddleware: [offset(8), flip(), shift()],\r\n\t\twhileElementsMounted: autoUpdate,\r\n\t\tplacement: 'bottom-start',\r\n\t});\r\n\r\n\tconst toggleButtonRef = useMergeRefs([refs.setReference, ref]);\r\n\tconst hasIcon = iconSystem !== undefined;\r\n\r\n\treturn (\r\n\t\t<SelectWrapper $variant={variant}>\r\n\t\t\t<ToggleButton\r\n\t\t\t\t$disabled={disabled}\r\n\t\t\t\t$hasIcon={hasIcon}\r\n\t\t\t\t$invalid={invalid}\r\n\t\t\t\t$open={open}\r\n\t\t\t\t$variant={variant}\r\n\t\t\t\t{...getToggleButtonProps({\r\n\t\t\t\t\t'aria-describedby': describedBy,\r\n\t\t\t\t\t'aria-invalid': invalid,\r\n\t\t\t\t\t'aria-required': required,\r\n\t\t\t\t\t'data-name': name,\r\n\t\t\t\t\t'aria-label': ariaLabel,\r\n\t\t\t\t\tdisabled: disabled,\r\n\t\t\t\t\tonBlur: onBlur,\r\n\t\t\t\t\tref: toggleButtonRef,\r\n\t\t\t\t\tid: id,\r\n\t\t\t\t})}\r\n\t\t\t>\r\n\t\t\t\t<ToggleButtonValue>\r\n\t\t\t\t\t{hasIcon && (\r\n\t\t\t\t\t\t<IconWrapper>\r\n\t\t\t\t\t\t\t<IconSystem\r\n\t\t\t\t\t\t\t\tsize={IconSystemSize.small}\r\n\t\t\t\t\t\t\t\tstroke={chooseColor(theme.colors.fg.brand.default)}\r\n\t\t\t\t\t\t\t\ttype={iconSystem}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t</IconWrapper>\r\n\t\t\t\t\t)}\r\n\r\n\t\t\t\t\t{variant === SelectVariant.inputLike ? (\r\n\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\tcolor={theme.colors.fg.neutral.default}\r\n\t\t\t\t\t\t\tvariant={TypographyVariant.textMd}\r\n\t\t\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t{formatter.format(value)}\r\n\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t) : (\r\n\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\tcolor={theme.colors.fg.neutral.subtle}\r\n\t\t\t\t\t\t\tdecoration={TextDecoration.underline}\r\n\t\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t{formatter.format(value)}\r\n\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t)}\r\n\t\t\t\t</ToggleButtonValue>\r\n\t\t\t\t<DropdownIndicator\r\n\t\t\t\t\topen={open}\r\n\t\t\t\t\tvariant={variant}\r\n\t\t\t\t/>\r\n\t\t\t</ToggleButton>\r\n\t\t\t<MenuWrapper\r\n\t\t\t\t$open={open}\r\n\t\t\t\tref={refs.setFloating}\r\n\t\t\t\tstyle={floatingStyles}\r\n\t\t\t>\r\n\t\t\t\t<Menu {...getMenuProps()}>\r\n\t\t\t\t\t{open &&\r\n\t\t\t\t\t\titems.map((item, itemIndex) => (\r\n\t\t\t\t\t\t\t<MenuItem\r\n\t\t\t\t\t\t\t\tkey={getItemKey?.(item) ?? `index-${itemIndex}`}\r\n\t\t\t\t\t\t\t\t$highlighted={itemIndex === highlightedIndex}\r\n\t\t\t\t\t\t\t\t$selected={item === value}\r\n\t\t\t\t\t\t\t\t{...getItemProps({ item: item, index: itemIndex })}\r\n\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\t\t\tcolor={item === value ? theme.palette.white : theme.colors.fg.neutral.subtle}\r\n\t\t\t\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\t\t\t\tweight={FontWeight.medium500}\r\n\t\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t\t{formatter.format(item)}\r\n\t\t\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t\t\t</MenuItem>\r\n\t\t\t\t\t\t))}\r\n\t\t\t\t</Menu>\r\n\t\t\t</MenuWrapper>\r\n\t\t</SelectWrapper>\r\n\t);\r\n});\r\n\r\nUntypedSelectControl.displayName = 'SelectControl';\r\n\r\nexport const SelectControl = UntypedSelectControl as <TItem extends SelectItem>(\r\n\tprops: RefAttributes<HTMLDivElement> & SelectControlProps<TItem>,\r\n) => ReactElement;\r\n","import { type Formatter } from 'afformative';\r\nimport { type ReactElement, useMemo } from 'react';\r\n\r\nexport const useSelectFormatter = <TInput, TOutput, TPrimitiveOutput>(formatter: Formatter<TInput, TOutput, TPrimitiveOutput>, nilMessage: string) => {\r\n\treturn useMemo(\r\n\t\t() =>\r\n\t\t\tformatter.wrap<TInput | null | undefined, ReactElement | TOutput, TPrimitiveOutput | string>((delegate, value) => {\r\n\t\t\t\tif (value === null || value === undefined) {\r\n\t\t\t\t\treturn nilMessage;\r\n\t\t\t\t}\r\n\r\n\t\t\t\tconst formattedValue = delegate(value);\r\n\r\n\t\t\t\tif (formattedValue === null || formattedValue === undefined || formattedValue === '') {\r\n\t\t\t\t\t// TODO: Perhaps use some custom message here.\r\n\t\t\t\t\treturn '';\r\n\t\t\t\t}\r\n\r\n\t\t\t\treturn formattedValue;\r\n\t\t\t}),\r\n\t\t[formatter, nilMessage],\r\n\t);\r\n};\r\n","import { type ReactElement, type RefAttributes } from 'react';\r\n\r\nimport { type FieldWrapperProps, withFieldWrapper } from '../../fieldWrapper';\r\nimport { SelectControl, type SelectControlProps } from '../selectControl/SelectControl';\r\nimport { type SelectItem } from '../types';\r\n\r\nconst UntypedSelect = withFieldWrapper<SelectProps<SelectItem>, HTMLDivElement>(SelectControl);\r\n\r\nexport type SelectProps<TItem extends SelectItem> = Omit<FieldWrapperProps, 'children'> & SelectControlProps<TItem>;\r\n\r\nexport const Select = UntypedSelect as <TItem extends SelectItem>(props: RefAttributes<HTMLDivElement> & SelectProps<TItem>) => ReactElement;\r\n","import { styled, type ChooseColor } from '@/utils';\r\n\r\ninterface NavigationProps {\r\n\t$chooseColor: ChooseColor;\r\n}\r\n// ex .react-datepicker__navigation\r\nexport const Navigation = styled.button<NavigationProps>`\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\tpadding: 0;\r\n\ttext-align: center;\r\n\tcursor: pointer;\r\n\tbackground: transparent;\r\n\tborder: none;\r\n\tborder: 0;\r\n\topacity: ${(props) => ((props.disabled ?? false) ? 0 : 1)};\r\n\r\n\t&:focus-visible {\r\n\t\toutline-width: 3px;\r\n\t\toutline-style: solid;\r\n\t\toutline-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.focus)};\r\n\t\toutline-offset: 2px;\r\n\t}\r\n`;\r\n\r\n// ex .react-datepicker__current-month\r\nexport const NavigationContainer = styled.div`\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\tpadding: ${({ theme }) => `${theme.spacing.md} 0 0 0`};\r\n`;\r\n\r\nexport const DayNamesWrapper = styled.div`\r\n\tdisplay: flex;\r\n\tflex-direction: row;\r\n\tjustify-content: space-between;\r\n\tmargin-right: ${({ theme }) => theme.spacing.xxs};\r\n\tmargin-left: ${({ theme }) => theme.spacing.xxs};\r\n`;\r\n\r\nexport const DayNameWrapper = styled.div`\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\twidth: 2rem;\r\n\theight: 2rem;\r\n`;\r\n\r\nexport const SelectsWrapper = styled.div`\r\n\tdisplay: flex;\r\n\tflex-direction: row;\r\n\tcolumn-gap: ${({ theme }) => theme.spacing.xxs};\r\n`;\r\n\r\nexport const SelectMonthWrapper = styled.div`\r\n\twidth: 134px;\r\n`;\r\n\r\nexport const SelectYearWrapper = styled.div`\r\n\twidth: 102px;\r\n`;\r\n","import { makeFormatter } from 'afformative';\r\nimport { type Day, formatDate, type Locale, type Month } from 'date-fns';\r\nimport { range } from 'lodash';\r\nimport { useCallback, useMemo } from 'react';\r\nimport { type ReactDatePickerCustomHeaderProps } from 'react-datepicker';\r\n\r\nimport { IconSystem, IconSystemSize, IconSystemType } from '@/components/iconSystem';\r\nimport { SelectControl } from '@/components/selectField';\r\nimport { Stack, StackDirection } from '@/components/stack';\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { FontWeight, Spacing, theme } from '@/theme';\r\n\r\nimport { DayNamesWrapper, DayNameWrapper, Navigation, NavigationContainer, SelectMonthWrapper, SelectsWrapper, SelectYearWrapper } from './CustomHeader.style';\r\n\r\nconst monthList = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12];\r\n\r\nconst defaultMinDate = new Date('1900-01-01');\r\nconst defaultMaxDate = new Date('2099-12-31');\r\n\r\nexport interface DayDescriptor {\r\n\tname: string;\r\n\tshortName: string;\r\n}\r\n\r\nexport interface CustomHeaderProps extends ReactDatePickerCustomHeaderProps, DesignSystemBaseProps {\r\n\tlocale: Locale;\r\n\tmaxDate?: Date;\r\n\tminDate?: Date;\r\n\tmonthSelectAriaLabel?: string;\r\n\tmonthYearSelectEnabled: boolean;\r\n\tnextMonthAriaLabel?: string;\r\n\tpreviousMonthAriaLabel?: string;\r\n\tyearSelectAriaLabel?: string;\r\n}\r\n\r\nexport const CustomHeader = (props: CustomHeaderProps) => {\r\n\tconst {\r\n\t\tchangeMonth,\r\n\t\tchangeYear,\r\n\t\tdecreaseMonth,\r\n\t\tincreaseMonth,\r\n\t\tlocale,\r\n\t\tmaxDate = defaultMaxDate,\r\n\t\tminDate = defaultMinDate,\r\n\t\tmonthDate,\r\n\t\tmonthSelectAriaLabel,\r\n\t\tmonthYearSelectEnabled,\r\n\t\tnextMonthAriaLabel,\r\n\t\tnextMonthButtonDisabled,\r\n\t\tpreviousMonthAriaLabel,\r\n\t\tprevMonthButtonDisabled,\r\n\t\tyearSelectAriaLabel,\r\n\t} = props;\r\n\r\n\tconst { chooseColor, colorScheme } = useDesignSystem(props);\r\n\r\n\tconst monthName = formatDate(monthDate, 'LLLL yyyy', { locale: locale });\r\n\r\n\t// Localized weekday names (starting from locale's first day of the week), memoized.\r\n\tconst dayDescriptors = useMemo<DayDescriptor[]>(() => {\r\n\t\tconst firstDay = locale.options?.weekStartsOn ?? 1;\r\n\r\n\t\tconst days = Array.from({ length: 7 }, (value, i) => {\r\n\t\t\tconst dayIndex = ((i + firstDay) % 7) as Day;\r\n\r\n\t\t\tconst label = locale.localize.day(dayIndex, { width: 'short' });\r\n\r\n\t\t\treturn {\r\n\t\t\t\tname: locale.localize.day(dayIndex, { width: 'wide' }),\r\n\t\t\t\tshortName: label.charAt(0).toUpperCase() + label.slice(1),\r\n\t\t\t};\r\n\t\t});\r\n\r\n\t\treturn days;\r\n\t}, [locale]);\r\n\r\n\tconst yearList = useMemo(() => {\r\n\t\tconst minYear = minDate.getFullYear();\r\n\t\tconst maxYear = maxDate.getFullYear();\r\n\r\n\t\treturn range(minYear, maxYear + 1);\r\n\t}, [maxDate, minDate]);\r\n\r\n\tconst handleYearChange = useCallback(\r\n\t\t(value: number | null) => {\r\n\t\t\tif (value === null) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t\tchangeYear(value);\r\n\t\t},\r\n\t\t[changeYear],\r\n\t);\r\n\r\n\tconst handleMonthChange = useCallback(\r\n\t\t(value: number | null) => {\r\n\t\t\tif (value === null) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t\tchangeMonth(value - 1);\r\n\t\t},\r\n\t\t[changeMonth],\r\n\t);\r\n\r\n\tconst monthFormatter = useMemo(() => {\r\n\t\treturn makeFormatter<number, string, string>((value) => {\r\n\t\t\tconst monthString = locale.localize.month((value - 1) as Month, { width: 'wide' });\r\n\r\n\t\t\treturn monthString.charAt(0).toUpperCase() + monthString.slice(1);\r\n\t\t});\r\n\t}, [locale]);\r\n\r\n\treturn (\r\n\t\t<Stack\r\n\t\t\tdirection={StackDirection.column}\r\n\t\t\tgap={Spacing.sm}\r\n\t\t>\r\n\t\t\t<NavigationContainer>\r\n\t\t\t\t<Navigation\r\n\t\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t\taria-label={previousMonthAriaLabel}\r\n\t\t\t\t\taria-labelledby=\"datepicker-prevMonth\"\r\n\t\t\t\t\tdisabled={prevMonthButtonDisabled}\r\n\t\t\t\t\tstyle={{ marginRight: 'auto' }}\r\n\t\t\t\t\ttype=\"button\"\r\n\t\t\t\t\tonClick={decreaseMonth}\r\n\t\t\t\t>\r\n\t\t\t\t\t<IconSystem\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\tsize={IconSystemSize.big}\r\n\t\t\t\t\t\ttype={IconSystemType.chevronLeft}\r\n\t\t\t\t\t/>\r\n\t\t\t\t</Navigation>\r\n\r\n\t\t\t\t{monthYearSelectEnabled && (\r\n\t\t\t\t\t<SelectsWrapper>\r\n\t\t\t\t\t\t<SelectMonthWrapper>\r\n\t\t\t\t\t\t\t<SelectControl\r\n\t\t\t\t\t\t\t\tariaLabel={monthSelectAriaLabel}\r\n\t\t\t\t\t\t\t\tformatter={monthFormatter}\r\n\t\t\t\t\t\t\t\titems={monthList}\r\n\t\t\t\t\t\t\t\tvalue={monthDate.getMonth() + 1}\r\n\t\t\t\t\t\t\t\tonChange={handleMonthChange}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t</SelectMonthWrapper>\r\n\t\t\t\t\t\t<SelectYearWrapper>\r\n\t\t\t\t\t\t\t<SelectControl\r\n\t\t\t\t\t\t\t\tariaLabel={yearSelectAriaLabel}\r\n\t\t\t\t\t\t\t\titems={yearList}\r\n\t\t\t\t\t\t\t\tvalue={monthDate.getFullYear()}\r\n\t\t\t\t\t\t\t\tonChange={handleYearChange}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t</SelectYearWrapper>\r\n\t\t\t\t\t</SelectsWrapper>\r\n\t\t\t\t)}\r\n\r\n\t\t\t\t{!monthYearSelectEnabled && (\r\n\t\t\t\t\t<Typography\r\n\t\t\t\t\t\tcolor={theme.colors.fg.neutral.subtle}\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\tvariant={TypographyVariant.h5}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t{monthName}\r\n\t\t\t\t\t</Typography>\r\n\t\t\t\t)}\r\n\r\n\t\t\t\t<Navigation\r\n\t\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t\taria-label={nextMonthAriaLabel}\r\n\t\t\t\t\taria-labelledby=\"datepicker-nextMonth\"\r\n\t\t\t\t\tdisabled={nextMonthButtonDisabled}\r\n\t\t\t\t\tstyle={{ marginLeft: 'auto' }}\r\n\t\t\t\t\ttype=\"button\"\r\n\t\t\t\t\tonClick={increaseMonth}\r\n\t\t\t\t>\r\n\t\t\t\t\t<IconSystem\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\tsize={IconSystemSize.big}\r\n\t\t\t\t\t\ttype={IconSystemType.chevronRight}\r\n\t\t\t\t\t/>\r\n\t\t\t\t</Navigation>\r\n\t\t\t</NavigationContainer>\r\n\r\n\t\t\t<DayNamesWrapper>\r\n\t\t\t\t{dayDescriptors.map((dayDescriptor, index) => (\r\n\t\t\t\t\t<DayNameWrapper key={index}>\r\n\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\taria-label={dayDescriptor.name}\r\n\t\t\t\t\t\t\tcolor={theme.colors.fg.neutral.subtle}\r\n\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t{dayDescriptor.shortName}\r\n\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t</DayNameWrapper>\r\n\t\t\t\t))}\r\n\t\t\t</DayNamesWrapper>\r\n\t\t</Stack>\r\n\t);\r\n};\r\n","import { useMergeRefs } from '@floating-ui/react';\r\nimport { type ForwardedRef, forwardRef } from 'react';\r\n\r\nimport { InputBase, type InputBaseProps } from '@/components/inputBase';\r\n// HACK: This component needs to exist because there's no other way to forward a ref to `DatePicker#customInput`.\r\n// Passing a ref directly to `InputBase` gets overwritten by some internal usage of `cloneElement`, and passing\r\n// `ref` to the `DatePicker` returns a class instance with a defined, but inaccessible `input` property (no clue).\r\nexport const InputBaseWithInnerRef = forwardRef<HTMLInputElement, InputBaseProps & { innerRef: ForwardedRef<HTMLInputElement> }>((props, forwardedRef) => {\r\n\tconst { innerRef, ...otherProps } = props;\r\n\tconst mergedRef = useMergeRefs([innerRef, forwardedRef]);\r\n\r\n\treturn (\r\n\t\t<InputBase\r\n\t\t\t{...otherProps}\r\n\t\t\tref={mergedRef}\r\n\t\t/>\r\n\t);\r\n});\r\n\r\nInputBaseWithInnerRef.displayName = 'InputBaseWithInnerRef';\r\n","import { styled, type ChooseColor } from '@/utils';\r\n\r\ninterface DatePickerContainerProps {\r\n\t$chooseColor: ChooseColor;\r\n}\r\n\r\n// ex .react-datepicker\r\nexport const DatePickerContainer = styled.div<DatePickerContainerProps>`\r\n\tposition: relative;\r\n\tdisplay: inline-block;\r\n\tline-height: initial;\r\n\tbackground-color: ${({ theme }) => theme.colors.bg.neutral.white.light};\r\n\tborder: 1px solid ${({ theme }) => theme.colors.bg.neutral.subtlest.light};\r\n\tborder-radius: ${({ theme }) => theme.spacing.md};\r\n\r\n\t/* stylelint-disable */\r\n\t.react-datepicker__aria-live {\r\n\t\tposition: absolute;\r\n\t\twidth: 1px;\r\n\t\theight: 1px;\r\n\t\tpadding: 0;\r\n\t\tmargin: -1px;\r\n\t\toverflow: hidden;\r\n\t\tclip-path: circle(0);\r\n\t\twhite-space: nowrap;\r\n\t\tborder: 0;\r\n\t}\r\n\r\n\t.react-datepicker__header {\r\n\t\tpadding-right: ${({ theme }) => theme.spacing.md};\r\n\t\tpadding-left: ${({ theme }) => theme.spacing.md};\r\n\t\tborder-bottom: 1px solid ${({ theme }) => theme.colors.bg.neutral.subtlest.light};\r\n\t}\r\n\r\n\t.react-datepicker__month {\r\n\t\tpadding: ${({ theme }) => theme.spacing.md};\r\n\t}\r\n\r\n\t.react-datepicker__day-names {\r\n\t\tdisplay: none;\r\n\t}\r\n\r\n\t.react-datepicker__day-names,\r\n\t.react-datepicker__month {\r\n\t\tline-height: 28px;\r\n\t\ttext-transform: capitalize;\r\n\t\twhite-space: nowrap;\r\n\t\tuser-select: none;\r\n\t}\r\n\r\n\t.react-datepicker__day-name,\r\n\t.react-datepicker__day,\r\n\t.react-datepicker__time-name {\r\n\t\tdisplay: inline-block;\r\n\t\twidth: 32px;\r\n\t\tmargin: ${({ theme }) => theme.spacing.xxs};\r\n\t\tfont-size: 14px;\r\n\t\ttext-align: center;\r\n\t}\r\n\r\n\t.react-datepicker__day {\r\n\t\tline-height: 32px;\r\n\t\tcolor: ${({ theme }) => theme.colors.fg.neutral.subtle};\r\n\t\tborder-radius: 99px;\r\n\r\n\t\t&:hover {\r\n\t\t\tcolor: ${({ theme }) => theme.colors.fg.neutral.subtle.light};\r\n\t\t\tbackground-color: ${({ theme }) => theme.colors.bg.neutral.subtle.light};\r\n\t\t}\r\n\r\n\t\t/* Aktualni den */\r\n\t\t&.react-datepicker__day--today {\r\n\t\t\tcolor: ${({ theme }) => theme.colors.fg.brand.default.light};\r\n\t\t\tbackground-color: ${({ theme }) => theme.colors.bg.neutral.subtlest.light};\r\n\t\t}\r\n\r\n\t\t&.react-datepicker__day--selected,\r\n\t\t&.react-datepicker__day--selected:hover {\r\n\t\t\tcolor: ${({ theme }) => theme.colors.bg.neutral.white.light};\r\n\t\t\tbackground-color: ${({ theme }) => theme.colors.fg.brand.bold.light};\r\n\t\t}\r\n\r\n\t\t&.react-datepicker__day--disabled,\r\n\t\t&.react-datepicker__day--disabled:hover {\r\n\t\t\tcolor: ${({ theme }) => theme.colors.fg.disabled.light};\r\n\t\t\tbackground-color: ${({ theme }) => theme.colors.bg.neutral.white.light};\r\n\t\t}\r\n\r\n\t\t&:focus-visible {\r\n\t\t\toutline-width: 0;\r\n\t\t}\r\n\r\n\t\t&.react-datepicker__day--keyboard-selected,\r\n\t\t&.react-datepicker__day--selected[tabindex='0'] {\r\n\t\t\toutline-width: 3px;\r\n\t\t\toutline-style: solid;\r\n\t\t\toutline-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.focus)};\r\n\t\t}\r\n\t}\r\n\r\n\t.react-datepicker__day:not(.react-datepicker__day--disabled) {\r\n\t\tcursor: pointer;\r\n\t}\r\n`;\r\n\r\nexport const NonVisible = styled.span`\r\n\tdisplay: none;\r\n`;\r\n\r\nexport const PopperContainer = styled.div`\r\n\t.react-datepicker-popper {\r\n\t\tz-index: ${(props) => props.theme.zIndex.dropdown};\r\n\t}\r\n`;\r\n\r\nexport const CalendarIconWrapper = styled.span`\r\n\tdisplay: inline-flex;\r\n\tcursor: pointer;\r\n`;\r\n\r\ninterface ChevronIconWrapperProps {\r\n\t$isOpen: boolean;\r\n}\r\n\r\nexport const ChevronIconWrapper = styled.span<ChevronIconWrapperProps>`\r\n\tdisplay: flex;\r\n\tjustify-content: center;\r\n\talign-items: center;\r\n\ttransition: all 0.15s ease-in-out;\r\n\ttransform: ${({ $isOpen }) => ($isOpen ? 'rotate(-180deg)' : 'none')};\r\n`;\r\n\r\nexport const DayWrapper = styled.div`\r\n\tdisplay: flex;\r\n\tjustify-content: center;\r\n\talign-items: center;\r\n\theight: 2rem;\r\n\twidth: 2rem;\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { type Locale } from 'date-fns';\r\nimport { cs } from 'date-fns/locale/cs';\r\nimport { forwardRef, useEffect, type MouseEvent, type KeyboardEvent } from 'react';\r\nimport { type DatePickerProps as ReactDatePickerProps, default as ReactDatepicker } from 'react-datepicker';\r\nimport { useBoolean } from 'usehooks-ts';\r\n\r\nimport { IconSystem, IconSystemSize, IconSystemType } from '@/components/iconSystem';\r\nimport { SpanButton } from '@/components/spanButton';\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { useDesignSystem } from '@/contexts';\r\nimport { FontWeight } from '@/theme';\r\nimport { type FieldControlProps, InputSize } from '@/types';\r\n\r\nimport { CustomHeader } from '../customHeader/CustomHeader';\r\nimport { InputBaseWithInnerRef } from './InputBaseWithInnerRef';\r\n\r\nimport { CalendarIconWrapper, ChevronIconWrapper, DatePickerContainer, DayWrapper, NonVisible, PopperContainer } from './DatePickerControl.style';\r\n\r\nconst defaultDateFormat = ['dd.MM.yyyy', 'dd. MM. yyyy'];\r\n\r\nexport interface DatePickerControlProps\r\n\textends\r\n\t\tPick<\r\n\t\t\tReactDatePickerProps,\r\n\t\t\t| 'chooseDayAriaLabelPrefix'\r\n\t\t\t| 'dateFormat'\r\n\t\t\t| 'disabledDayAriaLabelPrefix'\r\n\t\t\t| 'filterDate'\r\n\t\t\t| 'maxDate'\r\n\t\t\t| 'minDate'\r\n\t\t\t| 'monthAriaLabelPrefix'\r\n\t\t\t| 'nextMonthAriaLabel'\r\n\t\t\t| 'onBlur'\r\n\t\t\t| 'previousMonthAriaLabel'\r\n\t\t\t| 'selected'\r\n\t\t>,\r\n\t\tFieldControlProps {\r\n\tchevronCloseAriaLabel?: string;\r\n\tchevronOpenAriaLabel?: string;\r\n\tdisabled?: boolean;\r\n\tlocale?: Locale;\r\n\tmonthSelectAriaLabel?: string;\r\n\tmonthYearSelectEnabled?: boolean;\r\n\tname: string;\r\n\tonChange?: (date: Date | null, event?: KeyboardEvent<HTMLElement> | MouseEvent<HTMLElement>) => void;\r\n\tplaceholder?: string;\r\n\tyearSelectAriaLabel?: string;\r\n}\r\n\r\nexport const DatePickerControl = forwardRef<HTMLInputElement, DatePickerControlProps>((props, ref) => {\r\n\tconst {\r\n\t\tchevronCloseAriaLabel,\r\n\t\tchevronOpenAriaLabel,\r\n\t\tchooseDayAriaLabelPrefix,\r\n\t\tdateFormat = defaultDateFormat,\r\n\t\tdescribedBy,\r\n\t\tdisabled = false,\r\n\t\tdisabledDayAriaLabelPrefix,\r\n\t\tfilterDate,\r\n\t\tid,\r\n\t\tinvalid,\r\n\t\tlabelledBy,\r\n\t\tlocale: localeProp,\r\n\t\tmaxDate,\r\n\t\tminDate,\r\n\t\tmonthAriaLabelPrefix,\r\n\t\tmonthSelectAriaLabel,\r\n\t\tmonthYearSelectEnabled = false,\r\n\t\tname,\r\n\t\tnextMonthAriaLabel,\r\n\t\tonBlur,\r\n\t\tonChange,\r\n\t\tplaceholder,\r\n\t\tpreviousMonthAriaLabel,\r\n\t\trequired,\r\n\t\tselected,\r\n\t\tyearSelectAriaLabel,\r\n\t} = props;\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor, colorScheme } = useDesignSystem(props);\r\n\r\n\tconst { setFalse: close, setTrue: open, toggle: toggleIsOpen, value: isOpen } = useBoolean(false);\r\n\r\n\tconst locale = localeProp ?? cs;\r\n\r\n\t// If the input becomes disabled while the date picker is open, we need to close the picker to prevent interaction with a disabled field.\r\n\tuseEffect(() => {\r\n\t\tif (disabled && isOpen) {\r\n\t\t\tclose();\r\n\t\t}\r\n\t}, [close, disabled, isOpen]);\r\n\r\n\t/*\tTODO: better localization, change Container\r\n\t\thttps://github.com/Hacker0x01/react-datepicker/issues/2428\r\n\t*/\r\n\r\n\treturn (\r\n\t\t<ReactDatepicker\r\n\t\t\tariaDescribedBy={describedBy}\r\n\t\t\tariaInvalid={String(invalid)}\r\n\t\t\tariaLabelledBy={labelledBy}\r\n\t\t\tariaRequired={String(required)}\r\n\t\t\tcalendarContainer={({ children }) => (\r\n\t\t\t\t<DatePickerContainer\r\n\t\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t\trole=\"dialog\"\r\n\t\t\t\t>\r\n\t\t\t\t\t<NonVisible id=\"datepicker-prevMonth\">{previousMonthAriaLabel}</NonVisible>\r\n\t\t\t\t\t<NonVisible id=\"datepicker-nextMonth\">{nextMonthAriaLabel}</NonVisible>\r\n\t\t\t\t\t{children}\r\n\t\t\t\t</DatePickerContainer>\r\n\t\t\t)}\r\n\t\t\tchooseDayAriaLabelPrefix={chooseDayAriaLabelPrefix}\r\n\t\t\tcustomInput={\r\n\t\t\t\t<InputBaseWithInnerRef\r\n\t\t\t\t\ticon={\r\n\t\t\t\t\t\t<CalendarIconWrapper onClick={disabled ? undefined : open}>\r\n\t\t\t\t\t\t\t<IconSystem\r\n\t\t\t\t\t\t\t\tsize={IconSystemSize.small}\r\n\t\t\t\t\t\t\t\tstroke={chooseColor(theme.colors.icon.brand)}\r\n\t\t\t\t\t\t\t\ttype={IconSystemType.event}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t</CalendarIconWrapper>\r\n\t\t\t\t\t}\r\n\t\t\t\t\tinnerRef={ref}\r\n\t\t\t\t\tinvalid={invalid}\r\n\t\t\t\t\tname={name}\r\n\t\t\t\t\tsize={InputSize.md}\r\n\t\t\t\t\tsuffix={\r\n\t\t\t\t\t\t<SpanButton\r\n\t\t\t\t\t\t\taria-label={isOpen ? chevronCloseAriaLabel : chevronOpenAriaLabel}\r\n\t\t\t\t\t\t\tdisabled={disabled}\r\n\t\t\t\t\t\t\tonClick={(event) => {\r\n\t\t\t\t\t\t\t\tevent.preventDefault();\r\n\t\t\t\t\t\t\t\ttoggleIsOpen();\r\n\t\t\t\t\t\t\t}}\r\n\t\t\t\t\t\t\tonMouseDown={(event) => event.stopPropagation()}\r\n\t\t\t\t\t\t\tonMouseUp={(event) => event.stopPropagation()}\r\n\t\t\t\t\t\t\tonTouchStart={(event) => event.stopPropagation()}\r\n\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t<ChevronIconWrapper $isOpen={isOpen}>\r\n\t\t\t\t\t\t\t\t<IconSystem\r\n\t\t\t\t\t\t\t\t\tsize={IconSystemSize.big}\r\n\t\t\t\t\t\t\t\t\ttype={IconSystemType.chevronDown}\r\n\t\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t\t</ChevronIconWrapper>\r\n\t\t\t\t\t\t</SpanButton>\r\n\t\t\t\t\t}\r\n\t\t\t\t/>\r\n\t\t\t}\r\n\t\t\tdateFormat={dateFormat}\r\n\t\t\tdisabled={disabled}\r\n\t\t\tdisabledDayAriaLabelPrefix={disabledDayAriaLabelPrefix}\r\n\t\t\tfilterDate={filterDate}\r\n\t\t\tid={id}\r\n\t\t\tlocale={locale}\r\n\t\t\tmaxDate={maxDate}\r\n\t\t\tminDate={minDate}\r\n\t\t\tmonthAriaLabelPrefix={monthAriaLabelPrefix}\r\n\t\t\tname={name}\r\n\t\t\tnextMonthAriaLabel={nextMonthAriaLabel}\r\n\t\t\topen={isOpen}\r\n\t\t\tplaceholderText={placeholder}\r\n\t\t\tpopperContainer={PopperContainer}\r\n\t\t\tpreviousMonthAriaLabel={previousMonthAriaLabel}\r\n\t\t\trenderCustomHeader={(props) => {\r\n\t\t\t\treturn (\r\n\t\t\t\t\t<CustomHeader\r\n\t\t\t\t\t\t{...props}\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\tlocale={locale}\r\n\t\t\t\t\t\tmaxDate={maxDate}\r\n\t\t\t\t\t\tminDate={minDate}\r\n\t\t\t\t\t\tmonthSelectAriaLabel={monthSelectAriaLabel}\r\n\t\t\t\t\t\tmonthYearSelectEnabled={monthYearSelectEnabled}\r\n\t\t\t\t\t\tnextMonthAriaLabel={nextMonthAriaLabel}\r\n\t\t\t\t\t\tpreviousMonthAriaLabel={previousMonthAriaLabel}\r\n\t\t\t\t\t\tyearSelectAriaLabel={yearSelectAriaLabel}\r\n\t\t\t\t\t/>\r\n\t\t\t\t);\r\n\t\t\t}}\r\n\t\t\trenderDayContents={(day) => {\r\n\t\t\t\treturn (\r\n\t\t\t\t\t<DayWrapper>\r\n\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\tcolor={'inherit'}\r\n\t\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t{day}\r\n\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t</DayWrapper>\r\n\t\t\t\t);\r\n\t\t\t}}\r\n\t\t\tselected={selected}\r\n\t\t\t// @ts-ignore\r\n\t\t\tselectsMultiple={false}\r\n\t\t\t// @ts-ignore\r\n\t\t\tselectsRange={false}\r\n\t\t\tshowPopperArrow={false}\r\n\t\t\tshowTimeSelect={false}\r\n\t\t\tonBlur={onBlur}\r\n\t\t\tonChange={onChange}\r\n\t\t\tonClickOutside={close}\r\n\t\t\tonSelect={close}\r\n\t\t/>\r\n\t);\r\n});\r\n\r\nDatePickerControl.displayName = 'DatePickerControl';\r\n","export const datePickerValueFormat = 'yyyy-MM-dd';\r\n","import { type ComponentProps } from 'react';\r\n\r\nimport { DatePickerControl, type DatePickerControlProps } from '@/components/datePickerField/datePickerControl/DatePickerControl';\r\nimport { withFieldWrapper } from '@/components/fieldWrapper/withFieldWrapper';\r\n\r\nexport const DatePicker = withFieldWrapper<DatePickerControlProps, HTMLInputElement>(DatePickerControl);\r\n\r\nexport type DatePickerProps = ComponentProps<typeof DatePicker>;\r\n","import { type ComponentProps, forwardRef } from 'react';\r\n\r\nimport { withFieldWrapper } from '@/components/fieldWrapper';\r\nimport { InputBase } from '@/components/inputBase';\r\nimport { type InputProps } from '@/types';\r\n\r\nexport interface EmailInputControlProps extends InputProps {\r\n\tplaceholder?: string;\r\n}\r\n\r\nconst EmailInputControl = forwardRef<HTMLInputElement, EmailInputControlProps>((props, ref) => {\r\n\treturn (\r\n\t\t<InputBase\r\n\t\t\tref={ref}\r\n\t\t\ttype=\"email\"\r\n\t\t\t{...props}\r\n\t\t/>\r\n\t);\r\n});\r\n\r\nEmailInputControl.displayName = 'EmailInputControl';\r\n\r\nexport const EmailInput = withFieldWrapper<EmailInputControlProps, HTMLInputElement>(EmailInputControl);\r\n\r\nexport type EmailInputProps = ComponentProps<typeof EmailInput>;\r\n","import { styled, type ChooseColor } from '@/utils';\r\n\r\ninterface LiStyledProps {\r\n\t$chooseColor: ChooseColor;\r\n\t$isLink: boolean;\r\n}\r\n\r\nexport const LiStyled = styled.li<LiStyledProps>`\r\n\tpadding: 0;\r\n\tmargin: 0;\r\n\ttext-indent: 0;\r\n\ttext-decoration: ${({ $isLink }) => ($isLink ? 'underline' : 'initial')};\r\n\tcursor: ${({ $isLink }) => ($isLink ? 'pointer' : 'initial')};\r\n\tlist-style-type: none;\r\n\tborder-radius: ${(props) => props.theme.borderRadius.xxs};\r\n\r\n\t&:focus-visible {\r\n\t\toutline-width: 3px;\r\n\t\toutline-style: solid;\r\n\t\toutline-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.focus)};\r\n\t\toutline-offset: 2px;\r\n\t}\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { type KeyboardEvent, type PropsWithChildren, useCallback } from 'react';\r\n\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { useDesignSystem } from '@/contexts';\r\nimport { FontWeight } from '@/theme';\r\nimport { type ColorScheme } from '@/types';\r\n\r\nimport { LiStyled } from './ErrorBoxListItem.style';\r\n\r\nexport interface ErrorBoxListItemProps extends PropsWithChildren {\r\n\tcolorScheme?: ColorScheme;\r\n\tonClick?: () => void;\r\n}\r\n\r\nexport const ErrorBoxListItem = (props: ErrorBoxListItemProps) => {\r\n\tconst { children, onClick } = props;\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor } = useDesignSystem(props);\r\n\r\n\tconst handleKeyPress = useCallback(\r\n\t\t(event: KeyboardEvent) => {\r\n\t\t\tif (event.key === 'Enter') {\r\n\t\t\t\tonClick?.();\r\n\t\t\t}\r\n\t\t},\r\n\t\t[onClick],\r\n\t);\r\n\r\n\treturn (\r\n\t\t<LiStyled\r\n\t\t\t$chooseColor={chooseColor}\r\n\t\t\t$isLink={onClick !== undefined}\r\n\t\t\tonClick={onClick}\r\n\t\t\t{...(onClick && {\r\n\t\t\t\ttabIndex: 0,\r\n\t\t\t\trole: 'link',\r\n\t\t\t\tonKeyPress: handleKeyPress,\r\n\t\t\t})}\r\n\t\t>\r\n\t\t\t<Typography\r\n\t\t\t\tcolor={chooseColor(theme.colors.fg.error)}\r\n\t\t\t\tvariant={TypographyVariant.textMd}\r\n\t\t\t\tweight={FontWeight.medium500}\r\n\t\t\t>\r\n\t\t\t\t{children}\r\n\t\t\t</Typography>\r\n\t\t</LiStyled>\r\n\t);\r\n};\r\n","import { styled } from '@/utils';\r\n\r\nexport const UlStyled = styled.ul`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\trow-gap: ${({ theme }) => theme.spacing.xs};\r\n\tpadding: 0;\r\n\tmargin: 0;\r\n\ttext-indent: 0;\r\n\tlist-style-type: none;\r\n`;\r\n","import { type ErrorBoxItem } from '@/components/errorBox';\r\nimport { useDesignSystem } from '@/contexts';\r\nimport { type ColorScheme } from '@/types';\r\n\r\nimport { ErrorBoxListItem } from '../errorBoxListItem/ErrorBoxListItem';\r\n\r\nimport { UlStyled } from './ErrorBoxList.style';\r\n\r\nexport interface ErrorBoxListProps {\r\n\tcolorScheme?: ColorScheme;\r\n\titems: ErrorBoxItem[];\r\n}\r\n\r\nexport const ErrorBoxList = (props: ErrorBoxListProps) => {\r\n\tconst { items } = props;\r\n\r\n\tconst { colorScheme } = useDesignSystem(props);\r\n\r\n\treturn (\r\n\t\t<UlStyled>\r\n\t\t\t{items.map((item, index) => {\r\n\t\t\t\treturn (\r\n\t\t\t\t\t<ErrorBoxListItem\r\n\t\t\t\t\t\tkey={index}\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\tonClick={item.onClick}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t{item.body}\r\n\t\t\t\t\t</ErrorBoxListItem>\r\n\t\t\t\t);\r\n\t\t\t})}\r\n\t\t</UlStyled>\r\n\t);\r\n};\r\n","import { styled, type ChooseColor } from '@/utils';\r\n\r\ninterface WrapperProps {\r\n\t$chooseColor: ChooseColor;\r\n}\r\n\r\nexport const Wrapper = styled.div<WrapperProps>`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\trow-gap: ${({ theme }) => theme.spacing.md};\r\n\tpadding: ${({ theme }) => theme.spacing.lg};\r\n\tcolor: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.fg.error)};\r\n\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.bg.error.default)};\r\n\tborder-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.border.error)};\r\n\tborder-style: solid;\r\n\tborder-width: 2px;\r\n\tborder-radius: ${({ theme }) => theme.borderRadius.xs};\r\n\r\n\t&:focus-visible {\r\n\t\toutline-width: 3px;\r\n\t\toutline-style: solid;\r\n\t\toutline-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.focus)};\r\n\t\toutline-offset: 2px;\r\n\t}\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { forwardRef, type ReactNode } from 'react';\r\n\r\nimport { ErrorBoxList } from '@/components/errorBox/errorBoxList/ErrorBoxList';\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { useDesignSystem } from '@/contexts';\r\nimport { FontWeight } from '@/theme';\r\nimport { type ColorScheme } from '@/types';\r\nimport { isRenderable } from '@/utils';\r\n\r\nimport { type ErrorBoxItem } from './types';\r\n\r\nimport { Wrapper } from './ErrorBox.style';\r\n\r\nexport interface ErrorBoxProps {\r\n\tcolorScheme?: ColorScheme;\r\n\tcontent?: ReactNode;\r\n\titems?: ErrorBoxItem[];\r\n\ttabIndex?: number;\r\n\ttitle?: ReactNode;\r\n}\r\n\r\nexport const ErrorBox = forwardRef<HTMLDivElement, ErrorBoxProps>((props, ref) => {\r\n\tconst { content, items, tabIndex, title } = props;\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor, colorScheme } = useDesignSystem(props);\r\n\r\n\treturn (\r\n\t\t<Wrapper\r\n\t\t\t$chooseColor={chooseColor}\r\n\t\t\tref={ref}\r\n\t\t\ttabIndex={tabIndex}\r\n\t\t>\r\n\t\t\t{isRenderable(title) && (\r\n\t\t\t\t<Typography\r\n\t\t\t\t\tcolor={chooseColor(theme.colors.fg.error)}\r\n\t\t\t\t\tvariant={TypographyVariant.textLg}\r\n\t\t\t\t\tweight={FontWeight.semiBold600}\r\n\t\t\t\t>\r\n\t\t\t\t\t{title}\r\n\t\t\t\t</Typography>\r\n\t\t\t)}\r\n\t\t\t{items !== undefined && items.length > 0 && (\r\n\t\t\t\t<ErrorBoxList\r\n\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\titems={items}\r\n\t\t\t\t/>\r\n\t\t\t)}\r\n\t\t\t{isRenderable(content) && content}\r\n\t\t</Wrapper>\r\n\t);\r\n});\r\n\r\nErrorBox.displayName = 'ErrorBox';\r\n","import { type ComponentType, type ReactNode } from 'react';\r\n\r\nexport enum FileInputErrorCode {\r\n\tfileSizeTooLarge = 'fileSizeTooLarge',\r\n\tgeneral = 'general',\r\n\ttooManyFiles = 'tooManyFiles',\r\n\ttotalFileSizeTooLarge = 'totalFileSizeTooLarge',\r\n\tunsupportedFormat = 'unsupportedFormat',\r\n}\r\n\r\nexport interface FileInputError {\r\n\tcode: FileInputErrorCode;\r\n\tfileName: string;\r\n}\r\n\r\nexport enum FileInputItemType {\r\n\terror = 'error',\r\n\tfile = 'file',\r\n}\r\n\r\nexport interface FileInputErrorItem {\r\n\terror: FileInputError;\r\n\ttype: FileInputItemType.error;\r\n}\r\n\r\nexport interface FileInputFileItem {\r\n\tfile: File;\r\n\ttype: FileInputItemType.file;\r\n}\r\n\r\nexport type FileInputItem = FileInputErrorItem | FileInputFileItem;\r\n\r\nexport interface FileInputSettings {\r\n\tfileExtensions: string[];\r\n\tmaxFiles?: number;\r\n\tmaxSize: number;\r\n\tmaxTotalSize?: number;\r\n}\r\n\r\nexport type FileInputLimitDescriptionComponent = ComponentType<FileInputSettings>;\r\n\r\nexport type FileInputUploadErrorReasonComponent = ComponentType<{ errorCode: FileInputErrorCode }>;\r\n\r\nexport type FileInputUploadFailedComponent = ComponentType<{ fileName: string }>;\r\n\r\nexport type FileInputDropzoneDragOrSelectFilesComponent = ComponentType<{ selectedFiles: ReactNode }>;\r\n\r\nexport type FileInputDropzoneDragFilesHereComponent = ComponentType;\r\n\r\nexport type FileInputRemoveButtonTextComponent = ComponentType<{ fileName: string }>;\r\n\r\nexport type FileInputDropzoneSelectFilesComponent = ComponentType;\r\n","import { ErrorCode, type FileRejection } from 'react-dropzone';\r\n\r\nimport { type FileInputError, FileInputErrorCode } from './types';\r\n\r\nconst getFileErrorCode = (dropzoneErrorCode: string) => {\r\n\tswitch (dropzoneErrorCode as ErrorCode) {\r\n\t\tcase ErrorCode.FileInvalidType:\r\n\t\t\treturn FileInputErrorCode.unsupportedFormat;\r\n\t\tcase ErrorCode.FileTooLarge:\r\n\t\t\treturn FileInputErrorCode.fileSizeTooLarge;\r\n\t\tcase ErrorCode.TooManyFiles:\r\n\t\t\treturn FileInputErrorCode.tooManyFiles;\r\n\t\tdefault:\r\n\t\t\treturn FileInputErrorCode.general;\r\n\t}\r\n};\r\n\r\nexport const getFileErrorByDropzoneRejection = (rejection: FileRejection): FileInputError => {\r\n\tconst fileName = rejection.file.name;\r\n\r\n\tif (rejection.errors.length === 0) {\r\n\t\treturn {\r\n\t\t\tcode: FileInputErrorCode.general,\r\n\t\t\tfileName: fileName,\r\n\t\t};\r\n\t}\r\n\r\n\treturn {\r\n\t\tcode: getFileErrorCode(rejection.errors[0].code),\r\n\t\tfileName: fileName,\r\n\t};\r\n};\r\n\r\nexport const normalizeFileExtension = (extension: string) => extension.toLowerCase().replace(/^\\./, '');\r\n","import { css } from '@emotion/react';\r\n\r\nimport { styled, type ChooseColor } from '@/utils';\r\n\r\nexport const DropzoneWrapper = styled.div`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\tgap: ${(props) => props.theme.spacing.xs};\r\n\talign-items: center;\r\n\tpadding: ${(props) => props.theme.spacing.lg} 0;\r\n`;\r\n\r\ninterface UploadIconProps {\r\n\t$chooseColor: ChooseColor;\r\n}\r\n\r\nexport const UploadIcon = styled.div<UploadIconProps>`\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\twidth: 48px;\r\n\theight: 48px;\r\n\tcursor: pointer;\r\n\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.bg.brand.default)};\r\n\tborder-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.border.brand.subtlest)};\r\n\tborder-style: solid;\r\n\tborder-width: 1px;\r\n\tborder-radius: ${(props) => props.theme.borderRadius.full};\r\n`;\r\n\r\nexport const SelectFilesLink = styled.span`\r\n\ttext-decoration: underline;\r\n\tcursor: pointer;\r\n`;\r\n\r\ninterface LimitDescriptionWrapperProps {\r\n\t$dragActive: boolean;\r\n}\r\n\r\nexport const LimitDescriptionWrapper = styled.div<LimitDescriptionWrapperProps>`\r\n\t${(props) =>\r\n\t\tprops.$dragActive &&\r\n\t\tcss`\r\n\t\t\tvisibility: hidden;\r\n\t\t`}\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\n\r\nimport {\r\n\ttype FileInputDropzoneDragFilesHereComponent,\r\n\ttype FileInputDropzoneDragOrSelectFilesComponent,\r\n\ttype FileInputDropzoneSelectFilesComponent,\r\n\ttype FileInputLimitDescriptionComponent,\r\n\ttype FileInputSettings,\r\n} from '@/components/fileInputField/types';\r\nimport { IconSystem, IconSystemSize, IconSystemType } from '@/components/iconSystem';\r\nimport { Typography, TypographyTextAlign, TypographyVariant } from '@/components/typography';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { FontWeight } from '@/theme';\r\n\r\nimport { DropzoneWrapper, LimitDescriptionWrapper, SelectFilesLink, UploadIcon } from './Dropzone.style';\r\n\r\nexport interface DropzoneProps extends DesignSystemBaseProps {\r\n\tDropzoneDragFilesHere: FileInputDropzoneDragFilesHereComponent;\r\n\tDropzoneDragOrSelectFiles: FileInputDropzoneDragOrSelectFilesComponent;\r\n\tDropzoneSelectFiles: FileInputDropzoneSelectFilesComponent;\r\n\tLimitDescription: FileInputLimitDescriptionComponent;\r\n\tdragActive: boolean;\r\n\tfileInputSettings: FileInputSettings;\r\n\tonOpenClick: () => void;\r\n}\r\n\r\nexport const Dropzone = (props: DropzoneProps) => {\r\n\tconst { dragActive, DropzoneDragFilesHere, DropzoneDragOrSelectFiles, DropzoneSelectFiles, fileInputSettings, LimitDescription, onOpenClick } = props;\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor } = useDesignSystem(props);\r\n\r\n\treturn (\r\n\t\t<DropzoneWrapper>\r\n\t\t\t<UploadIcon\r\n\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\tonClick={onOpenClick}\r\n\t\t\t>\r\n\t\t\t\t<IconSystem\r\n\t\t\t\t\tariaHidden={true}\r\n\t\t\t\t\tsize={IconSystemSize.big}\r\n\t\t\t\t\tstroke={chooseColor(theme.colors.icon.brand)}\r\n\t\t\t\t\ttype={IconSystemType.uploadCloud}\r\n\t\t\t\t/>\r\n\t\t\t</UploadIcon>\r\n\r\n\t\t\t<Typography\r\n\t\t\t\tcolor={chooseColor(theme.colors.fg.neutral.default)}\r\n\t\t\t\tfullWidth={true}\r\n\t\t\t\ttextAlign={TypographyTextAlign.center}\r\n\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t>\r\n\t\t\t\t{dragActive ? (\r\n\t\t\t\t\t<DropzoneDragFilesHere />\r\n\t\t\t\t) : (\r\n\t\t\t\t\t<DropzoneDragOrSelectFiles\r\n\t\t\t\t\t\tselectedFiles={\r\n\t\t\t\t\t\t\t<SelectFilesLink onClick={onOpenClick}>\r\n\t\t\t\t\t\t\t\t<DropzoneSelectFiles />\r\n\t\t\t\t\t\t\t</SelectFilesLink>\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t/>\r\n\t\t\t\t)}\r\n\t\t\t</Typography>\r\n\r\n\t\t\t<LimitDescriptionWrapper $dragActive={dragActive}>\r\n\t\t\t\t<Typography\r\n\t\t\t\t\tcolor={chooseColor(theme.colors.fg.neutral.subtle)}\r\n\t\t\t\t\tfullWidth={true}\r\n\t\t\t\t\ttextAlign={TypographyTextAlign.center}\r\n\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t>\r\n\t\t\t\t\t<LimitDescription {...fileInputSettings} />\r\n\t\t\t\t</Typography>\r\n\t\t\t</LimitDescriptionWrapper>\r\n\t\t</DropzoneWrapper>\r\n\t);\r\n};\r\n","import { styled } from '@/utils';\r\n\r\nexport const ErrorRowWrapper = styled.li`\r\n\tdisplay: flex;\r\n\tgap: ${(props) => props.theme.spacing.xs};\r\n\talign-items: start;\r\n\tjustify-content: start;\r\n\tpadding: ${(props) => props.theme.spacing.sm} 0;\r\n\tborder-top-color: ${(props) => props.theme.colors.border.neutral.subtlest.light};\r\n\tborder-top-style: solid;\r\n\tborder-top-width: 1px;\r\n`;\r\n\r\nexport const DescriptionSection = styled.div`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\tgap: ${(props) => props.theme.spacing.xxs};\r\n\talign-items: start;\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\n\r\nimport { IconSystem, IconSystemSize, IconSystemType } from '@/components/iconSystem';\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { FontWeight } from '@/theme';\r\n\r\nimport { type FileInputError, type FileInputUploadErrorReasonComponent, type FileInputUploadFailedComponent } from '../../types';\r\n\r\nimport { DescriptionSection, ErrorRowWrapper } from './ErrorRow.style';\r\n\r\nexport interface ErrorRowProps {\r\n\tUploadErrorReason: FileInputUploadErrorReasonComponent;\r\n\tUploadFailed: FileInputUploadFailedComponent;\r\n\terror: FileInputError;\r\n}\r\n\r\nexport const ErrorRow = (props: ErrorRowProps) => {\r\n\tconst { error, UploadErrorReason, UploadFailed } = props;\r\n\r\n\tconst theme = useTheme();\r\n\r\n\treturn (\r\n\t\t<ErrorRowWrapper>\r\n\t\t\t<IconSystem\r\n\t\t\t\tariaHidden={true}\r\n\t\t\t\tsize={IconSystemSize.big}\r\n\t\t\t\tstroke={theme.colors.icon.error.light}\r\n\t\t\t\ttype={IconSystemType.close}\r\n\t\t\t/>\r\n\r\n\t\t\t<DescriptionSection role={'alert'}>\r\n\t\t\t\t<Typography\r\n\t\t\t\t\tcolor={theme.colors.fg.error.light}\r\n\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\tweight={FontWeight.medium500}\r\n\t\t\t\t>\r\n\t\t\t\t\t<UploadFailed fileName={error.fileName} />\r\n\t\t\t\t</Typography>\r\n\r\n\t\t\t\t<Typography\r\n\t\t\t\t\tcolor={theme.colors.fg.neutral.subtle.light}\r\n\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t>\r\n\t\t\t\t\t<UploadErrorReason errorCode={error.code} />\r\n\t\t\t\t</Typography>\r\n\t\t\t</DescriptionSection>\r\n\t\t</ErrorRowWrapper>\r\n\t);\r\n};\r\n","import { styled } from '@/utils';\r\n\r\nexport const FileRowWrapper = styled.li`\r\n\tdisplay: flex;\r\n\tgap: ${(props) => props.theme.spacing.xs};\r\n\talign-items: center;\r\n\tjustify-content: space-between;\r\n\tpadding: ${(props) => props.theme.spacing.sm} 0;\r\n\tborder-top-color: ${(props) => props.theme.colors.border.neutral.subtlest.light};\r\n\tborder-top-style: solid;\r\n\tborder-top-width: 1px;\r\n`;\r\n\r\nexport const LeftSection = styled.div`\r\n\tdisplay: flex;\r\n\tflex-direction: row;\r\n\tgap: ${(props) => props.theme.spacing.xs};\r\n\talign-items: center;\r\n\toverflow: hidden;\r\n`;\r\n\r\nexport const FileName = styled.div`\r\n\toverflow: hidden;\r\n\ttext-overflow: ellipsis;\r\n\twhite-space: nowrap;\r\n`;\r\n\r\nexport const RightSection = styled.div`\r\n\tdisplay: flex;\r\n\tflex-direction: row;\r\n\tflex-wrap: nowrap;\r\n\tgap: ${(props) => props.theme.spacing.xxs};\r\n\talign-items: center;\r\n\tpadding: ${(props) => props.theme.spacing.xxs};\r\n\tcursor: pointer;\r\n\tborder-radius: ${(props) => props.theme.borderRadius.xxs};\r\n\r\n\t&:focus-visible {\r\n\t\toutline-width: 3px;\r\n\t\toutline-style: solid;\r\n\t\toutline-color: ${(props) => props.theme.colors.border.error.light};\r\n\t\toutline-offset: 2px;\r\n\t}\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { type KeyboardEvent, useCallback } from 'react';\r\n\r\nimport { type FileInputRemoveButtonTextComponent } from '@/components/fileInputField/types';\r\nimport { IconSystem, IconSystemSize, IconSystemType } from '@/components/iconSystem';\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { FontWeight } from '@/theme';\r\n\r\nimport { FileName, FileRowWrapper, LeftSection, RightSection } from './FileRow.style';\r\n\r\nexport interface FileRowProps {\r\n\tRemoveButtonText: FileInputRemoveButtonTextComponent;\r\n\tfile: File;\r\n\tgetRemoveButtonAriaLabel: (fileName: string) => string;\r\n\tonRemove: () => void;\r\n}\r\n\r\nexport const FileRow = (props: FileRowProps) => {\r\n\tconst { file, getRemoveButtonAriaLabel, onRemove, RemoveButtonText } = props;\r\n\tconst theme = useTheme();\r\n\r\n\tconst handleRemoveKeyPress = useCallback(\r\n\t\t(event: KeyboardEvent<HTMLElement>) => {\r\n\t\t\tif (event.code === 'Space' || event.key === 'Enter') {\r\n\t\t\t\tonRemove();\r\n\t\t\t\tevent.stopPropagation();\r\n\t\t\t}\r\n\t\t},\r\n\t\t[onRemove],\r\n\t);\r\n\r\n\treturn (\r\n\t\t<FileRowWrapper>\r\n\t\t\t<LeftSection>\r\n\t\t\t\t<IconSystem\r\n\t\t\t\t\tariaHidden={true}\r\n\t\t\t\t\tsize={IconSystemSize.big}\r\n\t\t\t\t\tstroke={theme.colors.icon.neutral.light}\r\n\t\t\t\t\ttype={IconSystemType.fileText}\r\n\t\t\t\t/>\r\n\t\t\t\t<FileName>\r\n\t\t\t\t\t<Typography\r\n\t\t\t\t\t\tcolor={theme.colors.fg.neutral.default.light}\r\n\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\tweight={FontWeight.medium500}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t{file.name}\r\n\t\t\t\t\t</Typography>\r\n\t\t\t\t</FileName>\r\n\t\t\t</LeftSection>\r\n\t\t\t<RightSection\r\n\t\t\t\taria-label={getRemoveButtonAriaLabel(file.name)}\r\n\t\t\t\trole=\"button\"\r\n\t\t\t\ttabIndex={0}\r\n\t\t\t\tonClick={onRemove}\r\n\t\t\t\tonKeyDown={handleRemoveKeyPress}\r\n\t\t\t>\r\n\t\t\t\t<Typography\r\n\t\t\t\t\tcolor={theme.colors.fg.error.light}\r\n\t\t\t\t\tvariant={TypographyVariant.textXs}\r\n\t\t\t\t\tweight={FontWeight.medium500}\r\n\t\t\t\t>\r\n\t\t\t\t\t<RemoveButtonText fileName={file.name} />\r\n\t\t\t\t</Typography>\r\n\t\t\t\t<IconSystem\r\n\t\t\t\t\tariaHidden={true}\r\n\t\t\t\t\tsize={IconSystemSize.small}\r\n\t\t\t\t\tstroke={theme.colors.icon.error.light}\r\n\t\t\t\t\ttype={IconSystemType.trash}\r\n\t\t\t\t/>\r\n\t\t\t</RightSection>\r\n\t\t</FileRowWrapper>\r\n\t);\r\n};\r\n","import {\r\n\ttype FileInputItem,\r\n\tFileInputItemType,\r\n\ttype FileInputRemoveButtonTextComponent,\r\n\ttype FileInputUploadErrorReasonComponent,\r\n\ttype FileInputUploadFailedComponent,\r\n} from '../../types';\r\nimport { ErrorRow } from './ErrorRow';\r\nimport { FileRow } from './FileRow';\r\n\r\nexport interface FileListProps {\r\n\tRemoveButtonText: FileInputRemoveButtonTextComponent;\r\n\tUploadErrorReason: FileInputUploadErrorReasonComponent;\r\n\tUploadFailed: FileInputUploadFailedComponent;\r\n\tgetRemoveButtonAriaLabel: (fileName: string) => string;\r\n\titems: FileInputItem[];\r\n\tonFileRemove: (file: File) => void;\r\n}\r\n\r\nexport const FileList = (props: FileListProps) => {\r\n\tconst { getRemoveButtonAriaLabel, items, onFileRemove, RemoveButtonText, UploadErrorReason, UploadFailed } = props;\r\n\r\n\treturn (\r\n\t\t<ul>\r\n\t\t\t{items.map((item, index) => {\r\n\t\t\t\tif (item.type === FileInputItemType.file) {\r\n\t\t\t\t\treturn (\r\n\t\t\t\t\t\t<FileRow\r\n\t\t\t\t\t\t\tkey={index}\r\n\t\t\t\t\t\t\tRemoveButtonText={RemoveButtonText}\r\n\t\t\t\t\t\t\tfile={item.file}\r\n\t\t\t\t\t\t\tgetRemoveButtonAriaLabel={getRemoveButtonAriaLabel}\r\n\t\t\t\t\t\t\tonRemove={() => onFileRemove(item.file)}\r\n\t\t\t\t\t\t/>\r\n\t\t\t\t\t);\r\n\t\t\t\t}\r\n\r\n\t\t\t\treturn (\r\n\t\t\t\t\t<ErrorRow\r\n\t\t\t\t\t\tkey={index}\r\n\t\t\t\t\t\tUploadErrorReason={UploadErrorReason}\r\n\t\t\t\t\t\tUploadFailed={UploadFailed}\r\n\t\t\t\t\t\terror={item.error}\r\n\t\t\t\t\t/>\r\n\t\t\t\t);\r\n\t\t\t})}\r\n\t\t</ul>\r\n\t);\r\n};\r\n","import { css } from '@emotion/react';\r\n\r\nimport { styled, type ChooseColor } from '@/utils';\r\n\r\ninterface WrapperProps {\r\n\t$active: boolean;\r\n\t$chooseColor: ChooseColor;\r\n\t$invalid: boolean;\r\n}\r\n\r\nexport const Wrapper = styled.div<WrapperProps>`\r\n\tpadding: 0 ${(props) => props.theme.spacing.md};\r\n\tbackground-color: ${(props) =>\r\n\t\tprops.$active ? props.$chooseColor(props.theme.colors.bg.brand.default) : props.$chooseColor(props.theme.colors.bg.neutral.white)};\r\n\tborder-color: ${(props) => props.$chooseColor(props.theme.colors.border.neutral.default)};\r\n\tborder-style: dashed;\r\n\tborder-width: 1px;\r\n\tborder-radius: ${(props) => props.theme.borderRadius.xs};\r\n\ttransition: background-color 500ms;\r\n\r\n\t&:hover {\r\n\t\tbackground-color: ${(props) => props.$chooseColor(props.theme.colors.bg.brand.default)};\r\n\t}\r\n\r\n\t&:focus-visible {\r\n\t\toutline-width: 3px;\r\n\t\toutline-style: solid;\r\n\t\toutline-color: ${(props) => (props.$invalid ? props.$chooseColor(props.theme.colors.border.error) : props.$chooseColor(props.theme.colors.focus))};\r\n\t\toutline-offset: 2px;\r\n\t}\r\n\r\n\t${(props) =>\r\n\t\tprops.$invalid &&\r\n\t\tcss`\r\n\t\t\tborder-color: ${props.$chooseColor(props.theme.colors.border.error)};\r\n\t\t\tborder-style: solid;\r\n\t\t\tborder-width: 2px;\r\n\t\t`}\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { useMergeRefs } from '@floating-ui/react';\r\nimport { forwardRef, type HTMLAttributes, type Ref, useCallback, useMemo, useState } from 'react';\r\nimport { type FileRejection, useDropzone } from 'react-dropzone';\r\nimport { useMediaQuery } from 'usehooks-ts';\r\n\r\nimport { VisuallyHidden } from '@/components/visuallyHidden';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { MediaType } from '@/types';\r\n\r\nimport {\r\n\ttype FileInputDropzoneDragFilesHereComponent,\r\n\ttype FileInputDropzoneDragOrSelectFilesComponent,\r\n\ttype FileInputDropzoneSelectFilesComponent,\r\n\tFileInputErrorCode,\r\n\ttype FileInputItem,\r\n\tFileInputItemType,\r\n\ttype FileInputLimitDescriptionComponent,\r\n\ttype FileInputRemoveButtonTextComponent,\r\n\ttype FileInputSettings,\r\n\ttype FileInputUploadErrorReasonComponent,\r\n\ttype FileInputUploadFailedComponent,\r\n} from '../types';\r\nimport { getFileErrorByDropzoneRejection, normalizeFileExtension } from '../utils';\r\nimport { Dropzone } from './Dropzone';\r\nimport { FileList } from './fileList/FileList';\r\n\r\nimport { Wrapper } from './FileInputControl.style';\r\n\r\nexport interface FileInputControlProps extends FileInputSettings, DesignSystemBaseProps {\r\n\t/** Component displayed when a file is dragged over the dropzone. */\r\n\tDropzoneDragFilesHere: FileInputDropzoneDragFilesHereComponent;\r\n\t/** Component displaying prompt to drag or select files for upload. */\r\n\tDropzoneDragOrSelectFiles: FileInputDropzoneDragOrSelectFilesComponent;\r\n\t/** Clickable text prompting the user to select files for upload. */\r\n\tDropzoneSelectFiles: FileInputDropzoneSelectFilesComponent;\r\n\t/** Component describing the limits for uploaded files. */\r\n\tLimitDescription: FileInputLimitDescriptionComponent;\r\n\t/** Component for label for the remove file button. */\r\n\tRemoveButtonText: FileInputRemoveButtonTextComponent;\r\n\t/** Component displaying the reason for file upload failure. */\r\n\tUploadErrorReason: FileInputUploadErrorReasonComponent;\r\n\t/** Component displayed when file upload fails. */\r\n\tUploadFailed: FileInputUploadFailedComponent;\r\n\t/** Message read by screen readers after file is removed. */\r\n\tgetFileRemovedLiveText?: (fileName: string) => string;\r\n\t/** Message read by screen readers after files are added. */\r\n\tgetFilesAddedLiveText?: (fileNames: string[]) => string;\r\n\t/** aria-label for remove file button. */\r\n\tgetRemoveButtonAriaLabel: (fileName: string) => string;\r\n\tinvalid?: boolean;\r\n\tname: string;\r\n\tonBlur?: () => void;\r\n\tonChange: (files: File[]) => void;\r\n\tvalue: File[];\r\n}\r\n\r\nexport const FileInputControl = forwardRef<HTMLDivElement, FileInputControlProps>((props, ref) => {\r\n\tconst {\r\n\t\tDropzoneDragFilesHere,\r\n\t\tDropzoneDragOrSelectFiles,\r\n\t\tDropzoneSelectFiles,\r\n\t\tfileExtensions: fileExtensionsProp,\r\n\t\tgetFileRemovedLiveText,\r\n\t\tgetFilesAddedLiveText,\r\n\t\tgetRemoveButtonAriaLabel,\r\n\t\tinvalid = false,\r\n\t\tLimitDescription,\r\n\t\tmaxFiles,\r\n\t\tmaxSize,\r\n\t\tmaxTotalSize,\r\n\t\tname,\r\n\t\tonBlur,\r\n\t\tonChange,\r\n\t\tRemoveButtonText,\r\n\t\tUploadErrorReason,\r\n\t\tUploadFailed,\r\n\t\tvalue: files,\r\n\t} = props;\r\n\tconst [hovered, setHovered] = useState(false);\r\n\tconst [items, setItems] = useState<FileInputItem[]>([]);\r\n\tconst theme = useTheme();\r\n\r\n\tconst desktop = useMediaQuery(`(min-width: ${theme.breakpoints.sm})`);\r\n\tconst { chooseColor, colorScheme, mediaType } = useDesignSystem(props, {\r\n\t\tdefaultMediaType: desktop ? MediaType.desktop : MediaType.mobile,\r\n\t});\r\n\r\n\tconst fileExtensions = useMemo(() => fileExtensionsProp.map(normalizeFileExtension), [fileExtensionsProp]);\r\n\r\n\tconst [ariaLiveText, setAriaLiveText] = useState<string | undefined>(undefined);\r\n\r\n\tconst fileInputSettings: FileInputSettings = {\r\n\t\tmaxSize: maxSize,\r\n\t\tfileExtensions: fileExtensions,\r\n\t\tmaxFiles: maxFiles,\r\n\t\tmaxTotalSize: maxTotalSize,\r\n\t};\r\n\r\n\tconst handleDrop = useCallback(\r\n\t\t(acceptedFiles: File[], fileRejections: FileRejection[]) => {\r\n\t\t\tconst errors = fileRejections.map(getFileErrorByDropzoneRejection);\r\n\r\n\t\t\tlet totalFileSize = files.reduce<number>((sizeAccumulator, file) => sizeAccumulator + file.size, 0);\r\n\r\n\t\t\tconst filteredAcceptedFiles = acceptedFiles.filter((file) => {\r\n\t\t\t\tif (typeof maxTotalSize === 'number' && totalFileSize + file.size > maxTotalSize) {\r\n\t\t\t\t\terrors.push({\r\n\t\t\t\t\t\tcode: FileInputErrorCode.totalFileSizeTooLarge,\r\n\t\t\t\t\t\tfileName: file.name,\r\n\t\t\t\t\t});\r\n\r\n\t\t\t\t\treturn false;\r\n\t\t\t\t}\r\n\r\n\t\t\t\tconst fileExtension = file.name.toLowerCase().split('.').pop();\r\n\r\n\t\t\t\tif (fileExtension === undefined || !fileExtensions.includes(fileExtension)) {\r\n\t\t\t\t\terrors.push({\r\n\t\t\t\t\t\tcode: FileInputErrorCode.unsupportedFormat,\r\n\t\t\t\t\t\tfileName: file.name,\r\n\t\t\t\t\t});\r\n\r\n\t\t\t\t\treturn false;\r\n\t\t\t\t}\r\n\r\n\t\t\t\ttotalFileSize += file.size;\r\n\r\n\t\t\t\treturn true;\r\n\t\t\t});\r\n\r\n\t\t\tonChange([...files, ...filteredAcceptedFiles]);\r\n\t\t\tonBlur?.();\r\n\r\n\t\t\tconst fileItems: FileInputItem[] = filteredAcceptedFiles.map((file) => ({\r\n\t\t\t\tfile: file,\r\n\t\t\t\ttype: FileInputItemType.file,\r\n\t\t\t}));\r\n\r\n\t\t\tconst errorItems: FileInputItem[] = errors.map((error) => ({\r\n\t\t\t\terror: error,\r\n\t\t\t\ttype: FileInputItemType.error,\r\n\t\t\t}));\r\n\r\n\t\t\tsetItems((previousItems) => [...previousItems.filter((item) => item.type === FileInputItemType.file), ...fileItems, ...errorItems]);\r\n\r\n\t\t\tsetAriaLiveText(getFilesAddedLiveText?.(filteredAcceptedFiles.map((file) => file.name)) ?? undefined);\r\n\t\t},\r\n\t\t[fileExtensions, files, getFilesAddedLiveText, maxTotalSize, onBlur, onChange],\r\n\t);\r\n\r\n\tconst {\r\n\t\tgetInputProps,\r\n\t\tgetRootProps,\r\n\t\tisDragActive: dragActive,\r\n\t\topen,\r\n\t} = useDropzone({\r\n\t\tonDrop: handleDrop,\r\n\t\tmultiple: true,\r\n\t\tmaxFiles: maxFiles,\r\n\t\tmaxSize: maxSize,\r\n\t\tnoClick: true,\r\n\t});\r\n\r\n\tconst handleFileRemove = useCallback(\r\n\t\t(fileToRemove: File) => {\r\n\t\t\tonChange(files.filter((files) => files !== fileToRemove));\r\n\t\t\tsetItems(items.filter((item) => item.type !== FileInputItemType.file || item.file !== fileToRemove));\r\n\t\t\tsetAriaLiveText(getFileRemovedLiveText?.(fileToRemove.name));\r\n\t\t},\r\n\t\t[items, files, onChange, setAriaLiveText, getFileRemovedLiveText],\r\n\t);\r\n\r\n\tconst rootProps = getRootProps<HTMLAttributes<HTMLDivElement> & { ref?: Ref<HTMLDivElement> }>({\r\n\t\tonMouseEnter: () => setHovered(true),\r\n\t\tonMouseLeave: () => setHovered(false),\r\n\t\trole: 'none',\r\n\t});\r\n\r\n\tconst mergedRef = useMergeRefs([rootProps.ref, ref]);\r\n\r\n\treturn (\r\n\t\t<>\r\n\t\t\t<VisuallyHidden aria-live={'polite'}>{ariaLiveText}</VisuallyHidden>\r\n\r\n\t\t\t<Wrapper\r\n\t\t\t\t$active={dragActive || hovered}\r\n\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t$invalid={invalid}\r\n\t\t\t\t{...rootProps}\r\n\t\t\t\tref={mergedRef}\r\n\t\t\t>\r\n\t\t\t\t<Dropzone\r\n\t\t\t\t\tDropzoneDragFilesHere={DropzoneDragFilesHere}\r\n\t\t\t\t\tDropzoneDragOrSelectFiles={DropzoneDragOrSelectFiles}\r\n\t\t\t\t\tDropzoneSelectFiles={DropzoneSelectFiles}\r\n\t\t\t\t\tLimitDescription={LimitDescription}\r\n\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\tdragActive={dragActive}\r\n\t\t\t\t\tfileInputSettings={fileInputSettings}\r\n\t\t\t\t\tmediaType={mediaType}\r\n\t\t\t\t\tonOpenClick={() => open()}\r\n\t\t\t\t/>\r\n\t\t\t\t<input {...getInputProps({ name: name })} />\r\n\t\t\t\t<FileList\r\n\t\t\t\t\tRemoveButtonText={RemoveButtonText}\r\n\t\t\t\t\tUploadErrorReason={UploadErrorReason}\r\n\t\t\t\t\tUploadFailed={UploadFailed}\r\n\t\t\t\t\tgetRemoveButtonAriaLabel={getRemoveButtonAriaLabel}\r\n\t\t\t\t\titems={items}\r\n\t\t\t\t\tonFileRemove={handleFileRemove}\r\n\t\t\t\t/>\r\n\t\t\t</Wrapper>\r\n\t\t</>\r\n\t);\r\n});\r\n\r\nFileInputControl.displayName = 'FileInputControl';\r\n","import { forwardRef, type ComponentProps } from 'react';\r\n\r\nimport { withFieldWrapper } from '@/components/fieldWrapper/withFieldWrapper';\r\n\r\nimport { FileInputControl, type FileInputControlProps } from './FileInputControl';\r\n\r\nconst FileInputBase = withFieldWrapper<FileInputControlProps, HTMLDivElement>(FileInputControl);\r\n\r\nexport const FileInput = forwardRef<HTMLDivElement, ComponentProps<typeof FileInputBase>>((props, ref) => {\r\n\tconst { labelAs = 'span', ...restProps } = props;\r\n\r\n\treturn (\r\n\t\t<FileInputBase\r\n\t\t\t{...restProps}\r\n\t\t\tlabelAs={labelAs}\r\n\t\t\tref={ref}\r\n\t\t/>\r\n\t);\r\n});\r\n\r\nFileInput.displayName = 'FileInput';\r\n\r\nexport type FileInputProps = ComponentProps<typeof FileInput>;\r\n","export enum FormatAmountCurrencyDisplay {\r\n\tcode = 'code',\r\n\tname = 'name',\r\n\tnone = 'none',\r\n\tsymbol = 'symbol',\r\n}\r\n\r\nexport enum FormatAmountGrouping {\r\n\talways = 'always',\r\n\tauto = 'auto',\r\n\tnone = 'none',\r\n}\r\n\r\nexport interface FormatAmountDescriptor {\r\n\tcurrency?: string;\r\n\tcurrencyDisplay?: FormatAmountCurrencyDisplay;\r\n\tgrouping?: FormatAmountGrouping;\r\n\tmaximumFractionDigits?: number;\r\n\tminimumFractionDigits?: number;\r\n\tvalue: number;\r\n}\r\n\r\nexport interface FormatAmountParam extends FormatAmountDescriptor {}\r\n","import { type FormatNumberOptions } from '@formatjs/intl';\r\n\r\nimport { FormatAmountCurrencyDisplay, FormatAmountGrouping, type FormatAmountDescriptor } from './types';\r\n\r\nexport const getUseGrouping = (grouping: FormatAmountGrouping) => {\r\n\tswitch (grouping) {\r\n\t\tcase FormatAmountGrouping.auto:\r\n\t\t\treturn 'auto' as const;\r\n\t\tcase FormatAmountGrouping.always:\r\n\t\t\t// 'always' and 'true' have the same behavior: grouping separators are always applied\r\n\t\t\treturn true;\r\n\t\tcase FormatAmountGrouping.none:\r\n\t\t\treturn false;\r\n\t\tdefault:\r\n\t\t\tthrow new Error('Unexpected FormatAmountGrouping enum value');\r\n\t}\r\n};\r\n\r\nexport const getFormatNumberOptions = (param: FormatAmountDescriptor): FormatNumberOptions => {\r\n\tconst {\r\n\t\tcurrency = 'CZK',\r\n\t\tcurrencyDisplay = FormatAmountCurrencyDisplay.symbol,\r\n\t\tgrouping = FormatAmountGrouping.auto,\r\n\t\tmaximumFractionDigits = 0,\r\n\t\tminimumFractionDigits = 0,\r\n\t} = param;\r\n\r\n\treturn {\r\n\t\tstyle: 'currency',\r\n\t\tcurrency: currency,\r\n\t\tcurrencyDisplay: currencyDisplay === FormatAmountCurrencyDisplay.none ? FormatAmountCurrencyDisplay.code : currencyDisplay,\r\n\t\tminimumFractionDigits: minimumFractionDigits,\r\n\t\tmaximumFractionDigits: maximumFractionDigits,\r\n\t\tuseGrouping: getUseGrouping(grouping),\r\n\t};\r\n};\r\n\r\nexport const removeCurrencyCode = (formatted: string) => formatted.replace(/\\s([a-zA-Zá-žÁ-Ž]+)$/, '');\r\n","import { useCallback } from 'react';\r\nimport { useIntl } from 'react-intl';\r\n\r\nimport { FormatAmountCurrencyDisplay, type FormatAmountParam } from '../types';\r\nimport { getFormatNumberOptions, removeCurrencyCode } from '../utils';\r\n\r\nexport const useFormatAmount = () => {\r\n\tconst intl = useIntl();\r\n\r\n\tconst callback = useCallback(\r\n\t\t(param: FormatAmountParam): string => {\r\n\t\t\tconst options = getFormatNumberOptions(param);\r\n\t\t\tconst result = intl.formatNumber(param.value, options);\r\n\r\n\t\t\treturn param.currencyDisplay === FormatAmountCurrencyDisplay.none ? removeCurrencyCode(result) : result;\r\n\t\t},\r\n\t\t[intl],\r\n\t);\r\n\r\n\treturn callback;\r\n};\r\n","import { useFormatter } from 'next-intl';\r\nimport { useCallback } from 'react';\r\n\r\nimport { FormatAmountCurrencyDisplay, type FormatAmountParam } from '../types';\r\nimport { getFormatNumberOptions, removeCurrencyCode } from '../utils';\r\n\r\nexport const useFormatAmount = () => {\r\n\tconst format = useFormatter();\r\n\r\n\tconst callback = useCallback(\r\n\t\t(param: FormatAmountParam): string => {\r\n\t\t\tconst options = getFormatNumberOptions(param);\r\n\t\t\tconst result = format.number(param.value, options);\r\n\r\n\t\t\treturn param.currencyDisplay === FormatAmountCurrencyDisplay.none ? removeCurrencyCode(result) : result;\r\n\t\t},\r\n\t\t[format],\r\n\t);\r\n\r\n\treturn callback;\r\n};\r\n","import { VisuallyHidden } from '@/components/visuallyHidden';\r\n\r\nimport { FormatAmountCurrencyDisplay, type FormatAmountDescriptor, FormatAmountGrouping, type FormatAmountParam } from './types';\r\n\r\nexport interface BaseFormattedAmountProps extends FormatAmountDescriptor {\r\n\tformatAmount: (param: FormatAmountParam) => string;\r\n}\r\n\r\n/**\r\n * displays formatted amount with currency and formatting options\r\n * it includes an accessibility-friendly version without grouping for screen readers\r\n * if the formatted amount with and without grouping is the same, only one version is displayed\r\n */\r\nexport const BaseFormattedAmount = (props: BaseFormattedAmountProps) => {\r\n\tconst {\r\n\t\tcurrency = 'CZK',\r\n\t\tcurrencyDisplay = FormatAmountCurrencyDisplay.symbol,\r\n\t\tformatAmount,\r\n\t\tgrouping = FormatAmountGrouping.auto,\r\n\t\tmaximumFractionDigits = 0,\r\n\t\tminimumFractionDigits = 0,\r\n\t\tvalue,\r\n\t} = props;\r\n\r\n\t// formatting parameters for amount, including data from props\r\n\tconst param: FormatAmountParam = {\r\n\t\tcurrency: currency,\r\n\t\tminimumFractionDigits: minimumFractionDigits,\r\n\t\tmaximumFractionDigits: maximumFractionDigits,\r\n\t\tvalue: value,\r\n\t\tcurrencyDisplay: currencyDisplay,\r\n\t\tgrouping: grouping,\r\n\t};\r\n\r\n\t// formatting parameters for amount without grouping, used for accessibility (screen readers)\r\n\tconst noneGroupingParam: FormatAmountParam = {\r\n\t\t...param,\r\n\t\tgrouping: FormatAmountGrouping.none,\r\n\t};\r\n\r\n\tconst amount = formatAmount(param);\r\n\tconst noneGroupingAmount = formatAmount(noneGroupingParam);\r\n\r\n\tif (amount === noneGroupingAmount) {\r\n\t\t// formatted amount is the same with and without grouping\r\n\t\treturn <>{amount}</>;\r\n\t}\r\n\r\n\treturn (\r\n\t\t<>\r\n\t\t\t{/* visible amount with grouping */}\r\n\t\t\t<span aria-hidden={true}>{amount}</span>\r\n\r\n\t\t\t{/* screen reader accessibility version without grouping */}\r\n\t\t\t<VisuallyHidden>{noneGroupingAmount}</VisuallyHidden>\r\n\t\t</>\r\n\t);\r\n};\r\n","import { useCallback } from 'react';\r\nimport { useIntl } from 'react-intl';\r\n\r\nexport interface FormatPercentageParam {\r\n\tmaximumFractionDigits?: number;\r\n\tminimumFractionDigits?: number;\r\n\tvalue: number;\r\n}\r\n\r\nexport const useFormatPercentage = () => {\r\n\tconst intl = useIntl();\r\n\r\n\tconst callback = useCallback(\r\n\t\t(param: FormatPercentageParam): string => {\r\n\t\t\tconst { maximumFractionDigits = 2, minimumFractionDigits = 0, value } = param;\r\n\r\n\t\t\treturn intl.formatNumber(value / 100, {\r\n\t\t\t\tstyle: 'percent',\r\n\t\t\t\tminimumFractionDigits: minimumFractionDigits,\r\n\t\t\t\tmaximumFractionDigits: maximumFractionDigits,\r\n\t\t\t});\r\n\t\t},\r\n\t\t[intl],\r\n\t);\r\n\r\n\treturn callback;\r\n};\r\n","import { memo } from 'react';\r\n\r\nimport { useFormatPercentage } from './useFormatPercentage';\r\n\r\nexport interface FormattedPercentageProps {\r\n\tmaximumFractionDigits?: number;\r\n\tminimumFractionDigits?: number;\r\n\tvalue: number;\r\n}\r\n\r\nconst FormattedPercentageInner = (props: FormattedPercentageProps) => {\r\n\tconst { maximumFractionDigits = 2, minimumFractionDigits = 0, value } = props;\r\n\r\n\tconst formatPercentage = useFormatPercentage();\r\n\r\n\treturn formatPercentage({\r\n\t\tminimumFractionDigits: minimumFractionDigits,\r\n\t\tmaximumFractionDigits: maximumFractionDigits,\r\n\t\tvalue: value,\r\n\t});\r\n};\r\n\r\nexport const FormattedPercentage = memo(FormattedPercentageInner);\r\n","import { useFormatPercentage } from './useFormatPercentage';\r\n\r\nexport { FormattedPercentage, type FormattedPercentageProps } from './FormattedPercentage';\r\nexport { useFormatPercentage };\r\n\r\n/** @deprecated Use `useFormatPercentage` instead */\r\nexport const useFormattedPercentage = useFormatPercentage;\r\n","import { type ReactNode } from 'react';\r\n\r\nexport enum InfoboxVariant {\r\n\tprimary = 'primary',\r\n\tsecondary = 'secondary',\r\n}\r\n\r\nexport enum InfoboxSize {\r\n\tmd = 'md',\r\n\tsm = 'sm',\r\n\txs = 'xs',\r\n}\r\n\r\nexport interface InfoboxTextContent {\r\n\tprimary: ReactNode;\r\n\tsecondary?: ReactNode;\r\n}\r\n","import { css } from '@emotion/react';\r\n\r\nimport { ColorScheme, MediaType } from '@/types';\r\nimport { styled, type ChooseColor } from '@/utils';\r\n\r\nimport { InfoboxSize, InfoboxVariant } from './types';\r\n\r\ninterface InfoboxStyledProps {\r\n\t$chooseColor: ChooseColor;\r\n\t$colorScheme: ColorScheme;\r\n\t$fullWidth: boolean;\r\n\t$isWarning: boolean;\r\n\t$mediaType: MediaType;\r\n\t$size: InfoboxSize;\r\n\t$variant: InfoboxVariant;\r\n}\r\n\r\nexport const InfoboxStyled = styled.div<InfoboxStyledProps>`\r\n\t/* common styles */\r\n\tbox-sizing: border-box;\r\n\twidth: ${({ $fullWidth }) => ($fullWidth === true ? '100%' : 'initial')};\r\n\tmin-width: 100px;\r\n\tbox-shadow: ${({ $colorScheme, theme }) => {\r\n\t\tswitch ($colorScheme) {\r\n\t\t\tcase ColorScheme.light:\r\n\t\t\t\treturn 'none';\r\n\t\t\tcase ColorScheme.dark:\r\n\t\t\t\treturn theme.colors.shadow.ultraStrongBlueLg;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected value of enum ColorScheme infobox.styles.ts InfoboxStyled box-shadow');\r\n\t\t}\r\n\t}};\r\n\r\n\t@media (min-width: ${({ theme }) => theme.breakpoints.sm}) {\r\n\t\tmin-width: 320px;\r\n\t}\r\n\r\n\t/* variant specific styles */\r\n\r\n\t${({ $chooseColor, $colorScheme, $isWarning, $variant, theme }) => {\r\n\t\tswitch (true) {\r\n\t\t\tcase $variant === InfoboxVariant.primary && $isWarning:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tcolor: ${$chooseColor(theme.colors.fg.accent.bold)};\r\n\t\t\t\t\tbackground-color: ${$chooseColor(theme.colors.bg.accent)};\r\n\t\t\t\t\tborder: 1px solid ${$chooseColor(theme.colors.border.accent)};\r\n\t\t\t\t`;\r\n\t\t\tcase $variant === InfoboxVariant.primary && !$isWarning && $colorScheme === ColorScheme.light:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tcolor: ${theme.colors.fg.neutral.default.light};\r\n\t\t\t\t\tbackground-color: ${theme.colors.bg.info.default.light};\r\n\t\t\t\t\tborder: 1px solid ${theme.colors.border.brand.subtlest.light};\r\n\t\t\t\t`;\r\n\t\t\tcase $variant === InfoboxVariant.primary && !$isWarning && $colorScheme === ColorScheme.dark:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tcolor: ${theme.palette.white};\r\n\t\t\t\t\tbackground-color: ${theme.colors.surface.risen.dark};\r\n\t\t\t\t\tborder: 1px solid ${theme.colors.border.neutral.subtlest.dark};\r\n\t\t\t\t`;\r\n\t\t\tcase $variant === InfoboxVariant.secondary && $isWarning:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tcolor: ${$chooseColor(theme.colors.fg.accent.bold)};\r\n\t\t\t\t\tbackground-color: ${theme.palette.transparent};\r\n\t\t\t\t\tborder: 1px solid ${$chooseColor(theme.colors.border.accent)};\r\n\t\t\t\t`;\r\n\t\t\tcase $variant === InfoboxVariant.secondary && !$isWarning:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tcolor: ${$chooseColor(theme.colors.fg.neutral.default)};\r\n\t\t\t\t\tbackground-color: ${theme.palette.transparent};\r\n\t\t\t\t\tborder: 1px solid ${$chooseColor(theme.colors.border.brand.subtlest)};\r\n\t\t\t\t`;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected combination InfoboxVariant and $isWarning in infobox.styles.ts');\r\n\t\t}\r\n\t}}\r\n\r\n\t/* size specific styles */\r\n\t\r\n\t${({ $size, theme }) => {\r\n\t\tswitch ($size) {\r\n\t\t\tcase InfoboxSize.xs:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tpadding: ${theme.spacing.md} ${theme.spacing.lg};\r\n\t\t\t\t\tborder-radius: ${theme.borderRadius.xs};\r\n\t\t\t\t`;\r\n\t\t\tcase InfoboxSize.sm:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tpadding: ${theme.spacing.sm} ${theme.spacing.md};\r\n\t\t\t\t\tborder-radius: ${theme.borderRadius.xs};\r\n\t\t\t\t`;\r\n\t\t\tcase InfoboxSize.md:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tpadding: ${theme.spacing.md} ${theme.spacing.sm};\r\n\t\t\t\t\tborder-radius: ${theme.borderRadius.xs};\r\n\t\t\t\t`;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected value of enum InfoboxSize in infobox.styles.ts');\r\n\t\t}\r\n\t}}\r\n\r\n\t&:focus-visible {\r\n\t\toutline-width: 3px;\r\n\t\toutline-style: solid;\r\n\t\toutline-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.focus)};\r\n\t\toutline-offset: 2px;\r\n\t}\r\n`;\r\n\r\nconst getFlexDirection = (mediaType: MediaType) => {\r\n\tswitch (mediaType) {\r\n\t\tcase MediaType.desktop:\r\n\t\t\treturn 'row';\r\n\t\tcase MediaType.mobile:\r\n\t\t\treturn 'column';\r\n\t\tdefault:\r\n\t\t\tthrow new Error('unexpected value of enum MediaType in infobox.styles.ts Wrapper flex-direction');\r\n\t}\r\n};\r\n\r\ninterface InfoboxLayoutProps {\r\n\t$mediaType: MediaType;\r\n}\r\n\r\nexport const InfoboxLayout = styled.div<InfoboxLayoutProps>`\r\n\tdisplay: flex;\r\n\trow-gap: ${({ theme }) => theme.spacing.xs};\r\n\tcolumn-gap: ${({ theme }) => theme.spacing.md};\r\n\twidth: 100%;\r\n\r\n\t${({ $mediaType }) => {\r\n\t\tconst flexDirection = getFlexDirection($mediaType);\r\n\r\n\t\treturn css`\r\n\t\t\tflex-direction: ${flexDirection};\r\n\t\t\talign-items: ${flexDirection === 'row' ? 'center' : 'start'};\r\n\t\t`;\r\n\t}}\r\n`;\r\n\r\ninterface ContentWrapperProps {\r\n\t$mediaType: MediaType;\r\n}\r\n\r\nexport const ContentWrapper = styled.div<ContentWrapperProps>`\r\n\tdisplay: flex;\r\n\tflex: 1;\r\n\tgap: ${({ theme }) => theme.spacing.md};\r\n\tjustify-content: space-between;\r\n\r\n\t${({ $mediaType }) => {\r\n\t\tconst flexDirection = getFlexDirection($mediaType);\r\n\r\n\t\treturn css`\r\n\t\t\tflex-direction: ${flexDirection};\r\n\t\t\talign-items: ${flexDirection === 'row' ? 'center' : 'start'};\r\n\t\t`;\r\n\t}}\r\n`;\r\n\r\nexport const TextContentWrapper = styled.div`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\trow-gap: ${({ theme }) => theme.spacing.xxs};\r\n\tjustify-content: center;\r\n`;\r\n\r\nexport const ActionNodeWrapper = styled.div`\r\n\tflex-shrink: 0;\r\n`;\r\n\r\nexport const ChildrenWrapper = styled.div`\r\n\tflex-grow: 1;\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { type AriaAttributes, type AriaRole, forwardRef, type ReactNode, useMemo } from 'react';\r\n\r\nimport { CircularProgressBar } from '@/components/circularProgressBar/CircularProgressBar';\r\nimport { IconProduct, IconProductHighlightType, IconProductSize } from '@/components/iconProduct';\r\nimport { type IconProductType, IconProductVariant } from '@/components/iconProduct/index';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { ColorScheme, MediaType } from '@/types';\r\nimport { isRenderable } from '@/utils';\r\n\r\nimport { type InfoboxSize, type InfoboxTextContent, InfoboxVariant } from './types';\r\n\r\nimport { ActionNodeWrapper, ChildrenWrapper, ContentWrapper, InfoboxLayout, InfoboxStyled, TextContentWrapper } from './Infobox.style';\r\n\r\nexport interface InfoboxProps extends DesignSystemBaseProps, AriaAttributes {\r\n\t/** Cannot be used alongside `children`. */\r\n\tactionNode?: ReactNode;\r\n\tchildren?: ReactNode;\r\n\t/** In order to render a circular progress bar, `iconProduct` must be provided as well. */\r\n\tcircularProgress?: number;\r\n\tclassName?: string;\r\n\tfullWidth?: boolean;\r\n\ticonProduct?: IconProductType;\r\n\tid?: string;\r\n\tisWarning?: boolean;\r\n\trole?: AriaRole;\r\n\tsize: InfoboxSize;\r\n\ttabIndex?: number;\r\n\t/** Cannot be used alongside `children`. */\r\n\ttextContent?: InfoboxTextContent;\r\n\tvariant: InfoboxVariant;\r\n}\r\n\r\nexport const Infobox = forwardRef<HTMLDivElement, InfoboxProps>((props, ref) => {\r\n\tconst {\r\n\t\tactionNode,\r\n\t\tchildren,\r\n\t\tcircularProgress,\r\n\t\tclassName,\r\n\t\tcolorScheme: colorSchemeProp, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\tfullWidth = false,\r\n\t\ticonProduct,\r\n\t\tid,\r\n\t\tisWarning = false,\r\n\t\tmediaType: mediaTypeProp, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\trole,\r\n\t\tsize,\r\n\t\ttabIndex,\r\n\t\ttextContent,\r\n\t\tvariant,\r\n\t\t...otherProps\r\n\t} = props;\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor, colorScheme, mediaType } = useDesignSystem(props);\r\n\r\n\tconst iconSize = useMemo<IconProductSize>(() => {\r\n\t\tswitch (mediaType) {\r\n\t\t\tcase MediaType.desktop:\r\n\t\t\t\treturn IconProductSize.big;\r\n\t\t\tcase MediaType.mobile:\r\n\t\t\t\treturn IconProductSize.small;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected value of enum MediaType in infobox.tsx iconSize');\r\n\t\t}\r\n\t}, [mediaType]);\r\n\r\n\tconst iconStroke = useMemo<string | undefined>(() => {\r\n\t\tswitch (true) {\r\n\t\t\tcase isWarning:\r\n\t\t\t\treturn chooseColor(theme.colors.fg.accent.default);\r\n\t\t\tcase colorScheme === ColorScheme.dark:\r\n\t\t\t\treturn theme.palette.white;\r\n\t\t\tcase colorScheme === ColorScheme.light:\r\n\t\t\t\treturn undefined;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected combination of conditions in infobox.tsx iconStroke');\r\n\t\t}\r\n\t}, [chooseColor, colorScheme, isWarning, theme.colors.fg.accent.default, theme.palette.white]);\r\n\r\n\tif ((isRenderable(actionNode) || textContent) && isRenderable(children)) {\r\n\t\tthrow new Error('Infobox encountered both textContent/actionNode and children. These props are mutually exclusive.');\r\n\t}\r\n\r\n\treturn (\r\n\t\t<InfoboxStyled\r\n\t\t\t$chooseColor={chooseColor}\r\n\t\t\t$colorScheme={colorScheme}\r\n\t\t\t$fullWidth={fullWidth}\r\n\t\t\t$isWarning={isWarning}\r\n\t\t\t$mediaType={mediaType}\r\n\t\t\t$size={size}\r\n\t\t\t$variant={variant}\r\n\t\t\tclassName={className}\r\n\t\t\tid={id}\r\n\t\t\tref={ref}\r\n\t\t\trole={role}\r\n\t\t\ttabIndex={tabIndex}\r\n\t\t\t{...otherProps}\r\n\t\t>\r\n\t\t\t<InfoboxLayout $mediaType={mediaType}>\r\n\t\t\t\t{iconProduct !== undefined && circularProgress === undefined && (\r\n\t\t\t\t\t<IconProduct\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\thighlightType={variant === InfoboxVariant.primary ? IconProductHighlightType.defaultInverse : IconProductHighlightType.default}\r\n\t\t\t\t\t\tsize={iconSize}\r\n\t\t\t\t\t\tstroke={iconStroke}\r\n\t\t\t\t\t\ttype={iconProduct}\r\n\t\t\t\t\t\tvariant={IconProductVariant.default}\r\n\t\t\t\t\t/>\r\n\t\t\t\t)}\r\n\r\n\t\t\t\t{iconProduct !== undefined && circularProgress !== undefined && (\r\n\t\t\t\t\t<CircularProgressBar\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\ticonProduct={iconProduct}\r\n\t\t\t\t\t\tmediaType={mediaType}\r\n\t\t\t\t\t\tprogress={circularProgress}\r\n\t\t\t\t\t/>\r\n\t\t\t\t)}\r\n\r\n\t\t\t\t{textContent || isRenderable(actionNode) ? (\r\n\t\t\t\t\t<ContentWrapper $mediaType={mediaType}>\r\n\t\t\t\t\t\t{textContent && (\r\n\t\t\t\t\t\t\t<TextContentWrapper>\r\n\t\t\t\t\t\t\t\t<div>{textContent.primary}</div>\r\n\t\t\t\t\t\t\t\t{isRenderable(textContent.secondary) && <div>{textContent.secondary}</div>}\r\n\t\t\t\t\t\t\t</TextContentWrapper>\r\n\t\t\t\t\t\t)}\r\n\t\t\t\t\t\t{isRenderable(actionNode) && <ActionNodeWrapper>{actionNode}</ActionNodeWrapper>}\r\n\t\t\t\t\t</ContentWrapper>\r\n\t\t\t\t) : (\r\n\t\t\t\t\t<ChildrenWrapper>{children}</ChildrenWrapper>\r\n\t\t\t\t)}\r\n\t\t\t</InfoboxLayout>\r\n\t\t</InfoboxStyled>\r\n\t);\r\n});\r\n\r\nInfobox.displayName = 'Infobox';\r\n","import { createContext } from 'react';\r\n\r\nimport { type FormConfig } from './types';\r\n\r\nexport const FormConfigContext = createContext<FormConfig>({});\r\n","import { useFormContext as useReactHookFormContext, type FieldValues } from 'react-hook-form';\r\n\r\nimport { type UseFormReturn } from './useForm';\r\n\r\nexport const useFormContext = <TFieldValues extends FieldValues>() => useReactHookFormContext() as unknown as UseFormReturn<TFieldValues>;\r\n","import { styled } from '@/utils';\r\n\r\nexport const SubmitResultModalContentStyled = styled.div`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\tgap: ${(props) => props.theme.spacing.lg};\r\n`;\r\n","export enum IconFlagType {\r\n\tcz = 'cz',\r\n\teu = 'eu',\r\n\thr = 'hr',\r\n\tusa = 'usa',\r\n}\r\n","export const IconFlagCz = () => {\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t\txmlnsXlink=\"http://www.w3.org/1999/xlink\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\td=\"M12 24C18.6274 24 24 18.6274 24 12C24 5.37258 18.6274 0 12 0C5.37258 0 0 5.37258 0 12C0 18.6274 5.37258 24 12 24Z\"\r\n\t\t\t\tfill=\"#D8D8D8\"\r\n\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t/>\r\n\t\t\t<mask\r\n\t\t\t\theight=\"24\"\r\n\t\t\t\tid=\"mask0_1885_73294\"\r\n\t\t\t\tmaskUnits=\"userSpaceOnUse\"\r\n\t\t\t\t// style=\"mask-type:luminance\"\r\n\t\t\t\twidth=\"24\"\r\n\t\t\t\tx=\"0\"\r\n\t\t\t\ty=\"0\"\r\n\t\t\t>\r\n\t\t\t\t<path\r\n\t\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\t\td=\"M12 24C18.6274 24 24 18.6274 24 12C24 5.37258 18.6274 0 12 0C5.37258 0 0 5.37258 0 12C0 18.6274 5.37258 24 12 24Z\"\r\n\t\t\t\t\tfill=\"white\"\r\n\t\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t\t/>\r\n\t\t\t</mask>\r\n\t\t\t<g mask=\"url(#mask0_1885_73294)\">\r\n\t\t\t\t<rect\r\n\t\t\t\t\tfill=\"url(#patternCz)\"\r\n\t\t\t\t\theight=\"24\"\r\n\t\t\t\t\twidth=\"24\"\r\n\t\t\t\t/>\r\n\t\t\t</g>\r\n\t\t\t<defs>\r\n\t\t\t\t<pattern\r\n\t\t\t\t\theight=\"1\"\r\n\t\t\t\t\tid=\"patternCz\"\r\n\t\t\t\t\tpatternContentUnits=\"objectBoundingBox\"\r\n\t\t\t\t\twidth=\"1\"\r\n\t\t\t\t>\r\n\t\t\t\t\t<use\r\n\t\t\t\t\t\ttransform=\"translate(-0.236607 -0.368421) scale(0.00339227)\"\r\n\t\t\t\t\t\txlinkHref=\"#image0_1885_73294\"\r\n\t\t\t\t\t/>\r\n\t\t\t\t</pattern>\r\n\t\t\t\t<image\r\n\t\t\t\t\theight=\"512\"\r\n\t\t\t\t\tid=\"image0_1885_73294\"\r\n\t\t\t\t\twidth=\"512\"\r\n\t\t\t\t\txlinkHref=\"data:image/png;base64,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\"\r\n\t\t\t\t/>\r\n\t\t\t</defs>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","export const IconFlagEu = () => {\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t\txmlnsXlink=\"http://www.w3.org/1999/xlink\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\td=\"M12 24C18.6274 24 24 18.6274 24 12C24 5.37258 18.6274 0 12 0C5.37258 0 0 5.37258 0 12C0 18.6274 5.37258 24 12 24Z\"\r\n\t\t\t\tfill=\"#D8D8D8\"\r\n\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t/>\r\n\t\t\t<mask\r\n\t\t\t\theight=\"24\"\r\n\t\t\t\tid=\"mask0_1885_73273\"\r\n\t\t\t\tmaskUnits=\"userSpaceOnUse\"\r\n\t\t\t\t// style=\"mask-type:luminance\"\r\n\t\t\t\twidth=\"24\"\r\n\t\t\t\tx=\"0\"\r\n\t\t\t\ty=\"0\"\r\n\t\t\t>\r\n\t\t\t\t<path\r\n\t\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\t\td=\"M12 24C18.6274 24 24 18.6274 24 12C24 5.37258 18.6274 0 12 0C5.37258 0 0 5.37258 0 12C0 18.6274 5.37258 24 12 24Z\"\r\n\t\t\t\t\tfill=\"white\"\r\n\t\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t\t/>\r\n\t\t\t</mask>\r\n\t\t\t<g mask=\"url(#mask0_1885_73273)\">\r\n\t\t\t\t<rect\r\n\t\t\t\t\tfill=\"url(#patternEu)\"\r\n\t\t\t\t\theight=\"24\"\r\n\t\t\t\t\twidth=\"36\"\r\n\t\t\t\t\tx=\"-6.3158\"\r\n\t\t\t\t/>\r\n\t\t\t</g>\r\n\t\t\t<defs>\r\n\t\t\t\t<pattern\r\n\t\t\t\t\theight=\"1\"\r\n\t\t\t\t\tid=\"patternEu\"\r\n\t\t\t\t\tpatternContentUnits=\"objectBoundingBox\"\r\n\t\t\t\t\twidth=\"1\"\r\n\t\t\t\t>\r\n\t\t\t\t\t<use\r\n\t\t\t\t\t\ttransform=\"scale(0.00392157 0.00588235)\"\r\n\t\t\t\t\t\txlinkHref=\"#image0_1885_73273\"\r\n\t\t\t\t\t/>\r\n\t\t\t\t</pattern>\r\n\t\t\t\t<image\r\n\t\t\t\t\theight=\"170\"\r\n\t\t\t\t\tid=\"image0_1885_73273\"\r\n\t\t\t\t\twidth=\"255\"\r\n\t\t\t\t\txlinkHref=\"data:image/png;base64,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\"\r\n\t\t\t\t/>\r\n\t\t\t</defs>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","export const IconFlagHr = () => {\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t\txmlnsXlink=\"http://www.w3.org/1999/xlink\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\td=\"M12 24C18.6274 24 24 18.6274 24 12C24 5.37258 18.6274 0 12 0C5.37258 0 0 5.37258 0 12C0 18.6274 5.37258 24 12 24Z\"\r\n\t\t\t\tfill=\"#D8D8D8\"\r\n\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t/>\r\n\t\t\t<mask\r\n\t\t\t\theight=\"24\"\r\n\t\t\t\tid=\"mask0_1885_73282\"\r\n\t\t\t\tmaskUnits=\"userSpaceOnUse\"\r\n\t\t\t\t// style=\"mask-type:luminance\"\r\n\t\t\t\twidth=\"24\"\r\n\t\t\t\tx=\"0\"\r\n\t\t\t\ty=\"0\"\r\n\t\t\t>\r\n\t\t\t\t<path\r\n\t\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\t\td=\"M12 24C18.6274 24 24 18.6274 24 12C24 5.37258 18.6274 0 12 0C5.37258 0 0 5.37258 0 12C0 18.6274 5.37258 24 12 24Z\"\r\n\t\t\t\t\tfill=\"white\"\r\n\t\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t\t/>\r\n\t\t\t</mask>\r\n\t\t\t<g mask=\"url(#mask0_1885_73282)\">\r\n\t\t\t\t<rect\r\n\t\t\t\t\tfill=\"url(#patternHr)\"\r\n\t\t\t\t\theight=\"41.6842\"\r\n\t\t\t\t\twidth=\"41.6842\"\r\n\t\t\t\t\tx=\"-8.8421\"\r\n\t\t\t\t\ty=\"-8.8421\"\r\n\t\t\t\t/>\r\n\t\t\t</g>\r\n\t\t\t<defs>\r\n\t\t\t\t<pattern\r\n\t\t\t\t\theight=\"1\"\r\n\t\t\t\t\tid=\"patternHr\"\r\n\t\t\t\t\tpatternContentUnits=\"objectBoundingBox\"\r\n\t\t\t\t\twidth=\"1\"\r\n\t\t\t\t>\r\n\t\t\t\t\t<use\r\n\t\t\t\t\t\ttransform=\"scale(0.00444444)\"\r\n\t\t\t\t\t\txlinkHref=\"#image0_1885_73282\"\r\n\t\t\t\t\t/>\r\n\t\t\t\t</pattern>\r\n\t\t\t\t<image\r\n\t\t\t\t\theight=\"225\"\r\n\t\t\t\t\tid=\"image0_1885_73282\"\r\n\t\t\t\t\twidth=\"225\"\r\n\t\t\t\t\txlinkHref=\"data:image/png;base64,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\"\r\n\t\t\t\t/>\r\n\t\t\t</defs>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","export const IconFlagUsa = () => {\r\n\treturn (\r\n\t\t<svg\r\n\t\t\tfill=\"none\"\r\n\t\t\theight=\"24\"\r\n\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\twidth=\"24\"\r\n\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t\txmlnsXlink=\"http://www.w3.org/1999/xlink\"\r\n\t\t>\r\n\t\t\t<path\r\n\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\td=\"M12 24C18.6274 24 24 18.6274 24 12C24 5.37258 18.6274 0 12 0C5.37258 0 0 5.37258 0 12C0 18.6274 5.37258 24 12 24Z\"\r\n\t\t\t\tfill=\"#D8D8D8\"\r\n\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t/>\r\n\t\t\t<mask\r\n\t\t\t\theight=\"24\"\r\n\t\t\t\tid=\"mask0_1885_73241\"\r\n\t\t\t\tmaskUnits=\"userSpaceOnUse\"\r\n\t\t\t\t// style=\"mask-type:luminance\"\r\n\t\t\t\twidth=\"24\"\r\n\t\t\t\tx=\"0\"\r\n\t\t\t\ty=\"0\"\r\n\t\t\t>\r\n\t\t\t\t<path\r\n\t\t\t\t\tclipRule=\"evenodd\"\r\n\t\t\t\t\td=\"M12 24C18.6274 24 24 18.6274 24 12C24 5.37258 18.6274 0 12 0C5.37258 0 0 5.37258 0 12C0 18.6274 5.37258 24 12 24Z\"\r\n\t\t\t\t\tfill=\"white\"\r\n\t\t\t\t\tfillRule=\"evenodd\"\r\n\t\t\t\t/>\r\n\t\t\t</mask>\r\n\t\t\t<g mask=\"url(#mask0_1885_73241)\">\r\n\t\t\t\t<rect\r\n\t\t\t\t\tfill=\"url(#patternUsa)\"\r\n\t\t\t\t\theight=\"24\"\r\n\t\t\t\t\twidth=\"45.6442\"\r\n\t\t\t\t\tx=\"-8.8421\"\r\n\t\t\t\t/>\r\n\t\t\t</g>\r\n\t\t\t<defs>\r\n\t\t\t\t<pattern\r\n\t\t\t\t\theight=\"1\"\r\n\t\t\t\t\tid=\"patternUsa\"\r\n\t\t\t\t\tpatternContentUnits=\"objectBoundingBox\"\r\n\t\t\t\t\twidth=\"1\"\r\n\t\t\t\t>\r\n\t\t\t\t\t<use\r\n\t\t\t\t\t\ttransform=\"matrix(0.00322581 0 0 0.00613497 0.0701995 0)\"\r\n\t\t\t\t\t\txlinkHref=\"#image0_1885_73241\"\r\n\t\t\t\t\t/>\r\n\t\t\t\t</pattern>\r\n\t\t\t\t<image\r\n\t\t\t\t\theight=\"163\"\r\n\t\t\t\t\tid=\"image0_1885_73241\"\r\n\t\t\t\t\twidth=\"310\"\r\n\t\t\t\t\txlinkHref=\"data:image/png;base64,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\"\r\n\t\t\t\t/>\r\n\t\t\t</defs>\r\n\t\t</svg>\r\n\t);\r\n};\r\n","import { styled } from '@/utils';\r\n\r\nexport const Wrapper = styled.span`\r\n\tdisplay: inline-flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n`;\r\n","export enum LoaderSize {\r\n\tlg = 'lg',\r\n\tsm = 'sm',\r\n}\r\n","import { LoaderSize } from './types';\r\n\r\nexport interface LoaderSvgProps {\r\n\tloaderSize: LoaderSize;\r\n}\r\n\r\nexport const LoaderSvg = (props: LoaderSvgProps) => {\r\n\tconst { loaderSize } = props;\r\n\r\n\tswitch (loaderSize) {\r\n\t\tcase LoaderSize.sm:\r\n\t\t\treturn (\r\n\t\t\t\t<path d=\"M 17.771 21.755 l 10.515 10.138 l -10.512 10.138 V 21.755 h -0.003 z m 32.49 -11.089 l -18.544 17.9 l -18.381 -17.743 v 42.14 l 18.277 -17.692 l 3.54 -3.378 l 10.51 -10.138 v 20.276 l -7.077 -6.812 l -3.435 3.328 L 50.42 53.333 V 10.666 h -0.159 z\" />\r\n\t\t\t);\r\n\t\tcase LoaderSize.lg:\r\n\t\t\treturn (\r\n\t\t\t\t<path d=\"M 40.698 48.143 l 16.824 16.221 l -16.82 16.22 v -32.44 h -0.004 z M 92.682 30.4 l -29.67 28.64 l -29.41 -28.388 v 67.424 l 29.243 -28.308 l 5.662 -5.404 l 16.82 -16.22 v 32.44 L 74 69.685 l -5.496 5.326 l 24.43 23.657 V 30.4 h -0.253 z\" />\r\n\t\t\t);\r\n\t\tdefault:\r\n\t\t\tthrow new Error('unexpected LoaderSize enum LoaderSvg');\r\n\t}\r\n};\r\n","import { useTheme } from '@emotion/react';\r\nimport { type AriaAttributes, type AriaRole, useMemo } from 'react';\r\nimport ContentLoader from 'react-content-loader';\r\n\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { ColorScheme } from '@/types';\r\n\r\nimport { LoaderSvg } from './LoaderSvg';\r\nimport { LoaderSize } from './types';\r\n\r\nexport interface LoaderProps extends DesignSystemBaseProps, AriaAttributes {\r\n\tloaderSize: LoaderSize;\r\n\trole?: AriaRole;\r\n}\r\n\r\nexport const Loader = (props: LoaderProps) => {\r\n\tconst {\r\n\t\tcolorScheme: colorSchemeProp, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\tloaderSize,\r\n\t\tmediaType: mediaTypeProp, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\t...otherProps\r\n\t} = props;\r\n\r\n\tconst theme = useTheme();\r\n\tconst { colorScheme } = useDesignSystem(props);\r\n\r\n\tconst foregroundColor = useMemo(() => {\r\n\t\tswitch (colorScheme) {\r\n\t\t\tcase ColorScheme.light:\r\n\t\t\t\treturn theme.palette.grey700;\r\n\t\t\tcase ColorScheme.dark:\r\n\t\t\t\treturn theme.palette.white;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected ColorScheme enum Loader foregroundColor');\r\n\t\t}\r\n\t}, [colorScheme, theme]);\r\n\r\n\tconst backgroundColor = useMemo(() => {\r\n\t\tswitch (colorScheme) {\r\n\t\t\tcase ColorScheme.light:\r\n\t\t\t\treturn `${theme.palette.grey700}20`;\r\n\t\t\tcase ColorScheme.dark:\r\n\t\t\t\treturn '#C6CCD7';\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected ColorScheme enum Loader backgroundColor');\r\n\t\t}\r\n\t}, [colorScheme, theme]);\r\n\r\n\tconst size = useMemo<number>(() => {\r\n\t\tswitch (loaderSize) {\r\n\t\t\tcase LoaderSize.sm:\r\n\t\t\t\treturn 64;\r\n\t\t\tcase LoaderSize.lg:\r\n\t\t\t\treturn 128;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected LoaderSize enum Loader size');\r\n\t\t}\r\n\t}, [loaderSize]);\r\n\r\n\treturn (\r\n\t\t<ContentLoader\r\n\t\t\tbackgroundColor={backgroundColor}\r\n\t\t\tforegroundColor={foregroundColor}\r\n\t\t\theight={size}\r\n\t\t\tspeed={2}\r\n\t\t\tviewBox={`0 0 ${size} ${size}`}\r\n\t\t\twidth={size}\r\n\t\t\t{...otherProps}\r\n\t\t>\r\n\t\t\t<LoaderSvg loaderSize={loaderSize} />\r\n\t\t</ContentLoader>\r\n\t);\r\n};\r\n","import { ColorScheme } from '@/types';\r\nimport { styled } from '@/utils';\r\n\r\ninterface WrapperProps {\r\n\t$colorScheme: ColorScheme;\r\n}\r\n\r\nexport const Wrapper = styled.div<WrapperProps>`\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\twidth: 100%;\r\n\theight: 100%;\r\n\tbackground-color: ${({ $colorScheme, theme }) => {\r\n\t\tswitch ($colorScheme) {\r\n\t\t\tcase ColorScheme.light:\r\n\t\t\t\treturn theme.palette.grey100;\r\n\t\t\tcase ColorScheme.dark:\r\n\t\t\t\treturn theme.palette.grey900;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected enum value ColorScheme loaderOverlayBox.style.ts Wrapper background-color');\r\n\t\t}\r\n\t}};\r\n\tborder-radius: inherit;\r\n`;\r\n","import { useMergeRefs } from '@floating-ui/react';\r\nimport { type FactoryOpts } from 'imask';\r\nimport { forwardRef, useEffect } from 'react';\r\nimport { useIMask } from 'react-imask';\r\n\r\nimport { InputBase, type InputBaseProps } from '@/components/inputBase';\r\n\r\nimport { type MaskedInputOnAccept } from '../types';\r\n\r\nexport interface MaskedInputBaseProps extends InputBaseProps {\r\n\tmaskOptions: FactoryOpts;\r\n\tonAccept?: MaskedInputOnAccept;\r\n}\r\n\r\nexport const MaskedInputBase = forwardRef<HTMLInputElement, MaskedInputBaseProps>((props, forwardedRef) => {\r\n\tconst { maskOptions, onAccept, value, ...otherProps } = props;\r\n\r\n\tconst { ref, setUnmaskedValue } = useIMask<HTMLInputElement>(maskOptions, {\r\n\t\tonAccept: (maskedValue, mask) => onAccept?.(mask.unmaskedValue, maskedValue),\r\n\t});\r\n\r\n\tuseEffect(() => {\r\n\t\tsetUnmaskedValue(value ?? '');\r\n\t}, [setUnmaskedValue, value]);\r\n\r\n\tconst nextRef = useMergeRefs([forwardedRef, ref]);\r\n\r\n\treturn (\r\n\t\t<InputBase\r\n\t\t\t{...otherProps}\r\n\t\t\tref={nextRef}\r\n\t\t/>\r\n\t);\r\n});\r\n\r\nMaskedInputBase.displayName = 'MaskedInputBase';\r\n","import { type ComponentProps } from 'react';\r\n\r\nimport { withFieldWrapper } from '@/components/fieldWrapper/withFieldWrapper';\r\n\r\nimport { MaskedInputBase, type MaskedInputBaseProps } from './MaskedInputBase';\r\n\r\nexport const MaskedInput = withFieldWrapper<MaskedInputBaseProps, HTMLInputElement>(MaskedInputBase);\r\n\r\nexport type MaskedInputProps = ComponentProps<typeof MaskedInput>;\r\n","import { type ComponentProps, type ComponentType, useCallback } from 'react';\r\nimport { type FieldPath, type FieldValues, type RegisterOptions, useController, useFormContext } from 'react-hook-form';\r\n\r\nimport { MaskedInput, type MaskedInputProps } from './maskedInput/MaskedInput';\r\n\r\ntype ManagedMaskedInputProps = Pick<MaskedInputProps, 'errorMessage' | 'onAccept' | 'onBlur' | 'value'>;\r\n\r\nexport const withMaskedInputField = <TProps extends ManagedMaskedInputProps>(Component: ComponentType<TProps>) => {\r\n\tconst MaskedInputField = <TFieldValues extends FieldValues>(props: TProps & { name: FieldPath<TFieldValues>; options?: RegisterOptions<TFieldValues> }) => {\r\n\t\tconst { options, ...otherProps } = props;\r\n\t\tconst { control } = useFormContext<TFieldValues>();\r\n\r\n\t\tconst {\r\n\t\t\tfield: { onBlur, onChange, ref, value },\r\n\t\t\tfieldState,\r\n\t\t} = useController({\r\n\t\t\tname: props.name,\r\n\t\t\tcontrol: control,\r\n\t\t\trules: options,\r\n\t\t});\r\n\r\n\t\tconst errorMessage = fieldState.error?.message;\r\n\t\tconst handleBlur = useCallback(() => onBlur(), [onBlur]);\r\n\r\n\t\treturn (\r\n\t\t\t<Component\r\n\t\t\t\terrorMessage={errorMessage}\r\n\t\t\t\tref={ref}\r\n\t\t\t\tvalue={value}\r\n\t\t\t\tonAccept={onChange}\r\n\t\t\t\tonBlur={handleBlur}\r\n\t\t\t\t// NOTE: We spread `otherProps` instead of `props` here to avoid passing `options` down to the input element.\r\n\t\t\t\t{...(otherProps as TProps)}\r\n\t\t\t/>\r\n\t\t);\r\n\t};\r\n\r\n\treturn MaskedInputField;\r\n};\r\n\r\nexport const MaskedInputField = withMaskedInputField(MaskedInput);\r\n\r\nexport type MaskedInputFieldProps = ComponentProps<typeof MaskedInputField>;\r\n","import { type FactoryOpts } from 'imask';\r\n\r\ninterface GetNumberMaskFactoryOptsParam {\r\n\tallowNegative?: boolean;\r\n\tdecimalPlaces?: number;\r\n\tintegerPlaces?: number;\r\n}\r\n\r\nexport const getNumberMaskFactoryOpts = (param: GetNumberMaskFactoryOptsParam): FactoryOpts => {\r\n\tconst { allowNegative = false, decimalPlaces = 0, integerPlaces = 15 } = param;\r\n\r\n\tconst max = 10 ** integerPlaces;\r\n\r\n\treturn {\r\n\t\tmask: Number,\r\n\t\tscale: decimalPlaces,\r\n\t\tradix: ',',\r\n\t\tmapToRadix: ['.'],\r\n\t\tthousandsSeparator: ' ',\r\n\t\tmax: max,\r\n\t\tmin: allowNegative ? -max : 0,\r\n\t};\r\n};\r\n","import { type FactoryOpts } from 'imask';\r\nimport { forwardRef, useMemo } from 'react';\r\n\r\nimport { MaskedInput, type MaskedInputProps } from '@/components/maskedInputField/maskedInput/MaskedInput';\r\n\r\nimport { getNumberMaskFactoryOpts } from '../mask';\r\n\r\nexport interface NumberInputProps extends Omit<MaskedInputProps, 'maskOptions'> {\r\n\tallowNegative?: boolean;\r\n\tdecimalPlaces?: number;\r\n\tintegerPlaces?: number;\r\n\tmaskOptions?: FactoryOpts;\r\n}\r\n\r\nexport const NumberInput = forwardRef<HTMLInputElement, NumberInputProps>((props, ref) => {\r\n\tconst { allowNegative = false, decimalPlaces = 0, integerPlaces = 15, ...otherProps } = props;\r\n\r\n\tconst maskOptions: FactoryOpts = useMemo(() => {\r\n\t\treturn getNumberMaskFactoryOpts({\r\n\t\t\tdecimalPlaces: decimalPlaces,\r\n\t\t\tallowNegative: allowNegative,\r\n\t\t\tintegerPlaces: integerPlaces,\r\n\t\t});\r\n\t}, [allowNegative, decimalPlaces, integerPlaces]);\r\n\r\n\treturn (\r\n\t\t<MaskedInput\r\n\t\t\tmaskOptions={maskOptions}\r\n\t\t\tref={ref}\r\n\t\t\t{...otherProps}\r\n\t\t/>\r\n\t);\r\n});\r\n\r\nNumberInput.displayName = 'NumberInput';\r\n","import { type ComponentProps } from 'react';\r\n\r\nimport { withMaskedInputField } from '@/components/maskedInputField';\r\n\r\nimport { NumberInput } from './numberInput/NumberInput';\r\n\r\nexport const NumberInputField = withMaskedInputField(NumberInput);\r\n\r\nexport type NumberInputFieldProps = ComponentProps<typeof NumberInputField>;\r\n","export enum PaperShadow {\r\n\tlg = 'lg',\r\n\tmd = 'md',\r\n\tsm = 'sm',\r\n}\r\n","import { PaperShadow } from '@/components/paper/types';\r\nimport { type Overflow, resolveOverflowValue, resolveSpacingValue, type Spacing } from '@/theme';\r\nimport { type ChooseColor, styled } from '@/utils';\r\n\r\ninterface PaperStyledProps {\r\n\t$chooseColor: ChooseColor;\r\n\t$overflow: Overflow;\r\n\t$padding: Spacing;\r\n\t$shadow: PaperShadow;\r\n}\r\n\r\nexport const PaperStyled = styled.div<PaperStyledProps>`\r\n\tpadding: ${({ $padding, theme }) => resolveSpacingValue(theme, $padding)};\r\n\toverflow: ${({ $overflow }) => resolveOverflowValue($overflow)};\r\n\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.surface.risen)};\r\n\tborder-radius: ${({ theme }) => theme.borderRadius.md};\r\n\tbox-shadow: ${({ $shadow, theme }) => {\r\n\t\tswitch ($shadow) {\r\n\t\t\tcase PaperShadow.sm:\r\n\t\t\t\treturn theme.shadow.box.sm;\r\n\t\t\tcase PaperShadow.md:\r\n\t\t\t\treturn theme.shadow.box.md;\r\n\t\t\tcase PaperShadow.lg:\r\n\t\t\t\treturn theme.shadow.box.lg;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected value of enum PaperShadow paper.style.ts PaperStyled box-shadow');\r\n\t\t}\r\n\t}};\r\n`;\r\n","import { type AriaAttributes, type AriaRole, type ElementType, forwardRef, type ReactNode } from 'react';\r\n\r\nimport { PaperShadow } from '@/components/paper/types';\r\nimport { type DesignSystemBaseProps } from '@/contexts/designSystem/types';\r\nimport { useDesignSystem } from '@/contexts/designSystem/useDesignSystem';\r\nimport { Overflow, Spacing } from '@/theme';\r\nimport { MediaType, type SsrProps } from '@/types';\r\n\r\nimport { PaperStyled } from './Paper.style';\r\n\r\nexport interface PaperProps extends DesignSystemBaseProps, SsrProps, AriaAttributes {\r\n\tas?: ElementType;\r\n\tchildren: ReactNode;\r\n\tclassName?: string;\r\n\tid?: string;\r\n\toverflow?: Overflow;\r\n\tpadding?: Spacing;\r\n\trole?: AriaRole;\r\n\tshadow?: PaperShadow;\r\n\ttabIndex?: number;\r\n}\r\n\r\nexport const Paper = forwardRef<HTMLDivElement, PaperProps>((props, ref) => {\r\n\tconst {\r\n\t\tas,\r\n\t\tchildren,\r\n\t\tclassName,\r\n\t\tcolorScheme: colorSchemeProp, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\tid,\r\n\t\tmediaType: mediaTypeProp, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\toverflow = Overflow.auto,\r\n\t\tpadding: paddingProp,\r\n\t\tshadow = PaperShadow.md,\r\n\t\tsuppressHydrationWarning = false,\r\n\t\ttabIndex,\r\n\t\t...otherProps\r\n\t} = props;\r\n\r\n\tconst { chooseColor, mediaType } = useDesignSystem(props);\r\n\tconst padding = paddingProp ?? (mediaType === MediaType.desktop ? Spacing.xl : Spacing.lg);\r\n\r\n\treturn (\r\n\t\t<PaperStyled\r\n\t\t\t$chooseColor={chooseColor}\r\n\t\t\t$overflow={overflow}\r\n\t\t\t$padding={padding}\r\n\t\t\t$shadow={shadow}\r\n\t\t\tas={as}\r\n\t\t\tclassName={className}\r\n\t\t\tid={id}\r\n\t\t\tref={ref}\r\n\t\t\tsuppressHydrationWarning={suppressHydrationWarning}\r\n\t\t\ttabIndex={tabIndex}\r\n\t\t\t{...otherProps}\r\n\t\t>\r\n\t\t\t{children}\r\n\t\t</PaperStyled>\r\n\t);\r\n});\r\n\r\nPaper.displayName = 'Paper';\r\n","import { type Property } from 'csstype';\r\nimport { type FactoryOpts } from 'imask';\r\nimport { forwardRef } from 'react';\r\n\r\nimport { MaskedInput, type MaskedInputProps } from '@/components/maskedInputField/maskedInput/MaskedInput';\r\n\r\nconst czechCallingCode = '420';\r\nconst czechCallingCodePrefixRegExp = new RegExp(`^\\\\+?${czechCallingCode}`);\r\n\r\nconst maskOptions: FactoryOpts = {\r\n\tmask: '000 000 000',\r\n\tprepare: (chars) => chars.replace(czechCallingCodePrefixRegExp, ''),\r\n};\r\n\r\nexport interface PhoneInputProps extends Omit<MaskedInputProps, 'maskOptions'> {\r\n\tmaskOptions?: FactoryOpts;\r\n\tprefixColor?: Property.Color;\r\n}\r\n\r\nexport const PhoneInput = forwardRef<HTMLInputElement, PhoneInputProps>((props, ref) => (\r\n\t<MaskedInput\r\n\t\tmaskOptions={maskOptions}\r\n\t\tprefix={`+${czechCallingCode}`}\r\n\t\tref={ref}\r\n\t\t{...props}\r\n\t/>\r\n));\r\n\r\nPhoneInput.displayName = 'PhoneInput';\r\n","import { type ComponentProps } from 'react';\r\n\r\nimport { withMaskedInputField } from '@/components/maskedInputField';\r\n\r\nimport { PhoneInput, type PhoneInputProps } from './phoneInput/PhoneInput';\r\n\r\nexport const PhoneInputField = withMaskedInputField<PhoneInputProps>(PhoneInput);\r\n\r\nexport type PhoneInputFieldProps = ComponentProps<typeof PhoneInputField>;\r\n","import { styled, type ChooseColor } from '@/utils';\r\n\r\nconst height = 4; // px\r\n\r\nexport const ProgressStepperStyled = styled.div`\r\n\twidth: 100%;\r\n\theight: ${height}px;\r\n`;\r\n\r\ninterface ProgressProps {\r\n\t$chooseColor: ChooseColor;\r\n\t$percent: number;\r\n}\r\n\r\nexport const Progress = styled.div<ProgressProps>`\r\n\twidth: ${({ $percent }) => $percent}%;\r\n\theight: ${height}px;\r\n\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.fg.brand.default)};\r\n\tborder-top-right-radius: ${({ theme }) => theme.borderRadius.xs};\r\n\tborder-bottom-right-radius: ${({ theme }) => theme.borderRadius.xs};\r\n`;\r\n","import { type AriaAttributes, type AriaRole } from 'react';\r\n\r\nimport { type DesignSystemBaseProps } from '@/contexts/designSystem/types';\r\nimport { useDesignSystem } from '@/contexts/designSystem/useDesignSystem';\r\n\r\nimport { Progress, ProgressStepperStyled } from './ProgressStepper.style';\r\n\r\nexport interface ProgressDefinition extends AriaAttributes {\r\n\tactiveStepIndex: number;\r\n\t/**\r\n\t * Accessible label for the progress bar, e.g. \"Step progress\".\r\n\t * Maps directly to the native `aria-label` attribute.\r\n\t */\r\n\t'aria-label'?: string;\r\n\t/**\r\n\t * Maximum value for the progress bar.\r\n\t * Defaults to `numberOfSteps`.\r\n\t */\r\n\t'aria-valuemax'?: number;\r\n\t/**\r\n\t * Minimum value for the progress bar.\r\n\t * Defaults to `1`.\r\n\t */\r\n\t'aria-valuemin'?: number;\r\n\t/**\r\n\t * Current value for the progress bar.\r\n\t * Defaults to `activeStepIndex + 1`.\r\n\t */\r\n\t'aria-valuenow'?: number;\r\n\t/**\r\n\t * Accessible text describing the current progress value, e.g. \"Step 3 of 5\".\r\n\t * Maps directly to the native `aria-valuetext` attribute.\r\n\t */\r\n\t'aria-valuetext'?: string;\r\n\tnumberOfSteps: number;\r\n\trole?: AriaRole;\r\n}\r\n\r\nexport interface ProgressStepperProps extends ProgressDefinition, DesignSystemBaseProps {}\r\n\r\nexport const ProgressStepper = (props: ProgressStepperProps) => {\r\n\tconst {\r\n\t\tactiveStepIndex,\r\n\t\t'aria-label': ariaLabel,\r\n\t\t'aria-valuemax': ariaValueMax = props.numberOfSteps,\r\n\t\t'aria-valuemin': ariaValueMin = 1,\r\n\t\t'aria-valuenow': ariaValueNow = props.activeStepIndex + 1,\r\n\t\t'aria-valuetext': ariaValueText,\r\n\t\tcolorScheme: colorSchemeProp, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\tmediaType: mediaTypeProp, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\tnumberOfSteps,\r\n\t\trole = 'progressbar',\r\n\t\t...otherProps\r\n\t} = props;\r\n\r\n\tconst { chooseColor } = useDesignSystem(props);\r\n\r\n\tconst percent = ((activeStepIndex + 1) / numberOfSteps) * 100;\r\n\r\n\treturn (\r\n\t\t<ProgressStepperStyled\r\n\t\t\taria-label={ariaLabel}\r\n\t\t\taria-valuemax={ariaValueMax}\r\n\t\t\taria-valuemin={ariaValueMin}\r\n\t\t\taria-valuenow={ariaValueNow}\r\n\t\t\taria-valuetext={ariaValueText}\r\n\t\t\trole={role}\r\n\t\t\t{...otherProps}\r\n\t\t>\r\n\t\t\t<Progress\r\n\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t$percent={percent}\r\n\t\t\t/>\r\n\t\t</ProgressStepperStyled>\r\n\t);\r\n};\r\n","import { Paper } from '@/components/paper/Paper';\r\nimport { styled } from '@/utils';\r\n\r\nexport const PaperStyled = styled(Paper)`\r\n\tposition: relative;\r\n`;\r\n\r\nexport const ProgressStepperWrapper = styled.div`\r\n\tposition: absolute;\r\n\ttop: 0;\r\n\tleft: 0;\r\n\twidth: 100%;\r\n`;\r\n","import { forwardRef } from 'react';\r\n\r\nimport { type PaperProps } from '@/components/paper';\r\nimport { ProgressStepper, type ProgressDefinition } from '@/components/progressPaper/progressStepper/ProgressStepper';\r\nimport { useDesignSystem } from '@/contexts/designSystem/useDesignSystem';\r\nimport { type SsrProps } from '@/types';\r\n\r\nimport { PaperStyled, ProgressStepperWrapper } from './ProgressPaper.style';\r\n\r\nexport interface ProgressPaperProps extends PaperProps, SsrProps {\r\n\tprogressDefinition: ProgressDefinition;\r\n}\r\n\r\nexport const ProgressPaper = forwardRef<HTMLDivElement, ProgressPaperProps>((props, ref) => {\r\n\tconst { children, progressDefinition, ...otherProps } = props;\r\n\r\n\tconst { colorScheme, mediaType } = useDesignSystem(props);\r\n\r\n\treturn (\r\n\t\t<PaperStyled\r\n\t\t\t{...otherProps}\r\n\t\t\tcolorScheme={colorScheme}\r\n\t\t\tmediaType={mediaType}\r\n\t\t\tref={ref}\r\n\t\t>\r\n\t\t\t<ProgressStepperWrapper>\r\n\t\t\t\t<ProgressStepper\r\n\t\t\t\t\t{...progressDefinition}\r\n\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\tmediaType={mediaType}\r\n\t\t\t\t/>\r\n\t\t\t</ProgressStepperWrapper>\r\n\t\t\t{children}\r\n\t\t</PaperStyled>\r\n\t);\r\n});\r\n\r\nProgressPaper.displayName = 'ProgressPaper';\r\n","import { styled, type ChooseColor } from '@/utils';\r\n\r\nexport const Wrapper = styled.div`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\trow-gap: ${({ theme }) => theme.spacing.xs};\r\n\theight: 100%;\r\n`;\r\n\r\ninterface InputStyledProps {\r\n\t$chooseColor: ChooseColor;\r\n\t$invalid: boolean;\r\n}\r\n\r\nexport const InputStyled = styled.input<InputStyledProps>`\r\n\tposition: absolute;\r\n\tgrid-area: input;\r\n\twidth: 0;\r\n\theight: 0;\r\n\tpadding: 0;\r\n\tmargin: 0;\r\n\tborder-width: 0;\r\n\topacity: 0;\r\n\r\n\t&:focus-visible + label {\r\n\t\toutline-width: 3px;\r\n\t\toutline-style: solid;\r\n\t\toutline-color: ${({ $chooseColor, $invalid, theme }) => ($invalid ? $chooseColor(theme.colors.fg.error) : $chooseColor(theme.colors.focus))};\r\n\t\toutline-offset: 3px;\r\n\t}\r\n\r\n\t&:not(:disabled) + label:hover {\r\n\t\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.surface.default)};\r\n\t\tborder-color: ${({ $chooseColor, $invalid, theme }) => ($invalid ? $chooseColor(theme.colors.fg.error) : $chooseColor(theme.colors.border.brand.default))};\r\n\t}\r\n\r\n\t/* stylelint-disable-next-line no-descending-specificity */\r\n\t&:checked + label {\r\n\t\tpadding-top: calc(${({ theme }) => theme.spacing.sm} - 1px);\r\n\t\tpadding-right: calc(${({ theme }) => theme.spacing.xs} - 1px);\r\n\t\tpadding-bottom: calc(${({ theme }) => theme.spacing.sm} - 1px);\r\n\t\tpadding-left: calc(${({ theme }) => theme.spacing.xs} - 1px);\r\n\t\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.surface.default)};\r\n\t\tborder-color: ${({ $chooseColor, $invalid, theme }) => ($invalid ? $chooseColor(theme.colors.fg.error) : $chooseColor(theme.colors.border.brand.default))};\r\n\t\tborder-width: 2px;\r\n\t}\r\n\r\n\t/* stylelint-disable-next-line no-descending-specificity */\r\n\t&:disabled + label {\r\n\t\tcolor: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.fg.disabled)};\r\n\t\tcursor: auto;\r\n\t\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.bg.disabled)};\r\n\t\tborder-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.border.disabled)};\r\n\t}\r\n`;\r\n\r\ninterface LabelStyledProps {\r\n\t$chooseColor: ChooseColor;\r\n\t$invalid: boolean;\r\n}\r\n\r\nexport const LabelStyled = styled.label<LabelStyledProps>`\r\n\tposition: relative;\r\n\tbox-sizing: border-box;\r\n\tdisplay: flex;\r\n\tflex: 1;\r\n\tflex-direction: column;\r\n\tgrid-area: label;\r\n\trow-gap: ${({ theme }) => theme.spacing.sm};\r\n\talign-items: center;\r\n\tjustify-content: space-evenly;\r\n\tpadding-top: ${({ theme }) => theme.spacing.sm};\r\n\tpadding-right: ${({ theme }) => theme.spacing.xs};\r\n\tpadding-bottom: ${({ theme }) => theme.spacing.sm};\r\n\tpadding-left: ${({ theme }) => theme.spacing.xs};\r\n\tcolor: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.fg.neutral.subtle)};\r\n\tcursor: pointer;\r\n\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.surface.risen)};\r\n\tborder-color: ${({ $chooseColor, $invalid, theme }) => ($invalid ? $chooseColor(theme.colors.fg.error) : $chooseColor(theme.colors.border.neutral.subtle))};\r\n\tborder-style: solid;\r\n\tborder-width: 1px;\r\n\tborder-radius: ${({ theme }) => theme.borderRadius.xs};\r\n`;\r\n\r\nexport const ErrorWrapper = styled.span`\r\n\tgrid-area: error;\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { forwardRef, type ReactElement } from 'react';\r\n\r\nimport { type RadioGeneralProps } from '@/components/radioField/types';\r\nimport { Typography, TypographyTextAlign, TypographyVariant } from '@/components/typography';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { useUniqueIdIfIsUndefined } from '@/hooks/useUniqueIdIfIsUndefined';\r\nimport { FontWeight } from '@/theme';\r\n\r\nimport { type RadioButtonLabel } from '../types';\r\n\r\nimport { ErrorWrapper, InputStyled, LabelStyled, Wrapper } from './RadioButton.style';\r\n\r\nexport interface RadioButtonProps extends RadioGeneralProps, DesignSystemBaseProps {\r\n\terrorMessage?: ReactElement | string | undefined;\r\n\tlabel: RadioButtonLabel;\r\n}\r\n\r\n// For radio that looks like a native radio, use the Radio component\r\n\r\nexport const RadioButton = forwardRef<HTMLInputElement, RadioButtonProps>((props, ref) => {\r\n\tconst {\r\n\t\tchecked,\r\n\t\tcolorScheme, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\tdisabled,\r\n\t\terrorMessage,\r\n\t\tid: idProp,\r\n\t\tinvalid = false,\r\n\t\tlabel,\r\n\t\tmediaType, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\tname,\r\n\t\tonBlur,\r\n\t\tonChange,\r\n\t\tvalue,\r\n\t\t...otherProps\r\n\t} = props;\r\n\r\n\tconst id = useUniqueIdIfIsUndefined(idProp);\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor } = useDesignSystem(props);\r\n\r\n\treturn (\r\n\t\t<Wrapper>\r\n\t\t\t<InputStyled\r\n\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t$invalid={invalid}\r\n\t\t\t\tchecked={checked}\r\n\t\t\t\tdisabled={disabled}\r\n\t\t\t\tid={id}\r\n\t\t\t\tname={name}\r\n\t\t\t\tref={ref}\r\n\t\t\t\ttype={'radio'}\r\n\t\t\t\tvalue={value}\r\n\t\t\t\tonBlur={onBlur}\r\n\t\t\t\tonChange={onChange}\r\n\t\t\t\t{...otherProps}\r\n\t\t\t/>\r\n\t\t\t<LabelStyled\r\n\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t$invalid={invalid}\r\n\t\t\t\thtmlFor={id}\r\n\t\t\t>\r\n\t\t\t\t{label.top !== undefined && (\r\n\t\t\t\t\t<Typography\r\n\t\t\t\t\t\tcolor={invalid ? theme.colors.fg.error.light : 'inherit'}\r\n\t\t\t\t\t\ttextAlign={TypographyTextAlign.center}\r\n\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t{label.top}\r\n\t\t\t\t\t</Typography>\r\n\t\t\t\t)}\r\n\t\t\t\t<Typography\r\n\t\t\t\t\tcolor={invalid ? theme.colors.fg.error.light : 'inherit'}\r\n\t\t\t\t\ttextAlign={TypographyTextAlign.center}\r\n\t\t\t\t\tvariant={TypographyVariant.textMd}\r\n\t\t\t\t\tweight={FontWeight.medium500}\r\n\t\t\t\t>\r\n\t\t\t\t\t{label.main}\r\n\t\t\t\t</Typography>\r\n\t\t\t</LabelStyled>\r\n\t\t\t{errorMessage !== undefined && (\r\n\t\t\t\t<ErrorWrapper>\r\n\t\t\t\t\t<Typography\r\n\t\t\t\t\t\tcolor={theme.colors.fg.error.light}\r\n\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t{errorMessage}\r\n\t\t\t\t\t</Typography>\r\n\t\t\t\t</ErrorWrapper>\r\n\t\t\t)}\r\n\t\t</Wrapper>\r\n\t);\r\n});\r\n\r\nRadioButton.displayName = 'RadioButton';\r\n","import { type AriaAttributes, type AriaRole } from 'react';\r\n\r\nimport { type RadioButtonLabel } from '@/components/radioButtonField/types';\r\n\r\nexport interface RadioButtonGroupItem extends AriaAttributes {\r\n\tid?: string;\r\n\tlabel: RadioButtonLabel;\r\n\trole?: AriaRole;\r\n\tvalue: string;\r\n}\r\n\r\nexport enum RadioButtonGroupLayout {\r\n\tflex = 'flex',\r\n\tgrid = 'grid',\r\n\t/** Special layout ensuring that single item is not stretched to full width alone.\r\n\t * If there is only one or two items, they are displayed in 3-column layout.\r\n\t * Works only up to 6 items; if there are more, it behaves like `flex`.\r\n\t */\r\n\tsmartGrid = 'smartGrid',\r\n}\r\n","import { css } from '@emotion/react';\r\nimport { type Property } from 'csstype';\r\n\r\nimport { styled } from '@/utils';\r\n\r\ninterface ItemsWrapperProps {\r\n\t$controlWidth?: Property.Width;\r\n\t$fiveItemsCase: boolean;\r\n\t$gridColumns?: number;\r\n}\r\n\r\nexport const ItemsWrapper = styled.div<ItemsWrapperProps>`\r\n\tbox-sizing: border-box;\r\n\tdisplay: flex;\r\n\tflex-wrap: wrap;\r\n\tgap: ${({ theme }) => theme.spacing.sm};\r\n\t${({ $controlWidth }) => ($controlWidth === undefined ? '' : `width: ${$controlWidth};`)}\r\n\r\n\t${({ $gridColumns }) =>\r\n\t\t$gridColumns !== undefined &&\r\n\t\tcss`\r\n\t\t\tdisplay: grid;\r\n\t\t\tgrid-template-columns: repeat(${$gridColumns}, 1fr);\r\n\t\t\tgrid-auto-rows: 1fr;\r\n\t\t`}\r\n\r\n\t${({ $fiveItemsCase }) => {\r\n\t\treturn (\r\n\t\t\t$fiveItemsCase &&\r\n\t\t\tcss`\r\n\t\t\t\t& > :nth-child(1) {\r\n\t\t\t\t\tgrid-column: 1 / span 2;\r\n\t\t\t\t}\r\n\r\n\t\t\t\t& > :nth-child(2) {\r\n\t\t\t\t\tgrid-column: 3 / span 2;\r\n\t\t\t\t}\r\n\r\n\t\t\t\t& > :nth-child(3) {\r\n\t\t\t\t\tgrid-column: 5 / span 2;\r\n\t\t\t\t}\r\n\r\n\t\t\t\t& > :nth-child(4) {\r\n\t\t\t\t\tgrid-column: 1 / span 3;\r\n\t\t\t\t}\r\n\r\n\t\t\t\t& > :nth-child(5) {\r\n\t\t\t\t\tgrid-column: 4 / span 3;\r\n\t\t\t\t}\r\n\t\t\t`\r\n\t\t);\r\n\t}}\r\n`;\r\n\r\ninterface ItemWrapperProps {\r\n\t$arrangeInGrid: boolean;\r\n\t$itemMinWidth?: Property.Width;\r\n}\r\n\r\nexport const ItemWrapper = styled.div<ItemWrapperProps>`\r\n\tbox-sizing: border-box;\r\n\tflex: 1;\r\n\talign-content: center;\r\n\tjustify-content: space-between;\r\n\tmin-width: ${({ $arrangeInGrid, $itemMinWidth }) => {\r\n\t\tif ($itemMinWidth !== undefined) {\r\n\t\t\treturn $itemMinWidth;\r\n\t\t}\r\n\r\n\t\tif ($arrangeInGrid) {\r\n\t\t\treturn 'auto';\r\n\t\t}\r\n\r\n\t\treturn '160px';\r\n\t}};\r\n\r\n\t${({ $arrangeInGrid }) =>\r\n\t\t$arrangeInGrid &&\r\n\t\tcss`\r\n\t\t\t& > * {\r\n\t\t\t\theight: 100%;\r\n\t\t\t}\r\n\t\t`};\r\n`;\r\n","import { type Property } from 'csstype';\r\nimport { forwardRef, useMemo, type FocusEvent, type ChangeEvent } from 'react';\r\n\r\nimport { RadioButton } from '@/components/radioButtonField/radioButton/RadioButton';\r\nimport { type RadioButtonGroupItem, RadioButtonGroupLayout } from '@/components/radioButtonGroupField/types';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { type FieldControlProps } from '@/types';\r\n\r\nimport { ItemsWrapper, ItemWrapper } from './RadioButtonGroupControl.style';\r\n\r\nexport interface RadioButtonGroupControlProps extends DesignSystemBaseProps, FieldControlProps {\r\n\tbuttonsLayout?: RadioButtonGroupLayout;\r\n\tcontrolWidth?: Property.Width;\r\n\tdisabled?: boolean;\r\n\t/* works only in combination with `RadioButtonGroupLayout.Grid` */\r\n\tgridColumns?: number;\r\n\titemMinWidth?: Property.Width;\r\n\titems: RadioButtonGroupItem[];\r\n\tname: string;\r\n\tonBlur?: ((event: FocusEvent<HTMLInputElement>) => void) | undefined;\r\n\tonChange?: ((event: ChangeEvent<HTMLInputElement>) => void) | undefined;\r\n\tvalue?: string;\r\n}\r\n\r\nexport const RadioButtonGroupControl = forwardRef<HTMLInputElement, RadioButtonGroupControlProps>((props, ref) => {\r\n\tconst {\r\n\t\tbuttonsLayout = RadioButtonGroupLayout.flex,\r\n\t\tcontrolWidth,\r\n\t\tdisabled,\r\n\t\tgridColumns: gridColumnsProp,\r\n\t\tinvalid,\r\n\t\titemMinWidth,\r\n\t\titems,\r\n\t\tlabelledBy,\r\n\t\tname,\r\n\t\tonBlur,\r\n\t\tonChange,\r\n\t\tvalue,\r\n\t} = props;\r\n\r\n\tif (buttonsLayout === RadioButtonGroupLayout.grid && gridColumnsProp === undefined) {\r\n\t\tthrow new Error('RadioButtonGroupControl: gridColumns must be defined when layout is `grid`');\r\n\t}\r\n\tif (buttonsLayout !== RadioButtonGroupLayout.grid && gridColumnsProp !== undefined) {\r\n\t\tthrow new Error('RadioButtonGroupControl: gridColumns must be undefined when layout is not `grid`');\r\n\t}\r\n\r\n\tconst { colorScheme } = useDesignSystem(props);\r\n\r\n\tconst gridColumns = useMemo<number | undefined>(() => {\r\n\t\tif (buttonsLayout !== RadioButtonGroupLayout.smartGrid) {\r\n\t\t\treturn gridColumnsProp;\r\n\t\t}\r\n\r\n\t\tconst itemsCount = items.length;\r\n\t\tif (itemsCount === 1) {\r\n\t\t\treturn 3;\r\n\t\t}\r\n\t\tif (itemsCount === 2) {\r\n\t\t\treturn 3;\r\n\t\t}\r\n\t\tif (itemsCount === 3) {\r\n\t\t\treturn 3;\r\n\t\t}\r\n\t\tif (itemsCount === 4) {\r\n\t\t\treturn 2;\r\n\t\t}\r\n\t\tif (itemsCount === 5) {\r\n\t\t\treturn 6;\r\n\t\t}\r\n\t\tif (itemsCount === 6) {\r\n\t\t\treturn 3;\r\n\t\t}\r\n\r\n\t\treturn undefined;\r\n\t}, [gridColumnsProp, items.length, buttonsLayout]);\r\n\r\n\treturn (\r\n\t\t<ItemsWrapper\r\n\t\t\t$controlWidth={controlWidth}\r\n\t\t\t$fiveItemsCase={items.length === 5}\r\n\t\t\t$gridColumns={gridColumns}\r\n\t\t\taria-labelledby={labelledBy}\r\n\t\t\trole=\"radiogroup\"\r\n\t\t>\r\n\t\t\t{items.map((item) => {\r\n\t\t\t\tconst { id: itemId, label, value: itemValue, ...otherItemParams } = item;\r\n\r\n\t\t\t\tconst checked = value === undefined ? undefined : itemValue === value;\r\n\r\n\t\t\t\treturn (\r\n\t\t\t\t\t<ItemWrapper\r\n\t\t\t\t\t\tkey={item.value}\r\n\t\t\t\t\t\t$arrangeInGrid={gridColumns !== undefined}\r\n\t\t\t\t\t\t$itemMinWidth={itemMinWidth}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t<RadioButton\r\n\t\t\t\t\t\t\tchecked={checked}\r\n\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\tdisabled={disabled}\r\n\t\t\t\t\t\t\tid={itemId}\r\n\t\t\t\t\t\t\tinvalid={invalid}\r\n\t\t\t\t\t\t\tlabel={label}\r\n\t\t\t\t\t\t\tname={name}\r\n\t\t\t\t\t\t\tref={ref}\r\n\t\t\t\t\t\t\tvalue={itemValue}\r\n\t\t\t\t\t\t\tonBlur={onBlur}\r\n\t\t\t\t\t\t\tonChange={onChange}\r\n\t\t\t\t\t\t\t{...otherItemParams}\r\n\t\t\t\t\t\t/>\r\n\t\t\t\t\t</ItemWrapper>\r\n\t\t\t\t);\r\n\t\t\t})}\r\n\t\t</ItemsWrapper>\r\n\t);\r\n});\r\n\r\nRadioButtonGroupControl.displayName = 'RadioButtonGroupControl';\r\n","import { type ComponentProps, forwardRef } from 'react';\r\n\r\nimport { withFieldWrapper } from '@/components/fieldWrapper';\r\nimport { RadioButtonGroupControl, type RadioButtonGroupControlProps } from '@/components/radioButtonGroupField/radioButtonGroupControl/RadioButtonGroupControl';\r\n\r\nconst RadioButtonGroupBase = withFieldWrapper<RadioButtonGroupControlProps, HTMLInputElement>(RadioButtonGroupControl);\r\n\r\nexport const RadioButtonGroup = forwardRef<HTMLInputElement, ComponentProps<typeof RadioButtonGroupBase>>((props, ref) => {\r\n\tconst { labelAs = 'span', ...restProps } = props;\r\n\r\n\treturn (\r\n\t\t<RadioButtonGroupBase\r\n\t\t\t{...restProps}\r\n\t\t\tlabelAs={labelAs}\r\n\t\t\tref={ref}\r\n\t\t/>\r\n\t);\r\n});\r\n\r\nRadioButtonGroup.displayName = 'RadioButtonGroup';\r\n\r\nexport type RadioButtonGroupProps = ComponentProps<typeof RadioButtonGroup>;\r\n","import { type ChangeEvent, useCallback } from 'react';\r\nimport { type RegisterOptions, useController } from 'react-hook-form';\r\n\r\nimport { RadioButtonGroup, type RadioButtonGroupProps } from '@/components/radioButtonGroupField/radioButtonGroup/RadioButtonGroup';\r\n\r\nexport interface RadioButtonGroupFieldProps extends Omit<RadioButtonGroupProps, 'onBlur' | 'onChange' | 'value'> {\r\n\tname: string;\r\n\toptions?: RegisterOptions;\r\n}\r\n\r\nexport const RadioButtonGroupField = (props: RadioButtonGroupFieldProps) => {\r\n\tconst { name, options, ...otherProps } = props;\r\n\r\n\tconst {\r\n\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\r\n\t\tfield: { onBlur, onChange, ref, value },\r\n\t\tfieldState: { error },\r\n\t} = useController({\r\n\t\tname: name,\r\n\t\trules: options,\r\n\t});\r\n\r\n\t// NOTE: Ensures that validations are triggered immediately after changing value.\r\n\t// Using onblur validations with radios is confusing otherwise.\r\n\tconst handleChange = useCallback(\r\n\t\t(event: ChangeEvent<HTMLInputElement>) => {\r\n\t\t\tonChange(event);\r\n\t\t\tonBlur();\r\n\t\t},\r\n\t\t[onBlur, onChange],\r\n\t);\r\n\r\n\treturn (\r\n\t\t<RadioButtonGroup\r\n\t\t\terrorMessage={error?.message}\r\n\t\t\tname={name}\r\n\t\t\tref={ref}\r\n\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\r\n\t\t\tvalue={value}\r\n\t\t\tonBlur={onBlur}\r\n\t\t\tonChange={handleChange}\r\n\t\t\t{...otherProps}\r\n\t\t/>\r\n\t);\r\n};\r\n","import { encode as encodeBase64 } from 'base-64';\r\n\r\nexport const getRadioBaseCheck = (color: string) => {\r\n\treturn `\r\n\t\t<svg width=\"1rem\" height=\"1rem\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n\t\t\t<circle cx=\"8\" cy=\"8\" r=\"8\" fill=\"${color}\"/>\r\n\t\t</svg>\r\n`;\r\n};\r\n\r\nexport const getRadioControlCheckBase64 = (color: string) => {\r\n\treturn encodeBase64(getRadioBaseCheck(color));\r\n};\r\n","import { styled, type ChooseColor } from '@/utils';\r\n\r\nexport const radioSize = '1.5rem';\r\n\r\nexport const LabelStyled = styled.label`\r\n\tdisplay: flex;\r\n\tmargin: 0;\r\n`;\r\n\r\ninterface RadioStyledProps {\r\n\t$checkedBackground: string;\r\n\t$checkedDisabledBackground: string;\r\n\t$chooseColor: ChooseColor;\r\n\t$invalid: boolean;\r\n}\r\n\r\nexport const RadioStyled = styled.input<RadioStyledProps>`\r\n\tposition: absolute;\r\n\twidth: 0;\r\n\theight: 0;\r\n\tpadding: 0;\r\n\tmargin: 0;\r\n\tcursor: pointer;\r\n\toutline: none;\r\n\tborder-width: 0;\r\n\tbox-shadow: none;\r\n\topacity: 0;\r\n\r\n\t&:focus-visible + span {\r\n\t\toutline-width: 3px;\r\n\t\toutline-style: solid;\r\n\t\toutline-color: ${({ $chooseColor, $invalid, theme }) => ($invalid ? $chooseColor(theme.colors.fg.error) : $chooseColor(theme.colors.focus))};\r\n\t\toutline-offset: 2px;\r\n\t}\r\n\r\n\t&:not(:disabled):hover + span {\r\n\t\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.bg.brand.default)};\r\n\t\tborder-color: ${({ $chooseColor, $invalid, theme }) => ($invalid ? $chooseColor(theme.colors.fg.error) : $chooseColor(theme.colors.border.brand.bold))};\r\n\t}\r\n\r\n\t/* stylelint-disable-next-line no-descending-specificity */\r\n\t&:checked + span {\r\n\t\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.bg.brand.default)};\r\n\t\tbackground-image: url('data:image/svg+xml;base64,${({ $checkedBackground }) => $checkedBackground}');\r\n\t\tborder-color: ${({ $chooseColor, $invalid, theme }) => ($invalid ? $chooseColor(theme.colors.fg.error) : $chooseColor(theme.colors.border.brand.bold))};\r\n\t}\r\n\r\n\t/* stylelint-disable-next-line no-descending-specificity */\r\n\t&:disabled + span {\r\n\t\tcursor: auto;\r\n\t\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.bg.disabled)};\r\n\t\tborder-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.border.neutral.subtle)};\r\n\t}\r\n\r\n\t&:checked:disabled + span {\r\n\t\tbackground-image: url('data:image/svg+xml;base64,${({ $checkedDisabledBackground }) => $checkedDisabledBackground}');\r\n\t}\r\n`;\r\n\r\ninterface SpanStyledProps {\r\n\t$chooseColor: ChooseColor;\r\n\t$invalid: boolean;\r\n}\r\n\r\nexport const SpanStyled = styled.span<SpanStyledProps>`\r\n\tbox-sizing: border-box;\r\n\tdisplay: inline-block;\r\n\twidth: ${radioSize};\r\n\theight: ${radioSize};\r\n\tmargin: 0;\r\n\tcursor: pointer;\r\n\tbackground-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.surface.risen)};\r\n\tbackground-repeat: no-repeat;\r\n\tbackground-position: center;\r\n\tborder-color: ${({ $chooseColor, $invalid, theme }) => ($invalid ? $chooseColor(theme.colors.fg.error) : $chooseColor(theme.colors.border.neutral.default))};\r\n\tborder-style: solid;\r\n\tborder-width: 1px;\r\n\tborder-radius: ${({ theme }) => theme.borderRadius.full};\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { encode as encodeBase64 } from 'base-64';\r\nimport { forwardRef, useMemo } from 'react';\r\n\r\nimport { type RadioGeneralProps } from '@/components/radioField/types';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\n\r\nimport { getRadioControlCheckBase64 } from './radioControlSvgHandler';\r\n\r\nimport { LabelStyled, RadioStyled, SpanStyled } from './RadioControl.style';\r\n\r\nexport interface RadioControlProps extends DesignSystemBaseProps, RadioGeneralProps {}\r\n\r\nexport const RadioControl = forwardRef<HTMLInputElement, RadioControlProps>((props, ref) => {\r\n\tconst {\r\n\t\tchecked,\r\n\t\tcolorScheme: colorSchemeProp, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\tdisabled,\r\n\t\tid: idFromProps,\r\n\t\tinvalid = false,\r\n\t\tmediaType: mediaTypeProp, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\tname,\r\n\t\tonBlur,\r\n\t\tonChange,\r\n\t\tvalue,\r\n\t\t...otherProps\r\n\t} = props;\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor } = useDesignSystem(props);\r\n\r\n\tconst checkedBackground = useMemo(() => {\r\n\t\treturn getRadioControlCheckBase64(theme.colors.icon.brand.light);\r\n\t}, [theme]);\r\n\r\n\tconst checkedDisabledBackground = useMemo(() => {\r\n\t\treturn getRadioControlCheckBase64(theme.colors.icon.neutral.light);\r\n\t}, [theme]);\r\n\r\n\t// id must exist because of the connection between the label and the radio (html label as a wrapper component has problems with tooltip)\r\n\tconst id = useMemo<string>(() => {\r\n\t\tif (idFromProps !== undefined) {\r\n\t\t\treturn idFromProps;\r\n\t\t}\r\n\r\n\t\treturn encodeBase64(Math.random().toString());\r\n\t}, [idFromProps]);\r\n\r\n\treturn (\r\n\t\t<LabelStyled>\r\n\t\t\t<RadioStyled\r\n\t\t\t\t$checkedBackground={checkedBackground}\r\n\t\t\t\t$checkedDisabledBackground={checkedDisabledBackground}\r\n\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t$invalid={invalid}\r\n\t\t\t\tchecked={checked}\r\n\t\t\t\tdisabled={disabled}\r\n\t\t\t\tid={id}\r\n\t\t\t\tname={name}\r\n\t\t\t\tref={ref}\r\n\t\t\t\ttype={'radio'}\r\n\t\t\t\tvalue={value}\r\n\t\t\t\tonBlur={onBlur}\r\n\t\t\t\tonChange={onChange}\r\n\t\t\t\t{...otherProps}\r\n\t\t\t/>\r\n\t\t\t{/* style in firefox doesn't work without this extra span */}\r\n\t\t\t<SpanStyled\r\n\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t$invalid={invalid}\r\n\t\t\t/>\r\n\t\t</LabelStyled>\r\n\t);\r\n});\r\n\r\nRadioControl.displayName = 'RadioControl';\r\n","import { type AriaAttributes, type AriaRole, type ChangeEvent, type FocusEvent } from 'react';\r\n\r\nexport enum RadioPosition {\r\n\tleft = 'left',\r\n\tright = 'right',\r\n}\r\n\r\nexport interface RadioGeneralProps extends AriaAttributes {\r\n\tchecked?: boolean;\r\n\tdisabled?: boolean;\r\n\tid?: string;\r\n\tinvalid?: boolean;\r\n\tname: string;\r\n\tonBlur?: (event: FocusEvent<HTMLInputElement>) => void;\r\n\tonChange?: (event: ChangeEvent<HTMLInputElement>) => void;\r\n\trole?: AriaRole;\r\n\tvalue: string;\r\n}\r\n","import { css } from '@emotion/react';\r\n\r\nimport { iconProductSizeSmall } from '@/components/iconProduct/constants';\r\nimport { LabelTooltipPosition } from '@/types';\r\nimport { styled } from '@/utils';\r\n\r\nimport { RadioPosition } from '../types';\r\n\r\nimport { radioSize } from '../radioControl/RadioControl.style';\r\n\r\nexport const Wrapper = styled.div`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\trow-gap: ${({ theme }) => theme.spacing.xs};\r\n`;\r\n\r\ninterface ControlAndLabelWrapperProps {\r\n\t$position: RadioPosition;\r\n}\r\n\r\nexport const ControlAndLabelWrapper = styled.div<ControlAndLabelWrapperProps>`\r\n\tdisplay: flex;\r\n\tflex-direction: ${({ $position }) => {\r\n\t\tswitch ($position) {\r\n\t\t\tcase RadioPosition.left:\r\n\t\t\t\treturn 'row';\r\n\t\t\tcase RadioPosition.right:\r\n\t\t\t\treturn 'row-reverse';\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected enum values RadioPosition in radio.style.ts');\r\n\t\t}\r\n\t}};\r\n\tcolumn-gap: ${({ theme }) => theme.spacing.sm};\r\n\talign-items: start;\r\n\tjustify-content: left;\r\n`;\r\n\r\ninterface LabelAndTooltipWrapperProps {\r\n\t$tooltipPosition: LabelTooltipPosition;\r\n}\r\n\r\n// NOTE: When the radio label is multiline, the radio should be aligned with the first line of the label.\r\nexport const LabelAndTooltipWrapper = styled.div<LabelAndTooltipWrapperProps>`\r\n\tposition: relative;\r\n\ttop: calc((${radioSize} - 1lh) / 2);\r\n\r\n\t${(props) =>\r\n\t\tprops.$tooltipPosition === LabelTooltipPosition.rightCenter &&\r\n\t\tcss`\r\n\t\t\tdisplay: flex;\r\n\t\t\tgap: ${props.theme.spacing.xxs};\r\n\t\t\talign-items: center;\r\n\t\t`}\r\n`;\r\n\r\ninterface LabelStyledProps {\r\n\t$tooltipPosition: LabelTooltipPosition;\r\n}\r\n\r\nexport const LabelStyled = styled.label<LabelStyledProps>`\r\n\tposition: relative;\r\n\tdisplay: inline;\r\n\tmargin: 0;\r\n`;\r\n\r\ninterface TooltipWrapperProps {\r\n\t$tooltipPosition: LabelTooltipPosition;\r\n}\r\n\r\nexport const TooltipWrapper = styled.span<TooltipWrapperProps>`\r\n\tdisplay: inline-flex;\r\n\r\n\t${(props) =>\r\n\t\tprops.$tooltipPosition === LabelTooltipPosition.inline &&\r\n\t\tcss`\r\n\t\t\tposition: relative;\r\n\t\t\ttop: calc((1lh - ${iconProductSizeSmall}) / 2);\r\n\t\t\tvertical-align: top;\r\n\t\t`}\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { forwardRef, type ReactNode, useMemo } from 'react';\r\n\r\nimport { RadioControl, type RadioControlProps } from '@/components/radioField/radioControl/RadioControl';\r\nimport { TooltipInfo } from '@/components/tooltip';\r\nimport { mapTooltipInfoDescriptorToPropsSubset } from '@/components/tooltip/util';\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { VisuallyHidden } from '@/components/visuallyHidden';\r\nimport { liferayClassNames } from '@/constants';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { useUniqueIdIfIsUndefined } from '@/hooks/useUniqueIdIfIsUndefined';\r\nimport { FontWeight } from '@/theme';\r\nimport { type InputLabelPassthroughProps, LabelTooltipPosition } from '@/types';\r\nimport { isRenderable } from '@/utils';\r\n\r\nimport { RadioPosition } from '../types';\r\n\r\nimport { ControlAndLabelWrapper, LabelAndTooltipWrapper, LabelStyled, TooltipWrapper, Wrapper } from './Radio.style';\r\n\r\nexport interface RadioProps extends RadioControlProps, InputLabelPassthroughProps, DesignSystemBaseProps {\r\n\terrorMessage?: ReactNode;\r\n\tlabelColor?: string;\r\n\tposition?: RadioPosition;\r\n\ttooltipPosition?: LabelTooltipPosition;\r\n}\r\n\r\nexport const Radio = forwardRef<HTMLInputElement, RadioProps>((props, ref) => {\r\n\tconst {\r\n\t\terrorMessage,\r\n\t\tid: idProp,\r\n\t\tinvalid = false,\r\n\t\tlabel,\r\n\t\tlabelAs,\r\n\t\tlabelColor: labelColorProp,\r\n\t\tlabelHiddenText,\r\n\t\tlabelId,\r\n\t\tlabelSuffix,\r\n\t\tposition = RadioPosition.left,\r\n\t\ttooltip,\r\n\t\ttooltipPosition = LabelTooltipPosition.inline,\r\n\t\t...otherProps\r\n\t} = props;\r\n\r\n\tconst { chooseColor, colorScheme } = useDesignSystem(props);\r\n\tconst theme = useTheme();\r\n\r\n\tconst id = useUniqueIdIfIsUndefined(idProp);\r\n\r\n\tconst labelColor = useMemo(() => {\r\n\t\tif (invalid) {\r\n\t\t\treturn chooseColor(theme.colors.fg.error);\r\n\t\t}\r\n\r\n\t\treturn labelColorProp === undefined ? chooseColor(theme.colors.fg.neutral.subtle) : labelColorProp;\r\n\t}, [invalid, labelColorProp, chooseColor, theme.colors.fg.neutral.subtle, theme.colors.fg.error]);\r\n\r\n\treturn (\r\n\t\t<Wrapper>\r\n\t\t\t<ControlAndLabelWrapper $position={position}>\r\n\t\t\t\t<RadioControl\r\n\t\t\t\t\t{...otherProps}\r\n\t\t\t\t\tid={id}\r\n\t\t\t\t\tinvalid={invalid}\r\n\t\t\t\t\tref={ref}\r\n\t\t\t\t/>\r\n\t\t\t\t{isRenderable(label) && (\r\n\t\t\t\t\t<Typography\r\n\t\t\t\t\t\tcolor={labelColor}\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t<LabelAndTooltipWrapper $tooltipPosition={tooltipPosition}>\r\n\t\t\t\t\t\t\t<LabelStyled\r\n\t\t\t\t\t\t\t\t$tooltipPosition={tooltipPosition}\r\n\t\t\t\t\t\t\t\tas={labelAs}\r\n\t\t\t\t\t\t\t\tclassName={liferayClassNames.label}\r\n\t\t\t\t\t\t\t\thtmlFor={labelAs === 'label' || labelAs === undefined ? id : undefined}\r\n\t\t\t\t\t\t\t\tid={labelId}\r\n\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t{label}\r\n\t\t\t\t\t\t\t\t{isRenderable(labelSuffix) && (\r\n\t\t\t\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\t\t\t\tcolor={theme.colors.fg.neutral.subtle}\r\n\t\t\t\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t\t\t{' '}\r\n\t\t\t\t\t\t\t\t\t\t{labelSuffix}\r\n\t\t\t\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t\t\t\t)}\r\n\t\t\t\t\t\t\t\t{labelHiddenText !== undefined && (\r\n\t\t\t\t\t\t\t\t\t<>\r\n\t\t\t\t\t\t\t\t\t\t{' '}\r\n\t\t\t\t\t\t\t\t\t\t<VisuallyHidden>{labelHiddenText}</VisuallyHidden>\r\n\t\t\t\t\t\t\t\t\t</>\r\n\t\t\t\t\t\t\t\t)}\r\n\t\t\t\t\t\t\t</LabelStyled>\r\n\r\n\t\t\t\t\t\t\t{tooltip !== undefined && (\r\n\t\t\t\t\t\t\t\t<>\r\n\t\t\t\t\t\t\t\t\t{tooltipPosition === LabelTooltipPosition.inline && ' '}\r\n\t\t\t\t\t\t\t\t\t<TooltipWrapper $tooltipPosition={tooltipPosition}>\r\n\t\t\t\t\t\t\t\t\t\t<TooltipInfo\r\n\t\t\t\t\t\t\t\t\t\t\t{...mapTooltipInfoDescriptorToPropsSubset(tooltip)}\r\n\t\t\t\t\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t\t\t\t</TooltipWrapper>\r\n\t\t\t\t\t\t\t\t</>\r\n\t\t\t\t\t\t\t)}\r\n\t\t\t\t\t\t</LabelAndTooltipWrapper>\r\n\t\t\t\t\t</Typography>\r\n\t\t\t\t)}\r\n\t\t\t</ControlAndLabelWrapper>\r\n\t\t\t{errorMessage !== undefined && (\r\n\t\t\t\t<Typography\r\n\t\t\t\t\tcolor={chooseColor(theme.colors.fg.error)}\r\n\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t>\r\n\t\t\t\t\t{errorMessage}\r\n\t\t\t\t</Typography>\r\n\t\t\t)}\r\n\t\t</Wrapper>\r\n\t);\r\n});\r\n\r\nRadio.displayName = 'Radio';\r\n","import { type AriaAttributes, type AriaRole } from 'react';\r\n\r\nimport { type InputLabelPassthroughProps } from '@/types';\r\n\r\nexport interface RadioGroupItem extends InputLabelPassthroughProps, AriaAttributes {\r\n\tid?: string;\r\n\trole?: AriaRole;\r\n\tvalue: string;\r\n}\r\n\r\nexport enum RadioGroupDirection {\r\n\tcolumn = 'column',\r\n\tcolumnReverse = 'columnReverse',\r\n\trow = 'row',\r\n\trowReverse = 'rowReverse',\r\n}\r\n","import { css } from '@emotion/react';\r\nimport { type Property } from 'csstype';\r\n\r\nimport { RadioGroupDirection } from '@/components/radioGroupField/types';\r\nimport { resolveSpacingValue, type Spacing } from '@/theme';\r\nimport { styled } from '@/utils';\r\n\r\ninterface ItemsWrapperProps {\r\n\t$columnGap: Spacing;\r\n\t$controlWidth?: Property.Width;\r\n\t$direction: RadioGroupDirection;\r\n\t$rowGap: Spacing;\r\n}\r\n\r\nexport const ItemsWrapper = styled.div<ItemsWrapperProps>`\r\n\tbox-sizing: border-box;\r\n\tdisplay: flex;\r\n\tflex-direction: ${({ $direction }) => {\r\n\t\tswitch ($direction) {\r\n\t\t\tcase RadioGroupDirection.row:\r\n\t\t\t\treturn 'row';\r\n\t\t\tcase RadioGroupDirection.rowReverse:\r\n\t\t\t\treturn 'row-reverse';\r\n\t\t\tcase RadioGroupDirection.column:\r\n\t\t\t\treturn 'column';\r\n\t\t\tcase RadioGroupDirection.columnReverse:\r\n\t\t\t\treturn 'column-reverse';\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected value of enum RadioGroupDirection in RadioGroupControl.style.ts');\r\n\t\t}\r\n\t}};\r\n\tflex-wrap: wrap;\r\n\trow-gap: ${({ $rowGap, theme }) => resolveSpacingValue(theme, $rowGap)};\r\n\tcolumn-gap: ${({ $columnGap, theme }) => resolveSpacingValue(theme, $columnGap)};\r\n\t${({ $controlWidth }) =>\r\n\t\t$controlWidth !== undefined &&\r\n\t\tcss`\r\n\t\t\twidth: ${$controlWidth};\r\n\t\t`}\r\n`;\r\n\r\ninterface ItemWrapperProps {\r\n\t$itemMinWidth?: Property.Width;\r\n}\r\n\r\nexport const ItemWrapper = styled.div<ItemWrapperProps>`\r\n\tbox-sizing: border-box;\r\n\talign-content: center;\r\n\t${({ $itemMinWidth }) =>\r\n\t\t$itemMinWidth !== undefined &&\r\n\t\tcss`\r\n\t\t\tmin-width: ${$itemMinWidth};\r\n\t\t`}\r\n`;\r\n","import { type Property } from 'csstype';\r\nimport { forwardRef, type FocusEvent, type ChangeEvent } from 'react';\r\n\r\nimport { Radio } from '@/components/radioField/radio/Radio';\r\nimport { type RadioGroupDirection, type RadioGroupItem } from '@/components/radioGroupField/types';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { Spacing } from '@/theme';\r\nimport { type FieldControlProps } from '@/types';\r\n\r\nimport { ItemsWrapper, ItemWrapper } from './RadioGroupControl.style';\r\n\r\nexport interface RadioGroupControlProps extends FieldControlProps, DesignSystemBaseProps {\r\n\tcolumnGap?: Spacing;\r\n\tcontrolWidth?: Property.Width;\r\n\tdirection: RadioGroupDirection;\r\n\tdisabled?: boolean;\r\n\titemMinWidth?: Property.Width;\r\n\titems: RadioGroupItem[];\r\n\tname: string;\r\n\tonBlur?: ((event: FocusEvent<HTMLInputElement>) => void) | undefined;\r\n\tonChange?: ((event: ChangeEvent<HTMLInputElement>) => void) | undefined;\r\n\trowGap?: Spacing;\r\n\tvalue?: string;\r\n}\r\n\r\nexport const RadioGroupControl = forwardRef<HTMLInputElement, RadioGroupControlProps>((props, ref) => {\r\n\tconst {\r\n\t\tcolumnGap = Spacing.md,\r\n\t\tcontrolWidth,\r\n\t\tdirection,\r\n\t\tdisabled,\r\n\t\tinvalid,\r\n\t\titemMinWidth,\r\n\t\titems,\r\n\t\tlabelledBy,\r\n\t\tname,\r\n\t\tonBlur,\r\n\t\tonChange,\r\n\t\trowGap = Spacing.md,\r\n\t\tvalue,\r\n\t} = props;\r\n\r\n\tconst { colorScheme } = useDesignSystem(props);\r\n\r\n\treturn (\r\n\t\t<ItemsWrapper\r\n\t\t\t$columnGap={columnGap}\r\n\t\t\t$controlWidth={controlWidth}\r\n\t\t\t$direction={direction}\r\n\t\t\t$rowGap={rowGap}\r\n\t\t\taria-labelledby={labelledBy}\r\n\t\t\trole=\"radiogroup\"\r\n\t\t>\r\n\t\t\t{items.map((item) => {\r\n\t\t\t\tconst { id: itemId, label, value: itemValue, ...otherItemParams } = item;\r\n\r\n\t\t\t\tconst checked = value === undefined ? undefined : itemValue === value;\r\n\r\n\t\t\t\treturn (\r\n\t\t\t\t\t<ItemWrapper\r\n\t\t\t\t\t\tkey={item.value}\r\n\t\t\t\t\t\t$itemMinWidth={itemMinWidth}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t<Radio\r\n\t\t\t\t\t\t\tchecked={checked}\r\n\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\tdisabled={disabled}\r\n\t\t\t\t\t\t\tid={itemId}\r\n\t\t\t\t\t\t\tinvalid={invalid}\r\n\t\t\t\t\t\t\tlabel={label}\r\n\t\t\t\t\t\t\tname={name}\r\n\t\t\t\t\t\t\tref={ref}\r\n\t\t\t\t\t\t\tvalue={itemValue}\r\n\t\t\t\t\t\t\tonBlur={onBlur}\r\n\t\t\t\t\t\t\tonChange={onChange}\r\n\t\t\t\t\t\t\t{...otherItemParams}\r\n\t\t\t\t\t\t/>\r\n\t\t\t\t\t</ItemWrapper>\r\n\t\t\t\t);\r\n\t\t\t})}\r\n\t\t</ItemsWrapper>\r\n\t);\r\n});\r\n\r\nRadioGroupControl.displayName = 'RadioGroupControl';\r\n","import { type ComponentProps, forwardRef } from 'react';\r\n\r\nimport { withFieldWrapper } from '@/components/fieldWrapper';\r\nimport { RadioGroupControl, type RadioGroupControlProps } from '@/components/radioGroupField/radioGroupControl/RadioGroupControl';\r\n\r\nconst RadioGroupBase = withFieldWrapper<RadioGroupControlProps, HTMLInputElement>(RadioGroupControl);\r\n\r\nexport const RadioGroup = forwardRef<HTMLInputElement, ComponentProps<typeof RadioGroupBase>>((props, ref) => {\r\n\tconst { labelAs = 'span', ...restProps } = props;\r\n\r\n\treturn (\r\n\t\t<RadioGroupBase\r\n\t\t\t{...restProps}\r\n\t\t\tlabelAs={labelAs}\r\n\t\t\tref={ref}\r\n\t\t/>\r\n\t);\r\n});\r\n\r\nRadioGroup.displayName = 'RadioGroup';\r\n\r\nexport type RadioGroupProps = ComponentProps<typeof RadioGroup>;\r\n","import { type ChangeEvent, useCallback } from 'react';\r\nimport { type RegisterOptions, useController } from 'react-hook-form';\r\n\r\nimport { RadioGroup, type RadioGroupProps } from '@/components/radioGroupField/radioGroup/RadioGroup';\r\n\r\nexport interface RadioGroupFieldProps extends Omit<RadioGroupProps, 'onBlur' | 'onChange' | 'value'> {\r\n\tname: string;\r\n\toptions?: RegisterOptions;\r\n}\r\n\r\nexport const RadioGroupField = (props: RadioGroupFieldProps) => {\r\n\tconst { name, options, ...otherProps } = props;\r\n\r\n\tconst {\r\n\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\r\n\t\tfield: { onBlur, onChange, ref, value },\r\n\t\tfieldState: { error },\r\n\t} = useController({\r\n\t\tname: name,\r\n\t\trules: options,\r\n\t});\r\n\r\n\t// NOTE: Ensures that validations are triggered immediately after changing value.\r\n\t// Using onblur validations with radios is confusing otherwise.\r\n\tconst handleChange = useCallback(\r\n\t\t(event: ChangeEvent<HTMLInputElement>) => {\r\n\t\t\tonChange(event);\r\n\t\t\tonBlur();\r\n\t\t},\r\n\t\t[onBlur, onChange],\r\n\t);\r\n\r\n\treturn (\r\n\t\t<RadioGroup\r\n\t\t\terrorMessage={error?.message}\r\n\t\t\tname={name}\r\n\t\t\tref={ref}\r\n\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\r\n\t\t\tvalue={value}\r\n\t\t\tonBlur={onBlur}\r\n\t\t\tonChange={handleChange}\r\n\t\t\t{...otherProps}\r\n\t\t/>\r\n\t);\r\n};\r\n","import { type ComponentProps, forwardRef, type ReactNode } from 'react';\r\n\r\nimport { Button, ButtonSize, ButtonStyle, ButtonType } from '@/components/button';\r\nimport { withFieldWrapper } from '@/components/fieldWrapper';\r\nimport { IconSystem, IconSystemSize, IconSystemType } from '@/components/iconSystem';\r\nimport { type InputProps, InputSize } from '@/types';\r\n\r\nimport { InputBase } from '../inputBase';\r\n\r\nexport interface SearchInputControlProps extends InputProps {\r\n\tbuttonAction?: () => void;\r\n\tbuttonText?: ReactNode;\r\n\tinvalid?: boolean;\r\n\tplaceholder?: string;\r\n}\r\n\r\nconst SearchInputControl = forwardRef<HTMLInputElement, SearchInputControlProps>((props, ref) => {\r\n\tconst { buttonAction, buttonText, ...otherProps } = props;\r\n\tconst { invalid = false, size } = props;\r\n\r\n\treturn (\r\n\t\t<InputBase\r\n\t\t\tbutton={\r\n\t\t\t\t<Button\r\n\t\t\t\t\tbuttonStyle={ButtonStyle.primary}\r\n\t\t\t\t\tdisabled={invalid}\r\n\t\t\t\t\tsize={size === InputSize.xl ? ButtonSize.md : ButtonSize.sm}\r\n\t\t\t\t\ttype={ButtonType.button}\r\n\t\t\t\t\tonClick={buttonAction}\r\n\t\t\t\t>\r\n\t\t\t\t\t{buttonText}\r\n\t\t\t\t</Button>\r\n\t\t\t}\r\n\t\t\ticon={\r\n\t\t\t\t<IconSystem\r\n\t\t\t\t\tsize={IconSystemSize.big}\r\n\t\t\t\t\ttype={IconSystemType.search}\r\n\t\t\t\t/>\r\n\t\t\t}\r\n\t\t\tref={ref}\r\n\t\t\ttype=\"text\"\r\n\t\t\t{...otherProps}\r\n\t\t/>\r\n\t);\r\n});\r\n\r\nSearchInputControl.displayName = 'SearchInputControl';\r\n\r\nexport const SearchInput = withFieldWrapper<SearchInputControlProps, HTMLInputElement>(SearchInputControl);\r\n\r\nexport type SearchInputProps = ComponentProps<typeof SearchInput>;\r\n","export enum SliderInputRoundingType {\r\n\tceilBySteps = 'ceilBySteps',\r\n\tceilToThousands = 'ceilToThousands',\r\n\tfloorBySteps = 'floorBySteps',\r\n\tfloorToThousands = 'floorToThousands',\r\n\troundBySteps = 'roundBySteps',\r\n\troundToThousands = 'roundToThousands',\r\n}\r\n\r\nimport { type Formatter } from 'afformative';\r\nimport { type ReactElement } from 'react';\r\n\r\nexport interface SliderMapFunctionParam {\r\n\tmax: number;\r\n\tmin: number;\r\n\tsteps: SliderSteps;\r\n\tvalue: number;\r\n}\r\n\r\nexport interface SliderMapFunctionReturn {\r\n\tsliderMax: number;\r\n\tsliderMin: number;\r\n\tsliderStep: number | undefined;\r\n\tsliderValue: number;\r\n}\r\n\r\nexport type SliderMapFunction = (param: SliderMapFunctionParam) => SliderMapFunctionReturn;\r\n\r\nexport interface SliderMapOnChangeFunctionParam {\r\n\tmax: number;\r\n\tmin: number;\r\n\tsliderValue: number;\r\n\tsteps: SliderSteps;\r\n}\r\n\r\nexport type SliderMapOnChangeFunction = (param: SliderMapOnChangeFunctionParam) => number;\r\n\r\nexport interface SliderBreakpoint {\r\n\tbottomBreakpoint: number;\r\n\tstep: number;\r\n}\r\n\r\nexport interface SliderSteps {\r\n\tbaseStep: number;\r\n\tbreakpointList: SliderBreakpoint[];\r\n}\r\n\r\nexport enum SliderStepType {\r\n\tvisuallyLinearByValue = 'visuallyLinearByValue',\r\n\tvisuallySameStepSize = 'visuallySameStepSize',\r\n}\r\n\r\nexport interface SliderMinMaxLabels {\r\n\tmax: ReactElement | string;\r\n\tmin: ReactElement | string;\r\n}\r\n\r\nexport interface SliderAriaValueTextFormatterDataContext {\r\n\tclampMax?: number;\r\n\tclampMin?: number;\r\n}\r\n\r\nexport type SliderAriaValueTextFormatter = Formatter<number, string, string, SliderAriaValueTextFormatterDataContext>;\r\n\r\nexport interface SliderInputLimitExceededLiveTextFormatterDataContext {\r\n\tclampMax: number;\r\n\tclampMin: number;\r\n\teffectiveMax: number;\r\n\teffectiveMin: number;\r\n\tmax: number;\r\n\tmin: number;\r\n\toldValue: number;\r\n}\r\n\r\nexport type SliderInputLimitExceededLiveTextFormatter = Formatter<number, string, string, SliderInputLimitExceededLiveTextFormatterDataContext>;\r\n","import { type SliderSteps } from '@/components/sliderInputField/types';\r\n\r\nexport const clampSliderSteps = (steps: SliderSteps, min: number, max: number): SliderSteps => {\r\n\tlet baseStep = steps.baseStep;\r\n\tconst breakpointList = [...steps.breakpointList];\r\n\r\n\t// Clamp from the min side\r\n\twhile (breakpointList.length > 0 && breakpointList[0].bottomBreakpoint <= min) {\r\n\t\tbaseStep = breakpointList[0].step;\r\n\t\tbreakpointList.shift();\r\n\t}\r\n\r\n\t// Clamp from the max side\r\n\twhile (breakpointList.length > 0 && breakpointList[breakpointList.length - 1].bottomBreakpoint >= max) {\r\n\t\tbreakpointList.pop();\r\n\t}\r\n\r\n\treturn { baseStep: baseStep, breakpointList: breakpointList };\r\n};\r\n","import { type SliderBreakpoint, type SliderMapOnChangeFunction } from '@/components/sliderInputField/types';\r\n\r\nexport const getValueBySliderValueVisuallySameStepSize: SliderMapOnChangeFunction = (param): number => {\r\n\tconst { max, min, sliderValue, steps } = param;\r\n\r\n\tconst breakpoints: SliderBreakpoint[] = [{ step: steps.baseStep, bottomBreakpoint: min }, ...steps.breakpointList];\r\n\r\n\tlet currentSliderValue = min;\r\n\tlet currentValue = min;\r\n\r\n\twhile (currentSliderValue < sliderValue) {\r\n\t\tlet breakpointIndexFound = 0;\r\n\t\tlet breakpointFound: SliderBreakpoint = breakpoints[breakpointIndexFound];\r\n\r\n\t\tfor (const [currentBreakpointIndex, currentBreakpoint] of breakpoints.entries()) {\r\n\t\t\tif (currentBreakpoint.bottomBreakpoint > currentValue) {\r\n\t\t\t\tbreak;\r\n\t\t\t}\r\n\r\n\t\t\tbreakpointIndexFound = currentBreakpointIndex;\r\n\t\t\tbreakpointFound = currentBreakpoint;\r\n\t\t}\r\n\r\n\t\tconst breakpointFoundStep = breakpointFound.step;\r\n\r\n\t\t// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\r\n\t\tconst nextBreakpoint = breakpoints[breakpointIndexFound + 1]?.bottomBreakpoint === undefined ? max : breakpoints[breakpointIndexFound + 1].bottomBreakpoint;\r\n\r\n\t\tconst nextValue = currentValue + breakpointFoundStep;\r\n\t\tcurrentValue = nextValue < nextBreakpoint ? nextValue : nextBreakpoint;\r\n\t\tcurrentSliderValue = currentSliderValue + 1;\r\n\t}\r\n\r\n\treturn currentValue;\r\n};\r\n","import { type SliderMapFunction } from '@/components/sliderInputField/types';\r\n\r\nexport const sliderFunctionVisuallyLinearByValue: SliderMapFunction = (param) => {\r\n\tconst { max, min, steps, value } = param;\r\n\r\n\tconst step = steps.breakpointList.reduce((accumulator, currentValue) => {\r\n\t\tif (value < currentValue.bottomBreakpoint) {\r\n\t\t\treturn accumulator;\r\n\t\t}\r\n\r\n\t\treturn currentValue.step;\r\n\t}, steps.baseStep);\r\n\r\n\treturn {\r\n\t\tsliderStep: step,\r\n\t\tsliderValue: value,\r\n\t\tsliderMax: max,\r\n\t\tsliderMin: min,\r\n\t\tsliderMarks: undefined,\r\n\t};\r\n};\r\n","import { type SliderMapFunction } from '@/components/sliderInputField/types';\r\n\r\nimport { getSliderMax } from './getSliderMax';\r\nimport { getSliderValueByValue } from './getSliderValueByValue';\r\n\r\nexport const sliderFunctionVisuallySameStepSize: SliderMapFunction = (param) => {\r\n\tconst { max, min, steps, value } = param;\r\n\r\n\tconst sliderMax = getSliderMax({\r\n\t\tmax: max,\r\n\t\tsteps: steps,\r\n\t\tmin: min,\r\n\t});\r\n\r\n\tconst sliderValue = getSliderValueByValue({\r\n\t\tvalue: value,\r\n\t\tsteps: steps,\r\n\t\tmin: min,\r\n\t\tmax: max,\r\n\t});\r\n\r\n\treturn {\r\n\t\tsliderStep: 1,\r\n\t\tsliderValue: sliderValue,\r\n\t\tsliderMax: sliderMax,\r\n\t\tsliderMin: min,\r\n\t\tsliderMarks: undefined,\r\n\t};\r\n};\r\n","import { type SliderBreakpoint, type SliderSteps } from '@/components/sliderInputField/types';\r\n\r\ninterface GetSliderMaxParam {\r\n\tmax: number;\r\n\tmin: number;\r\n\tsteps: SliderSteps;\r\n}\r\n\r\nexport const getSliderMax = (param: GetSliderMaxParam): number => {\r\n\tconst { max, min, steps } = param;\r\n\r\n\tconst breakpoints: SliderBreakpoint[] = [{ step: steps.baseStep, bottomBreakpoint: min }, ...steps.breakpointList];\r\n\r\n\tconst sliderMax = breakpoints.reduce((accumulator, currentValue, currentIndex, array) => {\r\n\t\tconst { bottomBreakpoint: currenBottomBreakpoint, step } = currentValue;\r\n\t\t// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\r\n\t\tconst nextBreakpoint: number = array[currentIndex + 1]?.bottomBreakpoint === undefined ? max : array[currentIndex + 1].bottomBreakpoint;\r\n\r\n\t\tlet localSteps = 0;\r\n\t\tlet i = currenBottomBreakpoint;\r\n\t\twhile (i + step < nextBreakpoint) {\r\n\t\t\ti = i + step;\r\n\t\t\tlocalSteps = localSteps + 1;\r\n\t\t}\r\n\r\n\t\tif (i < nextBreakpoint) {\r\n\t\t\treturn accumulator + localSteps + 1;\r\n\t\t}\r\n\r\n\t\treturn accumulator + localSteps;\r\n\t}, min);\r\n\r\n\treturn sliderMax;\r\n};\r\n","import { type SliderBreakpoint, type SliderSteps } from '@/components/sliderInputField/types';\r\n\r\ninterface GetSliderValueByValueParam {\r\n\tmax: number;\r\n\tmin: number;\r\n\tsteps: SliderSteps;\r\n\tvalue: number;\r\n}\r\n\r\nexport const getSliderValueByValue = (param: GetSliderValueByValueParam): number => {\r\n\tconst { max, min, steps, value } = param;\r\n\r\n\tconst breakpoints: SliderBreakpoint[] = [{ step: steps.baseStep, bottomBreakpoint: min }, ...steps.breakpointList];\r\n\r\n\tlet sliderValue = min;\r\n\r\n\touterCycle: for (const [breakpointIndex, breakpoint] of breakpoints.entries()) {\r\n\t\tconst { bottomBreakpoint: currenBottomBreakpoint, step } = breakpoint;\r\n\t\t// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\r\n\t\tconst nextBreakpoint = breakpoints[breakpointIndex + 1]?.bottomBreakpoint === undefined ? max : breakpoints[breakpointIndex + 1].bottomBreakpoint;\r\n\r\n\t\tlet i: number = currenBottomBreakpoint;\r\n\t\tif (value <= currenBottomBreakpoint) {\r\n\t\t\tbreak;\r\n\t\t}\r\n\t\twhile (i + step < nextBreakpoint) {\r\n\t\t\ti = i + step;\r\n\t\t\tsliderValue = sliderValue + 1;\r\n\r\n\t\t\tif (i === value || (i > value && i < value + step)) {\r\n\t\t\t\tbreak outerCycle;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (i < nextBreakpoint) {\r\n\t\t\tsliderValue = sliderValue + 1;\r\n\t\t}\r\n\t}\r\n\r\n\treturn sliderValue;\r\n};\r\n","import { css, Global } from '@emotion/react';\r\n\r\nimport { styled } from '@/utils';\r\n\r\nexport const SliderWrapper = styled.div`\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\theight: 24px; /* height of handle */\r\n`;\r\n\r\nexport const Wrapper = styled.div`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\trow-gap: ${({ theme }) => theme.spacing.xs};\r\n\twidth: 100%;\r\n`;\r\n\r\nexport const HintsWrapper = styled.div`\r\n\tdisplay: flex;\r\n`;\r\n\r\nexport const HintLeftWrapper = styled.div`\r\n\tdisplay: flex;\r\n\tflex: 1;\r\n\tjustify-content: left;\r\n`;\r\n\r\nexport const HintRightWrapper = styled.div`\r\n\tdisplay: flex;\r\n\tflex: 1;\r\n\tjustify-content: right;\r\n`;\r\n\r\n// copy of styles from import 'rc-slider/assets/index.css';\r\nexport const RcSliderGlobal = () => (\r\n\t<Global\r\n\t\tstyles={css`\r\n\t\t\t/* stylelint-disable */\r\n\t\t\t.rc-slider {\r\n\t\t\t\tposition: relative;\r\n\t\t\t\twidth: 100%;\r\n\t\t\t\theight: 14px;\r\n\t\t\t\tpadding: 5px 0;\r\n\t\t\t\tborder-radius: 6px;\r\n\t\t\t\ttouch-action: none;\r\n\t\t\t\tbox-sizing: border-box;\r\n\t\t\t\t-webkit-tap-highlight-color: rgba(0, 0, 0, 0);\r\n\t\t\t}\r\n\t\t\t.rc-slider * {\r\n\t\t\t\tbox-sizing: border-box;\r\n\t\t\t\t-webkit-tap-highlight-color: rgba(0, 0, 0, 0);\r\n\t\t\t}\r\n\t\t\t.rc-slider-rail {\r\n\t\t\t\tposition: absolute;\r\n\t\t\t\twidth: 100%;\r\n\t\t\t\theight: 4px;\r\n\t\t\t\tbackground-color: #e9e9e9;\r\n\t\t\t\tborder-radius: 6px;\r\n\t\t\t}\r\n\t\t\t.rc-slider-track,\r\n\t\t\t.rc-slider-tracks {\r\n\t\t\t\tposition: absolute;\r\n\t\t\t\theight: 4px;\r\n\t\t\t\tbackground-color: #abe2fb;\r\n\t\t\t\tborder-radius: 6px;\r\n\t\t\t}\r\n\t\t\t.rc-slider-track-draggable {\r\n\t\t\t\tz-index: 1;\r\n\t\t\t\tbox-sizing: content-box;\r\n\t\t\t\tbackground-clip: content-box;\r\n\t\t\t\tborder-top: 5px solid rgba(0, 0, 0, 0);\r\n\t\t\t\tborder-bottom: 5px solid rgba(0, 0, 0, 0);\r\n\t\t\t\ttransform: translateY(-5px);\r\n\t\t\t}\r\n\t\t\t.rc-slider-handle {\r\n\t\t\t\tposition: absolute;\r\n\t\t\t\tz-index: 1;\r\n\t\t\t\twidth: 14px;\r\n\t\t\t\theight: 14px;\r\n\t\t\t\tmargin-top: -5px;\r\n\t\t\t\tbackground-color: #fff;\r\n\t\t\t\tborder: solid 2px #96dbfa;\r\n\t\t\t\tborder-radius: 50%;\r\n\t\t\t\tcursor: pointer;\r\n\t\t\t\tcursor: grab;\r\n\t\t\t\topacity: 0.8;\r\n\t\t\t\ttouch-action: pan-x;\r\n\t\t\t}\r\n\t\t\t.rc-slider-handle-dragging.rc-slider-handle-dragging.rc-slider-handle-dragging {\r\n\t\t\t\tborder-color: #57c5f7;\r\n\t\t\t\tbox-shadow: 0 0 0 5px #96dbfa;\r\n\t\t\t}\r\n\t\t\t.rc-slider-handle:focus {\r\n\t\t\t\toutline: none;\r\n\t\t\t\tbox-shadow: none;\r\n\t\t\t}\r\n\t\t\t.rc-slider-handle:focus-visible {\r\n\t\t\t\tborder-color: #2db7f5;\r\n\t\t\t\tbox-shadow: 0 0 0 3px #96dbfa;\r\n\t\t\t}\r\n\t\t\t.rc-slider-handle-click-focused:focus {\r\n\t\t\t\tborder-color: #96dbfa;\r\n\t\t\t\tbox-shadow: unset;\r\n\t\t\t}\r\n\t\t\t.rc-slider-handle:hover {\r\n\t\t\t\tborder-color: #57c5f7;\r\n\t\t\t}\r\n\t\t\t.rc-slider-handle:active {\r\n\t\t\t\tborder-color: #57c5f7;\r\n\t\t\t\tbox-shadow: 0 0 5px #57c5f7;\r\n\t\t\t\tcursor: grabbing;\r\n\t\t\t}\r\n\t\t\t.rc-slider-mark {\r\n\t\t\t\tposition: absolute;\r\n\t\t\t\ttop: 18px;\r\n\t\t\t\tleft: 0;\r\n\t\t\t\twidth: 100%;\r\n\t\t\t\tfont-size: 12px;\r\n\t\t\t}\r\n\t\t\t.rc-slider-mark-text {\r\n\t\t\t\tposition: absolute;\r\n\t\t\t\tdisplay: inline-block;\r\n\t\t\t\tcolor: #999;\r\n\t\t\t\ttext-align: center;\r\n\t\t\t\tvertical-align: middle;\r\n\t\t\t\tcursor: pointer;\r\n\t\t\t}\r\n\t\t\t.rc-slider-mark-text-active {\r\n\t\t\t\tcolor: #666;\r\n\t\t\t}\r\n\t\t\t.rc-slider-step {\r\n\t\t\t\tposition: absolute;\r\n\t\t\t\twidth: 100%;\r\n\t\t\t\theight: 4px;\r\n\t\t\t\tbackground: transparent;\r\n\t\t\t}\r\n\t\t\t.rc-slider-dot {\r\n\t\t\t\tposition: absolute;\r\n\t\t\t\tbottom: -2px;\r\n\t\t\t\twidth: 8px;\r\n\t\t\t\theight: 8px;\r\n\t\t\t\tvertical-align: middle;\r\n\t\t\t\tbackground-color: #fff;\r\n\t\t\t\tborder: 2px solid #e9e9e9;\r\n\t\t\t\tborder-radius: 50%;\r\n\t\t\t\tcursor: pointer;\r\n\t\t\t}\r\n\t\t\t.rc-slider-dot-active {\r\n\t\t\t\tborder-color: #96dbfa;\r\n\t\t\t}\r\n\t\t\t.rc-slider-dot-reverse {\r\n\t\t\t\tmargin-right: -4px;\r\n\t\t\t}\r\n\t\t\t.rc-slider-disabled {\r\n\t\t\t\t//background-color: #e9e9e9;\r\n\t\t\t}\r\n\t\t\t.rc-slider-disabled .rc-slider-track {\r\n\t\t\t\tbackground-color: #ccc;\r\n\t\t\t}\r\n\t\t\t.rc-slider-disabled .rc-slider-handle,\r\n\t\t\t.rc-slider-disabled .rc-slider-dot {\r\n\t\t\t\tbackground-color: #fff;\r\n\t\t\t\tborder-color: #ccc;\r\n\t\t\t\tbox-shadow: none;\r\n\t\t\t\tcursor: not-allowed;\r\n\t\t\t}\r\n\t\t\t.rc-slider-disabled .rc-slider-mark-text,\r\n\t\t\t.rc-slider-disabled .rc-slider-dot {\r\n\t\t\t\tcursor: not-allowed !important;\r\n\t\t\t}\r\n\t\t\t.rc-slider-vertical {\r\n\t\t\t\twidth: 14px;\r\n\t\t\t\theight: 100%;\r\n\t\t\t\tpadding: 0 5px;\r\n\t\t\t}\r\n\t\t\t.rc-slider-vertical .rc-slider-rail {\r\n\t\t\t\twidth: 4px;\r\n\t\t\t\theight: 100%;\r\n\t\t\t}\r\n\t\t\t.rc-slider-vertical .rc-slider-track {\r\n\t\t\t\tbottom: 0;\r\n\t\t\t\tleft: 5px;\r\n\t\t\t\twidth: 4px;\r\n\t\t\t}\r\n\t\t\t.rc-slider-vertical .rc-slider-track-draggable {\r\n\t\t\t\tborder-top: 0;\r\n\t\t\t\tborder-bottom: 0;\r\n\t\t\t\tborder-right: 5px solid rgba(0, 0, 0, 0);\r\n\t\t\t\tborder-left: 5px solid rgba(0, 0, 0, 0);\r\n\t\t\t\ttransform: translateX(-5px);\r\n\t\t\t}\r\n\t\t\t.rc-slider-vertical .rc-slider-handle {\r\n\t\t\t\tposition: absolute;\r\n\t\t\t\tz-index: 1;\r\n\t\t\t\tmargin-top: 0;\r\n\t\t\t\tmargin-left: -5px;\r\n\t\t\t\ttouch-action: pan-y;\r\n\t\t\t}\r\n\t\t\t.rc-slider-vertical .rc-slider-mark {\r\n\t\t\t\ttop: 0;\r\n\t\t\t\tleft: 18px;\r\n\t\t\t\theight: 100%;\r\n\t\t\t}\r\n\t\t\t.rc-slider-vertical .rc-slider-step {\r\n\t\t\t\twidth: 4px;\r\n\t\t\t\theight: 100%;\r\n\t\t\t}\r\n\t\t\t.rc-slider-vertical .rc-slider-dot {\r\n\t\t\t\tmargin-left: -2px;\r\n\t\t\t}\r\n\t\t\t.rc-slider-tooltip-zoom-down-enter,\r\n\t\t\t.rc-slider-tooltip-zoom-down-appear {\r\n\t\t\t\tdisplay: block !important;\r\n\t\t\t\tanimation-duration: 0.3s;\r\n\t\t\t\tanimation-fill-mode: both;\r\n\t\t\t\tanimation-play-state: paused;\r\n\t\t\t}\r\n\t\t\t.rc-slider-tooltip-zoom-down-leave {\r\n\t\t\t\tdisplay: block !important;\r\n\t\t\t\tanimation-duration: 0.3s;\r\n\t\t\t\tanimation-fill-mode: both;\r\n\t\t\t\tanimation-play-state: paused;\r\n\t\t\t}\r\n\t\t\t.rc-slider-tooltip-zoom-down-enter.rc-slider-tooltip-zoom-down-enter-active,\r\n\t\t\t.rc-slider-tooltip-zoom-down-appear.rc-slider-tooltip-zoom-down-appear-active {\r\n\t\t\t\tanimation-name: rcSliderTooltipZoomDownIn;\r\n\t\t\t\tanimation-play-state: running;\r\n\t\t\t}\r\n\t\t\t.rc-slider-tooltip-zoom-down-leave.rc-slider-tooltip-zoom-down-leave-active {\r\n\t\t\t\tanimation-name: rcSliderTooltipZoomDownOut;\r\n\t\t\t\tanimation-play-state: running;\r\n\t\t\t}\r\n\t\t\t.rc-slider-tooltip-zoom-down-enter,\r\n\t\t\t.rc-slider-tooltip-zoom-down-appear {\r\n\t\t\t\ttransform: scale(0, 0);\r\n\t\t\t\tanimation-timing-function: cubic-bezier(0.23, 1, 0.32, 1);\r\n\t\t\t}\r\n\t\t\t.rc-slider-tooltip-zoom-down-leave {\r\n\t\t\t\tanimation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);\r\n\t\t\t}\r\n\t\t\t@keyframes rcSliderTooltipZoomDownIn {\r\n\t\t\t\t0% {\r\n\t\t\t\t\ttransform: scale(0, 0);\r\n\t\t\t\t\ttransform-origin: 50% 100%;\r\n\t\t\t\t\topacity: 0;\r\n\t\t\t\t}\r\n\t\t\t\t100% {\r\n\t\t\t\t\ttransform: scale(1, 1);\r\n\t\t\t\t\ttransform-origin: 50% 100%;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\t@keyframes rcSliderTooltipZoomDownOut {\r\n\t\t\t\t0% {\r\n\t\t\t\t\ttransform: scale(1, 1);\r\n\t\t\t\t\ttransform-origin: 50% 100%;\r\n\t\t\t\t}\r\n\t\t\t\t100% {\r\n\t\t\t\t\ttransform: scale(0, 0);\r\n\t\t\t\t\ttransform-origin: 50% 100%;\r\n\t\t\t\t\topacity: 0;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\t.rc-slider-tooltip {\r\n\t\t\t\tposition: absolute;\r\n\t\t\t\ttop: -9999px;\r\n\t\t\t\tleft: -9999px;\r\n\t\t\t\tvisibility: visible;\r\n\t\t\t\tbox-sizing: border-box;\r\n\t\t\t\t-webkit-tap-highlight-color: rgba(0, 0, 0, 0);\r\n\t\t\t}\r\n\t\t\t.rc-slider-tooltip * {\r\n\t\t\t\tbox-sizing: border-box;\r\n\t\t\t\t-webkit-tap-highlight-color: rgba(0, 0, 0, 0);\r\n\t\t\t}\r\n\t\t\t.rc-slider-tooltip-hidden {\r\n\t\t\t\tdisplay: none;\r\n\t\t\t}\r\n\t\t\t.rc-slider-tooltip-placement-top {\r\n\t\t\t\tpadding: 4px 0 8px 0;\r\n\t\t\t}\r\n\t\t\t.rc-slider-tooltip-inner {\r\n\t\t\t\tmin-width: 24px;\r\n\t\t\t\theight: 24px;\r\n\t\t\t\tpadding: 6px 2px;\r\n\t\t\t\tcolor: #fff;\r\n\t\t\t\tfont-size: 12px;\r\n\t\t\t\tline-height: 1;\r\n\t\t\t\ttext-align: center;\r\n\t\t\t\ttext-decoration: none;\r\n\t\t\t\tbackground-color: #6c6c6c;\r\n\t\t\t\tborder-radius: 6px;\r\n\t\t\t\tbox-shadow: 0 0 4px #d9d9d9;\r\n\t\t\t}\r\n\t\t\t.rc-slider-tooltip-arrow {\r\n\t\t\t\tposition: absolute;\r\n\t\t\t\twidth: 0;\r\n\t\t\t\theight: 0;\r\n\t\t\t\tborder-color: transparent;\r\n\t\t\t\tborder-style: solid;\r\n\t\t\t}\r\n\t\t\t.rc-slider-tooltip-placement-top .rc-slider-tooltip-arrow {\r\n\t\t\t\tbottom: 4px;\r\n\t\t\t\tleft: 50%;\r\n\t\t\t\tmargin-left: -4px;\r\n\t\t\t\tborder-width: 4px 4px 0;\r\n\t\t\t\tborder-top-color: #6c6c6c;\r\n\t\t\t}\r\n\t\t`}\r\n\t/>\r\n);\r\n","import { useTheme } from '@emotion/react';\r\nimport { clamp } from 'lodash';\r\nimport RcSlider from 'rc-slider';\r\nimport { type FocusEventHandler, useCallback, useEffect, useMemo, useRef } from 'react';\r\nimport { useBoolean, useMediaQuery } from 'usehooks-ts';\r\n\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\n\r\nimport {\r\n\ttype SliderAriaValueTextFormatter,\r\n\ttype SliderMapFunction,\r\n\ttype SliderMapOnChangeFunction,\r\n\ttype SliderMinMaxLabels,\r\n\ttype SliderSteps,\r\n\tSliderStepType,\r\n} from '../types';\r\nimport { clampSliderSteps } from '../utils/clampSliderSteps';\r\nimport { getSliderHandleBackgroundSvgBase64 } from '../utils/getSliderHandleBackgroundSvgBase64';\r\nimport { getValueBySliderValueVisuallySameStepSize } from '../utils/getValueBySliderValueVisuallySameStepSize';\r\nimport { sliderFunctionVisuallyLinearByValue } from '../utils/sliderFunctionVisuallyLinearByValue';\r\nimport { sliderFunctionVisuallySameStepSize } from '../utils/sliderFunctionVisuallySameStepSize';\r\n\r\nimport { HintLeftWrapper, HintRightWrapper, HintsWrapper, RcSliderGlobal, SliderWrapper, Wrapper } from './Slider.style';\r\n\r\nexport interface SliderProps extends DesignSystemBaseProps {\r\n\tariaLabelForHandle?: string;\r\n\tariaLabelledByForHandle?: string;\r\n\tariaValueTextFormatter?: SliderAriaValueTextFormatter;\r\n\t/** The maximum value that the slider can be moved to. Even if the visible range allows higher values, the thumb cannot go above this limit. */\r\n\tclampMax?: number;\r\n\t/** The minimum value that the slider can be moved to. Even if the visible range allows lower values, the thumb cannot go below this limit. */\r\n\tclampMin?: number;\r\n\tdisable?: boolean | undefined;\r\n\tmax: number;\r\n\tmin: number;\r\n\tminMaxLabels: SliderMinMaxLabels | undefined;\r\n\tonBlur?: FocusEventHandler<HTMLDivElement>;\r\n\t/** it is triggered during movement */\r\n\tonChange: (value: number) => void;\r\n\t/** it is triggered after the user drops the handle */\r\n\tonFinalChange: (value: number) => void;\r\n\tsteps: SliderSteps;\r\n\tstepType: SliderStepType;\r\n\tvalue: number;\r\n}\r\n\r\nexport const Slider = (props: SliderProps) => {\r\n\tconst {\r\n\t\tariaLabelForHandle,\r\n\t\tariaLabelledByForHandle,\r\n\t\tariaValueTextFormatter,\r\n\t\tclampMax,\r\n\t\tclampMin,\r\n\t\tdisable = false,\r\n\t\tmax,\r\n\t\tmin,\r\n\t\tminMaxLabels,\r\n\t\tonBlur,\r\n\t\tonChange,\r\n\t\tonFinalChange,\r\n\t\tsteps: stepsProp,\r\n\t\tstepType,\r\n\t\tvalue,\r\n\t} = props;\r\n\r\n\tconst effectiveMin = clampMin === undefined ? min : Math.max(clampMin, min);\r\n\tconst effectiveMax = clampMax === undefined ? max : Math.min(clampMax, max);\r\n\r\n\tconst steps = useMemo(() => clampSliderSteps(stepsProp, min, max), [stepsProp, min, max]);\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor } = useDesignSystem(props);\r\n\r\n\tconst sliderWrapperRef = useRef<HTMLDivElement>(null);\r\n\r\n\t// Utilities for temporarily disabling text selection during interactions (during dragging a slider).\r\n\t// When activated, it saves the original user-select value and sets it to 'none' to prevent text highlighting during drag operations.\r\n\t// After the interaction ends, it restores the original value.\r\n\tconst bodyStyleUserSelectRef = useRef<string | null>(null);\r\n\tconst disableTextSelection = useCallback(() => {\r\n\t\tbodyStyleUserSelectRef.current = document.body.style.userSelect;\r\n\t\tdocument.body.style.userSelect = 'none';\r\n\t}, []);\r\n\tconst enableTextSelection = useCallback(() => {\r\n\t\tif (bodyStyleUserSelectRef.current !== null) {\r\n\t\t\tdocument.body.style.userSelect = bodyStyleUserSelectRef.current;\r\n\t\t}\r\n\t}, []);\r\n\r\n\tconst { setFalse: unsetFocused, setTrue: setFocused, value: focused } = useBoolean(false);\r\n\r\n\tconst handleFocus = useCallback(() => {\r\n\t\tdisableTextSelection();\r\n\t\tsetFocused();\r\n\t}, [setFocused, disableTextSelection]);\r\n\tconst handleBlur = useCallback<FocusEventHandler<HTMLDivElement>>(\r\n\t\t(event) => {\r\n\t\t\tenableTextSelection();\r\n\t\t\tunsetFocused();\r\n\t\t\tonBlur?.(event);\r\n\t\t},\r\n\t\t[enableTextSelection, onBlur, unsetFocused],\r\n\t);\r\n\r\n\tconst prefersHighContrast = useMediaQuery('(prefers-contrast: more)');\r\n\r\n\t// function for mapping values to slider values (if he wants to use non-linearity)\r\n\tconst mapOurValueToRcSliderValue = useMemo<SliderMapFunction>(() => {\r\n\t\tswitch (stepType) {\r\n\t\t\tcase SliderStepType.visuallyLinearByValue:\r\n\t\t\t\treturn sliderFunctionVisuallyLinearByValue;\r\n\t\t\tcase SliderStepType.visuallySameStepSize:\r\n\t\t\t\treturn sliderFunctionVisuallySameStepSize;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected SliderStepType in Slider mapOurValueToRcSliderValue');\r\n\t\t}\r\n\t}, [stepType]);\r\n\r\n\tconst {\r\n\t\tsliderMax,\r\n\t\tsliderMin,\r\n\t\tsliderStep,\r\n\t\tsliderValue: rcSliderValue,\r\n\t} = mapOurValueToRcSliderValue({\r\n\t\tmin: min,\r\n\t\tmax: max,\r\n\t\tvalue: value,\r\n\t\tsteps: steps,\r\n\t});\r\n\r\n\t// rc-slider does not natively support changing aria-valuemax, aria-valuemin, and aria-valuenow, so we modify these attributes directly in the DOM.\r\n\t// This approach is not perfect because the values may be incorrect while the slider is moving. However, they update correctly once the user releases the slider.\r\n\t// This is used when the slider applies a custom mapping function that transforms its internal values into different displayed values.\r\n\tuseEffect(() => {\r\n\t\tif (stepType === SliderStepType.visuallyLinearByValue) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tif (sliderWrapperRef.current !== null) {\r\n\t\t\tconst handle = sliderWrapperRef.current.querySelector('.rc-slider-handle');\r\n\t\t\tif (handle) {\r\n\t\t\t\thandle.setAttribute('aria-valuemax', max.toString());\r\n\t\t\t\thandle.setAttribute('aria-valuemin', min.toString());\r\n\t\t\t\thandle.setAttribute('aria-valuenow', value.toString());\r\n\r\n\t\t\t\tconst ariaValueNowObserver = new MutationObserver((mutations) => {\r\n\t\t\t\t\tmutations.forEach((mutation) => {\r\n\t\t\t\t\t\tif (mutation.type === 'attributes' && mutation.attributeName === 'aria-valuenow') {\r\n\t\t\t\t\t\t\tconst current = handle.getAttribute('aria-valuenow');\r\n\t\t\t\t\t\t\tif (current !== value.toString()) {\r\n\t\t\t\t\t\t\t\thandle.setAttribute('aria-valuenow', value.toString());\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t});\r\n\t\t\t\t});\r\n\t\t\t\tariaValueNowObserver.observe(handle, {\r\n\t\t\t\t\tattributes: true,\r\n\t\t\t\t\tattributeFilter: ['aria-valuenow'],\r\n\t\t\t\t});\r\n\r\n\t\t\t\treturn () => {\r\n\t\t\t\t\tariaValueNowObserver.disconnect();\r\n\t\t\t\t};\r\n\t\t\t}\r\n\t\t}\r\n\t}, [max, min, stepType, value]);\r\n\r\n\t// basically inverse function to mapOurValueToRcSliderValue (used for onChange and onFinalChange if not undefined). Unlike mapOurValueToRcSliderValue, only value is remapped here (not the min step, max step, etc.).\r\n\tconst mapRcSliderValueToOurValue = useMemo<SliderMapOnChangeFunction>(() => {\r\n\t\tswitch (stepType) {\r\n\t\t\tcase SliderStepType.visuallyLinearByValue:\r\n\t\t\t\treturn (params) => params.sliderValue;\r\n\t\t\tcase SliderStepType.visuallySameStepSize:\r\n\t\t\t\treturn getValueBySliderValueVisuallySameStepSize;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected SliderStepType in Slider mapRcSliderValueToOurValue');\r\n\t\t}\r\n\t}, [stepType]);\r\n\r\n\tconst ariaValueTextFormatterForHandle = useMemo(() => {\r\n\t\tif (ariaValueTextFormatter === undefined) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\r\n\t\t// avoid using `value` from parameter of function – it may be outdated after clampMin/clampMax/value change\r\n\t\treturn () => {\r\n\t\t\treturn ariaValueTextFormatter.formatAsPrimitive(value, [], { clampMax: clampMax, clampMin: clampMin });\r\n\t\t};\r\n\t}, [ariaValueTextFormatter, clampMax, clampMin, value]);\r\n\r\n\tconst resolveOurValueFromChangeHandler = useCallback(\r\n\t\t(sliderValueParam: number[] | number): number | undefined => {\r\n\t\t\tif (typeof sliderValueParam !== 'number') {\r\n\t\t\t\tthrow new TypeError('unexpected type in onChange');\r\n\t\t\t}\r\n\t\t\tif (disable) {\r\n\t\t\t\treturn undefined;\r\n\t\t\t}\r\n\r\n\t\t\tconst mappedValue = mapRcSliderValueToOurValue({\r\n\t\t\t\tmin: min,\r\n\t\t\t\tmax: max,\r\n\t\t\t\tsteps: steps,\r\n\t\t\t\tsliderValue: sliderValueParam,\r\n\t\t\t});\r\n\r\n\t\t\tconst clampedValue = clamp(mappedValue, effectiveMin, effectiveMax);\r\n\r\n\t\t\treturn clampedValue;\r\n\t\t},\r\n\t\t[disable, mapRcSliderValueToOurValue, min, max, steps, effectiveMin, effectiveMax],\r\n\t);\r\n\r\n\tconst secondToLastValue = mapRcSliderValueToOurValue({\r\n\t\tsliderValue:\r\n\t\t\tmapOurValueToRcSliderValue({\r\n\t\t\t\tmin: min,\r\n\t\t\t\tmax: max,\r\n\t\t\t\tsteps: steps,\r\n\t\t\t\tvalue: max,\r\n\t\t\t}).sliderValue - 1,\r\n\t\tmin: min,\r\n\t\tmax: max,\r\n\t\tsteps: steps,\r\n\t});\r\n\r\n\t/**\r\n\t * \tRef to store the last changed value from `handleChange` callback.\r\n\t * \tEnsures consistency between `onChange` and `onFinalChange`, because `onChangeComplete` (from rc-slider) is\r\n\t * \tdelayed by about 150 ms compared to `onChange`. If the component is used in controlled mode with clampMin,\r\n\t * \tthe value might revert during that delay, causing onFinalChange to receive an outdated value.\r\n\t * \tBy storing the last value here, the correct value can be passed to `onFinalChange`.\r\n\t */\r\n\tconst lastChangedValue = useRef<number | null>(null);\r\n\r\n\tconst handleChange = useCallback(\r\n\t\t(sliderValueParam: number[] | number) => {\r\n\t\t\tconst newValue = resolveOurValueFromChangeHandler(sliderValueParam);\r\n\t\t\tlastChangedValue.current = newValue ?? null;\r\n\r\n\t\t\tif (newValue !== undefined) {\r\n\t\t\t\t// special handling in case clampedMin is greater than the second-to-last step on the slider\r\n\t\t\t\tif (newValue > secondToLastValue && newValue < max && value > secondToLastValue && value !== clampMin) {\r\n\t\t\t\t\treturn;\r\n\t\t\t\t}\r\n\r\n\t\t\t\tonChange(newValue);\r\n\t\t\t}\r\n\t\t},\r\n\t\t[resolveOurValueFromChangeHandler, secondToLastValue, max, value, clampMin, onChange],\r\n\t);\r\n\r\n\tconst handleChangeComplete = useCallback(\r\n\t\t(sliderValueParam: number[] | number) => {\r\n\t\t\tconst newValue = resolveOurValueFromChangeHandler(sliderValueParam);\r\n\t\t\tif (newValue !== undefined) {\r\n\t\t\t\t// special handling in case clampedMin is greater than the second-to-last step on the slider\r\n\t\t\t\tif (newValue === max) {\r\n\t\t\t\t\tonChange(newValue);\r\n\t\t\t\t}\r\n\r\n\t\t\t\tonFinalChange(lastChangedValue.current ?? newValue);\r\n\t\t\t\tlastChangedValue.current = null;\r\n\t\t\t}\r\n\t\t},\r\n\t\t[resolveOurValueFromChangeHandler, onFinalChange, max, onChange],\r\n\t);\r\n\r\n\tconst handleBackgroundSvgBase64 = useMemo(() => {\r\n\t\treturn getSliderHandleBackgroundSvgBase64(disable, theme);\r\n\t}, [disable, theme]);\r\n\r\n\treturn (\r\n\t\t<>\r\n\t\t\t<RcSliderGlobal />\r\n\t\t\t<Wrapper>\r\n\t\t\t\t<SliderWrapper ref={sliderWrapperRef}>\r\n\t\t\t\t\t<RcSlider\r\n\t\t\t\t\t\tariaLabelForHandle={ariaLabelForHandle}\r\n\t\t\t\t\t\tariaLabelledByForHandle={ariaLabelledByForHandle}\r\n\t\t\t\t\t\tariaValueTextFormatterForHandle={ariaValueTextFormatterForHandle}\r\n\t\t\t\t\t\tdisabled={disable}\r\n\t\t\t\t\t\tmax={sliderMax}\r\n\t\t\t\t\t\tmin={sliderMin}\r\n\t\t\t\t\t\tstep={sliderStep}\r\n\t\t\t\t\t\tstyles={{\r\n\t\t\t\t\t\t\ttrack: {\r\n\t\t\t\t\t\t\t\tbackground: disable\r\n\t\t\t\t\t\t\t\t\t? chooseColor(theme.colors.fg.disabled)\r\n\t\t\t\t\t\t\t\t\t: `linear-gradient(270deg, ${theme.palette.pink600} 10.24%, ${theme.palette.blue600} 100%)`,\r\n\t\t\t\t\t\t\t\theight: 4,\r\n\t\t\t\t\t\t\t\tborderRadius: theme.borderRadius.xs,\r\n\t\t\t\t\t\t\t\t/* using outline only for high contrast mode, because changing the background didn't work properly in this mode */\r\n\t\t\t\t\t\t\t\toutlineWidth: prefersHighContrast ? 2 : 0,\r\n\t\t\t\t\t\t\t\toutlineStyle: prefersHighContrast ? 'solid' : 'none',\r\n\t\t\t\t\t\t\t\toutlineColor: prefersHighContrast ? chooseColor(theme.colors.border.brand.bold) : 'currentColor',\r\n\t\t\t\t\t\t\t\toutlineOffset: 0,\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\trail: {\r\n\t\t\t\t\t\t\t\tbackgroundColor: disable ? chooseColor(theme.colors.bg.disabled) : chooseColor(theme.colors.bg.brand.semibold),\r\n\t\t\t\t\t\t\t\theight: 4,\r\n\t\t\t\t\t\t\t\tborderRadius: theme.borderRadius.xs,\r\n\t\t\t\t\t\t\t\t/* using outline only for high contrast mode, because changing the background didn't work properly in this mode */\r\n\t\t\t\t\t\t\t\toutlineWidth: prefersHighContrast ? 1 : 0,\r\n\t\t\t\t\t\t\t\toutlineStyle: prefersHighContrast ? 'solid' : 'none',\r\n\t\t\t\t\t\t\t\toutlineColor: prefersHighContrast ? chooseColor(theme.colors.border.brand.bold) : 'currentColor',\r\n\t\t\t\t\t\t\t\toutlineOffset: 0,\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\thandle: {\r\n\t\t\t\t\t\t\t\theight: 24,\r\n\t\t\t\t\t\t\t\twidth: 24,\r\n\t\t\t\t\t\t\t\tborder: 'none',\r\n\t\t\t\t\t\t\t\tbackgroundImage: `url(\"data:image/svg+xml;base64,${handleBackgroundSvgBase64}\")`,\r\n\t\t\t\t\t\t\t\topacity: 1,\r\n\t\t\t\t\t\t\t\tmarginTop: -9,\r\n\t\t\t\t\t\t\t\tboxShadow: 'none',\r\n\t\t\t\t\t\t\t\tcursor: disable ? 'default' : 'pointer',\r\n\t\t\t\t\t\t\t\toutlineWidth: focused ? 3 : 0,\r\n\t\t\t\t\t\t\t\toutlineStyle: focused ? 'solid' : 'none',\r\n\t\t\t\t\t\t\t\toutlineColor: focused ? chooseColor(theme.colors.border.brand.bold) : 'currentColor',\r\n\t\t\t\t\t\t\t\toutlineOffset: focused ? 3 : 0,\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t}}\r\n\t\t\t\t\t\tvalue={rcSliderValue}\r\n\t\t\t\t\t\tonBlur={handleBlur}\r\n\t\t\t\t\t\tonChange={handleChange}\r\n\t\t\t\t\t\tonChangeComplete={handleChangeComplete}\r\n\t\t\t\t\t\tonFocus={handleFocus}\r\n\t\t\t\t\t/>\r\n\t\t\t\t</SliderWrapper>\r\n\t\t\t\t{minMaxLabels !== undefined && (\r\n\t\t\t\t\t<HintsWrapper>\r\n\t\t\t\t\t\t<HintLeftWrapper>\r\n\t\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\t\tcolor={chooseColor(theme.colors.fg.neutral.subtle)}\r\n\t\t\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t{minMaxLabels.min}\r\n\t\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t\t</HintLeftWrapper>\r\n\t\t\t\t\t\t<HintRightWrapper>\r\n\t\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\t\tcolor={chooseColor(theme.colors.fg.neutral.subtle)}\r\n\t\t\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t{minMaxLabels.max}\r\n\t\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t\t</HintRightWrapper>\r\n\t\t\t\t\t</HintsWrapper>\r\n\t\t\t\t)}\r\n\t\t\t</Wrapper>\r\n\t\t</>\r\n\t);\r\n};\r\n","import { type Theme } from '@emotion/react';\r\nimport { encode as encodeBase64 } from 'base-64';\r\n\r\nimport { getSliderHandleBackgroundSvg } from './getSliderHandleBackgroundSvg';\r\n\r\nexport const getSliderHandleBackgroundSvgBase64 = (disable: boolean, theme: Theme) => {\r\n\treturn encodeBase64(getSliderHandleBackgroundSvg(disable, theme));\r\n};\r\n","import { type Theme } from '@emotion/react';\r\n\r\nexport const getSliderHandleBackgroundSvg = (disable: boolean, theme: Theme) => {\r\n\tif (disable) {\r\n\t\treturn `\r\n\t\t\t\t<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n\t\t\t\t\t<circle cx=\"12\" cy=\"12\" r=\"11\" stroke=\"${theme.colors.fg.disabled.light}\" stroke-width=\"2\"/>\r\n\t\t\t\t</svg>`;\r\n\t}\r\n\r\n\treturn `\r\n\t\t\t<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n\t\t\t\t<circle cx=\"12\" cy=\"12\" r=\"11\" stroke=\"url(#paint0_linear_1206_76209)\" stroke-width=\"2\" />\r\n\t\t\t\t<defs>\r\n\t\t\t\t\t<linearGradient id=\"paint0_linear_1206_76209\" x1=\"24\" y1=\"0\" x2=\"0\" y2=\"24\" gradientUnits=\"userSpaceOnUse\">\r\n\t\t\t\t\t\t<stop offset=\"0.0677083\" stop-color=\"${theme.palette.pink600}\"/>\r\n\t\t\t\t\t\t<stop offset=\"1\" stop-color=\"${theme.palette.blue600}\"/>\r\n\t\t\t\t\t</linearGradient>\r\n\t\t\t\t</defs>\r\n\t\t\t</svg>`;\r\n};\r\n","import { createMask } from 'imask';\r\n\r\nimport { getNumberMaskFactoryOpts } from '@/components/numberInputField/mask';\r\n\r\nconst mask = createMask(getNumberMaskFactoryOpts({}));\r\n\r\nexport const getSliderInputMaskedValue = (value: string): string => {\r\n\tmask.resolve(value);\r\n\r\n\treturn mask.value;\r\n};\r\n","import { createMask } from 'imask';\r\n\r\nimport { getNumberMaskFactoryOpts } from '@/components/numberInputField/mask';\r\n\r\nconst mask = createMask(getNumberMaskFactoryOpts({}));\r\n\r\nexport const getSliderInputUnmaskedValue = (value: string): string => {\r\n\tmask.resolve(value);\r\n\r\n\treturn mask.unmaskedValue;\r\n};\r\n","import { MediaType } from '@/types';\r\nimport { styled } from '@/utils';\r\n\r\ninterface WrapperProps {\r\n\t$isHintVisible: boolean;\r\n\t$isInputNoteVisible: boolean;\r\n\t$isInputVisible: boolean;\r\n\t$mediaType: MediaType;\r\n}\r\n\r\nexport const Wrapper = styled.div<WrapperProps>`\r\n\tdisplay: grid;\r\n\t/* stylelint-disable named-grid-areas-no-invalid */\r\n\tgrid-template-areas: ${({ $isHintVisible, $isInputNoteVisible, $isInputVisible, $mediaType }) => {\r\n\t\tswitch (true) {\r\n\t\t\tcase $mediaType === MediaType.mobile && !$isInputVisible:\r\n\t\t\t\treturn `\r\n\t\t\t\t\t'label'\r\n\t\t\t\t\t${$isHintVisible ? \"'hint'\" : ''}\r\n\t\t\t\t\t'slider'\r\n\t\t\t\t`;\r\n\t\t\tcase $mediaType === MediaType.mobile && $isInputVisible:\r\n\t\t\t\treturn `\r\n\t\t\t\t\t'label input'\r\n\t\t\t\t\t${$isInputNoteVisible ? \"'inputNote inputNote'\" : ''}\r\n\t\t\t\t\t${$isHintVisible ? \"'hint hint'\" : ''}\r\n\t\t\t\t\t'slider slider'\r\n\t\t\t\t`;\r\n\t\t\tcase $mediaType === MediaType.desktop && !$isInputVisible:\r\n\t\t\t\treturn `\r\n\t\t\t\t\t'label'\r\n\t\t\t\t\t${$isHintVisible ? \"'hint'\" : ''}\r\n\t\t\t\t\t'slider'\r\n\t\t\t\t`;\r\n\t\t\tcase $mediaType === MediaType.desktop && $isInputVisible:\r\n\t\t\t\treturn `\r\n\t\t\t\t\t'label label'\r\n\t\t\t\t\t${$isHintVisible ? \"'hint hint'\" : ''}\r\n\t\t\t\t\t'slider input'\r\n\t\t\t\t\t${$isInputNoteVisible ? \"'inputNote inputNote'\" : ''}\r\n\t\t\t\t`;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected MediaType in sliderInput.style.ts Wrapper grid-template-areas');\r\n\t\t}\r\n\t}};\r\n\t/* stylelint-enable named-grid-areas-no-invalid */\r\n\tgrid-template-columns: ${({ $isInputVisible }) => ($isInputVisible ? '1fr 9.375rem' : '1fr')};\r\n\trow-gap: ${({ $isInputVisible, theme }) => ($isInputVisible ? theme.spacing.md : 0)};\r\n\tcolumn-gap: ${({ $isInputVisible, theme }) => ($isInputVisible ? theme.spacing.md : 0)};\r\n`;\r\n\r\nexport const LabelWrapper = styled.div`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\tgrid-area: label;\r\n\trow-gap: ${({ theme }) => theme.spacing.xxs};\r\n\talign-items: start;\r\n\tjustify-content: center;\r\n`;\r\n\r\nexport const HintWrapper = styled.div`\r\n\tdisplay: flex;\r\n\tgrid-area: hint;\r\n\tmargin-top: -${({ theme }) => theme.spacing.sm};\r\n`;\r\n\r\ninterface InputWrapperProps {\r\n\t$isInputHidden: boolean;\r\n}\r\n\r\nexport const InputWrapper = styled.div<InputWrapperProps>`\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\tgrid-area: input;\r\n\tjustify-content: flex-end;\r\n\twidth: ${({ $isInputHidden }) => ($isInputHidden ? '0' : 'initial')};\r\n\theight: ${({ $isInputHidden }) => ($isInputHidden ? '0' : 'initial')};\r\n\toverflow: ${({ $isInputHidden }) => ($isInputHidden ? 'hidden' : 'initial')};\r\n`;\r\n\r\ninterface InputNoteWrapperProps {\r\n\t$mediaType: MediaType;\r\n}\r\n\r\nexport const InputNoteWrapper = styled.div<InputNoteWrapperProps>`\r\n\tgrid-area: inputNote;\r\n\r\n\ttext-align: right;\r\n`;\r\n\r\nexport const SliderWrapper = styled.div`\r\n\tdisplay: flex;\r\n\tgrid-area: slider;\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { useMergeRefs } from '@floating-ui/react';\r\nimport {\r\n\ttype FocusEvent,\r\n\ttype FocusEventHandler,\r\n\tforwardRef,\r\n\ttype KeyboardEventHandler,\r\n\ttype ReactElement,\r\n\ttype ReactNode,\r\n\ttype RefAttributes,\r\n\tuseCallback,\r\n\tuseEffect,\r\n\tuseMemo,\r\n\tuseRef,\r\n\tuseState,\r\n} from 'react';\r\n\r\nimport { InputLabel } from '@/components/inputLabel';\r\nimport { InputLabelSize } from '@/components/inputLabel/types';\r\nimport { type MaskedInputOnAccept } from '@/components/maskedInputField/types';\r\nimport { NumberInput } from '@/components/numberInputField';\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { VisuallyHidden } from '@/components/visuallyHidden';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { useUniqueIdIfIsUndefined } from '@/hooks/useUniqueIdIfIsUndefined';\r\nimport { FontWeight } from '@/theme';\r\nimport { type InputLabelPassthroughProps, InputSize, InputTextAlign } from '@/types';\r\n\r\nimport { Slider } from '../slider/Slider';\r\nimport {\r\n\ttype SliderAriaValueTextFormatter,\r\n\ttype SliderInputLimitExceededLiveTextFormatter,\r\n\tSliderInputRoundingType,\r\n\ttype SliderMinMaxLabels,\r\n\ttype SliderSteps,\r\n\ttype SliderStepType,\r\n} from '../types';\r\nimport { clampSliderSteps } from '../utils/clampSliderSteps';\r\nimport { getRoundedValueBySteps } from '../utils/getRoundedValueBySteps';\r\nimport { getSliderInputMaskedValue } from '../utils/getSliderInputMaskedValue';\r\nimport { getSliderInputUnmaskedValue } from '../utils/getSliderInputUnmaskedValue';\r\n\r\nimport { HintWrapper, InputNoteWrapper, InputWrapper, LabelWrapper, SliderWrapper, Wrapper } from './SliderInput.style';\r\n\r\nexport interface SliderInputProps extends RefAttributes<HTMLInputElement>, DesignSystemBaseProps, InputLabelPassthroughProps {\r\n\tariaLabelForHandle?: string;\r\n\tariaLabelledByForHandle?: string;\r\n\tariaValueTextFormatter?: SliderAriaValueTextFormatter;\r\n\t/** The maximum value that the slider can be moved to. Even if the visible range allows higher values, the thumb cannot go above this limit. */\r\n\tclampMax?: number;\r\n\t/** The minimum value that the slider can be moved to. Even if the visible range allows lower values, the thumb cannot go below this limit. */\r\n\tclampMin?: number;\r\n\tcolorInput?: string;\r\n\tdisabled?: boolean;\r\n\thintText?: ReactElement | string;\r\n\tid?: string;\r\n\tinputLimitExceededLiveTextFormatter?: SliderInputLimitExceededLiveTextFormatter;\r\n\tinputNote?: ReactElement | string;\r\n\tinputRoundingType?: SliderInputRoundingType;\r\n\tinvalid?: boolean;\r\n\tisInputHidden?: boolean;\r\n\tmax: number;\r\n\tmin: number;\r\n\tminMaxLabels?: SliderMinMaxLabels;\r\n\tname: string;\r\n\t/**\r\n\t * Callback triggered when either the input field or the slider thumb loses focus.\r\n\t */\r\n\tonBlur?: () => void;\r\n\t/**\r\n\t * Callback triggered after the value is finalized, either by completing slider movement or by finalizing input (onBlur or Enter).\r\n\t */\r\n\tonChange?: (value: number) => void;\r\n\t/**\r\n\t * Callback triggered on every change in the input field, before the user blurs the field or presses Enter.\r\n\t * It is also called after completing slider movement or finalizing input (on Enter orBlur),\r\n\t * if the value needs to be adjusted (e.g., clamped to max if it exceeds the allowed maximum).\r\n\t */\r\n\tonInputChange?: (value: string) => void;\r\n\t/**\r\n\t * Callback triggered on every slider value change during movement (e.g., while dragging the thumb).\r\n\t * Also called when the value is finalized via input (onBlur or Enter).\r\n\t * Useful when another slider or component should react immediately to this slider’s changes.\r\n\t */\r\n\tonSliderChange?: (value: number) => void;\r\n\tprefix?: ReactNode;\r\n\tsteps: SliderSteps;\r\n\tstepType: SliderStepType;\r\n\tsuffix?: ReactNode;\r\n\tvalue: number;\r\n\tweight?: FontWeight;\r\n}\r\n\r\n/**\r\n * The `SliderInput` component triggers the `onChange` callback only after the user either:\r\n * 1. Presses Enter while the input field is focused, or\r\n * 2. The input field or the slider handle loses focus (onBlur).\r\n *\r\n * This behavior is intentional and aligns with use cases such as calculators, where the value is finalized\r\n * only after the user explicitly confirms their input. This ensures the input is validated and adjusted\r\n * appropriately before the change is committed. The value is not updated during slider movement to avoid\r\n * immediate side effects while the user is adjusting the value.\r\n *\r\n * For more immediate feedback during slider movement or input changes, you can use the `onSliderChange`\r\n * and `onInputChange` callbacks. These callbacks are triggered on every change during slider movement\r\n * or while typing in the input field, before the user finalizes their selection with Enter or onBlur.\r\n */\r\nexport const SliderInput = forwardRef<HTMLInputElement, SliderInputProps>((props, ref) => {\r\n\tconst {\r\n\t\tariaLabelForHandle,\r\n\t\tariaLabelledByForHandle,\r\n\t\tariaValueTextFormatter,\r\n\t\tclampMax,\r\n\t\tclampMin,\r\n\t\tcolorInput,\r\n\t\tdisabled,\r\n\t\thintText,\r\n\t\tid: idProp,\r\n\t\tinputLimitExceededLiveTextFormatter,\r\n\t\tinputNote,\r\n\t\tinputRoundingType,\r\n\t\tinvalid = false,\r\n\t\tisInputHidden = false,\r\n\t\tlabel,\r\n\t\tlabelAs,\r\n\t\tlabelHiddenText,\r\n\t\tlabelId: labelIdProp,\r\n\t\tlabelSuffix,\r\n\t\tmax,\r\n\t\tmin,\r\n\t\tminMaxLabels,\r\n\t\tname,\r\n\t\tonBlur,\r\n\t\tonChange,\r\n\t\tonInputChange,\r\n\t\tonSliderChange,\r\n\t\tprefix,\r\n\t\tsteps: stepsProp,\r\n\t\tstepType,\r\n\t\tsuffix,\r\n\t\ttooltip,\r\n\t\tvalue,\r\n\t\tweight,\r\n\t} = props;\r\n\r\n\tconst effectiveMin = clampMin === undefined ? min : Math.max(clampMin, min);\r\n\tconst effectiveMax = clampMax === undefined ? max : Math.min(clampMax, max);\r\n\r\n\tconst steps = useMemo(() => clampSliderSteps(stepsProp, min, max), [stepsProp, min, max]);\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor, colorScheme, mediaType } = useDesignSystem(props);\r\n\r\n\tconst id = useUniqueIdIfIsUndefined(idProp);\r\n\tconst labelId = useUniqueIdIfIsUndefined(labelIdProp);\r\n\r\n\tconst [localSliderValue, setLocalSliderValue] = useState<number>(value);\r\n\r\n\tconst localInputRef = useRef<HTMLInputElement>(null);\r\n\tconst mergedInputRef = useMergeRefs([ref, localInputRef]);\r\n\r\n\tconst [ariaLiveText, setAriaLiveText] = useState<string | undefined>(undefined);\r\n\r\n\tconst changeInputValue = useCallback((valueParam: number) => {\r\n\t\tif (localInputRef.current?.value !== undefined) {\r\n\t\t\t// inspired by https://stackoverflow.com/questions/23892547/what-is-the-best-way-to-trigger-change-or-input-event-in-react-js#answer-46012210\r\n\t\t\tconst nativeInputValueSetter = Object.getOwnPropertyDescriptor(window.HTMLInputElement.prototype, 'value')?.set;\r\n\t\t\tif (nativeInputValueSetter === undefined) {\r\n\t\t\t\tconsole.error('Failed to retrieve the native value setter for HTMLInputElement. The input value cannot be programmatically updated.');\r\n\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t\tnativeInputValueSetter.call(localInputRef.current, getSliderInputMaskedValue(valueParam.toString()));\r\n\t\t}\r\n\t}, []);\r\n\r\n\t// change localSliderValue if value (from props) changed\r\n\tuseEffect(() => {\r\n\t\tsetLocalSliderValue(value);\r\n\t}, [value]);\r\n\r\n\t// change input value if localSliderValue changed\r\n\tuseEffect(() => {\r\n\t\tchangeInputValue(localSliderValue);\r\n\t}, [changeInputValue, localSliderValue]);\r\n\r\n\tconst handleSliderChange = useCallback(\r\n\t\t(valueParam: number) => {\r\n\t\t\tonSliderChange?.(valueParam);\r\n\t\t\tsetLocalSliderValue(valueParam);\r\n\t\t},\r\n\t\t[onSliderChange],\r\n\t);\r\n\r\n\tconst handleSliderFinalChange = useCallback(\r\n\t\t(valueParam: number) => {\r\n\t\t\tonChange?.(valueParam);\r\n\t\t\tonInputChange?.(valueParam.toString());\r\n\t\t\t// Note: No need to call setLocalSliderValue here, because `handleSliderChange` is always triggered as well, which already updates the local slider value.\r\n\t\t},\r\n\t\t[onInputChange, onChange],\r\n\t);\r\n\r\n\tconst handleLimitExceeded = useCallback(\r\n\t\t(oldValue: number, newValue: number) => {\r\n\t\t\tif (inputLimitExceededLiveTextFormatter === undefined) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\r\n\t\t\tconst limitExceededText = inputLimitExceededLiveTextFormatter.formatAsPrimitive(newValue, [], {\r\n\t\t\t\tmin: min,\r\n\t\t\t\tmax: max,\r\n\t\t\t\toldValue: oldValue,\r\n\t\t\t\teffectiveMin: effectiveMin,\r\n\t\t\t\teffectiveMax: effectiveMax,\r\n\t\t\t\tclampMax: clampMax,\r\n\t\t\t\tclampMin: clampMin,\r\n\t\t\t});\r\n\r\n\t\t\tsetAriaLiveText(limitExceededText);\r\n\t\t},\r\n\t\t[clampMax, clampMin, effectiveMax, effectiveMin, inputLimitExceededLiveTextFormatter, max, min],\r\n\t);\r\n\r\n\t/**\r\n\t * Handles user input from the input field, validates it, clamps it within the allowed range,\r\n\t * optionally rounds it according to the configured rounding type, updates the slider value,\r\n\t * and notifies any listeners via onChange callbacks.\r\n\t *\r\n\t * This function is typically triggered when the user finishes editing the input (e.g., on blur, press Enter).\r\n\t */\r\n\tconst commitInputChange = useCallback(\r\n\t\t(value: string): number => {\r\n\t\t\tconst numberValue = Number.parseInt(getSliderInputUnmaskedValue(value));\r\n\r\n\t\t\tlet newValue: number;\r\n\t\t\tswitch (true) {\r\n\t\t\t\tcase Number.isNaN(numberValue):\r\n\t\t\t\t\tnewValue = effectiveMin;\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase numberValue < effectiveMin:\r\n\t\t\t\t\tnewValue = effectiveMin;\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase numberValue > effectiveMax:\r\n\t\t\t\t\tnewValue = effectiveMax;\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tdefault:\r\n\t\t\t\t\tnewValue = numberValue;\r\n\t\t\t}\r\n\r\n\t\t\tlet roundedNewValue = newValue;\r\n\t\t\tswitch (true) {\r\n\t\t\t\tcase inputRoundingType === undefined:\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase inputRoundingType === SliderInputRoundingType.ceilBySteps:\r\n\t\t\t\tcase inputRoundingType === SliderInputRoundingType.floorBySteps:\r\n\t\t\t\tcase inputRoundingType === SliderInputRoundingType.roundBySteps:\r\n\t\t\t\t\troundedNewValue = getRoundedValueBySteps({\r\n\t\t\t\t\t\tsteps: steps,\r\n\t\t\t\t\t\tvalue: newValue,\r\n\t\t\t\t\t\troundingType: inputRoundingType,\r\n\t\t\t\t\t\tmin: effectiveMin,\r\n\t\t\t\t\t\tmax: effectiveMax,\r\n\t\t\t\t\t});\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase inputRoundingType === SliderInputRoundingType.ceilToThousands:\r\n\t\t\t\t\troundedNewValue = Math.ceil(newValue / 1000) * 1000;\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase inputRoundingType === SliderInputRoundingType.floorToThousands:\r\n\t\t\t\t\troundedNewValue = Math.floor(newValue / 1000) * 1000;\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase inputRoundingType === SliderInputRoundingType.roundToThousands:\r\n\t\t\t\t\troundedNewValue = Math.round(newValue / 1000) * 1000;\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tdefault:\r\n\t\t\t\t\tthrow new Error('unexpected SliderInputRoundingType enum value in sliderInput.tsx handleInputBlur');\r\n\t\t\t}\r\n\r\n\t\t\tsetLocalSliderValue(roundedNewValue);\r\n\r\n\t\t\tonChange?.(roundedNewValue);\r\n\t\t\tonSliderChange?.(roundedNewValue);\r\n\t\t\tif (roundedNewValue !== numberValue) {\r\n\t\t\t\thandleLimitExceeded(numberValue, roundedNewValue);\r\n\t\t\t\tchangeInputValue(roundedNewValue);\r\n\t\t\t\tonInputChange?.(roundedNewValue.toString());\r\n\t\t\t}\r\n\r\n\t\t\treturn roundedNewValue;\r\n\t\t},\r\n\t\t[changeInputValue, onInputChange, effectiveMax, effectiveMin, inputRoundingType, onChange, onSliderChange, steps, handleLimitExceeded],\r\n\t);\r\n\r\n\tconst handleInputBlur = useCallback(\r\n\t\t(event: FocusEvent<HTMLInputElement>) => {\r\n\t\t\tconst eventValue = event.target.value;\r\n\t\t\tcommitInputChange(eventValue);\r\n\r\n\t\t\tonBlur?.();\r\n\t\t},\r\n\t\t[commitInputChange, onBlur],\r\n\t);\r\n\r\n\tconst handleSliderBlur = useCallback<FocusEventHandler<HTMLDivElement>>(() => {\r\n\t\tonChange?.(localSliderValue);\r\n\t\tonBlur?.();\r\n\t}, [onBlur, onChange, localSliderValue]);\r\n\r\n\tconst handleInputAccept = useCallback<MaskedInputOnAccept>(\r\n\t\t(unmaskedValue: string) => {\r\n\t\t\tonInputChange?.(unmaskedValue);\r\n\t\t},\r\n\t\t[onInputChange],\r\n\t);\r\n\r\n\tconst handleKeyDown = useCallback<KeyboardEventHandler<HTMLInputElement>>(\r\n\t\t(event) => {\r\n\t\t\tif (event.key === 'Enter') {\r\n\t\t\t\tcommitInputChange(event.currentTarget.value);\r\n\t\t\t}\r\n\t\t},\r\n\t\t[commitInputChange],\r\n\t);\r\n\r\n\t/**\r\n\t * Resetting the aria-live text to undefined so that screen readers will announce the next update even if the message is the same.\r\n\t * Without this reset, identical consecutive messages would be ignored.\r\n\t */\r\n\tconst handleInputFocus = useCallback(() => {\r\n\t\tsetAriaLiveText(undefined);\r\n\t}, []);\r\n\r\n\treturn (\r\n\t\t<Wrapper\r\n\t\t\t$isHintVisible={hintText !== undefined}\r\n\t\t\t$isInputNoteVisible={inputNote !== undefined}\r\n\t\t\t$isInputVisible={!isInputHidden}\r\n\t\t\t$mediaType={mediaType}\r\n\t\t>\r\n\t\t\t<VisuallyHidden aria-live={'polite'}>{ariaLiveText}</VisuallyHidden>\r\n\r\n\t\t\t<LabelWrapper>\r\n\t\t\t\t<InputLabel\r\n\t\t\t\t\tas={labelAs}\r\n\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\thiddenText={labelHiddenText}\r\n\t\t\t\t\tid={id}\r\n\t\t\t\t\tinvalid={invalid}\r\n\t\t\t\t\tlabel={label}\r\n\t\t\t\t\tlabelId={labelId}\r\n\t\t\t\t\tsize={InputLabelSize.md}\r\n\t\t\t\t\tsuffix={labelSuffix}\r\n\t\t\t\t\ttooltip={tooltip}\r\n\t\t\t\t/>\r\n\t\t\t</LabelWrapper>\r\n\r\n\t\t\t{hintText !== undefined && (\r\n\t\t\t\t<HintWrapper>\r\n\t\t\t\t\t<Typography\r\n\t\t\t\t\t\tcolor={chooseColor(theme.colors.fg.neutral.subtle)}\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t{hintText}\r\n\t\t\t\t\t</Typography>\r\n\t\t\t\t</HintWrapper>\r\n\t\t\t)}\r\n\r\n\t\t\t<InputWrapper $isInputHidden={isInputHidden}>\r\n\t\t\t\t<NumberInput\r\n\t\t\t\t\taria-labelledby={labelId}\r\n\t\t\t\t\tcolorInput={colorInput ?? chooseColor(theme.colors.fg.neutral.default)}\r\n\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\tdisabled={disabled}\r\n\t\t\t\t\tid={id}\r\n\t\t\t\t\tinvalid={invalid}\r\n\t\t\t\t\tname={name}\r\n\t\t\t\t\tprefix={prefix}\r\n\t\t\t\t\tref={mergedInputRef}\r\n\t\t\t\t\tsize={InputSize.md}\r\n\t\t\t\t\tsuffix={suffix}\r\n\t\t\t\t\ttextAlign={InputTextAlign.right}\r\n\t\t\t\t\tweight={weight}\r\n\t\t\t\t\tonAccept={handleInputAccept}\r\n\t\t\t\t\tonBlur={handleInputBlur}\r\n\t\t\t\t\tonFocus={handleInputFocus}\r\n\t\t\t\t\tonKeyDown={handleKeyDown}\r\n\t\t\t\t/>\r\n\t\t\t</InputWrapper>\r\n\t\t\t{inputNote !== undefined && !isInputHidden && (\r\n\t\t\t\t<InputNoteWrapper $mediaType={mediaType}>\r\n\t\t\t\t\t<Typography\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\tvariant={TypographyVariant.textMd}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t{inputNote}\r\n\t\t\t\t\t</Typography>\r\n\t\t\t\t</InputNoteWrapper>\r\n\t\t\t)}\r\n\t\t\t<SliderWrapper>\r\n\t\t\t\t<Slider\r\n\t\t\t\t\tariaLabelForHandle={ariaLabelForHandle}\r\n\t\t\t\t\tariaLabelledByForHandle={ariaLabelledByForHandle ?? labelId}\r\n\t\t\t\t\tariaValueTextFormatter={ariaValueTextFormatter}\r\n\t\t\t\t\tclampMax={clampMax}\r\n\t\t\t\t\tclampMin={clampMin}\r\n\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\tdisable={disabled}\r\n\t\t\t\t\tmax={max}\r\n\t\t\t\t\tmin={min}\r\n\t\t\t\t\tminMaxLabels={minMaxLabels}\r\n\t\t\t\t\tsteps={steps}\r\n\t\t\t\t\tstepType={stepType}\r\n\t\t\t\t\tvalue={localSliderValue}\r\n\t\t\t\t\tonBlur={handleSliderBlur}\r\n\t\t\t\t\tonChange={handleSliderChange}\r\n\t\t\t\t\tonFinalChange={handleSliderFinalChange}\r\n\t\t\t\t/>\r\n\t\t\t</SliderWrapper>\r\n\t\t</Wrapper>\r\n\t);\r\n});\r\n\r\nSliderInput.displayName = 'SliderInput';\r\n","import { type SliderBreakpoint, type SliderSteps } from '@/components/sliderInputField';\r\n\r\nimport { SliderInputRoundingType } from '../types';\r\n\r\nexport interface GetRoundedValueByStepsParam {\r\n\tmax: number;\r\n\tmin: number;\r\n\troundingType: SliderInputRoundingType;\r\n\tsteps: SliderSteps;\r\n\tvalue: number;\r\n}\r\n\r\nexport const getRoundedValueBySteps = (param: GetRoundedValueByStepsParam): number => {\r\n\tconst { max, min, roundingType, steps, value } = param;\r\n\r\n\tif (\r\n\t\troundingType !== SliderInputRoundingType.ceilBySteps &&\r\n\t\troundingType !== SliderInputRoundingType.floorBySteps &&\r\n\t\troundingType !== SliderInputRoundingType.roundBySteps\r\n\t) {\r\n\t\tthrow new Error('unexpected enum SliderInputRoundingType value in getRoundedValueBySteps');\r\n\t}\r\n\r\n\tif (value <= min) {\r\n\t\treturn min;\r\n\t}\r\n\tif (value >= max) {\r\n\t\treturn max;\r\n\t}\r\n\r\n\tconst breakpointList: SliderBreakpoint[] = [{ step: steps.baseStep, bottomBreakpoint: min }, ...steps.breakpointList];\r\n\r\n\t// all possible values\r\n\tconst items = breakpointList.reduce<number[]>(\r\n\t\t(accumulator, currentBreakpoint, currentIndex, array) => {\r\n\t\t\tconst nextBreakpoint: SliderBreakpoint | undefined = array[currentIndex + 1];\r\n\r\n\t\t\t// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\r\n\t\t\tconst nextMax = nextBreakpoint === undefined ? max : nextBreakpoint.bottomBreakpoint;\r\n\r\n\t\t\tconst steps: number[] = [];\r\n\t\t\tfor (let step = currentBreakpoint.bottomBreakpoint + currentBreakpoint.step; step < nextMax; step = step + currentBreakpoint.step) {\r\n\t\t\t\tsteps.push(step);\r\n\t\t\t}\r\n\r\n\t\t\treturn [...accumulator, ...steps, nextMax];\r\n\t\t},\r\n\t\t[min],\r\n\t);\r\n\r\n\tconst boundary = items.reduce<{ lowerBoundary: number; upperBoundary: number } | undefined>((accumulator, currentItem, currentIndex, array) => {\r\n\t\tif (accumulator !== undefined) {\r\n\t\t\treturn accumulator;\r\n\t\t}\r\n\r\n\t\tconst nextItem: number | undefined = array[currentIndex + 1];\r\n\r\n\t\tif (value > currentItem && value <= nextItem) {\r\n\t\t\treturn {\r\n\t\t\t\tlowerBoundary: currentItem,\r\n\t\t\t\tupperBoundary: nextItem,\r\n\t\t\t};\r\n\t\t}\r\n\r\n\t\treturn undefined;\r\n\t}, undefined);\r\n\r\n\tif (boundary === undefined) {\r\n\t\tthrow new Error('unexpected Error stepsRoundValue.ts');\r\n\t}\r\n\r\n\tif (value === boundary.lowerBoundary) {\r\n\t\treturn boundary.lowerBoundary;\r\n\t}\r\n\tif (value === boundary.upperBoundary) {\r\n\t\treturn boundary.upperBoundary;\r\n\t}\r\n\r\n\tif (roundingType === SliderInputRoundingType.floorBySteps) {\r\n\t\treturn boundary.lowerBoundary;\r\n\t}\r\n\tif (roundingType === SliderInputRoundingType.ceilBySteps) {\r\n\t\treturn boundary.upperBoundary;\r\n\t}\r\n\r\n\treturn value - boundary.lowerBoundary < (boundary.upperBoundary - boundary.lowerBoundary) / 2 ? boundary.lowerBoundary : boundary.upperBoundary;\r\n};\r\n","export enum StepperVariant {\r\n\thorizontal = 'horizontal',\r\n\tvertical = 'vertical',\r\n}\r\n","import { css } from '@emotion/react';\r\n\r\nimport { styled } from '@/utils';\r\n\r\nimport { StepperVariant } from '../types';\r\n\r\nexport const TextWrapper = styled.div`\r\n\tmargin-right: ${({ theme }) => theme.spacing.xs};\r\n\ttext-align: center;\r\n`;\r\n\r\ninterface WrapperProps {\r\n\t$variant: StepperVariant;\r\n}\r\n\r\nexport const Wrapper = styled.div<WrapperProps>`\r\n\tdisplay: flex;\r\n\tflex: 1;\r\n\tflex-shrink: 0;\r\n\tflex-direction: ${({ $variant }) => ($variant === StepperVariant.horizontal ? 'column' : 'row')};\r\n\tgap: ${({ theme }) => theme.spacing.xs};\r\n\talign-items: center;\r\n\tjustify-content: flex-start;\r\n\r\n\t@media (min-width: ${({ theme }) => theme.breakpoints.sm}) {\r\n\t\tflex: initial;\r\n\t\tflex-direction: row;\r\n\t\talign-items: center;\r\n\t\tjustify-content: flex-start;\r\n\r\n\t\t&:not(:last-child) {\r\n\t\t\tflex: 1;\r\n\t\t}\r\n\r\n\t\t&:not(:last-child)::after {\r\n\t\t\tflex: 1;\r\n\t\t\theight: 1px;\r\n\t\t\tcontent: '';\r\n\t\t\tbackground-color: ${({ theme }) => theme.colors.bg.neutral.default.light};\r\n\t\t}\r\n\t}\r\n`;\r\n\r\ninterface ClickableProps {\r\n\t$disabled: boolean;\r\n\t$variant: StepperVariant;\r\n}\r\n\r\nexport const Clickable = styled.div<ClickableProps>`\r\n\tdisplay: flex;\r\n\tflex: 1;\r\n\tflex-shrink: 0;\r\n\tflex-direction: ${({ $variant }) => ($variant === StepperVariant.horizontal ? 'column' : 'row')};\r\n\tgap: ${({ theme }) => theme.spacing.xs};\r\n\talign-items: center;\r\n\tjustify-content: flex-start;\r\n\tcursor: pointer;\r\n\r\n\t@media (min-width: ${({ theme }) => theme.breakpoints.sm}) {\r\n\t\tflex: initial;\r\n\t\tflex-direction: row;\r\n\t\talign-items: center;\r\n\t\tjustify-content: flex-start;\r\n\t}\r\n\r\n\t${({ $disabled }) =>\r\n\t\t$disabled === true &&\r\n\t\tcss`\r\n\t\t\tcursor: initial;\r\n\t\t`}\r\n`;\r\n\r\ninterface StepCircleProps {\r\n\t$isActive: boolean;\r\n\t$isCompleted: boolean;\r\n}\r\n\r\nexport const StepCircle = styled.div<StepCircleProps>`\r\n\tdisplay: flex;\r\n\tflex-shrink: 0;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\twidth: ${({ theme }) => theme.spacing.xl};\r\n\theight: ${({ theme }) => theme.spacing.xl};\r\n\tbackground-color: ${({ theme }) => theme.palette.grey100};\r\n\tborder: 1px solid ${({ theme }) => theme.palette.grey200};\r\n\tborder-radius: ${({ theme }) => theme.borderRadius.full};\r\n\r\n\t${({ $isActive, $isCompleted, theme }) =>\r\n\t\t($isActive === true || $isCompleted === true) &&\r\n\t\tcss`\r\n\t\t\tbackground-color: ${theme.colors.bg.brand.default.light};\r\n\t\t\tborder: 1px solid ${theme.palette.blue200};\r\n\t\t`}\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { type ReactNode } from 'react';\r\n\r\nimport { IconSystem, IconSystemSize, IconSystemType } from '@/components/iconSystem';\r\nimport { Typography, TypographyTextAlign, TypographyVariant } from '@/components/typography';\r\nimport { FontWeight } from '@/theme';\r\n\r\nimport { type StepperVariant } from '../types';\r\n\r\nimport { Clickable, StepCircle, TextWrapper, Wrapper } from './StepperItem.style';\r\n\r\nexport interface StepperItemProps {\r\n\tdisabled?: boolean;\r\n\tid: string;\r\n\tindex: number;\r\n\tisActive?: boolean;\r\n\tisCompleted?: boolean;\r\n\tonClick?: () => void;\r\n\ttext?: ReactNode | string;\r\n\tvariant: StepperVariant;\r\n}\r\n\r\nexport const StepperItem = (props: StepperItemProps) => {\r\n\tconst { disabled = false, index, isActive = false, isCompleted = false, onClick, text, variant } = props;\r\n\r\n\tconst theme = useTheme();\r\n\r\n\tconst indexColor = () => {\r\n\t\tif (disabled) {\r\n\t\t\treturn theme.colors.fg.disabled.light;\r\n\t\t}\r\n\t\tif (isActive) {\r\n\t\t\treturn theme.colors.fg.brand.bold.light;\r\n\t\t}\r\n\r\n\t\treturn theme.colors.fg.neutral.subtle.light;\r\n\t};\r\n\r\n\tconst textColor = () => {\r\n\t\tif (disabled) {\r\n\t\t\treturn theme.colors.fg.disabled.light;\r\n\t\t}\r\n\t\tif (isActive) {\r\n\t\t\treturn theme.colors.fg.neutral.default.light;\r\n\t\t}\r\n\r\n\t\treturn theme.colors.fg.neutral.subtle.light;\r\n\t};\r\n\r\n\treturn (\r\n\t\t<Wrapper $variant={variant}>\r\n\t\t\t<Clickable\r\n\t\t\t\t$disabled={disabled}\r\n\t\t\t\t$variant={variant}\r\n\t\t\t\tonClick={onClick}\r\n\t\t\t>\r\n\t\t\t\t<StepCircle\r\n\t\t\t\t\t$isActive={isActive}\r\n\t\t\t\t\t$isCompleted={isCompleted}\r\n\t\t\t\t>\r\n\t\t\t\t\t{isCompleted ? (\r\n\t\t\t\t\t\t<IconSystem\r\n\t\t\t\t\t\t\tsize={IconSystemSize.big}\r\n\t\t\t\t\t\t\tstroke={theme.colors.fg.brand.bold.light}\r\n\t\t\t\t\t\t\ttype={IconSystemType.checkmark}\r\n\t\t\t\t\t\t/>\r\n\t\t\t\t\t) : (\r\n\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\tcolor={indexColor()}\r\n\t\t\t\t\t\t\ttextAlign={TypographyTextAlign.center}\r\n\t\t\t\t\t\t\tvariant={TypographyVariant.textMd}\r\n\t\t\t\t\t\t\tweight={isActive ? FontWeight.medium500 : FontWeight.regular400}\r\n\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t{index}\r\n\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t)}\r\n\t\t\t\t</StepCircle>\r\n\r\n\t\t\t\t<TextWrapper>\r\n\t\t\t\t\t<Typography\r\n\t\t\t\t\t\tcolor={textColor()}\r\n\t\t\t\t\t\ttextAlign={TypographyTextAlign.center}\r\n\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\tweight={isActive ? FontWeight.semiBold600 : FontWeight.regular400}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t{text}\r\n\t\t\t\t\t</Typography>\r\n\t\t\t\t</TextWrapper>\r\n\t\t\t</Clickable>\r\n\t\t</Wrapper>\r\n\t);\r\n};\r\n","import { css } from '@emotion/react';\r\n\r\nimport { styled } from '@/utils';\r\n\r\nimport { StepperVariant } from './types';\r\n\r\ninterface WrapperProps {\r\n\t$variant: StepperVariant;\r\n}\r\n\r\nexport const Wrapper = styled.div<WrapperProps>`\r\n\tdisplay: flex;\r\n\tflex-direction: row;\r\n\tflex-wrap: nowrap;\r\n\tgap: ${({ theme }) => theme.spacing.md};\r\n\talign-items: flex-start;\r\n\tjustify-content: space-between;\r\n\twidth: 100%;\r\n\tpadding: ${({ theme }) => theme.spacing.md} ${({ theme }) => theme.spacing.xl};\r\n\tmargin: 0;\r\n\tborder-radius: ${({ theme }) => theme.borderRadius.xs};\r\n\tbox-shadow: ${({ theme }) => theme.colors.shadow.strongBlueMd};\r\n\r\n\t${({ $variant, theme }) =>\r\n\t\t$variant === StepperVariant.vertical &&\r\n\t\tcss`\r\n\t\t\tflex-direction: column;\r\n\t\t\twidth: fit-content;\r\n\t\t\tpadding: ${theme.spacing.lg} ${theme.spacing.md};\r\n\t\t`}\r\n\r\n\t@media (min-width: ${({ theme }) => theme.breakpoints.sm}) {\r\n\t\tgap: ${({ $variant, theme }) => ($variant === StepperVariant.vertical ? theme.spacing.xs : theme.spacing.md)};\r\n\t\tpadding: ${({ theme }) => theme.spacing.md};\r\n\r\n\t\t${({ $variant, theme }) =>\r\n\t\t\t$variant === StepperVariant.vertical &&\r\n\t\t\tcss`\r\n\t\t\t\tflex-direction: column;\r\n\t\t\t\twidth: fit-content;\r\n\t\t\t\tpadding: ${theme.spacing.lg} ${theme.spacing.md};\r\n\t\t\t`}\r\n\t}\r\n`;\r\n\r\nexport const Separator = styled.div`\r\n\tdisplay: none;\r\n\r\n\t@media (min-width: ${({ theme }) => theme.breakpoints.sm}) {\r\n\t\tdisplay: block;\r\n\t\twidth: 1px;\r\n\t\theight: ${({ theme }) => theme.spacing.xl};\r\n\t\tmargin-left: 16px;\r\n\t\tbackground-color: ${({ theme }) => theme.colors.bg.neutral.default.light};\r\n\t}\r\n`;\r\n","export enum StoreButtonVariant {\r\n\tandroid = 'android',\r\n\tapple = 'apple',\r\n}\r\n\r\nexport enum StoreButtonSize {\r\n\tbig = 'big',\r\n\tsmall = 'small',\r\n}\r\n","interface Props {\r\n\tclassName?: string;\r\n\theight?: string;\r\n\twidth?: string;\r\n}\r\n\r\nexport const AndroidSvg = ({ className, height = '29', width = '116' }: Props) => (\r\n\t<svg\r\n\t\tclassName={className}\r\n\t\tfill=\"none\"\r\n\t\theight={height}\r\n\t\tviewBox=\"0 0 116 29\"\r\n\t\twidth={width}\r\n\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t>\r\n\t\t<path\r\n\t\t\td=\"M58.1 16.8C55.7 16.8 53.8 18.6 53.8 21.1C53.8 23.5 55.7 25.4 58.1 25.4C60.5 25.4 62.4 23.6 62.4 21.1C62.4 18.5 60.5 16.8 58.1 16.8ZM58.1 23.6C56.8 23.6 55.7 22.5 55.7 21C55.7 19.5 56.8 18.4 58.1 18.4C59.4 18.4 60.5 19.4 60.5 21C60.5 22.5 59.4 23.6 58.1 23.6ZM48.8 16.8C46.4 16.8 44.5 18.6 44.5 21.1C44.5 23.5 46.4 25.4 48.8 25.4C51.2 25.4 53.1 23.6 53.1 21.1C53.1 18.5 51.2 16.8 48.8 16.8ZM48.8 23.6C47.5 23.6 46.4 22.5 46.4 21C46.4 19.5 47.5 18.4 48.8 18.4C50.1 18.4 51.2 19.4 51.2 21C51.2 22.5 50.1 23.6 48.8 23.6ZM37.7 18.1V19.9H42C41.9 20.9 41.5 21.7 41 22.2C40.4 22.8 39.4 23.5 37.7 23.5C35 23.5 33 21.4 33 18.7C33 16 35.1 13.9 37.7 13.9C39.1 13.9 40.2 14.5 41 15.2L42.3 13.9C41.2 12.9 39.8 12.1 37.8 12.1C34.2 12.1 31.1 15.1 31.1 18.7C31.1 22.3 34.2 25.3 37.8 25.3C39.8 25.3 41.2 24.7 42.4 23.4C43.6 22.2 44 20.5 44 19.2C44 18.8 44 18.4 43.9 18.1H37.7ZM83.1 19.5C82.7 18.5 81.7 16.8 79.5 16.8C77.3 16.8 75.5 18.5 75.5 21.1C75.5 23.5 77.3 25.4 79.7 25.4C81.6 25.4 82.8 24.2 83.2 23.5L81.8 22.5C81.3 23.2 80.7 23.7 79.7 23.7C78.7 23.7 78.1 23.3 77.6 22.4L83.3 20L83.1 19.5ZM77.3 20.9C77.3 19.3 78.6 18.4 79.5 18.4C80.2 18.4 80.9 18.8 81.1 19.3L77.3 20.9ZM72.6 25H74.5V12.5H72.6V25ZM69.6 17.7C69.1 17.2 68.3 16.7 67.3 16.7C65.2 16.7 63.2 18.6 63.2 21C63.2 23.4 65.1 25.2 67.3 25.2C68.3 25.2 69.1 24.7 69.5 24.2H69.6V24.8C69.6 26.4 68.7 27.3 67.3 27.3C66.2 27.3 65.4 26.5 65.2 25.8L63.6 26.5C64.1 27.6 65.3 29 67.4 29C69.6 29 71.4 27.7 71.4 24.6V17H69.6V17.7ZM67.4 23.6C66.1 23.6 65 22.5 65 21C65 19.5 66.1 18.4 67.4 18.4C68.7 18.4 69.7 19.5 69.7 21C69.7 22.5 68.7 23.6 67.4 23.6ZM91.8 12.5H87.3V25H89.2V20.3H91.8C93.9 20.3 95.9 18.8 95.9 16.4C95.9 14 93.9 12.5 91.8 12.5ZM91.9 18.5H89.2V14.2H91.9C93.3 14.2 94.1 15.4 94.1 16.3C94 17.4 93.2 18.5 91.9 18.5ZM103.4 16.7C102 16.7 100.6 17.3 100.1 18.6L101.8 19.3C102.2 18.6 102.8 18.4 103.5 18.4C104.5 18.4 105.4 19 105.5 20V20.1C105.2 19.9 104.4 19.6 103.6 19.6C101.8 19.6 100 20.6 100 22.4C100 24.1 101.5 25.2 103.1 25.2C104.4 25.2 105 24.6 105.5 24H105.6V25H107.4V20.2C107.2 18 105.5 16.7 103.4 16.7ZM103.2 23.6C102.6 23.6 101.7 23.3 101.7 22.5C101.7 21.5 102.8 21.2 103.7 21.2C104.5 21.2 104.9 21.4 105.4 21.6C105.2 22.8 104.2 23.6 103.2 23.6ZM113.7 17L111.6 22.4H111.5L109.3 17H107.3L110.6 24.6L108.7 28.8H110.6L115.7 17H113.7ZM96.9 25H98.8V12.5H96.9V25Z\"\r\n\t\t\tfill=\"white\"\r\n\t\t/>\r\n\t\t<path\r\n\t\t\td=\"M0.4 2.5C0.0999999 2.8 0 3.3 0 3.9V26C0 26.6 0.2 27.1 0.5 27.4L0.6 27.5L13 15.1V14.9L0.4 2.5Z\"\r\n\t\t\tfill=\"url(#paint0_linear_2551_76392)\"\r\n\t\t/>\r\n\t\t<path\r\n\t\t\td=\"M17 19.3L12.9 15.2V14.9L17 10.8L17.1 10.9L22 13.7C23.4 14.5 23.4 15.8 22 16.6L17 19.3Z\"\r\n\t\t\tfill=\"url(#paint1_linear_2551_76392)\"\r\n\t\t/>\r\n\t\t<path\r\n\t\t\td=\"M17.1 19.2L12.9 15L0.400024 27.5C0.900024 28 1.60002 28 2.50002 27.6L17.1 19.2Z\"\r\n\t\t\tfill=\"url(#paint2_linear_2551_76392)\"\r\n\t\t/>\r\n\t\t<path\r\n\t\t\td=\"M17.1 10.8L2.50002 2.49999C1.60002 1.99999 0.900024 2.09999 0.400024 2.59999L12.9 15L17.1 10.8Z\"\r\n\t\t\tfill=\"url(#paint3_linear_2551_76392)\"\r\n\t\t/>\r\n\t\t<path\r\n\t\t\td=\"M17 19.1L2.50002 27.3C1.70002 27.8 1.00003 27.7 0.500025 27.3L0.400024 27.4L0.500025 27.5C1.00003 27.9 1.70002 28 2.50002 27.5L17 19.1Z\"\r\n\t\t\tfill=\"black\"\r\n\t\t\topacity=\"0.2\"\r\n\t\t/>\r\n\t\t<path\r\n\t\t\td=\"M0.399999 27.3C0.0999995 27 0 26.5 0 25.9V26C0 26.6 0.2 27.1 0.5 27.4V27.3H0.399999Z\"\r\n\t\t\tfill=\"black\"\r\n\t\t\topacity=\"0.12\"\r\n\t\t/>\r\n\t\t<path\r\n\t\t\td=\"M22 16.3L17 19.1L17.1 19.2L22 16.4C22.7 16 23 15.5 23 15C23 15.5 22.6 15.9 22 16.3Z\"\r\n\t\t\tfill=\"black\"\r\n\t\t\topacity=\"0.12\"\r\n\t\t/>\r\n\t\t<path\r\n\t\t\td=\"M2.5 2.60003L22 13.7C22.6 14.1 23 14.5 23 15C23 14.5 22.7 14 22 13.6L2.5 2.50003C1.1 1.70003 0 2.30003 0 3.90003V4.00003C0 2.50003 1.1 1.80003 2.5 2.60003Z\"\r\n\t\t\tfill=\"white\"\r\n\t\t\topacity=\"0.25\"\r\n\t\t/>\r\n\t\t<path\r\n\t\t\td=\"M31.3 8V2H32.2L35.1 6.7V2H36V8H35.2L32.1 3.1V8H31.3ZM39.6 8H38.8V5.2L36.8 2H37.7L39.2 4.4L40.7 2H41.6L39.6 5.2V8ZM42.5 8V2H43.4001L46.3 6.7V2H47.1V8H46.3L43.2 3.1V8H42.5ZM48.5 8V2H49.3001V8H48.5ZM49.2 1.5H48.5L49.0001 0.5H49.8001L49.2 1.5ZM52.6001 8V2H53.5L56.4 6.7V2H57.2V8H56.4L53.3 3.1V8H52.6001ZM58.1 8L60.4001 2H61.3L63.6 8H62.7L62.1 6.4H59.6L59.0001 8H58.1ZM59.8001 5.7H61.8001L60.8 3L59.8001 5.7Z\"\r\n\t\t\tfill=\"white\"\r\n\t\t\tstroke=\"white\"\r\n\t\t\tstrokeWidth=\"0.138889\"\r\n\t\t/>\r\n\t\t<defs>\r\n\t\t\t<linearGradient\r\n\t\t\t\tgradientUnits=\"userSpaceOnUse\"\r\n\t\t\t\tid=\"paint0_linear_2551_76392\"\r\n\t\t\t\tx1=\"7.93299\"\r\n\t\t\t\tx2=\"-2.72718\"\r\n\t\t\t\ty1=\"3.70975\"\r\n\t\t\t\ty2=\"14.3701\"\r\n\t\t\t>\r\n\t\t\t\t<stop stopColor=\"#00A0FF\" />\r\n\t\t\t\t<stop\r\n\t\t\t\t\toffset=\"0.00657\"\r\n\t\t\t\t\tstopColor=\"#00A1FF\"\r\n\t\t\t\t/>\r\n\t\t\t\t<stop\r\n\t\t\t\t\toffset=\"0.2601\"\r\n\t\t\t\t\tstopColor=\"#00BEFF\"\r\n\t\t\t\t/>\r\n\t\t\t\t<stop\r\n\t\t\t\t\toffset=\"0.5122\"\r\n\t\t\t\t\tstopColor=\"#00D2FF\"\r\n\t\t\t\t/>\r\n\t\t\t\t<stop\r\n\t\t\t\t\toffset=\"0.7604\"\r\n\t\t\t\t\tstopColor=\"#00DFFF\"\r\n\t\t\t\t/>\r\n\t\t\t\t<stop\r\n\t\t\t\t\toffset=\"1\"\r\n\t\t\t\t\tstopColor=\"#00E3FF\"\r\n\t\t\t\t/>\r\n\t\t\t</linearGradient>\r\n\t\t\t<linearGradient\r\n\t\t\t\tgradientUnits=\"userSpaceOnUse\"\r\n\t\t\t\tid=\"paint1_linear_2551_76392\"\r\n\t\t\t\tx1=\"23.8343\"\r\n\t\t\t\tx2=\"-0.362575\"\r\n\t\t\t\ty1=\"15.0017\"\r\n\t\t\t\ty2=\"15.0017\"\r\n\t\t\t>\r\n\t\t\t\t<stop stopColor=\"#FFE000\" />\r\n\t\t\t\t<stop\r\n\t\t\t\t\toffset=\"0.4087\"\r\n\t\t\t\t\tstopColor=\"#FFBD00\"\r\n\t\t\t\t/>\r\n\t\t\t\t<stop\r\n\t\t\t\t\toffset=\"0.7754\"\r\n\t\t\t\t\tstopColor=\"#FFA500\"\r\n\t\t\t\t/>\r\n\t\t\t\t<stop\r\n\t\t\t\t\toffset=\"1\"\r\n\t\t\t\t\tstopColor=\"#FF9C00\"\r\n\t\t\t\t/>\r\n\t\t\t</linearGradient>\r\n\t\t\t<linearGradient\r\n\t\t\t\tgradientUnits=\"userSpaceOnUse\"\r\n\t\t\t\tid=\"paint2_linear_2551_76392\"\r\n\t\t\t\tx1=\"14.827\"\r\n\t\t\t\tx2=\"-3.33\"\r\n\t\t\t\ty1=\"18.9735\"\r\n\t\t\t\ty2=\"37.1305\"\r\n\t\t\t>\r\n\t\t\t\t<stop stopColor=\"#FF3A44\" />\r\n\t\t\t\t<stop\r\n\t\t\t\t\toffset=\"1\"\r\n\t\t\t\t\tstopColor=\"#C31162\"\r\n\t\t\t\t/>\r\n\t\t\t</linearGradient>\r\n\t\t\t<linearGradient\r\n\t\t\t\tgradientUnits=\"userSpaceOnUse\"\r\n\t\t\t\tid=\"paint3_linear_2551_76392\"\r\n\t\t\t\tx1=\"-2.70284\"\r\n\t\t\t\tx2=\"5.37702\"\r\n\t\t\t\ty1=\"0.672613\"\r\n\t\t\t\ty2=\"8.75243\"\r\n\t\t\t>\r\n\t\t\t\t<stop stopColor=\"#32A071\" />\r\n\t\t\t\t<stop\r\n\t\t\t\t\toffset=\"0.0685\"\r\n\t\t\t\t\tstopColor=\"#2DA771\"\r\n\t\t\t\t/>\r\n\t\t\t\t<stop\r\n\t\t\t\t\toffset=\"0.4762\"\r\n\t\t\t\t\tstopColor=\"#15CF74\"\r\n\t\t\t\t/>\r\n\t\t\t\t<stop\r\n\t\t\t\t\toffset=\"0.8009\"\r\n\t\t\t\t\tstopColor=\"#06E775\"\r\n\t\t\t\t/>\r\n\t\t\t\t<stop\r\n\t\t\t\t\toffset=\"1\"\r\n\t\t\t\t\tstopColor=\"#00F076\"\r\n\t\t\t\t/>\r\n\t\t\t</linearGradient>\r\n\t\t</defs>\r\n\t</svg>\r\n);\r\n","interface Props {\r\n\tclassName?: string;\r\n\theight?: string;\r\n\twidth?: string;\r\n}\r\n\r\nexport const AppleSvg = ({ className, height = '26', width = '100' }: Props) => (\r\n\t<svg\r\n\t\tclassName={className}\r\n\t\tfill=\"none\"\r\n\t\theight={height}\r\n\t\tviewBox=\"0 0 100 26\"\r\n\t\twidth={width}\r\n\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t>\r\n\t\t<path\r\n\t\t\td=\"M15.2691 12.3C15.28 11.4654 15.5018 10.6471 15.9138 9.92121C16.3258 9.19533 16.9148 8.58545 17.6258 8.1483C17.174 7.50312 16.5779 6.97218 15.885 6.59766C15.1921 6.22313 14.4214 6.01535 13.6341 5.9908C11.955 5.81497 10.3275 6.9958 9.47164 6.9958C8.59914 6.9958 7.28164 6.0083 5.8633 6.03747C4.94551 6.06707 4.05103 6.33395 3.26707 6.81209C2.4831 7.29024 1.83639 7.96335 1.38997 8.7658C-0.543363 12.1141 0.898303 17.035 2.7508 19.7408C3.6783 21.0666 4.76164 22.5475 6.17914 22.495C7.5658 22.4366 8.08414 21.61 9.7583 21.61C11.4166 21.61 11.9033 22.495 13.3491 22.4616C14.8375 22.4366 15.775 21.13 16.67 19.7925C17.3359 18.8481 17.8484 17.8044 18.1883 16.7C17.3235 16.3342 16.5854 15.7219 16.0663 14.9394C15.5472 14.157 15.2699 13.239 15.2691 12.3ZM12.5375 4.2108C13.3489 3.23649 13.7486 1.98423 13.6516 0.719971C12.4118 0.850316 11.2665 1.44302 10.4441 2.37997C10.042 2.83771 9.73411 3.37021 9.53792 3.94702C9.34174 4.52384 9.26117 5.13366 9.3008 5.74164C9.92096 5.74794 10.5345 5.61345 11.0951 5.34828C11.6558 5.08312 12.1489 4.69419 12.5375 4.2108Z\"\r\n\t\t\tfill=\"white\"\r\n\t\t/>\r\n\t\t<path\r\n\t\t\td=\"M32.8025 19.14H28.0692L26.9325 22.4958H24.9275L29.4108 10.0784H31.4942L35.9775 22.4958H33.9383L32.8025 19.14ZM28.5592 17.5908H32.3108L30.4608 12.1434H30.41L28.5583 17.5917L28.5592 17.5908ZM45.66 17.97C45.66 20.7833 44.1542 22.5908 41.8817 22.5908C41.306 22.6211 40.7334 22.4887 40.2295 22.2087C39.7256 21.9286 39.3108 21.5124 39.0325 21.0075H38.99V25.4908H37.1317V13.4425H38.93V14.9483H38.9642C39.2552 14.4459 39.6771 14.0318 40.1848 13.7501C40.6925 13.4683 41.2671 13.3295 41.8475 13.3483C44.145 13.3483 45.66 15.1642 45.66 17.97ZM43.7492 17.97C43.7492 16.1367 42.8025 14.9317 41.3575 14.9317C39.9367 14.9317 38.9825 16.1625 38.9825 17.97C38.9825 19.7942 39.9367 21.0158 41.3575 21.0158C42.8025 21.0158 43.7492 19.8192 43.7492 17.97ZM55.625 17.97C55.625 20.7833 54.1183 22.5908 51.8458 22.5908C51.2703 22.621 50.6979 22.4885 50.1941 22.2084C49.6904 21.9284 49.2757 21.5122 48.9975 21.0075H48.9542V25.4908H47.0958V13.4425H48.895V14.9483H48.9292C49.2202 14.4459 49.6421 14.0318 50.1498 13.7501C50.6575 13.4683 51.2321 13.3295 51.8125 13.3483C54.11 13.3483 55.6242 15.1642 55.6242 17.97H55.625ZM53.7142 17.97C53.7142 16.1367 52.7675 14.9317 51.3225 14.9317C49.9017 14.9317 48.9475 16.1625 48.9475 17.97C48.9475 19.7942 49.9017 21.0158 51.3225 21.0158C52.7675 21.0158 53.7142 19.8192 53.7142 17.97ZM62.2108 19.0358C62.3483 20.2675 63.5441 21.0758 65.1791 21.0758C66.7458 21.0758 67.8725 20.2675 67.8725 19.1575C67.8725 18.1933 67.1925 17.6158 65.5833 17.2208L63.975 16.8333C61.695 16.2825 60.6358 15.2158 60.6358 13.485C60.6358 11.3433 62.5033 9.87085 65.155 9.87085C67.7783 9.87085 69.5775 11.3425 69.6383 13.485H67.7616C67.65 12.2458 66.625 11.4984 65.1283 11.4984C63.6308 11.4984 62.6067 12.255 62.6067 13.3567C62.6067 14.2342 63.2608 14.7508 64.8617 15.1467L66.23 15.4825C68.7775 16.085 69.8367 17.1083 69.8367 18.9242C69.8367 21.2483 67.9858 22.7033 65.0425 22.7033C62.2883 22.7033 60.4292 21.2825 60.3092 19.0367H62.2117L62.2108 19.0358ZM73.8458 11.3V13.4417H75.5675V14.9142H73.8458V19.9058C73.8458 20.6808 74.1908 21.0417 74.9475 21.0417C75.1525 21.0383 75.3558 21.0242 75.5591 20.9992V22.4617C75.2191 22.5258 74.8733 22.5542 74.5266 22.5475C72.6933 22.5475 71.9791 21.8592 71.9791 20.1033V14.9142H70.6625V13.4417H71.9791V11.3H73.8458ZM76.565 17.97C76.565 15.1208 78.2425 13.3308 80.8591 13.3308C83.4841 13.3308 85.1541 15.1208 85.1541 17.97C85.1541 20.8258 83.4925 22.6083 80.8591 22.6083C78.2258 22.6083 76.565 20.8258 76.565 17.97ZM83.26 17.97C83.26 16.0158 82.365 14.8617 80.8591 14.8617C79.3533 14.8617 78.4592 16.0242 78.4592 17.97C78.4592 19.9317 79.3533 21.0758 80.8591 21.0758C82.365 21.0758 83.26 19.9317 83.26 17.97ZM86.6858 13.4417H88.4583V14.9833H88.5016C88.6215 14.5021 88.9034 14.0767 89.2999 13.7788C89.6965 13.4809 90.1835 13.3286 90.6791 13.3475C90.8933 13.3475 91.1066 13.37 91.3158 13.4167V15.155C91.0454 15.0726 90.7634 15.0349 90.4808 15.0433C90.2108 15.0323 89.9416 15.0799 89.6917 15.1828C89.4418 15.2857 89.2171 15.4415 89.0331 15.6394C88.8491 15.8373 88.7101 16.0727 88.6257 16.3295C88.5413 16.5862 88.5135 16.8582 88.5441 17.1267V22.4958H86.6858V13.4425V13.4417ZM99.8841 19.8367C99.6341 21.4808 98.0341 22.6083 95.9858 22.6083C93.3525 22.6083 91.7175 20.8433 91.7175 18.0125C91.7175 15.1725 93.3608 13.3308 95.9075 13.3308C98.4125 13.3308 99.9875 15.0517 99.9875 17.7975V18.4333H93.5933V18.5458C93.5639 18.879 93.6057 19.2147 93.7159 19.5305C93.8261 19.8463 94.0023 20.135 94.2327 20.3775C94.463 20.62 94.7424 20.8108 95.0521 20.9371C95.3618 21.0633 95.6949 21.1223 96.0291 21.11C96.4683 21.1512 96.909 21.0495 97.2857 20.8201C97.6624 20.5906 97.955 20.2457 98.12 19.8367H99.8841ZM93.6016 17.135H98.1283C98.145 16.8354 98.0996 16.5355 97.995 16.2543C97.8903 15.973 97.7286 15.7164 97.5201 15.5006C97.3115 15.2848 97.0607 15.1144 96.7831 15.0001C96.5056 14.8859 96.2075 14.8302 95.9075 14.8367C95.6048 14.8348 95.3047 14.8929 95.0246 15.0077C94.7445 15.1224 94.4899 15.2915 94.2755 15.5052C94.0611 15.7189 93.8912 15.973 93.7755 16.2527C93.6598 16.5324 93.6008 16.8323 93.6016 17.135Z\"\r\n\t\t\tfill=\"white\"\r\n\t\t/>\r\n\t\t<path\r\n\t\t\td=\"M26.8082 5.09333C26.8866 5.66 27.4407 6.01916 28.2391 6.01916C28.9832 6.01916 29.5291 5.63583 29.5291 5.10583C29.5291 4.65083 29.1816 4.37833 28.3916 4.19166L27.6232 4.00583C26.5441 3.75333 26.0516 3.2325 26.0516 2.35583C26.0516 1.29333 26.9199 0.585832 28.2224 0.585832C28.7343 0.528865 29.2479 0.676978 29.6508 0.997763C30.0537 1.31855 30.3132 1.78588 30.3724 2.2975H29.4707C29.4113 2.01744 29.2485 1.77006 29.0149 1.60465C28.7812 1.43924 28.4938 1.36796 28.2099 1.405C27.4774 1.405 26.9899 1.75666 26.9899 2.29416C26.9899 2.71916 27.3049 2.96416 28.0816 3.14583L28.7399 3.3075C29.9632 3.5925 30.4674 4.08833 30.4674 4.98583C30.4674 6.1275 29.5832 6.8425 28.1691 6.8425C26.8457 6.8425 25.9557 6.16 25.8899 5.0925H26.8082V5.09333ZM32.9091 1.07333V2.215H33.8841V2.96416H32.9091V5.27917C32.9091 5.75083 33.1032 5.9575 33.5457 5.9575C33.6591 5.9575 33.7724 5.95 33.8849 5.93667V6.6775C33.7253 6.70591 33.5636 6.72096 33.4016 6.7225C32.4132 6.7225 32.0191 6.375 32.0191 5.50666V2.96416H31.3049V2.215H32.0191V1.07333H32.9091ZM34.8007 5.425C34.8007 4.61417 35.4041 4.14667 36.4757 4.08L37.6949 4.01V3.62083C37.6949 3.14583 37.3807 2.87666 36.7732 2.87666C36.2774 2.87666 35.9332 3.05917 35.8349 3.37667H34.9749C35.0657 2.60417 35.7932 2.10833 36.8141 2.10833C37.9432 2.10833 38.5807 2.67 38.5807 3.62083V6.6975H37.7249V6.06417H37.6541C37.5115 6.2914 37.3112 6.47671 37.0736 6.60116C36.8359 6.72561 36.5695 6.78474 36.3016 6.7725C36.1125 6.79219 35.9214 6.77201 35.7405 6.71328C35.5597 6.65454 35.3932 6.55855 35.2518 6.4315C35.1104 6.30445 34.9972 6.14916 34.9195 5.97565C34.8418 5.80214 34.8013 5.61427 34.8007 5.42416V5.425ZM37.6949 5.03917V4.66333L36.5949 4.73333C35.9757 4.775 35.6949 4.98583 35.6949 5.38333C35.6949 5.78833 36.0457 6.02417 36.5291 6.02417C36.6708 6.03858 36.814 6.02431 36.9501 5.98222C37.0862 5.94012 37.2125 5.87106 37.3213 5.77915C37.4302 5.68724 37.5195 5.57436 37.5838 5.44723C37.6481 5.3201 37.6862 5.18132 37.6957 5.03917H37.6949ZM36.2816 1.44166L37.3191 0.019165H38.3607L37.1999 1.44166H36.2824H36.2816ZM40.0124 0.436665H40.8932V2.91833H40.9641C41.2057 2.3875 41.7549 2.065 42.3366 2.11166C42.5546 2.09977 42.7725 2.13616 42.9748 2.21822C43.1772 2.30028 43.3589 2.426 43.507 2.58639C43.6552 2.74678 43.7661 2.9379 43.8318 3.1461C43.8976 3.3543 43.9165 3.57445 43.8874 3.79083V6.6975H42.9982V4.01C42.9982 3.29083 42.6632 2.92667 42.0349 2.92667C41.8822 2.91416 41.7286 2.93518 41.5848 2.98825C41.4411 3.04132 41.3107 3.12516 41.2027 3.23391C41.0947 3.34266 41.0119 3.47368 40.9598 3.61782C40.9078 3.76195 40.8879 3.91571 40.9016 4.06833V6.6975H40.0124V0.436665ZM45.2616 2.195H46.1174V2.91H46.1841C46.2967 2.65313 46.4866 2.43779 46.7274 2.29394C46.9682 2.1501 47.2478 2.08493 47.5274 2.1075C47.7465 2.09098 47.9665 2.124 48.1712 2.2041C48.3758 2.2842 48.5597 2.40933 48.7094 2.57021C48.8591 2.73109 48.9706 2.92359 49.0358 3.13345C49.1009 3.34331 49.118 3.56514 49.0857 3.7825V6.6975H48.1974V4.00583C48.1974 3.2825 47.8824 2.9225 47.2257 2.9225C47.077 2.91566 46.9285 2.94105 46.7904 2.99695C46.6524 3.05285 46.528 3.13793 46.4259 3.24636C46.3238 3.35479 46.2464 3.48401 46.1989 3.62516C46.1514 3.76632 46.135 3.91607 46.1507 4.06417V6.6975H45.2616V2.195ZM50.2374 4.44416C50.2086 4.14801 50.2421 3.84911 50.3357 3.56667C50.4293 3.28423 50.581 3.02449 50.781 2.80415C50.9809 2.58381 51.2248 2.40774 51.4969 2.28725C51.7689 2.16676 52.0632 2.10451 52.3607 2.10451C52.6583 2.10451 52.9525 2.16676 53.2246 2.28725C53.4967 2.40774 53.7405 2.58381 53.9405 2.80415C54.1405 3.02449 54.2921 3.28423 54.3857 3.56667C54.4793 3.84911 54.5128 4.14801 54.4841 4.44416C54.5128 4.74032 54.4793 5.03922 54.3857 5.32166C54.2921 5.6041 54.1405 5.86384 53.9405 6.08418C53.7405 6.30452 53.4967 6.48059 53.2246 6.60108C52.9525 6.72157 52.6583 6.78381 52.3607 6.78381C52.0632 6.78381 51.7689 6.72157 51.4969 6.60108C51.2248 6.48059 50.9809 6.30452 50.781 6.08418C50.581 5.86384 50.4293 5.6041 50.3357 5.32166C50.2421 5.03922 50.2086 4.74032 50.2374 4.44416ZM53.5707 4.44416C53.5707 3.46833 53.1316 2.8975 52.3624 2.8975C51.5899 2.8975 51.1549 3.46833 51.1549 4.44416C51.1549 5.4275 51.5899 5.99416 52.3624 5.99416C53.1316 5.99416 53.5707 5.42416 53.5707 4.44416ZM59.4732 6.6975H58.6166V5.9825H58.5466C58.4328 6.24224 58.2401 6.45955 57.9958 6.60359C57.7515 6.74764 57.4681 6.81111 57.1857 6.785C56.968 6.80027 56.7496 6.76662 56.5466 6.68651C56.3436 6.60641 56.1611 6.48188 56.0124 6.32206C55.8638 6.16224 55.7528 5.97119 55.6877 5.7629C55.6225 5.55461 55.6047 5.33437 55.6357 5.11833V2.195H56.5249V4.88666C56.5249 5.61416 56.8182 5.96166 57.4707 5.96166C57.6222 5.97603 57.775 5.9564 57.9179 5.90422C58.0609 5.85203 58.1904 5.7686 58.297 5.66001C58.4035 5.55142 58.4846 5.42041 58.5341 5.27653C58.5836 5.13265 58.6004 4.97953 58.5832 4.82833V2.195H59.4732V6.6975ZM62.0916 1.07333V2.215H63.0674V2.96416H62.0924V5.27917C62.0924 5.75083 62.2866 5.9575 62.7291 5.9575C62.8424 5.9575 62.9557 5.95 63.0674 5.93667V6.6775C62.9078 6.70596 62.7461 6.72101 62.5841 6.7225C61.5957 6.7225 61.2024 6.375 61.2024 5.50666V2.96416H60.4874V2.215H61.2024V1.07333H62.0924H62.0916ZM68.8749 6.6975H67.9191L66.2941 2.195H67.2441L68.3657 5.74667H68.4357L69.5524 2.195H70.4957L68.8749 6.6975Z\"\r\n\t\t\tfill=\"white\"\r\n\t\t/>\r\n\t</svg>\r\n);\r\n","import { css } from '@emotion/react';\r\n\r\nimport { styled } from '@/utils';\r\n\r\nimport { StoreButtonSize } from './types';\r\n\r\ninterface StoreButtonStyledProps {\r\n\t$size: StoreButtonSize;\r\n}\r\n\r\nexport const StoreButtonStyled = styled.button<StoreButtonStyledProps>`\r\n\t/* common styles */\r\n\tdisplay: flex;\r\n\tflex-shrink: 0;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\tcursor: pointer;\r\n\tbackground-color: ${({ theme }) => theme.palette.black};\r\n\tborder: 1px solid ${({ theme }) => theme.colors.border.neutral.default.light};\r\n\r\n\t/* size specific styles */\r\n\t${({ $size, theme }) => {\r\n\t\tswitch ($size) {\r\n\t\t\tcase StoreButtonSize.small:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\twidth: 135px;\r\n\t\t\t\t\theight: ${theme.spacing.xxl};\r\n\t\t\t\t\tborder-radius: ${theme.borderRadius.xs};\r\n\t\t\t\t`;\r\n\t\t\tcase StoreButtonSize.big:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\twidth: 162px;\r\n\t\t\t\t\theight: 48px;\r\n\t\t\t\t\tborder-radius: 6px;\r\n\t\t\t\t`;\r\n\t\t\tdefault:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tborder-radius: ${theme.borderRadius.xs};\r\n\t\t\t\t`;\r\n\t\t}\r\n\t}}\r\n`;\r\n","export enum TableVariant {\r\n\texchange = 'exchange',\r\n\tsimple = 'simple',\r\n\tsimpleWithoutShadow = 'simpleWithoutShadow',\r\n}\r\n\r\nexport enum TableTextAlign {\r\n\tcenter = 'center',\r\n\tleft = 'left',\r\n\tright = 'right',\r\n}\r\n\r\nexport enum TableHeadScope {\r\n\tcol = 'col',\r\n\tcolgroup = 'colgroup',\r\n\trow = 'row',\r\n\trowgroup = 'rowgroup',\r\n}\r\n","import { css } from '@emotion/react';\r\nimport { type Property } from 'csstype';\r\n\r\nimport { styled } from '@/utils';\r\n\r\nimport { TableVariant } from '../types';\r\n\r\ninterface TableStyledProps {\r\n\t$variant: TableVariant;\r\n\t$width: Property.Width;\r\n}\r\n\r\nexport const TableStyled = styled.table<TableStyledProps>`\r\n\twidth: ${({ $width }) => $width};\r\n\tbackground-color: ${({ theme }) => theme.colors.surface.risen};\r\n\r\n\t/* variant specific styles */\r\n\t${({ $variant, theme }) => {\r\n\t\tswitch ($variant) {\r\n\t\t\tcase TableVariant.simple:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tpadding: ${theme.spacing.xl};\r\n\t\t\t\t\tborder-radius: ${theme.borderRadius.xs};\r\n\t\t\t\t\tbox-shadow: ${theme.colors.shadow.cards};\r\n\t\t\t\t`;\r\n\t\t\tcase TableVariant.simpleWithoutShadow:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tpadding: ${theme.spacing.xl};\r\n\t\t\t\t\tborder-radius: ${theme.borderRadius.xs};\r\n\t\t\t\t\tbox-shadow: none;\r\n\t\t\t\t`;\r\n\t\t\tcase TableVariant.exchange:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tborder-radius: ${theme.borderRadius.md};\r\n\t\t\t\t`;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected enum of TableVariant in table.styles.ts');\r\n\t\t}\r\n\t}}\r\n`;\r\n","import { css } from '@emotion/react';\r\nimport { type Property } from 'csstype';\r\n\r\nimport { type ChooseColor, styled } from '@/utils';\r\n\r\nimport { type TableTextAlign, TableVariant } from '../types';\r\n\r\ninterface TableDataStyledProps {\r\n\t$align: TableTextAlign;\r\n\t$chooseColor: ChooseColor;\r\n\t$delimiter: boolean;\r\n\t$variant: TableVariant;\r\n}\r\n\r\nexport const TableDataStyled = styled.td<TableDataStyledProps>`\r\n\t/* common styles */\r\n\tpadding: ${({ theme }) => theme.spacing.md};\r\n\ttext-align: ${({ $align }) => $align satisfies Property.TextAlign};\r\n\r\n\t/* variant specific styles */\r\n\t${({ $chooseColor, $delimiter, $variant, theme }) => {\r\n\t\tswitch ($variant) {\r\n\t\t\tcase TableVariant.exchange:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tborder-right: ${$delimiter === true ? `${$chooseColor(theme.colors.border.neutral.subtlest)} 1px solid` : 'none'};\r\n\t\t\t\t\tborder-bottom: 1px solid ${$chooseColor(theme.colors.border.neutral.subtlest)};\r\n\t\t\t\t`;\r\n\t\t\tcase TableVariant.simpleWithoutShadow:\r\n\t\t\tcase TableVariant.simple:\r\n\t\t\t\treturn css``;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected enum of TableVariant in tableData.styles.ts');\r\n\t\t}\r\n\t}}\r\n`;\r\n","import { styled } from '@/utils';\r\n\r\nexport const TableHeadStyled = styled.thead`\r\n\tdisplay: table-header-group;\r\n`;\r\n","import { css } from '@emotion/react';\r\nimport { type Property } from 'csstype';\r\n\r\nimport { type ChooseColor, styled } from '@/utils';\r\n\r\nimport { type TableTextAlign, TableVariant } from '../types';\r\n\r\ninterface TableHeadDataStyledProps {\r\n\t$align: TableTextAlign;\r\n\t$chooseColor: ChooseColor;\r\n\t$delimiter: boolean;\r\n\t$variant: TableVariant;\r\n\t$width?: Property.Width;\r\n}\r\n\r\nexport const TableHeadDataStyled = styled.th<TableHeadDataStyledProps>`\r\n\twidth: ${({ $width }) => ($width === undefined ? 'auto' : $width)};\r\n\tpadding: ${({ theme }) => theme.spacing.md};\r\n\ttext-align: ${({ $align }) => $align satisfies Property.TextAlign};\r\n\tborder-right: ${({ $chooseColor, $delimiter, theme }) => ($delimiter ? `${$chooseColor(theme.colors.border.neutral.subtlest)} 1px solid` : 'none')};\r\n\tborder-bottom: 1px solid ${({ $chooseColor, theme }) => $chooseColor(theme.colors.border.neutral.subtlest)};\r\n\r\n\t/* variant specific styles */\r\n\t${({ $chooseColor, $variant, theme }) => {\r\n\t\tswitch ($variant) {\r\n\t\t\tcase TableVariant.exchange:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tbackground-color: ${$chooseColor(theme.colors.bg.brand.default)};\r\n\t\t\t\t`;\r\n\t\t\tcase TableVariant.simple:\r\n\t\t\tcase TableVariant.simpleWithoutShadow:\r\n\t\t\t\treturn css``;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected enum of TableVariant in tableHeadData.styles.ts');\r\n\t\t}\r\n\t}}\r\n`;\r\n","import { css } from '@emotion/react';\r\n\r\nimport { styled, type ChooseColor } from '@/utils';\r\n\r\nimport { TableVariant } from '../types';\r\n\r\ninterface TableRowStyledProps {\r\n\t$chooseColor: ChooseColor;\r\n\t$variant: TableVariant;\r\n}\r\n\r\nexport const TableRowStyled = styled.tr<TableRowStyledProps>`\r\n\t/* common styles */\r\n\t&:not(:last-of-type) {\r\n\t\tborder-bottom: 1px solid ${({ $chooseColor, theme }) => $chooseColor(theme.colors.border.neutral.subtlest)};\r\n\t}\r\n\r\n\t/* variant specific styles */\r\n\t${({ $variant }) => {\r\n\t\tswitch ($variant) {\r\n\t\t\tcase TableVariant.exchange:\r\n\t\t\tcase TableVariant.simple:\r\n\t\t\tcase TableVariant.simpleWithoutShadow:\r\n\t\t\t\treturn css``;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected enum of TableVariant in tableRow.styles.ts');\r\n\t\t}\r\n\t}}\r\n`;\r\n","export enum TagType {\r\n\talert = 'alert',\r\n\tinfo = 'info',\r\n\tinfoLight = 'infoLight',\r\n\tinvert = 'invert',\r\n\tneutralDefault = 'neutralDefault',\r\n\tneutralSubtle = 'neutralSubtle',\r\n\tsuccess = 'success',\r\n\twarning = 'warning',\r\n}\r\n\r\nexport enum TagSize {\r\n\tmd = 'md',\r\n\tsm = 'sm',\r\n}\r\n\r\nexport enum TagTextTransform {\r\n\tnone = 'none',\r\n\tuppercase = 'uppercase',\r\n}\r\n\r\nexport enum TagIconPosition {\r\n\tleft = 'left',\r\n\tright = 'right',\r\n\ttop = 'top',\r\n}\r\n","import { css } from '@emotion/react';\r\n\r\nimport { getTextDecorationStyle, type TextDecoration } from '@/theme';\r\nimport { styled, type ChooseColor } from '@/utils';\r\n\r\nimport { TagIconPosition, TagTextTransform, TagType } from './types';\r\n\r\ninterface TagStyledProps {\r\n\t$chooseColor: ChooseColor;\r\n\t$clickable: boolean;\r\n\t$decoration?: TextDecoration;\r\n\t$iconPosition: TagIconPosition;\r\n\t$textTransform: TagTextTransform;\r\n\t$type: TagType;\r\n}\r\n\r\nexport const TagStyled = styled.div<TagStyledProps>`\r\n\t/* COMMON STYLES */\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\twidth: fit-content;\r\n\tpadding: ${({ theme }) => theme.spacing.xxs} ${({ theme }) => theme.spacing.sm};\r\n\tmargin: 0;\r\n\ttext-decoration: none;\r\n\tcursor: ${({ $clickable }) => ($clickable ? 'pointer' : 'default')};\r\n\tborder-style: solid;\r\n\tborder-width: 1px;\r\n\tborder-radius: ${({ theme }) => theme.borderRadius.xs};\r\n\r\n\t/* SPECIFIC STYLES */\r\n\t${({ $chooseColor, $type, theme }) => {\r\n\t\tswitch ($type) {\r\n\t\t\tcase TagType.info:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tbackground-color: ${$chooseColor(theme.colors.bg.brand.default)};\r\n\t\t\t\t\tborder-color: ${$chooseColor(theme.colors.border.brand.subtlest)};\r\n\t\t\t\t`;\r\n\t\t\tcase TagType.infoLight:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tbackground-color: ${$chooseColor(theme.colors.surface.risen)};\r\n\t\t\t\t\tborder-color: ${$chooseColor(theme.colors.border.brand.subtlest)};\r\n\t\t\t\t`;\r\n\t\t\tcase TagType.warning:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tbackground-color: ${$chooseColor(theme.colors.bg.warning.default)};\r\n\t\t\t\t\tborder-color: ${theme.palette.yellow400};\r\n\t\t\t\t`;\r\n\t\t\tcase TagType.success:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tbackground-color: ${$chooseColor(theme.colors.bg.success.default)};\r\n\t\t\t\t\tborder-color: ${theme.palette.green300};\r\n\t\t\t\t`;\r\n\t\t\tcase TagType.neutralSubtle:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tbackground-color: ${$chooseColor(theme.colors.surface.default)};\r\n\t\t\t\t\tborder-color: ${theme.palette.grey200};\r\n\t\t\t\t`;\r\n\t\t\tcase TagType.invert:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tbackground-color: rgb(255 255 255 / 20%);\r\n\t\t\t\t\tborder-color: rgb(255 255 255 / 30%);\r\n\t\t\t\t`;\r\n\t\t\tcase TagType.alert:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tbackground-color: ${$chooseColor(theme.colors.bg.accent)};\r\n\t\t\t\t\tborder-color: ${$chooseColor(theme.colors.border.accent)};\r\n\t\t\t\t`;\r\n\t\t\tcase TagType.neutralDefault:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tpadding: ${theme.spacing.md};\r\n\t\t\t\t\tbackground-color: transparent;\r\n\t\t\t\t\tborder-color: ${$chooseColor(theme.colors.border.neutral.subtlest)};\r\n\t\t\t\t`;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected enum values TagType in tag.styles.ts');\r\n\t\t}\r\n\t}}\r\n\r\n\t/* SPECIFIC STYLES */\r\n\t${({ $textTransform }) => {\r\n\t\tswitch ($textTransform) {\r\n\t\t\tcase TagTextTransform.none:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\ttext-transform: none;\r\n\t\t\t\t`;\r\n\t\t\tcase TagTextTransform.uppercase:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\ttext-transform: uppercase;\r\n\t\t\t\t`;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected enum values TagTextTransform in tag.styles.ts');\r\n\t\t}\r\n\t}}\r\n\r\n\t/* SPECIFIC STYLES */\r\n\t${({ $iconPosition }) => {\r\n\t\tswitch ($iconPosition) {\r\n\t\t\tcase TagIconPosition.right:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tflex-direction: row;\r\n\t\t\t\t`;\r\n\t\t\tcase TagIconPosition.left:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tflex-direction: row-reverse;\r\n\t\t\t\t`;\r\n\t\t\tcase TagIconPosition.top:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tflex-direction: column-reverse;\r\n\t\t\t\t\talign-items: flex-start;\r\n\t\t\t\t`;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected enum values TagIconPosition in tag.styles.ts');\r\n\t\t}\r\n\t}}\r\n\r\n\t&:focus-visible {\r\n\t\toutline-width: 3px;\r\n\t\toutline-style: solid;\r\n\t\toutline-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.focus)};\r\n\t\toutline-offset: 1px;\r\n\t}\r\n\r\n\t${({ $decoration }) => getTextDecorationStyle($decoration)};\r\n`;\r\n\r\ninterface TagIconWrapperProps {\r\n\t$iconPosition: TagIconPosition;\r\n\t$isProduct: boolean;\r\n}\r\n\r\nexport const TagIconWrapper = styled.div<TagIconWrapperProps>`\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\r\n\t${({ $iconPosition, $isProduct, theme }) => {\r\n\t\tswitch ($iconPosition) {\r\n\t\t\tcase TagIconPosition.right:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tmargin: 0 0 0 ${$isProduct ? theme.spacing.xs : theme.spacing.xxs};\r\n\t\t\t\t`;\r\n\t\t\tcase TagIconPosition.left:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tmargin: 0 ${$isProduct ? theme.spacing.xs : theme.spacing.xxs} 0 0;\r\n\t\t\t\t`;\r\n\t\t\tcase TagIconPosition.top:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tmargin: 0 0 ${theme.spacing.md} 0;\r\n\t\t\t\t`;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected enum values TagIconPosition in tag.styles.ts');\r\n\t\t}\r\n\t}}\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { type Property } from 'csstype';\r\nimport { type AriaAttributes, type AriaRole, type ElementType, forwardRef, type KeyboardEvent, type MouseEvent, type ReactNode, useMemo } from 'react';\r\n\r\nimport { IconSystem, IconSystemSize, type IconSystemType } from '@/components/iconSystem';\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { FontWeight, type TextDecoration, WhiteSpace } from '@/theme';\r\n\r\nimport { IconProduct, IconProductSize, type IconProductType } from '../iconProduct';\r\nimport { TagIconPosition, TagSize, TagTextTransform, TagType } from './types';\r\n\r\nimport { TagIconWrapper, TagStyled } from './Tag.style';\r\n\r\nexport interface TagProps extends DesignSystemBaseProps, AriaAttributes {\r\n\tas?: ElementType;\r\n\tchildren: ReactNode;\r\n\tclassName?: string;\r\n\tfontWeight?: FontWeight;\r\n\thref?: string;\r\n\ticonPosition?: TagIconPosition;\r\n\ticonProduct?: IconProductType;\r\n\ticonSystem?: IconSystemType;\r\n\tonClick?: (event: MouseEvent<HTMLDivElement>) => void;\r\n\tonKeyDown?: (event: KeyboardEvent<HTMLDivElement>) => void;\r\n\trole?: AriaRole;\r\n\tsize?: TagSize;\r\n\ttabIndex?: number;\r\n\ttextDecoration?: TextDecoration;\r\n\ttextTransform?: TagTextTransform;\r\n\ttype: TagType;\r\n\twhiteSpace?: WhiteSpace;\r\n}\r\n\r\nexport const Tag = forwardRef<HTMLDivElement, TagProps>((props, ref) => {\r\n\tconst {\r\n\t\tas: asProp,\r\n\t\tchildren,\r\n\t\tclassName,\r\n\t\tcolorScheme: colorSchemeProp, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\tfontWeight = FontWeight.regular400,\r\n\t\thref,\r\n\t\ticonPosition = TagIconPosition.right,\r\n\t\ticonProduct,\r\n\t\ticonSystem,\r\n\t\tmediaType: mediaTypeProp, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\tonClick,\r\n\t\tonKeyDown,\r\n\t\trole,\r\n\t\tsize = TagSize.md,\r\n\t\ttabIndex,\r\n\t\ttextDecoration,\r\n\t\ttextTransform = TagTextTransform.none,\r\n\t\ttype,\r\n\t\twhiteSpace = WhiteSpace.normal,\r\n\t\t...otherProps\r\n\t} = props;\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor, colorScheme } = useDesignSystem(props);\r\n\r\n\tconst color = useMemo<Property.Color>(() => {\r\n\t\tswitch (type) {\r\n\t\t\tcase TagType.info:\r\n\t\t\tcase TagType.infoLight:\r\n\t\t\t\treturn chooseColor(theme.colors.fg.brand.bold);\r\n\t\t\tcase TagType.warning:\r\n\t\t\t\treturn theme.palette.yellow800;\r\n\t\t\tcase TagType.success:\r\n\t\t\t\treturn chooseColor(theme.colors.fg.success);\r\n\t\t\tcase TagType.neutralSubtle:\r\n\t\t\t\treturn chooseColor(theme.colors.fg.neutral.subtle);\r\n\t\t\tcase TagType.invert:\r\n\t\t\t\treturn theme.palette.white;\r\n\t\t\tcase TagType.alert:\r\n\t\t\t\treturn chooseColor(theme.colors.fg.accent.bold);\r\n\t\t\tcase TagType.neutralDefault:\r\n\t\t\t\treturn chooseColor(theme.colors.fg.neutral.default);\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected enum values TagType in tag.tsx');\r\n\t\t}\r\n\t}, [chooseColor, theme, type]);\r\n\r\n\tconst typographyVariant = useMemo<TypographyVariant>(() => {\r\n\t\tswitch (size) {\r\n\t\t\tcase TagSize.sm:\r\n\t\t\t\treturn TypographyVariant.textSm;\r\n\t\t\tcase TagSize.md:\r\n\t\t\t\treturn TypographyVariant.textMd;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected enum values TagSize in tag.tsx');\r\n\t\t}\r\n\t}, [size]);\r\n\r\n\tconst as = useMemo<ElementType | undefined>(() => {\r\n\t\tif (asProp !== undefined) {\r\n\t\t\treturn asProp;\r\n\t\t}\r\n\t\tif (href !== undefined) {\r\n\t\t\treturn 'a';\r\n\t\t}\r\n\r\n\t\treturn onClick === undefined ? undefined : 'button';\r\n\t}, [asProp, href, onClick]);\r\n\r\n\treturn (\r\n\t\t<TagStyled\r\n\t\t\t$chooseColor={chooseColor}\r\n\t\t\t$clickable={onClick !== undefined || href !== undefined}\r\n\t\t\t$decoration={textDecoration}\r\n\t\t\t$iconPosition={iconPosition}\r\n\t\t\t$textTransform={textTransform}\r\n\t\t\t$type={type}\r\n\t\t\tas={as}\r\n\t\t\tclassName={className}\r\n\t\t\t// @ts-ignore 'href' is valid only if rendered as <a> via `as=\"a\"`\r\n\t\t\thref={href}\r\n\t\t\tref={ref}\r\n\t\t\trole={role}\r\n\t\t\ttabIndex={tabIndex}\r\n\t\t\ttype={as === 'button' ? 'button' : undefined}\r\n\t\t\tonClick={onClick}\r\n\t\t\tonKeyDown={onKeyDown}\r\n\t\t\t{...otherProps}\r\n\t\t>\r\n\t\t\t<Typography\r\n\t\t\t\tcolor={color}\r\n\t\t\t\tvariant={typographyVariant}\r\n\t\t\t\tweight={fontWeight}\r\n\t\t\t\twhiteSpace={whiteSpace}\r\n\t\t\t>\r\n\t\t\t\t{children}\r\n\t\t\t</Typography>\r\n\t\t\t{iconSystem !== undefined && (\r\n\t\t\t\t<TagIconWrapper\r\n\t\t\t\t\t$iconPosition={iconPosition}\r\n\t\t\t\t\t$isProduct={false}\r\n\t\t\t\t>\r\n\t\t\t\t\t<IconSystem\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\tsize={IconSystemSize.big}\r\n\t\t\t\t\t\tstroke={color}\r\n\t\t\t\t\t\ttype={iconSystem}\r\n\t\t\t\t\t/>\r\n\t\t\t\t</TagIconWrapper>\r\n\t\t\t)}\r\n\t\t\t{iconProduct !== undefined && (\r\n\t\t\t\t<TagIconWrapper\r\n\t\t\t\t\t$iconPosition={iconPosition}\r\n\t\t\t\t\t$isProduct={true}\r\n\t\t\t\t>\r\n\t\t\t\t\t<IconProduct\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\tsize={IconProductSize.big}\r\n\t\t\t\t\t\tstroke={color}\r\n\t\t\t\t\t\ttype={iconProduct}\r\n\t\t\t\t\t/>\r\n\t\t\t\t</TagIconWrapper>\r\n\t\t\t)}\r\n\t\t</TagStyled>\r\n\t);\r\n});\r\n\r\nTag.displayName = 'Tag';\r\n","import { type ElementType, type ReactElement, type ReactNode } from 'react';\r\n\r\nimport { type Spacing } from '@/theme';\r\n\r\nexport enum TabsVariant {\r\n\tinfoTags = 'infoTags',\r\n\tprimary = 'primary',\r\n\tsecondary = 'secondary',\r\n\ttertiary = 'tertiary',\r\n}\r\n\r\n/* eslint-disable perfectionist/sort-enums */\r\nexport enum TabsSize {\r\n\txs = 'xs',\r\n\tsm = 'sm',\r\n\tmd = 'md',\r\n\tlg = 'lg',\r\n}\r\n/* eslint-enable perfectionist/sort-enums */\r\n\r\nexport enum TabsActiveTabDefaultPosition {\r\n\tcenter = 'center',\r\n\tnoScrolling = 'noScrolling',\r\n\tscrollOnlyWhenNotVisible = 'scrollOnlyWhenNotVisible',\r\n}\r\n\r\nexport enum TabsWrap {\r\n\tnoWrap = 'noWrap',\r\n\t/**\r\n\t * Tabs wrap to the next line based on the container width instead of scrolling.\r\n\t * Each tab sizes according to its text content.\r\n\t * This option is intended only for {@link TabsVariant.infoTags}.\r\n\t * When enabled, {@link TabsActiveTabDefaultPosition} has no effect.\r\n\t */\r\n\twrap = 'wrap',\r\n}\r\n\r\nexport interface TabItemType {\r\n\tariaControls?: string;\r\n\tas?: ElementType;\r\n\thref?: string;\r\n\ticon?: ReactNode;\r\n\tid: string;\r\n\tisActive?: boolean;\r\n\tonActivate?: () => void;\r\n\ttext?: ReactElement | string;\r\n}\r\n\r\nexport interface TabsType {\r\n\tactiveTabDefaultPosition: TabsActiveTabDefaultPosition;\r\n\tfullWidth?: boolean;\r\n\t/**\r\n\t * Controls the gap between individual tab items.\r\n\t * Defaults to {@link Spacing.xxs}.\r\n\t */\r\n\tgap?: Spacing;\r\n\t/**\r\n\t * Removes the border and background from the tabs container.\r\n\t * Defaults to `false`.\r\n\t */\r\n\tnoBorder?: boolean;\r\n\t// if used, takes priority over default setting according to variant\r\n\tsize?: TabsSize;\r\n\ttabItems: TabItemType[];\r\n\tvariant: TabsVariant;\r\n\twrap?: TabsWrap;\r\n}\r\n","import { css, type Theme } from '@emotion/react';\r\n\r\nimport { ColorScheme } from '@/types';\r\nimport { pxToRem, styled, type ChooseColor } from '@/utils';\r\n\r\nimport { TabsSize, TabsVariant } from '../types';\r\n\r\nconst primarySpacing = (theme: Theme) => css`\r\n\tflex-direction: column;\r\n\tgap: ${theme.spacing.xs};\r\n\theight: ${pxToRem(76)};\r\n\r\n\t@media (min-width: ${theme.breakpoints.sm}) {\r\n\t\theight: ${pxToRem(88)};\r\n\t}\r\n`;\r\n\r\nconst secondarySpacing = (theme: Theme) => css`\r\n\tflex-direction: row;\r\n\tgap: ${theme.spacing.sm};\r\n\theight: ${pxToRem(40)};\r\n`;\r\n\r\nconst tertiarySpacing = (theme: Theme) => css`\r\n\tflex-direction: row;\r\n\tgap: ${theme.spacing.xxs};\r\n\theight: ${pxToRem(32)};\r\n`;\r\n\r\ninterface TabItemStyledProps {\r\n\t$chooseColor: ChooseColor;\r\n\t$fullWidth: boolean;\r\n\t$isActive: boolean;\r\n\t$variant: TabsVariant;\r\n\t/* TS hack: added to allow \"href\" when rendered as <a> via \"as\", since button normally doesn't accept it. */\r\n\thref?: string | undefined;\r\n}\r\n\r\nexport const TabItemStyled = styled.button<TabItemStyledProps>`\r\n\tall: unset;\r\n\tdisplay: flex;\r\n\tflex: 1;\r\n\twidth: ${({ $fullWidth }) => ($fullWidth === true ? '100%' : 'fit-content')};\r\n\tpadding-bottom: ${({ $variant }) => ($variant === TabsVariant.tertiary ? '0px' : '2px')};\r\n\tbackground: transparent;\r\n\tborder-top-left-radius: ${({ theme }) => theme.borderRadius.md};\r\n\tborder-top-right-radius: ${({ theme }) => theme.borderRadius.md};\r\n\tborder-bottom-right-radius: ${({ theme }) => theme.borderRadius.xs};\r\n\tborder-bottom-left-radius: ${({ theme }) => theme.borderRadius.xs};\r\n\r\n\t${({ $isActive, theme }) =>\r\n\t\t$isActive &&\r\n\t\tcss`\r\n\t\t\tbackground: ${`linear-gradient(270deg, ${theme.palette.pink600} 10.24%, ${theme.palette.blue600} 100%)`};\r\n\t\t`}\r\n\t&:focus-visible {\r\n\t\toutline-width: 3px;\r\n\t\toutline-style: solid;\r\n\t\toutline-color: ${({ $chooseColor, theme }) => $chooseColor(theme.colors.border.brand.bold)};\r\n\t\toutline-offset: 2px;\r\n\t}\r\n`;\r\n\r\ninterface ContentWrapperProps {\r\n\t$colorScheme: ColorScheme;\r\n\t$fullWidth: boolean;\r\n\t$isActive: boolean;\r\n\t$size: TabsSize | undefined;\r\n\t$variant: TabsVariant;\r\n}\r\n\r\nexport const ContentWrapper = styled.div<ContentWrapperProps>`\r\n\tbox-sizing: border-box;\r\n\tdisplay: flex;\r\n\tflex: 1;\r\n\tflex-shrink: 0;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\twidth: ${({ $fullWidth }) => ($fullWidth === true ? '100%' : 'fit-content')};\r\n\tmin-width: 80px;\r\n\tcursor: pointer;\r\n\tbackground: transparent;\r\n\tborder-radius: ${({ theme }) => theme.borderRadius.xs};\r\n\r\n\t@media (min-width: ${({ theme }) => theme.breakpoints.md}) {\r\n\t\tmin-width: 120px;\r\n\t}\r\n\r\n\t${({ $size, $variant, theme }) => {\r\n\t\tswitch (true) {\r\n\t\t\tcase $variant === TabsVariant.primary:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tpadding: ${theme.spacing.md};\r\n\r\n\t\t\t\t\t@media (min-width: ${theme.breakpoints.sm}) {\r\n\t\t\t\t\t\tpadding: ${theme.spacing.md} ${theme.spacing.lg};\r\n\t\t\t\t\t}\r\n\t\t\t\t`;\r\n\t\t\tcase $variant === TabsVariant.secondary && $size === undefined:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tpadding: ${theme.spacing.xs} ${theme.spacing.lg};\r\n\t\t\t\t`;\r\n\t\t\tcase $variant === TabsVariant.secondary && $size === TabsSize.xs:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tpadding: ${theme.spacing.xs} ${theme.spacing.xs};\r\n\t\t\t\t`;\r\n\t\t\tcase $variant === TabsVariant.secondary && $size === TabsSize.sm:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tpadding: ${theme.spacing.xs} ${theme.spacing.sm};\r\n\t\t\t\t`;\r\n\t\t\tcase $variant === TabsVariant.secondary && $size === TabsSize.md:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tpadding: ${theme.spacing.xs} ${theme.spacing.md};\r\n\t\t\t\t`;\r\n\t\t\tcase $variant === TabsVariant.secondary && $size === TabsSize.lg:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tpadding: ${theme.spacing.xs} ${theme.spacing.lg};\r\n\t\t\t\t`;\r\n\t\t\tcase $variant === TabsVariant.tertiary:\r\n\t\t\t\treturn css`\r\n\t\t\t\t\tpadding: ${theme.spacing.xxs} ${theme.spacing.sm};\r\n\t\t\t\t`;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected combination of TabsVariant and TabsSize');\r\n\t\t}\r\n\t}};\r\n\r\n\t${({ $colorScheme, $isActive, $variant, theme }) => {\r\n\t\tif ($variant === TabsVariant.primary) {\r\n\t\t\tif ($isActive) {\r\n\t\t\t\treturn css`\r\n\t\t\t\t\t${primarySpacing(theme)};\r\n\t\t\t\t\tbackground: ${theme.colors.surface.risen.light};\r\n\t\t\t\t\tbox-shadow: ${theme.shadow.box.sm};\r\n\t\t\t\t`;\r\n\t\t\t}\r\n\r\n\t\t\tif ($colorScheme === ColorScheme.dark) {\r\n\t\t\t\treturn css`\r\n\t\t\t\t\t${primarySpacing(theme)};\r\n\r\n\t\t\t\t\t&:hover {\r\n\t\t\t\t\t\tbackground: ${theme.colors.surface.risen.dark};\r\n\t\t\t\t\t\tbox-shadow: ${theme.shadow.box.sm};\r\n\t\t\t\t\t}\r\n\t\t\t\t`;\r\n\t\t\t}\r\n\r\n\t\t\treturn css`\r\n\t\t\t\t${primarySpacing(theme)};\r\n\r\n\t\t\t\t&:hover {\r\n\t\t\t\t\tbackground: ${theme.colors.surface.risen.light};\r\n\t\t\t\t\tbox-shadow: ${theme.shadow.box.sm};\r\n\t\t\t\t}\r\n\t\t\t`;\r\n\t\t}\r\n\r\n\t\tif ($variant === TabsVariant.secondary) {\r\n\t\t\tif ($isActive) {\r\n\t\t\t\treturn css`\r\n\t\t\t\t\t${secondarySpacing(theme)};\r\n\t\t\t\t\tbackground: ${theme.colors.surface.risen.light};\r\n\t\t\t\t\tbox-shadow: 0 0 8px 0 rgb(0 0 0 / 15%);\r\n\t\t\t\t`;\r\n\t\t\t}\r\n\r\n\t\t\tif ($colorScheme === ColorScheme.dark) {\r\n\t\t\t\treturn css`\r\n\t\t\t\t\t${secondarySpacing(theme)};\r\n\r\n\t\t\t\t\t&:hover {\r\n\t\t\t\t\t\tbackground: ${theme.colors.surface.risen.dark};\r\n\t\t\t\t\t\tbox-shadow: 0 0 8px 0 rgb(0 0 0 / 15%);\r\n\t\t\t\t\t}\r\n\t\t\t\t`;\r\n\t\t\t}\r\n\r\n\t\t\treturn css`\r\n\t\t\t\t${secondarySpacing(theme)};\r\n\r\n\t\t\t\t&:hover {\r\n\t\t\t\t\tbackground: ${theme.colors.surface.risen.light};\r\n\t\t\t\t\tbox-shadow: 0 0 8px 0 rgb(0 0 0 / 15%);\r\n\t\t\t\t}\r\n\t\t\t`;\r\n\t\t}\r\n\r\n\t\tif ($isActive && $colorScheme === ColorScheme.dark) {\r\n\t\t\treturn css`\r\n\t\t\t\t${tertiarySpacing(theme)};\r\n\t\t\t\tbackground: ${theme.colors.surface.risen.dark};\r\n\t\t\t\tborder: 1px solid ${theme.colors.border.neutral.subtle.dark};\r\n\t\t\t`;\r\n\t\t}\r\n\r\n\t\tif ($isActive) {\r\n\t\t\treturn css`\r\n\t\t\t\t${tertiarySpacing(theme)};\r\n\t\t\t\tbackground: ${theme.colors.bg.neutral.white.light};\r\n\t\t\t\tborder: 1px solid ${theme.colors.border.neutral.subtle.light};\r\n\t\t\t`;\r\n\t\t}\r\n\r\n\t\treturn css`\r\n\t\t\t${tertiarySpacing(theme)};\r\n\t\t`;\r\n\t}}\r\n`;\r\n\r\nexport const ActiveText = styled.span`\r\n\tcolor: transparent;\r\n\tbackground: ${({ theme }) => `linear-gradient(270deg, ${theme.palette.pink700} 10.24%, ${theme.palette.blue600} 100%)`};\r\n\tbackground-clip: text;\r\n`;\r\n","import { useTheme } from '@emotion/react';\r\nimport { type ElementType, type KeyboardEventHandler, type MouseEventHandler, type RefObject, useMemo } from 'react';\r\n\r\nimport { Typography, TypographyTextAlign, TypographyVariant } from '@/components/typography';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { FontWeight, WhiteSpace } from '@/theme';\r\n\r\nimport { type TabItemType, TabsSize, TabsVariant } from '../types';\r\n\r\nimport { ActiveText, ContentWrapper, TabItemStyled } from './TabsItem.style';\r\n\r\nexport interface TabsItemProps extends Omit<TabItemType, 'onActivate'>, DesignSystemBaseProps {\r\n\tas?: ElementType;\r\n\tfullWidth?: boolean;\r\n\thref?: string;\r\n\thtmlRef?: RefObject<HTMLButtonElement | null> | ((instance: HTMLButtonElement | null) => void);\r\n\tonClick?: MouseEventHandler<HTMLButtonElement> | undefined;\r\n\tonKeyDown?: KeyboardEventHandler<HTMLButtonElement> | undefined;\r\n\t// if used, takes priority over default setting according to variant\r\n\tsize?: TabsSize;\r\n\tvariant: TabsVariant;\r\n}\r\n\r\nexport const TabsItem = (props: TabsItemProps) => {\r\n\tconst { ariaControls, as, fullWidth = false, href, htmlRef, icon, id, isActive = false, onClick, onKeyDown, size, text, variant } = props;\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor, colorScheme } = useDesignSystem(props);\r\n\r\n\tconst typographyVariant = useMemo(() => {\r\n\t\tswitch (true) {\r\n\t\t\tcase size === TabsSize.lg:\r\n\t\t\t\treturn TypographyVariant.textLg;\r\n\t\t\tcase size === TabsSize.md:\r\n\t\t\t\treturn TypographyVariant.textMd;\r\n\t\t\tcase size === TabsSize.sm:\r\n\t\t\t\treturn TypographyVariant.textSm;\r\n\t\t\tcase size === TabsSize.xs:\r\n\t\t\t\treturn TypographyVariant.textXs;\r\n\t\t\tcase variant === TabsVariant.infoTags:\r\n\t\t\t\t// no relevance, Typography is not used in this variant\r\n\t\t\t\treturn TypographyVariant.textSm;\r\n\t\t\tcase size === undefined:\r\n\t\t\t\treturn variant === TabsVariant.tertiary ? TypographyVariant.textSm : TypographyVariant.textMd;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected TabsSize enum value');\r\n\t\t}\r\n\t}, [size, variant]);\r\n\r\n\treturn (\r\n\t\t<TabItemStyled\r\n\t\t\t$chooseColor={chooseColor}\r\n\t\t\t$fullWidth={fullWidth}\r\n\t\t\t$isActive={isActive && variant !== TabsVariant.tertiary}\r\n\t\t\t$variant={variant}\r\n\t\t\taria-controls={ariaControls}\r\n\t\t\taria-selected={isActive}\r\n\t\t\tas={as}\r\n\t\t\thref={href}\r\n\t\t\tid={id}\r\n\t\t\tref={htmlRef}\r\n\t\t\trole={'tab'}\r\n\t\t\ttabIndex={isActive ? 0 : -1}\r\n\t\t\ttype={'button'}\r\n\t\t\tonClick={onClick}\r\n\t\t\tonKeyDown={onKeyDown}\r\n\t\t>\r\n\t\t\t<ContentWrapper\r\n\t\t\t\t$colorScheme={colorScheme}\r\n\t\t\t\t$fullWidth={fullWidth}\r\n\t\t\t\t$isActive={isActive}\r\n\t\t\t\t$size={size}\r\n\t\t\t\t$variant={variant}\r\n\t\t\t>\r\n\t\t\t\t{icon !== undefined && icon}\r\n\r\n\t\t\t\t{isActive ? (\r\n\t\t\t\t\t<Typography\r\n\t\t\t\t\t\tcolor={variant === TabsVariant.tertiary ? chooseColor(theme.colors.fg.neutral.subtle) : theme.palette.transparent}\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\ttextAlign={TypographyTextAlign.center}\r\n\t\t\t\t\t\tvariant={typographyVariant}\r\n\t\t\t\t\t\tweight={FontWeight.medium500}\r\n\t\t\t\t\t\twhiteSpace={WhiteSpace.nowrap}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t{variant === TabsVariant.tertiary ? <>{text}</> : <ActiveText>{text}</ActiveText>}\r\n\t\t\t\t\t</Typography>\r\n\t\t\t\t) : (\r\n\t\t\t\t\t<Typography\r\n\t\t\t\t\t\tcolor={chooseColor(theme.colors.fg.neutral.subtle)}\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\ttextAlign={TypographyTextAlign.center}\r\n\t\t\t\t\t\tvariant={typographyVariant}\r\n\t\t\t\t\t\tweight={FontWeight.medium500}\r\n\t\t\t\t\t\twhiteSpace={WhiteSpace.nowrap}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t{text}\r\n\t\t\t\t\t</Typography>\r\n\t\t\t\t)}\r\n\t\t\t</ContentWrapper>\r\n\t\t</TabItemStyled>\r\n\t);\r\n};\r\n","import { css, type Theme } from '@emotion/react';\r\n\r\nimport { resolveSpacingValue, type Spacing } from '@/theme';\r\nimport { styled, type ChooseColor } from '@/utils';\r\n\r\nexport const Wrapper = styled.div`\r\n\tposition: relative;\r\n`;\r\n\r\nexport interface TabsWrapperProps {\r\n\t$wrap: boolean;\r\n}\r\n\r\nexport const TabsWrapper = styled.div<TabsWrapperProps>`\r\n\tdisplay: flex;\r\n\toverflow-y: ${({ $wrap }) => ($wrap ? 'visible' : 'auto')};\r\n`;\r\n\r\nexport interface TabItemsBoxProps {\r\n\t$chooseColor: ChooseColor;\r\n\t$fullWidth: boolean;\r\n\t$noBorder: boolean;\r\n\t$tabsSpacing: Spacing;\r\n\t$wrap: boolean;\r\n}\r\n\r\nexport const TabItemsBox = styled.div<TabItemsBoxProps>`\r\n\tbox-sizing: border-box;\r\n\tdisplay: flex;\r\n\tflex: 1 1 auto;\r\n\tflex-direction: row;\r\n\tflex-wrap: ${({ $wrap }) => ($wrap ? 'wrap' : 'nowrap')};\r\n\tgap: ${({ $tabsSpacing, theme }) => resolveSpacingValue(theme, $tabsSpacing)};\r\n\talign-items: center;\r\n\tjustify-content: flex-start;\r\n\tpadding: ${({ $noBorder, theme }) => ($noBorder ? '0' : theme.spacing.xxs)};\r\n\tbackground: ${({ $chooseColor, $noBorder, theme }) => ($noBorder ? 'transparent' : $chooseColor(theme.colors.surface.default))};\r\n\tborder: ${({ $chooseColor, $noBorder, theme }) => ($noBorder ? 'none' : `1px solid ${$chooseColor(theme.colors.border.neutral.subtlest)}`)};\r\n\tborder-radius: ${({ theme }) => theme.borderRadius.sm};\r\n\r\n\t${({ $fullWidth }) =>\r\n\t\t$fullWidth\r\n\t\t\t? ''\r\n\t\t\t: css`\r\n\t\t\t\t\tmax-width: max-content;\r\n\t\t\t\t`};\r\n`;\r\n\r\nconst arrowWrapper = css`\r\n\tposition: absolute;\r\n\ttop: 0;\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\theight: 100%;\r\n`;\r\n\r\nconst arrow = (theme: Theme) => css`\r\n\tposition: relative;\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\twidth: 2rem;\r\n\theight: 2rem;\r\n\tpadding: ${theme.spacing.xxs};\r\n\tcursor: pointer;\r\n\tbackground-color: ${theme.colors.icon.bg.light};\r\n\tborder-radius: ${theme.borderRadius.xs};\r\n\tbox-shadow: 0 4px 10px 0 rgb(0 0 0 / 10%);\r\n`;\r\n\r\nexport const LeftArrowWrapper = styled.div`\r\n\t${arrowWrapper};\r\n\tleft: ${({ theme }) => theme.spacing.xs};\r\n`;\r\n\r\nexport const LeftArrow = styled.div`\r\n\t${({ theme }) => arrow(theme)};\r\n`;\r\n\r\nexport const RightArrowWrapper = styled.div`\r\n\t${arrowWrapper};\r\n\tright: ${({ theme }) => theme.spacing.xs};\r\n`;\r\n\r\nexport const RightArrow = styled.div`\r\n\t${({ theme }) => arrow(theme)};\r\n`;\r\n","import { type KeyboardEventHandler, useCallback, useEffect, useMemo, useRef, useState } from 'react';\r\nimport { useDebounceCallback } from 'usehooks-ts';\r\n\r\nimport { IconSystem, IconSystemSize, IconSystemType } from '@/components/iconSystem';\r\nimport { Tag, TagSize, TagType } from '@/components/tag';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { FontWeight, Spacing, WhiteSpace } from '@/theme';\r\n\r\nimport { TabsItem } from './tabsItem/TabsItem';\r\nimport { TabsActiveTabDefaultPosition, TabsSize, type TabsType, TabsVariant, TabsWrap } from './types';\r\n\r\nimport { LeftArrow, LeftArrowWrapper, RightArrow, RightArrowWrapper, TabItemsBox, TabsWrapper, Wrapper } from './Tabs.style';\r\n\r\nconst scrollStep = 150; //px\r\nconst debounceDelay = 200; //ms\r\n\r\n// clientWidth or scrollWidth is not exactly\r\nconst scrollBalancingValue = 4; //px\r\n\r\nconst tagSizeMap: Record<TabsSize, TagSize> = {\r\n\t[TabsSize.xs]: TagSize.sm,\r\n\t[TabsSize.sm]: TagSize.sm,\r\n\t[TabsSize.md]: TagSize.md,\r\n\t[TabsSize.lg]: TagSize.md,\r\n};\r\n\r\nconst scrollActiveTabToCenter = (wrapperElement: HTMLDivElement, activeTabItemElement: HTMLElement) => {\r\n\twrapperElement.scrollLeft = activeTabItemElement.offsetLeft - (wrapperElement.offsetWidth - activeTabItemElement.offsetWidth) / 2;\r\n};\r\n\r\nconst makeActiveTabVisibleIfItIsNot = (wrapperElement: HTMLDivElement, activeTabItemElement: HTMLElement) => {\r\n\tconst elementRect = activeTabItemElement.getBoundingClientRect();\r\n\tconst containerRect = wrapperElement.getBoundingClientRect();\r\n\r\n\tif (elementRect.left < containerRect.left || elementRect.right > containerRect.right) {\r\n\t\twrapperElement.scrollLeft = activeTabItemElement.offsetLeft - wrapperElement.offsetLeft;\r\n\t}\r\n};\r\n\r\nexport interface TabsProps extends TabsType, DesignSystemBaseProps {}\r\n\r\n/**\r\n * This component implements accessibility for tabs according to W3C WAI-ARIA guidelines.\r\n * To ensure proper functionality, tab panels must also be described using ARIA attributes.\r\n *\r\n * More info: https://www.w3.org/WAI/ARIA/apg/patterns/tabs/examples/tabs-manual/\r\n */\r\nexport const Tabs = (props: TabsProps) => {\r\n\tconst { activeTabDefaultPosition, fullWidth = false, gap = Spacing.xxs, noBorder = false, size, tabItems, variant, wrap = TabsWrap.noWrap } = props;\r\n\r\n\tconst { chooseColor, colorScheme } = useDesignSystem(props);\r\n\r\n\tconst wrapperRef = useRef<HTMLDivElement>(null);\r\n\tconst tabItemsRef = useRef<(HTMLElement | null)[]>([]);\r\n\r\n\tconst [scrollLeft, setScrollLeft] = useState<number | undefined>(undefined);\r\n\r\n\tconst checkScrollPosition = useCallback(() => {\r\n\t\tconst element = wrapperRef.current;\r\n\t\tif (element === null) {\r\n\t\t\tthrow new Error('unexpected error tabs.tsx checkScrollPosition');\r\n\t\t}\r\n\r\n\t\tsetScrollLeft(element.scrollLeft);\r\n\t}, []);\r\n\r\n\tconst checkScrollPositionDebounced = useDebounceCallback(checkScrollPosition, debounceDelay, { maxWait: debounceDelay });\r\n\r\n\tuseEffect(() => {\r\n\t\tcheckScrollPosition();\r\n\t\tconst element = wrapperRef.current;\r\n\t\tif (element === null) {\r\n\t\t\tthrow new Error('unexpected error tabs.tsx');\r\n\t\t}\r\n\r\n\t\telement.addEventListener('scroll', checkScrollPositionDebounced);\r\n\r\n\t\treturn () => {\r\n\t\t\telement.removeEventListener('scroll', checkScrollPositionDebounced);\r\n\t\t};\r\n\t}, [checkScrollPosition, checkScrollPositionDebounced]);\r\n\r\n\tconst leftArrowClickHandler = useCallback(() => {\r\n\t\tconst element = wrapperRef.current;\r\n\t\tif (element === null) {\r\n\t\t\tthrow new Error('unexpected error tabs.tsx leftArrowClickHandler');\r\n\t\t}\r\n\r\n\t\telement.scrollTo({\r\n\t\t\tleft: element.scrollLeft - scrollStep > 0 ? element.scrollLeft - scrollStep : 0,\r\n\t\t\tbehavior: 'smooth',\r\n\t\t});\r\n\t}, []);\r\n\r\n\tconst rightArrowClickHandler = useCallback(() => {\r\n\t\tconst element = wrapperRef.current;\r\n\t\tif (element === null) {\r\n\t\t\tthrow new Error('unexpected error tabs.tsx rightArrowClickHandler');\r\n\t\t}\r\n\r\n\t\telement.scrollTo({\r\n\t\t\tleft: element.scrollLeft + scrollStep + element.clientWidth <= element.scrollWidth ? element.scrollLeft + scrollStep : element.scrollWidth,\r\n\t\t\tbehavior: 'smooth',\r\n\t\t});\r\n\t}, []);\r\n\r\n\tconst isWrap = wrap === TabsWrap.wrap;\r\n\tconst isLeftArrowShowing = !isWrap && scrollLeft !== undefined && scrollLeft > 0;\r\n\tconst isRightArrowShowing =\r\n\t\t!isWrap &&\r\n\t\tscrollLeft !== undefined &&\r\n\t\twrapperRef.current !== null &&\r\n\t\tscrollLeft + wrapperRef.current.clientWidth < wrapperRef.current.scrollWidth - scrollBalancingValue;\r\n\r\n\tconst activeTabIndex = useMemo<number | undefined>(() => {\r\n\t\tconst index = tabItems.findIndex((item) => {\r\n\t\t\treturn item.isActive === true;\r\n\t\t});\r\n\r\n\t\treturn index < 0 ? undefined : index;\r\n\t}, [tabItems]);\r\n\r\n\tuseEffect(() => {\r\n\t\tif (activeTabIndex === undefined) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst wrapperElement = wrapperRef.current;\r\n\t\tconst activeTabItemElement = tabItemsRef.current[activeTabIndex];\r\n\r\n\t\tif (wrapperElement === null || activeTabItemElement === null) {\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tif (tabItemsRef.current.includes(null)) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst tabItemsWidth = tabItemsRef.current.reduce((accumulator, currentValue) => {\r\n\t\t\tif (currentValue === null) {\r\n\t\t\t\tthrow new Error('unexpected null value in tabItems elements');\r\n\t\t\t}\r\n\r\n\t\t\treturn currentValue.offsetWidth + accumulator;\r\n\t\t}, 0);\r\n\r\n\t\tif (wrapperElement.offsetWidth > tabItemsWidth) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tswitch (activeTabDefaultPosition) {\r\n\t\t\tcase TabsActiveTabDefaultPosition.center:\r\n\t\t\t\tscrollActiveTabToCenter(wrapperElement, activeTabItemElement);\r\n\t\t\t\tbreak;\r\n\t\t\tcase TabsActiveTabDefaultPosition.scrollOnlyWhenNotVisible:\r\n\t\t\t\tmakeActiveTabVisibleIfItIsNot(wrapperElement, activeTabItemElement);\r\n\t\t\t\tbreak;\r\n\t\t\tcase TabsActiveTabDefaultPosition.noScrolling:\r\n\t\t\t\tbreak;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected value of TabsActiveTabDefaultPosition enum in tabs.tsx');\r\n\t\t}\r\n\t}, [activeTabDefaultPosition, activeTabIndex]);\r\n\r\n\tconst focusFirstTab = useCallback(() => {\r\n\t\ttabItemsRef.current[0]?.focus();\r\n\t}, []);\r\n\tconst focusLastTab = useCallback(() => {\r\n\t\ttabItemsRef.current[tabItemsRef.current.length - 1]?.focus();\r\n\t}, []);\r\n\r\n\tconst moveFocusToPreviousTab = useCallback(\r\n\t\t(element: HTMLElement) => {\r\n\t\t\tif (tabItemsRef.current[0] === element) {\r\n\t\t\t\tfocusLastTab();\r\n\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t\tconst index = tabItemsRef.current.indexOf(element);\r\n\t\t\ttabItemsRef.current[index - 1]?.focus();\r\n\t\t},\r\n\t\t[focusLastTab],\r\n\t);\r\n\r\n\tconst moveFocusToNextTab = useCallback(\r\n\t\t(element: HTMLElement) => {\r\n\t\t\tif (tabItemsRef.current[tabItemsRef.current.length - 1] === element) {\r\n\t\t\t\tfocusFirstTab();\r\n\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t\tconst index = tabItemsRef.current.indexOf(element);\r\n\t\t\ttabItemsRef.current[index + 1]?.focus();\r\n\t\t},\r\n\t\t[focusFirstTab],\r\n\t);\r\n\r\n\tconst handleKeydown = useCallback<KeyboardEventHandler<HTMLElement>>(\r\n\t\t(event) => {\r\n\t\t\tconst target = event.currentTarget;\r\n\t\t\tlet flag = false;\r\n\r\n\t\t\tswitch (event.key) {\r\n\t\t\t\tcase 'ArrowLeft':\r\n\t\t\t\t\tmoveFocusToPreviousTab(target);\r\n\t\t\t\t\tflag = true;\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase 'ArrowRight':\r\n\t\t\t\t\tmoveFocusToNextTab(target);\r\n\t\t\t\t\tflag = true;\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase 'Home':\r\n\t\t\t\t\tfocusFirstTab();\r\n\t\t\t\t\tflag = true;\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase 'End':\r\n\t\t\t\t\tfocusLastTab();\r\n\t\t\t\t\tflag = true;\r\n\t\t\t\t\tbreak;\r\n\r\n\t\t\t\tdefault:\r\n\t\t\t\t\tbreak;\r\n\t\t\t}\r\n\t\t\tif (flag) {\r\n\t\t\t\tevent.stopPropagation();\r\n\t\t\t\tevent.preventDefault();\r\n\t\t\t}\r\n\t\t},\r\n\t\t[focusFirstTab, focusLastTab, moveFocusToNextTab, moveFocusToPreviousTab],\r\n\t);\r\n\r\n\treturn (\r\n\t\t<Wrapper>\r\n\t\t\t<TabsWrapper\r\n\t\t\t\t$wrap={isWrap}\r\n\t\t\t\taria-orientation={'horizontal'}\r\n\t\t\t\tref={wrapperRef}\r\n\t\t\t\trole={'tablist'}\r\n\t\t\t>\r\n\t\t\t\t<TabItemsBox\r\n\t\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t\t$fullWidth={fullWidth}\r\n\t\t\t\t\t$noBorder={noBorder}\r\n\t\t\t\t\t$tabsSpacing={gap}\r\n\t\t\t\t\t$wrap={isWrap}\r\n\t\t\t\t>\r\n\t\t\t\t\t{tabItems.map((item, tabItemIndex) => {\r\n\t\t\t\t\t\tif (variant === TabsVariant.infoTags) {\r\n\t\t\t\t\t\t\tconst tagSize = size === undefined ? undefined : tagSizeMap[size];\r\n\r\n\t\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t\t<Tag\r\n\t\t\t\t\t\t\t\t\tkey={item.id}\r\n\t\t\t\t\t\t\t\t\taria-controls={item.ariaControls}\r\n\t\t\t\t\t\t\t\t\tas={item.as}\r\n\t\t\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\t\t\tfontWeight={item.isActive === true ? FontWeight.semiBold600 : FontWeight.regular400}\r\n\t\t\t\t\t\t\t\t\thref={item.href}\r\n\t\t\t\t\t\t\t\t\tref={(tabItem) => {\r\n\t\t\t\t\t\t\t\t\t\ttabItemsRef.current[tabItemIndex] = tabItem;\r\n\t\t\t\t\t\t\t\t\t}}\r\n\t\t\t\t\t\t\t\t\trole={'tab'}\r\n\t\t\t\t\t\t\t\t\tsize={tagSize}\r\n\t\t\t\t\t\t\t\t\ttabIndex={item.isActive === true ? 0 : -1}\r\n\t\t\t\t\t\t\t\t\ttype={TagType.info}\r\n\t\t\t\t\t\t\t\t\twhiteSpace={WhiteSpace.nowrap}\r\n\t\t\t\t\t\t\t\t\tonClick={item.onActivate}\r\n\t\t\t\t\t\t\t\t\tonKeyDown={handleKeydown}\r\n\t\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t\t{item.text}\r\n\t\t\t\t\t\t\t\t</Tag>\r\n\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t}\r\n\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<TabsItem\r\n\t\t\t\t\t\t\t\tkey={item.id}\r\n\t\t\t\t\t\t\t\tariaControls={item.ariaControls}\r\n\t\t\t\t\t\t\t\tas={item.as}\r\n\t\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\t\tfullWidth={fullWidth}\r\n\t\t\t\t\t\t\t\thref={item.href}\r\n\t\t\t\t\t\t\t\thtmlRef={(tabItem) => (tabItemsRef.current[tabItemIndex] = tabItem)}\r\n\t\t\t\t\t\t\t\ticon={item.icon}\r\n\t\t\t\t\t\t\t\tid={item.id}\r\n\t\t\t\t\t\t\t\tisActive={item.isActive}\r\n\t\t\t\t\t\t\t\tsize={size}\r\n\t\t\t\t\t\t\t\ttext={item.text}\r\n\t\t\t\t\t\t\t\tvariant={variant}\r\n\t\t\t\t\t\t\t\tonClick={item.onActivate}\r\n\t\t\t\t\t\t\t\tonKeyDown={handleKeydown}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t})}\r\n\t\t\t\t</TabItemsBox>\r\n\t\t\t</TabsWrapper>\r\n\t\t\t{isLeftArrowShowing && (\r\n\t\t\t\t<LeftArrowWrapper>\r\n\t\t\t\t\t<LeftArrow onClick={leftArrowClickHandler}>\r\n\t\t\t\t\t\t<IconSystem\r\n\t\t\t\t\t\t\tsize={IconSystemSize.big}\r\n\t\t\t\t\t\t\ttype={IconSystemType.chevronLeft}\r\n\t\t\t\t\t\t/>\r\n\t\t\t\t\t</LeftArrow>\r\n\t\t\t\t</LeftArrowWrapper>\r\n\t\t\t)}\r\n\t\t\t{isRightArrowShowing && (\r\n\t\t\t\t<RightArrowWrapper>\r\n\t\t\t\t\t<RightArrow onClick={rightArrowClickHandler}>\r\n\t\t\t\t\t\t<IconSystem\r\n\t\t\t\t\t\t\tsize={IconSystemSize.big}\r\n\t\t\t\t\t\t\ttype={IconSystemType.chevronRight}\r\n\t\t\t\t\t\t/>\r\n\t\t\t\t\t</RightArrow>\r\n\t\t\t\t</RightArrowWrapper>\r\n\t\t\t)}\r\n\t\t</Wrapper>\r\n\t);\r\n};\r\n","import { getClampedFontSize, styled } from '@/utils';\r\n\r\ninterface TextAreaStyledProps {\r\n\t$invalid: boolean;\r\n}\r\n\r\nexport const TextAreaStyled = styled.textarea<TextAreaStyledProps>`\r\n\tbox-sizing: border-box;\r\n\twidth: 100%;\r\n\tmin-height: 7.75rem;\r\n\tpadding: ${({ theme }) => theme.spacing.sm};\r\n\tfont-family: ${({ theme }) => theme.font.family.main};\r\n\tfont-size: ${({ theme }) => getClampedFontSize(theme.font.size.body.md)};\r\n\tline-height: ${({ theme }) => theme.font.lineHeight.body.md};\r\n\tletter-spacing: ${({ theme }) => theme.font.letterSpacing.body.sm};\r\n\tresize: vertical;\r\n\tbackground: ${({ theme }) => theme.palette.white};\r\n\tborder-color: ${({ $invalid, theme }) => ($invalid ? theme.colors.border.error.dark : theme.colors.border.neutral.subtlest.dark)};\r\n\tborder-width: ${({ $invalid }) => ($invalid ? '2px' : '1px')};\r\n\tborder-radius: ${({ theme }) => theme.borderRadius.xs};\r\n\r\n\t&:focus {\r\n\t\toutline: none;\r\n\t\tborder-color: ${({ $invalid, theme }) => ($invalid ? theme.colors.border.error.dark : theme.colors.border.brand.default.dark)};\r\n\t\tbox-shadow: ${({ $invalid, theme }) =>\r\n\t\t\t$invalid\r\n\t\t\t\t? `0px 0 0 2px ${theme.palette.white}, 0 0 0 5px ${theme.colors.border.error.dark}`\r\n\t\t\t\t: `0px 0 0 2px ${theme.palette.white}, 0 0 0 5px ${theme.colors.border.brand.bold.dark}`};\r\n\t}\r\n\r\n\t&:disabled {\r\n\t\tcolor: ${({ theme }) => theme.colors.fg.neutral.subtlest.dark};\r\n\t\tcursor: not-allowed;\r\n\t\tbackground: ${({ theme }) => theme.colors.bg.disabled.light};\r\n\t\tborder: 1px solid ${({ theme }) => theme.colors.border.disabled.light};\r\n\t}\r\n`;\r\n","import { type ComponentProps, forwardRef, type TextareaHTMLAttributes } from 'react';\r\n\r\nimport { withFieldWrapper } from '@/components/fieldWrapper';\r\nimport { type FieldControlProps } from '@/types';\r\n\r\nimport { TextAreaStyled } from './TextArea.style';\r\n\r\nexport interface TextAreaControlProps extends TextareaHTMLAttributes<HTMLTextAreaElement>, FieldControlProps {}\r\n\r\nconst TextAreaControl = forwardRef<HTMLTextAreaElement, TextAreaControlProps>((props, ref) => {\r\n\tconst {\r\n\t\tcolorScheme, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\tdescribedBy,\r\n\t\tinvalid = false,\r\n\t\tlabelledBy,\r\n\t\tmediaType, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\trequired,\r\n\t\t...otherProps\r\n\t} = props;\r\n\r\n\treturn (\r\n\t\t<TextAreaStyled\r\n\t\t\t$invalid={invalid}\r\n\t\t\taria-describedby={describedBy}\r\n\t\t\taria-invalid={invalid}\r\n\t\t\taria-labelledby={labelledBy}\r\n\t\t\taria-required={required}\r\n\t\t\tref={ref}\r\n\t\t\t{...otherProps}\r\n\t\t/>\r\n\t);\r\n});\r\n\r\nTextAreaControl.displayName = 'TextAreaControl';\r\n\r\nexport const TextArea = withFieldWrapper<TextAreaControlProps, HTMLTextAreaElement>(TextAreaControl);\r\n\r\nexport type TextAreaProps = ComponentProps<typeof TextArea>;\r\n","import { type ComponentProps, forwardRef } from 'react';\r\n\r\nimport { withFieldWrapper } from '@/components/fieldWrapper';\r\nimport { type IconSystemType } from '@/components/iconSystem';\r\nimport { InputBase } from '@/components/inputBase';\r\nimport { type InputProps } from '@/types';\r\n\r\nexport interface TextInputControlProps extends InputProps {\r\n\ticonSystem?: IconSystemType;\r\n\tplaceholder?: string;\r\n}\r\n\r\nconst TextInputControl = forwardRef<HTMLInputElement, TextInputControlProps>((props, ref) => {\r\n\treturn (\r\n\t\t<InputBase\r\n\t\t\tref={ref}\r\n\t\t\ttype=\"text\"\r\n\t\t\t{...props}\r\n\t\t/>\r\n\t);\r\n});\r\n\r\nTextInputControl.displayName = 'TextInputControl';\r\n\r\nexport const TextInput = withFieldWrapper<TextInputControlProps, HTMLInputElement>(TextInputControl);\r\n\r\nexport type TextInputProps = ComponentProps<typeof TextInput>;\r\n","import { css } from '@emotion/react';\r\n\r\nimport { styled } from '@/utils';\r\n\r\ninterface WrapperProps {\r\n\t$checked?: boolean;\r\n\t$disabled?: boolean;\r\n}\r\n\r\nexport const Wrapper = styled.div<WrapperProps>`\r\n\tdisplay: flex;\r\n\tflex-direction: row;\r\n\tgap: ${({ theme }) => theme.spacing.xs};\r\n\talign-items: center;\r\n\tjustify-content: flex-start;\r\n\r\n\tinput {\r\n\t\tposition: relative;\r\n\t\tappearance: initial;\r\n\t\toutline: none;\r\n\t\tbox-shadow: none;\r\n\t\ttransform: scale(0.5);\r\n\r\n\t\t&:focus-visible {\r\n\t\t\tposition: absolute;\r\n\t\t\ttop: 6.5px;\r\n\t\t\tleft: 10px;\r\n\t\t\tz-index: -1;\r\n\t\t\twidth: 0;\r\n\t\t\theight: 0;\r\n\t\t\tpadding: 0;\r\n\t\t\tmargin: -1px;\r\n\t\t\toverflow: initial !important;\r\n\t\t\t/* stylelint-disable-next-line property-no-deprecated */\r\n\t\t\tclip: auto !important;\r\n\r\n\t\t\t&::before {\r\n\t\t\t\tposition: absolute;\r\n\t\t\t\tdisplay: block;\r\n\t\t\t\twidth: 38px;\r\n\t\t\t\theight: 21.5px;\r\n\t\t\t\toutline: none;\r\n\t\t\t\toutline-width: 3px;\r\n\t\t\t\toutline-style: solid;\r\n\t\t\t\toutline-color: ${({ theme }) => theme.colors.border.brand.bold.light};\r\n\t\t\t\toutline-offset: 3px;\r\n\t\t\t\tcontent: '';\r\n\t\t\t\tborder: none;\r\n\t\t\t\tborder-radius: ${({ theme }) => theme.borderRadius.md};\r\n\t\t\t\ttransform: scale(2);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t.react-switch-bg {\r\n\t\tborder: 1px solid ${({ theme }) => theme.colors.border.neutral.subtle.light};\r\n\t}\r\n\r\n\t.react-switch-handle {\r\n\t\t/* have to use !important here bc of component transition styles */\r\n\t\tborder: 1px solid ${({ theme }) => theme.colors.border.neutral.subtle.light}!important;\r\n\t\tbox-shadow: ${({ theme }) => theme.shadow.border.sm};\r\n\t}\r\n\r\n\t${({ $checked, theme }) =>\r\n\t\t$checked === true &&\r\n\t\tcss`\r\n\t\t\t.react-switch-bg {\r\n\t\t\t\tborder: 1px solid ${theme.colors.border.brand.bold.light};\r\n\t\t\t}\r\n\r\n\t\t\t.react-switch-handle {\r\n\t\t\t\t/* have to use !important here bc of component transition styles */\r\n\t\t\t\tborder: 1px solid ${theme.colors.bg.neutral.white.light}!important;\r\n\t\t\t}\r\n\r\n\t\t\t&:hover {\r\n\t\t\t\t.react-switch {\r\n\t\t\t\t\t.react-switch-bg {\r\n\t\t\t\t\t\tbackground-color: ${theme.colors.bg.brand.bold.hover.light}!important;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t`};\r\n\r\n\t${({ $disabled, theme }) =>\r\n\t\t$disabled === true &&\r\n\t\tcss`\r\n\t\t\t.react-switch-bg {\r\n\t\t\t\tborder: 1px solid ${theme.colors.border.neutral.subtlest.light};\r\n\t\t\t}\r\n\r\n\t\t\t.react-switch-handle {\r\n\t\t\t\t/* have to use !important here bc of component transition styles */\r\n\t\t\t\tborder: 1px solid ${theme.colors.border.neutral.subtlest.light}!important;\r\n\t\t\t}\r\n\t\t`};\r\n`;\r\n\r\nexport const LabelStyled = styled.label`\r\n\tcursor: pointer;\r\n`;\r\n","import { type ComponentProps, forwardRef, type ReactNode } from 'react';\r\n\r\nimport { withFieldWrapper } from '@/components/fieldWrapper';\r\nimport { type InputProps, InputTextAlign } from '@/types';\r\n\r\nimport { InputBase } from '../inputBase';\r\n\r\nexport interface TrailingTextInputControlProps extends InputProps {\r\n\tplaceholder?: string;\r\n\tsuffix?: ReactNode;\r\n}\r\n\r\nconst TrailingTextInputControl = forwardRef<HTMLInputElement, TrailingTextInputControlProps>((props, ref) => {\r\n\treturn (\r\n\t\t<InputBase\r\n\t\t\tref={ref}\r\n\t\t\ttextAlign={InputTextAlign.right}\r\n\t\t\ttype=\"text\"\r\n\t\t\t{...props}\r\n\t\t/>\r\n\t);\r\n});\r\n\r\nTrailingTextInputControl.displayName = 'TrailingTextInputControl';\r\n\r\nexport const TrailingTextInput = withFieldWrapper<TrailingTextInputControlProps, HTMLInputElement>(TrailingTextInputControl);\r\n\r\nexport type TrailingTextInputProps = ComponentProps<typeof TrailingTextInput>;\r\n","export enum ReCaptchaErrorType {\r\n\tinstanceNotInitialized = 'instanceNotInitialized',\r\n\tscriptLoading = 'scriptLoading',\r\n}\r\n\r\nexport class ReCaptchaError extends Error {\r\n\tpublic readonly type: ReCaptchaErrorType;\r\n\r\n\tconstructor(type: ReCaptchaErrorType) {\r\n\t\tlet message: string;\r\n\r\n\t\tswitch (type) {\r\n\t\t\tcase ReCaptchaErrorType.instanceNotInitialized:\r\n\t\t\t\tmessage = 'Google reCAPTCHA v3 is not initialized.';\r\n\t\t\t\tbreak;\r\n\t\t\tcase ReCaptchaErrorType.scriptLoading:\r\n\t\t\t\tmessage = 'Google reCAPTCHA v3 script is still loading.';\r\n\t\t\t\tbreak;\r\n\t\t\tdefault:\r\n\t\t\t\tmessage = 'Unknown Google reCAPTCHA error.';\r\n\t\t}\r\n\r\n\t\tsuper(message);\r\n\t\tthis.type = type;\r\n\t\tthis.name = 'ReCaptchaError';\r\n\t}\r\n}\r\n","import { type Formatter } from 'afformative';\r\nimport { type BaseSyntheticEvent, type ReactNode } from 'react';\r\nimport { type FieldValues } from 'react-hook-form';\r\n\r\nimport { type IconProductType } from '@/components/iconProduct';\r\n\r\nexport interface ThrownFieldLevelError {\r\n\tcode: string;\r\n\tfieldName: string;\r\n\tmessage: string;\r\n}\r\n\r\nexport enum ThrownFormLevelErrorType {\r\n\t/**\r\n\t * Used for displaying custom application-specific errors.\r\n\t *\r\n\t * Pass additional info in the `meta` property and consume it in using `thrownFormLevelErrorFormatter`.\r\n\t * Make sure to extend `ThrownFormLevelErrorMeta` via declaration merging.\r\n\t */\r\n\tapplication = 'application',\r\n\t/** Indicates that an unknown error occurred, just like an HTTP 500 status code. */\r\n\tgeneric = 'generic',\r\n\t/** Indicates that an error occured due to a request timing out. */\r\n\ttimeout = 'timeout',\r\n}\r\n\r\nexport interface ThrownFormLevelErrorMeta {}\r\n\r\nexport interface ThrownFormLevelError {\r\n\tmeta?: ThrownFormLevelErrorMeta;\r\n\ttype: ThrownFormLevelErrorType;\r\n}\r\n\r\nexport interface ThrownFormErrors {\r\n\tfieldLevelErrors: ThrownFieldLevelError[];\r\n\tformLevelErrors: ThrownFormLevelError[];\r\n}\r\n\r\nexport interface ThrownFormLevelErrorFormatterOutput {\r\n\tdescription: ReactNode;\r\n\ticonProduct?: IconProductType;\r\n\ttitle: ReactNode;\r\n}\r\n\r\nexport type ThrownFieldLevelErrorFormatter = Formatter<ThrownFieldLevelError, ReactNode, string>;\r\nexport type ThrownFormLevelErrorFormatter = Formatter<ThrownFormLevelError, ReactNode | ThrownFormLevelErrorFormatterOutput, string>;\r\n\r\nexport interface ReCaptchaV3Config {\r\n\tisEnabled: boolean;\r\n\tisEnterprise: boolean;\r\n\tsiteKey: string;\r\n}\r\n\r\nexport enum CaptchaType {\r\n\treCaptchaV3 = 'reCaptchaV3',\r\n}\r\n\r\nexport interface SubmitHandlerErrorInfo {\r\n\tcaptchaToken?: string;\r\n\ttimings: {\r\n\t\tcaptchaExecuteEnd?: number;\r\n\t\tcaptchaExecuteStart?: number;\r\n\t\tsubmitEnd?: number;\r\n\t\tsubmitStart?: number;\r\n\t};\r\n}\r\n\r\nexport interface FormConfig {\r\n\tonSubmitHandlerError?: (error: unknown, errorInfo: SubmitHandlerErrorInfo) => void;\r\n\treCaptchaV3Config?: ReCaptchaV3Config;\r\n\tresolveThrownFormErrors?: (error: unknown) => ThrownFormErrors;\r\n\tthrownFieldLevelErrorFormatter?: ThrownFieldLevelErrorFormatter;\r\n\tthrownFormLevelErrorFormatter?: ThrownFormLevelErrorFormatter;\r\n}\r\n\r\nexport interface SubmitHandlerExtraParam {\r\n\tcaptchaToken?: string;\r\n}\r\n\r\nexport type SubmitHandler<TFieldValues extends FieldValues> = (\r\n\tdata: TFieldValues,\r\n\textraParam: SubmitHandlerExtraParam,\r\n\tevent?: BaseSyntheticEvent,\r\n\t// eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\r\n) => Promise<unknown> | unknown;\r\n","import { checkGoogleReCaptchaInjected, injectGoogleReCaptchaScript } from '@google-recaptcha/core';\r\nimport { zodResolver } from '@hookform/resolvers/zod';\r\nimport { type BaseSyntheticEvent, useCallback, useContext, useEffect, useRef, useState } from 'react';\r\nimport {\r\n\ttype FieldValues,\r\n\ttype Path,\r\n\ttype SubmitHandler as ReactHookFormSubmitHandler,\r\n\ttype Resolver,\r\n\ttype SubmitErrorHandler,\r\n\tuseForm as useReactHookForm,\r\n\ttype UseFormProps as UseReactHookFormProps,\r\n\ttype UseFormReturn as UseReactHookFormReturn,\r\n} from 'react-hook-form';\r\nimport { type z } from 'zod';\r\n\r\nimport { FormConfigContext } from './contexts';\r\nimport { ReCaptchaError, ReCaptchaErrorType } from './errors';\r\nimport { CaptchaType, type FormConfig, type SubmitHandler, type ThrownFormErrors, ThrownFormLevelErrorType } from './types';\r\n\r\nconst defaultThrownFormErrors: ThrownFormErrors = {\r\n\tformLevelErrors: [],\r\n\tfieldLevelErrors: [],\r\n};\r\n\r\nconst genericThrownFormErrors: ThrownFormErrors = {\r\n\tformLevelErrors: [{ type: ThrownFormLevelErrorType.generic }],\r\n\tfieldLevelErrors: [],\r\n};\r\n\r\nconst defaultResolveThrownFormErrors = () => genericThrownFormErrors;\r\n\r\nexport interface UseFormCaptchaProp {\r\n\taction: string;\r\n\ttype: CaptchaType;\r\n}\r\n\r\nexport interface UseFormProps<TFieldValues extends FieldValues>\r\n\textends\r\n\t\tUseReactHookFormProps<TFieldValues>,\r\n\t\tPick<FormConfig, 'onSubmitHandlerError' | 'reCaptchaV3Config' | 'resolveThrownFormErrors' | 'thrownFieldLevelErrorFormatter'> {\r\n\tcaptcha?: UseFormCaptchaProp;\r\n\t// TODO: Improve type once we start using Zod v4 everywhere. `UseFormProps` should also accept `TSubmitValues`.\r\n\tschema?: z.ZodType;\r\n}\r\n\r\nexport type UseFormHandleSubmit<TFieldValues extends FieldValues, TSubmitValues extends FieldValues | undefined = undefined> = (\r\n\tonValid: TSubmitValues extends FieldValues ? SubmitHandler<TSubmitValues> : SubmitHandler<TFieldValues>,\r\n\tonInvalid?: SubmitErrorHandler<TFieldValues>,\r\n) => (event?: BaseSyntheticEvent) => Promise<void>;\r\n\r\nexport type UseFormReturn<TFieldValues extends FieldValues, TSubmitValues extends FieldValues | undefined = undefined> = Omit<\r\n\t// eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n\tUseReactHookFormReturn<TFieldValues, any, TSubmitValues>,\r\n\t'handleSubmit'\r\n> & {\r\n\thandleSubmit: UseFormHandleSubmit<TFieldValues, TSubmitValues>;\r\n\tthrownFormErrors: ThrownFormErrors;\r\n};\r\n\r\n/**\r\n * `TFieldValues` represents the shape of the field values at any given time, whereas `TSubmitValues` represents the form values\r\n * received by the submit handler.\r\n *\r\n * If `schema` is provided, `TFieldValues` must be assignable to the schema input type, and `TSubmitValues` should exactly\r\n * match the schema output type.\r\n *\r\n * If `defaultValues` are not provided, `TFieldValues` should be something like `DeepPartial<TSubmitValues>`.\r\n *\r\n * If enabled using the `captcha` prop, automatically performs Google reCAPTCHA verification when submitting a form.\r\n * The reCAPTCHA token is passed to the submit handler.\r\n */\r\nexport const useForm = <TFieldValues extends FieldValues, TSubmitValues extends FieldValues | undefined = undefined>(\r\n\tprops: UseFormProps<TFieldValues> = {},\r\n): UseFormReturn<TFieldValues, TSubmitValues> => {\r\n\tconst formConfig = useContext(FormConfigContext);\r\n\r\n\tconst {\r\n\t\tcaptcha: captchaProp,\r\n\t\tonSubmitHandlerError = formConfig.onSubmitHandlerError,\r\n\t\treCaptchaV3Config = formConfig.reCaptchaV3Config,\r\n\t\tresolveThrownFormErrors = formConfig.resolveThrownFormErrors ?? defaultResolveThrownFormErrors,\r\n\t\tschema,\r\n\t\tthrownFieldLevelErrorFormatter = formConfig.thrownFieldLevelErrorFormatter,\r\n\t\t...otherProps\r\n\t} = props;\r\n\r\n\tconst [thrownFormErrors, setThrownFormErrors] = useState<ThrownFormErrors>(defaultThrownFormErrors);\r\n\r\n\tconst isReCaptchaV3Enabled = reCaptchaV3Config?.isEnabled === true && captchaProp?.type === CaptchaType.reCaptchaV3;\r\n\tconst [isReCaptchaScriptLoading, setIsReCaptchaScriptLoading] = useState<boolean>(isReCaptchaV3Enabled);\r\n\r\n\t// inject reCaptcha script (if not already present)\r\n\tuseEffect(() => {\r\n\t\tif (!isReCaptchaV3Enabled) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tif (checkGoogleReCaptchaInjected()) {\r\n\t\t\tsetIsReCaptchaScriptLoading(false);\r\n\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tinjectGoogleReCaptchaScript({\r\n\t\t\tisEnterprise: reCaptchaV3Config.isEnterprise,\r\n\t\t\trender: reCaptchaV3Config.siteKey,\r\n\t\t\tid: `google-recaptcha-v3-script`,\r\n\t\t\tonload: () => {\r\n\t\t\t\tsetIsReCaptchaScriptLoading(false);\r\n\t\t\t},\r\n\t\t});\r\n\t}, [isReCaptchaV3Enabled, reCaptchaV3Config]);\r\n\r\n\tconst form = useReactHookForm({\r\n\t\tmode: 'onSubmit',\r\n\t\treValidateMode: 'onBlur',\r\n\t\tshouldFocusError: false,\r\n\t\t// We'll type this better once we drop support for Zod v3.\r\n\t\t// eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n\t\t...(schema && { resolver: zodResolver(schema as any) as Resolver<TFieldValues> }),\r\n\t\t...otherProps,\r\n\t});\r\n\r\n\tconst { control, setError } = form;\r\n\r\n\tconst handleSubmitRef = useRef(form.handleSubmit);\r\n\tconst reactHookFormHandleSubmit = handleSubmitRef.current;\r\n\r\n\tconst handleSubmit = useCallback<UseFormHandleSubmit<TFieldValues, TSubmitValues>>(\r\n\t\t(onValid, onInvalid) => {\r\n\t\t\tconst handleValid: ReactHookFormSubmitHandler<TFieldValues> = async (data, event) => {\r\n\t\t\t\tlet submitStart: number | undefined;\r\n\t\t\t\tlet submitEnd: number | undefined;\r\n\t\t\t\tlet captchaExecuteStart: number | undefined;\r\n\t\t\t\tlet captchaExecuteEnd: number | undefined;\r\n\r\n\t\t\t\tlet captchaToken: string | undefined;\r\n\r\n\t\t\t\ttry {\r\n\t\t\t\t\tsetThrownFormErrors(defaultThrownFormErrors);\r\n\r\n\t\t\t\t\tif (isReCaptchaV3Enabled) {\r\n\t\t\t\t\t\tif (isReCaptchaScriptLoading) {\r\n\t\t\t\t\t\t\tthrow new ReCaptchaError(ReCaptchaErrorType.scriptLoading);\r\n\t\t\t\t\t\t}\r\n\r\n\t\t\t\t\t\tconst reCaptchaInstance = reCaptchaV3Config.isEnterprise ? window.grecaptcha?.enterprise : window.grecaptcha;\r\n\r\n\t\t\t\t\t\tif (reCaptchaInstance?.execute === undefined) {\r\n\t\t\t\t\t\t\tthrow new ReCaptchaError(ReCaptchaErrorType.instanceNotInitialized);\r\n\t\t\t\t\t\t}\r\n\r\n\t\t\t\t\t\tcaptchaExecuteStart = Date.now();\r\n\t\t\t\t\t\tcaptchaToken = await reCaptchaInstance.execute(reCaptchaV3Config.siteKey, { action: captchaProp.action });\r\n\t\t\t\t\t\tcaptchaExecuteEnd = Date.now();\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\ttry {\r\n\t\t\t\t\t\tsubmitStart = Date.now();\r\n\r\n\t\t\t\t\t\treturn await onValid(data, { captchaToken: captchaToken }, event);\r\n\t\t\t\t\t} catch (error) {\r\n\t\t\t\t\t\tsubmitEnd = Date.now();\r\n\r\n\t\t\t\t\t\tconst nextThrownFormErrors = resolveThrownFormErrors(error);\r\n\t\t\t\t\t\tconst matchedFieldLevelErrors = nextThrownFormErrors.fieldLevelErrors.filter(({ fieldName }) => control._names.mount.has(fieldName));\r\n\r\n\t\t\t\t\t\tconst normalizedThrownFormErrors =\r\n\t\t\t\t\t\t\tmatchedFieldLevelErrors.length > 0\r\n\t\t\t\t\t\t\t\t? nextThrownFormErrors\r\n\t\t\t\t\t\t\t\t: {\r\n\t\t\t\t\t\t\t\t\t\tformLevelErrors:\r\n\t\t\t\t\t\t\t\t\t\t\tnextThrownFormErrors.formLevelErrors.length > 0 ? nextThrownFormErrors.formLevelErrors : genericThrownFormErrors.formLevelErrors,\r\n\t\t\t\t\t\t\t\t\t\tfieldLevelErrors: [],\r\n\t\t\t\t\t\t\t\t\t};\r\n\r\n\t\t\t\t\t\tnormalizedThrownFormErrors.fieldLevelErrors.forEach((fieldLevelError) => {\r\n\t\t\t\t\t\t\tconst reactHookFormError = {\r\n\t\t\t\t\t\t\t\tmessage: thrownFieldLevelErrorFormatter?.formatAsPrimitive(fieldLevelError) ?? fieldLevelError.message,\r\n\t\t\t\t\t\t\t\ttype: 'custom',\r\n\t\t\t\t\t\t\t} as const;\r\n\r\n\t\t\t\t\t\t\tsetError(fieldLevelError.fieldName as Path<TFieldValues>, reactHookFormError, { shouldFocus: false });\r\n\t\t\t\t\t\t});\r\n\r\n\t\t\t\t\t\tsetThrownFormErrors(normalizedThrownFormErrors);\r\n\r\n\t\t\t\t\t\tthrow error;\r\n\t\t\t\t\t}\r\n\t\t\t\t} catch (error) {\r\n\t\t\t\t\tonSubmitHandlerError?.(error, {\r\n\t\t\t\t\t\tcaptchaToken: captchaToken,\r\n\t\t\t\t\t\ttimings: {\r\n\t\t\t\t\t\t\tsubmitStart: submitStart,\r\n\t\t\t\t\t\t\tsubmitEnd: submitEnd,\r\n\t\t\t\t\t\t\tcaptchaExecuteStart: captchaExecuteStart,\r\n\t\t\t\t\t\t\tcaptchaExecuteEnd: captchaExecuteEnd,\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t});\r\n\r\n\t\t\t\t\tconsole.error(error);\r\n\t\t\t\t}\r\n\t\t\t};\r\n\r\n\t\t\treturn reactHookFormHandleSubmit(handleValid, onInvalid);\r\n\t\t},\r\n\t\t[\r\n\t\t\tcaptchaProp?.action,\r\n\t\t\tcontrol._names.mount,\r\n\t\t\tisReCaptchaScriptLoading,\r\n\t\t\tisReCaptchaV3Enabled,\r\n\t\t\tonSubmitHandlerError,\r\n\t\t\treCaptchaV3Config?.isEnterprise,\r\n\t\t\treCaptchaV3Config?.siteKey,\r\n\t\t\treactHookFormHandleSubmit,\r\n\t\t\tresolveThrownFormErrors,\r\n\t\t\tsetError,\r\n\t\t\tthrownFieldLevelErrorFormatter,\r\n\t\t],\r\n\t);\r\n\r\n\t// NOTE: `useForm` internally creates the form instance just once and assigns `formState`\r\n\t// to it every render. Creating our own form instance via `useMemo` would thus make no sense.\r\n\t// https://github.com/react-hook-form/react-hook-form/blob/master/src/useForm.ts\r\n\tObject.assign(form, {\r\n\t\thandleSubmit: handleSubmit,\r\n\t\tthrownFormErrors: thrownFormErrors,\r\n\t});\r\n\r\n\treturn form as unknown as UseFormReturn<TFieldValues, TSubmitValues>;\r\n};\r\n","import { useState } from 'react';\r\n\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\n\r\nimport { AccordionItem } from './accordionItem/AccordionItem';\r\nimport { type AccordionItemType, AccordionVariant } from './types';\r\n\r\nexport interface AccordionProps extends DesignSystemBaseProps {\r\n\tdata: AccordionItemType[];\r\n\tvariant?: AccordionVariant;\r\n}\r\n\r\nexport const Accordion = (props: AccordionProps) => {\r\n\tconst { data, variant = AccordionVariant.default } = props;\r\n\r\n\tconst { colorScheme } = useDesignSystem(props);\r\n\r\n\tconst [activeIndex, setActiveIndex] = useState<number | null>(null);\r\n\r\n\tconst handleItemClick = (index: number | null) => {\r\n\t\tsetActiveIndex((prevIndex) => (prevIndex === index ? null : index));\r\n\t};\r\n\r\n\treturn (\r\n\t\t<>\r\n\t\t\t{data.map((item: AccordionItemType, index: number | null) => (\r\n\t\t\t\t<AccordionItem\r\n\t\t\t\t\tkey={item.id}\r\n\t\t\t\t\tcloseActionAriaLabel={item.closeActionAriaLabel}\r\n\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\tcontent={item.content}\r\n\t\t\t\t\tdescription={item.description}\r\n\t\t\t\t\ticon={item.icon}\r\n\t\t\t\t\tid={item.id}\r\n\t\t\t\t\tisOpen={activeIndex === index}\r\n\t\t\t\t\tlabel={item.label}\r\n\t\t\t\t\topenActionAriaLabel={item.openActionAriaLabel}\r\n\t\t\t\t\tvariant={variant}\r\n\t\t\t\t\tonClick={() => handleItemClick(index)}\r\n\t\t\t\t/>\r\n\t\t\t))}\r\n\t\t</>\r\n\t);\r\n};\r\n","import { useTheme } from '@emotion/react';\r\nimport { type ReactNode } from 'react';\r\n\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { FontWeight } from '@/theme';\r\nimport { type ColorScheme } from '@/types';\r\n\r\nimport { AccordionContent } from '../accordionContent/AccordionContent';\r\n\r\nimport { DescriptionIconWrapper, LabelWrapper } from './AccordionKeyValue.style';\r\n\r\nexport interface AccordionKeyValueProps extends DesignSystemBaseProps {\r\n\tcolorScheme?: ColorScheme;\r\n\tlabel: ReactNode;\r\n\tvalue: ReactNode;\r\n}\r\n\r\nexport const AccordionKeyValue = (props: AccordionKeyValueProps) => {\r\n\tconst { label, value } = props;\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor, colorScheme } = useDesignSystem(props);\r\n\r\n\treturn (\r\n\t\t<AccordionContent colorScheme={colorScheme}>\r\n\t\t\t<LabelWrapper>\r\n\t\t\t\t<Typography\r\n\t\t\t\t\tcolor={chooseColor(theme.colors.fg.neutral.default)}\r\n\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\tweight={FontWeight.medium500}\r\n\t\t\t\t>\r\n\t\t\t\t\t{label}\r\n\t\t\t\t</Typography>\r\n\t\t\t</LabelWrapper>\r\n\r\n\t\t\t<DescriptionIconWrapper>\r\n\t\t\t\t<Typography\r\n\t\t\t\t\tcolor={chooseColor(theme.colors.fg.neutral.subtle)}\r\n\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\tweight={FontWeight.medium500}\r\n\t\t\t\t>\r\n\t\t\t\t\t{value}\r\n\t\t\t\t</Typography>\r\n\t\t\t</DescriptionIconWrapper>\r\n\t\t</AccordionContent>\r\n\t);\r\n};\r\n","import { Fragment, type ReactNode } from 'react';\r\n\r\nimport { Spacing } from '@/theme';\r\nimport { FlexWrap } from '@/theme/flexWrap';\r\nimport { type SsrProps } from '@/types';\r\nimport { isRenderable } from '@/utils';\r\n\r\nimport { type ButtonsLayoutAlign, type ButtonsLayoutDirection } from './types';\r\n\r\nimport { ButtonsLayoutStyled } from './ButtonsLayout.style';\r\n\r\nexport interface ButtonsLayoutProps extends SsrProps {\r\n\talign: ButtonsLayoutAlign;\r\n\tbuttons: ReactNode[];\r\n\tdirection: ButtonsLayoutDirection;\r\n\tgap?: Spacing;\r\n\twrap?: FlexWrap;\r\n}\r\n\r\nexport const ButtonsLayout = (props: ButtonsLayoutProps) => {\r\n\tconst { align, buttons, direction, gap = Spacing.md, suppressHydrationWarning = false, wrap = FlexWrap.noWrap } = props;\r\n\r\n\treturn (\r\n\t\t<ButtonsLayoutStyled\r\n\t\t\t$align={align}\r\n\t\t\t$direction={direction}\r\n\t\t\t$gap={gap}\r\n\t\t\t$wrap={wrap}\r\n\t\t\tsuppressHydrationWarning={suppressHydrationWarning}\r\n\t\t>\r\n\t\t\t{buttons.filter(isRenderable).map((button, buttonIndex) => (\r\n\t\t\t\t<Fragment key={buttonIndex}>{button}</Fragment>\r\n\t\t\t))}\r\n\t\t</ButtonsLayoutStyled>\r\n\t);\r\n};\r\n","import { useTheme } from '@emotion/react';\r\nimport { type ReactElement, type RefObject } from 'react';\r\n\r\nimport { CalculatorResultDescription } from '@/components/calculatorResult/description/CalculatorResultDescription';\r\nimport { CalculatorResultModal } from '@/components/calculatorResult/modal/CalculatorResultModal';\r\nimport {\r\n\ttype CalculatorResultBodyItem,\r\n\ttype CalculatorResultHeader,\r\n\tCalculatorResultInfoPosition,\r\n\ttype CalculatorResultMain,\r\n\ttype CalculatorResultModalDescriptor,\r\n} from '@/components/calculatorResult/types';\r\nimport { Stack } from '@/components/stack';\r\nimport { TooltipInfo, TooltipInfoDisplayMethod } from '@/components/tooltip';\r\nimport { TooltipInfoConditional } from '@/components/tooltip/infoConditional/TooltipInfoConditional';\r\nimport { mapTooltipInfoDescriptorToPropsSubset } from '@/components/tooltip/util';\r\nimport { Typography, TypographyTextAlign, TypographyVariant } from '@/components/typography';\r\nimport { VisuallyHidden } from '@/components/visuallyHidden';\r\nimport { type DesignSystemBaseProps, DesignSystemProvider, useDesignSystem } from '@/contexts';\r\nimport { FontWeight } from '@/theme';\r\nimport { ColorScheme } from '@/types';\r\n\r\nimport {\r\n\tBodyItemLeftWrapper,\r\n\tBodyItemRightWrapper,\r\n\tBodyItemsWrapper,\r\n\tBodyItemWrapper,\r\n\tBorderGradientWrapper,\r\n\tHeaderBottomWrapper,\r\n\tHeaderMainWrapper,\r\n\tHeaderTopWrapper,\r\n\tHeaderWrapper,\r\n\tHr,\r\n\tMainWrapper,\r\n\tResult,\r\n\tTopWrapper,\r\n\tWrapper,\r\n} from './CalculatorResult.style';\r\n\r\nexport interface CalculatorResultProps extends DesignSystemBaseProps {\r\n\tbodyItems: CalculatorResultBodyItem[];\r\n\tcontainerRef?: RefObject<HTMLDivElement | null>;\r\n\tdescription?: ReactElement | string;\r\n\theader: CalculatorResultHeader;\r\n\tinfoPosition?: CalculatorResultInfoPosition;\r\n\tmain: CalculatorResultMain;\r\n\tmodal?: CalculatorResultModalDescriptor;\r\n\tresultBoxRef?: RefObject<HTMLDivElement | null>;\r\n}\r\n\r\nexport const CalculatorResult = (props: CalculatorResultProps) => {\r\n\tconst {\r\n\t\tbodyItems,\r\n\t\tcolorScheme: colorSchemeProp = ColorScheme.dark,\r\n\t\tcontainerRef,\r\n\t\tdescription,\r\n\t\theader,\r\n\t\tinfoPosition = CalculatorResultInfoPosition.underBox,\r\n\t\tmain,\r\n\t\tmodal,\r\n\t\tresultBoxRef,\r\n\t} = props;\r\n\r\n\tconst theme = useTheme();\r\n\r\n\tconst { chooseColor, colorScheme, mediaType } = useDesignSystem({ ...props, colorScheme: colorSchemeProp });\r\n\r\n\treturn (\r\n\t\t<Wrapper\r\n\t\t\t$isDescriptionVisible={description !== undefined}\r\n\t\t\t$mediaType={mediaType}\r\n\t\t\tref={containerRef}\r\n\t\t>\r\n\t\t\t<DesignSystemProvider colorScheme={colorScheme}>\r\n\t\t\t\t<BorderGradientWrapper\r\n\t\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t\tref={resultBoxRef}\r\n\t\t\t\t>\r\n\t\t\t\t\t<Result $chooseColor={chooseColor}>\r\n\t\t\t\t\t\t<TopWrapper $chooseColor={chooseColor}>\r\n\t\t\t\t\t\t\t{(header.main !== undefined || header.top !== undefined || header.bottom !== undefined) && (\r\n\t\t\t\t\t\t\t\t<>\r\n\t\t\t\t\t\t\t\t\t<HeaderWrapper $chooseColor={chooseColor}>\r\n\t\t\t\t\t\t\t\t\t\t{header.top !== undefined && (\r\n\t\t\t\t\t\t\t\t\t\t\t<HeaderTopWrapper $chooseColor={chooseColor}>\r\n\t\t\t\t\t\t\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\t\t\t\t\t\t\tcolor={chooseColor(theme.colors.fg.neutral.default)}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\tfullWidth={true}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\ttextAlign={TypographyTextAlign.center}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\tvariant={TypographyVariant.textMd}\r\n\t\t\t\t\t\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t{header.top}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t{header.topHiddenText !== undefined && <VisuallyHidden>{header.topHiddenText}</VisuallyHidden>}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t<TooltipInfoConditional\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t{...mapTooltipInfoDescriptorToPropsSubset(header.topTooltip)}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tdisplayMethod={TooltipInfoDisplayMethod.withNbsp}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t\t\t\t\t\t\t</HeaderTopWrapper>\r\n\t\t\t\t\t\t\t\t\t\t)}\r\n\t\t\t\t\t\t\t\t\t\t{header.main !== undefined && (\r\n\t\t\t\t\t\t\t\t\t\t\t<HeaderMainWrapper $chooseColor={chooseColor}>\r\n\t\t\t\t\t\t\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\t\t\t\t\t\t\tas={'span'}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\tcolor={chooseColor(theme.colors.fg.neutral.default)}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\tfullWidth={true}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\ttextAlign={TypographyTextAlign.center}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\tvariant={TypographyVariant.h2}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\tweight={FontWeight.semiBold600}\r\n\t\t\t\t\t\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t{header.main}\r\n\t\t\t\t\t\t\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t\t\t\t\t\t\t</HeaderMainWrapper>\r\n\t\t\t\t\t\t\t\t\t\t)}\r\n\t\t\t\t\t\t\t\t\t\t{header.bottom !== undefined && (\r\n\t\t\t\t\t\t\t\t\t\t\t<HeaderBottomWrapper $chooseColor={chooseColor}>\r\n\t\t\t\t\t\t\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\t\t\t\t\t\t\tcolor={chooseColor(theme.colors.fg.neutral.default)}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\tfullWidth={true}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\ttextAlign={TypographyTextAlign.center}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\tvariant={TypographyVariant.textMd}\r\n\t\t\t\t\t\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t{header.bottom}\r\n\t\t\t\t\t\t\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t\t\t\t\t\t\t</HeaderBottomWrapper>\r\n\t\t\t\t\t\t\t\t\t\t)}\r\n\t\t\t\t\t\t\t\t\t</HeaderWrapper>\r\n\t\t\t\t\t\t\t\t\t<Hr $chooseColor={chooseColor} />\r\n\t\t\t\t\t\t\t\t</>\r\n\t\t\t\t\t\t\t)}\r\n\t\t\t\t\t\t\t{bodyItems.length > 0 && (\r\n\t\t\t\t\t\t\t\t<BodyItemsWrapper $chooseColor={chooseColor}>\r\n\t\t\t\t\t\t\t\t\t{bodyItems.map((bodyItem, index) => {\r\n\t\t\t\t\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t\t\t\t\t<BodyItemWrapper\r\n\t\t\t\t\t\t\t\t\t\t\t\tkey={index}\r\n\t\t\t\t\t\t\t\t\t\t\t\t$chooseColor={chooseColor}\r\n\t\t\t\t\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t\t\t\t\t<BodyItemLeftWrapper $chooseColor={chooseColor}>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcolor={theme.colors.fg.neutral.subtle.dark}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tfullWidth={true}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\ttextAlign={TypographyTextAlign.left}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tvariant={TypographyVariant.textMd}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t{bodyItem.left.element}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t{bodyItem.left.hiddenText !== undefined && <VisuallyHidden>{bodyItem.left.hiddenText}</VisuallyHidden>}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t{bodyItem.left.tooltip !== undefined && (\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t<>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t \r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t<TooltipInfo\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t{...mapTooltipInfoDescriptorToPropsSubset(bodyItem.left.tooltip)}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t</>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t)}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t\t\t\t\t\t\t\t</BodyItemLeftWrapper>\r\n\t\t\t\t\t\t\t\t\t\t\t\t<BodyItemRightWrapper $chooseColor={chooseColor}>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcolor={chooseColor(theme.colors.fg.neutral.default)}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tfullWidth={true}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\ttextAlign={TypographyTextAlign.right}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tvariant={TypographyVariant.textMd}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t{bodyItem.right.element}\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t\t\t\t\t\t\t\t</BodyItemRightWrapper>\r\n\t\t\t\t\t\t\t\t\t\t\t</BodyItemWrapper>\r\n\t\t\t\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\t\t\t})}\r\n\t\t\t\t\t\t\t\t</BodyItemsWrapper>\r\n\t\t\t\t\t\t\t)}\r\n\t\t\t\t\t\t</TopWrapper>\r\n\r\n\t\t\t\t\t\t<MainWrapper $chooseColor={chooseColor}>\r\n\t\t\t\t\t\t\t{main.topSeparator === true && <Hr $chooseColor={chooseColor} />}\r\n\t\t\t\t\t\t\t{main.element}\r\n\t\t\t\t\t\t</MainWrapper>\r\n\t\t\t\t\t\t{infoPosition === CalculatorResultInfoPosition.inBox && modal !== undefined && (\r\n\t\t\t\t\t\t\t<CalculatorResultModal\r\n\t\t\t\t\t\t\t\tcontent={modal.content}\r\n\t\t\t\t\t\t\t\tmediaType={mediaType}\r\n\t\t\t\t\t\t\t\tmodalCloseButtonAriaLabel={modal.modalCloseButtonAriaLabel}\r\n\t\t\t\t\t\t\t\ttriggerText={modal.triggerText}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t)}\r\n\t\t\t\t\t</Result>\r\n\t\t\t\t</BorderGradientWrapper>\r\n\t\t\t</DesignSystemProvider>\r\n\r\n\t\t\t<DesignSystemProvider colorScheme={ColorScheme.light}>\r\n\t\t\t\t<Stack>\r\n\t\t\t\t\t<CalculatorResultDescription description={description} />\r\n\t\t\t\t\t{infoPosition === CalculatorResultInfoPosition.underBox && modal !== undefined && (\r\n\t\t\t\t\t\t<CalculatorResultModal\r\n\t\t\t\t\t\t\tcontent={modal.content}\r\n\t\t\t\t\t\t\tmediaType={mediaType}\r\n\t\t\t\t\t\t\tmodalCloseButtonAriaLabel={modal.modalCloseButtonAriaLabel}\r\n\t\t\t\t\t\t\ttriggerText={modal.triggerText}\r\n\t\t\t\t\t\t/>\r\n\t\t\t\t\t)}\r\n\t\t\t\t</Stack>\r\n\t\t\t</DesignSystemProvider>\r\n\t\t</Wrapper>\r\n\t);\r\n};\r\n","import { useEffect } from 'react';\r\nimport { useController, useFormContext, type RegisterOptions } from 'react-hook-form';\r\n\r\nimport { ComboBox, type ComboBoxProps } from '@/components/comboBoxField/comboBox/ComboBox';\r\nimport { type ComboBoxItem } from '@/components/comboBoxField/types';\r\n\r\nexport interface ComboBoxFieldProps<TItem extends ComboBoxItem> extends Omit<ComboBoxProps<TItem>, 'onChange' | 'value'> {\r\n\tdefaultValue?: TItem | null;\r\n\tname: string;\r\n\toptions?: RegisterOptions;\r\n\tshouldResetInvalidValues?: boolean;\r\n}\r\n// TODO: Possibly add support for `TFieldValues`.\r\nexport const ComboBoxField = <TItem extends ComboBoxItem>(props: ComboBoxFieldProps<TItem>) => {\r\n\tconst { defaultValue = null, items, name, options, shouldResetInvalidValues = false, ...otherProps } = props;\r\n\tconst { control, resetField } = useFormContext();\r\n\r\n\tconst {\r\n\t\tfield,\r\n\t\tfieldState: { error },\r\n\t} = useController({\r\n\t\tname: name,\r\n\t\tcontrol: control,\r\n\t\trules: options,\r\n\t\tdefaultValue: defaultValue,\r\n\t});\r\n\r\n\tconst value = field.value as TItem | null;\r\n\r\n\tuseEffect(() => {\r\n\t\tif (shouldResetInvalidValues && value !== null && !items.includes(value)) {\r\n\t\t\tresetField(name);\r\n\t\t}\r\n\t}, [items, name, resetField, shouldResetInvalidValues, value]);\r\n\r\n\treturn (\r\n\t\t<ComboBox\r\n\t\t\terrorMessage={error?.message}\r\n\t\t\titems={items}\r\n\t\t\t{...field}\r\n\t\t\t{...otherProps}\r\n\t\t/>\r\n\t);\r\n};\r\n","import { format } from 'date-fns';\r\nimport { type ComponentProps, useCallback } from 'react';\r\nimport { type RegisterOptions, useController, useFormContext } from 'react-hook-form';\r\n\r\nimport { datePickerValueFormat } from '@/components/datePickerField/constants';\r\nimport { DatePicker } from '@/components/datePickerField/datePicker/DatePicker';\r\n\r\nexport interface DatePickerFieldProps extends Omit<ComponentProps<typeof DatePicker>, 'onChange'> {\r\n\toptions?: RegisterOptions;\r\n}\r\n\r\nexport const DatePickerField = (props: DatePickerFieldProps) => {\r\n\tconst { name, options, ...otherProps } = props;\r\n\tconst { control } = useFormContext();\r\n\r\n\tconst {\r\n\t\tfield: { onBlur, onChange, ref, value }, // eslint-disable-line @typescript-eslint/no-unsafe-assignment\r\n\t\tfieldState: { error },\r\n\t} = useController({\r\n\t\tcontrol: control,\r\n\t\tname: name,\r\n\t\trules: options,\r\n\t});\r\n\r\n\tconst handleChange = useCallback(\r\n\t\t(date: Date | null) => {\r\n\t\t\tonChange(date === null ? null : format(date, datePickerValueFormat));\r\n\t\t},\r\n\t\t[onChange],\r\n\t);\r\n\r\n\treturn (\r\n\t\t<DatePicker\r\n\t\t\terrorMessage={error?.message}\r\n\t\t\tname={name}\r\n\t\t\tref={ref}\r\n\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\r\n\t\t\tselected={value}\r\n\t\t\tonBlur={onBlur}\r\n\t\t\tonChange={handleChange}\r\n\t\t\t{...otherProps}\r\n\t\t/>\r\n\t);\r\n};\r\n","import { type RegisterOptions, useController, useFormContext } from 'react-hook-form';\r\n\r\nimport { EmailInput, type EmailInputProps } from './emailInput/EmailInput';\r\n\r\nexport interface EmailInputFieldProps extends Omit<EmailInputProps, 'onChange' | 'value'> {\r\n\toptions?: RegisterOptions;\r\n}\r\n\r\nexport const EmailInputField = (props: EmailInputFieldProps) => {\r\n\tconst { name, options, ...otherProps } = props;\r\n\r\n\tconst { control } = useFormContext();\r\n\r\n\tconst {\r\n\t\tfield,\r\n\t\tfieldState: { error },\r\n\t} = useController({\r\n\t\tname: name,\r\n\t\tcontrol: control,\r\n\t\trules: options,\r\n\t});\r\n\r\n\tconst errorMessage = error?.message;\r\n\r\n\treturn (\r\n\t\t<EmailInput\r\n\t\t\terrorMessage={errorMessage}\r\n\t\t\t{...field}\r\n\t\t\t{...otherProps}\r\n\t\t/>\r\n\t);\r\n};\r\n","import { type RegisterOptions, useController } from 'react-hook-form';\r\n\r\nimport { FileInput, type FileInputProps } from './fileInput/FileInput';\r\n\r\nexport interface FileInputFieldProps extends Omit<FileInputProps, 'onBlur' | 'onChange' | 'value'> {\r\n\toptions?: RegisterOptions;\r\n}\r\n\r\nexport const FileInputField = (props: FileInputFieldProps) => {\r\n\tconst { name, options, ...otherProps } = props;\r\n\r\n\tconst {\r\n\t\tfield,\r\n\t\tfieldState: { error },\r\n\t} = useController({\r\n\t\tdefaultValue: [],\r\n\t\tname: name,\r\n\t\trules: options,\r\n\t});\r\n\r\n\treturn (\r\n\t\t<FileInput\r\n\t\t\terrorMessage={error?.message}\r\n\t\t\t{...field}\r\n\t\t\t{...otherProps}\r\n\t\t/>\r\n\t);\r\n};\r\n","import { useContext, useMemo, type ReactNode } from 'react';\r\n\r\nimport { FormConfigContext } from './contexts';\r\nimport { type FormConfig } from './types';\r\n\r\nexport interface FormConfigProviderProps {\r\n\tchildren: ReactNode;\r\n\tconfig: FormConfig;\r\n}\r\n\r\nexport const FormConfigProvider = (props: FormConfigProviderProps) => {\r\n\tconst previousConfig = useContext(FormConfigContext);\r\n\tconst { children, config: configProp } = props;\r\n\r\n\tconst nextConfig = useMemo(\r\n\t\t() => ({\r\n\t\t\t...previousConfig,\r\n\t\t\t...configProp,\r\n\t\t}),\r\n\t\t[previousConfig, configProp],\r\n\t);\r\n\r\n\treturn <FormConfigContext.Provider value={nextConfig}>{children}</FormConfigContext.Provider>;\r\n};\r\n","import { useTheme } from '@emotion/react';\r\nimport { useContext, useEffect, useRef } from 'react';\r\n\r\nimport { IconProductType } from '@/components/iconProduct';\r\nimport { Infobox, InfoboxSize, InfoboxVariant } from '@/components/infobox';\r\nimport { Stack } from '@/components/stack';\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { FormConfigContext } from '@/form/contexts';\r\nimport { type FormConfig } from '@/form/types';\r\nimport { useFormContext } from '@/form/useFormContext';\r\nimport { jsonFormatter } from '@/formatters';\r\nimport { FontWeight, Spacing } from '@/theme';\r\n\r\nexport interface FormErrorOutcomeProps extends DesignSystemBaseProps, Pick<FormConfig, 'thrownFormLevelErrorFormatter'> {}\r\n\r\nexport const FormErrorOutcome = (props: FormErrorOutcomeProps) => {\r\n\tconst formConfig = useContext(FormConfigContext);\r\n\tconst thrownFormLevelErrorFormatter = props.thrownFormLevelErrorFormatter ?? formConfig.thrownFormLevelErrorFormatter ?? jsonFormatter;\r\n\tconst theme = useTheme();\r\n\tconst { colorScheme } = useDesignSystem(props);\r\n\tconst { thrownFormErrors } = useFormContext();\r\n\tconst hasFormLevelErrors = thrownFormErrors.formLevelErrors.length > 0;\r\n\tconst ref = useRef<HTMLDivElement>(null);\r\n\r\n\tuseEffect(() => {\r\n\t\tif (hasFormLevelErrors && ref.current) {\r\n\t\t\tref.current.scrollIntoView({ behavior: 'smooth', block: 'nearest' });\r\n\t\t}\r\n\t}, [hasFormLevelErrors]);\r\n\r\n\tif (!hasFormLevelErrors) {\r\n\t\treturn null;\r\n\t}\r\n\r\n\treturn (\r\n\t\t<Stack\r\n\t\t\tgap={Spacing.sm}\r\n\t\t\tref={ref}\r\n\t\t\trole=\"alert\"\r\n\t\t>\r\n\t\t\t{thrownFormErrors.formLevelErrors.map((error, index) => {\r\n\t\t\t\tconst output = thrownFormLevelErrorFormatter.format(error);\r\n\t\t\t\tconst outputStructured = typeof output === 'object' && output !== null && 'title' in output;\r\n\r\n\t\t\t\treturn (\r\n\t\t\t\t\t<Infobox\r\n\t\t\t\t\t\tkey={index}\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\ticonProduct={(outputStructured ? output.iconProduct : null) ?? IconProductType.warningCircle}\r\n\t\t\t\t\t\tisWarning={true}\r\n\t\t\t\t\t\tsize={InfoboxSize.sm}\r\n\t\t\t\t\t\ttextContent={\r\n\t\t\t\t\t\t\toutputStructured\r\n\t\t\t\t\t\t\t\t? {\r\n\t\t\t\t\t\t\t\t\t\tprimary: (\r\n\t\t\t\t\t\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\t\t\t\t\t\tcolor={theme.colors.fg.accent.bold}\r\n\t\t\t\t\t\t\t\t\t\t\t\tfullWidth={true}\r\n\t\t\t\t\t\t\t\t\t\t\t\tvariant={TypographyVariant.textMd}\r\n\t\t\t\t\t\t\t\t\t\t\t\tweight={FontWeight.semiBold600}\r\n\t\t\t\t\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t\t\t\t\t{output.title}\r\n\t\t\t\t\t\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t\t\t\t\t\t),\r\n\t\t\t\t\t\t\t\t\t\tsecondary: (\r\n\t\t\t\t\t\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\t\t\t\t\t\tcolor={theme.colors.fg.accent.bold}\r\n\t\t\t\t\t\t\t\t\t\t\t\tfullWidth={true}\r\n\t\t\t\t\t\t\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\t\t\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t\t\t\t\t{output.description}\r\n\t\t\t\t\t\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t\t\t\t\t\t),\r\n\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t: {\r\n\t\t\t\t\t\t\t\t\t\tprimary: (\r\n\t\t\t\t\t\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\t\t\t\t\t\tcolor={theme.colors.fg.accent.bold}\r\n\t\t\t\t\t\t\t\t\t\t\t\tfullWidth={true}\r\n\t\t\t\t\t\t\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\t\t\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t\t\t\t\t{output}\r\n\t\t\t\t\t\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t\t\t\t\t\t),\r\n\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tvariant={InfoboxVariant.primary}\r\n\t\t\t\t\t/>\r\n\t\t\t\t);\r\n\t\t\t})}\r\n\t\t</Stack>\r\n\t);\r\n};\r\n","import { sortBy } from 'lodash';\r\nimport { type ReactNode, useEffect, useMemo, useRef } from 'react';\r\nimport { type FieldError, get } from 'react-hook-form';\r\n\r\nimport { ErrorBox, type ErrorBoxItem } from '@/components/errorBox';\r\nimport { type DesignSystemBaseProps, useDesignSystem, useDesignSystemMessages, useFieldLabels } from '@/contexts';\r\nimport { useFormContext } from '@/form/useFormContext';\r\nimport { useSubmitErrors } from '@/form/useSubmitErrors';\r\nimport { isRenderable } from '@/utils';\r\n\r\nconst getComparableIndex = (index: number) => (index === -1 ? Number.POSITIVE_INFINITY : index);\r\n\r\nconst queryFieldNames = (rootElement: HTMLElement): string[] => {\r\n\tconst elements = rootElement.querySelectorAll('[name], [data-name]');\r\n\r\n\treturn Array.from(elements)\r\n\t\t.map((element) => element.getAttribute('data-name') ?? element.getAttribute('name'))\r\n\t\t.filter((name): name is string => typeof name === 'string');\r\n};\r\n\r\nexport interface FormErrorSummaryProps extends DesignSystemBaseProps {\r\n\torder?: string[];\r\n\ttitle?: ReactNode;\r\n}\r\n\r\nexport const FormErrorSummary = (props: FormErrorSummaryProps) => {\r\n\tconst { order: orderProp, title: titleProp } = props;\r\n\r\n\tconst designSystemMessages = useDesignSystemMessages();\r\n\tconst title = titleProp ?? designSystemMessages.formErrorSummary.title;\r\n\tconst { colorScheme } = useDesignSystem(props);\r\n\r\n\tconst { control, formState, setFocus } = useFormContext();\r\n\tconst { errors, submitCount } = formState;\r\n\tconst errorCount = Object.entries(errors).length;\r\n\tconst submitErrors = useSubmitErrors(formState);\r\n\tconst fieldLabels = useFieldLabels();\r\n\tconst formLocatorRef = useRef<HTMLDivElement>(null);\r\n\tconst formRef = useRef<HTMLFormElement | undefined>(undefined);\r\n\tconst alertRef = useRef<HTMLDivElement>(null);\r\n\r\n\tuseEffect(() => {\r\n\t\tformRef.current = formLocatorRef.current?.closest('form') ?? undefined;\r\n\t}, []);\r\n\r\n\tconst errorBoxItems = useMemo(() => {\r\n\t\tif (!formRef.current) {\r\n\t\t\treturn [];\r\n\t\t}\r\n\r\n\t\t// NOTE: `errors` are referentially stable (mutable), but we need to recalculate `errorBoxItems`\r\n\t\t// whenever some field is unmounted. When a field is unmounted, its error disappears as well.\r\n\t\tvoid errorCount;\r\n\r\n\t\tconst queriedFieldNames = queryFieldNames(formRef.current);\r\n\t\tconst fieldOrder = orderProp ?? queriedFieldNames;\r\n\r\n\t\t// NOTE: We use `control._names.mount` since both `errors` and `submitErrors` have a nested structure\r\n\t\t// from which it is difficult to retrieve all the field names, and should be safer than just using `queryFieldNames`.\r\n\t\tconst fieldNames = Array.from(control._names.mount);\r\n\t\tconst orderedFieldNames = sortBy(fieldNames, (fieldName) => getComparableIndex(fieldOrder.indexOf(String(fieldName))));\r\n\r\n\t\treturn orderedFieldNames.reduce<ErrorBoxItem[]>((accumulator, fieldName) => {\r\n\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\r\n\t\t\tconst submitError: FieldError | undefined = get(submitErrors, fieldName);\r\n\t\t\tconst label = fieldLabels[fieldName];\r\n\r\n\t\t\tif (submitError === undefined) {\r\n\t\t\t\treturn accumulator;\r\n\t\t\t}\r\n\r\n\t\t\t// NOTE: If there's a submit error for a field which *no longer* exists, we don't display it.\r\n\t\t\t// We do not trust `queryFieldNames` to 100% find all the fields, so we also use `errors` presence.\r\n\t\t\tif (get(errors, fieldName) === undefined && !queriedFieldNames.includes(fieldName)) {\r\n\t\t\t\treturn accumulator;\r\n\t\t\t}\r\n\r\n\t\t\taccumulator.push({\r\n\t\t\t\tbody: (\r\n\t\t\t\t\t<>\r\n\t\t\t\t\t\t{isRenderable(label) && <>{label}: </>}\r\n\t\t\t\t\t\t{submitError.message}\r\n\t\t\t\t\t</>\r\n\t\t\t\t),\r\n\t\t\t\tonClick: () => setFocus(fieldName),\r\n\t\t\t});\r\n\r\n\t\t\treturn accumulator;\r\n\t\t}, []);\r\n\t}, [control._names.mount, errorCount, errors, fieldLabels, orderProp, setFocus, submitErrors]);\r\n\r\n\t// NOTE: We only need this `useEffect` to fire upon submission, that's why we depend on `submitCount` (and not `errorBoxItems`).\r\n\tuseEffect(() => {\r\n\t\tif (control._options.shouldFocusError === false) {\r\n\t\t\t// NOTE: Using `?.focus()` is safe even without any errors, since we're displaying the error box dynamically already.\r\n\t\t\talertRef.current?.focus();\r\n\t\t}\r\n\t}, [control, submitCount]);\r\n\r\n\treturn (\r\n\t\t<>\r\n\t\t\t{errorBoxItems.length > 0 && (\r\n\t\t\t\t<ErrorBox\r\n\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\titems={errorBoxItems}\r\n\t\t\t\t\tref={alertRef}\r\n\t\t\t\t\ttabIndex={-1}\r\n\t\t\t\t\ttitle={title}\r\n\t\t\t\t/>\r\n\t\t\t)}\r\n\r\n\t\t\t<div\r\n\t\t\t\t// HACK: Since we render the error box conditionally, it's not possible to use any `forwardRef` logic\r\n\t\t\t\t// to reliably find the form. Furthermore, since we often render this component inside a `Stack`,\r\n\t\t\t\t// we don't want to use any extra wrapper divs. We could add some generated ID logic to `useForm`,\r\n\t\t\t\t// but that would need extra plumbing (passing it to the form element). This is easier.\r\n\t\t\t\tref={formLocatorRef}\r\n\t\t\t\tstyle={{ display: 'none' }}\r\n\t\t\t/>\r\n\t\t</>\r\n\t);\r\n};\r\n","import { cloneDeep } from 'lodash';\r\nimport { useRef } from 'react';\r\nimport { type FieldErrors, type FieldValues, type FormState } from 'react-hook-form';\r\n\r\nexport const useSubmitErrors = <TFieldValues extends FieldValues>(formState: FormState<TFieldValues>): FieldErrors<TFieldValues> => {\r\n\tconst submitErrorsRef = useRef<FieldErrors<TFieldValues>>({});\r\n\tconst { errors, submitCount } = formState;\r\n\tconst previousSubmitCountRef = useRef(submitCount);\r\n\r\n\tconst previousSubmitCount = previousSubmitCountRef.current;\r\n\tpreviousSubmitCountRef.current = submitCount;\r\n\r\n\tif (submitCount !== previousSubmitCount) {\r\n\t\t// NOTE: `errors` are mutable. We need `submitErrors` to be stable until the next submission.\r\n\t\tsubmitErrorsRef.current = cloneDeep(errors);\r\n\t}\r\n\r\n\treturn submitErrorsRef.current;\r\n};\r\n","import { type ReactNode } from 'react';\r\nimport { FormProvider as ReactHookFormProvider, type FieldValues, type UseFormReturn as ReactHookFormUseFormReturn } from 'react-hook-form';\r\n\r\nimport { FieldLabelStoreProvider } from '@/contexts';\r\n\r\nimport { type UseFormReturn } from './useForm';\r\n\r\nexport interface FormProviderProps<TFieldValues extends FieldValues> {\r\n\tchildren: ReactNode;\r\n\tform: UseFormReturn<TFieldValues>;\r\n}\r\n\r\nexport const FormProvider = <TFieldValues extends FieldValues>(props: FormProviderProps<TFieldValues>) => {\r\n\tconst { children, form } = props;\r\n\r\n\treturn (\r\n\t\t<ReactHookFormProvider {...(form as unknown as ReactHookFormUseFormReturn<TFieldValues>)}>\r\n\t\t\t<FieldLabelStoreProvider>{children}</FieldLabelStoreProvider>\r\n\t\t</ReactHookFormProvider>\r\n\t);\r\n};\r\n","import { useTheme } from '@emotion/react';\r\nimport { type ReactNode } from 'react';\r\n\r\nimport { Modal } from '@/components/modal';\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { FontWeight } from '@/theme';\r\nimport { isRenderable } from '@/utils';\r\n\r\nimport { SubmitResultModalContentStyled } from './FormSuccessOutcome.style';\r\n\r\nexport interface FormSuccessOutcomeProps extends DesignSystemBaseProps {\r\n\tchildren: ReactNode;\r\n\tonHide: () => void;\r\n\ttitle: ReactNode;\r\n\tvisible: boolean;\r\n}\r\n\r\nexport const FormSuccessOutcome = (props: FormSuccessOutcomeProps) => {\r\n\tconst { children, onHide, title, visible } = props;\r\n\r\n\tconst theme = useTheme();\r\n\tconst { colorScheme } = useDesignSystem(props);\r\n\r\n\treturn (\r\n\t\t<Modal\r\n\t\t\tcolorScheme={colorScheme}\r\n\t\t\thideCloseButton={false}\r\n\t\t\tisOpen={visible}\r\n\t\t\tonClose={onHide}\r\n\t\t>\r\n\t\t\t<SubmitResultModalContentStyled>\r\n\t\t\t\t{isRenderable(title) && (\r\n\t\t\t\t\t<Typography\r\n\t\t\t\t\t\tcolor={theme.colors.fg.neutral.default}\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\tvariant={TypographyVariant.h3}\r\n\t\t\t\t\t\tweight={FontWeight.semiBold600}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t{title}\r\n\t\t\t\t\t</Typography>\r\n\t\t\t\t)}\r\n\t\t\t\t{isRenderable(children) && (\r\n\t\t\t\t\t<Typography\r\n\t\t\t\t\t\tcolor={theme.colors.fg.neutral.subtle}\r\n\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\tvariant={TypographyVariant.textMd}\r\n\t\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t{children}\r\n\t\t\t\t\t</Typography>\r\n\t\t\t\t)}\r\n\t\t\t</SubmitResultModalContentStyled>\r\n\t\t</Modal>\r\n\t);\r\n};\r\n","import { type BaseFormattedAmountProps, BaseFormattedAmount } from '../BaseFormattedAmount';\r\nimport { useFormatAmount } from './useFormatAmount';\r\n\r\nexport interface FormattedAmountProps extends Omit<BaseFormattedAmountProps, 'formatAmount'> {}\r\n\r\nexport const FormattedAmount = (props: FormattedAmountProps) => {\r\n\tconst formatAmount = useFormatAmount();\r\n\r\n\treturn (\r\n\t\t<BaseFormattedAmount\r\n\t\t\t{...props}\r\n\t\t\tformatAmount={formatAmount}\r\n\t\t/>\r\n\t);\r\n};\r\n","import { IconFlagCz } from './svg/IconFlagCz';\r\nimport { IconFlagEu } from './svg/IconFlagEu';\r\nimport { IconFlagHr } from './svg/IconFlagHr';\r\nimport { IconFlagUsa } from './svg/IconFlagUsa';\r\nimport { IconFlagType } from './types';\r\n\r\nimport { Wrapper } from './IconFlag.style';\r\n\r\nexport interface IconFlagProps {\r\n\ttype: IconFlagType;\r\n}\r\n\r\nexport const IconFlag = (props: IconFlagProps) => {\r\n\tconst { type } = props;\r\n\r\n\treturn (\r\n\t\t<Wrapper>\r\n\t\t\t{(() => {\r\n\t\t\t\tswitch (true) {\r\n\t\t\t\t\tcase type === IconFlagType.eu:\r\n\t\t\t\t\t\treturn <IconFlagEu />;\r\n\t\t\t\t\tcase type === IconFlagType.cz:\r\n\t\t\t\t\t\treturn <IconFlagCz />;\r\n\t\t\t\t\tcase type === IconFlagType.hr:\r\n\t\t\t\t\t\treturn <IconFlagHr />;\r\n\t\t\t\t\tcase type === IconFlagType.usa:\r\n\t\t\t\t\t\treturn <IconFlagUsa />;\r\n\t\t\t\t\tdefault:\r\n\t\t\t\t\t\tthrow new Error('unexpected enum value IconFlagType and IconFlagSize in IconFlag');\r\n\t\t\t\t}\r\n\t\t\t})()}\r\n\t\t</Wrapper>\r\n\t);\r\n};\r\n","import { type AriaAttributes, type AriaRole } from 'react';\r\n\r\nimport { Loader } from '@/components/loader/Loader';\r\nimport { type LoaderSize } from '@/components/loader/types';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\n\r\nimport { Wrapper } from './LoaderOverlayBox.style';\r\n\r\nexport interface LoaderOverlayBoxProps extends DesignSystemBaseProps, AriaAttributes {\r\n\tloaderSize: LoaderSize;\r\n\trole?: AriaRole;\r\n}\r\n\r\nexport const LoaderOverlayBox = (props: LoaderOverlayBoxProps) => {\r\n\tconst {\r\n\t\tcolorScheme: colorSchemeProp, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\tloaderSize,\r\n\t\tmediaType: mediaTypeProp, // eslint-disable-line @typescript-eslint/no-unused-vars\r\n\t\t...otherProps\r\n\t} = props;\r\n\r\n\tconst { colorScheme } = useDesignSystem(props);\r\n\r\n\treturn (\r\n\t\t<Wrapper\r\n\t\t\t$colorScheme={colorScheme}\r\n\t\t\t{...otherProps}\r\n\t\t>\r\n\t\t\t<Loader\r\n\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\tloaderSize={loaderSize}\r\n\t\t\t/>\r\n\t\t</Wrapper>\r\n\t);\r\n};\r\n","import { type BaseFormattedAmountProps, BaseFormattedAmount } from '../BaseFormattedAmount';\r\nimport { useFormatAmount } from './useFormatAmount';\r\n\r\nexport interface FormattedAmountProps extends Omit<BaseFormattedAmountProps, 'formatAmount'> {}\r\n\r\nexport const FormattedAmount = (props: FormattedAmountProps) => {\r\n\tconst formatAmount = useFormatAmount();\r\n\r\n\treturn (\r\n\t\t<BaseFormattedAmount\r\n\t\t\t{...props}\r\n\t\t\tformatAmount={formatAmount}\r\n\t\t/>\r\n\t);\r\n};\r\n","import { get, type RegisterOptions, useFormContext } from 'react-hook-form';\r\n\r\nimport { RadioButton, type RadioButtonProps } from '@/components/radioButtonField/radioButton/RadioButton';\r\n\r\nexport interface RadioButtonFieldProps extends Omit<RadioButtonProps, 'onChange'> {\r\n\tname: string;\r\n\toptions?: RegisterOptions;\r\n}\r\n\r\nexport const RadioButtonField = (props: RadioButtonFieldProps) => {\r\n\tconst { name, options, ...otherProps } = props;\r\n\tconst { formState, register } = useFormContext();\r\n\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\r\n\tconst error = get(formState.errors, name);\r\n\r\n\treturn (\r\n\t\t<RadioButton\r\n\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access\r\n\t\t\terrorMessage={error?.message}\r\n\t\t\t{...register(name, options)}\r\n\t\t\t{...otherProps}\r\n\t\t/>\r\n\t);\r\n};\r\n","import { get, type RegisterOptions, useFormContext } from 'react-hook-form';\r\n\r\nimport { Radio, type RadioProps } from '@/components/radioField/radio/Radio';\r\n\r\nexport interface RadioFieldProps extends Omit<RadioProps, 'onChange'> {\r\n\tname: string;\r\n\toptions?: RegisterOptions;\r\n}\r\n\r\nexport const RadioField = (props: RadioFieldProps) => {\r\n\tconst { name, options, ...otherProps } = props;\r\n\tconst { formState, register } = useFormContext();\r\n\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\r\n\tconst error = get(formState.errors, name);\r\n\r\n\treturn (\r\n\t\t<Radio\r\n\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access\r\n\t\t\terrorMessage={error?.message}\r\n\t\t\t{...register(name, options)}\r\n\t\t\t{...otherProps}\r\n\t\t/>\r\n\t);\r\n};\r\n","import { useEffect } from 'react';\r\nimport { useController, useFormContext, type RegisterOptions } from 'react-hook-form';\r\n\r\nimport { Select, type SelectProps } from './select/Select';\r\nimport { type SelectItem } from './types';\r\n\r\nexport interface SelectFieldProps<TItem extends SelectItem> extends Omit<SelectProps<TItem>, 'onChange' | 'value'> {\r\n\tdefaultValue?: TItem | null;\r\n\tname: string;\r\n\toptions?: RegisterOptions;\r\n\tshouldResetInvalidValues?: boolean;\r\n}\r\n\r\n// TODO: Possibly add support for `TFieldValues`.\r\nexport const SelectField = <TItem extends SelectItem>(props: SelectFieldProps<TItem>) => {\r\n\tconst { defaultValue = null, items, name, options, shouldResetInvalidValues = false, ...otherProps } = props;\r\n\tconst { control, resetField } = useFormContext();\r\n\r\n\tconst {\r\n\t\tfield,\r\n\t\tfieldState: { error },\r\n\t} = useController({\r\n\t\tname: name,\r\n\t\tcontrol: control,\r\n\t\trules: options,\r\n\t\tdefaultValue: defaultValue,\r\n\t});\r\n\r\n\tconst value = field.value as TItem | null;\r\n\r\n\tuseEffect(() => {\r\n\t\tif (shouldResetInvalidValues && value !== null && !items.includes(value)) {\r\n\t\t\tresetField(name);\r\n\t\t}\r\n\t}, [items, name, resetField, shouldResetInvalidValues, value]);\r\n\r\n\treturn (\r\n\t\t<Select\r\n\t\t\terrorMessage={error?.message}\r\n\t\t\titems={items}\r\n\t\t\t{...field}\r\n\t\t\t{...otherProps}\r\n\t\t/>\r\n\t);\r\n};\r\n","import { useController, useFormContext, type RegisterOptions } from 'react-hook-form';\r\n\r\nimport { SliderInput, type SliderInputProps } from './sliderInput/SliderInput';\r\n\r\nexport interface SliderInputFieldProps extends Omit<SliderInputProps, 'onChange' | 'value'> {\r\n\toptions?: RegisterOptions;\r\n}\r\n\r\n/**\r\n * Note: You must set the `defaultValues` for this field in `useForm`. Without it, the field throw error.\r\n */\r\nexport const SliderInputField = (props: SliderInputFieldProps) => {\r\n\tconst { name, options, ...otherProps } = props;\r\n\tconst { control } = useFormContext();\r\n\r\n\tconst { field } = useController({\r\n\t\tname: name,\r\n\t\tcontrol: control,\r\n\t\trules: options,\r\n\t});\r\n\r\n\treturn (\r\n\t\t<SliderInput\r\n\t\t\t{...field}\r\n\t\t\t{...otherProps}\r\n\t\t/>\r\n\t);\r\n};\r\n","import { Fragment } from 'react';\r\n\r\nimport { StepperItem, type StepperItemProps } from './stepperItem/StepperItem';\r\nimport { StepperVariant } from './types';\r\n\r\nimport { Separator, Wrapper } from './Stepper.style';\r\n\r\nexport interface StepperProps {\r\n\tsteps: StepperItemProps[];\r\n\tvariant: StepperVariant;\r\n}\r\n\r\nexport const Stepper = (props: StepperProps) => {\r\n\tconst { steps, variant } = props;\r\n\r\n\treturn (\r\n\t\t<Wrapper $variant={variant}>\r\n\t\t\t{steps.map((item: StepperItemProps, index: number) => (\r\n\t\t\t\t<Fragment key={item.id}>\r\n\t\t\t\t\t<StepperItem\r\n\t\t\t\t\t\tdisabled={item.disabled}\r\n\t\t\t\t\t\tid={item.id}\r\n\t\t\t\t\t\tindex={item.index}\r\n\t\t\t\t\t\tisActive={item.isActive}\r\n\t\t\t\t\t\tisCompleted={item.isCompleted}\r\n\t\t\t\t\t\ttext={item.text}\r\n\t\t\t\t\t\tvariant={variant}\r\n\t\t\t\t\t\tonClick={item.onClick}\r\n\t\t\t\t\t/>\r\n\r\n\t\t\t\t\t{variant === StepperVariant.vertical && index < steps.length - 1 && <Separator />}\r\n\t\t\t\t</Fragment>\r\n\t\t\t))}\r\n\t\t</Wrapper>\r\n\t);\r\n};\r\n","import { AndroidSvg } from './assets/AndroidSvg';\r\nimport { AppleSvg } from './assets/AppleSvg';\r\nimport { StoreButtonSize, StoreButtonVariant } from './types';\r\n\r\nimport { StoreButtonStyled } from './StoreButton.style';\r\n\r\nexport interface StoreButtonProps {\r\n\thref: string;\r\n\tsize: StoreButtonSize;\r\n\tvariant: StoreButtonVariant;\r\n}\r\n\r\nexport const StoreButton = (props: StoreButtonProps) => {\r\n\tconst { size, variant } = props;\r\n\r\n\treturn (\r\n\t\t<StoreButtonStyled $size={size}>\r\n\t\t\t{variant === StoreButtonVariant.apple ? (\r\n\t\t\t\t<AppleSvg\r\n\t\t\t\t\theight={size === StoreButtonSize.small ? '26' : '30'}\r\n\t\t\t\t\twidth={size === StoreButtonSize.small ? '100' : '120'}\r\n\t\t\t\t/>\r\n\t\t\t) : (\r\n\t\t\t\t<AndroidSvg\r\n\t\t\t\t\theight={size === StoreButtonSize.small ? '26' : '30'}\r\n\t\t\t\t\twidth={size === StoreButtonSize.small ? '100' : '120'}\r\n\t\t\t\t/>\r\n\t\t\t)}\r\n\t\t</StoreButtonStyled>\r\n\t);\r\n};\r\n","import { type Property } from 'csstype';\r\nimport { type ReactNode } from 'react';\r\n\r\nimport { type TableVariant } from '../types';\r\n\r\nimport { TableStyled } from './Table.style';\r\n\r\nexport interface TableProps {\r\n\tchildren: ReactNode;\r\n\tvariant: TableVariant;\r\n\twidth?: Property.Width;\r\n}\r\n\r\nexport const Table = (props: TableProps) => {\r\n\tconst { children, variant, width = '100%' } = props;\r\n\r\n\treturn (\r\n\t\t<TableStyled\r\n\t\t\t$variant={variant}\r\n\t\t\t$width={width}\r\n\t\t>\r\n\t\t\t{children}\r\n\t\t</TableStyled>\r\n\t);\r\n};\r\n","import { type ReactNode } from 'react';\r\n\r\nexport interface TableBodyProps {\r\n\tchildren: ReactNode;\r\n}\r\n\r\nexport const TableBody = (props: TableBodyProps) => {\r\n\tconst { children } = props;\r\n\r\n\treturn <tbody>{children}</tbody>;\r\n};\r\n","import { useTheme } from '@emotion/react';\r\nimport { type ReactNode, useMemo } from 'react';\r\n\r\nimport { Typography, TypographyTextAlign, TypographyVariant } from '@/components/typography';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\nimport { FontWeight } from '@/theme';\r\n\r\nimport { TableTextAlign, TableVariant } from '../types';\r\n\r\nimport { TableDataStyled } from './TableData.style';\r\n\r\nexport interface TableDataProps extends DesignSystemBaseProps {\r\n\tchildren: ReactNode;\r\n\tdelimiter?: boolean;\r\n\theaders?: string;\r\n\ttextAlign?: TableTextAlign;\r\n\tvariant: TableVariant;\r\n}\r\n\r\nexport const TableData = (props: TableDataProps) => {\r\n\tconst { children, delimiter = false, headers, textAlign = TableTextAlign.left, variant } = props;\r\n\r\n\tconst theme = useTheme();\r\n\tconst { chooseColor, colorScheme } = useDesignSystem(props);\r\n\r\n\tconst typographyTextAlign = useMemo<TypographyTextAlign>(() => {\r\n\t\tswitch (textAlign) {\r\n\t\t\tcase TableTextAlign.left:\r\n\t\t\t\treturn TypographyTextAlign.left;\r\n\t\t\tcase TableTextAlign.center:\r\n\t\t\t\treturn TypographyTextAlign.center;\r\n\t\t\tcase TableTextAlign.right:\r\n\t\t\t\treturn TypographyTextAlign.right;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error('unexpected enum of TableTextAlign in tableData.tsx');\r\n\t\t}\r\n\t}, [textAlign]);\r\n\r\n\treturn (\r\n\t\t<TableDataStyled\r\n\t\t\t$align={textAlign}\r\n\t\t\t$chooseColor={chooseColor}\r\n\t\t\t$delimiter={delimiter}\r\n\t\t\t$variant={variant}\r\n\t\t\theaders={headers}\r\n\t\t>\r\n\t\t\t{(() => {\r\n\t\t\t\tswitch (variant) {\r\n\t\t\t\t\tcase TableVariant.exchange:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\t\tcolor={theme.colors.fg.neutral.subtle}\r\n\t\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\t\ttextAlign={typographyTextAlign}\r\n\t\t\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\t\t\tweight={FontWeight.medium500}\r\n\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t{children}\r\n\t\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase TableVariant.simple:\r\n\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t<Typography\r\n\t\t\t\t\t\t\t\tcolor={theme.colors.fg.neutral.subtlest}\r\n\t\t\t\t\t\t\t\tcolorScheme={colorScheme}\r\n\t\t\t\t\t\t\t\ttextAlign={typographyTextAlign}\r\n\t\t\t\t\t\t\t\tvariant={TypographyVariant.textMd}\r\n\t\t\t\t\t\t\t\tweight={FontWeight.regular400}\r\n\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t\t{children}\r\n\t\t\t\t\t\t\t</Typography>\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tcase TableVariant.simpleWithoutShadow:\r\n\t\t\t\t\t\treturn children;\r\n\t\t\t\t\tdefault:\r\n\t\t\t\t\t\tthrow new Error('unexpected enum of TableVariant in tableData.tsx');\r\n\t\t\t\t}\r\n\t\t\t})()}\r\n\t\t</TableDataStyled>\r\n\t);\r\n};\r\n","import { type ReactNode } from 'react';\r\n\r\nimport { TableHeadStyled } from './TableHead.style';\r\n\r\nexport interface TableHeadProps {\r\n\tchildren: ReactNode;\r\n}\r\n\r\nexport const TableHead = (props: TableHeadProps) => {\r\n\tconst { children } = props;\r\n\r\n\treturn <TableHeadStyled>{children}</TableHeadStyled>;\r\n};\r\n","import { type Property } from 'csstype';\r\nimport { type ReactNode } from 'react';\r\n\r\nimport { type TableHeadScope, TableTextAlign, type TableVariant } from '@/components/table/types';\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\n\r\nimport { TableHeadDataStyled } from './TableHeadData.style';\r\n\r\nexport interface TableHeadDataProps extends DesignSystemBaseProps {\r\n\tabbr?: string;\r\n\tchildren: ReactNode;\r\n\tdelimiter?: boolean;\r\n\theaders?: string;\r\n\tscope?: TableHeadScope;\r\n\ttextAlign?: TableTextAlign;\r\n\tvariant: TableVariant;\r\n\twidth?: Property.Width;\r\n}\r\n\r\nexport const TableHeadData = (props: TableHeadDataProps) => {\r\n\tconst { abbr, children, delimiter = false, headers, scope, textAlign = TableTextAlign.left, variant, width } = props;\r\n\r\n\tconst { chooseColor } = useDesignSystem(props);\r\n\r\n\treturn (\r\n\t\t<TableHeadDataStyled\r\n\t\t\t$align={textAlign}\r\n\t\t\t$chooseColor={chooseColor}\r\n\t\t\t$delimiter={delimiter}\r\n\t\t\t$variant={variant}\r\n\t\t\t$width={width}\r\n\t\t\tabbr={abbr}\r\n\t\t\theaders={headers}\r\n\t\t\tscope={scope}\r\n\t\t>\r\n\t\t\t{children}\r\n\t\t</TableHeadDataStyled>\r\n\t);\r\n};\r\n","import { type ReactNode } from 'react';\r\n\r\nimport { type DesignSystemBaseProps, useDesignSystem } from '@/contexts';\r\n\r\nimport { type TableVariant } from '../types';\r\n\r\nimport { TableRowStyled } from './TableRow.style';\r\n\r\nexport interface TableRowProps extends DesignSystemBaseProps {\r\n\tchildren: ReactNode;\r\n\tvariant: TableVariant;\r\n}\r\n\r\nexport const TableRow = (props: TableRowProps) => {\r\n\tconst { children, variant } = props;\r\n\r\n\tconst { chooseColor } = useDesignSystem(props);\r\n\r\n\treturn (\r\n\t\t<TableRowStyled\r\n\t\t\t$chooseColor={chooseColor}\r\n\t\t\t$variant={variant}\r\n\t\t>\r\n\t\t\t{children}\r\n\t\t</TableRowStyled>\r\n\t);\r\n};\r\n","import { get, type RegisterOptions, useFormContext } from 'react-hook-form';\r\n\r\nimport { TextArea, type TextAreaProps } from './textArea/TextArea';\r\n\r\nexport interface TextAreaFieldProps extends Omit<TextAreaProps, 'onChange' | 'value'> {\r\n\tname: string;\r\n\toptions?: RegisterOptions;\r\n}\r\n\r\nexport const TextAreaField = (props: TextAreaFieldProps) => {\r\n\tconst { name, options, ...otherProps } = props;\r\n\tconst { formState, register } = useFormContext();\r\n\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\r\n\tconst error = get(formState.errors, name);\r\n\r\n\treturn (\r\n\t\t<TextArea\r\n\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access\r\n\t\t\terrorMessage={error?.message}\r\n\t\t\t{...register(name, options)}\r\n\t\t\t{...otherProps}\r\n\t\t/>\r\n\t);\r\n};\r\n","import { get, type RegisterOptions, useFormContext } from 'react-hook-form';\r\n\r\nimport { TextInput, type TextInputProps } from './textInput/TextInput';\r\n\r\nexport interface TextInputFieldProps extends Omit<TextInputProps, 'onChange' | 'value'> {\r\n\toptions?: RegisterOptions;\r\n}\r\n\r\nexport const TextInputField = (props: TextInputFieldProps) => {\r\n\tconst { name, options, ...otherProps } = props;\r\n\tconst { formState, register } = useFormContext();\r\n\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\r\n\tconst error = get(formState.errors, name);\r\n\r\n\treturn (\r\n\t\t<TextInput\r\n\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access\r\n\t\t\terrorMessage={error?.message}\r\n\t\t\t{...register(name, options)}\r\n\t\t\t{...otherProps}\r\n\t\t/>\r\n\t);\r\n};\r\n","import { useTheme } from '@emotion/react';\r\nimport { type ReactNode, useCallback, useState } from 'react';\r\nimport Switch from 'react-switch';\r\n\r\nimport { Typography, TypographyVariant } from '@/components/typography';\r\nimport { FontWeight } from '@/theme';\r\n\r\nimport { LabelStyled, Wrapper } from './Toggle.style';\r\n\r\nexport interface ToggleProps {\r\n\tdefaultValue?: boolean;\r\n\tdisabled?: boolean;\r\n\tid: string | undefined;\r\n\tlabel?: ReactNode | string;\r\n\tname: string;\r\n\tonChange?: (value: boolean) => void;\r\n}\r\n\r\n/**\r\n * Currently not compatible with react-hook-form\r\n */\r\nexport const Toggle = (props: ToggleProps) => {\r\n\tconst { defaultValue = false, disabled, id, label, name, onChange } = props;\r\n\r\n\tconst theme = useTheme();\r\n\r\n\tconst [checked, setChecked] = useState<boolean>(defaultValue);\r\n\r\n\tconst handleChange = useCallback(\r\n\t\t(nextChecked: boolean) => {\r\n\t\t\tsetChecked(nextChecked);\r\n\t\t\tif (onChange !== undefined) {\r\n\t\t\t\tonChange(nextChecked);\r\n\t\t\t}\r\n\t\t},\r\n\t\t[onChange],\r\n\t);\r\n\r\n\treturn (\r\n\t\t<Wrapper\r\n\t\t\t$checked={checked}\r\n\t\t\t$disabled={disabled}\r\n\t\t>\r\n\t\t\t<Switch\r\n\t\t\t\tactiveBoxShadow=\"\"\r\n\t\t\t\tborderRadius={9999}\r\n\t\t\t\tchecked={checked}\r\n\t\t\t\tcheckedIcon={false}\r\n\t\t\t\tclassName=\"react-switch\"\r\n\t\t\t\tdisabled={disabled}\r\n\t\t\t\thandleDiameter={16}\r\n\t\t\t\theight={21}\r\n\t\t\t\tid={id}\r\n\t\t\t\tname={name}\r\n\t\t\t\toffColor={theme.colors.bg.neutral.white.light}\r\n\t\t\t\toffHandleColor={theme.colors.bg.neutral.white.light}\r\n\t\t\t\tuncheckedIcon={false}\r\n\t\t\t\twidth={36}\r\n\t\t\t\tonChange={handleChange}\r\n\t\t\t\tonColor={disabled === true ? theme.colors.bg.neutral.white.light : theme.colors.bg.brand.bold.light}\r\n\t\t\t\tonHandleColor={theme.colors.bg.neutral.white.light}\r\n\t\t\t/>\r\n\r\n\t\t\t{label !== undefined && (\r\n\t\t\t\t<LabelStyled htmlFor={id}>\r\n\t\t\t\t\t<Typography\r\n\t\t\t\t\t\tvariant={TypographyVariant.textSm}\r\n\t\t\t\t\t\tweight={FontWeight.medium500}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t{label}\r\n\t\t\t\t\t</Typography>\r\n\t\t\t\t</LabelStyled>\r\n\t\t\t)}\r\n\t\t</Wrapper>\r\n\t);\r\n};\r\n","import { useIntl } from 'react-intl';\r\n\r\nimport { FormattedHtmlMessage, useIsMessageDisplayable } from '@/components/formattedMessage';\r\nimport { TooltipInfo } from '@/components/tooltip/info/TooltipInfo';\r\nimport { TooltipInfoDisplayMethod } from '@/components/tooltip/types';\r\nimport { htmlNbsp } from '@/constants';\r\nimport { type DesignSystemBaseProps } from '@/contexts';\r\nimport { type MessageDescriptorWithPrimitiveValues } from '@/types';\r\n\r\nexport interface TooltipInfoDisplayableCheckProps extends DesignSystemBaseProps {\r\n\tbody: MessageDescriptorWithPrimitiveValues;\r\n\tcloseButtonAriaLabel?: MessageDescriptorWithPrimitiveValues;\r\n\tdisplayMethod: TooltipInfoDisplayMethod;\r\n\ttitle?: MessageDescriptorWithPrimitiveValues;\r\n\ttriggerAriaLabel?: MessageDescriptorWithPrimitiveValues;\r\n}\r\n\r\nexport const TooltipInfoDisplayableCheck = (props: TooltipInfoDisplayableCheckProps) => {\r\n\tconst { body, closeButtonAriaLabel, displayMethod, title, triggerAriaLabel, ...restProps } = props;\r\n\r\n\tconst { formatMessage } = useIntl();\r\n\r\n\tconst isMessageDisplayable = useIsMessageDisplayable();\r\n\r\n\tif (!isMessageDisplayable(body)) {\r\n\t\treturn null;\r\n\t}\r\n\r\n\treturn (\r\n\t\t<>\r\n\t\t\t{displayMethod === TooltipInfoDisplayMethod.withNbsp && htmlNbsp}\r\n\t\t\t<TooltipInfo\r\n\t\t\t\t{...restProps}\r\n\t\t\t\tfloatingElement={{\r\n\t\t\t\t\tbody: <FormattedHtmlMessage {...body} />,\r\n\t\t\t\t\ttitle: title !== undefined && isMessageDisplayable(title) ? <FormattedHtmlMessage {...title} /> : undefined,\r\n\t\t\t\t\tcloseButtonAriaLabel:\r\n\t\t\t\t\t\tcloseButtonAriaLabel !== undefined && isMessageDisplayable(closeButtonAriaLabel)\r\n\t\t\t\t\t\t\t? formatMessage(closeButtonAriaLabel, closeButtonAriaLabel.values)\r\n\t\t\t\t\t\t\t: undefined,\r\n\t\t\t\t}}\r\n\t\t\t\ttriggerAriaLabel={\r\n\t\t\t\t\ttriggerAriaLabel !== undefined && isMessageDisplayable(triggerAriaLabel) ? formatMessage(triggerAriaLabel, triggerAriaLabel.values) : undefined\r\n\t\t\t\t}\r\n\t\t\t/>\r\n\t\t</>\r\n\t);\r\n};\r\n","import { useCallback } from 'react';\r\nimport { useIntl } from 'react-intl';\r\n\r\nimport { FormattedHtmlMessage, useIsMessageDisplayable } from '@/components/formattedMessage';\r\nimport { type TooltipInfoDescriptor, type TooltipWidth } from '@/components/tooltip';\r\nimport { type MessageDescriptorWithPrimitiveValues } from '@/types';\r\n\r\nexport interface CreateTooltipInfoDescriptorParam {\r\n\tbody: MessageDescriptorWithPrimitiveValues;\r\n\tcloseButtonAriaLabel?: MessageDescriptorWithPrimitiveValues;\r\n\ttitle?: MessageDescriptorWithPrimitiveValues;\r\n\ttriggerAriaLabel?: MessageDescriptorWithPrimitiveValues;\r\n\twidth?: TooltipWidth;\r\n}\r\n\r\nexport type CreateTooltipInfoDescriptor = (param: CreateTooltipInfoDescriptorParam) => TooltipInfoDescriptor | undefined;\r\n\r\nexport const useCreateTooltipInfoDescriptor = (): CreateTooltipInfoDescriptor => {\r\n\tconst { formatMessage } = useIntl();\r\n\r\n\tconst isMessageDisplayable = useIsMessageDisplayable();\r\n\r\n\tconst callback = useCallback<CreateTooltipInfoDescriptor>(\r\n\t\t(param) => {\r\n\t\t\tconst { body, closeButtonAriaLabel, title, triggerAriaLabel, width } = param;\r\n\r\n\t\t\tif (!isMessageDisplayable(body)) {\r\n\t\t\t\treturn undefined;\r\n\t\t\t}\r\n\r\n\t\t\treturn {\r\n\t\t\t\tbody: <FormattedHtmlMessage {...body} />,\r\n\t\t\t\ttitle: title !== undefined && isMessageDisplayable(title) ? <FormattedHtmlMessage {...title} /> : undefined,\r\n\t\t\t\tcloseButtonAriaLabel:\r\n\t\t\t\t\tcloseButtonAriaLabel !== undefined && isMessageDisplayable(closeButtonAriaLabel)\r\n\t\t\t\t\t\t? formatMessage(closeButtonAriaLabel, closeButtonAriaLabel.values)\r\n\t\t\t\t\t\t: undefined,\r\n\t\t\t\ttriggerAriaLabel:\r\n\t\t\t\t\ttriggerAriaLabel !== undefined && isMessageDisplayable(triggerAriaLabel) ? formatMessage(triggerAriaLabel, triggerAriaLabel.values) : undefined,\r\n\t\t\t\twidth: width,\r\n\t\t\t};\r\n\t\t},\r\n\t\t[isMessageDisplayable, formatMessage],\r\n\t);\r\n\r\n\treturn callback;\r\n};\r\n","import { type Key, useCallback, useState } from 'react';\r\n\r\nexport interface UseFormSuccessOutcomeManagerReturn {\r\n\tformKey: Key;\r\n\tformSuccessOutcomeProps: {\r\n\t\tonHide: () => void;\r\n\t\tvisible: boolean;\r\n\t};\r\n\tonMutationSuccess: () => void;\r\n}\r\n\r\nexport const useFormSuccessOutcomeManager = (): UseFormSuccessOutcomeManagerReturn => {\r\n\tconst [visible, setVisible] = useState(false);\r\n\tconst [successCount, setSuccessCount] = useState(0);\r\n\r\n\tconst handleMutationSuccess = useCallback(() => {\r\n\t\tsetSuccessCount((count) => count + 1);\r\n\t\tsetVisible(true);\r\n\t}, []);\r\n\r\n\treturn {\r\n\t\tonMutationSuccess: handleMutationSuccess,\r\n\t\tformKey: successCount,\r\n\t\tformSuccessOutcomeProps: {\r\n\t\t\tvisible: visible,\r\n\t\t\tonHide: () => setVisible(false),\r\n\t\t},\r\n\t};\r\n};\r\n","import { useCallback } from 'react';\r\nimport { useIntl } from 'react-intl';\r\n\r\nimport { type MessageDescriptorWithPrimitiveValues } from '@/types';\r\n\r\nimport { FormattedHtmlMessage } from '../formattedHtmlMessage/FormattedHtmlMessage';\r\nimport { isMessageDisplayable } from '../isMessageDisplayable/isMessageDisplayable';\r\n\r\nexport const useGetFormattedHtmlMessageIfDisplayable = () => {\r\n\tconst { formatMessage: t } = useIntl();\r\n\r\n\tconst callback = useCallback(\r\n\t\t(messageDescriptor: MessageDescriptorWithPrimitiveValues) => {\r\n\t\t\tif (isMessageDisplayable(t, messageDescriptor)) {\r\n\t\t\t\treturn <FormattedHtmlMessage {...messageDescriptor} />;\r\n\t\t\t}\r\n\r\n\t\t\treturn undefined;\r\n\t\t},\r\n\t\t[t],\r\n\t);\r\n\r\n\treturn callback;\r\n};\r\n"],"names":["defaultValue","mediaType","undefined","MediaTypeContext","createContext","MediaTypeProvider","props","children","value","useMemo","_jsx","Provider","InputSize","InputTextAlign","MediaType","ColorScheme","FieldOptionality","LabelTooltipPosition","fallbackMediaType","desktop","useMediaType","param","options","context","useContext","paramMediaType","defaultMediaType","contextMediaType","colorScheme","ColorSchemeContext","ColorSchemeProvider","fallbackColorScheme","light","useColorScheme","paramColorScheme","defaultColorScheme","contextColorScheme","fullMessages","button","formErrorSummary","title","fieldWrapper","DesignSystemMessagesContext","DesignSystemMessagesProvider","messages","messagesProp","contextValue","Object","fromEntries","entries","map","componentName","fullPropDefaults","busyDelay","DesignSystemPropDefaultsContext","DesignSystemPropDefaultsProvider","defaults","defaultsProp","DesignSystemProvider","propDefaults","node","getClampedFontSize","fontSize","getColor","colorSchemeObject","dark","Error","isRenderable","mergeRefs","refs","filteredRefs","filter","Boolean","length","element","ref","current","pxToRem","px","base","match","exec","trim","Number","parseFloat","isFinite","number","toFixed","toString","renderReactNodeArray","items","separator","renderableItems","separatorRenderable","result","forEach","item","index","push","Fragment","memoize","fn","cache","create","arg","reactPropsRegex","isPropValid","prop","test","charCodeAt","baseStyled","tag","emotionStyled","shouldForwardProp","customShouldForwardProp","isDomTag","startsWith","styled","Proxy","get","v","useChooseColor","useCallback","useDesignSystem","chooseColor","FieldLabelStoreContext","labels","registerLabel","FieldLabelStoreProvider","labelsRef","useRef","name","label","useFieldLabels","useRegisterFieldLabel","FieldConfigContext","useFieldConfig","useDesignSystemMessages","useDesignSystemPropDefaults","AccordionVariant","IconSystemArrowDownBig","stroke","_jsxs","fill","height","viewBox","width","xmlns","d","strokeLinecap","strokeLinejoin","strokeWidth","IconSystemArrowDownSmall","IconSystemArrowLeftBig","transform","IconSystemArrowLeftSmall","IconSystemArrowRightBig","IconSystemArrowRightSmall","IconSystemArrowUpBig","IconSystemArrowUpSmall","IconSystemArrowUpRightBig","IconSystemArrowUpRightSmall","IconSystemBankBig","IconSystemBankSmall","IconSystemCheckmarkBig","IconSystemCheckmarkSmall","IconSystemChevronDownBig","IconSystemChevronDownSmall","IconSystemChevronLeftBig","IconSystemChevronLeftSmall","IconSystemChevronRightBig","IconSystemChevronRightSmall","IconSystemChevronUpBig","IconSystemChevronUpSmall","IconSystemCloseBig","IconSystemCloseSmall","IconSystemCrosshairBig","IconSystemCrosshairSmall","IconSystemEventBig","IconSystemEventSmall","IconSystemFileTextBig","IconSystemFileTextSmall","IconSystemLogoutBig","IconSystemLogoutSmall","IconSystemMapBig","IconSystemMapSmall","IconSystemMinusBig","IconSystemMinusSmall","IconSystemPinBig","IconSystemPinSmall","IconSystemRefreshBig","IconSystemRefreshSmall","IconSystemSearchBig","IconSystemSearchSmall","IconSystemShareBig","IconSystemShareSmall","IconSystemSpinnerBig","IconSystemSpinnerSmall","IconSystemTrashBig","IconSystemTrashSmall","IconSystemUnorderedListBig","IconSystemUnorderedListSmall","IconSystemCalendarBig","IconSystemCalendarSmall","IconChevronRightCircleBig","IconChevronRightCircleSmall","IconSystemClockBig","IconSystemClockSmall","IconSystemCloseCircleBig","IconSystemCloseCircleSmall","IconSystemDownloadBig","IconSystemDownloadSmall","IconSystemEyeClosedBig","IconSystemEyeClosedSmall","IconSystemEyeOpenBig","IconSystemEyeOpenSmall","IconSystemMailBig","IconSystemMailSmall","IconSystemMenuBig","IconSystemMenuSmall","IconSystemPlusBig","IconSystemPlusSmall","IconSystemPlusCircleBig","IconSystemPlusCircleSmall","IconSystemUploadCloudBig","IconSystemUploadCloudSmall","IconSystemType","IconSystemSize","sizeBig","sizeSmall","Wrapper","process","env","NODE_ENV","target","$size","big","small","TypeError","IconSystem","ariaHidden","fillFromProps","size","strokeFromProps","type","theme","useTheme","colors","icon","neutral","bg","white","arrowDown","arrowUp","arrowUpRight","arrowRight","arrowLeft","bank","checkmark","chevronDown","chevronUp","chevronRight","chevronLeft","close","plus","plusCircle","minus","search","pin","crosshair","unorderedList","event","refresh","share","logout","spinner","fileText","trash","uploadCloud","chevronRightCircle","download","closeCircle","calendar","clock","menu","mail","eyeOpen","eyeClosed","Spacing","resolveSpacingValue","spacing","none","WhiteSpace","resolveWhiteSpaceValue","whiteSpace","FontWeight","resolveFontWeightValue","fontWeight","font","weight","variables","color","fg","default","subtle","subtlest","disabled","inverse","link","hover","pressed","success","warning","error","info","promo","brand","bold","accent","semibold","surface","risen","sunken","border","background","layout","breakpoint","xs","sm","md","lg","xl","container","xxs","full","gold","pink","grey","black","yellow","transparent","green","red","blue","palette","gold500","gold600","gold700","gold800","pink100","pink200","pink300","pink400","pink500","pink600","pink700","pink800","pink900","pink1000","grey100","grey200","grey300","grey400","grey500","grey600","grey700","grey800","grey900","grey1000","yellow100","yellow200","yellow300","yellow400","yellow500","yellow600","yellow700","yellow800","yellow900","yellow1000","green100","green200","green300","green400","green500","green600","green700","green800","green900","green1000","red100","red200","red300","red400","red500","red600","red700","red800","red900","red1000","blue100","blue200","blue300","blue400","blue500","blue600","blue700","blue800","blue900","blue1000","overlay","shadow","cards","ultraStrongBlueLg","strongBlueMd","focus","heading","h1","mobile","h2","h3","h4","h5","body","lineHeight","thin","extraLight","regular","medium","semiBold","extraBold","heavy","ultra","letterSpacing","family","main","xxl","xxxl","xxxxl","xxxxxl","borderRadius","box","breakpoints","zIndex","dropdown","sticky","fixed","modalBackdrop","offcanvas","modal","popover","tooltip","Overflow","resolveOverflowValue","overflow","BorderRadius","resolveBorderRadiusValue","FlexWrap","resolveFlexWrapValue","flexWrap","TextDecoration","resolveTextDecorationValue","textDecoration","noneImportant","underline","getTextDecorationStyle","css","SpanButtonStyled","$disabled","$borderRadius","$chooseColor","SpanButton","className","id","onClick","onMouseDown","onMouseUp","onTouchStart","restProps","TypographyVariant","TypographyTextAlign","_ref","styles","TypographyStyled","$weight","$color","$textAlign","$whiteSpace","$fullWidth","$decoration","$variant","textLg","textMd","textSm","textXs","getAs","variant","originalAs","Typography","forwardRef","as","colorProp","colorSchemeProp","decoration","fullWidth","mediaTypeProp","role","suppressHydrationWarning","tabIndex","textAlign","left","regular400","inherit","otherProps","displayName","$isOpen","ItemContainer","Item","IconLabelWrapper","DescriptionIconWrapper","_EMOTION_STRINGIFIED_CSS_ERROR__","_ref2","Container","AccordionItem","closeActionAriaLabel","content","description","isOpen","openActionAriaLabel","contentWrapperId","useId","itemContainerId","medium500","stopPropagation","AccordionContent","LabelWrapper","VisuallyHiddenStyled","VisuallyHidden","ButtonStyle","ButtonSize","ButtonType","ButtonContentAlign","ButtonStyled","$contentAlign","center","right","$type","anchor","$buttonStyle","primary","secondary","tertiary","IconWrapper","SpinnerWrapper","Button","ariaDisabledAttribute","ariaLabelAttribute","ariaDisabled","ariaDisabledProp","ariaLabel","ariaLabelProp","busy","busyProp","busyDelayProp","busyMessage","busyMessageProp","buttonStyle","contentAlign","href","htmlRef","iconLeft","iconRight","iconSystemLeft","iconSystemRight","isLoading","rel","designSystemMessages","designSystemPropDefaults","localRef","mergedRef","useMergeRefs","submit","busySubmit","busyGeneric","busyDelayed","setBusyDelayed","useState","busyTimeoutId","useEffect","window","clearTimeout","setTimeout","typographyVariant","iconSystemSize","handleClick","preventDefault","_Fragment","reset","ButtonsLayoutAlign","ButtonsLayoutDirection","_ref3","_ref4","_ref5","_ref6","_ref7","_ref8","_ref9","_ref0","_ref1","_ref10","_ref11","_ref12","ButtonsLayoutStyled","$wrap","$gap","$direction","row","rowReverse","column","columnReverse","$align","stretch","spaceBetween","start","end","CalculatorResultDescription","createModalContainer","modalContainerId","modalContainer","document","createElement","appendChild","modalCloseButtonDimensions","ModalCloseButton","Overlay","ModalOverlay","ModalWidthType","ModalVerticalPosition","ReasonForClosing","verticalPaddingOffset","$withoutPadding","$widthType","narrow","narrowOnDesktopAndTablet","$verticalPosition","centerOnTablet","Box","CloseButtonWrapper","defaultModalRootElement","Modal","closeButtonAriaLabel","hideCloseButton","idProp","onClose","rootElement","modalRootElementProp","verticalPosition","widthType","withoutPadding","modalRootElement","Element","getElementById","modalCreatedEvent","CustomEvent","dispatchEvent","getOrCreateModalContainer","generatedId","wrapperId","titleId","previousActiveElementRef","activeElement","initialFocusElement","scope","querySelector","join","focusableElements","querySelectorAll","queryFocusableElements","firstFocusableElement","at","lastFocusableElement","handleKeyDown","key","esc","shiftKey","includes","addEventListener","removeEventListener","useModalFocusTrap","createPortal","closeButton","ModalTextWrapper","ModalTextWrapperIn","ModalTextIconWrapper","ModalTextIconWrapperIn","CalculatorResultModal","modalCloseButtonAriaLabel","triggerText","setFalse","closeModal","setTrue","openModal","isModalOpen","useBoolean","CalculatorResultInfoPosition","StackDirection","StackStyled","Stack","direction","gap","wrap","noWrap","FormattedHtmlMessage","defaultMessage","htmlValues","values","valuesProp","intl","useIntl","messageDescriptor","messageValues","mapValues","escape","dangerouslySetInnerHTML","__html","formatMessage","ignoreTag","isMessageDisplayable","t","toLowerCase","useIsMessageDisplayable","IconBillBig","clipRule","fillRule","IconBillSmall","IconCheckBig","IconCheckSmall","IconGraphIncreaseBig","IconGraphIncreaseSmall","IconProductInformationBig","IconProductInformationSmall","IconLoginPasswordBig","IconLoginPasswordSmall","IconMoneyBagBig","IconMoneyBagSmall","IconProductPasswordLockBig","IconProductPasswordLockSmall","IconPeopleBig","IconPeopleSmall","IconPiggyBankBig","IconPiggyBankSmall","IconProductRewardBig","clipPath","IconProductRewardSmall","IconUserBig","IconUserSmall","IconUserAddPlusBig","IconUserAddPlusSmall","IconProductWarningCircleBig","IconProductWarningCircleSmall","IconProductWarningTriangleBig","IconProductWarningTriangleSmall","IconAtmBig","IconAtmSmall","IconBankBig","IconBankSmall","IconBillingPaymentBig","IconBillingPaymentSmall","IconCoinsStackBig","IconCoinsStackSmall","IconCreditCardBig","IconCreditCardSmall","IconHelpChatBig","IconHelpChatSmall","IconHouseRefreshBig","IconHouseRefreshSmall","IconMailCheckBig","IconMailCheckSmall","IconMobilePhoneBig","IconMobilePhoneSmall","IconMonetaBig","IconMonetaSmall","IconShieldCheckBig","IconShieldCheckSmall","IconSuitcaseBig","IconSuitcaseSmall","IconWalletBig","IconWalletSmall","IconProductType","IconProductSize","IconProductVariant","IconProductHighlightType","iconProductSizeBig","iconProductSizeSmall","getSvgSize","$highlightType","getWrapperSize","hasHighlight","backgroundColor","borderColor","defaultInverse","IconProduct","highlightType","active","information","reward","warningTriangle","passwordLock","people","warningCircle","creditCard","billingPayment","mobilePhone","suitcase","atm","moneta","helpChat","mailCheck","check","bill","piggyBank","user","userAddPlus","moneyBag","loginPassword","shieldCheck","wallet","coinsStack","graphIncrease","houseRefresh","TooltipPlacement","TooltipInfoDisplayMethod","TooltipCloseReason","TooltipWidth","wrapperPadding","$width","TitleWrapper","BodyWrapper","CloseButton","TooltipFloatingElement","style","nextCloseReason","setNextCloseReason","onKeyDown","closeButtonKeyPress","closeButtonClick","Arrow","FloatingArrow","initialCloseReason","TooltipGeneral","closeDelay","floatingElement","onOpen","openDelay","placement","portalRootElement","renderParent","closeReason","setCloseReason","zeroClosing","arrowRef","floatingStyles","floating","floatingRef","setFloating","setFloatingRef","setReference","setReferenceRef","useFloating","open","onOpenChange","middleware","offset","flip","shift","arrow","whileElementsMounted","autoUpdate","useHover","move","mouseOnly","delay","handleClose","safePolygon","buffer","blockPointerEvents","requireIntent","click","useClick","dismiss","useDismiss","useRole","getFloatingProps","getReferenceProps","useInteractions","transitionStyles","useTransitionStyles","initial","opacity","duration","handleFloatingWrapperBlur","nextFocusedElement","relatedTarget","contains","focusLost","userProps","FloatingPortal","root","onBlur","closeReasonParam","tipRadius","liferayClassNames","tooltipInfoButton","TooltipInfo","triggerAriaLabel","setClose","setOpen","unsetHover","setHover","isHover","portalRootElementRef","wrapperRef","handleTooltipGeneralClose","top","getParentProps","wrapperProps","onMouseEnter","onMouseLeave","TooltipInfoConditional","displayMethod","withNbsp","mapTooltipInfoDescriptorToPropsSubset","tooltipInfoDescriptor","$isDescriptionVisible","$mediaType","BorderGradientWrapper","Result","TopWrapper","HeaderWrapper","HeaderTopWrapper","HeaderMainWrapper","HeaderBottomWrapper","Hr","BodyItemsWrapper","BodyItemWrapper","BodyItemLeftWrapper","BodyItemRightWrapper","MainWrapper","checkboxSize","LabelStyled","CheckboxStyled","$focused","$invalid","focusStyle","$checkBackground","SpanStyled","CheckboxControl","checked","focused","invalid","onChange","checkBackground","encodeBase64","getCheckboxBaseCheck","useUniqueIdIfIsUndefined","idParam","reactUniqueId","CheckboxPosition","ControlAndLabelWrapper","$position","LabelAndTooltipWrapper","$tooltipPosition","rightCenter","TooltipWrapper","inline","Checkbox","errorMessage","labelAs","labelColor","labelColorProp","labelHiddenText","labelId","labelSuffix","position","tooltipPosition","htmlFor","CircularProgressBar","iconProduct","progress","circumference","Math","PI","gradientId","gradientUnits","x1","x2","y1","y2","stopColor","cx","cy","r","strokeDasharray","strokeDashoffset","transition","ComboBoxItemOrderSource","ComboBoxValueType","useAddonWidth","addon","inputRef","currentWidth","setCurrentWidth","previousWidthRef","addonDefined","updateWidth","previousWidth","offsetWidth","updateWidthDebounced","useDebounceCallback","maxWait","useLayoutEffect","resizeObserverHandler","useResizeObserver","onResize","getInputSizeValue","$halfWidth","fontStyles","getPrefixSideInputPaddingValue","prefixWidth","hasThickBorder","getSuffixSideInputPaddingValue","suffixWidth","getButtonSideInputPaddingValue","buttonWidth","InputBaseStyled","$colorInput","parseInt","$hasIcon","$prefixWidth","$suffixWidth","$buttonWidth","PrefixWrapper","$prefixColor","ButtonWrapper","SuffixWrapper","InputBase","forwardedRef","ariaDescribedByAttribute","ariaInvalidAttribute","ariaLabelledByAttribute","ariaRequiredAttribute","colorInput","describedBy","halfWidth","iconSystem","isPastingDisabled","labelledBy","maxLength","onFocus","placeholder","prefix","prefixColor","required","suffix","prefixWrapperRef","suffixWrapperRef","buttonWrapperRef","handlePaste","$colorScheme","onPaste","identityFormatter","makeFormatter","jsonFormatter","JSON","stringify","ComboBoxWrapper","MenuWrapper","Menu","MenuItem","$highlighted","$selected","defaultCompareFn","a","b","String","localeCompare","UntypedComboBoxControl","formatter","formatterProp","getItemKey","inputPrefix","inputSize","inputSuffix","inputTextAlign","inputWeight","itemOrder","itemsProp","shouldHighlightFirstItem","itemFormatter","delegate","formattedValue","itemToString","downshiftItem","custom","input","formatAsPrimitive","itemOrderSource","source","itemOrderCompareFn","compareFn","wrappedItems","wrappedItemsProp","nilItems","otherItems","partition","wrappedItem","Array","from","sort","resolveNextSelectedItem","inputValueParam","highlightedIndexParam","matchedItem","find","closeMenu","getInputProps","getItemProps","getMenuProps","highlightedIndex","inputValue","selectItem","useCombobox","selectedItem","onSelectedItemChange","defaultHighlightedIndex","onStateChange","nextInputValue","stateChangeTypes","InputChange","InputBlur","stateReducer","state","actionAndChanges","changes","InputClick","nextSelectedItem","itemToKey","inputProps","menuProps","itemIndex","isSelected","format","ComboBoxControl","FieldWrapperLayout","InputLabelSize","Label","InputLabel","hiddenText","$layout","vertical","horizontal","LabelAndHintWrapper","ControlSection","HintTextWrapper","ControlAndAddonsWrapper","ControlWrapper","$mobileWidth","ValidationOutputAndNoteWrapper","$onlyNote","ValidationOutputWrapper","FieldAddonPosition","FieldWrapper","addons","controlMobileWidth","controlWidth","hiddenHintText","hiddenHintTextProp","hintText","invalidProp","labelSuffixProp","note","optionality","successMessage","tooltipProp","controlSectionWidth","fieldConfig","optionalLabelSuffix","optional","getTooltipTriggerAriaLabel","tooltipHiddenHintText","uniqueId","controlId","validationOutputId","hintTextId","registerFieldLabel","beforeControl","afterControl","belowControl","bottom","joinIdReferenceLists","lists","withFieldWrapper","FieldControl","WithFieldWrapper","describedByProp","labelledByProp","requiredProp","ComboBox","SelectVariant","SelectItemOrderSource","DownChevron","focusable","display","DropdownIndicatorStyled","inputLike","$open","DropdownIndicator","SelectWrapper","text","focusOutlineCss","ToggleButton","getToggleButtonBorderColor","ToggleButtonValue","UntypedSelectControl","nilMessage","useSelectFormatter","getToggleButtonProps","useSelect","toggleButtonRef","hasIcon","SelectControl","Select","Navigation","NavigationContainer","DayNamesWrapper","DayNameWrapper","SelectsWrapper","SelectMonthWrapper","SelectYearWrapper","monthList","defaultMinDate","Date","defaultMaxDate","CustomHeader","changeMonth","changeYear","decreaseMonth","increaseMonth","locale","maxDate","minDate","monthDate","monthSelectAriaLabel","monthYearSelectEnabled","nextMonthAriaLabel","nextMonthButtonDisabled","previousMonthAriaLabel","prevMonthButtonDisabled","yearSelectAriaLabel","monthName","formatDate","dayDescriptors","firstDay","weekStartsOn","i","dayIndex","localize","day","shortName","charAt","toUpperCase","slice","yearList","minYear","getFullYear","maxYear","range","handleYearChange","handleMonthChange","monthFormatter","monthString","month","marginRight","getMonth","marginLeft","dayDescriptor","InputBaseWithInnerRef","innerRef","DatePickerContainer","NonVisible","PopperContainer","CalendarIconWrapper","ChevronIconWrapper","DayWrapper","defaultDateFormat","DatePickerControl","chevronCloseAriaLabel","chevronOpenAriaLabel","chooseDayAriaLabelPrefix","dateFormat","disabledDayAriaLabelPrefix","filterDate","localeProp","monthAriaLabelPrefix","selected","toggle","toggleIsOpen","cs","ReactDatepicker","ariaDescribedBy","ariaInvalid","ariaLabelledBy","ariaRequired","calendarContainer","customInput","placeholderText","popperContainer","renderCustomHeader","renderDayContents","selectsMultiple","selectsRange","showPopperArrow","showTimeSelect","onClickOutside","onSelect","datePickerValueFormat","DatePicker","EmailInputControl","EmailInput","LiStyled","$isLink","ErrorBoxListItem","handleKeyPress","onKeyPress","UlStyled","ErrorBoxList","ErrorBox","semiBold600","FileInputErrorCode","FileInputItemType","getFileErrorCode","dropzoneErrorCode","ErrorCode","FileInvalidType","unsupportedFormat","FileTooLarge","fileSizeTooLarge","TooManyFiles","tooManyFiles","general","getFileErrorByDropzoneRejection","rejection","fileName","file","errors","code","normalizeFileExtension","extension","replace","DropzoneWrapper","UploadIcon","SelectFilesLink","LimitDescriptionWrapper","$dragActive","Dropzone","dragActive","DropzoneDragFilesHere","DropzoneDragOrSelectFiles","DropzoneSelectFiles","fileInputSettings","LimitDescription","onOpenClick","selectedFiles","ErrorRowWrapper","DescriptionSection","ErrorRow","UploadErrorReason","UploadFailed","errorCode","FileRowWrapper","LeftSection","FileName","RightSection","FileRow","getRemoveButtonAriaLabel","onRemove","RemoveButtonText","handleRemoveKeyPress","FileList","onFileRemove","$active","FileInputControl","fileExtensions","fileExtensionsProp","getFileRemovedLiveText","getFilesAddedLiveText","maxFiles","maxSize","maxTotalSize","files","hovered","setHovered","setItems","useMediaQuery","ariaLiveText","setAriaLiveText","handleDrop","acceptedFiles","fileRejections","totalFileSize","reduce","sizeAccumulator","filteredAcceptedFiles","totalFileSizeTooLarge","fileExtension","split","pop","fileItems","errorItems","previousItems","getRootProps","isDragActive","useDropzone","onDrop","multiple","noClick","handleFileRemove","fileToRemove","rootProps","FileInputBase","FileInput","FormatAmountCurrencyDisplay","FormatAmountGrouping","getUseGrouping","grouping","auto","always","getFormatNumberOptions","currency","currencyDisplay","symbol","maximumFractionDigits","minimumFractionDigits","useGrouping","removeCurrencyCode","formatted","useFormatAmount","formatNumber","useFormatter","BaseFormattedAmount","formatAmount","noneGroupingParam","amount","noneGroupingAmount","useFormatPercentage","FormattedPercentageInner","formatPercentage","FormattedPercentage","memo","useFormattedPercentage","InfoboxVariant","InfoboxSize","InfoboxStyled","$isWarning","getFlexDirection","InfoboxLayout","flexDirection","ContentWrapper","TextContentWrapper","ActionNodeWrapper","ChildrenWrapper","Infobox","actionNode","circularProgress","isWarning","textContent","iconSize","iconStroke","FormConfigContext","useFormContext","useReactHookFormContext","SubmitResultModalContentStyled","IconFlagType","IconFlagCz","xmlnsXlink","maskUnits","x","y","mask","patternContentUnits","xlinkHref","IconFlagEu","IconFlagHr","IconFlagUsa","LoaderSize","LoaderSvg","loaderSize","Loader","foregroundColor","ContentLoader","speed","MaskedInputBase","maskOptions","onAccept","setUnmaskedValue","useIMask","maskedValue","unmaskedValue","nextRef","MaskedInput","withMaskedInputField","Component","control","field","fieldState","useController","rules","message","handleBlur","MaskedInputField","getNumberMaskFactoryOpts","allowNegative","decimalPlaces","integerPlaces","max","scale","radix","mapToRadix","thousandsSeparator","min","NumberInput","NumberInputField","PaperShadow","PaperStyled","$padding","$overflow","$shadow","Paper","padding","paddingProp","czechCallingCodePrefixRegExp","RegExp","prepare","chars","PhoneInput","PhoneInputField","ProgressStepperStyled","Progress","$percent","ProgressStepper","activeStepIndex","ariaValueMax","numberOfSteps","ariaValueMin","ariaValueNow","ariaValueText","percent","ProgressStepperWrapper","ProgressPaper","progressDefinition","InputStyled","ErrorWrapper","RadioButton","RadioButtonGroupLayout","ItemsWrapper","$controlWidth","$gridColumns","$fiveItemsCase","ItemWrapper","$arrangeInGrid","$itemMinWidth","RadioButtonGroupControl","buttonsLayout","flex","gridColumns","gridColumnsProp","itemMinWidth","grid","smartGrid","itemsCount","itemId","itemValue","otherItemParams","RadioButtonGroupBase","RadioButtonGroup","getRadioControlCheckBase64","getRadioBaseCheck","radioSize","RadioStyled","$checkedBackground","$checkedDisabledBackground","RadioControl","idFromProps","checkedBackground","checkedDisabledBackground","random","RadioPosition","Radio","RadioGroupDirection","$rowGap","$columnGap","RadioGroupControl","columnGap","rowGap","RadioGroupBase","RadioGroup","SearchInputControl","buttonAction","buttonText","SearchInput","SliderInputRoundingType","SliderStepType","clampSliderSteps","steps","baseStep","breakpointList","bottomBreakpoint","step","getValueBySliderValueVisuallySameStepSize","sliderValue","currentSliderValue","currentValue","breakpointIndexFound","breakpointFound","currentBreakpointIndex","currentBreakpoint","breakpointFoundStep","nextBreakpoint","nextValue","sliderFunctionVisuallyLinearByValue","sliderStep","accumulator","sliderMax","sliderMin","sliderMarks","sliderFunctionVisuallySameStepSize","currentIndex","array","currenBottomBreakpoint","localSteps","getSliderMax","outerCycle","breakpointIndex","getSliderValueByValue","SliderWrapper","HintsWrapper","HintLeftWrapper","HintRightWrapper","RcSliderGlobal","Global","Slider","ariaLabelForHandle","ariaLabelledByForHandle","ariaValueTextFormatter","clampMax","clampMin","disable","minMaxLabels","onFinalChange","stepsProp","stepType","effectiveMin","effectiveMax","sliderWrapperRef","bodyStyleUserSelectRef","disableTextSelection","userSelect","enableTextSelection","unsetFocused","setFocused","handleFocus","prefersHighContrast","mapOurValueToRcSliderValue","visuallyLinearByValue","visuallySameStepSize","rcSliderValue","handle","setAttribute","ariaValueNowObserver","MutationObserver","mutations","mutation","attributeName","getAttribute","observe","attributes","attributeFilter","disconnect","mapRcSliderValueToOurValue","params","ariaValueTextFormatterForHandle","resolveOurValueFromChangeHandler","sliderValueParam","mappedValue","clamp","secondToLastValue","lastChangedValue","handleChange","newValue","handleChangeComplete","handleBackgroundSvgBase64","getSliderHandleBackgroundSvgBase64","getSliderHandleBackgroundSvg","RcSlider","track","outlineWidth","outlineStyle","outlineColor","outlineOffset","rail","backgroundImage","marginTop","boxShadow","cursor","onChangeComplete","createMask","$isHintVisible","$isInputNoteVisible","$isInputVisible","HintWrapper","InputWrapper","$isInputHidden","InputNoteWrapper","SliderInput","inputLimitExceededLiveTextFormatter","inputNote","inputRoundingType","isInputHidden","labelIdProp","onInputChange","onSliderChange","localSliderValue","setLocalSliderValue","localInputRef","mergedInputRef","changeInputValue","valueParam","nativeInputValueSetter","getOwnPropertyDescriptor","HTMLInputElement","prototype","set","console","call","resolve","getSliderInputMaskedValue","handleSliderChange","handleSliderFinalChange","handleLimitExceeded","oldValue","limitExceededText","commitInputChange","numberValue","getSliderInputUnmaskedValue","isNaN","roundedNewValue","ceilBySteps","floorBySteps","roundBySteps","roundingType","nextMax","boundary","currentItem","nextItem","lowerBoundary","upperBoundary","getRoundedValueBySteps","ceilToThousands","ceil","floorToThousands","floor","roundToThousands","round","handleInputBlur","eventValue","handleSliderBlur","handleInputAccept","currentTarget","handleInputFocus","StepperVariant","TextWrapper","Clickable","StepCircle","$isActive","$isCompleted","StepperItem","isActive","isCompleted","Separator","StoreButtonVariant","StoreButtonSize","AndroidSvg","AppleSvg","StoreButtonStyled","TableVariant","TableTextAlign","TableHeadScope","TableStyled","simple","simpleWithoutShadow","exchange","TableDataStyled","$delimiter","TableHeadStyled","TableHeadDataStyled","TableRowStyled","TagType","TagSize","TagTextTransform","TagIconPosition","TagStyled","$clickable","infoLight","neutralSubtle","invert","alert","neutralDefault","$textTransform","uppercase","$iconPosition","TagIconWrapper","$isProduct","Tag","asProp","iconPosition","textTransform","normal","TabsVariant","TabsSize","TabsActiveTabDefaultPosition","TabsWrap","primarySpacing","secondarySpacing","tertiarySpacing","TabItemStyled","ActiveText","TabsItem","ariaControls","infoTags","nowrap","TabsWrapper","TabItemsBox","$tabsSpacing","$noBorder","arrowWrapper","LeftArrowWrapper","LeftArrow","RightArrowWrapper","RightArrow","scrollStep","tagSizeMap","TextAreaStyled","TextAreaControl","TextArea","TextInputControl","TextInput","$checked","TrailingTextInputControl","TrailingTextInput","ReCaptchaErrorType","ReCaptchaError","constructor","instanceNotInitialized","scriptLoading","super","this","ThrownFormLevelErrorType","CaptchaType","defaultThrownFormErrors","formLevelErrors","fieldLevelErrors","genericThrownFormErrors","generic","defaultResolveThrownFormErrors","data","activeIndex","setActiveIndex","prevIndex","handleItemClick","align","buttons","buttonIndex","bodyItems","containerRef","header","infoPosition","underBox","resultBoxRef","topHiddenText","topTooltip","bodyItem","topSeparator","inBox","shouldResetInvalidValues","resetField","date","config","previousConfig","configProp","nextConfig","formConfig","thrownFormLevelErrorFormatter","thrownFormErrors","hasFormLevelErrors","scrollIntoView","behavior","block","output","outputStructured","order","orderProp","titleProp","formState","setFocus","submitCount","errorCount","submitErrors","submitErrorsRef","previousSubmitCountRef","previousSubmitCount","cloneDeep","useSubmitErrors","fieldLabels","formLocatorRef","formRef","alertRef","closest","errorBoxItems","queriedFieldNames","elements","queryFieldNames","fieldOrder","fieldNames","_names","mount","sortBy","fieldName","getComparableIndex","indexOf","POSITIVE_INFINITY","submitError","_options","shouldFocusError","form","ReactHookFormProvider","onHide","visible","ReactIntlFormattedMessage","txt","eu","cz","hr","usa","register","apple","delimiter","headers","typographyTextAlign","abbr","activeTabDefaultPosition","noBorder","tabItems","tabItemsRef","scrollLeft","setScrollLeft","checkScrollPosition","checkScrollPositionDebounced","leftArrowClickHandler","scrollTo","rightArrowClickHandler","clientWidth","scrollWidth","isWrap","isLeftArrowShowing","isRightArrowShowing","activeTabIndex","findIndex","wrapperElement","activeTabItemElement","tabItemsWidth","scrollActiveTabToCenter","offsetLeft","scrollOnlyWhenNotVisible","makeActiveTabVisibleIfItIsNot","elementRect","getBoundingClientRect","containerRect","noScrolling","focusFirstTab","focusLastTab","moveFocusToPreviousTab","moveFocusToNextTab","handleKeydown","flag","tabItemIndex","tagSize","tabItem","onActivate","setChecked","nextChecked","Switch","activeBoxShadow","checkedIcon","handleDiameter","offColor","offHandleColor","uncheckedIcon","onColor","onHandleColor","useCreateTooltipInfoDescriptor","useForm","captcha","captchaProp","onSubmitHandlerError","reCaptchaV3Config","resolveThrownFormErrors","schema","thrownFieldLevelErrorFormatter","setThrownFormErrors","isReCaptchaV3Enabled","isEnabled","reCaptchaV3","isReCaptchaScriptLoading","setIsReCaptchaScriptLoading","checkGoogleReCaptchaInjected","injectGoogleReCaptchaScript","isEnterprise","render","siteKey","onload","useReactHookForm","mode","reValidateMode","resolver","zodResolver","setError","reactHookFormHandleSubmit","handleSubmit","onValid","onInvalid","async","submitStart","submitEnd","captchaExecuteStart","captchaExecuteEnd","captchaToken","reCaptchaInstance","grecaptcha","enterprise","execute","now","action","nextThrownFormErrors","normalizedThrownFormErrors","has","fieldLevelError","reactHookFormError","shouldFocus","timings","assign","useFormSuccessOutcomeManager","setVisible","successCount","setSuccessCount","onMutationSuccess","count","formKey","formSuccessOutcomeProps","useGetFormattedHtmlMessageIfDisplayable","getMessage","suggestions"],"mappings":"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","x_google_ignoreList":[18,19]}
|