intelicoreact 1.8.69 → 2.0.0
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/Atomic/FormElements/ActionAlert/ActionAlert.d.ts +5 -0
- package/dist/Atomic/FormElements/ActionAlert/ActionAlert.interface.d.ts +21 -0
- package/dist/Atomic/FormElements/ActionAlert/index.d.ts +4 -0
- package/dist/Atomic/FormElements/AdvancedStatus/AdvancedStatus.d.ts +5 -0
- package/dist/Atomic/FormElements/AdvancedStatus/AdvancedStatus.interface.d.ts +11 -0
- package/dist/Atomic/FormElements/AdvancedStatus/index.d.ts +3 -0
- package/dist/Atomic/FormElements/Calendar/Calendar.d.ts +5 -0
- package/dist/Atomic/FormElements/Calendar/Calendar.props.d.ts +28 -0
- package/dist/Atomic/FormElements/CheckboxInput/CheckboxInput.d.ts +5 -0
- package/dist/Atomic/FormElements/CheckboxInput/CheckboxInput.interface.d.ts +11 -0
- package/dist/Atomic/FormElements/CheckboxInput/index.d.ts +3 -0
- package/dist/Atomic/FormElements/CheckboxesLine/CheckboxesLine.d.ts +5 -0
- package/dist/Atomic/FormElements/CheckboxesLine/CheckboxesLine.interface.d.ts +24 -0
- package/dist/Atomic/FormElements/CheckboxesLine/index.d.ts +3 -0
- package/dist/Atomic/FormElements/Datepicker/Datepicker.d.ts +5 -0
- package/dist/Atomic/FormElements/Datepicker/Datepicker.props.d.ts +25 -0
- package/dist/Atomic/FormElements/Datepicker/components/DatepickerCalendar.d.ts +4 -0
- package/dist/Atomic/FormElements/Datepicker/components/DatepickerCalendar.props.d.ts +23 -0
- package/dist/Atomic/FormElements/Dropdown/Dropdown.d.ts +6 -0
- package/dist/Atomic/FormElements/Dropdown/Dropdown.interface.d.ts +102 -0
- package/dist/Atomic/FormElements/Dropdown/_utils.d.ts +8 -0
- package/dist/Atomic/FormElements/Dropdown/components/DropdownLoader.d.ts +4 -0
- package/dist/Atomic/FormElements/Dropdown/index.d.ts +4 -0
- package/dist/Atomic/FormElements/Dropdown/useDropdown.d.ts +3 -0
- package/dist/Atomic/FormElements/DropdownLiveSearch/DropdownLiveSearch.d.ts +5 -0
- package/dist/Atomic/FormElements/DropdownLiveSearch/DropdownLiveSearch.interface.d.ts +34 -0
- package/dist/Atomic/FormElements/FileLoader/FileLoader.d.ts +5 -0
- package/dist/Atomic/FormElements/FileLoader/FileLoader.interface.d.ts +29 -0
- package/dist/Atomic/FormElements/FileLoader/partial/LoadZone.d.ts +5 -0
- package/dist/Atomic/FormElements/FileLoader/partial/LoadZone.interface.d.ts +16 -0
- package/dist/Atomic/FormElements/FileLoader/partial/LoadedContent.d.ts +5 -0
- package/dist/Atomic/FormElements/FileLoader/partial/LoadedContent.interface.d.ts +12 -0
- package/dist/Atomic/FormElements/FileLoaderDescription/FileLoaderDescription.d.ts +5 -0
- package/dist/Atomic/FormElements/FileLoaderDescription/FileLoaderDescription.interface.d.ts +31 -0
- package/dist/Atomic/FormElements/FileLoaderLocal/FileLoaderLocal.d.ts +5 -0
- package/dist/Atomic/FormElements/FileLoaderLocal/FileLoaderLocal.interface.d.ts +31 -0
- package/dist/Atomic/FormElements/FileLoaderLocalGroup/FileLoaderLocalGroup.d.ts +5 -0
- package/dist/Atomic/FormElements/FileLoaderLocalGroup/FileLoaderLocalGroup.interface.d.ts +28 -0
- package/dist/Atomic/FormElements/FormattedRawSSN/FormattedRawSSN.d.ts +5 -0
- package/dist/Atomic/FormElements/FormattedRawSSN/FormattedRawSSN.interface.d.ts +14 -0
- package/dist/Atomic/FormElements/FormattedRawSSN/FormattedRawSSN_old.d.ts +11 -0
- package/dist/Atomic/FormElements/FormattedRawSSN/index.d.ts +4 -0
- package/dist/Atomic/FormElements/Input/Input.d.ts +8 -0
- package/dist/Atomic/FormElements/Input/hooks/useErrorBlink.d.ts +11 -0
- package/dist/Atomic/FormElements/Input/hooks/useInputFocus.d.ts +15 -0
- package/dist/Atomic/FormElements/Input/hooks/useInputHover.d.ts +5 -0
- package/dist/Atomic/FormElements/Input/hooks/useInputValueProcessing.d.ts +12 -0
- package/dist/Atomic/FormElements/Input/hooks/useKeyboardHandling.d.ts +17 -0
- package/dist/Atomic/FormElements/Input/index.d.ts +5 -0
- package/dist/Atomic/FormElements/Input/lib/autocomplete.d.ts +61 -0
- package/dist/Atomic/FormElements/Input/types.d.ts +122 -0
- package/dist/Atomic/FormElements/InputCalendar/InputCalendar.d.ts +5 -0
- package/dist/Atomic/FormElements/InputCalendar/InputCalendar.interface.d.ts +17 -0
- package/dist/Atomic/FormElements/InputColor/InputColor.d.ts +5 -0
- package/dist/Atomic/FormElements/InputColor/InputColor.interface.d.ts +15 -0
- package/dist/Atomic/FormElements/InputColor/index.d.ts +4 -0
- package/dist/Atomic/FormElements/InputCurrency/InputCurrency.d.ts +5 -0
- package/dist/Atomic/FormElements/InputCurrency/InputCurrency.interface.d.ts +29 -0
- package/dist/Atomic/FormElements/InputDateRange/InputDateRange.d.ts +5 -0
- package/dist/Atomic/FormElements/InputDateRange/InputDateRange.interface.d.ts +144 -0
- package/dist/Atomic/FormElements/InputDateRange/components/DateInput.d.ts +7 -0
- package/dist/Atomic/FormElements/InputDateRange/components/Datepicker.d.ts +4 -0
- package/dist/Atomic/FormElements/InputDateRange/components/OpenedPart.d.ts +4 -0
- package/dist/Atomic/FormElements/InputDateRange/components/SelectItem.d.ts +4 -0
- package/dist/Atomic/FormElements/InputDateRange/dependencies.d.ts +18 -0
- package/dist/Atomic/FormElements/InputLink/InputLink.d.ts +5 -0
- package/dist/Atomic/FormElements/InputLink/InputLink.interface.d.ts +15 -0
- package/dist/Atomic/FormElements/InputLink/index.d.ts +4 -0
- package/dist/Atomic/FormElements/InputMask/InputMask.d.ts +2 -0
- package/dist/Atomic/FormElements/InputMask/index.d.ts +4 -0
- package/dist/Atomic/FormElements/InputMask3/InputMask3.d.ts +5 -0
- package/dist/Atomic/FormElements/InputMask3/InputMask3.interface.d.ts +78 -0
- package/dist/Atomic/FormElements/InputMask3/config.d.ts +8 -0
- package/dist/Atomic/FormElements/InputMask3/functions.d.ts +11 -0
- package/dist/Atomic/FormElements/InputWithAction/InputWithAction.d.ts +5 -0
- package/dist/Atomic/FormElements/InputWithAction/InputWithAction.interface.d.ts +26 -0
- package/dist/Atomic/FormElements/InputWithAction/index.d.ts +4 -0
- package/dist/Atomic/FormElements/InputsRow/InputsRow.d.ts +5 -0
- package/dist/Atomic/FormElements/InputsRow/InputsRow.interface.d.ts +15 -0
- package/dist/Atomic/FormElements/InputsRow/index.d.ts +4 -0
- package/dist/Atomic/FormElements/Label/Label.d.ts +5 -0
- package/dist/Atomic/FormElements/Label/Label.interface.d.ts +19 -0
- package/dist/Atomic/FormElements/Label/index.d.ts +3 -0
- package/dist/Atomic/FormElements/MobileCalendar/MobileCalendar.d.ts +5 -0
- package/dist/Atomic/FormElements/MobileCalendar/MobileCalendar.interface.d.ts +34 -0
- package/dist/Atomic/FormElements/MultiSelect/MultiSelect.d.ts +14 -0
- package/dist/Atomic/FormElements/NumericInput/NumericInput.d.ts +36 -0
- package/dist/Atomic/FormElements/RadioGroup/RadioGroup.d.ts +5 -0
- package/dist/Atomic/FormElements/RadioGroup/RadioGroup.interface.d.ts +16 -0
- package/dist/Atomic/FormElements/RadioGroupWithInput/RadioGroupWithInput.d.ts +5 -0
- package/dist/Atomic/FormElements/RadioGroupWithInput/RadioGroupWithInput.interface.d.ts +24 -0
- package/dist/Atomic/FormElements/RadioInput/RadioInput.d.ts +5 -0
- package/dist/Atomic/FormElements/RadioInput/RadioInput.interface.d.ts +13 -0
- package/dist/Atomic/FormElements/RadioInput/index.d.ts +4 -0
- package/dist/Atomic/FormElements/RadioRowSwitcher/RadioRowSwitcher.d.ts +14 -0
- package/dist/Atomic/FormElements/RangeCalendar/RangeCalendar.d.ts +2 -0
- package/dist/Atomic/FormElements/RangeInputs/RangeInputs.d.ts +5 -0
- package/dist/Atomic/FormElements/RangeInputs/RangeInputs.interface.d.ts +32 -0
- package/dist/Atomic/FormElements/RangeInputs/index.d.ts +4 -0
- package/dist/Atomic/FormElements/RangeList/RangeList.d.ts +5 -0
- package/dist/Atomic/FormElements/RangeList/RangeList.interface.d.ts +36 -0
- package/dist/Atomic/FormElements/RangeList/index.d.ts +4 -0
- package/dist/Atomic/FormElements/RangeList/partial/RangeListRow.d.ts +5 -0
- package/dist/Atomic/FormElements/RangeSlider/RangeSlider.d.ts +19 -0
- package/dist/Atomic/FormElements/RangeSlider2/RangeSlider2.d.ts +5 -0
- package/dist/Atomic/FormElements/RangeSlider2/RangeSlider2.interface.d.ts +47 -0
- package/dist/Atomic/FormElements/SwitchableRow/SwitchableRow.d.ts +5 -0
- package/dist/Atomic/FormElements/SwitchableRow/SwitchableRow.interface.d.ts +12 -0
- package/dist/Atomic/FormElements/Switcher/Switcher.d.ts +5 -0
- package/dist/Atomic/FormElements/Switcher/Switcher.interface.d.ts +14 -0
- package/dist/Atomic/FormElements/Switcher/index.d.ts +4 -0
- package/dist/Atomic/FormElements/SwitcherCheckbox/SwitcherCheckbox.d.ts +5 -0
- package/dist/Atomic/FormElements/SwitcherCheckbox/SwitcherCheckbox.interface.d.ts +23 -0
- package/dist/Atomic/FormElements/SwitcherHide/SwitcherHide.d.ts +5 -0
- package/dist/Atomic/FormElements/SwitcherHide/SwitcherHide.interface.d.ts +15 -0
- package/dist/Atomic/FormElements/SwitcherHide/index.d.ts +4 -0
- package/dist/Atomic/FormElements/SwitcherRadio/SwitcherRadio.d.ts +5 -0
- package/dist/Atomic/FormElements/SwitcherRadio/SwitcherRadio.interface.d.ts +26 -0
- package/dist/Atomic/FormElements/SwitcherRadio/index.d.ts +4 -0
- package/dist/Atomic/FormElements/SwitcherRange/SwitcherRange.d.ts +4 -0
- package/dist/Atomic/FormElements/SwitcherRange/SwitcherRange.interface.d.ts +21 -0
- package/dist/Atomic/FormElements/SwitcherRange/index.d.ts +4 -0
- package/dist/Atomic/FormElements/SwitcherRangeList/SwitcherRangeList.d.ts +5 -0
- package/dist/Atomic/FormElements/SwitcherRangeList/SwitcherRangeList.interface.d.ts +28 -0
- package/dist/Atomic/FormElements/SwitcherTagsDropdown/partial/States.d.ts +5 -0
- package/dist/Atomic/FormElements/SwitcherTextarea/SwitcherTextarea.d.ts +5 -0
- package/dist/Atomic/FormElements/SwitcherTextarea/SwitcherTextarea.interface.d.ts +17 -0
- package/dist/Atomic/FormElements/Text/Text.d.ts +17 -0
- package/dist/Atomic/FormElements/Text/Text.interface.d.ts +23 -0
- package/dist/Atomic/FormElements/Text/index.d.ts +4 -0
- package/dist/Atomic/FormElements/TextSwitcher/TextSwitcher.d.ts +12 -0
- package/dist/Atomic/FormElements/Textarea/Textarea.d.ts +7 -0
- package/dist/Atomic/FormElements/Textarea/Textarea.interface.d.ts +19 -0
- package/dist/Atomic/FormElements/TieredCheckboxes/TieredCheckboxes.d.ts +5 -0
- package/dist/Atomic/FormElements/TieredCheckboxes/TieredCheckboxes.interface.d.ts +42 -0
- package/dist/Atomic/FormElements/TieredCheckboxes/index.d.ts +4 -0
- package/dist/Atomic/FormElements/TieredCheckboxes/partial/AccordionWithCheckbox.d.ts +5 -0
- package/dist/Atomic/FormElements/TimeRange/TimeRange.d.ts +5 -0
- package/dist/Atomic/FormElements/TimeRange/TimeRange.interface.d.ts +7 -0
- package/dist/Atomic/FormElements/TimeRange/index.d.ts +3 -0
- package/dist/Atomic/FormElements/UserContacts/UserContacts.d.ts +5 -0
- package/dist/Atomic/FormElements/UserContacts/UserContacts.interface.d.ts +32 -0
- package/dist/Atomic/FormElements/UserContacts/index.d.ts +3 -0
- package/dist/Atomic/FormElements/VariantsListRadio/VariantsListRadio.d.ts +17 -0
- package/dist/Atomic/FormElements/VariantsListRadio/partials/VariantsListRadioItem.d.ts +12 -0
- package/dist/Atomic/FormElements/WidgetPseudoTable/WidgetPseudoTable.d.ts +2 -0
- package/dist/Atomic/FormElements/WidgetPseudoTable/partial/constructor.d.ts +23 -0
- package/dist/Atomic/FormElements/WidgetWithSwitchableRows/WidgetWithSwitchableRows.d.ts +2 -0
- package/dist/Atomic/FormElements/WidgetWithSwitchableRows/partial/constructor.d.ts +38 -0
- package/dist/Atomic/Layout/Header/Header.d.ts +5 -0
- package/dist/Atomic/Layout/Header/Header.interface.d.ts +10 -0
- package/dist/Atomic/Layout/MainMenu/MainMenu.d.ts +5 -0
- package/dist/Atomic/Layout/MainMenu/MainMenu.interface.d.ts +18 -0
- package/dist/Atomic/Layout/Spinner/Spinner.d.ts +5 -0
- package/dist/Atomic/Layout/Spinner/Spinner.interface.d.ts +4 -0
- package/dist/Atomic/Layout/Spinner/index.d.ts +3 -0
- package/dist/Atomic/UI/Accordion/Accordion.d.ts +5 -0
- package/dist/Atomic/UI/Accordion/Accordion.interface.d.ts +56 -0
- package/dist/Atomic/UI/Accordion/AccordionItem.d.ts +5 -0
- package/dist/Atomic/UI/Accordion/index.d.ts +3 -0
- package/dist/Atomic/UI/AccordionTable/AccordionTable.d.ts +10 -0
- package/dist/Atomic/UI/AccordionText/AccordionText.d.ts +8 -0
- package/dist/Atomic/UI/AdvancedTag/AdvTag.d.ts +5 -0
- package/dist/Atomic/UI/AdvancedTag/AdvancedTags.interface.d.ts +36 -0
- package/dist/Atomic/UI/Alert/Alert.d.ts +5 -0
- package/dist/Atomic/UI/Alert/Alert.interface.d.ts +30 -0
- package/dist/Atomic/UI/Alert/index.d.ts +4 -0
- package/dist/Atomic/UI/Arrow/Arrow.d.ts +5 -0
- package/dist/Atomic/UI/Arrow/Arrow.interface.d.ts +10 -0
- package/dist/Atomic/UI/Box/Box.d.ts +5 -0
- package/dist/Atomic/UI/Box/Box.interface.d.ts +9 -0
- package/dist/Atomic/UI/Button/Button.d.ts +19 -0
- package/dist/Atomic/UI/ButtonsBar/ButtonsBar.d.ts +5 -0
- package/dist/Atomic/UI/ButtonsBar/ButtonsBar.interface.d.ts +22 -0
- package/dist/Atomic/UI/ButtonsBar/index.d.ts +4 -0
- package/dist/Atomic/UI/Chart/Chart.d.ts +5 -0
- package/dist/Atomic/UI/Chart/Chart.interface.d.ts +34 -0
- package/dist/Atomic/UI/Chart/index.d.ts +4 -0
- package/dist/Atomic/UI/Chart/partial/Chart.constants.d.ts +78 -0
- package/dist/Atomic/UI/Chart/partial/ChartTypeSwitcherIcon/ChartTypeSwitcherIcon.d.ts +5 -0
- package/dist/Atomic/UI/Chart/partial/datasetSetters.d.ts +13 -0
- package/dist/Atomic/UI/Chart/partial/optionsConstructor.d.ts +145 -0
- package/dist/Atomic/UI/Chart/partial/optionsSetters.d.ts +4 -0
- package/dist/Atomic/UI/Chart/partial/utils.d.ts +5 -0
- package/dist/Atomic/UI/CircleProgressBar/CircleProgressBar.d.ts +14 -0
- package/dist/Atomic/UI/DateTime/DateTime.d.ts +5 -0
- package/dist/Atomic/UI/DateTime/DateTime.interface.d.ts +11 -0
- package/dist/Atomic/UI/DebugContainer/DebugContainer.d.ts +10 -0
- package/dist/Atomic/UI/DebugContainer/useDebugContainer.d.ts +7 -0
- package/dist/Atomic/UI/DoubleString/DoubleString.d.ts +5 -0
- package/dist/Atomic/UI/DoubleString/DoubleString.interface.d.ts +22 -0
- package/dist/Atomic/UI/DoubleString/index.d.ts +4 -0
- package/dist/Atomic/UI/DynamicIcon/DynamicIcon.d.ts +4 -0
- package/dist/Atomic/UI/DynamicIcon/DynamicIcon.interface.d.ts +6 -0
- package/dist/Atomic/UI/DynamicIcon/index.d.ts +3 -0
- package/dist/Atomic/UI/ExampleChartIntegration/ExampleChartIntegration.d.ts +2 -0
- package/dist/Atomic/UI/ExampleChartIntegration/partial/utils.d.ts +4 -0
- package/dist/Atomic/UI/Hint/Hint.d.ts +5 -0
- package/dist/Atomic/UI/Hint/Hint.interface.d.ts +26 -0
- package/dist/Atomic/UI/Hint/index.d.ts +4 -0
- package/dist/Atomic/UI/Hint/partials/_constants.d.ts +6 -0
- package/dist/Atomic/UI/Hint/partials/_utils.d.ts +6 -0
- package/dist/Atomic/UI/Modal/Modal.d.ts +20 -0
- package/dist/Atomic/UI/Modal/Modal.interface.d.ts +70 -0
- package/dist/Atomic/UI/Modal/ModalHOC.d.ts +5 -0
- package/dist/Atomic/UI/Modal/index.d.ts +9 -0
- package/dist/Atomic/UI/Modal/partials/ModalFooter.d.ts +4 -0
- package/dist/Atomic/UI/Modal/partials/ModalTitle.d.ts +4 -0
- package/dist/Atomic/UI/Modal/partials/_constants.d.ts +23 -0
- package/dist/Atomic/UI/Modal/partials/_utils.d.ts +11 -0
- package/dist/Atomic/UI/Modal/partials/useMobileModal.d.ts +31 -0
- package/dist/Atomic/UI/MonoAccordion/MonoAccordion._test.d.ts +1 -0
- package/dist/Atomic/UI/MonoAccordion/MonoAccordion.d.ts +12 -0
- package/dist/Atomic/UI/MonoAccordion/MonoAccordion.interface.d.ts +17 -0
- package/dist/Atomic/UI/MonoAccordion/index.d.ts +3 -0
- package/dist/Atomic/UI/NavLine/NavLine.d.ts +5 -0
- package/dist/Atomic/UI/NavLine/NavLine.interface.d.ts +31 -0
- package/dist/Atomic/UI/NavLine/index.d.ts +3 -0
- package/dist/Atomic/UI/PageTitle/PageTitle.d.ts +5 -0
- package/dist/Atomic/UI/PageTitle/PageTitle.interface.d.ts +15 -0
- package/dist/Atomic/UI/PageTitle/index.d.ts +3 -0
- package/dist/Atomic/UI/PieChart/PieChart.d.ts +8 -0
- package/dist/Atomic/UI/Price/Price.d.ts +4 -0
- package/dist/Atomic/UI/Price/Price.interface.d.ts +6 -0
- package/dist/Atomic/UI/Price/index.d.ts +3 -0
- package/dist/Atomic/UI/PriceRange/PriceRange.d.ts +4 -0
- package/dist/Atomic/UI/PriceRange/PriceRange.interface.d.ts +8 -0
- package/dist/Atomic/UI/PriceRange/index.d.ts +3 -0
- package/dist/Atomic/UI/ProgressLine/ProgressLine.d.ts +5 -0
- package/dist/Atomic/UI/ProgressLine/ProgressLine.interface.d.ts +25 -0
- package/dist/Atomic/UI/ProgressLine/index.d.ts +3 -0
- package/dist/Atomic/UI/Status/Status.d.ts +5 -0
- package/dist/Atomic/UI/Status/Status.interface.d.ts +15 -0
- package/dist/Atomic/UI/Status/index.d.ts +3 -0
- package/dist/Atomic/UI/Table/Partials/TdHeader.d.ts +5 -0
- package/dist/Atomic/UI/Table/TdTypes/TdActions.d.ts +6 -0
- package/dist/Atomic/UI/Table/TdTypes/TdPriority.d.ts +6 -0
- package/dist/Atomic/UI/Table/TdTypes/TdRange.d.ts +4 -0
- package/dist/Atomic/UI/Table/TdTypes/TdWeight.d.ts +7 -0
- package/dist/Atomic/UI/UserBox/UserBox.d.ts +5 -0
- package/dist/Atomic/UI/UserBox/UserBox.interface.d.ts +9 -0
- package/dist/Atomic/UI/UserBox/index.d.ts +3 -0
- package/dist/Atomic/UI/WizardStepper/WizardStepper.interface.d.ts +40 -0
- package/dist/Atomic/UI/WizardStepper/constructor.d.ts +51 -0
- package/dist/Atomic/UI/WizardStepper/index.d.ts +3 -0
- package/dist/Atomic/UI/WizardStepper/ui/StateIcon/StateIcon.d.ts +4 -0
- package/dist/Atomic/UI/WizardStepper/ui/StateIcon/index.d.ts +2 -0
- package/dist/Atomic/UI/WizardStepper/ui/StepRow/StepRow.d.ts +5 -0
- package/dist/Atomic/UI/WizardStepper/ui/StepRow/index.d.ts +2 -0
- package/dist/Atomic/UI/WizardStepper/ui/StepWrapper/StepWrapper.d.ts +5 -0
- package/dist/Atomic/UI/WizardStepper/ui/StepWrapper/index.d.ts +2 -0
- package/dist/Atomic/UI/WizardStepper/ui/icons.d.ts +6 -0
- package/dist/Atomic/UI/WizardStepper/ui/index.d.ts +2 -0
- package/dist/Classes/AbortableFetch.d.ts +43 -0
- package/dist/Classes/AnimatedHandler.d.ts +4 -0
- package/dist/Classes/RESTAPI/index.d.ts +9 -0
- package/dist/Classes/RESTAPI/partials/AbortableFetch.d.ts +43 -0
- package/dist/Classes/RESTAPI/partials/ApiBase.d.ts +10 -0
- package/dist/Classes/RESTAPI/partials/ApiRequestCreators.d.ts +9 -0
- package/dist/Classes/RESTAPI/partials/ApiUtils.d.ts +12 -0
- package/dist/Classes/RESTAPI/partials/CredentialsProcessing.d.ts +24 -0
- package/dist/Classes/RESTAPI/partials/Utils.d.ts +4 -0
- package/dist/Classes/RESTAPI/partials/_utils.d.ts +9 -0
- package/dist/Constants/index.constants.d.ts +20 -0
- package/dist/Functions/Portal.d.ts +6 -0
- package/dist/Functions/customEventListener.d.ts +27 -0
- package/dist/Functions/dateTime.d.ts +95 -0
- package/dist/Functions/fieldValueFormatters.d.ts +19 -0
- package/dist/Functions/guards/assertions.d.ts +224 -0
- package/dist/Functions/guards/safeValue.d.ts +40 -0
- package/dist/Functions/guards/typeGuards.d.ts +193 -0
- package/dist/Functions/hooks/useFormFieldsChangesManager.d.ts +15 -0
- package/dist/Functions/locale/createTranslator.d.ts +3 -0
- package/dist/Functions/operations.d.ts +1 -0
- package/dist/Functions/presets/inputMaskPresets.d.ts +136 -0
- package/dist/Functions/presets/inputPresets.d.ts +16 -0
- package/dist/Functions/presets/mobileKeyboardTypesPresets.d.ts +17 -0
- package/dist/Functions/schemas.d.ts +3 -0
- package/dist/Functions/useBodyScrollLock.d.ts +2 -0
- package/dist/Functions/useClickOutside.d.ts +1 -0
- package/dist/Functions/useDebounce.d.ts +4 -0
- package/dist/Functions/useFieldFocus.d.ts +7 -0
- package/dist/Functions/useFormTools/form-drivers/ArrayWithObjects.d.ts +15 -0
- package/dist/Functions/useFormTools/form-drivers/ObjectWithIterableObjects.d.ts +12 -0
- package/dist/Functions/useFormTools/form-drivers/ObjectWithNamedKeyObjects.d.ts +15 -0
- package/dist/Functions/useFormTools/functions/General.d.ts +15 -0
- package/dist/Functions/useFormTools/functions/RenderFields.d.ts +7 -0
- package/dist/Functions/useFormTools/functions/usePrevious.d.ts +2 -0
- package/dist/Functions/useFormTools/index.d.ts +86 -0
- package/dist/Functions/useInputHighlightError.d.ts +12 -0
- package/dist/Functions/useIsMobile/index.d.ts +2 -0
- package/dist/Functions/useIsMobile/useIsMobile.d.ts +18 -0
- package/dist/Functions/useKeyPress/useHandleKeyPress.d.ts +35 -0
- package/dist/Functions/useKeyPress/useKeyPress.d.ts +12 -0
- package/dist/Functions/useLocalStorage.d.ts +2 -0
- package/dist/Functions/useLocationParams.d.ts +1 -0
- package/dist/Functions/useMediaQuery.d.ts +2 -0
- package/dist/Functions/useMetaInfo.d.ts +8 -0
- package/dist/Functions/useMouseUpOutside.d.ts +1 -0
- package/dist/Functions/useOnlineStatus.d.ts +2 -0
- package/dist/Functions/usePasswordChecker.d.ts +7 -0
- package/dist/Functions/usePrevious.d.ts +2 -0
- package/dist/Functions/useResize.d.ts +3 -0
- package/dist/Functions/useScrollTo.d.ts +2 -0
- package/dist/Functions/useToggle.d.ts +7 -0
- package/dist/Functions/utils/disableDefaultBehavior/disableDefaultBehavior.d.ts +4 -0
- package/dist/Functions/utils/disableDefaultBehavior/index.d.ts +1 -0
- package/dist/Functions/utils/getLimitedMask/getLimitedMask.d.ts +18 -0
- package/dist/Functions/utils/getLimitedMask/index.d.ts +1 -0
- package/dist/Functions/utils.d.ts +35 -80
- package/dist/Langs.d.ts +179 -0
- package/dist/Molecular/CustomIcons/components/AffiliateNetworks.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/AlertCircle.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/AppStore.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Arrow.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/ArrowDown.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/ArrowLeft.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/ArrowRight.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/ArrowUp.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Bell.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Button.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Campaigns.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Check.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Check2.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/ChevronDown.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/ChevronDownDisabled.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/ChevronLeft.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/ChevronRight.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/ChevronUp.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/ChevronUpDown.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Close.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/ColumnsOrder.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Delete.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Edit.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Email.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/FinturfLogo.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/FinturfLogo2.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Flows.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Gift.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/GoogleAuth.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/GooglePlay.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/HelpCircle.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/HelpCircle2.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/HelpCircleFilled.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Home.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Home2.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Key.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Landers.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Lock.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Mail.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Mastercard.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Minus.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Offers.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Pause.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/PayPal.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/PayPalLightLarge.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Phone.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Play.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Plus.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Profile.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/QRCode.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Rectangle.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Revert.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Star.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Star2.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/TrafficSources.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Trash.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/TrashRed.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Triggers.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/User.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/Visa.d.ts +2 -0
- package/dist/Molecular/CustomIcons/components/X.d.ts +2 -0
- package/dist/Molecular/FormElement/FormElement.d.ts +5 -0
- package/dist/Molecular/FormElement/FormElement.interface.d.ts +27 -0
- package/dist/Molecular/FormWithDependOn/FormWithDependOn.d.ts +3 -0
- package/dist/Molecular/FormWithDependOn/partials/_utils.d.ts +8 -0
- package/dist/Molecular/InputAddress/InputAddress.d.ts +5 -0
- package/dist/Molecular/InputAddress/InputAddress.interface.d.ts +37 -0
- package/dist/Molecular/InputCustomFetch/InputCustomFetch.d.ts +4 -0
- package/dist/Molecular/InputCustomFetch/index.d.ts +2 -0
- package/dist/Molecular/InputCustomFetch/lib/hooks/useDebouncedCallback.d.ts +8 -0
- package/dist/Molecular/InputCustomFetch/lib/hooks/useFetchWithAbort.d.ts +10 -0
- package/dist/Molecular/InputCustomFetch/lib/utils.d.ts +13 -0
- package/dist/Molecular/InputCustomFetch/model/types.d.ts +46 -0
- package/dist/Molecular/InputPassword/InputPassword.d.ts +5 -0
- package/dist/Molecular/InputPassword/InputPassword.interface.d.ts +8 -0
- package/dist/classes.cjs +1464 -0
- package/dist/classes.cjs.map +7 -0
- package/dist/classes.d.ts +7 -0
- package/dist/classes.js +1442 -0
- package/dist/classes.js.map +7 -0
- package/dist/form.cjs +14837 -0
- package/dist/form.cjs.map +7 -0
- package/dist/form.d.ts +75 -0
- package/dist/form.js +14852 -0
- package/dist/form.js.map +7 -0
- package/dist/hooks.cjs +2644 -0
- package/dist/hooks.cjs.map +7 -0
- package/dist/hooks.d.ts +34 -0
- package/dist/hooks.js +2612 -0
- package/dist/hooks.js.map +7 -0
- package/dist/icons.cjs +1807 -0
- package/dist/icons.cjs.map +7 -0
- package/dist/icons.d.ts +5 -0
- package/dist/icons.js +1785 -0
- package/dist/icons.js.map +7 -0
- package/dist/index.cjs +29060 -0
- package/dist/index.cjs.map +7 -0
- package/dist/index.d.ts +18 -0
- package/dist/index.js +29097 -1
- package/dist/index.js.map +7 -0
- package/dist/layout.cjs +7119 -0
- package/dist/layout.cjs.map +7 -0
- package/dist/layout.d.ts +8 -0
- package/dist/layout.js +7087 -0
- package/dist/layout.js.map +7 -0
- package/dist/presets.cjs +905 -0
- package/dist/presets.cjs.map +7 -0
- package/dist/presets.d.ts +9 -0
- package/dist/presets.js +873 -0
- package/dist/presets.js.map +7 -0
- package/dist/types/base.interface.d.ts +6 -0
- package/dist/types/base.types.d.ts +2 -0
- package/dist/types/declaration/TWithEventManagementAsObj/index.d.ts +10 -0
- package/dist/types/declaration/TWithEventManagementAsObj/innerTypes/Modal.d.ts +4 -0
- package/dist/types/declaration/index.d.ts +17 -0
- package/dist/types/index.cjs +18 -0
- package/dist/types/index.cjs.map +7 -0
- package/dist/types/index.d.ts +1 -0
- package/dist/types/index.js +1 -0
- package/dist/types/index.js.map +7 -0
- package/dist/ui.cjs +11582 -0
- package/dist/ui.cjs.map +7 -0
- package/dist/ui.d.ts +51 -0
- package/dist/ui.js +11572 -0
- package/dist/ui.js.map +7 -0
- package/dist/utils.cjs +700 -0
- package/dist/utils.cjs.map +7 -0
- package/dist/utils.d.ts +8 -0
- package/dist/utils.js +668 -0
- package/dist/utils.js.map +7 -0
- package/package.json +86 -59
- package/dist/Atomic/FormElements/ActionAlert/ActionAlert.interface.ts +0 -24
- package/dist/Atomic/FormElements/ActionAlert/ActionAlert.js +0 -1
- package/dist/Atomic/FormElements/ActionAlert/ActionAlert.scss +0 -50
- package/dist/Atomic/FormElements/ActionAlert/index.ts +0 -5
- package/dist/Atomic/FormElements/AdvancedStatus/AdvancedStatus.interface.ts +0 -15
- package/dist/Atomic/FormElements/AdvancedStatus/AdvancedStatus.js +0 -1
- package/dist/Atomic/FormElements/AdvancedStatus/AdvancedStatus.scss +0 -85
- package/dist/Atomic/FormElements/AdvancedStatus/index.ts +0 -4
- package/dist/Atomic/FormElements/Calendar/Calendar.js +0 -1
- package/dist/Atomic/FormElements/Calendar/Calendar.props.js +0 -1
- package/dist/Atomic/FormElements/Calendar/Calendar.scss +0 -627
- package/dist/Atomic/FormElements/CheckboxInput/CheckboxInput.interface.ts +0 -15
- package/dist/Atomic/FormElements/CheckboxInput/CheckboxInput.js +0 -1
- package/dist/Atomic/FormElements/CheckboxInput/CheckboxInput.scss +0 -151
- package/dist/Atomic/FormElements/CheckboxInput/index.ts +0 -4
- package/dist/Atomic/FormElements/CheckboxesLine/CheckboxesLine.interface.ts +0 -25
- package/dist/Atomic/FormElements/CheckboxesLine/CheckboxesLine.js +0 -1
- package/dist/Atomic/FormElements/CheckboxesLine/CheckboxesLine.scss +0 -32
- package/dist/Atomic/FormElements/CheckboxesLine/index.ts +0 -4
- package/dist/Atomic/FormElements/CheckboxesLine/partial/AnyOuterClass.scss +0 -5
- package/dist/Atomic/FormElements/Datepicker/Datepicker.js +0 -1
- package/dist/Atomic/FormElements/Datepicker/Datepicker.props.js +0 -1
- package/dist/Atomic/FormElements/Datepicker/Datepicker.scss +0 -0
- package/dist/Atomic/FormElements/Datepicker/components/DatepickerCalendar.js +0 -1
- package/dist/Atomic/FormElements/Datepicker/components/DatepickerCalendar.props.js +0 -1
- package/dist/Atomic/FormElements/Dropdown/Dropdown.interface.ts +0 -116
- package/dist/Atomic/FormElements/Dropdown/Dropdown.js +0 -1
- package/dist/Atomic/FormElements/Dropdown/Dropdown.scss +0 -710
- package/dist/Atomic/FormElements/Dropdown/_utils.js +0 -1
- package/dist/Atomic/FormElements/Dropdown/components/DropdownLoader.js +0 -1
- package/dist/Atomic/FormElements/Dropdown/components/DropdownLoader.scss +0 -75
- package/dist/Atomic/FormElements/Dropdown/index.ts +0 -5
- package/dist/Atomic/FormElements/Dropdown/useDropdown.js +0 -1
- package/dist/Atomic/FormElements/DropdownLiveSearch/DropdownLiveSearch.interface.ts +0 -36
- package/dist/Atomic/FormElements/DropdownLiveSearch/DropdownLiveSearch.js +0 -1
- package/dist/Atomic/FormElements/DropdownLiveSearch/DropdownLiveSearch.scss +0 -539
- package/dist/Atomic/FormElements/FileLoader/FileLoader.interface.ts +0 -39
- package/dist/Atomic/FormElements/FileLoader/FileLoader.js +0 -1
- package/dist/Atomic/FormElements/FileLoader/FileLoader.scss +0 -169
- package/dist/Atomic/FormElements/FileLoader/partial/AnyOuterClass.scss +0 -9
- package/dist/Atomic/FormElements/FileLoader/partial/LoadZone.interface.ts +0 -22
- package/dist/Atomic/FormElements/FileLoader/partial/LoadZone.js +0 -1
- package/dist/Atomic/FormElements/FileLoader/partial/LoadedContent.interface.ts +0 -13
- package/dist/Atomic/FormElements/FileLoader/partial/LoadedContent.js +0 -1
- package/dist/Atomic/FormElements/FileLoaderDescription/FileLoaderDescription.interface.ts +0 -38
- package/dist/Atomic/FormElements/FileLoaderDescription/FileLoaderDescription.js +0 -1
- package/dist/Atomic/FormElements/FileLoaderDescription/FileLoaderDescription.scss +0 -106
- package/dist/Atomic/FormElements/FileLoaderLocal/FileLoaderLocal.interface.ts +0 -30
- package/dist/Atomic/FormElements/FileLoaderLocal/FileLoaderLocal.js +0 -1
- package/dist/Atomic/FormElements/FileLoaderLocal/FileLoaderLocal.scss +0 -134
- package/dist/Atomic/FormElements/FileLoaderLocalGroup/FileLoaderLocalGroup.interface.ts +0 -30
- package/dist/Atomic/FormElements/FileLoaderLocalGroup/FileLoaderLocalGroup.js +0 -1
- package/dist/Atomic/FormElements/FileLoaderLocalGroup/FileLoaderLocalGroup.scss +0 -19
- package/dist/Atomic/FormElements/FormattedRawSSN/FormattedRawSSN.interface.ts +0 -15
- package/dist/Atomic/FormElements/FormattedRawSSN/FormattedRawSSN.js +0 -1
- package/dist/Atomic/FormElements/FormattedRawSSN/FormattedRawSSN.scss +0 -67
- package/dist/Atomic/FormElements/FormattedRawSSN/FormattedRawSSN_old.js +0 -1
- package/dist/Atomic/FormElements/FormattedRawSSN/index.ts +0 -5
- package/dist/Atomic/FormElements/Input/Input.js +0 -1
- package/dist/Atomic/FormElements/Input/Input.scss +0 -170
- package/dist/Atomic/FormElements/Input/hooks/useErrorBlink.js +0 -1
- package/dist/Atomic/FormElements/Input/hooks/useInputFocus.js +0 -1
- package/dist/Atomic/FormElements/Input/hooks/useInputHover.js +0 -1
- package/dist/Atomic/FormElements/Input/hooks/useInputValueProcessing.js +0 -1
- package/dist/Atomic/FormElements/Input/hooks/useKeyboardHandling.js +0 -1
- package/dist/Atomic/FormElements/Input/index.ts +0 -7
- package/dist/Atomic/FormElements/Input/lib/autocomplete.js +0 -1
- package/dist/Atomic/FormElements/Input/types.js +0 -1
- package/dist/Atomic/FormElements/InputCalendar/InputCalendar.interface.ts +0 -19
- package/dist/Atomic/FormElements/InputCalendar/InputCalendar.js +0 -1
- package/dist/Atomic/FormElements/InputCalendar/InputCalendar.scss +0 -28
- package/dist/Atomic/FormElements/InputColor/InputColor.interface.ts +0 -17
- package/dist/Atomic/FormElements/InputColor/InputColor.js +0 -1
- package/dist/Atomic/FormElements/InputColor/InputColor.scss +0 -21
- package/dist/Atomic/FormElements/InputColor/index.ts +0 -5
- package/dist/Atomic/FormElements/InputCurrency/InputCurrency.interface.ts +0 -31
- package/dist/Atomic/FormElements/InputCurrency/InputCurrency.js +0 -1
- package/dist/Atomic/FormElements/InputCurrency/InputCurrency.scss +0 -18
- package/dist/Atomic/FormElements/InputDateRange/InputDateRange.interface.ts +0 -161
- package/dist/Atomic/FormElements/InputDateRange/InputDateRange.js +0 -1
- package/dist/Atomic/FormElements/InputDateRange/InputDateRange.scss +0 -812
- package/dist/Atomic/FormElements/InputDateRange/components/DateInput.js +0 -1
- package/dist/Atomic/FormElements/InputDateRange/components/Datepicker.js +0 -1
- package/dist/Atomic/FormElements/InputDateRange/components/OpenedPart.js +0 -1
- package/dist/Atomic/FormElements/InputDateRange/components/SelectItem.js +0 -1
- package/dist/Atomic/FormElements/InputDateRange/dependencies.js +0 -1
- package/dist/Atomic/FormElements/InputLink/InputLink.interface.ts +0 -17
- package/dist/Atomic/FormElements/InputLink/InputLink.js +0 -1
- package/dist/Atomic/FormElements/InputLink/InputLink.scss +0 -58
- package/dist/Atomic/FormElements/InputLink/index.ts +0 -5
- package/dist/Atomic/FormElements/InputMask/InputMask.js +0 -1
- package/dist/Atomic/FormElements/InputMask/index.ts +0 -4
- package/dist/Atomic/FormElements/InputMask3/InputMask3.interface.ts +0 -91
- package/dist/Atomic/FormElements/InputMask3/InputMask3.js +0 -1
- package/dist/Atomic/FormElements/InputMask3/InputMask3.scss +0 -183
- package/dist/Atomic/FormElements/InputMask3/config.js +0 -1
- package/dist/Atomic/FormElements/InputMask3/functions.js +0 -1
- package/dist/Atomic/FormElements/InputWithAction/InputWithAction.interface.ts +0 -27
- package/dist/Atomic/FormElements/InputWithAction/InputWithAction.js +0 -1
- package/dist/Atomic/FormElements/InputWithAction/InputWithAction.scss +0 -115
- package/dist/Atomic/FormElements/InputWithAction/index.ts +0 -5
- package/dist/Atomic/FormElements/InputsRow/InputsRow.interface.ts +0 -17
- package/dist/Atomic/FormElements/InputsRow/InputsRow.js +0 -1
- package/dist/Atomic/FormElements/InputsRow/InputsRow.scss +0 -50
- package/dist/Atomic/FormElements/InputsRow/index.ts +0 -5
- package/dist/Atomic/FormElements/Label/Label.interface.ts +0 -20
- package/dist/Atomic/FormElements/Label/Label.js +0 -1
- package/dist/Atomic/FormElements/Label/Label.scss +0 -41
- package/dist/Atomic/FormElements/Label/index.ts +0 -4
- package/dist/Atomic/FormElements/MobileCalendar/MobileCalendar.interface.ts +0 -39
- package/dist/Atomic/FormElements/MobileCalendar/MobileCalendar.js +0 -1
- package/dist/Atomic/FormElements/MobileCalendar/MobileCalendar.scss +0 -126
- package/dist/Atomic/FormElements/MultiSelect/MultiSelect.js +0 -1
- package/dist/Atomic/FormElements/MultiSelect/MultiSelect.scss +0 -18
- package/dist/Atomic/FormElements/MultiSelect/MultiSelect.scss.d.ts +0 -4
- package/dist/Atomic/FormElements/NumericInput/NumericInput.js +0 -1
- package/dist/Atomic/FormElements/NumericInput/NumericInput.scss +0 -174
- package/dist/Atomic/FormElements/RadioGroup/RadioGroup.interface.ts +0 -17
- package/dist/Atomic/FormElements/RadioGroup/RadioGroup.js +0 -1
- package/dist/Atomic/FormElements/RadioGroup/RadioGroup.scss +0 -27
- package/dist/Atomic/FormElements/RadioGroupWithInput/RadioGroupWithInput.interface.ts +0 -26
- package/dist/Atomic/FormElements/RadioGroupWithInput/RadioGroupWithInput.js +0 -1
- package/dist/Atomic/FormElements/RadioGroupWithInput/RadioGroupWithInput.scss +0 -31
- package/dist/Atomic/FormElements/RadioInput/RadioInput.interface.ts +0 -14
- package/dist/Atomic/FormElements/RadioInput/RadioInput.js +0 -1
- package/dist/Atomic/FormElements/RadioInput/RadioInput.scss +0 -72
- package/dist/Atomic/FormElements/RadioInput/index.ts +0 -5
- package/dist/Atomic/FormElements/RadioRowSwitcher/RadioRowSwitcher.js +0 -1
- package/dist/Atomic/FormElements/RadioRowSwitcher/RadioRowSwitcher.scss +0 -173
- package/dist/Atomic/FormElements/RadioRowSwitcher/RadioRowSwitcher.scss.d.ts +0 -4
- package/dist/Atomic/FormElements/RangeCalendar/RangeCalendar.js +0 -1
- package/dist/Atomic/FormElements/RangeCalendar/RangeCalendar.scss +0 -113
- package/dist/Atomic/FormElements/RangeInputs/RangeInputs.interface.ts +0 -25
- package/dist/Atomic/FormElements/RangeInputs/RangeInputs.js +0 -1
- package/dist/Atomic/FormElements/RangeInputs/RangeInputs.scss +0 -64
- package/dist/Atomic/FormElements/RangeInputs/index.ts +0 -5
- package/dist/Atomic/FormElements/RangeList/RangeList.interface.ts +0 -40
- package/dist/Atomic/FormElements/RangeList/RangeList.js +0 -1
- package/dist/Atomic/FormElements/RangeList/RangeList.scss +0 -163
- package/dist/Atomic/FormElements/RangeList/index.ts +0 -5
- package/dist/Atomic/FormElements/RangeList/partial/AnyOuterClass.scss +0 -26
- package/dist/Atomic/FormElements/RangeList/partial/RangeListRow.js +0 -1
- package/dist/Atomic/FormElements/RangeSlider/RangeSlider.js +0 -1
- package/dist/Atomic/FormElements/RangeSlider/RangeSlider.scss +0 -177
- package/dist/Atomic/FormElements/RangeSlider2/RangeSlider2.interface.ts +0 -57
- package/dist/Atomic/FormElements/RangeSlider2/RangeSlider2.js +0 -1
- package/dist/Atomic/FormElements/RangeSlider2/RangeSlider2.scss +0 -520
- package/dist/Atomic/FormElements/SwitchableRow/SwitchableRow.interface.ts +0 -13
- package/dist/Atomic/FormElements/SwitchableRow/SwitchableRow.js +0 -1
- package/dist/Atomic/FormElements/SwitchableRow/SwitchableRow.scss +0 -16
- package/dist/Atomic/FormElements/SwitchableRow/partial/AnyOuterClass.scss +0 -18
- package/dist/Atomic/FormElements/Switcher/Switcher.interface.ts +0 -15
- package/dist/Atomic/FormElements/Switcher/Switcher.js +0 -1
- package/dist/Atomic/FormElements/Switcher/Switcher.scss +0 -86
- package/dist/Atomic/FormElements/Switcher/index.ts +0 -5
- package/dist/Atomic/FormElements/Switcher/partial/AnyOuterClass.scss +0 -7
- package/dist/Atomic/FormElements/SwitcherCheckbox/SwitcherCheckbox.interface.ts +0 -24
- package/dist/Atomic/FormElements/SwitcherCheckbox/SwitcherCheckbox.js +0 -1
- package/dist/Atomic/FormElements/SwitcherCheckbox/SwitcherCheckbox.scss +0 -32
- package/dist/Atomic/FormElements/SwitcherCheckbox/partial/AnyOuterClass.scss +0 -7
- package/dist/Atomic/FormElements/SwitcherHide/SwitcherHide.interface.ts +0 -16
- package/dist/Atomic/FormElements/SwitcherHide/SwitcherHide.js +0 -1
- package/dist/Atomic/FormElements/SwitcherHide/SwitcherHide.scss +0 -32
- package/dist/Atomic/FormElements/SwitcherHide/index.ts +0 -5
- package/dist/Atomic/FormElements/SwitcherHide/partial/AnyOuterClass.scss +0 -7
- package/dist/Atomic/FormElements/SwitcherRadio/SwitcherRadio.interface.ts +0 -28
- package/dist/Atomic/FormElements/SwitcherRadio/SwitcherRadio.js +0 -1
- package/dist/Atomic/FormElements/SwitcherRadio/SwitcherRadio.scss +0 -30
- package/dist/Atomic/FormElements/SwitcherRadio/index.ts +0 -5
- package/dist/Atomic/FormElements/SwitcherRadio/partial/AnyOuterClass.scss +0 -7
- package/dist/Atomic/FormElements/SwitcherRange/SwitcherRange.interface.ts +0 -19
- package/dist/Atomic/FormElements/SwitcherRange/SwitcherRange.js +0 -1
- package/dist/Atomic/FormElements/SwitcherRange/SwitcherRange.scss +0 -25
- package/dist/Atomic/FormElements/SwitcherRange/index.ts +0 -5
- package/dist/Atomic/FormElements/SwitcherRangeList/SwitcherRangeList.interface.ts +0 -29
- package/dist/Atomic/FormElements/SwitcherRangeList/SwitcherRangeList.js +0 -1
- package/dist/Atomic/FormElements/SwitcherRangeList/SwitcherRangeList.scss +0 -12
- package/dist/Atomic/FormElements/SwitcherRangeList/partial/AnyOuterClass.scss +0 -37
- package/dist/Atomic/FormElements/SwitcherTagsDropdown/SwitcherTagsDropdown.interface.ts +0 -19
- package/dist/Atomic/FormElements/SwitcherTagsDropdown/SwitcherTagsDropdown.js +0 -1
- package/dist/Atomic/FormElements/SwitcherTagsDropdown/SwitcherTagsDropdown.scss +0 -47
- package/dist/Atomic/FormElements/SwitcherTagsDropdown/partial/AnyOuterClass.scss +0 -13
- package/dist/Atomic/FormElements/SwitcherTagsDropdown/partial/States.js +0 -1
- package/dist/Atomic/FormElements/SwitcherTextarea/SwitcherTextarea.interface.ts +0 -18
- package/dist/Atomic/FormElements/SwitcherTextarea/SwitcherTextarea.js +0 -1
- package/dist/Atomic/FormElements/SwitcherTextarea/SwitcherTextarea.scss +0 -25
- package/dist/Atomic/FormElements/SwitcherTextarea/partial/AnyOuterClass.scss +0 -21
- package/dist/Atomic/FormElements/TagListToDropdown/TagListToDropdown.interface.ts +0 -12
- package/dist/Atomic/FormElements/TagListToDropdown/TagListToDropdown.js +0 -1
- package/dist/Atomic/FormElements/TagsDropdown/TagsDropdown.interface.js +0 -1
- package/dist/Atomic/FormElements/TagsDropdown/TagsDropdown.interface.js.map +0 -1
- package/dist/Atomic/FormElements/TagsDropdown/TagsDropdown.interface.ts +0 -100
- package/dist/Atomic/FormElements/TagsDropdown/TagsDropdown.js +0 -1
- package/dist/Atomic/FormElements/TagsDropdown/TagsDropdown.js.map +0 -1
- package/dist/Atomic/FormElements/TagsDropdown/TagsDropdown.scss +0 -945
- package/dist/Atomic/FormElements/Text/Text.interface.ts +0 -22
- package/dist/Atomic/FormElements/Text/Text.js +0 -1
- package/dist/Atomic/FormElements/Text/Text.scss +0 -14
- package/dist/Atomic/FormElements/Text/index.ts +0 -5
- package/dist/Atomic/FormElements/TextSwitcher/TextSwitcher.js +0 -1
- package/dist/Atomic/FormElements/TextSwitcher/TextSwitcher.scss +0 -86
- package/dist/Atomic/FormElements/TextSwitcher/partial/AnyOuterClass.scss +0 -5
- package/dist/Atomic/FormElements/Textarea/Textarea.interface.ts +0 -24
- package/dist/Atomic/FormElements/Textarea/Textarea.js +0 -1
- package/dist/Atomic/FormElements/Textarea/Textarea.scss +0 -55
- package/dist/Atomic/FormElements/TieredCheckboxes/TieredCheckboxes.interface.ts +0 -44
- package/dist/Atomic/FormElements/TieredCheckboxes/TieredCheckboxes.js +0 -1
- package/dist/Atomic/FormElements/TieredCheckboxes/TieredCheckboxes.scss +0 -61
- package/dist/Atomic/FormElements/TieredCheckboxes/index.ts +0 -5
- package/dist/Atomic/FormElements/TieredCheckboxes/partial/AccordionWithCheckbox.js +0 -1
- package/dist/Atomic/FormElements/TimeRange/TimeRange.interface.ts +0 -8
- package/dist/Atomic/FormElements/TimeRange/TimeRange.js +0 -1
- package/dist/Atomic/FormElements/TimeRange/TimeRange.scss +0 -23
- package/dist/Atomic/FormElements/TimeRange/index.ts +0 -4
- package/dist/Atomic/FormElements/UserContacts/UserContacts.interface.ts +0 -36
- package/dist/Atomic/FormElements/UserContacts/UserContacts.js +0 -1
- package/dist/Atomic/FormElements/UserContacts/UserContacts.scss +0 -19
- package/dist/Atomic/FormElements/UserContacts/index.ts +0 -4
- package/dist/Atomic/FormElements/UserContacts/partial/AnyOuterClass.scss +0 -21
- package/dist/Atomic/FormElements/VariantsListRadio/VariantsListRadio.js +0 -1
- package/dist/Atomic/FormElements/VariantsListRadio/VariantsListRadio.scss +0 -314
- package/dist/Atomic/FormElements/VariantsListRadio/partials/VariantsListRadioItem.js +0 -1
- package/dist/Atomic/FormElements/WidgetPseudoTable/WidgetPseudoTable.js +0 -1
- package/dist/Atomic/FormElements/WidgetPseudoTable/WidgetPseudoTable.scss +0 -93
- package/dist/Atomic/FormElements/WidgetPseudoTable/partial/AnyOuterClass.scss +0 -83
- package/dist/Atomic/FormElements/WidgetPseudoTable/partial/constructor.js +0 -1
- package/dist/Atomic/FormElements/WidgetWithSwitchableRows/WidgetWithSwitchableRows.js +0 -1
- package/dist/Atomic/FormElements/WidgetWithSwitchableRows/WidgetWithSwitchableRows.scss +0 -93
- package/dist/Atomic/FormElements/WidgetWithSwitchableRows/partial/AnyOuterClass.scss +0 -83
- package/dist/Atomic/FormElements/WidgetWithSwitchableRows/partial/constructor.js +0 -1
- package/dist/Atomic/Layout/Header/Header.interface.ts +0 -11
- package/dist/Atomic/Layout/Header/Header.js +0 -1
- package/dist/Atomic/Layout/Header/Header.scss +0 -111
- package/dist/Atomic/Layout/Header/partials/default_ava.png +0 -0
- package/dist/Atomic/Layout/MainMenu/MainMenu.interface.tsx +0 -19
- package/dist/Atomic/Layout/MainMenu/MainMenu.js +0 -1
- package/dist/Atomic/Layout/MainMenu/MainMenu.jsx +0 -164
- package/dist/Atomic/Layout/MainMenu/MainMenu.scss +0 -207
- package/dist/Atomic/Layout/MainMenu/partials/fiLogo.svg +0 -14
- package/dist/Atomic/Layout/MainMenu/partials/finturfLogo.svg +0 -7
- package/dist/Atomic/Layout/Spinner/Spinner.interface.ts +0 -5
- package/dist/Atomic/Layout/Spinner/Spinner.js +0 -1
- package/dist/Atomic/Layout/Spinner/Spinner.scss +0 -103
- package/dist/Atomic/Layout/Spinner/index.ts +0 -4
- package/dist/Atomic/UI/Accordion/Accordion.interface.ts +0 -59
- package/dist/Atomic/UI/Accordion/Accordion.js +0 -1
- package/dist/Atomic/UI/Accordion/Accordion.scss +0 -98
- package/dist/Atomic/UI/Accordion/AccordionItem.js +0 -1
- package/dist/Atomic/UI/Accordion/index.ts +0 -4
- package/dist/Atomic/UI/AccordionTable/AccordionTable.js +0 -1
- package/dist/Atomic/UI/AccordionTable/AccordionTable.scss +0 -324
- package/dist/Atomic/UI/AccordionText/AccordionText.js +0 -1
- package/dist/Atomic/UI/AccordionText/AccordionText.scss +0 -66
- package/dist/Atomic/UI/AdvancedTag/AdvTag.js +0 -1
- package/dist/Atomic/UI/AdvancedTag/AdvancedTags.interface.ts +0 -40
- package/dist/Atomic/UI/AdvancedTag/AdvancedTags.js +0 -1
- package/dist/Atomic/UI/AdvancedTag/AdvancedTags.scss +0 -144
- package/dist/Atomic/UI/AdvancedTag/index.ts +0 -8
- package/dist/Atomic/UI/Alert/Alert.interface.ts +0 -31
- package/dist/Atomic/UI/Alert/Alert.js +0 -1
- package/dist/Atomic/UI/Alert/Alert.scss +0 -86
- package/dist/Atomic/UI/Alert/index.ts +0 -5
- package/dist/Atomic/UI/Arrow/Arrow.interface.ts +0 -11
- package/dist/Atomic/UI/Arrow/Arrow.js +0 -1
- package/dist/Atomic/UI/Arrow/Arrow.scss +0 -17
- package/dist/Atomic/UI/Box/Box.interface.ts +0 -10
- package/dist/Atomic/UI/Box/Box.js +0 -1
- package/dist/Atomic/UI/Box/Box.scss +0 -56
- package/dist/Atomic/UI/Button/Button.js +0 -1
- package/dist/Atomic/UI/Button/Button.scss +0 -163
- package/dist/Atomic/UI/ButtonsBar/ButtonsBar.interface.ts +0 -23
- package/dist/Atomic/UI/ButtonsBar/ButtonsBar.js +0 -1
- package/dist/Atomic/UI/ButtonsBar/ButtonsBar.scss +0 -8
- package/dist/Atomic/UI/ButtonsBar/index.ts +0 -5
- package/dist/Atomic/UI/Chart/Chart.interface.ts +0 -38
- package/dist/Atomic/UI/Chart/Chart.js +0 -1
- package/dist/Atomic/UI/Chart/Chart.scss +0 -58
- package/dist/Atomic/UI/Chart/index.ts +0 -5
- package/dist/Atomic/UI/Chart/partial/AnyOuterClass.scss +0 -39
- package/dist/Atomic/UI/Chart/partial/Chart.constants.js +0 -1
- package/dist/Atomic/UI/Chart/partial/ChartTypeSwitcherIcon/ChartTypeSwitcherIcon.js +0 -1
- package/dist/Atomic/UI/Chart/partial/ChartTypeSwitcherIcon/ChartTypeSwitcherIcon.scss +0 -23
- package/dist/Atomic/UI/Chart/partial/datasetSetters.js +0 -1
- package/dist/Atomic/UI/Chart/partial/optionsConstructor.js +0 -1
- package/dist/Atomic/UI/Chart/partial/optionsSetters.js +0 -1
- package/dist/Atomic/UI/Chart/partial/utils.js +0 -1
- package/dist/Atomic/UI/CircleProgressBar/CircleProgressBar.js +0 -1
- package/dist/Atomic/UI/CircleProgressBar/CircleProgressBar.scss +0 -66
- package/dist/Atomic/UI/DateTime/DateTime.interface.ts +0 -12
- package/dist/Atomic/UI/DateTime/DateTime.js +0 -1
- package/dist/Atomic/UI/DateTime/DateTime.scss +0 -17
- package/dist/Atomic/UI/DateTime/partial/AnyOuterClass.scss +0 -10
- package/dist/Atomic/UI/DebugContainer/DebugContainer.js +0 -1
- package/dist/Atomic/UI/DebugContainer/DebugContainer.scss +0 -42
- package/dist/Atomic/UI/DebugContainer/useDebugContainer.js +0 -1
- package/dist/Atomic/UI/DoubleString/DoubleString.interface.ts +0 -23
- package/dist/Atomic/UI/DoubleString/DoubleString.js +0 -1
- package/dist/Atomic/UI/DoubleString/DoubleString.scss +0 -59
- package/dist/Atomic/UI/DoubleString/index.ts +0 -5
- package/dist/Atomic/UI/DoubleString/partial/AnyOuterClass.scss +0 -18
- package/dist/Atomic/UI/DynamicIcon/DynamicIcon.interface.ts +0 -8
- package/dist/Atomic/UI/DynamicIcon/DynamicIcon.js +0 -1
- package/dist/Atomic/UI/DynamicIcon/index.ts +0 -4
- package/dist/Atomic/UI/ExampleChartIntegration/ExampleChartIntegration.js +0 -1
- package/dist/Atomic/UI/ExampleChartIntegration/partial/AnyOuterClass.scss +0 -68
- package/dist/Atomic/UI/ExampleChartIntegration/partial/utils.js +0 -1
- package/dist/Atomic/UI/Hint/Hint.interface.ts +0 -23
- package/dist/Atomic/UI/Hint/Hint.js +0 -1
- package/dist/Atomic/UI/Hint/Hint.scss +0 -150
- package/dist/Atomic/UI/Hint/index.ts +0 -5
- package/dist/Atomic/UI/Hint/partials/_constants.js +0 -1
- package/dist/Atomic/UI/Hint/partials/_utils.js +0 -1
- package/dist/Atomic/UI/Modal/Modal.interface.ts +0 -104
- package/dist/Atomic/UI/Modal/Modal.js +0 -1
- package/dist/Atomic/UI/Modal/Modal.scss +0 -362
- package/dist/Atomic/UI/Modal/ModalHOC.js +0 -1
- package/dist/Atomic/UI/Modal/ModalMobile.scss +0 -83
- package/dist/Atomic/UI/Modal/index.ts +0 -15
- package/dist/Atomic/UI/Modal/partials/ModalFooter.js +0 -1
- package/dist/Atomic/UI/Modal/partials/ModalTitle.js +0 -1
- package/dist/Atomic/UI/Modal/partials/_constants.js +0 -1
- package/dist/Atomic/UI/Modal/partials/_utils.js +0 -1
- package/dist/Atomic/UI/Modal/partials/useMobileModal.js +0 -1
- package/dist/Atomic/UI/MonoAccordion/MonoAccordion._test.js +0 -1
- package/dist/Atomic/UI/MonoAccordion/MonoAccordion.interface.ts +0 -19
- package/dist/Atomic/UI/MonoAccordion/MonoAccordion.js +0 -1
- package/dist/Atomic/UI/MonoAccordion/MonoAccordion.scss +0 -69
- package/dist/Atomic/UI/MonoAccordion/index.ts +0 -4
- package/dist/Atomic/UI/MonoAccordion/partial/AnyOuterClass.scss +0 -41
- package/dist/Atomic/UI/NavLine/NavLine.interface.ts +0 -34
- package/dist/Atomic/UI/NavLine/NavLine.js +0 -1
- package/dist/Atomic/UI/NavLine/NavLine.scss +0 -269
- package/dist/Atomic/UI/NavLine/index.ts +0 -4
- package/dist/Atomic/UI/PageTitle/PageTitle.interface.ts +0 -17
- package/dist/Atomic/UI/PageTitle/PageTitle.js +0 -1
- package/dist/Atomic/UI/PageTitle/PageTitle.scss +0 -94
- package/dist/Atomic/UI/PageTitle/index.ts +0 -4
- package/dist/Atomic/UI/PieChart/PieChart.js +0 -1
- package/dist/Atomic/UI/PieChart/PieChart.scss +0 -52
- package/dist/Atomic/UI/Price/Price.interface.ts +0 -7
- package/dist/Atomic/UI/Price/Price.js +0 -1
- package/dist/Atomic/UI/Price/index.ts +0 -4
- package/dist/Atomic/UI/PriceRange/PriceRange.interface.ts +0 -9
- package/dist/Atomic/UI/PriceRange/PriceRange.js +0 -1
- package/dist/Atomic/UI/PriceRange/index.ts +0 -4
- package/dist/Atomic/UI/ProgressLine/ProgressLine.interface.ts +0 -38
- package/dist/Atomic/UI/ProgressLine/ProgressLine.js +0 -1
- package/dist/Atomic/UI/ProgressLine/ProgressLine.scss +0 -348
- package/dist/Atomic/UI/ProgressLine/index.ts +0 -4
- package/dist/Atomic/UI/Status/Status.interface.ts +0 -17
- package/dist/Atomic/UI/Status/Status.js +0 -1
- package/dist/Atomic/UI/Status/Status.scss +0 -111
- package/dist/Atomic/UI/Status/index.ts +0 -4
- package/dist/Atomic/UI/Table/Partials/TdCell.js +0 -1
- package/dist/Atomic/UI/Table/Partials/TdHeader.js +0 -1
- package/dist/Atomic/UI/Table/Partials/TdRow.js +0 -1
- package/dist/Atomic/UI/Table/Partials/TdTitle.js +0 -1
- package/dist/Atomic/UI/Table/Table.js +0 -1
- package/dist/Atomic/UI/Table/Table.scss +0 -85
- package/dist/Atomic/UI/Table/TdTypes/TdActions.js +0 -1
- package/dist/Atomic/UI/Table/TdTypes/TdPriority.js +0 -1
- package/dist/Atomic/UI/Table/TdTypes/TdRange.js +0 -1
- package/dist/Atomic/UI/Table/TdTypes/TdTypes.scss +0 -40
- package/dist/Atomic/UI/Table/TdTypes/TdWeight.js +0 -1
- package/dist/Atomic/UI/Tag/Tag.interface.js +0 -1
- package/dist/Atomic/UI/Tag/Tag.interface.js.map +0 -1
- package/dist/Atomic/UI/Tag/Tag.interface.ts +0 -25
- package/dist/Atomic/UI/Tag/Tag.js +0 -1
- package/dist/Atomic/UI/Tag/Tag.js.map +0 -1
- package/dist/Atomic/UI/Tag/Tag.scss +0 -169
- package/dist/Atomic/UI/Tag/index.ts +0 -4
- package/dist/Atomic/UI/TagList/TagList.interface.js +0 -1
- package/dist/Atomic/UI/TagList/TagList.interface.js.map +0 -1
- package/dist/Atomic/UI/TagList/TagList.interface.ts +0 -17
- package/dist/Atomic/UI/TagList/TagList.js +0 -1
- package/dist/Atomic/UI/TagList/TagList.js.map +0 -1
- package/dist/Atomic/UI/TagList/TagList.scss +0 -78
- package/dist/Atomic/UI/TagList/TagListStories.scss +0 -6
- package/dist/Atomic/UI/UserBox/UserBox.interface.ts +0 -10
- package/dist/Atomic/UI/UserBox/UserBox.js +0 -1
- package/dist/Atomic/UI/UserBox/UserBox.scss +0 -79
- package/dist/Atomic/UI/UserBox/index.ts +0 -4
- package/dist/Atomic/UI/WizardStepper/WizardStepper.interface.ts +0 -43
- package/dist/Atomic/UI/WizardStepper/constructor.js +0 -1
- package/dist/Atomic/UI/WizardStepper/index.ts +0 -4
- package/dist/Atomic/UI/WizardStepper/ui/StateIcon/StateIcon.js +0 -1
- package/dist/Atomic/UI/WizardStepper/ui/StateIcon/StateIcon.scss +0 -37
- package/dist/Atomic/UI/WizardStepper/ui/StateIcon/index.ts +0 -3
- package/dist/Atomic/UI/WizardStepper/ui/StepRow/StepRow.js +0 -1
- package/dist/Atomic/UI/WizardStepper/ui/StepRow/StepRow.scss +0 -81
- package/dist/Atomic/UI/WizardStepper/ui/StepRow/index.ts +0 -3
- package/dist/Atomic/UI/WizardStepper/ui/StepWrapper/StepWrapper.js +0 -1
- package/dist/Atomic/UI/WizardStepper/ui/StepWrapper/StepWrapper.scss +0 -76
- package/dist/Atomic/UI/WizardStepper/ui/StepWrapper/index.ts +0 -3
- package/dist/Atomic/UI/WizardStepper/ui/icons.js +0 -1
- package/dist/Atomic/UI/WizardStepper/ui/index.ts +0 -3
- package/dist/Classes/AbortableFetch.js +0 -1
- package/dist/Classes/AnimatedHandler.js +0 -1
- package/dist/Classes/RESTAPI/index.js +0 -1
- package/dist/Classes/RESTAPI/partials/AbortableFetch.js +0 -1
- package/dist/Classes/RESTAPI/partials/ApiBase.js +0 -1
- package/dist/Classes/RESTAPI/partials/ApiRequestCreators.js +0 -1
- package/dist/Classes/RESTAPI/partials/ApiUtils.js +0 -1
- package/dist/Classes/RESTAPI/partials/CredentialsProcessing.js +0 -1
- package/dist/Classes/RESTAPI/partials/Utils.js +0 -1
- package/dist/Classes/RESTAPI/partials/_utils.js +0 -1
- package/dist/Classes/RESTAPI/readme.txt +0 -196
- package/dist/Constants/index.constants.js +0 -1
- package/dist/Functions/Portal.js +0 -1
- package/dist/Functions/README.txt +0 -9
- package/dist/Functions/customEventListener.js +0 -1
- package/dist/Functions/dateTime.js +0 -1
- package/dist/Functions/fieldValueFormatters.js +0 -1
- package/dist/Functions/guards/assertions.js +0 -1
- package/dist/Functions/guards/safeValue.js +0 -1
- package/dist/Functions/guards/typeGuards.js +0 -1
- package/dist/Functions/hooks/useFormFieldsChangesManager.js +0 -1
- package/dist/Functions/locale/createTranslator.js +0 -1
- package/dist/Functions/operations.js +0 -1
- package/dist/Functions/presets/inputMaskPresets.js +0 -1
- package/dist/Functions/presets/inputPresets.js +0 -1
- package/dist/Functions/presets/mobileKeyboardTypesPresets.js +0 -1
- package/dist/Functions/schemas.js +0 -1
- package/dist/Functions/useBodyScrollLock.js +0 -1
- package/dist/Functions/useClickOutside.js +0 -1
- package/dist/Functions/useDebounce.js +0 -1
- package/dist/Functions/useFieldFocus.js +0 -1
- package/dist/Functions/useFormTools/form-drivers/ArrayWithObjects.js +0 -1
- package/dist/Functions/useFormTools/form-drivers/ObjectWithIterableObjects.js +0 -1
- package/dist/Functions/useFormTools/form-drivers/ObjectWithNamedKeyObjects.js +0 -1
- package/dist/Functions/useFormTools/functions/General.js +0 -1
- package/dist/Functions/useFormTools/functions/RenderFields.js +0 -1
- package/dist/Functions/useFormTools/functions/usePrevious.js +0 -1
- package/dist/Functions/useFormTools/index.js +0 -1
- package/dist/Functions/useInputHighlightError.js +0 -1
- package/dist/Functions/useIsMobile/index.ts +0 -3
- package/dist/Functions/useIsMobile/useIsMobile.js +0 -1
- package/dist/Functions/useKeyPress/useHandleKeyPress.js +0 -1
- package/dist/Functions/useKeyPress/useKeyPress.js +0 -1
- package/dist/Functions/useLocalStorage.js +0 -1
- package/dist/Functions/useLocationParams.js +0 -1
- package/dist/Functions/useMediaQuery.js +0 -1
- package/dist/Functions/useMetaInfo.js +0 -1
- package/dist/Functions/useMouseUpOutside.js +0 -1
- package/dist/Functions/useOnlineStatus.js +0 -1
- package/dist/Functions/usePasswordChecker.js +0 -1
- package/dist/Functions/usePrevious.js +0 -1
- package/dist/Functions/useResize.js +0 -1
- package/dist/Functions/useScrollTo.js +0 -1
- package/dist/Functions/useToggle.js +0 -1
- package/dist/Functions/utils/disableDefaultBehavior/disableDefaultBehavior.js +0 -1
- package/dist/Functions/utils/disableDefaultBehavior/index.ts +0 -1
- package/dist/Functions/utils/getLimitedMask/getLimitedMask.js +0 -1
- package/dist/Functions/utils/getLimitedMask/index.ts +0 -1
- package/dist/Functions/utils.js +0 -1
- package/dist/Langs.js +0 -1
- package/dist/Molecular/CustomIcons/components/AffiliateNetworks.js +0 -1
- package/dist/Molecular/CustomIcons/components/AlertCircle.js +0 -1
- package/dist/Molecular/CustomIcons/components/AppStore.js +0 -1
- package/dist/Molecular/CustomIcons/components/Arrow.js +0 -1
- package/dist/Molecular/CustomIcons/components/ArrowDown.js +0 -1
- package/dist/Molecular/CustomIcons/components/ArrowLeft.js +0 -1
- package/dist/Molecular/CustomIcons/components/ArrowRight.js +0 -1
- package/dist/Molecular/CustomIcons/components/ArrowUp.js +0 -1
- package/dist/Molecular/CustomIcons/components/Bell.js +0 -1
- package/dist/Molecular/CustomIcons/components/Button.js +0 -1
- package/dist/Molecular/CustomIcons/components/Campaigns.js +0 -1
- package/dist/Molecular/CustomIcons/components/Check.js +0 -1
- package/dist/Molecular/CustomIcons/components/Check2.js +0 -1
- package/dist/Molecular/CustomIcons/components/ChevronDown.js +0 -1
- package/dist/Molecular/CustomIcons/components/ChevronDownDisabled.js +0 -1
- package/dist/Molecular/CustomIcons/components/ChevronLeft.js +0 -1
- package/dist/Molecular/CustomIcons/components/ChevronRight.js +0 -1
- package/dist/Molecular/CustomIcons/components/ChevronUp.js +0 -1
- package/dist/Molecular/CustomIcons/components/ChevronUpDown.js +0 -1
- package/dist/Molecular/CustomIcons/components/Close.js +0 -1
- package/dist/Molecular/CustomIcons/components/ColumnsOrder.js +0 -1
- package/dist/Molecular/CustomIcons/components/Delete.js +0 -1
- package/dist/Molecular/CustomIcons/components/Edit.js +0 -1
- package/dist/Molecular/CustomIcons/components/Email.js +0 -1
- package/dist/Molecular/CustomIcons/components/FinturfLogo.js +0 -1
- package/dist/Molecular/CustomIcons/components/FinturfLogo2.js +0 -1
- package/dist/Molecular/CustomIcons/components/Flows.js +0 -1
- package/dist/Molecular/CustomIcons/components/Gift.js +0 -1
- package/dist/Molecular/CustomIcons/components/GoogleAuth.js +0 -1
- package/dist/Molecular/CustomIcons/components/GooglePlay.js +0 -1
- package/dist/Molecular/CustomIcons/components/HelpCircle.js +0 -1
- package/dist/Molecular/CustomIcons/components/HelpCircle2.js +0 -1
- package/dist/Molecular/CustomIcons/components/HelpCircleFilled.js +0 -1
- package/dist/Molecular/CustomIcons/components/Home.js +0 -1
- package/dist/Molecular/CustomIcons/components/Home2.js +0 -1
- package/dist/Molecular/CustomIcons/components/Key.js +0 -1
- package/dist/Molecular/CustomIcons/components/Landers.js +0 -1
- package/dist/Molecular/CustomIcons/components/Lock.js +0 -1
- package/dist/Molecular/CustomIcons/components/Mail.js +0 -1
- package/dist/Molecular/CustomIcons/components/Mastercard.js +0 -1
- package/dist/Molecular/CustomIcons/components/Minus.js +0 -1
- package/dist/Molecular/CustomIcons/components/Offers.js +0 -1
- package/dist/Molecular/CustomIcons/components/Pause.js +0 -1
- package/dist/Molecular/CustomIcons/components/PayPal.js +0 -1
- package/dist/Molecular/CustomIcons/components/PayPalLightLarge.js +0 -1
- package/dist/Molecular/CustomIcons/components/Phone.js +0 -1
- package/dist/Molecular/CustomIcons/components/Play.js +0 -1
- package/dist/Molecular/CustomIcons/components/Plus.js +0 -1
- package/dist/Molecular/CustomIcons/components/Profile.js +0 -1
- package/dist/Molecular/CustomIcons/components/QRCode.js +0 -1
- package/dist/Molecular/CustomIcons/components/Rectangle.js +0 -1
- package/dist/Molecular/CustomIcons/components/Revert.js +0 -1
- package/dist/Molecular/CustomIcons/components/Star.js +0 -1
- package/dist/Molecular/CustomIcons/components/Star2.js +0 -1
- package/dist/Molecular/CustomIcons/components/TrafficSources.js +0 -1
- package/dist/Molecular/CustomIcons/components/Trash.js +0 -1
- package/dist/Molecular/CustomIcons/components/TrashRed.js +0 -1
- package/dist/Molecular/CustomIcons/components/Triggers.js +0 -1
- package/dist/Molecular/CustomIcons/components/User.js +0 -1
- package/dist/Molecular/CustomIcons/components/Visa.js +0 -1
- package/dist/Molecular/CustomIcons/components/X.js +0 -1
- package/dist/Molecular/FormElement/FormElement.interface.ts +0 -28
- package/dist/Molecular/FormElement/FormElement.js +0 -1
- package/dist/Molecular/FormElement/FormElement.scss +0 -28
- package/dist/Molecular/FormWithDependOn/FormWithDependOn.js +0 -1
- package/dist/Molecular/FormWithDependOn/partials/_utils.js +0 -1
- package/dist/Molecular/InputAddress/InputAddress.interface.ts +0 -39
- package/dist/Molecular/InputAddress/InputAddress.js +0 -1
- package/dist/Molecular/InputAddress/InputAddress.scss +0 -457
- package/dist/Molecular/InputCustomFetch/InputCustomFetch.js +0 -1
- package/dist/Molecular/InputCustomFetch/InputCustomFetch.scss +0 -464
- package/dist/Molecular/InputCustomFetch/README.md +0 -343
- package/dist/Molecular/InputCustomFetch/index.ts +0 -8
- package/dist/Molecular/InputCustomFetch/lib/hooks/useDebouncedCallback.js +0 -1
- package/dist/Molecular/InputCustomFetch/lib/hooks/useFetchWithAbort.js +0 -1
- package/dist/Molecular/InputCustomFetch/lib/utils.js +0 -1
- package/dist/Molecular/InputCustomFetch/model/types.js +0 -1
- package/dist/Molecular/InputPassword/InputPassword.interface.ts +0 -9
- package/dist/Molecular/InputPassword/InputPassword.js +0 -1
- package/dist/Molecular/InputPassword/InputPassword.scss +0 -31
- package/dist/index.ts +0 -5
- package/dist/types/base.interface.ts +0 -7
- package/dist/types/base.types.ts +0 -7
- package/dist/types/declaration/ArrayElement.d.ts +0 -13
- package/dist/types/declaration/AsyncReturnType.d.ts +0 -17
- package/dist/types/declaration/DeepPartial.d.ts +0 -40
- package/dist/types/declaration/DeepReadonly.d.ts +0 -38
- package/dist/types/declaration/DeepRequired.d.ts +0 -50
- package/dist/types/declaration/Flatten.d.ts +0 -34
- package/dist/types/declaration/FunctionType.d.ts +0 -37
- package/dist/types/declaration/If.d.ts +0 -34
- package/dist/types/declaration/KeysType.d.ts +0 -10
- package/dist/types/declaration/NonNullableType.d.ts +0 -13
- package/dist/types/declaration/ObjectType.d.ts +0 -9
- package/dist/types/declaration/OnlyObjectKeys.d.ts +0 -65
- package/dist/types/declaration/PrettyPrint.d.ts +0 -29
- package/dist/types/declaration/RequiredFields.d.ts +0 -21
- package/dist/types/declaration/TWithEventLogicAsObj/readme +0 -5
- package/dist/types/declaration/TWithEventManagementAsObj/index.ts +0 -35
- package/dist/types/declaration/TWithEventManagementAsObj/innerTypes/Modal.js +0 -1
- package/dist/types/declaration/TWithEventManagementAsObj/readme +0 -7
- package/dist/types/declaration/TupleType.d.ts +0 -10
- package/dist/types/declaration/ValuesType.d.ts +0 -10
- package/dist/types/declaration/index.ts +0 -35
- package/dist/types/index.ts +0 -1
- /package/dist/Atomic/FormElements/Input/hooks/{index.ts → index.d.ts} +0 -0
- /package/dist/Atomic/FormElements/InputCurrency/{index.ts → index.d.ts} +0 -0
- /package/dist/Atomic/FormElements/MultiSelect/{index.ts → index.d.ts} +0 -0
- /package/dist/Atomic/FormElements/RadioRowSwitcher/{index.ts → index.d.ts} +0 -0
- /package/dist/Atomic/UI/DebugContainer/{index.ts → index.d.ts} +0 -0
- /package/dist/Molecular/CustomIcons/{index.ts → index.d.ts} +0 -0
package/dist/hooks.js
ADDED
|
@@ -0,0 +1,2612 @@
|
|
|
1
|
+
// src/Functions/customEventListener.js
|
|
2
|
+
(function() {
|
|
3
|
+
Element.prototype._addEventListener = Element.prototype.addEventListener;
|
|
4
|
+
Element.prototype.addEventListener = function(a, b, c) {
|
|
5
|
+
if (c == void 0) c = false;
|
|
6
|
+
this._addEventListener(a, b, c);
|
|
7
|
+
if (!this.eventListenerList) this.eventListenerList = {};
|
|
8
|
+
if (!this.eventListenerList[a]) this.eventListenerList[a] = [];
|
|
9
|
+
this.eventListenerList[a].push({ listener: b, useCapture: c });
|
|
10
|
+
};
|
|
11
|
+
Element.prototype.getEventListeners = function(a) {
|
|
12
|
+
if (!this.eventListenerList) this.eventListenerList = {};
|
|
13
|
+
if (a == void 0) return this.eventListenerList;
|
|
14
|
+
return this.eventListenerList[a];
|
|
15
|
+
};
|
|
16
|
+
Element.prototype.clearEventListeners = function(a) {
|
|
17
|
+
if (!this.eventListenerList) this.eventListenerList = {};
|
|
18
|
+
if (a == void 0) {
|
|
19
|
+
for (const x in this.getEventListeners()) this.clearEventListeners(x);
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
const el = this.getEventListeners(a);
|
|
23
|
+
if (el == void 0) return;
|
|
24
|
+
for (let i = el.length - 1; i >= 0; --i) {
|
|
25
|
+
const ev = el[i];
|
|
26
|
+
this.removeEventListener(a, ev.listener, ev.useCapture);
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
Element.prototype._removeEventListener = Element.prototype.removeEventListener;
|
|
30
|
+
Element.prototype.removeEventListener = function(a, b, c) {
|
|
31
|
+
if (c == void 0) c = false;
|
|
32
|
+
this._removeEventListener(a, b, c);
|
|
33
|
+
if (!this.eventListenerList) this.eventListenerList = {};
|
|
34
|
+
if (!this.eventListenerList[a]) this.eventListenerList[a] = [];
|
|
35
|
+
for (let i = 0; i < this.eventListenerList[a].length; i++) {
|
|
36
|
+
if (this.eventListenerList[a][i].listener == b, this.eventListenerList[a][i].useCapture == c) {
|
|
37
|
+
this.eventListenerList[a].splice(i, 1);
|
|
38
|
+
break;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
if (this.eventListenerList[a].length == 0) delete this.eventListenerList[a];
|
|
42
|
+
};
|
|
43
|
+
})();
|
|
44
|
+
function addEventListener(element, eventName, handler) {
|
|
45
|
+
if (element && element.addEventListener) {
|
|
46
|
+
element.addEventListener(eventName, handler);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
function removeEventListener(element, eventName, handler) {
|
|
50
|
+
if (element && element.removeEventListener) {
|
|
51
|
+
element.removeEventListener(eventName, handler);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
function dispatchCustomEvent(element, eventName, detail = {}) {
|
|
55
|
+
if (element) {
|
|
56
|
+
const event = new CustomEvent(eventName, { detail });
|
|
57
|
+
element.dispatchEvent(event);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
var customEventListener_default = {
|
|
61
|
+
addEventListener,
|
|
62
|
+
removeEventListener,
|
|
63
|
+
dispatchCustomEvent
|
|
64
|
+
};
|
|
65
|
+
|
|
66
|
+
// src/Functions/dateTime.js
|
|
67
|
+
import moment from "moment";
|
|
68
|
+
var DATETIME_FORMATS = Object.freeze({
|
|
69
|
+
// Основные форматы
|
|
70
|
+
DATE_FORMAT: "YYYY-MM-DD",
|
|
71
|
+
// Стандартный формат даты
|
|
72
|
+
DATE_WITHOUT_SEPARATORS: "MMDDYYYY",
|
|
73
|
+
// Без разделителей
|
|
74
|
+
VALIDATION_DATE_FORMAT: "MM/DD/YYYY",
|
|
75
|
+
// Для валидации
|
|
76
|
+
INPUT_DATE_FORMAT: "MM.DD.YYYY",
|
|
77
|
+
// Формат для ввода
|
|
78
|
+
INPUT_TIME_FORMAT: "YYYY-MM-DD HH:mm:SS",
|
|
79
|
+
// Ввод времени
|
|
80
|
+
TIME_FORMAT_WSPACE: "YYYY-MM-DD HH:mm:SS",
|
|
81
|
+
// Время с пробелом
|
|
82
|
+
TIME_FORMAT: "YYYY-MM-DDTHH:mm:SS",
|
|
83
|
+
// Время с T (ISO формат)
|
|
84
|
+
DATE_FORMAT_WITH_SLASH: "MM/DD/YYYY",
|
|
85
|
+
// Дата с разделителем /
|
|
86
|
+
// Дополнительные форматы
|
|
87
|
+
DATE_WITH_DASHES: "MM-DD-YYYY",
|
|
88
|
+
// Дата с дефисами
|
|
89
|
+
DATE_WITH_DOTS: "DD.MM.YYYY",
|
|
90
|
+
// Дата с точками
|
|
91
|
+
DATE_WITH_COMMA: "DD,MM,YYYY",
|
|
92
|
+
// Дата с запятыми
|
|
93
|
+
FULL_DATE_TIME: "YYYY-MM-DD HH:mm:ss",
|
|
94
|
+
// Полная дата и время
|
|
95
|
+
ISO_DATE_TIME: "YYYY-MM-DDTHH:mm:ss.SSSZ",
|
|
96
|
+
// ISO стандарт с миллисекундами
|
|
97
|
+
LOCALIZED_DATE: "MMMM DD, YYYY",
|
|
98
|
+
// Локализованный формат с полным названием месяца
|
|
99
|
+
SHORT_DATE: "MM/DD/YY",
|
|
100
|
+
// Краткая дата
|
|
101
|
+
SHORT_DATE_WITH_TIME: "MM/DD/YY HH:mm",
|
|
102
|
+
// Краткая дата с временем
|
|
103
|
+
TIME_24H: "HH:mm",
|
|
104
|
+
// Время в 24-часовом формате
|
|
105
|
+
TIME_12H: "hh:mm A",
|
|
106
|
+
// Время в 12-часовом формате
|
|
107
|
+
TIME_12H_WITH_SECONDS: "hh:mm:ss A",
|
|
108
|
+
// Время в 12-часовом формате с секундами
|
|
109
|
+
TIME_24H_WITH_SECONDS: "HH:mm:ss",
|
|
110
|
+
// Время в 24-часовом формате с секундами
|
|
111
|
+
MONTH_DAY: "MM/DD",
|
|
112
|
+
// Только месяц и день
|
|
113
|
+
YEAR_MONTH_DAY: "YYYY/MM/DD"
|
|
114
|
+
// Год/Месяц/День
|
|
115
|
+
});
|
|
116
|
+
var formatMap = Object.freeze({
|
|
117
|
+
[DATETIME_FORMATS.DATE_FORMAT]: "YYYY-MM-DD",
|
|
118
|
+
// Стандартный формат даты
|
|
119
|
+
[DATETIME_FORMATS.DATE_WITHOUT_SEPARATORS]: "MMDDYYYY",
|
|
120
|
+
// Без разделителей
|
|
121
|
+
[DATETIME_FORMATS.VALIDATION_DATE_FORMAT]: "MM/DD/YYYY",
|
|
122
|
+
// Для валидации
|
|
123
|
+
[DATETIME_FORMATS.INPUT_DATE_FORMAT]: "MM.DD.YYYY",
|
|
124
|
+
// Формат для ввода
|
|
125
|
+
[DATETIME_FORMATS.INPUT_TIME_FORMAT]: "YYYY-MM-DD HH:mm:SS",
|
|
126
|
+
// Ввод времени
|
|
127
|
+
[DATETIME_FORMATS.TIME_FORMAT_WSPACE]: "YYYY-MM-DD HH:mm:SS",
|
|
128
|
+
// Время с пробелом
|
|
129
|
+
[DATETIME_FORMATS.TIME_FORMAT]: "YYYY-MM-DDTHH:mm:SS",
|
|
130
|
+
// Время с T (ISO формат)
|
|
131
|
+
[DATETIME_FORMATS.DATE_FORMAT_WITH_SLASH]: "MM/DD/YYYY",
|
|
132
|
+
// Дата с разделителем /
|
|
133
|
+
[DATETIME_FORMATS.DATE_WITH_DASHES]: "MM-DD-YYYY",
|
|
134
|
+
// Дата с дефисами
|
|
135
|
+
[DATETIME_FORMATS.DATE_WITH_DOTS]: "DD.MM.YYYY",
|
|
136
|
+
// Дата с точками
|
|
137
|
+
[DATETIME_FORMATS.DATE_WITH_COMMA]: "DD,MM,YYYY",
|
|
138
|
+
// Дата с запятыми
|
|
139
|
+
[DATETIME_FORMATS.FULL_DATE_TIME]: "YYYY-MM-DD HH:mm:ss",
|
|
140
|
+
// Полная дата и время
|
|
141
|
+
[DATETIME_FORMATS.ISO_DATE_TIME]: "YYYY-MM-DDTHH:mm:ss.SSSZ",
|
|
142
|
+
// ISO стандарт с миллисекундами
|
|
143
|
+
[DATETIME_FORMATS.LOCALIZED_DATE]: "MMMM DD, YYYY",
|
|
144
|
+
// Локализованный формат с полным названием месяца
|
|
145
|
+
[DATETIME_FORMATS.SHORT_DATE]: "MM/DD/YY",
|
|
146
|
+
// Краткая дата
|
|
147
|
+
[DATETIME_FORMATS.SHORT_DATE_WITH_TIME]: "MM/DD/YY HH:mm",
|
|
148
|
+
// Краткая дата с временем
|
|
149
|
+
[DATETIME_FORMATS.TIME_24H]: "HH:mm",
|
|
150
|
+
// Время в 24-часовом формате
|
|
151
|
+
[DATETIME_FORMATS.TIME_12H]: "hh:mm A",
|
|
152
|
+
// Время в 12-часовом формате
|
|
153
|
+
[DATETIME_FORMATS.TIME_12H_WITH_SECONDS]: "hh:mm:ss A",
|
|
154
|
+
// Время в 12-часовом формате с секундами
|
|
155
|
+
[DATETIME_FORMATS.TIME_24H_WITH_SECONDS]: "HH:mm:ss",
|
|
156
|
+
// Время в 24-часовом формате с секундами
|
|
157
|
+
[DATETIME_FORMATS.MONTH_DAY]: "MM/DD",
|
|
158
|
+
// Только месяц и день
|
|
159
|
+
[DATETIME_FORMATS.YEAR_MONTH_DAY]: "YYYY/MM/DD"
|
|
160
|
+
// Год/Месяц/День
|
|
161
|
+
});
|
|
162
|
+
var DATE_UNITS = Object.freeze({
|
|
163
|
+
YEARS: Object.freeze({
|
|
164
|
+
YEARS: "years",
|
|
165
|
+
YEAR: "year",
|
|
166
|
+
Y: "y",
|
|
167
|
+
TEMPLATE: "YYYY"
|
|
168
|
+
}),
|
|
169
|
+
MONTHS: Object.freeze({
|
|
170
|
+
MONTHS: "months",
|
|
171
|
+
MONTH: "month",
|
|
172
|
+
MON: "M",
|
|
173
|
+
TEMPLATE: "MM"
|
|
174
|
+
}),
|
|
175
|
+
DAYS: Object.freeze({
|
|
176
|
+
DAYS: "days",
|
|
177
|
+
DAY: "day",
|
|
178
|
+
D: "d",
|
|
179
|
+
TEMPLATE: "DD"
|
|
180
|
+
}),
|
|
181
|
+
HOURS: Object.freeze({
|
|
182
|
+
HOURS: "hours",
|
|
183
|
+
HOUR: "hour",
|
|
184
|
+
H: "h",
|
|
185
|
+
TEMPLATE: "HH"
|
|
186
|
+
}),
|
|
187
|
+
WEEKS: Object.freeze({
|
|
188
|
+
WEEKS: "weeks",
|
|
189
|
+
WEEK: "week",
|
|
190
|
+
W: "w"
|
|
191
|
+
}),
|
|
192
|
+
QUARTERS: Object.freeze({
|
|
193
|
+
QUARTERS: "quarters",
|
|
194
|
+
QUARTER: "quarter",
|
|
195
|
+
Q: "Q"
|
|
196
|
+
}),
|
|
197
|
+
MINUTES: Object.freeze({
|
|
198
|
+
MINUTES: "minutes",
|
|
199
|
+
MINUTE: "minute",
|
|
200
|
+
MIN: "m"
|
|
201
|
+
}),
|
|
202
|
+
SECONDS: Object.freeze({
|
|
203
|
+
SECONDS: "seconds",
|
|
204
|
+
SECOND: "second",
|
|
205
|
+
S: "s"
|
|
206
|
+
}),
|
|
207
|
+
MILLISECONDS: Object.freeze({
|
|
208
|
+
MILLISECONDS: "milliseconds",
|
|
209
|
+
MILLISECOND: "millisecond",
|
|
210
|
+
MS: "ms"
|
|
211
|
+
})
|
|
212
|
+
});
|
|
213
|
+
function parseAndFormatDate(value, outputFormat = DATETIME_FORMATS.INPUT_DATE_FORMAT) {
|
|
214
|
+
if (!value || typeof value !== "string") return value;
|
|
215
|
+
for (let format in formatMap) {
|
|
216
|
+
const parsedDate = moment(value, formatMap[format], true);
|
|
217
|
+
if (parsedDate.isValid()) {
|
|
218
|
+
return parsedDate.format(outputFormat);
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
return value;
|
|
222
|
+
}
|
|
223
|
+
|
|
224
|
+
// src/Constants/index.constants.js
|
|
225
|
+
var KEYBOARD_SERVICE_KEYS = [
|
|
226
|
+
"Escape",
|
|
227
|
+
"F1",
|
|
228
|
+
"F2",
|
|
229
|
+
"F3",
|
|
230
|
+
"F4",
|
|
231
|
+
"F5",
|
|
232
|
+
"F6",
|
|
233
|
+
"F7",
|
|
234
|
+
"F8",
|
|
235
|
+
"F9",
|
|
236
|
+
"F10",
|
|
237
|
+
"F11",
|
|
238
|
+
"F12",
|
|
239
|
+
"Tab",
|
|
240
|
+
"CapsLock",
|
|
241
|
+
"Shift",
|
|
242
|
+
"Control",
|
|
243
|
+
"Meta",
|
|
244
|
+
"Option",
|
|
245
|
+
"Alt",
|
|
246
|
+
"ContextMenu",
|
|
247
|
+
"ArrowLeft",
|
|
248
|
+
"ArrowRight",
|
|
249
|
+
"ArrowUp",
|
|
250
|
+
"ArrowDown",
|
|
251
|
+
"NumLock",
|
|
252
|
+
"Backspace",
|
|
253
|
+
"Delete",
|
|
254
|
+
"Enter",
|
|
255
|
+
"Return",
|
|
256
|
+
"Insert",
|
|
257
|
+
"Home",
|
|
258
|
+
"End",
|
|
259
|
+
"PageUp",
|
|
260
|
+
"PageDown",
|
|
261
|
+
"PrintScreen",
|
|
262
|
+
"ScrollLock",
|
|
263
|
+
"Pause"
|
|
264
|
+
];
|
|
265
|
+
var MAX_PHONE_LENGTH = 10;
|
|
266
|
+
var MAX_NAME_LENGTH = 128;
|
|
267
|
+
var DEFAULT_DATE_MASK_NO_VALUE_SYMBOL = "_";
|
|
268
|
+
var DEFAULT_COLORS = [
|
|
269
|
+
"#D9C1FF",
|
|
270
|
+
"#FFBAF0",
|
|
271
|
+
"#FFB8CE",
|
|
272
|
+
"#FFC3A2",
|
|
273
|
+
"#FFDB7C",
|
|
274
|
+
"#F9F871",
|
|
275
|
+
"#C3FCF1",
|
|
276
|
+
"#F6F2CB",
|
|
277
|
+
"#E0F8D1",
|
|
278
|
+
"#B1DFFB",
|
|
279
|
+
"#8DECFE",
|
|
280
|
+
"#76F7ED",
|
|
281
|
+
"#8AFEC8"
|
|
282
|
+
];
|
|
283
|
+
var KEYBOARD_KEY_CODES = {
|
|
284
|
+
Backspace: 8,
|
|
285
|
+
Delete: 46,
|
|
286
|
+
ARROW_LEFT: 37,
|
|
287
|
+
ARROW_RIGHT: 39
|
|
288
|
+
};
|
|
289
|
+
var OS = {
|
|
290
|
+
iOS: "iOS",
|
|
291
|
+
Android: "Android",
|
|
292
|
+
WP: "Windows Phone",
|
|
293
|
+
Linux: "Linux",
|
|
294
|
+
Windows: "Windows",
|
|
295
|
+
MacOS: "MacOS",
|
|
296
|
+
Unknown: "unknown"
|
|
297
|
+
};
|
|
298
|
+
|
|
299
|
+
// src/Functions/utils.js
|
|
300
|
+
import { useEffect } from "react";
|
|
301
|
+
import moment2 from "moment-timezone";
|
|
302
|
+
var uuid = () => Date.now().toString(36) + Math.random().toString(36).substring(2);
|
|
303
|
+
var getIsOnlyAnObject = (input) => {
|
|
304
|
+
return typeof input === "object" && // "отбивает" примитивы и функции
|
|
305
|
+
input instanceof Object && // "отбивает" null
|
|
306
|
+
!Array.isArray(input) && // "отбивает" массивы
|
|
307
|
+
!(input instanceof Set) && // "отбивает" сеты
|
|
308
|
+
!(input instanceof Map);
|
|
309
|
+
};
|
|
310
|
+
var handleObjectChange = (updateObject, updateFunction) => (data, prop = "", isNumber) => {
|
|
311
|
+
let value;
|
|
312
|
+
if (data?.target) {
|
|
313
|
+
value = data.target.type === "checkbox" ? data.target.checked : data.target.value;
|
|
314
|
+
} else value = data;
|
|
315
|
+
value = isNumber ? Number(value) : value;
|
|
316
|
+
const props = prop.split(".");
|
|
317
|
+
const currentObject = props.reduce((res, chapter, index) => {
|
|
318
|
+
if (props.length !== index + 1) res = res[chapter];
|
|
319
|
+
return res;
|
|
320
|
+
}, updateObject);
|
|
321
|
+
currentObject[props.pop()] = value;
|
|
322
|
+
updateFunction();
|
|
323
|
+
};
|
|
324
|
+
var useOutsideToggle = (ref, setOut, open) => {
|
|
325
|
+
function handleClickOutside(event) {
|
|
326
|
+
if (ref.current && !ref.current.contains(event.target)) {
|
|
327
|
+
setOut(open);
|
|
328
|
+
}
|
|
329
|
+
}
|
|
330
|
+
useEffect(() => {
|
|
331
|
+
document.addEventListener("mouseup", handleClickOutside);
|
|
332
|
+
return () => {
|
|
333
|
+
document.removeEventListener("mouseup", handleClickOutside);
|
|
334
|
+
};
|
|
335
|
+
}, [ref]);
|
|
336
|
+
};
|
|
337
|
+
var clone = (input) => {
|
|
338
|
+
if (input === null || typeof input !== "object") return input;
|
|
339
|
+
const data = input instanceof Array ? [] : {};
|
|
340
|
+
for (const i in input) data[i] = clone(input[i]);
|
|
341
|
+
return data;
|
|
342
|
+
};
|
|
343
|
+
var getResponseClone = async (res) => await (typeof res?.clone === "function" ? res.clone() : clone(res));
|
|
344
|
+
function transformUTCTimeToLocal(date, format = "YYYY-MM-DD HH:mm:ss") {
|
|
345
|
+
if (!date) return;
|
|
346
|
+
const utcDate = moment2.utc(date).toDate();
|
|
347
|
+
return moment2(utcDate, format).local().format(format);
|
|
348
|
+
}
|
|
349
|
+
function transformLocalTimeToUTC(date, format = "YYYY-MM-DD HH:mm:ss") {
|
|
350
|
+
if (!date) return;
|
|
351
|
+
return moment2(date, format).utc().format(format);
|
|
352
|
+
}
|
|
353
|
+
function transformUTCHoursToLocal(time, format = "HH:mm:ss") {
|
|
354
|
+
if (!time) return;
|
|
355
|
+
const splitedTime = time.split(":");
|
|
356
|
+
const offset = moment2().utcOffset();
|
|
357
|
+
let HH = Number(splitedTime[0]);
|
|
358
|
+
let mm = Number(splitedTime[1]);
|
|
359
|
+
const ss = splitedTime[2];
|
|
360
|
+
mm = mm + offset;
|
|
361
|
+
while (mm > 59) {
|
|
362
|
+
mm -= 60;
|
|
363
|
+
HH += 1;
|
|
364
|
+
}
|
|
365
|
+
if (HH > 23) HH -= 24;
|
|
366
|
+
while (mm < 0) {
|
|
367
|
+
mm += 60;
|
|
368
|
+
HH -= 1;
|
|
369
|
+
}
|
|
370
|
+
if (HH < 0) HH += 24;
|
|
371
|
+
return `${HH}:${mm}:${ss}`;
|
|
372
|
+
}
|
|
373
|
+
function transformDateOrTimeOrTogetherToFormat(data, outputFormat = "HH:mm", additional) {
|
|
374
|
+
const ERROR_VALUE = "Invalid date";
|
|
375
|
+
const ERROR_MESSGE = `Invalid input data for ${outputFormat} format`;
|
|
376
|
+
const { parseFormat, isReturnAsMomentInstance } = getIsOnlyAnObject(
|
|
377
|
+
additional
|
|
378
|
+
) ? additional : {};
|
|
379
|
+
if (typeof data !== "string" && typeof data !== "number") {
|
|
380
|
+
return isReturnAsMomentInstance ? moment2("error") : ERROR_MESSGE;
|
|
381
|
+
}
|
|
382
|
+
const momentArgs = [
|
|
383
|
+
data,
|
|
384
|
+
...!Number.isNaN(Number(data)) || typeof parseFormat === "string" ? [] : [parseFormat]
|
|
385
|
+
];
|
|
386
|
+
const momentInstance = (() => {
|
|
387
|
+
let instance = moment2(...momentArgs);
|
|
388
|
+
if (instance.format(outputFormat) !== ERROR_VALUE) return instance;
|
|
389
|
+
else if (/^\d\d.\d\d/.test(data)) {
|
|
390
|
+
instance = moment2();
|
|
391
|
+
const symbols = data.split("");
|
|
392
|
+
const timeArr = symbols.reduce(
|
|
393
|
+
(acc, symbol, idx) => {
|
|
394
|
+
if (Number.isNaN(Number(symbol))) {
|
|
395
|
+
if (acc.group) acc.result.push(acc.group);
|
|
396
|
+
acc.group = "";
|
|
397
|
+
} else acc.group = `${acc.group}${symbol}`;
|
|
398
|
+
if (idx === symbols.length - 1 && acc.group)
|
|
399
|
+
acc.result.push(acc.group);
|
|
400
|
+
return acc;
|
|
401
|
+
},
|
|
402
|
+
{ result: [], group: "" }
|
|
403
|
+
).result.reverse();
|
|
404
|
+
instance.hours(Number(timeArr.pop()));
|
|
405
|
+
instance.minutes(Number(timeArr.pop()));
|
|
406
|
+
instance.seconds(timeArr.length ? Number(timeArr.pop()) : 0);
|
|
407
|
+
instance.milliseconds(timeArr.length ? Number(timeArr.pop()) : 0);
|
|
408
|
+
} else instance = moment2("error");
|
|
409
|
+
return instance;
|
|
410
|
+
})();
|
|
411
|
+
if (isReturnAsMomentInstance) return momentInstance;
|
|
412
|
+
const output = momentInstance.format(outputFormat);
|
|
413
|
+
return output === ERROR_VALUE ? ERROR_MESSGE : output;
|
|
414
|
+
}
|
|
415
|
+
function transformDateOrTimeOrTogetherToFormattedLocal(data, outputFormat = "HH:mm", additional) {
|
|
416
|
+
const ERROR_VALUE = "Invalid date";
|
|
417
|
+
const ERROR_MESSGE = `Invalid input data for ${outputFormat} format`;
|
|
418
|
+
if (additional && !getIsOnlyAnObject(additional)) {
|
|
419
|
+
throw new Error(
|
|
420
|
+
"Bad additional [transformDateOrTimeOrTogetherToFormattedLocal]"
|
|
421
|
+
);
|
|
422
|
+
}
|
|
423
|
+
const compositeAdditional = {
|
|
424
|
+
...additional || {},
|
|
425
|
+
isReturnAsMomentInstance: true
|
|
426
|
+
};
|
|
427
|
+
const date = transformDateOrTimeOrTogetherToFormat(
|
|
428
|
+
data,
|
|
429
|
+
outputFormat,
|
|
430
|
+
compositeAdditional
|
|
431
|
+
);
|
|
432
|
+
const dateWithLocale = date.add(moment2().utcOffset(), "minutes");
|
|
433
|
+
const output = dateWithLocale.format(outputFormat);
|
|
434
|
+
return output === ERROR_VALUE ? ERROR_MESSGE : output;
|
|
435
|
+
}
|
|
436
|
+
var omitKeys = (obj = {}, keys = []) => keys.reduce((acc, key) => {
|
|
437
|
+
const { [key]: omit, ...rest } = acc;
|
|
438
|
+
return rest;
|
|
439
|
+
}, obj);
|
|
440
|
+
var logout = () => {
|
|
441
|
+
window.localStorage.removeItem("accessToken");
|
|
442
|
+
window.localStorage.removeItem("tokenExpires");
|
|
443
|
+
window.location.reload();
|
|
444
|
+
};
|
|
445
|
+
var getStyles = (el, prop) => {
|
|
446
|
+
if (!el) return null;
|
|
447
|
+
if (!prop) return window.getComputedStyle(el);
|
|
448
|
+
return window.getComputedStyle(el).getPropertyValue(prop);
|
|
449
|
+
};
|
|
450
|
+
var getColorById = (id, colors) => {
|
|
451
|
+
if (!id) return "#FF7D00";
|
|
452
|
+
const idToArr = Array.from(id);
|
|
453
|
+
const colorsArr = colors && colors.length > 0 ? colors : DEFAULT_COLORS;
|
|
454
|
+
let number = idToArr.reduce((acc, item) => {
|
|
455
|
+
if (Number(item)) {
|
|
456
|
+
return acc + Number(item);
|
|
457
|
+
}
|
|
458
|
+
return acc;
|
|
459
|
+
}, 0);
|
|
460
|
+
while (number >= colorsArr.length) {
|
|
461
|
+
number -= colorsArr.length;
|
|
462
|
+
}
|
|
463
|
+
return colorsArr[number];
|
|
464
|
+
};
|
|
465
|
+
var debounce = (fn, ms) => {
|
|
466
|
+
let id = null;
|
|
467
|
+
return (...args) => {
|
|
468
|
+
clearTimeout(id);
|
|
469
|
+
id = setTimeout(() => {
|
|
470
|
+
clearTimeout(id);
|
|
471
|
+
fn(...args);
|
|
472
|
+
}, ms);
|
|
473
|
+
};
|
|
474
|
+
};
|
|
475
|
+
var throttle = (fn, ms) => {
|
|
476
|
+
let id = null;
|
|
477
|
+
return (...args) => {
|
|
478
|
+
if (id) return;
|
|
479
|
+
fn(...args);
|
|
480
|
+
id = setTimeout(() => {
|
|
481
|
+
clearTimeout(id);
|
|
482
|
+
id = null;
|
|
483
|
+
}, ms);
|
|
484
|
+
};
|
|
485
|
+
};
|
|
486
|
+
var addBitDepthPoints = (value, step = 3) => {
|
|
487
|
+
const isFraction = value?.includes(".");
|
|
488
|
+
const valueBeforeDot = isFraction ? value?.slice(0, value?.indexOf(".")) : value;
|
|
489
|
+
const intPart = valueBeforeDot.split("").reverse().reduce(
|
|
490
|
+
(acc, item, idx) => idx % step === 0 && idx !== 0 ? [...acc, ",", item] : [...acc, item],
|
|
491
|
+
[]
|
|
492
|
+
).reverse().join("");
|
|
493
|
+
return isFraction ? intPart + value?.slice(value?.indexOf(".")) : intPart;
|
|
494
|
+
};
|
|
495
|
+
var changeMeta = (key, items = []) => {
|
|
496
|
+
const defaultMeta = items.find((i) => i.key === "default");
|
|
497
|
+
if (key) {
|
|
498
|
+
const item = items.find((i) => i.key === key);
|
|
499
|
+
document.title = item?.title ?? defaultMeta?.title;
|
|
500
|
+
document.querySelector('meta[name="description"]').setAttribute("content", item?.description ?? defaultMeta?.description);
|
|
501
|
+
}
|
|
502
|
+
};
|
|
503
|
+
var firstLetterCapital = (str) => typeof str === "string" ? `${str.charAt(0).toUpperCase()}${str.slice(1)}` : str;
|
|
504
|
+
var capitalized = firstLetterCapital;
|
|
505
|
+
var checkedRef = (ref) => ref ? typeof ref === "function" ? (node) => ref(node) : ref : null;
|
|
506
|
+
function downloadEmulation(data, filename, type = "image/*") {
|
|
507
|
+
const file = new Blob([data], { type });
|
|
508
|
+
if (window.navigator.msSaveOrOpenBlob)
|
|
509
|
+
window.navigator.msSaveOrOpenBlob(file, filename);
|
|
510
|
+
else {
|
|
511
|
+
const a = document.createElement("a"), url = URL.createObjectURL(file);
|
|
512
|
+
a.href = url;
|
|
513
|
+
a.download = filename;
|
|
514
|
+
document.body.appendChild(a);
|
|
515
|
+
a.click();
|
|
516
|
+
setTimeout(() => {
|
|
517
|
+
document.body.removeChild(a);
|
|
518
|
+
window.URL.revokeObjectURL(url);
|
|
519
|
+
}, 0);
|
|
520
|
+
}
|
|
521
|
+
}
|
|
522
|
+
var downloadFile = async ({ url, name, type = null }) => {
|
|
523
|
+
const response = await fetch(url).then(async (res) => ({
|
|
524
|
+
data: await res.blob(),
|
|
525
|
+
type: type ?? res.headers.get("content-type")
|
|
526
|
+
}));
|
|
527
|
+
downloadEmulation(response.data, name, response.type);
|
|
528
|
+
};
|
|
529
|
+
var compare = (first, second, keys = []) => {
|
|
530
|
+
if (typeof first !== typeof second) return false;
|
|
531
|
+
if (Array.isArray(first) !== Array.isArray(second)) return false;
|
|
532
|
+
if (!(first instanceof Object)) return first === second;
|
|
533
|
+
const getComparationStructure = (data) => {
|
|
534
|
+
if (typeof data === "function") return data.toString();
|
|
535
|
+
if (!(data instanceof Object)) return data;
|
|
536
|
+
return Object.entries(data).sort((a, b) => a[0].localeCompare(b[0])).map(([key, value]) => [key, getComparationStructure(data[key])]);
|
|
537
|
+
};
|
|
538
|
+
const structureForComparingOfFirst = getComparationStructure(first);
|
|
539
|
+
const structureForComparingOfSecond = getComparationStructure(second);
|
|
540
|
+
return JSON.stringify(structureForComparingOfFirst) === JSON.stringify(structureForComparingOfSecond);
|
|
541
|
+
};
|
|
542
|
+
var setCarretToEnd = (input) => {
|
|
543
|
+
setTimeout(() => {
|
|
544
|
+
const tmp = input.value;
|
|
545
|
+
input.value = "";
|
|
546
|
+
input.value = tmp;
|
|
547
|
+
}, 10);
|
|
548
|
+
};
|
|
549
|
+
var compareAlphabetical = (a, b, key = "label") => {
|
|
550
|
+
let item1 = a?.[key];
|
|
551
|
+
let item2 = b?.[key];
|
|
552
|
+
if (typeof item1 !== "string" || typeof item2 !== "string") return 0;
|
|
553
|
+
item1 = item1?.toLowerCase();
|
|
554
|
+
item2 = item2?.toLowerCase();
|
|
555
|
+
if (item1 < item2) {
|
|
556
|
+
return -1;
|
|
557
|
+
}
|
|
558
|
+
if (item1 > item2) {
|
|
559
|
+
return 1;
|
|
560
|
+
}
|
|
561
|
+
return 0;
|
|
562
|
+
};
|
|
563
|
+
var getBase64 = (file) => {
|
|
564
|
+
if (file) {
|
|
565
|
+
return new Promise(function(resolve, reject) {
|
|
566
|
+
const reader = new FileReader();
|
|
567
|
+
reader.readAsDataURL(file);
|
|
568
|
+
reader.onload = () => resolve(reader.result);
|
|
569
|
+
reader.onerror = (error) => reject("Error: ", error);
|
|
570
|
+
});
|
|
571
|
+
}
|
|
572
|
+
};
|
|
573
|
+
var renderFileSize = (bytes, decimals = 2) => {
|
|
574
|
+
if (!Number(bytes)) return "0 Bytes";
|
|
575
|
+
const k = 1024;
|
|
576
|
+
const dm = decimals < 0 ? 0 : decimals;
|
|
577
|
+
const sizes = ["Bytes", "KB", "MB", "GB"];
|
|
578
|
+
const i = Math.floor(Math.log(bytes) / Math.log(k));
|
|
579
|
+
return `${parseFloat((bytes / Math.pow(k, i)).toFixed(dm))} ${sizes[i]}`;
|
|
580
|
+
};
|
|
581
|
+
var getUniqueFileExtensions = (extListString) => {
|
|
582
|
+
const extArray = extListString?.split(",").map((ext) => ext.trim().toUpperCase());
|
|
583
|
+
const uniqueExts = [...new Set(extArray)];
|
|
584
|
+
return uniqueExts.join(", ");
|
|
585
|
+
};
|
|
586
|
+
var getOS = () => {
|
|
587
|
+
let userAgent = window.navigator.userAgent, platform = window.navigator?.userAgentData?.platform || window.navigator.platform, macosPlatforms = ["Macintosh", "MacIntel", "MacPPC", "Mac68K"], windowsPlatforms = ["Win32", "Win64", "Windows", "WinCE"], iosPlatforms = ["iPhone", "iPad", "iPod"], os = OS.Unknown;
|
|
588
|
+
if (macosPlatforms.indexOf(platform) !== -1) {
|
|
589
|
+
os = OS.MacOS;
|
|
590
|
+
} else if (iosPlatforms.indexOf(platform) !== -1) {
|
|
591
|
+
os = OS.iOS;
|
|
592
|
+
} else if (windowsPlatforms.indexOf(platform) !== -1) {
|
|
593
|
+
os = OS.Windows;
|
|
594
|
+
} else if (/Android/.test(userAgent)) {
|
|
595
|
+
os = OS.Android;
|
|
596
|
+
} else if (/Linux/.test(platform)) {
|
|
597
|
+
os = OS.Linux;
|
|
598
|
+
}
|
|
599
|
+
return os;
|
|
600
|
+
};
|
|
601
|
+
String.prototype.longerThan = function(compareWith) {
|
|
602
|
+
return this?.length > compareWith?.length;
|
|
603
|
+
};
|
|
604
|
+
String.prototype.lastIndexEqualsTo = function(index) {
|
|
605
|
+
return this?.length - 1 === index;
|
|
606
|
+
};
|
|
607
|
+
var getCorrectTestId = ({ testId = "", withTier = true }) => testId && testId !== void 0 ? `${withTier ? "-" : ""}${testId}` : "";
|
|
608
|
+
|
|
609
|
+
// src/Functions/fieldValueFormatters.js
|
|
610
|
+
var getSafelyValue = (value) => value !== void 0 && value !== null ? value?.toString?.() || "" : "";
|
|
611
|
+
var intlNumbersFormatter = (inputValue, settings = {}) => {
|
|
612
|
+
const safelyInputValue = getSafelyValue(inputValue);
|
|
613
|
+
const previousValue = safelyInputValue.slice(0, -1);
|
|
614
|
+
const lastSym = safelyInputValue.slice(-1);
|
|
615
|
+
const value = lastSym === "." ? previousValue : safelyInputValue;
|
|
616
|
+
if (Number.isNaN(Number(value)) || !getSafelyValue(value)) return "";
|
|
617
|
+
const {
|
|
618
|
+
// локаль, даже региональная, влияет на отображение знаков и формата.
|
|
619
|
+
locale = "en-US",
|
|
620
|
+
// percent || currency(default case) || decimal(просто число) влияет на ТИП обработки.
|
|
621
|
+
withSymbol,
|
|
622
|
+
//группировка запятыми поразрядно.
|
|
623
|
+
useGrouping = true,
|
|
624
|
+
//!!работает только при withSymbol: 'currency' !! влияет на то, как именно будет выглядет формат валюты.
|
|
625
|
+
currency = {},
|
|
626
|
+
//сколько знаков после точки, и всегда ли они будут.
|
|
627
|
+
// !!если поставить isAlwaysRender: true, но не дать центов, то будет 100.00
|
|
628
|
+
fractionDigits = {}
|
|
629
|
+
} = settings;
|
|
630
|
+
const { currencyType = "USD", currencyDisplay: inputCurrencyDisplay } = currency;
|
|
631
|
+
let currencyDisplay;
|
|
632
|
+
switch (inputCurrencyDisplay) {
|
|
633
|
+
case "name":
|
|
634
|
+
currencyDisplay = "name";
|
|
635
|
+
break;
|
|
636
|
+
case "code":
|
|
637
|
+
currencyDisplay = "code";
|
|
638
|
+
break;
|
|
639
|
+
case "narrowSymbol":
|
|
640
|
+
currencyDisplay = "narrowSymbol";
|
|
641
|
+
break;
|
|
642
|
+
default:
|
|
643
|
+
currencyDisplay = "symbol";
|
|
644
|
+
}
|
|
645
|
+
let numberStyle;
|
|
646
|
+
switch (withSymbol) {
|
|
647
|
+
case "percent":
|
|
648
|
+
numberStyle = "percent";
|
|
649
|
+
break;
|
|
650
|
+
case "currency":
|
|
651
|
+
numberStyle = "currency";
|
|
652
|
+
break;
|
|
653
|
+
default:
|
|
654
|
+
numberStyle = "decimal";
|
|
655
|
+
break;
|
|
656
|
+
}
|
|
657
|
+
const {
|
|
658
|
+
quantity,
|
|
659
|
+
isRenderAlways = false,
|
|
660
|
+
minimumFractionDigits: inputMinimumFractionDigits,
|
|
661
|
+
maximumFractionDigits: inputMaximumFractionDigits,
|
|
662
|
+
conditionallyMinimumFractionDigits
|
|
663
|
+
} = fractionDigits;
|
|
664
|
+
const dotIndex = safelyInputValue?.indexOf(".");
|
|
665
|
+
const afterDot = dotIndex !== -1 ? safelyInputValue.slice(dotIndex + 1) : "";
|
|
666
|
+
const minimumFractionDigits = (() => {
|
|
667
|
+
if (typeof inputMinimumFractionDigits === "number")
|
|
668
|
+
return inputMinimumFractionDigits;
|
|
669
|
+
if (typeof conditionallyMinimumFractionDigits === "number") {
|
|
670
|
+
return afterDot && lastSym !== "." ? conditionallyMinimumFractionDigits : 0;
|
|
671
|
+
}
|
|
672
|
+
return afterDot && lastSym !== "." ? safelyInputValue.slice(dotIndex).length - 1 : isRenderAlways ? quantity : 0;
|
|
673
|
+
})();
|
|
674
|
+
const priceSettings = {
|
|
675
|
+
useGrouping,
|
|
676
|
+
//группировка разрядов
|
|
677
|
+
style: numberStyle,
|
|
678
|
+
//тип форматирования (валюта или число). decimal - без знака валюты
|
|
679
|
+
currency: currencyType,
|
|
680
|
+
//валюта
|
|
681
|
+
currencyDisplay,
|
|
682
|
+
//валюта в виде символа
|
|
683
|
+
//минимально не надо отображать центы, если их нет, иначе всегда будет .00
|
|
684
|
+
minimumFractionDigits,
|
|
685
|
+
//! Важно! Если придет велью с количеством дробных разрядов БОЛЬШИМ
|
|
686
|
+
//! чем указано в (inputMaximumFractionDigits ?? quantity) - округлит по правилам округления
|
|
687
|
+
//максимально отображать 2 цифры после запятой, если центы всё же есть
|
|
688
|
+
maximumFractionDigits: inputMaximumFractionDigits ?? quantity
|
|
689
|
+
};
|
|
690
|
+
let output;
|
|
691
|
+
try {
|
|
692
|
+
output = new Intl.NumberFormat(locale, priceSettings).format(value);
|
|
693
|
+
} catch (e) {
|
|
694
|
+
output = value;
|
|
695
|
+
console.warn("Intl.NumberFormat error", e);
|
|
696
|
+
}
|
|
697
|
+
return lastSym === "." ? output + lastSym : output;
|
|
698
|
+
};
|
|
699
|
+
var formatOnlyNumbers = (value) => getSafelyValue(value).replace(/\D/g, "");
|
|
700
|
+
var formatToRemoveComa = (value) => getSafelyValue(value).replace(/,/g, "");
|
|
701
|
+
var formatToAddBitDepthPoints = (value, settings) => intlNumbersFormatter(getSafelyValue(value), {
|
|
702
|
+
fractionDigits: {
|
|
703
|
+
quantity: settings?.type === "int" ? 0 : settings?.decimalPlaces
|
|
704
|
+
}
|
|
705
|
+
});
|
|
706
|
+
var formatToPriceWithUSD = (value) => {
|
|
707
|
+
if (isNaN(Number(value))) return value;
|
|
708
|
+
return intlNumbersFormatter(getSafelyValue(value), {
|
|
709
|
+
withSymbol: "currency",
|
|
710
|
+
currency: { currencyType: "USD" },
|
|
711
|
+
fractionDigits: { quantity: 2, conditionallyMinimumFractionDigits: 2 }
|
|
712
|
+
});
|
|
713
|
+
};
|
|
714
|
+
var formatToPriceWithCurrency = (value, currencyCode, symbolPosition = "before") => {
|
|
715
|
+
if (isNaN(Number(value))) return value;
|
|
716
|
+
return intlNumbersFormatter(getSafelyValue(value), {
|
|
717
|
+
withSymbol: "currency",
|
|
718
|
+
currency: { currencyType: currencyCode },
|
|
719
|
+
fractionDigits: { quantity: 2, conditionallyMinimumFractionDigits: 2 }
|
|
720
|
+
});
|
|
721
|
+
};
|
|
722
|
+
var formatAsPercentage = (value, settings) => {
|
|
723
|
+
const {
|
|
724
|
+
isCommonPercentageSymbol = true,
|
|
725
|
+
decimalPlaces = 2,
|
|
726
|
+
beforeValueSymbol = "",
|
|
727
|
+
afterValueSymbol = "",
|
|
728
|
+
isGlueSameRangesTogether = false,
|
|
729
|
+
// ? Тут удобный ф-л, поэтому иной раз удобно обработать обычный диапазан (НЕ проценты).
|
|
730
|
+
// ? Добавил возможность выпиливать значек процентов.
|
|
731
|
+
// todo(VL) - вообще правильно заренеймить (formatAsDiapason), а добавление процентов сделать как опцию,
|
|
732
|
+
// todo(VL) - но как обычно нет времени, нужно будет перечекать по всем проектам где тянется со старым неймингом
|
|
733
|
+
isUseAsSimpleDiapason = false
|
|
734
|
+
} = getIsOnlyAnObject(settings) ? settings : {};
|
|
735
|
+
let safelyInputValue;
|
|
736
|
+
const checkValue = (value2) => getSafelyValue(value2) || "0";
|
|
737
|
+
const transform = (valueAsSting) => {
|
|
738
|
+
const processedValue = valueAsSting.replace(/,/g, ".");
|
|
739
|
+
if (Number.isNaN(Number(processedValue))) return processedValue;
|
|
740
|
+
return `${intlNumbersFormatter(getSafelyValue(Number(processedValue)), {
|
|
741
|
+
fractionDigits: {
|
|
742
|
+
quantity: decimalPlaces,
|
|
743
|
+
minimumFractionDigits: decimalPlaces
|
|
744
|
+
}
|
|
745
|
+
})}`;
|
|
746
|
+
};
|
|
747
|
+
if (getIsOnlyAnObject(value)) {
|
|
748
|
+
safelyInputValue = {
|
|
749
|
+
from: checkValue(value.from),
|
|
750
|
+
to: checkValue(value.to)
|
|
751
|
+
};
|
|
752
|
+
} else {
|
|
753
|
+
safelyInputValue = checkValue(value);
|
|
754
|
+
if (safelyInputValue.includes(" - ")) {
|
|
755
|
+
const valuesArr = safelyInputValue.split(" - ").map((partOfValue) => partOfValue.trim());
|
|
756
|
+
safelyInputValue = {
|
|
757
|
+
from: checkValue(valuesArr[0]),
|
|
758
|
+
to: checkValue(valuesArr[1])
|
|
759
|
+
};
|
|
760
|
+
} else {
|
|
761
|
+
return `${beforeValueSymbol}${transform(safelyInputValue)}${afterValueSymbol}${isUseAsSimpleDiapason ? "" : "%"}`;
|
|
762
|
+
}
|
|
763
|
+
}
|
|
764
|
+
if (safelyInputValue.from === safelyInputValue.to && !!isGlueSameRangesTogether) {
|
|
765
|
+
return `${beforeValueSymbol}${transform(safelyInputValue.from)}${afterValueSymbol}${isUseAsSimpleDiapason ? "" : "%"}`;
|
|
766
|
+
}
|
|
767
|
+
if (isCommonPercentageSymbol)
|
|
768
|
+
return `${beforeValueSymbol}${transform(safelyInputValue.from)} - ${transform(
|
|
769
|
+
safelyInputValue.to
|
|
770
|
+
)}${afterValueSymbol}${isUseAsSimpleDiapason ? "" : "%"}`;
|
|
771
|
+
else
|
|
772
|
+
return `${beforeValueSymbol}${transform(safelyInputValue.from)}${isUseAsSimpleDiapason ? "" : "%"} - ${transform(
|
|
773
|
+
safelyInputValue.to
|
|
774
|
+
)}${isUseAsSimpleDiapason ? "" : "%"}${afterValueSymbol}`;
|
|
775
|
+
};
|
|
776
|
+
var formatToOnlyASCIICodeText = (text) => getSafelyValue(text).replace(/[^\x00-\x7F]+/g, "");
|
|
777
|
+
var formatNumberValueToMask = (inputValue, settings) => {
|
|
778
|
+
const safelyInputValue = getSafelyValue(inputValue);
|
|
779
|
+
const {
|
|
780
|
+
mask = "XXX-XXX-XXXX",
|
|
781
|
+
valueSymbol = "X",
|
|
782
|
+
isReturnAdvanced = false
|
|
783
|
+
} = settings || {};
|
|
784
|
+
const processing = mask.split("").reduce(
|
|
785
|
+
(acc, item) => {
|
|
786
|
+
if (acc.value.length) ++acc.cursorPosition;
|
|
787
|
+
acc.newValue.push(
|
|
788
|
+
item === valueSymbol && acc.value.length ? acc.value.shift() : item
|
|
789
|
+
);
|
|
790
|
+
return acc;
|
|
791
|
+
},
|
|
792
|
+
{
|
|
793
|
+
value: safelyInputValue.split("").filter((sym) => /[0-9]/g.test(sym)),
|
|
794
|
+
newValue: [],
|
|
795
|
+
cursorPosition: 0
|
|
796
|
+
}
|
|
797
|
+
);
|
|
798
|
+
return isReturnAdvanced ? {
|
|
799
|
+
value: processing.newValue.join(""),
|
|
800
|
+
cursorPosition: processing.cursorPosition
|
|
801
|
+
} : processing.newValue.join("");
|
|
802
|
+
};
|
|
803
|
+
var formatToLimitLength = (inputValue, limit) => {
|
|
804
|
+
const value = getSafelyValue(inputValue);
|
|
805
|
+
return limit && typeof limit === "number" && !Number.isNaN(limit) && value?.length > limit ? value.substr(0, limit) : value;
|
|
806
|
+
};
|
|
807
|
+
var formatToHex = ({ inputValue, withSharp }) => {
|
|
808
|
+
const value = getSafelyValue(inputValue);
|
|
809
|
+
if (withSharp) return `#${value.replace(/[^a-f0-9]/gi, "")}`;
|
|
810
|
+
return `${value.replace(/[^#a-f0-9]/gi, "")}`;
|
|
811
|
+
};
|
|
812
|
+
function formatToReplaceAllWhiteSpace(str) {
|
|
813
|
+
const value = getSafelyValue(str);
|
|
814
|
+
return value.replace(/\s+/g, "");
|
|
815
|
+
}
|
|
816
|
+
var filterFloat = (inputValue, decimalPlaces) => {
|
|
817
|
+
const replaser = (input) => ("" + input).replace(/[^\.\d]/g, "");
|
|
818
|
+
const value = getSafelyValue(inputValue);
|
|
819
|
+
const safelyDecimalPlaces = (() => {
|
|
820
|
+
if (decimalPlaces === null) return decimalPlaces;
|
|
821
|
+
const DEFAULT_VALUE = 2;
|
|
822
|
+
const isNumber = typeof decimalPlaces === "number" || typeof decimalPlaces === "string" && !Number.isNaN(+decimalPlaces);
|
|
823
|
+
return isNumber ? Number((+decimalPlaces).toFixed()) : DEFAULT_VALUE;
|
|
824
|
+
})();
|
|
825
|
+
if (value.length === 1 && (value[0] === "." || value[0] === ",")) return "0.";
|
|
826
|
+
let output = ("" + value)?.replace(/,/g, ".");
|
|
827
|
+
if (value.length > 1 && value[0] === "0" && value[1] !== "." && value[0] !== ",") output = value.slice(1);
|
|
828
|
+
const previousValue = "" + output.slice(0, -1);
|
|
829
|
+
const lastSym = "" + output.slice(-1);
|
|
830
|
+
if (lastSym === "." && previousValue.includes(".")) output = previousValue;
|
|
831
|
+
if (typeof safelyDecimalPlaces === "number") {
|
|
832
|
+
if (!safelyDecimalPlaces && lastSym === ".") return replaser(previousValue);
|
|
833
|
+
if (previousValue.includes(".") && previousValue.indexOf(".") + 1 + safelyDecimalPlaces === previousValue?.length) {
|
|
834
|
+
return replaser(previousValue);
|
|
835
|
+
}
|
|
836
|
+
}
|
|
837
|
+
return replaser(output);
|
|
838
|
+
};
|
|
839
|
+
var filterNumeric = (value, settings) => {
|
|
840
|
+
value = getSafelyValue(value)?.replace(/,/g, "");
|
|
841
|
+
const { type = "float", decimalPlaces } = settings || {};
|
|
842
|
+
const executor = type === "float" ? filterFloat : formatOnlyNumbers;
|
|
843
|
+
return executor(getSafelyValue(value), decimalPlaces);
|
|
844
|
+
};
|
|
845
|
+
var formatToHideValuePartially = (value, settings) => {
|
|
846
|
+
const {
|
|
847
|
+
showSymbolsCount = 4,
|
|
848
|
+
isVisibleFromFront = false,
|
|
849
|
+
isCutOutWhiteSpaces = true
|
|
850
|
+
} = settings || {};
|
|
851
|
+
const safelyValue = getSafelyValue(value);
|
|
852
|
+
const newValue = isCutOutWhiteSpaces ? safelyValue.replace(/\s/g, "") : safelyValue;
|
|
853
|
+
if (newValue.length <= showSymbolsCount) return newValue;
|
|
854
|
+
const hide = (val) => val.split("").map(() => "*").join("");
|
|
855
|
+
const visiblePart = isVisibleFromFront ? newValue.slice(0, showSymbolsCount) : newValue.slice(-1 * showSymbolsCount);
|
|
856
|
+
const hiddenPart = isVisibleFromFront ? newValue.slice(showSymbolsCount) : newValue.slice(0, -1 * showSymbolsCount);
|
|
857
|
+
return isVisibleFromFront ? `${visiblePart}${hide(hiddenPart)}` : `${hide(hiddenPart)}${visiblePart}`;
|
|
858
|
+
};
|
|
859
|
+
|
|
860
|
+
// src/Functions/hooks/useFormFieldsChangesManager.js
|
|
861
|
+
import React, { useEffect as useEffect2, useState } from "react";
|
|
862
|
+
var timeouts = { timeoutId: null };
|
|
863
|
+
var formChanges = [];
|
|
864
|
+
var DELAY_TIME = 1;
|
|
865
|
+
function useFormFieldsChangesManager({ form, setForm, callback, validateField, settings }) {
|
|
866
|
+
const { isNotSetForm, isUseValidation = false } = settings || {};
|
|
867
|
+
const [isFormMustBeChanget, setIsFormMustBeChanget] = useState(false);
|
|
868
|
+
const startChangesProcessing = () => {
|
|
869
|
+
if (isFormMustBeChanget) return;
|
|
870
|
+
setIsFormMustBeChanget(true);
|
|
871
|
+
};
|
|
872
|
+
const assignChangesToField = /* @__PURE__ */ (() => {
|
|
873
|
+
return (data, key, settings2) => {
|
|
874
|
+
clearTimeout(timeouts.timeoutId);
|
|
875
|
+
if (getIsOnlyAnObject(data) || typeof data === "function") {
|
|
876
|
+
formChanges.push({ key, data, settings: settings2 });
|
|
877
|
+
}
|
|
878
|
+
setIsFormMustBeChanget(false);
|
|
879
|
+
timeouts.timeoutId = setTimeout(() => setIsFormMustBeChanget(true), DELAY_TIME);
|
|
880
|
+
return clone(formChanges);
|
|
881
|
+
};
|
|
882
|
+
})();
|
|
883
|
+
const addChangesToField = (field, data, currentForm, currentChangesSettings) => {
|
|
884
|
+
const changesDataSafely = (() => {
|
|
885
|
+
if (typeof data === "function") return data(field, currentForm, currentChangesSettings);
|
|
886
|
+
return getIsOnlyAnObject(data) ? data : {};
|
|
887
|
+
})();
|
|
888
|
+
const { error } = changesDataSafely;
|
|
889
|
+
return { newField: { ...field, ...changesDataSafely }, ...error !== void 0 ? { error } : {} };
|
|
890
|
+
};
|
|
891
|
+
const changeForm = async () => {
|
|
892
|
+
let modifiedFormFromOutside;
|
|
893
|
+
const errorsFromChanges = {};
|
|
894
|
+
const newForm = formChanges.reduce((acc, changesItem) => {
|
|
895
|
+
const { data, key, settings: settings2 } = changesItem;
|
|
896
|
+
const field = acc.find((field2) => field2.key === key);
|
|
897
|
+
if (field) {
|
|
898
|
+
acc = acc.map((field2) => {
|
|
899
|
+
if (field2.key !== key) return field2;
|
|
900
|
+
const { newField, error } = addChangesToField(field2, data, acc, settings2);
|
|
901
|
+
if (error || error !== void 0) errorsFromChanges[key] = error;
|
|
902
|
+
return newField;
|
|
903
|
+
});
|
|
904
|
+
}
|
|
905
|
+
return acc;
|
|
906
|
+
}, form);
|
|
907
|
+
const validatedForm = isUseValidation && typeof validateField === "function" ? newForm.map((field) => ({
|
|
908
|
+
...field,
|
|
909
|
+
error: (() => {
|
|
910
|
+
let output = "";
|
|
911
|
+
const validateFieldResult = validateField({ ...field }, newForm);
|
|
912
|
+
if (validateFieldResult?.field?.error !== void 0) output = validateFieldResult.field.error;
|
|
913
|
+
else if (errorsFromChanges[field.key] !== void 0) output = errorsFromChanges[field.key];
|
|
914
|
+
return output;
|
|
915
|
+
})()
|
|
916
|
+
})) : newForm;
|
|
917
|
+
if (callback && typeof callback === "function") modifiedFormFromOutside = await callback(validatedForm);
|
|
918
|
+
if (!isNotSetForm) await setForm(modifiedFormFromOutside ?? validatedForm);
|
|
919
|
+
formChanges.length = 0;
|
|
920
|
+
setIsFormMustBeChanget(false);
|
|
921
|
+
};
|
|
922
|
+
useEffect2(() => {
|
|
923
|
+
if (isFormMustBeChanget) changeForm();
|
|
924
|
+
}, [isFormMustBeChanget]);
|
|
925
|
+
return {
|
|
926
|
+
assignChangesToField,
|
|
927
|
+
// метод установки отложенных изменений
|
|
928
|
+
isFormMustBeChanget,
|
|
929
|
+
// флаг сработки непосредственных мутаций формы
|
|
930
|
+
// метод принудительной установки флага сработки непосредственных мутаций формы
|
|
931
|
+
// работает только на включения, НЕ включает, если уже отрабатывает применение
|
|
932
|
+
startChangesProcessing,
|
|
933
|
+
// todo(vl) - deprecated, но пока не выпиливаю, не проверил используется ли на проектах
|
|
934
|
+
setIsFormMustBeChanget: startChangesProcessing,
|
|
935
|
+
// метод принудительной установки флага сработки непосредственных мутаций формы
|
|
936
|
+
changesArray: clone(formChanges),
|
|
937
|
+
// теккущее состояние массива изменений
|
|
938
|
+
// Константа (на чтение) задержки, которая выжидается между назначениями,
|
|
939
|
+
// после которой отрабатывает установка накопившихся изменений в форму
|
|
940
|
+
DELAY_TIME
|
|
941
|
+
};
|
|
942
|
+
}
|
|
943
|
+
var useFormFieldsChangesManager_default = useFormFieldsChangesManager;
|
|
944
|
+
|
|
945
|
+
// src/Functions/locale/createTranslator.js
|
|
946
|
+
var DEFAULT_CODE = "en";
|
|
947
|
+
function createTranslator({ ...langCatalogs }) {
|
|
948
|
+
const loc = {
|
|
949
|
+
...langCatalogs
|
|
950
|
+
};
|
|
951
|
+
let code = window.localStorage.getItem("lng");
|
|
952
|
+
if (!code)
|
|
953
|
+
code = window.navigator ? window.navigator.language.split("-")[0] : DEFAULT_CODE;
|
|
954
|
+
if (!loc[code]) code = DEFAULT_CODE;
|
|
955
|
+
return function(text, values) {
|
|
956
|
+
const safelyValues = values ?? {};
|
|
957
|
+
const safelyText = getSafelyValue(text);
|
|
958
|
+
let translatedText = loc[code] && loc[code][safelyText] ? loc[code][safelyText] : safelyText;
|
|
959
|
+
if (Object?.keys(safelyValues)?.length) {
|
|
960
|
+
for (const key in values) {
|
|
961
|
+
const regex = new RegExp(`%${key}%`, "g");
|
|
962
|
+
translatedText = translatedText?.replace(regex, values[key]);
|
|
963
|
+
}
|
|
964
|
+
}
|
|
965
|
+
return translatedText;
|
|
966
|
+
};
|
|
967
|
+
}
|
|
968
|
+
|
|
969
|
+
// src/Functions/operations.js
|
|
970
|
+
(function() {
|
|
971
|
+
function decimalAdjust(type, value, exp) {
|
|
972
|
+
if (typeof exp === "undefined" || Number(exp) === 0) {
|
|
973
|
+
return Math[type](value);
|
|
974
|
+
}
|
|
975
|
+
value = Number(value);
|
|
976
|
+
exp = Number(exp);
|
|
977
|
+
if (isNaN(value) || !(typeof exp === "number" && exp % 1 === 0)) {
|
|
978
|
+
return NaN;
|
|
979
|
+
}
|
|
980
|
+
value = value.toString().split("e");
|
|
981
|
+
value = Math[type](
|
|
982
|
+
Number(value[0] + "e" + (value[1] ? Number(value[1]) - exp : -exp))
|
|
983
|
+
);
|
|
984
|
+
value = value.toString().split("e");
|
|
985
|
+
return Number(value[0] + "e" + (value[1] ? Number(value[1]) + exp : exp));
|
|
986
|
+
}
|
|
987
|
+
if (!Math.round10) {
|
|
988
|
+
Math.round10 = function(value, exp) {
|
|
989
|
+
return decimalAdjust("round", value, exp);
|
|
990
|
+
};
|
|
991
|
+
}
|
|
992
|
+
if (!Math.floor10) {
|
|
993
|
+
Math.floor10 = function(value, exp) {
|
|
994
|
+
return decimalAdjust("floor", value, exp);
|
|
995
|
+
};
|
|
996
|
+
}
|
|
997
|
+
if (!Math.ceil10) {
|
|
998
|
+
Math.ceil10 = function(value, exp) {
|
|
999
|
+
return decimalAdjust("ceil", value, exp);
|
|
1000
|
+
};
|
|
1001
|
+
}
|
|
1002
|
+
})();
|
|
1003
|
+
var addRangeDefault = (from, to, currentValues, decimalPlaces) => {
|
|
1004
|
+
if (!currentValues?.length) return [{ from, to }];
|
|
1005
|
+
const step = decimalPlaces ? Math.pow(10, -1 * decimalPlaces) : 1;
|
|
1006
|
+
const resultOfProcessAddingRange = currentValues.reduce(
|
|
1007
|
+
(acc, range) => {
|
|
1008
|
+
const isIncludesFrom = Boolean(acc.from) && range.from < acc.from && range.to >= acc.from;
|
|
1009
|
+
const isIncludesTo = Boolean(acc.to) && range.from <= acc.to && range.to > acc.to;
|
|
1010
|
+
const isRangeMustBeIncludet = Boolean(acc.from) && Boolean(acc.to) && acc.from <= range.from && acc.to >= range.to;
|
|
1011
|
+
const processTo = () => {
|
|
1012
|
+
const lastAccRange = acc.result[acc.result.length - 1];
|
|
1013
|
+
if (acc.to < range.from) {
|
|
1014
|
+
lastAccRange.to = acc.to;
|
|
1015
|
+
acc.to = null;
|
|
1016
|
+
acc.result = [...acc.result, range];
|
|
1017
|
+
} else if (isIncludesTo) {
|
|
1018
|
+
lastAccRange.to = acc.to;
|
|
1019
|
+
acc.result = [
|
|
1020
|
+
...acc.result,
|
|
1021
|
+
{
|
|
1022
|
+
from: Math.round10(acc.to + step, -1 * decimalPlaces),
|
|
1023
|
+
to: range.to
|
|
1024
|
+
}
|
|
1025
|
+
];
|
|
1026
|
+
acc.to = null;
|
|
1027
|
+
} else if (acc.to === range.to) {
|
|
1028
|
+
lastAccRange.to = acc.to;
|
|
1029
|
+
acc.to = null;
|
|
1030
|
+
}
|
|
1031
|
+
};
|
|
1032
|
+
if (!acc.from && !acc.to) acc.result = [...acc.result, range];
|
|
1033
|
+
else if (!acc.from && acc.to) processTo();
|
|
1034
|
+
else if (acc.from && acc.to) {
|
|
1035
|
+
if (acc.from <= range.from) {
|
|
1036
|
+
acc.result = [...acc.result, { from: acc.from }];
|
|
1037
|
+
acc.from = null;
|
|
1038
|
+
processTo();
|
|
1039
|
+
} else if (isIncludesFrom) {
|
|
1040
|
+
acc.result = [
|
|
1041
|
+
...acc.result,
|
|
1042
|
+
{
|
|
1043
|
+
from: range.from,
|
|
1044
|
+
to: Math.round10(acc.from - step, -1 * decimalPlaces)
|
|
1045
|
+
},
|
|
1046
|
+
{ from: acc.from }
|
|
1047
|
+
];
|
|
1048
|
+
acc.from = null;
|
|
1049
|
+
processTo();
|
|
1050
|
+
} else {
|
|
1051
|
+
acc.result = [
|
|
1052
|
+
...acc.result,
|
|
1053
|
+
...!isRangeMustBeIncludet ? [range] : [],
|
|
1054
|
+
{
|
|
1055
|
+
from: Math.round10(acc.from, -1 * decimalPlaces),
|
|
1056
|
+
to: Math.round10(acc.to, -1 * decimalPlaces)
|
|
1057
|
+
}
|
|
1058
|
+
];
|
|
1059
|
+
}
|
|
1060
|
+
}
|
|
1061
|
+
return acc;
|
|
1062
|
+
},
|
|
1063
|
+
{ from, to, result: [] }
|
|
1064
|
+
);
|
|
1065
|
+
const result = resultOfProcessAddingRange.result;
|
|
1066
|
+
if (!result[result.length - 1].to) result[result.length - 1].to = to;
|
|
1067
|
+
return result;
|
|
1068
|
+
};
|
|
1069
|
+
|
|
1070
|
+
// src/Functions/Portal.js
|
|
1071
|
+
import React2, { useEffect as useEffect3, useState as useState2 } from "react";
|
|
1072
|
+
import ReactDOM from "react-dom";
|
|
1073
|
+
var Portal = ({ children, parentSelector }) => {
|
|
1074
|
+
const [container] = useState2(() => document.createElement("div"));
|
|
1075
|
+
useEffect3(() => {
|
|
1076
|
+
let parent;
|
|
1077
|
+
if (parentSelector) parent = document.querySelector(parentSelector);
|
|
1078
|
+
else parent = document.body;
|
|
1079
|
+
parent?.appendChild(container);
|
|
1080
|
+
return () => {
|
|
1081
|
+
parent?.removeChild(container);
|
|
1082
|
+
};
|
|
1083
|
+
}, []);
|
|
1084
|
+
return ReactDOM.createPortal(children, container);
|
|
1085
|
+
};
|
|
1086
|
+
var Portal_default = React2.memo(Portal);
|
|
1087
|
+
|
|
1088
|
+
// src/Functions/useBodyScrollLock.js
|
|
1089
|
+
import { useEffect as useEffect4 } from "react";
|
|
1090
|
+
var useBodyScrollLock = (isScrollBodyLocked) => {
|
|
1091
|
+
useEffect4(() => {
|
|
1092
|
+
if (isScrollBodyLocked) {
|
|
1093
|
+
document.body.style.overflow = "hidden";
|
|
1094
|
+
} else {
|
|
1095
|
+
document.body.style.overflow = "auto";
|
|
1096
|
+
}
|
|
1097
|
+
return () => {
|
|
1098
|
+
document.body.style.overflow = "auto";
|
|
1099
|
+
};
|
|
1100
|
+
}, [isScrollBodyLocked]);
|
|
1101
|
+
};
|
|
1102
|
+
var useBodyScrollLock_default = useBodyScrollLock;
|
|
1103
|
+
|
|
1104
|
+
// src/Functions/useClickOutside.js
|
|
1105
|
+
import { useEffect as useEffect5 } from "react";
|
|
1106
|
+
var useClickOutside = (ref, setOut, open) => {
|
|
1107
|
+
function handleClickOutside(event) {
|
|
1108
|
+
if (ref.current && !ref.current.contains(event.target)) {
|
|
1109
|
+
setOut(open);
|
|
1110
|
+
}
|
|
1111
|
+
}
|
|
1112
|
+
useEffect5(() => {
|
|
1113
|
+
document.addEventListener("mousedown", handleClickOutside);
|
|
1114
|
+
return () => {
|
|
1115
|
+
document.removeEventListener("mousedown", handleClickOutside);
|
|
1116
|
+
};
|
|
1117
|
+
}, [ref]);
|
|
1118
|
+
};
|
|
1119
|
+
|
|
1120
|
+
// src/Functions/useDebounce.js
|
|
1121
|
+
import React3, { useEffect as useEffect6, useState as useState3 } from "react";
|
|
1122
|
+
var useDebounce = ({ searchValue, delay }) => {
|
|
1123
|
+
const [debouncedValue, setDebouncedValue] = useState3(searchValue);
|
|
1124
|
+
useEffect6(() => {
|
|
1125
|
+
const handler = setTimeout(() => {
|
|
1126
|
+
setDebouncedValue(searchValue);
|
|
1127
|
+
}, delay);
|
|
1128
|
+
return () => {
|
|
1129
|
+
clearTimeout(handler);
|
|
1130
|
+
};
|
|
1131
|
+
}, [searchValue, delay]);
|
|
1132
|
+
return debouncedValue;
|
|
1133
|
+
};
|
|
1134
|
+
|
|
1135
|
+
// src/Functions/useFieldFocus.js
|
|
1136
|
+
import { createRef, useEffect as useEffect7 } from "react";
|
|
1137
|
+
function useFieldsFocus({ form, setForm }) {
|
|
1138
|
+
const isFormAsObject = Boolean(
|
|
1139
|
+
typeof form === "object" && !Array.isArray(form)
|
|
1140
|
+
);
|
|
1141
|
+
const getField = (key) => {
|
|
1142
|
+
if (isFormAsObject) {
|
|
1143
|
+
return form?.[key] ?? Object.values(form)?.find((field) => field.key === key);
|
|
1144
|
+
} else {
|
|
1145
|
+
return form?.find((field) => field.key === key);
|
|
1146
|
+
}
|
|
1147
|
+
};
|
|
1148
|
+
const getErroredFields = () => {
|
|
1149
|
+
if (isFormAsObject) {
|
|
1150
|
+
return Object.values(form)?.filter((field) => field.error);
|
|
1151
|
+
} else {
|
|
1152
|
+
return form?.filter((f) => f?.error);
|
|
1153
|
+
}
|
|
1154
|
+
};
|
|
1155
|
+
const addRefsToFields = () => {
|
|
1156
|
+
if (isFormAsObject) {
|
|
1157
|
+
setForm((form2) => {
|
|
1158
|
+
return Object.keys(form2)?.reduce((result, key) => {
|
|
1159
|
+
const field = form2[key];
|
|
1160
|
+
return {
|
|
1161
|
+
...result,
|
|
1162
|
+
[key]: {
|
|
1163
|
+
...field,
|
|
1164
|
+
ref: createRef(),
|
|
1165
|
+
wrapperRef: createRef()
|
|
1166
|
+
}
|
|
1167
|
+
};
|
|
1168
|
+
}, {});
|
|
1169
|
+
});
|
|
1170
|
+
} else {
|
|
1171
|
+
setForm((form2) => {
|
|
1172
|
+
return form2?.map((field) => {
|
|
1173
|
+
field.ref = createRef();
|
|
1174
|
+
field.wrapperRef = createRef();
|
|
1175
|
+
return field;
|
|
1176
|
+
});
|
|
1177
|
+
});
|
|
1178
|
+
}
|
|
1179
|
+
};
|
|
1180
|
+
const toggleFieldFocus = ({ field, action = "focus" }) => {
|
|
1181
|
+
if (!field || !field?.ref) return null;
|
|
1182
|
+
setTimeout(() => {
|
|
1183
|
+
field.ref.current?.querySelector(field?.focusSelector || "input")?.[action]();
|
|
1184
|
+
}, 50);
|
|
1185
|
+
};
|
|
1186
|
+
const setFocusTo = (key) => {
|
|
1187
|
+
const field = getField(key);
|
|
1188
|
+
if (!field) return false;
|
|
1189
|
+
toggleFieldFocus({ field });
|
|
1190
|
+
};
|
|
1191
|
+
const setFocusToErroredField = () => {
|
|
1192
|
+
const field = getErroredFields()?.[0];
|
|
1193
|
+
if (!field) return false;
|
|
1194
|
+
toggleFieldFocus({ field });
|
|
1195
|
+
};
|
|
1196
|
+
useEffect7(() => {
|
|
1197
|
+
addRefsToFields();
|
|
1198
|
+
}, [form?.length]);
|
|
1199
|
+
return {
|
|
1200
|
+
setFocusTo,
|
|
1201
|
+
setFocusToErroredField
|
|
1202
|
+
};
|
|
1203
|
+
}
|
|
1204
|
+
|
|
1205
|
+
// src/Functions/useFormTools/functions/General.js
|
|
1206
|
+
function General({ form, FormFields = [] } = {}) {
|
|
1207
|
+
const joinData = (...args) => {
|
|
1208
|
+
const [mainArg] = args;
|
|
1209
|
+
const MainArgProto = Array.isArray(mainArg) ? "Array" : typeof mainArg === "object" ? "Object" : void 0;
|
|
1210
|
+
const template = Array.isArray(mainArg) ? [] : typeof mainArg === "object" ? {} : null;
|
|
1211
|
+
if (!template) return void 0;
|
|
1212
|
+
return args.reduce((result, item) => {
|
|
1213
|
+
if (MainArgProto === "Array") {
|
|
1214
|
+
if (Array.isArray(item)) {
|
|
1215
|
+
return [...result, ...item];
|
|
1216
|
+
} else {
|
|
1217
|
+
return [...result, item];
|
|
1218
|
+
}
|
|
1219
|
+
} else if (MainArgProto === "Object") {
|
|
1220
|
+
return { ...result, ...item };
|
|
1221
|
+
} else {
|
|
1222
|
+
return template;
|
|
1223
|
+
}
|
|
1224
|
+
}, template);
|
|
1225
|
+
};
|
|
1226
|
+
const getFieldData = (key) => {
|
|
1227
|
+
if (Array.isArray(FormFields)) {
|
|
1228
|
+
if (FormFields[key]) {
|
|
1229
|
+
return { ...FormFields[key] };
|
|
1230
|
+
} else {
|
|
1231
|
+
return { ...FormFields.find((f) => f.key === key) };
|
|
1232
|
+
}
|
|
1233
|
+
} else if (typeof FormFields === "object") {
|
|
1234
|
+
return { ...FormFields[key] };
|
|
1235
|
+
} else {
|
|
1236
|
+
return void 0;
|
|
1237
|
+
}
|
|
1238
|
+
};
|
|
1239
|
+
const getFormFields = (argForm = form) => {
|
|
1240
|
+
return argForm?.fields || argForm;
|
|
1241
|
+
};
|
|
1242
|
+
const getFormFieldsAsArray = (fields) => {
|
|
1243
|
+
if (Array.isArray(fields)) return fields;
|
|
1244
|
+
if (typeof fields === "object") {
|
|
1245
|
+
return Object.values(fields);
|
|
1246
|
+
}
|
|
1247
|
+
return fields;
|
|
1248
|
+
};
|
|
1249
|
+
const getFormFieldsKeys = (fields = getFormFields()) => {
|
|
1250
|
+
if (Array.isArray(fields)) return fields.map(({ key }) => key);
|
|
1251
|
+
if (typeof fields === "object") {
|
|
1252
|
+
return Object.values(fields).map(({ key }) => key);
|
|
1253
|
+
}
|
|
1254
|
+
return fields;
|
|
1255
|
+
};
|
|
1256
|
+
const popFormField = (fields, key) => {
|
|
1257
|
+
const result = { item: void 0, itemIndex: void 0 };
|
|
1258
|
+
if (Array.isArray(fields)) {
|
|
1259
|
+
result.item = fields?.find((f) => f.key === key);
|
|
1260
|
+
result.itemIndex = result.item ? fields.findIndex((f) => f.key === key) : fields.length;
|
|
1261
|
+
} else if (typeof fields === "object") {
|
|
1262
|
+
result.item = fields[key] || Object.values(fields).find((f) => f.key === key);
|
|
1263
|
+
result.itemIndex = result.item ? fields[key] ? key : Object.values(fields).findIndex((f) => f.key === key) : key;
|
|
1264
|
+
}
|
|
1265
|
+
return result;
|
|
1266
|
+
};
|
|
1267
|
+
const updateFormField = (fields, data, key) => {
|
|
1268
|
+
const isFunction = typeof data === "function";
|
|
1269
|
+
if (!key) {
|
|
1270
|
+
return data.key ? Object.values(fields).reduce((result, field2, i) => {
|
|
1271
|
+
const index = fields[field2.key] ? field2.key : i;
|
|
1272
|
+
return {
|
|
1273
|
+
...result,
|
|
1274
|
+
[index]: data.key === field2.key ? isFunction ? data(field2) : data : field2
|
|
1275
|
+
};
|
|
1276
|
+
}, {}) : {
|
|
1277
|
+
...fields,
|
|
1278
|
+
[fields.length || 0]: isFunction ? data({}) : data
|
|
1279
|
+
};
|
|
1280
|
+
}
|
|
1281
|
+
const { item: field = data, itemIndex } = popFormField(fields, key);
|
|
1282
|
+
fields[itemIndex] = isFunction ? data(field || {}) : { ...field, ...data };
|
|
1283
|
+
return fields;
|
|
1284
|
+
};
|
|
1285
|
+
const getFieldClassName = (key, type) => {
|
|
1286
|
+
return `form-${type}_field-${key}`;
|
|
1287
|
+
};
|
|
1288
|
+
return {
|
|
1289
|
+
joinData,
|
|
1290
|
+
getFieldData,
|
|
1291
|
+
popFormField,
|
|
1292
|
+
updateFormField,
|
|
1293
|
+
getFormFields,
|
|
1294
|
+
getFormFieldsAsArray,
|
|
1295
|
+
getFieldClassName,
|
|
1296
|
+
getFormFieldsKeys
|
|
1297
|
+
};
|
|
1298
|
+
}
|
|
1299
|
+
|
|
1300
|
+
// src/Functions/useFormTools/form-drivers/ArrayWithObjects.js
|
|
1301
|
+
function ArrayWithObjects({ form, setForm, FormFields }) {
|
|
1302
|
+
const {
|
|
1303
|
+
joinData,
|
|
1304
|
+
getFieldData,
|
|
1305
|
+
updateFormField,
|
|
1306
|
+
getFormFields,
|
|
1307
|
+
getFormFieldsAsArray,
|
|
1308
|
+
getFormFieldsKeys
|
|
1309
|
+
} = General({
|
|
1310
|
+
FormFields
|
|
1311
|
+
});
|
|
1312
|
+
const getFormField = (key, argForm = form) => {
|
|
1313
|
+
return getFormFields(argForm)?.find((f) => f.key === key);
|
|
1314
|
+
};
|
|
1315
|
+
const setFormFields = (data) => {
|
|
1316
|
+
const isFunction = typeof data === "function";
|
|
1317
|
+
setForm((state) => isFunction ? data(state) : data);
|
|
1318
|
+
};
|
|
1319
|
+
const setFormField = (data, key = null) => setFormFields((fields) => updateFormField(fields, data, key));
|
|
1320
|
+
const removeAllFormFields = () => setFormFields([]);
|
|
1321
|
+
return {
|
|
1322
|
+
joinData,
|
|
1323
|
+
getFieldData,
|
|
1324
|
+
getFormFields,
|
|
1325
|
+
getFormField,
|
|
1326
|
+
setFormFields,
|
|
1327
|
+
setFormField,
|
|
1328
|
+
getFormFieldsAsArray: (fields) => getFormFieldsAsArray(fields || getFormFields()),
|
|
1329
|
+
getFormFieldsKeys: (fields) => getFormFieldsKeys(fields || getFormFields()),
|
|
1330
|
+
removeAllFormFields
|
|
1331
|
+
};
|
|
1332
|
+
}
|
|
1333
|
+
|
|
1334
|
+
// src/Functions/useFormTools/form-drivers/ObjectWithIterableObjects.js
|
|
1335
|
+
function ObjectWithIterableObjects({
|
|
1336
|
+
form,
|
|
1337
|
+
setForm,
|
|
1338
|
+
FormFields
|
|
1339
|
+
}) {
|
|
1340
|
+
const joinData = (...args) => {
|
|
1341
|
+
const [mainArg] = args;
|
|
1342
|
+
const MainArgProto = Array.isArray(mainArg) ? "Array" : typeof mainArg === "object" ? "Object" : void 0;
|
|
1343
|
+
const template = Array.isArray(mainArg) ? [] : typeof mainArg === "object" ? {} : null;
|
|
1344
|
+
if (!template) return void 0;
|
|
1345
|
+
return args.reduce((result, item) => {
|
|
1346
|
+
if (MainArgProto === "Array") {
|
|
1347
|
+
if (Array.isArray(item)) {
|
|
1348
|
+
return [...result, ...item];
|
|
1349
|
+
} else {
|
|
1350
|
+
return [...result, item];
|
|
1351
|
+
}
|
|
1352
|
+
} else if (MainArgProto === "Object") {
|
|
1353
|
+
return { ...result, ...item };
|
|
1354
|
+
} else {
|
|
1355
|
+
return template;
|
|
1356
|
+
}
|
|
1357
|
+
}, template);
|
|
1358
|
+
};
|
|
1359
|
+
const getFieldData = (key) => {
|
|
1360
|
+
if (Array.isArray(FormFields)) {
|
|
1361
|
+
return FormFields[key] || FormFields.find((f) => f.key === key);
|
|
1362
|
+
} else if (typeof FormFields === "object") {
|
|
1363
|
+
return FormFields[key] || Object.values(FormFields).find((f) => f.key === key);
|
|
1364
|
+
} else {
|
|
1365
|
+
return void 0;
|
|
1366
|
+
}
|
|
1367
|
+
};
|
|
1368
|
+
const getFormFields = () => {
|
|
1369
|
+
return form.fields || form;
|
|
1370
|
+
};
|
|
1371
|
+
const getFormField = (key) => {
|
|
1372
|
+
if (FormProto === "Array") {
|
|
1373
|
+
return getFormFields().find((field) => field.key === key);
|
|
1374
|
+
} else if (FormProto === "Object") {
|
|
1375
|
+
return Object.values(getFormFields()).find((field) => field.key === key) || Object.keys(getFormFields()).reduce((result, field) => {
|
|
1376
|
+
if (field === key) result = getFormFields()[field];
|
|
1377
|
+
return result;
|
|
1378
|
+
}, {});
|
|
1379
|
+
} else {
|
|
1380
|
+
return void 0;
|
|
1381
|
+
}
|
|
1382
|
+
};
|
|
1383
|
+
const setFormFields = (data) => {
|
|
1384
|
+
const isFunction = typeof data === "function";
|
|
1385
|
+
setForm((state) => {
|
|
1386
|
+
if (state.fields) {
|
|
1387
|
+
return {
|
|
1388
|
+
...state,
|
|
1389
|
+
fields: isFunction ? data(state.fields) : data
|
|
1390
|
+
};
|
|
1391
|
+
} else {
|
|
1392
|
+
return isFunction ? data(state) : data;
|
|
1393
|
+
}
|
|
1394
|
+
});
|
|
1395
|
+
};
|
|
1396
|
+
const setFormField = (data, key = null) => {
|
|
1397
|
+
const isFunction = typeof data === "function";
|
|
1398
|
+
setFormFields((fields) => {
|
|
1399
|
+
const pop = (fields2, key2) => {
|
|
1400
|
+
const result = { fields: fields2, item: void 0 };
|
|
1401
|
+
result.item = fields2[key2] || fields2.find((f) => f.key === key2);
|
|
1402
|
+
if (!result.item) return result;
|
|
1403
|
+
if (Array.isArray(fields2)) {
|
|
1404
|
+
const index = parseInt(key2, 10);
|
|
1405
|
+
if (!isNaN(index)) {
|
|
1406
|
+
result.fields.splice(key2, 1);
|
|
1407
|
+
} else {
|
|
1408
|
+
result.fields = result.fields.filter((f) => f.key !== key2);
|
|
1409
|
+
}
|
|
1410
|
+
} else if (typeof fields2 === "object") {
|
|
1411
|
+
result.fields = Object.values(fields2).reduce(
|
|
1412
|
+
(object, { key: fKey }) => {
|
|
1413
|
+
if (key2 !== fKey) {
|
|
1414
|
+
object[key2] = fields2[key2];
|
|
1415
|
+
}
|
|
1416
|
+
return object;
|
|
1417
|
+
},
|
|
1418
|
+
{}
|
|
1419
|
+
);
|
|
1420
|
+
}
|
|
1421
|
+
return result;
|
|
1422
|
+
};
|
|
1423
|
+
const update = (fields2) => {
|
|
1424
|
+
if (!key) {
|
|
1425
|
+
return data.key ? Object.values(fields2).reduce((result, field2, i) => {
|
|
1426
|
+
const index = fields2[field2.key] ? field2.key : i;
|
|
1427
|
+
return {
|
|
1428
|
+
...result,
|
|
1429
|
+
[index]: data.key === field2.key ? isFunction ? data(field2) : data : field2
|
|
1430
|
+
};
|
|
1431
|
+
}, {}) : {
|
|
1432
|
+
...fields2,
|
|
1433
|
+
[fields2.length || 0]: isFunction ? data({}) : data
|
|
1434
|
+
};
|
|
1435
|
+
}
|
|
1436
|
+
const { fields: filtered, item: field } = pop(fields2, key);
|
|
1437
|
+
const updatedField = isFunction ? data(field || {}) : { ...field, ...data };
|
|
1438
|
+
return joinData(
|
|
1439
|
+
filtered,
|
|
1440
|
+
fields2[key] ? { [key]: updatedField } : updatedField
|
|
1441
|
+
);
|
|
1442
|
+
};
|
|
1443
|
+
return update(fields);
|
|
1444
|
+
});
|
|
1445
|
+
};
|
|
1446
|
+
return {
|
|
1447
|
+
joinData,
|
|
1448
|
+
getFieldData,
|
|
1449
|
+
getFormFields,
|
|
1450
|
+
getFormField,
|
|
1451
|
+
setFormFields,
|
|
1452
|
+
setFormField
|
|
1453
|
+
};
|
|
1454
|
+
}
|
|
1455
|
+
|
|
1456
|
+
// src/Functions/useFormTools/form-drivers/ObjectWithNamedKeyObjects.js
|
|
1457
|
+
var noop = () => {
|
|
1458
|
+
};
|
|
1459
|
+
function ObjectWithNamedKeyObjects({
|
|
1460
|
+
form,
|
|
1461
|
+
setForm = noop,
|
|
1462
|
+
FormFields
|
|
1463
|
+
} = {}) {
|
|
1464
|
+
const {
|
|
1465
|
+
joinData,
|
|
1466
|
+
getFieldData,
|
|
1467
|
+
updateFormField,
|
|
1468
|
+
getFormFields,
|
|
1469
|
+
getFormFieldsAsArray,
|
|
1470
|
+
getFormFieldsKeys
|
|
1471
|
+
} = General({
|
|
1472
|
+
FormFields
|
|
1473
|
+
});
|
|
1474
|
+
const getFormField = (key, argForm = form) => {
|
|
1475
|
+
return Object.values(getFormFields(argForm))?.find(
|
|
1476
|
+
(field) => field?.key === key
|
|
1477
|
+
) || Object.keys(getFormFields(argForm))?.reduce((result, field) => {
|
|
1478
|
+
if (field === key) result = getFormFields(argForm)[field];
|
|
1479
|
+
return result;
|
|
1480
|
+
}, null);
|
|
1481
|
+
};
|
|
1482
|
+
const setFormFields = (data) => {
|
|
1483
|
+
const isFunction = typeof data === "function";
|
|
1484
|
+
setForm((state) => {
|
|
1485
|
+
if (state.fields) {
|
|
1486
|
+
return {
|
|
1487
|
+
...state,
|
|
1488
|
+
fields: isFunction ? data(state.fields) : data
|
|
1489
|
+
};
|
|
1490
|
+
} else {
|
|
1491
|
+
return isFunction ? data(state) : data;
|
|
1492
|
+
}
|
|
1493
|
+
});
|
|
1494
|
+
};
|
|
1495
|
+
const setFormField = (data, key = null) => setFormFields((fields) => updateFormField(fields, data, key));
|
|
1496
|
+
const removeAllFormFields = () => setFormFields({});
|
|
1497
|
+
const removeFormField = (key) => setFormFields(
|
|
1498
|
+
(state) => Object.keys(state).filter((fKey) => fKey !== key).reduce((obj, key2) => ({ ...obj, [key2]: state[key2] }), {})
|
|
1499
|
+
);
|
|
1500
|
+
const removeFormFields = ([...keys]) => setFormFields(
|
|
1501
|
+
(state) => Object.keys(state).filter((fKey) => !keys.includes(fKey)).reduce((obj, key) => ({ ...obj, [key]: state[key] }), {})
|
|
1502
|
+
);
|
|
1503
|
+
return {
|
|
1504
|
+
joinData,
|
|
1505
|
+
getFieldData,
|
|
1506
|
+
getFormField,
|
|
1507
|
+
setFormFields,
|
|
1508
|
+
setFormField,
|
|
1509
|
+
getFormFields: () => getFormFields(form),
|
|
1510
|
+
getFormFieldsAsArray: () => getFormFieldsAsArray(getFormFields(form)),
|
|
1511
|
+
getFormFieldsKeys: () => getFormFieldsKeys(getFormFields(form)),
|
|
1512
|
+
removeAllFormFields,
|
|
1513
|
+
removeFormField,
|
|
1514
|
+
removeFormFields
|
|
1515
|
+
};
|
|
1516
|
+
}
|
|
1517
|
+
|
|
1518
|
+
// src/Functions/useFormTools/functions/RenderFields.js
|
|
1519
|
+
import { jsx } from "react/jsx-runtime";
|
|
1520
|
+
var defaultRenderFieldComponent = () => {
|
|
1521
|
+
console.error("RenderFields: RenderFieldComponent Property is not recieved!");
|
|
1522
|
+
return null;
|
|
1523
|
+
};
|
|
1524
|
+
var defaultFormDataDriver = () => {
|
|
1525
|
+
console.error("RenderFields: FormDataDriver Property is not recieved!");
|
|
1526
|
+
return null;
|
|
1527
|
+
};
|
|
1528
|
+
var defaultOnFieldChange = () => {
|
|
1529
|
+
console.warn(
|
|
1530
|
+
"RenderFields: Be careful, onFieldChange handler is not recieved!"
|
|
1531
|
+
);
|
|
1532
|
+
return null;
|
|
1533
|
+
};
|
|
1534
|
+
var defaultOnFieldBlur = () => {
|
|
1535
|
+
console.warn(
|
|
1536
|
+
"RenderFields: Be careful, defaultOnFieldBlur handler is not recieved!"
|
|
1537
|
+
);
|
|
1538
|
+
return null;
|
|
1539
|
+
};
|
|
1540
|
+
function RenderFields({
|
|
1541
|
+
form,
|
|
1542
|
+
fields,
|
|
1543
|
+
cols = 1,
|
|
1544
|
+
FormDataDriver = defaultFormDataDriver,
|
|
1545
|
+
RenderFieldComponent = defaultRenderFieldComponent,
|
|
1546
|
+
onFieldChange = defaultOnFieldChange,
|
|
1547
|
+
onFieldBlur = defaultOnFieldBlur
|
|
1548
|
+
} = {}) {
|
|
1549
|
+
const maxColumns = 6;
|
|
1550
|
+
const maxWidth = 12;
|
|
1551
|
+
const { getFormField } = FormDataDriver({ form });
|
|
1552
|
+
const getColumnsQty = () => {
|
|
1553
|
+
return cols > maxColumns ? maxColumns : cols;
|
|
1554
|
+
};
|
|
1555
|
+
const renderFormField = (key) => {
|
|
1556
|
+
try {
|
|
1557
|
+
const field = { ...getFormField(key), key };
|
|
1558
|
+
const { wrapperRef } = field;
|
|
1559
|
+
return /* @__PURE__ */ jsx(
|
|
1560
|
+
"div",
|
|
1561
|
+
{
|
|
1562
|
+
id: `render-field-wrapper-${key}`,
|
|
1563
|
+
ref: wrapperRef ? typeof wrapperRef === "function" ? (node) => wrapperRef(node, key) : wrapperRef : null,
|
|
1564
|
+
children: /* @__PURE__ */ jsx(
|
|
1565
|
+
RenderFieldComponent,
|
|
1566
|
+
{
|
|
1567
|
+
field,
|
|
1568
|
+
onChange: (value) => onFieldChange(key, value),
|
|
1569
|
+
onBlur: (...args) => onFieldBlur(...args)
|
|
1570
|
+
},
|
|
1571
|
+
key
|
|
1572
|
+
)
|
|
1573
|
+
},
|
|
1574
|
+
`render-field-wrapper-${key}`
|
|
1575
|
+
);
|
|
1576
|
+
} catch (e) {
|
|
1577
|
+
return null;
|
|
1578
|
+
}
|
|
1579
|
+
};
|
|
1580
|
+
const renderSingleColumn = () => {
|
|
1581
|
+
return fields.map(renderFormField);
|
|
1582
|
+
};
|
|
1583
|
+
const renderSplitColumns = () => {
|
|
1584
|
+
const fieldsLen = fields?.length || 0;
|
|
1585
|
+
const columnsQty = getColumnsQty() > fieldsLen ? fieldsLen : getColumnsQty();
|
|
1586
|
+
if (!columnsQty) return null;
|
|
1587
|
+
const parts = new Array(columnsQty).fill([]).map((v, i) => {
|
|
1588
|
+
const startIndex = fieldsLen / columnsQty * i;
|
|
1589
|
+
const endIndex = startIndex + fieldsLen / columnsQty;
|
|
1590
|
+
return fields.slice(startIndex, endIndex);
|
|
1591
|
+
});
|
|
1592
|
+
return /* @__PURE__ */ jsx("div", { className: "row", children: parts.map((part, i) => /* @__PURE__ */ jsx(
|
|
1593
|
+
"div",
|
|
1594
|
+
{
|
|
1595
|
+
className: `col-12 col-lg-${parseInt(maxWidth / columnsQty, 10)}`,
|
|
1596
|
+
children: part.map(renderFormField)
|
|
1597
|
+
},
|
|
1598
|
+
`render-fields-row-${i}`
|
|
1599
|
+
)) });
|
|
1600
|
+
};
|
|
1601
|
+
const render = cols === 1 ? renderSingleColumn : renderSplitColumns;
|
|
1602
|
+
return render();
|
|
1603
|
+
}
|
|
1604
|
+
|
|
1605
|
+
// src/Functions/useFormTools/index.js
|
|
1606
|
+
import { createRef as createRef2, useEffect as useEffect8, useState as useState4 } from "react";
|
|
1607
|
+
var DefaultFocusControllerProps = {
|
|
1608
|
+
setAutoFocus: true,
|
|
1609
|
+
onlyEmptyFieldAutoFocus: false
|
|
1610
|
+
};
|
|
1611
|
+
function useFormTools({
|
|
1612
|
+
form,
|
|
1613
|
+
setForm,
|
|
1614
|
+
FormType,
|
|
1615
|
+
FormFields,
|
|
1616
|
+
FormDataDriverName = "ArrayWithObjects",
|
|
1617
|
+
FormDataDriver = null,
|
|
1618
|
+
FocusControllerProps = DefaultFocusControllerProps,
|
|
1619
|
+
goToNextFieldOnEnterPressed = true
|
|
1620
|
+
} = {}) {
|
|
1621
|
+
FocusControllerProps = {
|
|
1622
|
+
...DefaultFocusControllerProps,
|
|
1623
|
+
...FocusControllerProps
|
|
1624
|
+
};
|
|
1625
|
+
const FormDataDrivers = {
|
|
1626
|
+
ArrayWithObjects: {
|
|
1627
|
+
handlers: ArrayWithObjects,
|
|
1628
|
+
default: true
|
|
1629
|
+
},
|
|
1630
|
+
ObjectWithIterableObjects: {
|
|
1631
|
+
handlers: ObjectWithIterableObjects
|
|
1632
|
+
},
|
|
1633
|
+
ObjectWithNamedKeyObjects: {
|
|
1634
|
+
handlers: ObjectWithNamedKeyObjects
|
|
1635
|
+
}
|
|
1636
|
+
};
|
|
1637
|
+
const getFormDataDriver = (name) => {
|
|
1638
|
+
return FormDataDriver || FormDataDrivers[name]?.handlers || Object.values(FormDataDrivers).find((df) => df.default === true)?.handlers || (() => ({}));
|
|
1639
|
+
};
|
|
1640
|
+
const getFormDataDriverInstance = (name, ...args) => {
|
|
1641
|
+
return getFormDataDriver(name)(...args);
|
|
1642
|
+
};
|
|
1643
|
+
const { getFieldClassName, updateFormField } = General();
|
|
1644
|
+
const {
|
|
1645
|
+
getFieldData,
|
|
1646
|
+
getFormField,
|
|
1647
|
+
setFormFields,
|
|
1648
|
+
setFormField,
|
|
1649
|
+
getFormFieldsAsArray,
|
|
1650
|
+
getFormFieldsKeys,
|
|
1651
|
+
removeAllFormFields,
|
|
1652
|
+
removeFormField,
|
|
1653
|
+
removeFormFields
|
|
1654
|
+
} = getFormDataDriverInstance(FormDataDriverName, {
|
|
1655
|
+
form,
|
|
1656
|
+
setForm,
|
|
1657
|
+
FormFields
|
|
1658
|
+
});
|
|
1659
|
+
const [onChangeObservers, setOnChangeObservers] = useState4({});
|
|
1660
|
+
const addOnChangeObserver = (key, cb) => {
|
|
1661
|
+
let observerId = null;
|
|
1662
|
+
setOnChangeObservers((state) => {
|
|
1663
|
+
if (!state[key]) state[key] = {};
|
|
1664
|
+
observerId = state[key].length;
|
|
1665
|
+
state[key][observerId] = cb;
|
|
1666
|
+
return state;
|
|
1667
|
+
});
|
|
1668
|
+
return observerId;
|
|
1669
|
+
};
|
|
1670
|
+
const removeOnChangeObserver = (key, id) => {
|
|
1671
|
+
setOnChangeObservers((state) => {
|
|
1672
|
+
if (!state[key]) return state;
|
|
1673
|
+
state[key] = Object.keys(state).filter((cbId) => cbId !== id).map((cbId) => state[key][cbId]);
|
|
1674
|
+
return state;
|
|
1675
|
+
});
|
|
1676
|
+
};
|
|
1677
|
+
const onChangeObserver = (key, value) => {
|
|
1678
|
+
if (!onChangeObservers[key] || typeof onChangeObservers[key] !== "object")
|
|
1679
|
+
return;
|
|
1680
|
+
const Observers = onChangeObservers[key];
|
|
1681
|
+
Object.values(Observers).map((cb) => {
|
|
1682
|
+
cb({ value, form });
|
|
1683
|
+
return null;
|
|
1684
|
+
});
|
|
1685
|
+
};
|
|
1686
|
+
const onFieldChange = (key, value) => {
|
|
1687
|
+
if (value === getFormField(key)?.value) return false;
|
|
1688
|
+
onChangeObserver(key, value);
|
|
1689
|
+
setFormField(
|
|
1690
|
+
(field) => ({
|
|
1691
|
+
...field,
|
|
1692
|
+
error: "",
|
|
1693
|
+
value
|
|
1694
|
+
}),
|
|
1695
|
+
key
|
|
1696
|
+
);
|
|
1697
|
+
};
|
|
1698
|
+
const [formSubmitBlockers, setFormSubmitBlockers] = useState4([]);
|
|
1699
|
+
const toggleFormSubmitBlock = (key, value) => {
|
|
1700
|
+
setFormSubmitBlockers(
|
|
1701
|
+
(state) => state.includes(key) || !value ? [...state.filter((k) => k !== key)] : [...state, key]
|
|
1702
|
+
);
|
|
1703
|
+
};
|
|
1704
|
+
const clearFormSubmitBlockers = () => setFormSubmitBlockers([]);
|
|
1705
|
+
const [isFormFieldsAdded, setIsFormFieldsAdded] = useState4(false);
|
|
1706
|
+
const [renderFormFields, setRenderFormFieldsState] = useState4([]);
|
|
1707
|
+
const setRenderFormFields = (data) => {
|
|
1708
|
+
setIsFormFieldsAdded(true);
|
|
1709
|
+
removeRenderFields(renderFormFields);
|
|
1710
|
+
resetIsInitFocused();
|
|
1711
|
+
setRenderFormFieldsState(data);
|
|
1712
|
+
};
|
|
1713
|
+
const addRenderFields = (fields) => {
|
|
1714
|
+
setRenderFormFieldsState((state) => [...state, ...fields]);
|
|
1715
|
+
};
|
|
1716
|
+
const removeRenderFields = (fields) => {
|
|
1717
|
+
setRenderFormFieldsState(
|
|
1718
|
+
(state) => state.filter((field) => !fields.includes(field))
|
|
1719
|
+
);
|
|
1720
|
+
};
|
|
1721
|
+
const [isFormRendered, setIsFormRendered] = useState4(false);
|
|
1722
|
+
const submitIsFormRendered = () => setIsFormRendered(true);
|
|
1723
|
+
const resetIsFormRendered = () => setIsFormRendered(false);
|
|
1724
|
+
const onEnterDown = async (e) => {
|
|
1725
|
+
if (!goToNextFieldOnEnterPressed) return false;
|
|
1726
|
+
const focusable = document.querySelectorAll(
|
|
1727
|
+
'a, button, input, [tabindex]:not([tabindex="-1"])'
|
|
1728
|
+
);
|
|
1729
|
+
const currentIndex = await new Promise((resolve) => {
|
|
1730
|
+
focusable.forEach((node, i) => {
|
|
1731
|
+
if (node === e.target) resolve(i);
|
|
1732
|
+
});
|
|
1733
|
+
});
|
|
1734
|
+
if (!currentIndex) return false;
|
|
1735
|
+
const nextIndex = currentIndex + 1;
|
|
1736
|
+
if (nextIndex >= focusable.length) return false;
|
|
1737
|
+
const nextItem = focusable[nextIndex];
|
|
1738
|
+
nextItem.focus();
|
|
1739
|
+
};
|
|
1740
|
+
const onKeyDown = (...args) => {
|
|
1741
|
+
const event = args.reduce((e, item) => {
|
|
1742
|
+
if (item?.nativeEvent instanceof KeyboardEvent) return item;
|
|
1743
|
+
return e;
|
|
1744
|
+
}, null);
|
|
1745
|
+
if (!event) return false;
|
|
1746
|
+
const { keyCode } = event;
|
|
1747
|
+
switch (keyCode) {
|
|
1748
|
+
//OnEnterDown
|
|
1749
|
+
case 13:
|
|
1750
|
+
onEnterDown(event);
|
|
1751
|
+
break;
|
|
1752
|
+
default:
|
|
1753
|
+
break;
|
|
1754
|
+
}
|
|
1755
|
+
};
|
|
1756
|
+
useEffect8(() => {
|
|
1757
|
+
resetIsFormRendered();
|
|
1758
|
+
}, [FormType]);
|
|
1759
|
+
useEffect8(() => {
|
|
1760
|
+
if (isFormFieldsAdded) resetIsFormRendered(false);
|
|
1761
|
+
if (renderFormFields.length !== 0) {
|
|
1762
|
+
setFormFields((fields) => {
|
|
1763
|
+
return renderFormFields.reduce((result, key) => {
|
|
1764
|
+
const fieldData = getFieldData(key);
|
|
1765
|
+
const field = getFormField(key) ? getFormField(key) : fieldData;
|
|
1766
|
+
if (!field?.className || field?.className?.indexOf(getFieldClassName(key, FormType)) === -1) {
|
|
1767
|
+
field.className = `${field?.className} ${getFieldClassName(key, FormType)}`;
|
|
1768
|
+
}
|
|
1769
|
+
if (typeof fieldData?.label === "object") {
|
|
1770
|
+
field.label = fieldData.label[FormType] || fieldData.label.default;
|
|
1771
|
+
}
|
|
1772
|
+
field.ref = createRef2();
|
|
1773
|
+
field.wrapperRef = createRef2();
|
|
1774
|
+
field.isValueChangedByUser = false;
|
|
1775
|
+
if (goToNextFieldOnEnterPressed) {
|
|
1776
|
+
const onKeyDownProp = field.onKeyDown || (() => {
|
|
1777
|
+
});
|
|
1778
|
+
field.onKeyDown = (...args) => {
|
|
1779
|
+
onKeyDown(...args);
|
|
1780
|
+
onKeyDownProp(...args);
|
|
1781
|
+
};
|
|
1782
|
+
}
|
|
1783
|
+
addOnFieldRenderedObserver(
|
|
1784
|
+
key,
|
|
1785
|
+
() => {
|
|
1786
|
+
const element = getFormField(key)?.ref?.current?.querySelector(
|
|
1787
|
+
field?.focusSelector || "input"
|
|
1788
|
+
);
|
|
1789
|
+
const handler = () => setFormField({ isValueChangedByUser: true }, key);
|
|
1790
|
+
element?.addEventListener("paste", handler, { once: true });
|
|
1791
|
+
element?.addEventListener("keypress", handler, { once: true });
|
|
1792
|
+
},
|
|
1793
|
+
true
|
|
1794
|
+
);
|
|
1795
|
+
return updateFormField(result, field, key);
|
|
1796
|
+
}, fields);
|
|
1797
|
+
});
|
|
1798
|
+
}
|
|
1799
|
+
}, [renderFormFields]);
|
|
1800
|
+
const [onFormRenderObservers, setOnFormRenderObservers] = useState4([]);
|
|
1801
|
+
const addOnFormRenderObserver = (cb, { once = false } = {}) => {
|
|
1802
|
+
setOnFormRenderObservers((state) => [
|
|
1803
|
+
...state,
|
|
1804
|
+
{ cb, once, isWorkedOut: false }
|
|
1805
|
+
]);
|
|
1806
|
+
};
|
|
1807
|
+
const updateOnFormRenderObserver = (key, data) => {
|
|
1808
|
+
setOnFormRenderObservers((state) => {
|
|
1809
|
+
const copy = [...state];
|
|
1810
|
+
copy[key] = { ...state[key], ...data };
|
|
1811
|
+
return copy;
|
|
1812
|
+
});
|
|
1813
|
+
};
|
|
1814
|
+
const removeOnFormRenderObserver = (key) => {
|
|
1815
|
+
setOnFormRenderObservers(
|
|
1816
|
+
(state) => state.slice().filter((v, i) => i !== key)
|
|
1817
|
+
);
|
|
1818
|
+
};
|
|
1819
|
+
const onFormRenderWorker = () => {
|
|
1820
|
+
onFormRenderObservers.map(
|
|
1821
|
+
({ once, isWorkedOut, cb = () => {
|
|
1822
|
+
} } = {}, key) => {
|
|
1823
|
+
if (once && isWorkedOut) return null;
|
|
1824
|
+
cb(form);
|
|
1825
|
+
if (once) removeOnFormRenderObserver(key);
|
|
1826
|
+
else updateOnFormRenderObserver(key, { isWorkedOut: true });
|
|
1827
|
+
return null;
|
|
1828
|
+
}
|
|
1829
|
+
);
|
|
1830
|
+
};
|
|
1831
|
+
useEffect8(() => {
|
|
1832
|
+
if (!isFormRendered && onFormRenderObservers.length) {
|
|
1833
|
+
const formFieldsKeys = getFormFieldsKeys(form);
|
|
1834
|
+
const isAllFieldsRendered = renderFormFields.reduce((result, key) => {
|
|
1835
|
+
if (!formFieldsKeys.includes(key)) result = false;
|
|
1836
|
+
return result;
|
|
1837
|
+
}, true);
|
|
1838
|
+
if (isAllFieldsRendered) {
|
|
1839
|
+
submitIsFormRendered(true);
|
|
1840
|
+
onFormRenderWorker();
|
|
1841
|
+
}
|
|
1842
|
+
}
|
|
1843
|
+
}, [form, renderFormFields, onFormRenderObservers]);
|
|
1844
|
+
const hightliteErrorLabels = () => {
|
|
1845
|
+
const fields = getFormFieldsAsArray();
|
|
1846
|
+
const filtered = fields?.reduce((result, field) => {
|
|
1847
|
+
if (field?.errorLabelHightlite) {
|
|
1848
|
+
result.push({
|
|
1849
|
+
...field,
|
|
1850
|
+
className: getFieldClassName(field?.key, FormType)
|
|
1851
|
+
});
|
|
1852
|
+
}
|
|
1853
|
+
return result;
|
|
1854
|
+
}, []);
|
|
1855
|
+
filtered?.map((field) => {
|
|
1856
|
+
const formField = document.querySelector(`.${field?.className}`);
|
|
1857
|
+
if (!formField) return null;
|
|
1858
|
+
formField.classList.remove("errorLabelHightlite");
|
|
1859
|
+
if (field?.error) {
|
|
1860
|
+
formField.classList.add("errorLabelHightlite");
|
|
1861
|
+
}
|
|
1862
|
+
return null;
|
|
1863
|
+
});
|
|
1864
|
+
};
|
|
1865
|
+
useEffect8(() => {
|
|
1866
|
+
hightliteErrorLabels();
|
|
1867
|
+
}, [form]);
|
|
1868
|
+
const [isInitFocused, setIsInitFocused] = useState4(false);
|
|
1869
|
+
const [autoFocusedField, setAutoFocusedField] = useState4(null);
|
|
1870
|
+
const setFirstFieldInitFocused = () => setIsInitFocused(true);
|
|
1871
|
+
const resetIsInitFocused = () => setIsInitFocused(false);
|
|
1872
|
+
const toggleFieldFocus = ({ key, cb = () => {
|
|
1873
|
+
}, form: argForm, field }, action = "focus") => {
|
|
1874
|
+
if (!key && !field) return null;
|
|
1875
|
+
if (!argForm) argForm = form;
|
|
1876
|
+
const formField = field || getFormField(key, argForm);
|
|
1877
|
+
if (!formField || !formField.ref) {
|
|
1878
|
+
return false;
|
|
1879
|
+
}
|
|
1880
|
+
if (action === "focus" && FocusControllerProps.onlyEmptyFieldAutoFocus && Boolean(formField?.value))
|
|
1881
|
+
return null;
|
|
1882
|
+
setTimeout(() => {
|
|
1883
|
+
formField.ref.current?.querySelector(formField?.focusSelector || "input")?.[action]();
|
|
1884
|
+
cb();
|
|
1885
|
+
}, 50);
|
|
1886
|
+
};
|
|
1887
|
+
const setFieldFocus = ({ key, cb = () => {
|
|
1888
|
+
}, form: argForm, field }) => toggleFieldFocus({ key, cb, form: argForm, field }, "focus");
|
|
1889
|
+
const setFieldBlur = ({ key, cb = () => {
|
|
1890
|
+
}, form: argForm, field }) => toggleFieldFocus({ key, cb, form: argForm, field }, "blur");
|
|
1891
|
+
const setFirstFieldFocus = () => {
|
|
1892
|
+
let field = null;
|
|
1893
|
+
for (let i = 0; i < renderFormFields.length && !field; ++i) {
|
|
1894
|
+
const key = renderFormFields[i];
|
|
1895
|
+
const tmpField = getFormField(key);
|
|
1896
|
+
if (tmpField && !tmpField?.disabled) field = tmpField;
|
|
1897
|
+
}
|
|
1898
|
+
if (!field) return false;
|
|
1899
|
+
if (FocusControllerProps.onlyEmptyFieldAutoFocus && Boolean(field?.value)) {
|
|
1900
|
+
setFirstFieldInitFocused();
|
|
1901
|
+
return false;
|
|
1902
|
+
}
|
|
1903
|
+
setAutoFocusedField(field.key);
|
|
1904
|
+
const callback = () => {
|
|
1905
|
+
setFormField({ value: field.value }, field.key);
|
|
1906
|
+
setFirstFieldInitFocused();
|
|
1907
|
+
};
|
|
1908
|
+
setTimeout(() => setFieldFocus({ key: field.key, cb: callback, form }), 50);
|
|
1909
|
+
};
|
|
1910
|
+
const [onFieldFocusCallbacks, setOnFieldFocusCallbacks] = useState4({});
|
|
1911
|
+
const addOnFieldFocusCallback = (key, cb) => {
|
|
1912
|
+
setOnFieldFocusCallbacks((state) => {
|
|
1913
|
+
const stateCopy = { ...state };
|
|
1914
|
+
if (!state[key]) stateCopy[key] = [];
|
|
1915
|
+
stateCopy[key].push(cb);
|
|
1916
|
+
return stateCopy;
|
|
1917
|
+
});
|
|
1918
|
+
};
|
|
1919
|
+
const callOnFieldFocusCallbacks = (key) => {
|
|
1920
|
+
if (!Array.isArray(onFieldFocusCallbacks[key])) return null;
|
|
1921
|
+
onFieldFocusCallbacks[key]?.map((cb) => cb());
|
|
1922
|
+
};
|
|
1923
|
+
const [focusOnRenderFields, setFocusOnRenderFields] = useState4([]);
|
|
1924
|
+
const addFocusFieldOnRender = (key, cb) => {
|
|
1925
|
+
setFocusOnRenderFields((state) => [...state, key]);
|
|
1926
|
+
if (cb) addOnFieldFocusCallback(key, cb);
|
|
1927
|
+
};
|
|
1928
|
+
const removeFocusFieldOnRender = (key) => {
|
|
1929
|
+
setFocusOnRenderFields((state) => state.filter((field) => field !== key));
|
|
1930
|
+
};
|
|
1931
|
+
useEffect8(() => {
|
|
1932
|
+
if (FocusControllerProps.setAutoFocus && !isInitFocused && !autoFocusedField && isFormRendered)
|
|
1933
|
+
setFirstFieldFocus();
|
|
1934
|
+
if (focusOnRenderFields.length) {
|
|
1935
|
+
getFormFieldsKeys(form)?.map((key) => {
|
|
1936
|
+
if (focusOnRenderFields.includes(key) && getFormField(key)?.value?.length === 0) {
|
|
1937
|
+
const cb = () => {
|
|
1938
|
+
removeFocusFieldOnRender(key);
|
|
1939
|
+
callOnFieldFocusCallbacks(key);
|
|
1940
|
+
};
|
|
1941
|
+
setFieldFocus({ key, form, cb });
|
|
1942
|
+
}
|
|
1943
|
+
return null;
|
|
1944
|
+
});
|
|
1945
|
+
}
|
|
1946
|
+
}, [form, focusOnRenderFields, isInitFocused, isFormRendered]);
|
|
1947
|
+
useEffect8(() => {
|
|
1948
|
+
setAutoFocusedField(null);
|
|
1949
|
+
}, [isInitFocused]);
|
|
1950
|
+
useEffect8(() => {
|
|
1951
|
+
resetIsInitFocused();
|
|
1952
|
+
}, [FormType]);
|
|
1953
|
+
const [onFieldRenderedObservers, setOnFieldRenderedObservers] = useState4({});
|
|
1954
|
+
const [isFieldObserversReset, setIsFieldObserversReset] = useState4(false);
|
|
1955
|
+
const resetOnFieldRenderObserversWorkedOut = () => {
|
|
1956
|
+
if (!isFieldObserversReset && renderFormFields.length) {
|
|
1957
|
+
renderFormFields.map((key) => {
|
|
1958
|
+
setFormField({ isOnRenderObserversWorkedOut: false }, key);
|
|
1959
|
+
return key;
|
|
1960
|
+
});
|
|
1961
|
+
setIsFieldObserversReset(true);
|
|
1962
|
+
}
|
|
1963
|
+
};
|
|
1964
|
+
const addOnFieldRenderedObserver = (key, cb, isOnceCallable = true) => {
|
|
1965
|
+
let observerId = null;
|
|
1966
|
+
setOnFieldRenderedObservers((state) => {
|
|
1967
|
+
if (!state[key]) state[key] = {};
|
|
1968
|
+
observerId = Object.keys(state[key]).length || 0;
|
|
1969
|
+
state[key][observerId] = {
|
|
1970
|
+
f: cb,
|
|
1971
|
+
isOnceCallable
|
|
1972
|
+
};
|
|
1973
|
+
return state;
|
|
1974
|
+
});
|
|
1975
|
+
return observerId;
|
|
1976
|
+
};
|
|
1977
|
+
const updateOnFieldRenderedObserver = (key, id, data) => {
|
|
1978
|
+
setOnFieldRenderedObservers((state) => {
|
|
1979
|
+
if (!state[key]) return state;
|
|
1980
|
+
state[key][id] = {
|
|
1981
|
+
...state[key][id],
|
|
1982
|
+
...data
|
|
1983
|
+
};
|
|
1984
|
+
return state;
|
|
1985
|
+
});
|
|
1986
|
+
};
|
|
1987
|
+
const removeOnFieldRenderedObserver = (key, id) => {
|
|
1988
|
+
setOnFieldRenderedObservers((state) => {
|
|
1989
|
+
if (!state[key]) return state;
|
|
1990
|
+
state[key] = Object.keys(state).filter((cbId) => cbId !== id).map((cbId) => state[key][cbId]);
|
|
1991
|
+
return state;
|
|
1992
|
+
});
|
|
1993
|
+
};
|
|
1994
|
+
const onFieldRenderedObserver = (key, data) => {
|
|
1995
|
+
if (!onFieldRenderedObservers[key] || typeof onFieldRenderedObservers[key] !== "object")
|
|
1996
|
+
return;
|
|
1997
|
+
const Observers = onFieldRenderedObservers[key];
|
|
1998
|
+
const FilteredObservers = Object.values(Observers).filter(
|
|
1999
|
+
(observer) => !observer?.isObserverWorkedOut
|
|
2000
|
+
);
|
|
2001
|
+
if (FilteredObservers.length === 0) return null;
|
|
2002
|
+
setFormField({ isOnRenderObserversWorkedOut: true }, key);
|
|
2003
|
+
FilteredObservers.map(({ f, isOnceCallable }, id) => {
|
|
2004
|
+
f(data);
|
|
2005
|
+
if (isOnceCallable)
|
|
2006
|
+
updateOnFieldRenderedObserver(key, id, { isObserverWorkedOut: true });
|
|
2007
|
+
return null;
|
|
2008
|
+
});
|
|
2009
|
+
};
|
|
2010
|
+
const onRenderObserverWorker = () => {
|
|
2011
|
+
return getFormFieldsKeys(form)?.map((key) => {
|
|
2012
|
+
const fieldData = getFormField(key);
|
|
2013
|
+
if (!fieldData?.isOnRenderObserversWorkedOut) {
|
|
2014
|
+
onFieldRenderedObserver(key, fieldData);
|
|
2015
|
+
return { key, isWorkedOut: true };
|
|
2016
|
+
}
|
|
2017
|
+
return { key, isWorkedOut: false };
|
|
2018
|
+
});
|
|
2019
|
+
};
|
|
2020
|
+
useEffect8(() => {
|
|
2021
|
+
resetOnFieldRenderObserversWorkedOut();
|
|
2022
|
+
onRenderObserverWorker();
|
|
2023
|
+
}, [form]);
|
|
2024
|
+
useEffect8(() => {
|
|
2025
|
+
setIsFieldObserversReset(false);
|
|
2026
|
+
}, [FormType]);
|
|
2027
|
+
const scrollToField = ({ key = null, field = null, form: argForm }) => {
|
|
2028
|
+
if (!key && !field) return false;
|
|
2029
|
+
if (!argForm) argForm = form;
|
|
2030
|
+
if (!field) field = getFormField(key, argForm);
|
|
2031
|
+
const wrapperRef = field?.wrapperRef || field?.ref;
|
|
2032
|
+
const { top: topOffset } = wrapperRef?.current?.getBoundingClientRect();
|
|
2033
|
+
const scrollTop = Math.abs(Math.abs(topOffset) - Math.abs(window.scrollY)) - 16;
|
|
2034
|
+
window.scrollTo({ top: scrollTop });
|
|
2035
|
+
};
|
|
2036
|
+
const addErrorsToForm = (errors, argForm = form) => {
|
|
2037
|
+
if (!argForm) argForm = form;
|
|
2038
|
+
setFormFields((fields) => {
|
|
2039
|
+
return errors.reduce(
|
|
2040
|
+
(fields2, { message: error, propertyPath: errKey }) => {
|
|
2041
|
+
return updateFormField(fields2, { error }, errKey);
|
|
2042
|
+
},
|
|
2043
|
+
fields
|
|
2044
|
+
);
|
|
2045
|
+
});
|
|
2046
|
+
};
|
|
2047
|
+
return {
|
|
2048
|
+
FormDataDrivers,
|
|
2049
|
+
//OnChangeObserver
|
|
2050
|
+
addOnChangeObserver,
|
|
2051
|
+
removeOnChangeObserver,
|
|
2052
|
+
onChangeObservers,
|
|
2053
|
+
//OnChangeHandler
|
|
2054
|
+
onFieldChange,
|
|
2055
|
+
//Form Submit Blocker
|
|
2056
|
+
toggleFormSubmitBlock,
|
|
2057
|
+
clearFormSubmitBlockers,
|
|
2058
|
+
isFormSubmitBlocked: Boolean(formSubmitBlockers.length),
|
|
2059
|
+
//Property Observers
|
|
2060
|
+
// addPropertyObserver,
|
|
2061
|
+
//Render Fields
|
|
2062
|
+
renderFormFields,
|
|
2063
|
+
setRenderFormFields,
|
|
2064
|
+
addRenderFields,
|
|
2065
|
+
removeRenderFields,
|
|
2066
|
+
getFieldClassName,
|
|
2067
|
+
//Field Focus Controller
|
|
2068
|
+
isInitFocused,
|
|
2069
|
+
setFirstFieldInitFocused,
|
|
2070
|
+
resetIsInitFocused,
|
|
2071
|
+
setFieldFocus,
|
|
2072
|
+
setFieldBlur,
|
|
2073
|
+
setFirstFieldFocus,
|
|
2074
|
+
autoFocusedField,
|
|
2075
|
+
addFocusFieldOnRender,
|
|
2076
|
+
removeFocusFieldOnRender,
|
|
2077
|
+
//Field Render Controller
|
|
2078
|
+
addOnFieldRenderedObserver,
|
|
2079
|
+
removeOnFieldRenderedObserver,
|
|
2080
|
+
onFieldRenderedObservers,
|
|
2081
|
+
updateFormField,
|
|
2082
|
+
addOnFormRenderObserver,
|
|
2083
|
+
submitIsFormRendered,
|
|
2084
|
+
resetIsFormRendered,
|
|
2085
|
+
renderFields: ({
|
|
2086
|
+
form: argForm = form,
|
|
2087
|
+
fields: argFields = renderFormFields,
|
|
2088
|
+
cols: argCols = 1,
|
|
2089
|
+
RenderFieldComponent
|
|
2090
|
+
}) => RenderFields({
|
|
2091
|
+
form: argForm,
|
|
2092
|
+
fields: argFields,
|
|
2093
|
+
cols: argCols,
|
|
2094
|
+
RenderFieldComponent,
|
|
2095
|
+
onFieldChange,
|
|
2096
|
+
FormDataDriver: getFormDataDriver(FormDataDriverName)
|
|
2097
|
+
}),
|
|
2098
|
+
scrollToField,
|
|
2099
|
+
getFieldData,
|
|
2100
|
+
getFormField,
|
|
2101
|
+
setFormFields,
|
|
2102
|
+
setFormField: (data, key) => setFormField(data, key),
|
|
2103
|
+
getFormFieldsAsArray,
|
|
2104
|
+
getFormFieldsKeys,
|
|
2105
|
+
removeAllFormFields,
|
|
2106
|
+
removeFormField,
|
|
2107
|
+
removeFormFields,
|
|
2108
|
+
addErrorsToForm
|
|
2109
|
+
};
|
|
2110
|
+
}
|
|
2111
|
+
|
|
2112
|
+
// src/Functions/useInputHighlightError.js
|
|
2113
|
+
import React4, { useEffect as useEffect9, useState as useState5 } from "react";
|
|
2114
|
+
var useInputHighlightError = ({
|
|
2115
|
+
value,
|
|
2116
|
+
blinkTime,
|
|
2117
|
+
isUseErrorsBlink
|
|
2118
|
+
}) => {
|
|
2119
|
+
const DEFAULT_BLINK_TIME = 100;
|
|
2120
|
+
const [isToHighlightError, setIsToHighlightError] = useState5(false);
|
|
2121
|
+
const [isAttemptToChange, setIsAttemptToChange] = useState5(false);
|
|
2122
|
+
const [prevValue, setPreviousValue] = useState5(value);
|
|
2123
|
+
function hasHighlightError(e) {
|
|
2124
|
+
const changedValue = `${value ?? ""}`;
|
|
2125
|
+
const previousValue = `${prevValue ?? ""}`;
|
|
2126
|
+
const short = previousValue.length <= changedValue.length ? previousValue : changedValue;
|
|
2127
|
+
const long = previousValue.length > changedValue.length ? previousValue : changedValue;
|
|
2128
|
+
const infoAboutDifferencesSameness = short.split("").reduce(
|
|
2129
|
+
(acc, symbol, idx) => {
|
|
2130
|
+
if (acc.countOn && symbol === long[idx]) acc.same.push(symbol);
|
|
2131
|
+
else {
|
|
2132
|
+
acc.countOn = false;
|
|
2133
|
+
acc.differences.push([idx, symbol]);
|
|
2134
|
+
}
|
|
2135
|
+
return acc;
|
|
2136
|
+
},
|
|
2137
|
+
{ same: [], countOn: true, differences: [] }
|
|
2138
|
+
);
|
|
2139
|
+
const samePart = infoAboutDifferencesSameness.same.join("");
|
|
2140
|
+
const differencesLength = infoAboutDifferencesSameness.differences.length;
|
|
2141
|
+
const currentSet = changedValue?.replace(samePart, "");
|
|
2142
|
+
if (!KEYBOARD_SERVICE_KEYS.includes(e.key) && changedValue === previousValue)
|
|
2143
|
+
setIsAttemptToChange(!(!differencesLength && e.key === currentSet));
|
|
2144
|
+
}
|
|
2145
|
+
useEffect9(() => {
|
|
2146
|
+
if (isUseErrorsBlink && isAttemptToChange) {
|
|
2147
|
+
setIsAttemptToChange(null);
|
|
2148
|
+
setIsToHighlightError(true);
|
|
2149
|
+
setTimeout(() => {
|
|
2150
|
+
setIsToHighlightError(false);
|
|
2151
|
+
}, blinkTime || DEFAULT_BLINK_TIME);
|
|
2152
|
+
}
|
|
2153
|
+
}, [isAttemptToChange]);
|
|
2154
|
+
return {
|
|
2155
|
+
isToHighlightError,
|
|
2156
|
+
setPreviousValue,
|
|
2157
|
+
setIsToHighlightError,
|
|
2158
|
+
hasHighlightError
|
|
2159
|
+
};
|
|
2160
|
+
};
|
|
2161
|
+
var useInputHighlightError_default = useInputHighlightError;
|
|
2162
|
+
|
|
2163
|
+
// src/Functions/useIsMobile/useIsMobile.ts
|
|
2164
|
+
import { useEffect as useEffect10, useState as useState6 } from "react";
|
|
2165
|
+
function useIsMobile({ isWithoutWidthCheck = false } = {}) {
|
|
2166
|
+
const isIPad = () => {
|
|
2167
|
+
const ua = navigator.userAgent || navigator.vendor || window.opera;
|
|
2168
|
+
const isMac = /Macintosh/.test(ua);
|
|
2169
|
+
const hasTouch = navigator.maxTouchPoints && navigator.maxTouchPoints > 2;
|
|
2170
|
+
return isMac && !!hasTouch;
|
|
2171
|
+
};
|
|
2172
|
+
const getIsMobile = () => {
|
|
2173
|
+
return /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent) || isIPad();
|
|
2174
|
+
};
|
|
2175
|
+
const [isMobile, setIsMobile] = useState6(getIsMobile());
|
|
2176
|
+
useEffect10(() => {
|
|
2177
|
+
if (getIsMobile()) {
|
|
2178
|
+
setIsMobile(true);
|
|
2179
|
+
}
|
|
2180
|
+
}, [navigator.userAgent]);
|
|
2181
|
+
return {
|
|
2182
|
+
isMobile: isMobile && (isWithoutWidthCheck || window.screen.width <= 768 || window.screen.width <= 1024 && window.matchMedia("(orientation: landscape)").matches),
|
|
2183
|
+
isMobilePortrait: isMobile && window.screen.width <= 768 && window.matchMedia("(orientation: portait)").matches,
|
|
2184
|
+
isMobileLandscape: isMobile && window.screen.width <= 1024 && window.matchMedia("(orientation: landscape)").matches
|
|
2185
|
+
};
|
|
2186
|
+
}
|
|
2187
|
+
var useIsMobile_default = useIsMobile;
|
|
2188
|
+
|
|
2189
|
+
// src/Functions/useIsMobile/index.ts
|
|
2190
|
+
var useIsMobile_default2 = useIsMobile_default;
|
|
2191
|
+
|
|
2192
|
+
// src/Functions/useKeyPress/useKeyPress.ts
|
|
2193
|
+
import { useCallback, useEffect as useEffect11, useState as useState7 } from "react";
|
|
2194
|
+
function isISuspendProcessing(x) {
|
|
2195
|
+
return getIsOnlyAnObject(x) && Object.values(x).every((v) => typeof v === "function");
|
|
2196
|
+
}
|
|
2197
|
+
function useKeyPress(targetKey, clamping = true, isForbidden, suspendProcessing) {
|
|
2198
|
+
const [keyPressed, setKeyPressed] = useState7(false);
|
|
2199
|
+
const safelySuspendProcessing = isISuspendProcessing(suspendProcessing) ? suspendProcessing : {};
|
|
2200
|
+
const downHandler = useCallback(
|
|
2201
|
+
(event) => {
|
|
2202
|
+
const { key, repeat, altKey, ctrlKey, shiftKey, metaKey } = event;
|
|
2203
|
+
const isPressingWithoutAuxiliaryKeys = !altKey && !ctrlKey && !shiftKey && !metaKey;
|
|
2204
|
+
if (key === targetKey && isPressingWithoutAuxiliaryKeys && !safelySuspendProcessing[key]?.(event)) {
|
|
2205
|
+
if (!clamping && repeat) return;
|
|
2206
|
+
setKeyPressed(true);
|
|
2207
|
+
}
|
|
2208
|
+
},
|
|
2209
|
+
// ? Намерянно в зависимостях используем именно входной suspendProcessing,
|
|
2210
|
+
// ? хоть в коде используем "безопасный"
|
|
2211
|
+
[clamping, targetKey, suspendProcessing]
|
|
2212
|
+
);
|
|
2213
|
+
const upHandler = useCallback(
|
|
2214
|
+
(event) => {
|
|
2215
|
+
const { key, repeat, altKey, ctrlKey, shiftKey, metaKey } = event;
|
|
2216
|
+
const isPressingWithoutAuxiliaryKeys = !altKey && !ctrlKey && !shiftKey && !metaKey;
|
|
2217
|
+
if (key === targetKey && isPressingWithoutAuxiliaryKeys && !safelySuspendProcessing[key]?.(event)) {
|
|
2218
|
+
if (!clamping && repeat) return;
|
|
2219
|
+
setKeyPressed(false);
|
|
2220
|
+
}
|
|
2221
|
+
},
|
|
2222
|
+
// ? Намерянно в зависимостях используем именно входной suspendProcessing,
|
|
2223
|
+
// ? хоть в коде используем "безопасный"
|
|
2224
|
+
[clamping, targetKey, suspendProcessing]
|
|
2225
|
+
);
|
|
2226
|
+
useEffect11(
|
|
2227
|
+
() => {
|
|
2228
|
+
const handleDown = (event) => downHandler(event);
|
|
2229
|
+
const handleUp = (event) => upHandler(event);
|
|
2230
|
+
if (!isForbidden) {
|
|
2231
|
+
window.addEventListener("keydown", handleDown);
|
|
2232
|
+
window.addEventListener("keyup", handleUp);
|
|
2233
|
+
}
|
|
2234
|
+
return () => {
|
|
2235
|
+
window.removeEventListener("keydown", handleDown);
|
|
2236
|
+
window.removeEventListener("keyup", handleUp);
|
|
2237
|
+
};
|
|
2238
|
+
},
|
|
2239
|
+
// ? Намерянно в зависимостях используем именно входной suspendProcessing,
|
|
2240
|
+
// ? хоть в коде используем "безопасный"
|
|
2241
|
+
[downHandler, upHandler, isForbidden, suspendProcessing]
|
|
2242
|
+
);
|
|
2243
|
+
return keyPressed;
|
|
2244
|
+
}
|
|
2245
|
+
var useKeyPress_default = useKeyPress;
|
|
2246
|
+
|
|
2247
|
+
// src/Functions/useLocalStorage.js
|
|
2248
|
+
import { useState as useState8 } from "react";
|
|
2249
|
+
var useLocalStorage = (key, initialValue) => {
|
|
2250
|
+
const [storedValue, setStoredValue] = useState8(() => {
|
|
2251
|
+
if (typeof window === "undefined") {
|
|
2252
|
+
return initialValue;
|
|
2253
|
+
}
|
|
2254
|
+
try {
|
|
2255
|
+
const item = window.localStorage.getItem(key);
|
|
2256
|
+
return item ? JSON.parse(item) : initialValue;
|
|
2257
|
+
} catch (error) {
|
|
2258
|
+
console.log(error);
|
|
2259
|
+
return initialValue;
|
|
2260
|
+
}
|
|
2261
|
+
});
|
|
2262
|
+
const setValue = (value) => {
|
|
2263
|
+
try {
|
|
2264
|
+
const valueToStore = value instanceof Function ? value(storedValue) : value;
|
|
2265
|
+
setStoredValue(valueToStore);
|
|
2266
|
+
if (typeof window !== "undefined") {
|
|
2267
|
+
window.localStorage.setItem(key, JSON.stringify(valueToStore));
|
|
2268
|
+
}
|
|
2269
|
+
} catch (error) {
|
|
2270
|
+
console.log(error);
|
|
2271
|
+
}
|
|
2272
|
+
};
|
|
2273
|
+
return [storedValue, setValue];
|
|
2274
|
+
};
|
|
2275
|
+
var useLocalStorage_default = useLocalStorage;
|
|
2276
|
+
|
|
2277
|
+
// src/Functions/useLocationParams.js
|
|
2278
|
+
import { useEffect as useEffect12, useState as useState9 } from "react";
|
|
2279
|
+
function useLocationParams() {
|
|
2280
|
+
const [params, setParams] = useState9({});
|
|
2281
|
+
useEffect12(() => {
|
|
2282
|
+
setParams((state) => {
|
|
2283
|
+
const arr = window.location.search?.replace("?", "").split("&");
|
|
2284
|
+
return {
|
|
2285
|
+
...state,
|
|
2286
|
+
...arr.reduce((obj, item) => {
|
|
2287
|
+
const keyVal = item.split("=");
|
|
2288
|
+
const key = keyVal[0];
|
|
2289
|
+
const value = decodeURIComponent(keyVal[1]);
|
|
2290
|
+
return {
|
|
2291
|
+
...obj,
|
|
2292
|
+
[key]: value
|
|
2293
|
+
};
|
|
2294
|
+
}, {})
|
|
2295
|
+
};
|
|
2296
|
+
});
|
|
2297
|
+
}, [window.location.search]);
|
|
2298
|
+
return params;
|
|
2299
|
+
}
|
|
2300
|
+
|
|
2301
|
+
// src/Functions/useMediaQuery.js
|
|
2302
|
+
import { useSyncExternalStore } from "react";
|
|
2303
|
+
function subscribe(callback) {
|
|
2304
|
+
const observer = new ResizeObserver(() => callback());
|
|
2305
|
+
observer.observe(document.documentElement);
|
|
2306
|
+
return () => observer.disconnect();
|
|
2307
|
+
}
|
|
2308
|
+
var useMediaQuery = (query) => {
|
|
2309
|
+
return useSyncExternalStore(
|
|
2310
|
+
subscribe,
|
|
2311
|
+
() => window.matchMedia(query).matches,
|
|
2312
|
+
() => false
|
|
2313
|
+
);
|
|
2314
|
+
};
|
|
2315
|
+
var useMediaQuery_default = useMediaQuery;
|
|
2316
|
+
|
|
2317
|
+
// src/Functions/useMetaInfo.js
|
|
2318
|
+
import { useEffect as useEffect13, useState as useState10 } from "react";
|
|
2319
|
+
var useMetaInfo = () => {
|
|
2320
|
+
const [browser, setBrowser] = useState10("Other");
|
|
2321
|
+
const [device, setDevice] = useState10("desktop");
|
|
2322
|
+
const [isiOS, setIsiOS] = useState10(false);
|
|
2323
|
+
const [chromeVersion, setChromeVersion] = useState10(null);
|
|
2324
|
+
const [iOSVersion, setiOSVersion] = useState10(null);
|
|
2325
|
+
useEffect13(() => {
|
|
2326
|
+
const userAgent = navigator.userAgent;
|
|
2327
|
+
if (userAgent.indexOf("Chrome") !== -1) {
|
|
2328
|
+
setBrowser("Chrome");
|
|
2329
|
+
const version = userAgent.match(/Chrom(e|ium)\/([0-9\.]+)/)[2];
|
|
2330
|
+
setChromeVersion(version);
|
|
2331
|
+
} else if (userAgent.indexOf("Safari") !== -1) setBrowser("Safari");
|
|
2332
|
+
const iOSV = ((userAgent.match(/(CPU|iPhone).*OS (\d+_?\d*)|CPU like Mac OS X/i) || [])[2] || "0").replace("_", ".");
|
|
2333
|
+
const iOSVersion2 = parseFloat(iOSV);
|
|
2334
|
+
setIsiOS(!isNaN(iOSVersion2));
|
|
2335
|
+
if (!isNaN(iOSVersion2)) {
|
|
2336
|
+
setiOSVersion(iOSV);
|
|
2337
|
+
}
|
|
2338
|
+
if (/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(
|
|
2339
|
+
userAgent
|
|
2340
|
+
))
|
|
2341
|
+
setDevice("mobile");
|
|
2342
|
+
}, []);
|
|
2343
|
+
return { browser, device, isiOS, chromeVersion, iOSVersion };
|
|
2344
|
+
};
|
|
2345
|
+
var useMetaInfo_default = useMetaInfo;
|
|
2346
|
+
|
|
2347
|
+
// src/Functions/useMouseUpOutside.js
|
|
2348
|
+
import { useEffect as useEffect14 } from "react";
|
|
2349
|
+
function useMouseUpOutside(ref, setOut, open) {
|
|
2350
|
+
function handleMouseUpOutside(event) {
|
|
2351
|
+
if (ref.current && !ref.current.contains(event.target)) {
|
|
2352
|
+
setOut(open);
|
|
2353
|
+
}
|
|
2354
|
+
}
|
|
2355
|
+
useEffect14(() => {
|
|
2356
|
+
document.addEventListener("mouseup", handleMouseUpOutside);
|
|
2357
|
+
return () => {
|
|
2358
|
+
document.removeEventListener("mouseup", handleMouseUpOutside);
|
|
2359
|
+
};
|
|
2360
|
+
}, [ref]);
|
|
2361
|
+
}
|
|
2362
|
+
|
|
2363
|
+
// src/Functions/useOnlineStatus.js
|
|
2364
|
+
import { useEffect as useEffect15, useState as useState11 } from "react";
|
|
2365
|
+
var useOnlineStatus = () => {
|
|
2366
|
+
function getOnlineStatus() {
|
|
2367
|
+
return typeof navigator !== "undefined" && typeof navigator.onLine === "boolean" ? navigator.onLine : true;
|
|
2368
|
+
}
|
|
2369
|
+
const [onlineStatus, setOnlineStatus] = useState11(getOnlineStatus());
|
|
2370
|
+
const goOnline = () => setOnlineStatus(true);
|
|
2371
|
+
const goOffline = () => setOnlineStatus(false);
|
|
2372
|
+
useEffect15(() => {
|
|
2373
|
+
window.addEventListener("online", goOnline);
|
|
2374
|
+
window.addEventListener("offline", goOffline);
|
|
2375
|
+
return () => {
|
|
2376
|
+
window.removeEventListener("online", goOnline);
|
|
2377
|
+
window.removeEventListener("offline", goOffline);
|
|
2378
|
+
};
|
|
2379
|
+
}, []);
|
|
2380
|
+
return onlineStatus;
|
|
2381
|
+
};
|
|
2382
|
+
var useOnlineStatus_default = useOnlineStatus;
|
|
2383
|
+
|
|
2384
|
+
// src/Functions/usePasswordChecker.js
|
|
2385
|
+
import { jsxs } from "react/jsx-runtime";
|
|
2386
|
+
import React5, { useState as useState12 } from "react";
|
|
2387
|
+
import cn from "classnames";
|
|
2388
|
+
function usePasswordChecker({ label = "Password must:" } = {}) {
|
|
2389
|
+
const [checkRules, setCheckRules] = useState12([]);
|
|
2390
|
+
const addCheckRule = (data) => setCheckRules((state) => [...state, data]);
|
|
2391
|
+
const handleCheckRule = (type, props = {}, value = "") => {
|
|
2392
|
+
const { min, max } = props;
|
|
2393
|
+
switch (type) {
|
|
2394
|
+
case "len":
|
|
2395
|
+
if (min && value.length < min) return false;
|
|
2396
|
+
if (max && value.length > max) return false;
|
|
2397
|
+
return true;
|
|
2398
|
+
case "lowerCaseContains": {
|
|
2399
|
+
const toUpperCase = value.slice().toUpperCase().split("");
|
|
2400
|
+
const original = value.slice().split("");
|
|
2401
|
+
return original.reduce((isMatch, char, i) => {
|
|
2402
|
+
if (char !== toUpperCase[i]) isMatch = true;
|
|
2403
|
+
return isMatch;
|
|
2404
|
+
}, false);
|
|
2405
|
+
}
|
|
2406
|
+
case "upperCaseContains": {
|
|
2407
|
+
const toLowerCase = value.slice().toLowerCase().split("");
|
|
2408
|
+
const original = value.slice().split("");
|
|
2409
|
+
return original.reduce((isMatch, char, i) => {
|
|
2410
|
+
if (char !== toLowerCase[i]) isMatch = true;
|
|
2411
|
+
return isMatch;
|
|
2412
|
+
}, false);
|
|
2413
|
+
}
|
|
2414
|
+
case "numberContains": {
|
|
2415
|
+
const original = value.slice().split("");
|
|
2416
|
+
return original.reduce((isMatch, char) => {
|
|
2417
|
+
if (Number.isInteger(parseInt(char, 10))) isMatch = true;
|
|
2418
|
+
return isMatch;
|
|
2419
|
+
}, false);
|
|
2420
|
+
}
|
|
2421
|
+
case "specialContains": {
|
|
2422
|
+
const original = value.slice().split("");
|
|
2423
|
+
return original.reduce((isMatch, char) => {
|
|
2424
|
+
if (!Number.isInteger(parseInt(char, 10)) && !char.match(/[a-z]/i))
|
|
2425
|
+
isMatch = true;
|
|
2426
|
+
return isMatch;
|
|
2427
|
+
}, false);
|
|
2428
|
+
}
|
|
2429
|
+
default:
|
|
2430
|
+
return false;
|
|
2431
|
+
}
|
|
2432
|
+
};
|
|
2433
|
+
const testCheckRules = (value) => {
|
|
2434
|
+
let result = true;
|
|
2435
|
+
setCheckRules((state) => {
|
|
2436
|
+
const rules = [...state];
|
|
2437
|
+
return rules.map((rule) => {
|
|
2438
|
+
const isMatch = handleCheckRule(rule.type, rule.props, value);
|
|
2439
|
+
if (!isMatch) result = false;
|
|
2440
|
+
return { ...rule, isMatch };
|
|
2441
|
+
});
|
|
2442
|
+
});
|
|
2443
|
+
return result;
|
|
2444
|
+
};
|
|
2445
|
+
const renderPasswordChecker = () => {
|
|
2446
|
+
return /* @__PURE__ */ jsxs("div", { className: "password-checker", children: [
|
|
2447
|
+
/* @__PURE__ */ jsxs("div", { className: "password-checker__header", children: [
|
|
2448
|
+
/* @__PURE__ */ jsxs("label", { className: "password-checker__header-label", children: [
|
|
2449
|
+
" ",
|
|
2450
|
+
label,
|
|
2451
|
+
" "
|
|
2452
|
+
] }),
|
|
2453
|
+
" "
|
|
2454
|
+
] }),
|
|
2455
|
+
" ",
|
|
2456
|
+
/* @__PURE__ */ jsxs("div", { className: "password-checker__body", children: [
|
|
2457
|
+
" ",
|
|
2458
|
+
checkRules.map(({ icon, text, isMatch, key }) => /* @__PURE__ */ jsxs(
|
|
2459
|
+
"div",
|
|
2460
|
+
{
|
|
2461
|
+
className: cn("password-checker__body-item", {
|
|
2462
|
+
"password-checker__body-item--match": isMatch && isMatch !== null,
|
|
2463
|
+
"password-checker__body-item--dont-match": !isMatch && isMatch !== null
|
|
2464
|
+
}),
|
|
2465
|
+
children: [
|
|
2466
|
+
/* @__PURE__ */ jsxs("div", { className: "password-checker__body-item__icon", children: [
|
|
2467
|
+
" ",
|
|
2468
|
+
icon,
|
|
2469
|
+
" "
|
|
2470
|
+
] }),
|
|
2471
|
+
" ",
|
|
2472
|
+
/* @__PURE__ */ jsxs("div", { className: "password-checker__body-item__text", children: [
|
|
2473
|
+
" ",
|
|
2474
|
+
text,
|
|
2475
|
+
" "
|
|
2476
|
+
] }),
|
|
2477
|
+
" "
|
|
2478
|
+
]
|
|
2479
|
+
},
|
|
2480
|
+
key
|
|
2481
|
+
)),
|
|
2482
|
+
" "
|
|
2483
|
+
] }),
|
|
2484
|
+
" "
|
|
2485
|
+
] });
|
|
2486
|
+
};
|
|
2487
|
+
return {
|
|
2488
|
+
addCheckRule,
|
|
2489
|
+
testCheckRules,
|
|
2490
|
+
renderPasswordChecker
|
|
2491
|
+
};
|
|
2492
|
+
}
|
|
2493
|
+
|
|
2494
|
+
// src/Functions/usePrevious.js
|
|
2495
|
+
import { useEffect as useEffect16, useRef } from "react";
|
|
2496
|
+
function usePrevious(value) {
|
|
2497
|
+
const ref = useRef();
|
|
2498
|
+
useEffect16(() => {
|
|
2499
|
+
ref.current = value;
|
|
2500
|
+
}, [value]);
|
|
2501
|
+
return ref.current;
|
|
2502
|
+
}
|
|
2503
|
+
var usePrevious_default = usePrevious;
|
|
2504
|
+
|
|
2505
|
+
// src/Functions/useResize.js
|
|
2506
|
+
import { useEffect as useEffect17, useLayoutEffect, useState as useState13 } from "react";
|
|
2507
|
+
var useResize = (element) => {
|
|
2508
|
+
const [elemPosition, setElemPosition] = useState13("");
|
|
2509
|
+
const onResize = (elemRightPosition) => {
|
|
2510
|
+
if (elemRightPosition > document.documentElement.clientWidth) {
|
|
2511
|
+
return setElemPosition("left");
|
|
2512
|
+
} else setElemPosition("");
|
|
2513
|
+
};
|
|
2514
|
+
useEffect17(() => {
|
|
2515
|
+
const elemRightPosition = element?.current?.getBoundingClientRect().right + 20;
|
|
2516
|
+
window.addEventListener("resize", () => onResize(elemRightPosition));
|
|
2517
|
+
return () => {
|
|
2518
|
+
window.removeEventListener("resize", () => setElemPosition(""));
|
|
2519
|
+
};
|
|
2520
|
+
}, []);
|
|
2521
|
+
useLayoutEffect(() => {
|
|
2522
|
+
const elemRightPosition = element?.current?.getBoundingClientRect().right + 20;
|
|
2523
|
+
if (elemRightPosition > document.documentElement.clientWidth) {
|
|
2524
|
+
return setElemPosition("left");
|
|
2525
|
+
}
|
|
2526
|
+
}, []);
|
|
2527
|
+
return { elemPosition };
|
|
2528
|
+
};
|
|
2529
|
+
|
|
2530
|
+
// src/Functions/useScrollTo.js
|
|
2531
|
+
import { useEffect as useEffect18, useRef as useRef2, useState as useState14 } from "react";
|
|
2532
|
+
var useScrollTo = (reference) => {
|
|
2533
|
+
const ref = useRef2(reference);
|
|
2534
|
+
const [shouldScrollTo, setShouldScrollTo] = useState14(false);
|
|
2535
|
+
useEffect18(() => {
|
|
2536
|
+
if (ref?.current && shouldScrollTo) {
|
|
2537
|
+
ref?.current?.scrollIntoView?.({ behavior: "smooth" });
|
|
2538
|
+
setShouldScrollTo(false);
|
|
2539
|
+
}
|
|
2540
|
+
}, [shouldScrollTo]);
|
|
2541
|
+
return [ref, setShouldScrollTo];
|
|
2542
|
+
};
|
|
2543
|
+
var useScrollTo_default = useScrollTo;
|
|
2544
|
+
|
|
2545
|
+
// src/Functions/useToggle.js
|
|
2546
|
+
import { useCallback as useCallback2, useState as useState15 } from "react";
|
|
2547
|
+
var useToggle = (initialState) => {
|
|
2548
|
+
const [isToggled, setToggle] = useState15(Boolean(initialState));
|
|
2549
|
+
const toggle = useCallback2(() => setToggle((isOn) => !isOn), []);
|
|
2550
|
+
const toggleOn = useCallback2(() => setToggle(true), []);
|
|
2551
|
+
const toggleOff = useCallback2(() => setToggle(false), []);
|
|
2552
|
+
return {
|
|
2553
|
+
isToggled,
|
|
2554
|
+
toggle,
|
|
2555
|
+
toggleOn,
|
|
2556
|
+
toggleOff
|
|
2557
|
+
};
|
|
2558
|
+
};
|
|
2559
|
+
var useToggle_default = useToggle;
|
|
2560
|
+
export {
|
|
2561
|
+
DATETIME_FORMATS,
|
|
2562
|
+
DATE_UNITS,
|
|
2563
|
+
Portal_default as Portal,
|
|
2564
|
+
addEventListener,
|
|
2565
|
+
addRangeDefault,
|
|
2566
|
+
createTranslator,
|
|
2567
|
+
customEventListener_default as customEventListener,
|
|
2568
|
+
dispatchCustomEvent,
|
|
2569
|
+
filterFloat,
|
|
2570
|
+
filterNumeric,
|
|
2571
|
+
formatAsPercentage,
|
|
2572
|
+
formatNumberValueToMask,
|
|
2573
|
+
formatOnlyNumbers,
|
|
2574
|
+
formatToAddBitDepthPoints,
|
|
2575
|
+
formatToHex,
|
|
2576
|
+
formatToHideValuePartially,
|
|
2577
|
+
formatToLimitLength,
|
|
2578
|
+
formatToOnlyASCIICodeText,
|
|
2579
|
+
formatToPriceWithCurrency,
|
|
2580
|
+
formatToPriceWithUSD,
|
|
2581
|
+
formatToRemoveComa,
|
|
2582
|
+
formatToReplaceAllWhiteSpace,
|
|
2583
|
+
getSafelyValue,
|
|
2584
|
+
intlNumbersFormatter,
|
|
2585
|
+
isISuspendProcessing,
|
|
2586
|
+
parseAndFormatDate,
|
|
2587
|
+
removeEventListener,
|
|
2588
|
+
useBodyScrollLock_default as useBodyScrollLock,
|
|
2589
|
+
useClickOutside,
|
|
2590
|
+
useDebounce,
|
|
2591
|
+
useFieldsFocus,
|
|
2592
|
+
useFormFieldsChangesManager_default as useFormFieldsChangesManager,
|
|
2593
|
+
useFormTools,
|
|
2594
|
+
useInputHighlightError_default as useInputHighlightError,
|
|
2595
|
+
useIsMobile_default2 as useIsMobile,
|
|
2596
|
+
useKeyPress_default as useKeyPress,
|
|
2597
|
+
useLocalStorage_default as useLocalStorage,
|
|
2598
|
+
useLocationParams,
|
|
2599
|
+
useMediaQuery_default as useMediaQuery,
|
|
2600
|
+
useMetaInfo_default as useMetaInfo,
|
|
2601
|
+
useMouseUpOutside,
|
|
2602
|
+
useOnlineStatus_default as useOnlineStatus,
|
|
2603
|
+
usePasswordChecker,
|
|
2604
|
+
usePrevious_default as usePrevious,
|
|
2605
|
+
useResize,
|
|
2606
|
+
useScrollTo_default as useScrollTo,
|
|
2607
|
+
useToggle_default as useToggle
|
|
2608
|
+
};
|
|
2609
|
+
//! Важно! Если придет велью с количеством дробных разрядов БОЛЬШИМ
|
|
2610
|
+
//! чем указано в quantity - округлит по правилам округления
|
|
2611
|
+
//! чем указано в decimalPlaces - округлит по правилам округления
|
|
2612
|
+
//# sourceMappingURL=hooks.js.map
|