@apia/components 2.0.9 → 2.0.10
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/components/IconsList/Icon.js +42 -0
- package/dist/components/IconsList/Icon.js.map +1 -0
- package/dist/components/IconsList/IconWrapper.js +24 -0
- package/dist/components/IconsList/IconWrapper.js.map +1 -0
- package/dist/components/IconsList/KeyHandler.js +147 -0
- package/dist/components/IconsList/KeyHandler.js.map +1 -0
- package/dist/components/IconsList/context.js +14 -0
- package/dist/components/IconsList/context.js.map +1 -0
- package/dist/components/IconsList/index.d.ts +12 -0
- package/dist/components/IconsList/index.d.ts.map +1 -0
- package/dist/components/IconsList/index.js +119 -0
- package/dist/components/IconsList/index.js.map +1 -0
- package/dist/components/IconsList/renderers/DefaultIconRenderer.d.ts +7 -0
- package/dist/components/IconsList/renderers/DefaultIconRenderer.d.ts.map +1 -0
- package/dist/components/IconsList/renderers/DefaultIconRenderer.js +30 -0
- package/dist/components/IconsList/renderers/DefaultIconRenderer.js.map +1 -0
- package/dist/components/IconsList/store/context.js +9 -0
- package/dist/components/IconsList/store/context.js.map +1 -0
- package/dist/components/IconsList/store/distinctors.js +42 -0
- package/dist/components/IconsList/store/distinctors.js.map +1 -0
- package/dist/components/IconsList/store/keysMaker.js +8 -0
- package/dist/components/IconsList/store/keysMaker.js.map +1 -0
- package/dist/components/IconsList/store/operations.js +138 -0
- package/dist/components/IconsList/store/operations.js.map +1 -0
- package/dist/components/IconsList/store/state.js +9 -0
- package/dist/components/IconsList/store/state.js.map +1 -0
- package/dist/components/IconsList/store/useStore.js +52 -0
- package/dist/components/IconsList/store/useStore.js.map +1 -0
- package/dist/components/IconsList/styles.js +48 -0
- package/dist/components/IconsList/styles.js.map +1 -0
- package/dist/components/IconsList/types.d.ts +98 -0
- package/dist/components/IconsList/types.d.ts.map +1 -0
- package/dist/components/IconsList/util.js +46 -0
- package/dist/components/IconsList/util.js.map +1 -0
- package/dist/components/ListBox/Combobox.js +52 -0
- package/dist/components/ListBox/Combobox.js.map +1 -0
- package/dist/components/ListBox/ListboxContext.d.ts +35 -0
- package/dist/components/ListBox/ListboxContext.d.ts.map +1 -0
- package/dist/components/ListBox/ListboxContext.js +6 -0
- package/dist/components/ListBox/ListboxContext.js.map +1 -0
- package/dist/components/ListBox/ListboxItem.d.ts +17 -0
- package/dist/components/ListBox/ListboxItem.d.ts.map +1 -0
- package/dist/components/ListBox/ListboxItem.js +67 -0
- package/dist/components/ListBox/ListboxItem.js.map +1 -0
- package/dist/components/ListBox/ListboxKeyhandler.js +154 -0
- package/dist/components/ListBox/ListboxKeyhandler.js.map +1 -0
- package/dist/components/ListBox/common.d.ts +46 -0
- package/dist/components/ListBox/common.d.ts.map +1 -0
- package/dist/components/ListBox/common.js +118 -0
- package/dist/components/ListBox/common.js.map +1 -0
- package/dist/components/ListBox/index.d.ts +21 -0
- package/dist/components/ListBox/index.d.ts.map +1 -0
- package/dist/components/ListBox/index.js +71 -0
- package/dist/components/ListBox/index.js.map +1 -0
- package/dist/components/ListBox/listbox.js +46 -0
- package/dist/components/ListBox/listbox.js.map +1 -0
- package/dist/components/ListBox/operations.js +330 -0
- package/dist/components/ListBox/operations.js.map +1 -0
- package/dist/components/ListBox/useIndexedChildren.js +25 -0
- package/dist/components/ListBox/useIndexedChildren.js.map +1 -0
- package/dist/components/ListBox/useListboxAutofocus.js +48 -0
- package/dist/components/ListBox/useListboxAutofocus.js.map +1 -0
- package/dist/components/ListBox/useListboxContextValue.js +8 -0
- package/dist/components/ListBox/useListboxContextValue.js.map +1 -0
- package/dist/components/ListBox/useShoutSelectionChange.js +26 -0
- package/dist/components/ListBox/useShoutSelectionChange.js.map +1 -0
- package/dist/components/ListBox/useStore.js +36 -0
- package/dist/components/ListBox/useStore.js.map +1 -0
- package/dist/components/ListBox/useUpdateRowCount.js +19 -0
- package/dist/components/ListBox/useUpdateRowCount.js.map +1 -0
- package/dist/components/SortableList/SortableListHandler.js +161 -0
- package/dist/components/SortableList/SortableListHandler.js.map +1 -0
- package/dist/components/SortableList/SortableListItem.d.ts +14 -0
- package/dist/components/SortableList/SortableListItem.d.ts.map +1 -0
- package/dist/components/SortableList/SortableListItem.js +24 -0
- package/dist/components/SortableList/SortableListItem.js.map +1 -0
- package/dist/components/SortableList/index.d.ts +21 -0
- package/dist/components/SortableList/index.d.ts.map +1 -0
- package/dist/components/SortableList/index.js +53 -0
- package/dist/components/SortableList/index.js.map +1 -0
- package/dist/components/Toolbar/ToolbarController.d.ts +24 -0
- package/dist/components/Toolbar/ToolbarController.d.ts.map +1 -0
- package/dist/components/Toolbar/ToolbarController.js +50 -0
- package/dist/components/Toolbar/ToolbarController.js.map +1 -0
- package/dist/components/Toolbar/ToolbarIconButton.d.ts +7 -0
- package/dist/components/Toolbar/ToolbarIconButton.d.ts.map +1 -0
- package/dist/components/Toolbar/ToolbarIconButton.js +108 -0
- package/dist/components/Toolbar/ToolbarIconButton.js.map +1 -0
- package/dist/components/Toolbar/ToolbarInput.d.ts +7 -0
- package/dist/components/Toolbar/ToolbarInput.d.ts.map +1 -0
- package/dist/components/Toolbar/ToolbarInput.js +13 -0
- package/dist/components/Toolbar/ToolbarInput.js.map +1 -0
- package/dist/components/Toolbar/ToolbarSelect.d.ts +7 -0
- package/dist/components/Toolbar/ToolbarSelect.d.ts.map +1 -0
- package/dist/components/Toolbar/ToolbarSelect.js +17 -0
- package/dist/components/Toolbar/ToolbarSelect.js.map +1 -0
- package/dist/components/Toolbar/ToolbarSeparator.d.ts +6 -0
- package/dist/components/Toolbar/ToolbarSeparator.d.ts.map +1 -0
- package/dist/components/Toolbar/ToolbarSeparator.js +9 -0
- package/dist/components/Toolbar/ToolbarSeparator.js.map +1 -0
- package/dist/components/Toolbar/ToolbarTextButton.d.ts +9 -0
- package/dist/components/Toolbar/ToolbarTextButton.d.ts.map +1 -0
- package/dist/components/Toolbar/ToolbarTextButton.js +18 -0
- package/dist/components/Toolbar/ToolbarTextButton.js.map +1 -0
- package/dist/components/Toolbar/index.d.ts +19 -0
- package/dist/components/Toolbar/index.d.ts.map +1 -0
- package/dist/components/Toolbar/index.js +23 -0
- package/dist/components/Toolbar/index.js.map +1 -0
- package/dist/components/Toolbar/styles.js +84 -0
- package/dist/components/Toolbar/styles.js.map +1 -0
- package/dist/components/Toolbar/types.d.ts +39 -0
- package/dist/components/Toolbar/types.d.ts.map +1 -0
- package/dist/components/accordion/Accordion.d.ts +21 -0
- package/dist/components/accordion/Accordion.d.ts.map +1 -0
- package/dist/components/accordion/Accordion.js +66 -0
- package/dist/components/accordion/Accordion.js.map +1 -0
- package/dist/components/accordion/AccordionItem.d.ts +20 -0
- package/dist/components/accordion/AccordionItem.d.ts.map +1 -0
- package/dist/components/accordion/AccordionItem.js +26 -0
- package/dist/components/accordion/AccordionItem.js.map +1 -0
- package/dist/components/accordion/AccordionItemButton.d.ts +10 -0
- package/dist/components/accordion/AccordionItemButton.d.ts.map +1 -0
- package/dist/components/accordion/AccordionItemButton.js +8 -0
- package/dist/components/accordion/AccordionItemButton.js.map +1 -0
- package/dist/components/accordion/AccordionItemContent.d.ts +7 -0
- package/dist/components/accordion/AccordionItemContent.d.ts.map +1 -0
- package/dist/components/accordion/AccordionItemContent.js +50 -0
- package/dist/components/accordion/AccordionItemContent.js.map +1 -0
- package/dist/components/accordion/KeyHandler.js +82 -0
- package/dist/components/accordion/KeyHandler.js.map +1 -0
- package/dist/components/accordion/context.d.ts +10 -0
- package/dist/components/accordion/context.d.ts.map +1 -0
- package/dist/components/accordion/context.js +13 -0
- package/dist/components/accordion/context.js.map +1 -0
- package/dist/components/accordion/defaultElements/Checkbox.js +22 -0
- package/dist/components/accordion/defaultElements/Checkbox.js.map +1 -0
- package/dist/components/accordion/defaultElements/DefaultAccordionItemButton.d.ts +40 -0
- package/dist/components/accordion/defaultElements/DefaultAccordionItemButton.d.ts.map +1 -0
- package/dist/components/accordion/defaultElements/DefaultAccordionItemButton.js +77 -0
- package/dist/components/accordion/defaultElements/DefaultAccordionItemButton.js.map +1 -0
- package/dist/components/accordion/defaultElements/useIsChecked.js +25 -0
- package/dist/components/accordion/defaultElements/useIsChecked.js.map +1 -0
- package/dist/components/accordion/handler.d.ts +40 -0
- package/dist/components/accordion/handler.d.ts.map +1 -0
- package/dist/components/accordion/handler.js +126 -0
- package/dist/components/accordion/handler.js.map +1 -0
- package/dist/components/accordion/index.d.ts +8 -0
- package/dist/components/accordion/index.d.ts.map +1 -0
- package/dist/components/accordion/types.d.ts +11 -0
- package/dist/components/accordion/types.d.ts.map +1 -0
- package/dist/components/apia/ApiaDateFilter.js +57 -0
- package/dist/components/apia/ApiaDateFilter.js.map +1 -0
- package/dist/components/apia/ApiaFilter.d.ts +13 -0
- package/dist/components/apia/ApiaFilter.d.ts.map +1 -0
- package/dist/components/apia/ApiaFilter.js +128 -0
- package/dist/components/apia/ApiaFilter.js.map +1 -0
- package/dist/components/buttons/useOtherTagButton.d.ts +28 -0
- package/dist/components/buttons/useOtherTagButton.d.ts.map +1 -0
- package/dist/components/buttons/useOtherTagButton.js +38 -0
- package/dist/components/buttons/useOtherTagButton.js.map +1 -0
- package/dist/components/collapsiblePanel/index.d.ts +7 -0
- package/dist/components/collapsiblePanel/index.d.ts.map +1 -0
- package/dist/components/collapsiblePanel/index.js +130 -0
- package/dist/components/collapsiblePanel/index.js.map +1 -0
- package/dist/components/collapsiblePanel/styles.js +4 -0
- package/dist/components/collapsiblePanel/styles.js.map +1 -0
- package/dist/components/collapsiblePanel/types.d.ts +23 -0
- package/dist/components/collapsiblePanel/types.d.ts.map +1 -0
- package/dist/components/dialogs/AlertModal.d.ts +11 -0
- package/dist/components/dialogs/AlertModal.d.ts.map +1 -0
- package/dist/components/dialogs/AlertModal.js +42 -0
- package/dist/components/dialogs/AlertModal.js.map +1 -0
- package/dist/components/dialogs/ConfirmModal.d.ts +25 -0
- package/dist/components/dialogs/ConfirmModal.d.ts.map +1 -0
- package/dist/components/dialogs/ConfirmModal.js +45 -0
- package/dist/components/dialogs/ConfirmModal.js.map +1 -0
- package/dist/components/forms/Captcha.d.ts +12 -0
- package/dist/components/forms/Captcha.d.ts.map +1 -0
- package/dist/components/forms/Captcha.js +66 -0
- package/dist/components/forms/Captcha.js.map +1 -0
- package/dist/components/forms/Checkbox.d.ts +21 -0
- package/dist/components/forms/Checkbox.d.ts.map +1 -0
- package/dist/components/forms/Checkbox.js +124 -0
- package/dist/components/forms/Checkbox.js.map +1 -0
- package/dist/components/forms/DateInput.d.ts +44 -0
- package/dist/components/forms/DateInput.d.ts.map +1 -0
- package/dist/components/forms/DateInput.js +246 -0
- package/dist/components/forms/DateInput.js.map +1 -0
- package/dist/components/forms/FieldErrorMessage.d.ts +10 -0
- package/dist/components/forms/FieldErrorMessage.d.ts.map +1 -0
- package/dist/components/forms/FieldErrorMessage.js +34 -0
- package/dist/components/forms/FieldErrorMessage.js.map +1 -0
- package/dist/components/forms/FieldLabel.d.ts +40 -0
- package/dist/components/forms/FieldLabel.d.ts.map +1 -0
- package/dist/components/forms/FieldLabel.js +66 -0
- package/dist/components/forms/FieldLabel.js.map +1 -0
- package/dist/components/forms/IconInput.d.ts +28 -0
- package/dist/components/forms/IconInput.d.ts.map +1 -0
- package/dist/components/forms/IconInput.js +80 -0
- package/dist/components/forms/IconInput.js.map +1 -0
- package/dist/components/forms/NumberInput.d.ts +37 -0
- package/dist/components/forms/NumberInput.d.ts.map +1 -0
- package/dist/components/forms/NumberInput.js +149 -0
- package/dist/components/forms/NumberInput.js.map +1 -0
- package/dist/components/forms/RequiredMark.d.ts +14 -0
- package/dist/components/forms/RequiredMark.d.ts.map +1 -0
- package/dist/components/forms/RequiredMark.js +13 -0
- package/dist/components/forms/RequiredMark.js.map +1 -0
- package/dist/components/forms/buttons/BaseButton.d.ts +24 -0
- package/dist/components/forms/buttons/BaseButton.d.ts.map +1 -0
- package/dist/components/forms/buttons/BaseButton.js +58 -0
- package/dist/components/forms/buttons/BaseButton.js.map +1 -0
- package/dist/components/forms/buttons/IconButton.d.ts +37 -0
- package/dist/components/forms/buttons/IconButton.d.ts.map +1 -0
- package/dist/components/forms/buttons/IconButton.js +79 -0
- package/dist/components/forms/buttons/IconButton.js.map +1 -0
- package/dist/components/forms/buttons/SimpleButton.d.ts +21 -0
- package/dist/components/forms/buttons/SimpleButton.d.ts.map +1 -0
- package/dist/components/forms/buttons/SimpleButton.js +94 -0
- package/dist/components/forms/buttons/SimpleButton.js.map +1 -0
- package/dist/components/forms/util/style.d.ts +7 -0
- package/dist/components/forms/util/style.d.ts.map +1 -0
- package/dist/components/forms/util/style.js +17 -0
- package/dist/components/forms/util/style.js.map +1 -0
- package/dist/components/importComponent.d.ts +11 -0
- package/dist/components/importComponent.d.ts.map +1 -0
- package/dist/components/importComponent.js +25 -0
- package/dist/components/importComponent.js.map +1 -0
- package/dist/components/loaders/LinearLoader.d.ts +6 -0
- package/dist/components/loaders/LinearLoader.d.ts.map +1 -0
- package/dist/components/loaders/LinearLoader.js +33 -0
- package/dist/components/loaders/LinearLoader.js.map +1 -0
- package/dist/components/loaders/LoaderSpinner.d.ts +10 -0
- package/dist/components/loaders/LoaderSpinner.d.ts.map +1 -0
- package/dist/components/loaders/LoaderSpinner.js +26 -0
- package/dist/components/loaders/LoaderSpinner.js.map +1 -0
- package/dist/components/loaders/ProgressBar.d.ts +11 -0
- package/dist/components/loaders/ProgressBar.d.ts.map +1 -0
- package/dist/components/loaders/ProgressBar.js +39 -0
- package/dist/components/loaders/ProgressBar.js.map +1 -0
- package/dist/components/modals/CalendarModal.d.ts +13 -0
- package/dist/components/modals/CalendarModal.d.ts.map +1 -0
- package/dist/components/modals/CalendarModal.js +43 -0
- package/dist/components/modals/CalendarModal.js.map +1 -0
- package/dist/components/modals/Modal.d.ts +178 -0
- package/dist/components/modals/Modal.d.ts.map +1 -0
- package/dist/components/modals/Modal.js +19 -0
- package/dist/components/modals/Modal.js.map +1 -0
- package/dist/components/modals/ModalContext.d.ts +9 -0
- package/dist/components/modals/ModalContext.d.ts.map +1 -0
- package/dist/components/modals/ModalContext.js +12 -0
- package/dist/components/modals/ModalContext.js.map +1 -0
- package/dist/components/modals/Overlay.d.ts +21 -0
- package/dist/components/modals/Overlay.d.ts.map +1 -0
- package/dist/components/modals/Overlay.js +74 -0
- package/dist/components/modals/Overlay.js.map +1 -0
- package/dist/components/modals/StaticModal.js +203 -0
- package/dist/components/modals/StaticModal.js.map +1 -0
- package/dist/components/modals/WindowModal.js +229 -0
- package/dist/components/modals/WindowModal.js.map +1 -0
- package/dist/components/modals/hooks/useEscapeKey.js +36 -0
- package/dist/components/modals/hooks/useEscapeKey.js.map +1 -0
- package/dist/components/modals/hooks/useInitialFocus.js +37 -0
- package/dist/components/modals/hooks/useInitialFocus.js.map +1 -0
- package/dist/components/modals/hooks/useModal.d.ts +97 -0
- package/dist/components/modals/hooks/useModal.d.ts.map +1 -0
- package/dist/components/modals/hooks/useModal.js +73 -0
- package/dist/components/modals/hooks/useModal.js.map +1 -0
- package/dist/components/modals/hooks/useStyleState.js +44 -0
- package/dist/components/modals/hooks/useStyleState.js.map +1 -0
- package/dist/components/modals/layout/Confirm.d.ts +7 -0
- package/dist/components/modals/layout/Confirm.d.ts.map +1 -0
- package/dist/components/modals/layout/Confirm.js +96 -0
- package/dist/components/modals/layout/Confirm.js.map +1 -0
- package/dist/components/modals/layout/DialogButtonBar.d.ts +10 -0
- package/dist/components/modals/layout/DialogButtonBar.d.ts.map +1 -0
- package/dist/components/modals/layout/DialogButtonBar.js +19 -0
- package/dist/components/modals/layout/DialogButtonBar.js.map +1 -0
- package/dist/components/modals/layout/DialogHeader.d.ts +18 -0
- package/dist/components/modals/layout/DialogHeader.d.ts.map +1 -0
- package/dist/components/modals/layout/DialogHeader.js +116 -0
- package/dist/components/modals/layout/DialogHeader.js.map +1 -0
- package/dist/components/responsive/AutoEllipsis.d.ts +21 -0
- package/dist/components/responsive/AutoEllipsis.d.ts.map +1 -0
- package/dist/components/responsive/AutoEllipsis.js +128 -0
- package/dist/components/responsive/AutoEllipsis.js.map +1 -0
- package/dist/components/responsive/makeResponsiveComponent.d.ts +38 -0
- package/dist/components/responsive/makeResponsiveComponent.d.ts.map +1 -0
- package/dist/components/responsive/makeResponsiveComponent.js +88 -0
- package/dist/components/responsive/makeResponsiveComponent.js.map +1 -0
- package/dist/components/types.d.ts +5 -0
- package/dist/components/types.d.ts.map +1 -0
- package/dist/components/waiAriaHelpers/typeAhead.d.ts +44 -0
- package/dist/components/waiAriaHelpers/typeAhead.d.ts.map +1 -0
- package/dist/components/waiAriaHelpers/typeAhead.js +75 -0
- package/dist/components/waiAriaHelpers/typeAhead.js.map +1 -0
- package/dist/globalFocus.js +95 -0
- package/dist/globalFocus.js.map +1 -0
- package/dist/hooks/useBodyScrollLock.js +106 -0
- package/dist/hooks/useBodyScrollLock.js.map +1 -0
- package/dist/index.d.ts +69 -1658
- package/dist/index.js +58 -7198
- package/dist/index.js.map +1 -1
- package/dist/objects/ApiaUtil/dialogs/ApiaUtilDialogs.d.ts +18 -0
- package/dist/objects/ApiaUtil/dialogs/ApiaUtilDialogs.d.ts.map +1 -0
- package/dist/objects/ApiaUtil/dialogs/ApiaUtilDialogs.js +116 -0
- package/dist/objects/ApiaUtil/dialogs/ApiaUtilDialogs.js.map +1 -0
- package/dist/objects/ApiaUtil/index.d.ts +27 -0
- package/dist/objects/ApiaUtil/index.d.ts.map +1 -0
- package/dist/objects/ApiaUtil/index.js +89 -0
- package/dist/objects/ApiaUtil/index.js.map +1 -0
- package/dist/objects/ApiaUtil/menu/ApiaUtilMenu.d.ts +23 -0
- package/dist/objects/ApiaUtil/menu/ApiaUtilMenu.d.ts.map +1 -0
- package/dist/objects/ApiaUtil/menu/ApiaUtilMenu.js +108 -0
- package/dist/objects/ApiaUtil/menu/ApiaUtilMenu.js.map +1 -0
- package/dist/objects/ApiaUtil/modals/ApiaUtilModals.d.ts +17 -0
- package/dist/objects/ApiaUtil/modals/ApiaUtilModals.d.ts.map +1 -0
- package/dist/objects/ApiaUtil/modals/ApiaUtilModals.js +111 -0
- package/dist/objects/ApiaUtil/modals/ApiaUtilModals.js.map +1 -0
- package/dist/objects/ApiaUtil/modals/OpenModal.d.ts +38 -0
- package/dist/objects/ApiaUtil/modals/OpenModal.d.ts.map +1 -0
- package/dist/objects/ApiaUtil/modals/OpenModal.js +37 -0
- package/dist/objects/ApiaUtil/modals/OpenModal.js.map +1 -0
- package/dist/objects/ApiaUtil/mouse/ApiaUtilMouse.d.ts +19 -0
- package/dist/objects/ApiaUtil/mouse/ApiaUtilMouse.d.ts.map +1 -0
- package/dist/objects/ApiaUtil/mouse/ApiaUtilMouse.js +26 -0
- package/dist/objects/ApiaUtil/mouse/ApiaUtilMouse.js.map +1 -0
- package/dist/objects/ApiaUtil/notifications/ApiaUtilNotifications.d.ts +14 -0
- package/dist/objects/ApiaUtil/notifications/ApiaUtilNotifications.d.ts.map +1 -0
- package/dist/objects/ApiaUtil/notifications/ApiaUtilNotifications.js +33 -0
- package/dist/objects/ApiaUtil/notifications/ApiaUtilNotifications.js.map +1 -0
- package/dist/objects/ApiaUtil/parsers/ApiaUtilParsers.d.ts +23 -0
- package/dist/objects/ApiaUtil/parsers/ApiaUtilParsers.d.ts.map +1 -0
- package/dist/objects/ApiaUtil/parsers/ApiaUtilParsers.js +79 -0
- package/dist/objects/ApiaUtil/parsers/ApiaUtilParsers.js.map +1 -0
- package/dist/objects/ApiaUtil/tabs/ApiaUtilCurrentTab.d.ts +33 -0
- package/dist/objects/ApiaUtil/tabs/ApiaUtilCurrentTab.d.ts.map +1 -0
- package/dist/objects/ApiaUtil/tabs/ApiaUtilCurrentTab.js +50 -0
- package/dist/objects/ApiaUtil/tabs/ApiaUtilCurrentTab.js.map +1 -0
- package/dist/objects/ApiaUtil/tabs/ApiaUtilTabsController.d.ts +20 -0
- package/dist/objects/ApiaUtil/tabs/ApiaUtilTabsController.d.ts.map +1 -0
- package/dist/objects/ApiaUtil/tabs/ApiaUtilTabsController.js +37 -0
- package/dist/objects/ApiaUtil/tabs/ApiaUtilTabsController.js.map +1 -0
- package/dist/objects/ApiaUtil/tabs/util.js +17 -0
- package/dist/objects/ApiaUtil/tabs/util.js.map +1 -0
- package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltip.d.ts +11 -0
- package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltip.d.ts.map +1 -0
- package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltip.js +17 -0
- package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltip.js.map +1 -0
- package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltips.d.ts +22 -0
- package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltips.d.ts.map +1 -0
- package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltips.js +104 -0
- package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltips.js.map +1 -0
- package/dist/objects/ApiaUtil/tooltips/AutomaticTooltip.d.ts +13 -0
- package/dist/objects/ApiaUtil/tooltips/AutomaticTooltip.d.ts.map +1 -0
- package/dist/objects/ApiaUtil/tooltips/AutomaticTooltip.js +79 -0
- package/dist/objects/ApiaUtil/tooltips/AutomaticTooltip.js.map +1 -0
- package/dist/objects/ApiaUtil/tooltips/tooltip/Tooltip.js +62 -0
- package/dist/objects/ApiaUtil/tooltips/tooltip/Tooltip.js.map +1 -0
- package/dist/objects/ApiaUtil/tooltips/tooltip/types.d.ts +117 -0
- package/dist/objects/ApiaUtil/tooltips/tooltip/types.d.ts.map +1 -0
- package/dist/objects/ApiaUtil/tooltips/tooltip/util.js +273 -0
- package/dist/objects/ApiaUtil/tooltips/tooltip/util.js.map +1 -0
- package/dist/objects/ScreenLocker/index.d.ts +37 -0
- package/dist/objects/ScreenLocker/index.d.ts.map +1 -0
- package/dist/objects/ScreenLocker/index.js +92 -0
- package/dist/objects/ScreenLocker/index.js.map +1 -0
- package/dist/tabs/Content.d.ts +7 -0
- package/dist/tabs/Content.d.ts.map +1 -0
- package/dist/tabs/Content.js +52 -0
- package/dist/tabs/Content.js.map +1 -0
- package/dist/tabs/ContextMenu.js +76 -0
- package/dist/tabs/ContextMenu.js.map +1 -0
- package/dist/tabs/Item.js +63 -0
- package/dist/tabs/Item.js.map +1 -0
- package/dist/tabs/Tabs.d.ts +8 -0
- package/dist/tabs/Tabs.d.ts.map +1 -0
- package/dist/tabs/Tabs.js +78 -0
- package/dist/tabs/Tabs.js.map +1 -0
- package/dist/tabs/TabsList.d.ts +8 -0
- package/dist/tabs/TabsList.d.ts.map +1 -0
- package/dist/tabs/TabsList.js +138 -0
- package/dist/tabs/TabsList.js.map +1 -0
- package/dist/tabs/renderers/DefaultTabsLabelRenderer.d.ts +6 -0
- package/dist/tabs/renderers/DefaultTabsLabelRenderer.d.ts.map +1 -0
- package/dist/tabs/renderers/DefaultTabsLabelRenderer.js +71 -0
- package/dist/tabs/renderers/DefaultTabsLabelRenderer.js.map +1 -0
- package/dist/tabs/tabsController.d.ts +41 -0
- package/dist/tabs/tabsController.d.ts.map +1 -0
- package/dist/tabs/tabsController.js +303 -0
- package/dist/tabs/tabsController.js.map +1 -0
- package/dist/tabs/types.d.ts +115 -0
- package/dist/tabs/types.d.ts.map +1 -0
- package/dist/tabs/useTabsList.js +20 -0
- package/dist/tabs/useTabsList.js.map +1 -0
- package/dist/tabs/util.js +11 -0
- package/dist/tabs/util.js.map +1 -0
- package/package.json +2 -2
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
import { jsx, jsxs, Fragment } from '@apia/theme/jsx-runtime';
|
|
2
|
+
import { Button, getVariant, Input } from '@apia/theme';
|
|
3
|
+
import { useUpdateEffect, getSpecificParent } from '@apia/util';
|
|
4
|
+
import { forwardRef, useState, useRef, useMemo, useEffect } from 'react';
|
|
5
|
+
import { Icon } from '@apia/icons';
|
|
6
|
+
|
|
7
|
+
const Checkbox = forwardRef(
|
|
8
|
+
({
|
|
9
|
+
onChange,
|
|
10
|
+
required,
|
|
11
|
+
disabled,
|
|
12
|
+
readOnly,
|
|
13
|
+
name,
|
|
14
|
+
native,
|
|
15
|
+
indeterminate,
|
|
16
|
+
...props
|
|
17
|
+
}, ref) => {
|
|
18
|
+
const [isChecked, setIsChecked] = useState(
|
|
19
|
+
props.defaultChecked ?? props.checked ?? false
|
|
20
|
+
);
|
|
21
|
+
const checkbox = useRef(null);
|
|
22
|
+
useUpdateEffect(
|
|
23
|
+
() => setIsChecked(props.checked ?? false),
|
|
24
|
+
[props.checked]
|
|
25
|
+
);
|
|
26
|
+
const sx = useMemo(
|
|
27
|
+
() => ({
|
|
28
|
+
bg: props.background ?? void 0,
|
|
29
|
+
color: props.color ?? void 0,
|
|
30
|
+
'&[aria-checked="false"]': {
|
|
31
|
+
bg: props.background ?? void 0,
|
|
32
|
+
color: "transparent"
|
|
33
|
+
}
|
|
34
|
+
}),
|
|
35
|
+
[props.background, props.color]
|
|
36
|
+
);
|
|
37
|
+
useEffect(() => {
|
|
38
|
+
if (checkbox.current && indeterminate !== void 0)
|
|
39
|
+
checkbox.current.indeterminate = indeterminate;
|
|
40
|
+
}, [indeterminate]);
|
|
41
|
+
const nativeSx = useMemo(
|
|
42
|
+
() => ({ variant: "forms.checkbox" }),
|
|
43
|
+
[]
|
|
44
|
+
);
|
|
45
|
+
return native ? (
|
|
46
|
+
// eslint-disable-next-line react/forbid-elements
|
|
47
|
+
/* @__PURE__ */ jsx(
|
|
48
|
+
"input",
|
|
49
|
+
{
|
|
50
|
+
type: "checkbox",
|
|
51
|
+
onClick: props.onClick,
|
|
52
|
+
"aria-checked": isChecked,
|
|
53
|
+
sx: nativeSx,
|
|
54
|
+
ref: checkbox,
|
|
55
|
+
disabled,
|
|
56
|
+
name,
|
|
57
|
+
checked: isChecked,
|
|
58
|
+
onChange: (ev) => {
|
|
59
|
+
if (props.checked === void 0)
|
|
60
|
+
setIsChecked(ev.target.checked);
|
|
61
|
+
if (onChange)
|
|
62
|
+
onChange(ev);
|
|
63
|
+
},
|
|
64
|
+
required,
|
|
65
|
+
className: ` ${props.className ?? ""} nativeCheckbox `,
|
|
66
|
+
...props
|
|
67
|
+
}
|
|
68
|
+
)
|
|
69
|
+
) : /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
70
|
+
/* @__PURE__ */ jsx(
|
|
71
|
+
Button,
|
|
72
|
+
{
|
|
73
|
+
...props,
|
|
74
|
+
onClick: (ev) => {
|
|
75
|
+
if (readOnly) {
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
if (getSpecificParent(
|
|
79
|
+
ev.target,
|
|
80
|
+
(current) => current.type === "button"
|
|
81
|
+
)) {
|
|
82
|
+
if (props.onClick)
|
|
83
|
+
props.onClick(ev);
|
|
84
|
+
checkbox.current?.click();
|
|
85
|
+
}
|
|
86
|
+
},
|
|
87
|
+
type: "button",
|
|
88
|
+
...getVariant("forms.customCheckbox"),
|
|
89
|
+
role: "checkbox",
|
|
90
|
+
"aria-checked": isChecked,
|
|
91
|
+
sx,
|
|
92
|
+
ref,
|
|
93
|
+
disabled,
|
|
94
|
+
children: /* @__PURE__ */ jsx(Icon, { title: "", name: "Check", size: "32px" })
|
|
95
|
+
}
|
|
96
|
+
),
|
|
97
|
+
/* @__PURE__ */ jsx(
|
|
98
|
+
Input,
|
|
99
|
+
{
|
|
100
|
+
type: "checkbox",
|
|
101
|
+
sx: { display: "none" },
|
|
102
|
+
ref: checkbox,
|
|
103
|
+
onClick: (ev) => {
|
|
104
|
+
ev.stopPropagation();
|
|
105
|
+
},
|
|
106
|
+
name,
|
|
107
|
+
checked: isChecked,
|
|
108
|
+
onChange: (ev) => {
|
|
109
|
+
if (props.checked === void 0)
|
|
110
|
+
setIsChecked(ev.target.checked);
|
|
111
|
+
if (onChange)
|
|
112
|
+
onChange(ev);
|
|
113
|
+
},
|
|
114
|
+
required,
|
|
115
|
+
disabled
|
|
116
|
+
}
|
|
117
|
+
)
|
|
118
|
+
] });
|
|
119
|
+
}
|
|
120
|
+
);
|
|
121
|
+
Checkbox.displayName = "Checkbox";
|
|
122
|
+
|
|
123
|
+
export { Checkbox };
|
|
124
|
+
//# sourceMappingURL=Checkbox.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Checkbox.js","sources":["../../../src/components/forms/Checkbox.tsx"],"sourcesContent":["import {\r\n Button,\r\n ButtonProps,\r\n Input,\r\n InputProps,\r\n ThemeUIStyleObject,\r\n} from '@apia/theme';\r\nimport { TModify, getSpecificParent, useUpdateEffect } from '@apia/util';\r\nimport {\r\n ChangeEventHandler,\r\n forwardRef,\r\n MouseEventHandler,\r\n useEffect,\r\n useMemo,\r\n useRef,\r\n useState,\r\n} from 'react';\r\nimport { getVariant } from '@apia/theme';\r\nimport { Icon } from '@apia/icons';\r\n\r\nexport type TCheckbox = TModify<\r\n ButtonProps,\r\n {\r\n background?: string;\r\n checked?: boolean;\r\n color?: string;\r\n defaultChecked?: boolean;\r\n indeterminate?: boolean;\r\n native?: boolean;\r\n onChange?: ChangeEventHandler<HTMLInputElement>;\r\n readOnly?: boolean;\r\n required?: boolean;\r\n type?: string;\r\n }\r\n>;\r\n\r\nexport const Checkbox = forwardRef<HTMLButtonElement, TCheckbox>(\r\n (\r\n {\r\n onChange,\r\n required,\r\n disabled,\r\n readOnly,\r\n name,\r\n native,\r\n indeterminate,\r\n ...props\r\n },\r\n ref,\r\n ) => {\r\n const [isChecked, setIsChecked] = useState(\r\n props.defaultChecked ?? props.checked ?? false,\r\n );\r\n\r\n const checkbox = useRef<HTMLInputElement>(null);\r\n\r\n useUpdateEffect(\r\n () => setIsChecked(props.checked ?? false),\r\n [props.checked],\r\n );\r\n\r\n const sx = useMemo(\r\n () => ({\r\n bg: props.background ?? undefined,\r\n color: props.color ?? undefined,\r\n '&[aria-checked=\"false\"]': {\r\n bg: props.background ?? undefined,\r\n color: 'transparent',\r\n },\r\n }),\r\n [props.background, props.color],\r\n );\r\n\r\n useEffect(() => {\r\n if (checkbox.current && indeterminate !== undefined)\r\n checkbox.current.indeterminate = indeterminate;\r\n }, [indeterminate]);\r\n\r\n const nativeSx = useMemo(\r\n () => ({ variant: 'forms.checkbox' } as ThemeUIStyleObject),\r\n [],\r\n );\r\n\r\n return native ? (\r\n // eslint-disable-next-line react/forbid-elements\r\n <input\r\n type=\"checkbox\"\r\n onClick={props.onClick as unknown as MouseEventHandler}\r\n aria-checked={isChecked}\r\n sx={nativeSx}\r\n ref={checkbox}\r\n disabled={disabled}\r\n name={name}\r\n checked={isChecked}\r\n onChange={(ev) => {\r\n if (props.checked === undefined) setIsChecked(ev.target.checked);\r\n if (onChange) onChange(ev);\r\n }}\r\n required={required}\r\n className={` ${props.className ?? ''} nativeCheckbox `}\r\n {...(props as unknown as InputProps)}\r\n />\r\n ) : (\r\n <>\r\n <Button\r\n {...props}\r\n onClick={(ev) => {\r\n if (readOnly) {\r\n return;\r\n }\r\n if (\r\n getSpecificParent(\r\n ev.target as HTMLElement,\r\n (current) => (current as HTMLInputElement).type === 'button',\r\n )\r\n ) {\r\n if (props.onClick) props.onClick(ev);\r\n checkbox.current?.click();\r\n }\r\n }}\r\n type=\"button\"\r\n {...getVariant('forms.customCheckbox')}\r\n role=\"checkbox\"\r\n aria-checked={isChecked}\r\n sx={sx}\r\n ref={ref}\r\n disabled={disabled}\r\n >\r\n <Icon title=\"\" name=\"Check\" size=\"32px\" />\r\n </Button>\r\n <Input\r\n type=\"checkbox\"\r\n sx={{ display: 'none' }}\r\n ref={checkbox}\r\n onClick={(ev) => {\r\n ev.stopPropagation();\r\n }}\r\n name={name}\r\n checked={isChecked}\r\n onChange={(ev) => {\r\n if (props.checked === undefined) setIsChecked(ev.target.checked);\r\n if (onChange) onChange(ev);\r\n }}\r\n required={required}\r\n disabled={disabled}\r\n />\r\n </>\r\n );\r\n },\r\n);\r\n\r\nCheckbox.displayName = 'Checkbox';\r\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { InputProps } from '@apia/theme';
|
|
2
|
+
import { TModify } from '@apia/util';
|
|
3
|
+
import React__default from 'react';
|
|
4
|
+
import { IIconInput } from './IconInput.js';
|
|
5
|
+
|
|
6
|
+
declare global {
|
|
7
|
+
interface Window {
|
|
8
|
+
LANG_CODE: string;
|
|
9
|
+
MSG_INVALID_DATE: string;
|
|
10
|
+
MSG_FEC_FIN_MAY_FEC_INI: string;
|
|
11
|
+
LBL_PICK_DATE: string;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
type TDateProps = TModify<InputProps, {
|
|
15
|
+
allowPickBeforeToday?: boolean;
|
|
16
|
+
error?: string | null;
|
|
17
|
+
/**
|
|
18
|
+
* Con esta propiedad se puede proveer una función que será utilizada para
|
|
19
|
+
* determinar qué máscara debe utilizar el input
|
|
20
|
+
*/
|
|
21
|
+
getCustomMask?: () => string;
|
|
22
|
+
isLoading?: boolean;
|
|
23
|
+
/**
|
|
24
|
+
* Recibe la nueva fecha. En caso de devolver
|
|
25
|
+
* false desde este método, el nuevo valor no
|
|
26
|
+
* se persistirá.
|
|
27
|
+
*/
|
|
28
|
+
onChange?: (newValue: string) => boolean | string | void;
|
|
29
|
+
/**
|
|
30
|
+
* Es llamado cada vez que alguien presiona el botón de eliminar fecha.
|
|
31
|
+
*/
|
|
32
|
+
onDelete?: () => void;
|
|
33
|
+
onError?: (error: string | null) => unknown;
|
|
34
|
+
/**
|
|
35
|
+
* Con esta propiedad se puede proveer una función que recibirá como
|
|
36
|
+
* parámetro el valor actual del cmapo y debe devolver el valor a mostrar.
|
|
37
|
+
*/
|
|
38
|
+
renderLabel?: (value: string) => string;
|
|
39
|
+
value?: string;
|
|
40
|
+
}> & Pick<IIconInput, 'buttonProps'>;
|
|
41
|
+
declare const DateInput: React__default.ForwardRefExoticComponent<Omit<TDateProps, "ref"> & React__default.RefAttributes<HTMLInputElement>>;
|
|
42
|
+
|
|
43
|
+
export { DateInput, type TDateProps };
|
|
44
|
+
//# sourceMappingURL=DateInput.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DateInput.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
|
|
@@ -0,0 +1,246 @@
|
|
|
1
|
+
import { jsx, jsxs, Fragment } from '@apia/theme/jsx-runtime';
|
|
2
|
+
import { Close, Box, getVariant } from '@apia/theme';
|
|
3
|
+
import { getDateFormat, useUpdateEffect, isChild } from '@apia/util';
|
|
4
|
+
import dayjs from 'dayjs';
|
|
5
|
+
import uniqueId from 'lodash-es/uniqueId';
|
|
6
|
+
import React__default from 'react';
|
|
7
|
+
import { icons } from '@apia/icons';
|
|
8
|
+
import globalFocus from '../../globalFocus.js';
|
|
9
|
+
import { CalendarModal } from '../modals/CalendarModal.js';
|
|
10
|
+
import { FieldErrorMessage } from './FieldErrorMessage.js';
|
|
11
|
+
import { IconInput } from './IconInput.js';
|
|
12
|
+
import { getFieldErrorStyles } from './util/style.js';
|
|
13
|
+
import { useModal } from '../modals/hooks/useModal.js';
|
|
14
|
+
|
|
15
|
+
const DEFAULT_LOCALE = window.LANG_CODE;
|
|
16
|
+
const DEFAULT_MASK_PLACEHOLDER = "_";
|
|
17
|
+
const dateFormat = getDateFormat();
|
|
18
|
+
const getMaskForDateFormat = () => {
|
|
19
|
+
if (dateFormat === "YYYY/MM/DD")
|
|
20
|
+
return "9999/99/99";
|
|
21
|
+
return "99/99/9999";
|
|
22
|
+
};
|
|
23
|
+
const DateInput = React__default.forwardRef(
|
|
24
|
+
({
|
|
25
|
+
allowPickBeforeToday,
|
|
26
|
+
buttonProps: outerButtonProps,
|
|
27
|
+
className,
|
|
28
|
+
error,
|
|
29
|
+
getCustomMask,
|
|
30
|
+
isLoading,
|
|
31
|
+
onBlur,
|
|
32
|
+
onChange,
|
|
33
|
+
onDelete,
|
|
34
|
+
onError,
|
|
35
|
+
renderLabel,
|
|
36
|
+
value: outerValue,
|
|
37
|
+
...props
|
|
38
|
+
}, ref) => {
|
|
39
|
+
const id = React__default.useMemo(uniqueId, []);
|
|
40
|
+
const [inputValue, setInputValue] = React__default.useState(outerValue ?? "");
|
|
41
|
+
const [calValue, setCalValue] = React__default.useState();
|
|
42
|
+
const boxRef = React__default.useRef(null);
|
|
43
|
+
const { show, hide, ...modalProps } = useModal({
|
|
44
|
+
preFetcher() {
|
|
45
|
+
globalFocus.focus = () => boxRef.current?.querySelector(".iconButton");
|
|
46
|
+
return new Promise((resolve) => {
|
|
47
|
+
let currentSelectedDate = dayjs(inputValue, dateFormat);
|
|
48
|
+
if (!currentSelectedDate.isValid())
|
|
49
|
+
currentSelectedDate = dayjs(/* @__PURE__ */ new Date());
|
|
50
|
+
setCalValue(currentSelectedDate.toDate());
|
|
51
|
+
resolve();
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
const [stateError, setError] = React__default.useState(error ?? null);
|
|
56
|
+
const lastEmittedValue = React__default.useRef(outerValue ?? "");
|
|
57
|
+
useUpdateEffect(() => {
|
|
58
|
+
setInputValue(outerValue ?? "");
|
|
59
|
+
lastEmittedValue.current = outerValue;
|
|
60
|
+
}, [outerValue]);
|
|
61
|
+
useUpdateEffect(() => {
|
|
62
|
+
setError(error ?? null);
|
|
63
|
+
}, [error]);
|
|
64
|
+
useUpdateEffect(() => {
|
|
65
|
+
if (onError)
|
|
66
|
+
onError(stateError);
|
|
67
|
+
}, [stateError]);
|
|
68
|
+
const shoutOnChange = React__default.useCallback(
|
|
69
|
+
(newValue) => {
|
|
70
|
+
if (newValue !== lastEmittedValue.current && onChange) {
|
|
71
|
+
lastEmittedValue.current = newValue;
|
|
72
|
+
return onChange(newValue);
|
|
73
|
+
}
|
|
74
|
+
return true;
|
|
75
|
+
},
|
|
76
|
+
[onChange]
|
|
77
|
+
);
|
|
78
|
+
const setCalendarValue = React__default.useCallback(
|
|
79
|
+
(value, nocheck) => {
|
|
80
|
+
if (value === "") {
|
|
81
|
+
void shoutOnChange("");
|
|
82
|
+
setInputValue("");
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
let newDate;
|
|
86
|
+
if (value !== "") {
|
|
87
|
+
newDate = dayjs(value, dateFormat);
|
|
88
|
+
if (!newDate.isValid())
|
|
89
|
+
newDate = dayjs(/* @__PURE__ */ new Date());
|
|
90
|
+
} else {
|
|
91
|
+
newDate = dayjs(/* @__PURE__ */ new Date());
|
|
92
|
+
}
|
|
93
|
+
const formattedDate = newDate.format(dateFormat);
|
|
94
|
+
const today = /* @__PURE__ */ new Date();
|
|
95
|
+
today.setHours(0, 0, 0, 0);
|
|
96
|
+
if (formattedDate !== inputValue && nocheck !== true) {
|
|
97
|
+
void shoutOnChange("");
|
|
98
|
+
setInputValue("");
|
|
99
|
+
setError(window.MSG_INVALID_DATE);
|
|
100
|
+
} else if (allowPickBeforeToday === false && newDate.isBefore(today)) {
|
|
101
|
+
void shoutOnChange("");
|
|
102
|
+
setInputValue("");
|
|
103
|
+
setError(window.MSG_FEC_FIN_MAY_FEC_INI);
|
|
104
|
+
} else {
|
|
105
|
+
const shoutResult = shoutOnChange(value === "" ? "" : formattedDate);
|
|
106
|
+
if (shoutResult === false) {
|
|
107
|
+
setInputValue(shoutResult || "");
|
|
108
|
+
setError(null);
|
|
109
|
+
} else if (typeof shoutResult === "string") {
|
|
110
|
+
setInputValue("");
|
|
111
|
+
setError(shoutResult);
|
|
112
|
+
} else {
|
|
113
|
+
setInputValue(formattedDate);
|
|
114
|
+
setError(null);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
},
|
|
118
|
+
[allowPickBeforeToday, inputValue, shoutOnChange]
|
|
119
|
+
);
|
|
120
|
+
const selectDate = React__default.useCallback(
|
|
121
|
+
(val) => {
|
|
122
|
+
hide();
|
|
123
|
+
const newValue = dayjs(val).format(dateFormat);
|
|
124
|
+
setCalendarValue(newValue, true);
|
|
125
|
+
},
|
|
126
|
+
[hide, setCalendarValue]
|
|
127
|
+
);
|
|
128
|
+
const onCloseCalendarModal = React__default.useCallback(() => {
|
|
129
|
+
hide();
|
|
130
|
+
}, [hide]);
|
|
131
|
+
const handleBlur = React__default.useCallback(
|
|
132
|
+
(ev) => {
|
|
133
|
+
if (onBlur && !isChild(ev.relatedTarget, (current) => {
|
|
134
|
+
return current.id === `DateModal${id}` || current.id === `DateInput${id}`;
|
|
135
|
+
})) {
|
|
136
|
+
onBlur(ev);
|
|
137
|
+
}
|
|
138
|
+
},
|
|
139
|
+
[id, onBlur]
|
|
140
|
+
);
|
|
141
|
+
const inputProps = React__default.useMemo(
|
|
142
|
+
() => ({
|
|
143
|
+
...props,
|
|
144
|
+
className: "dateInput",
|
|
145
|
+
value: renderLabel ? renderLabel(inputValue) : inputValue,
|
|
146
|
+
ref,
|
|
147
|
+
onChange: (ev) => {
|
|
148
|
+
setInputValue(ev.target.value);
|
|
149
|
+
if (getMaskForDateFormat().replaceAll("9", DEFAULT_MASK_PLACEHOLDER) !== ev.target.value && ev.target.value !== "")
|
|
150
|
+
setError(null);
|
|
151
|
+
},
|
|
152
|
+
onBlur: (ev) => {
|
|
153
|
+
if (!(props.readOnly || getCustomMask))
|
|
154
|
+
setCalendarValue(ev.target.value);
|
|
155
|
+
handleBlur(ev);
|
|
156
|
+
},
|
|
157
|
+
onKeyDown: (ev) => {
|
|
158
|
+
if (ev.key === "Enter")
|
|
159
|
+
setCalendarValue(inputValue);
|
|
160
|
+
}
|
|
161
|
+
}),
|
|
162
|
+
[
|
|
163
|
+
getCustomMask,
|
|
164
|
+
handleBlur,
|
|
165
|
+
inputValue,
|
|
166
|
+
props,
|
|
167
|
+
ref,
|
|
168
|
+
renderLabel,
|
|
169
|
+
setCalendarValue
|
|
170
|
+
]
|
|
171
|
+
);
|
|
172
|
+
const buttonProps = React__default.useMemo(
|
|
173
|
+
() => ({
|
|
174
|
+
disabled: props.disabled ?? props.readOnly,
|
|
175
|
+
"aria-label": window.LBL_PICK_DATE,
|
|
176
|
+
...outerButtonProps
|
|
177
|
+
}),
|
|
178
|
+
[outerButtonProps, props.disabled, props.readOnly]
|
|
179
|
+
);
|
|
180
|
+
const additionalButtons = React__default.useMemo(
|
|
181
|
+
() => /* @__PURE__ */ jsx(
|
|
182
|
+
Close,
|
|
183
|
+
{
|
|
184
|
+
className: "delete_date_button",
|
|
185
|
+
onClick: () => {
|
|
186
|
+
setCalendarValue("");
|
|
187
|
+
onDelete?.();
|
|
188
|
+
document.querySelector(
|
|
189
|
+
`#DateInput${id} input`
|
|
190
|
+
)?.focus();
|
|
191
|
+
},
|
|
192
|
+
type: "button"
|
|
193
|
+
}
|
|
194
|
+
),
|
|
195
|
+
[id, onDelete, setCalendarValue]
|
|
196
|
+
);
|
|
197
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
198
|
+
/* @__PURE__ */ jsx(
|
|
199
|
+
CalendarModal,
|
|
200
|
+
{
|
|
201
|
+
...modalProps,
|
|
202
|
+
calValue,
|
|
203
|
+
locale: DEFAULT_LOCALE,
|
|
204
|
+
handleClickDay: selectDate,
|
|
205
|
+
onCancel: onCloseCalendarModal,
|
|
206
|
+
id: `DateModal${id}`
|
|
207
|
+
}
|
|
208
|
+
),
|
|
209
|
+
/* @__PURE__ */ jsxs(
|
|
210
|
+
Box,
|
|
211
|
+
{
|
|
212
|
+
...getVariant("forms.dateInput"),
|
|
213
|
+
className: `${className ?? ""} dateInput`,
|
|
214
|
+
id: `DateInput${id}`,
|
|
215
|
+
ref: boxRef,
|
|
216
|
+
children: [
|
|
217
|
+
/* @__PURE__ */ jsx(
|
|
218
|
+
IconInput,
|
|
219
|
+
{
|
|
220
|
+
additionalButtons: inputValue && inputValue !== getMaskForDateFormat().replaceAll(
|
|
221
|
+
"9",
|
|
222
|
+
DEFAULT_MASK_PLACEHOLDER
|
|
223
|
+
) && !props.readOnly && !props.disabled ? additionalButtons : void 0,
|
|
224
|
+
isLoading,
|
|
225
|
+
maskPlaceholder: DEFAULT_MASK_PLACEHOLDER,
|
|
226
|
+
mask: getCustomMask ? getCustomMask() : getMaskForDateFormat(),
|
|
227
|
+
icon: icons.Calendar,
|
|
228
|
+
onBlur: handleBlur,
|
|
229
|
+
buttonProps,
|
|
230
|
+
inputProps,
|
|
231
|
+
readOnly: props.readOnly,
|
|
232
|
+
sx: getFieldErrorStyles(stateError === null),
|
|
233
|
+
onClick: show
|
|
234
|
+
}
|
|
235
|
+
),
|
|
236
|
+
stateError && /* @__PURE__ */ jsx(FieldErrorMessage, { children: stateError })
|
|
237
|
+
]
|
|
238
|
+
}
|
|
239
|
+
)
|
|
240
|
+
] });
|
|
241
|
+
}
|
|
242
|
+
);
|
|
243
|
+
DateInput.displayName = "DateInput";
|
|
244
|
+
|
|
245
|
+
export { DateInput };
|
|
246
|
+
//# sourceMappingURL=DateInput.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DateInput.js","sources":["../../../src/components/forms/DateInput.tsx"],"sourcesContent":["import { getVariant, Box, Close, InputProps } from '@apia/theme';\r\nimport {\r\n getDateFormat,\r\n isChild,\r\n TDateFormat,\r\n TModify,\r\n useUpdateEffect,\r\n} from '@apia/util';\r\nimport dayjs from 'dayjs';\r\nimport uniqueId from 'lodash-es/uniqueId';\r\nimport React from 'react';\r\nimport { icons } from '@apia/icons';\r\nimport globalFocus from '../../globalFocus';\r\nimport { useModal } from '../modals';\r\nimport { CalendarModal } from '../modals/CalendarModal';\r\nimport { FieldErrorMessage } from './FieldErrorMessage';\r\nimport { IconInput, IIconInput } from './IconInput';\r\nimport { getFieldErrorStyles } from './util/style';\r\n\r\ndeclare global {\r\n interface Window {\r\n LANG_CODE: string;\r\n MSG_INVALID_DATE: string;\r\n MSG_FEC_FIN_MAY_FEC_INI: string;\r\n LBL_PICK_DATE: string;\r\n }\r\n}\r\n\r\nconst DEFAULT_LOCALE = window.LANG_CODE;\r\nconst DEFAULT_MASK_PLACEHOLDER = '_';\r\n\r\nconst dateFormat: TDateFormat = getDateFormat();\r\n\r\nconst getMaskForDateFormat = (): string => {\r\n if (dateFormat === 'YYYY/MM/DD') return '9999/99/99';\r\n return '99/99/9999';\r\n};\r\n\r\nexport type TDateProps = TModify<\r\n InputProps,\r\n {\r\n allowPickBeforeToday?: boolean;\r\n error?: string | null;\r\n /**\r\n * Con esta propiedad se puede proveer una función que será utilizada para\r\n * determinar qué máscara debe utilizar el input\r\n */\r\n getCustomMask?: () => string;\r\n isLoading?: boolean;\r\n /**\r\n * Recibe la nueva fecha. En caso de devolver\r\n * false desde este método, el nuevo valor no\r\n * se persistirá.\r\n */\r\n onChange?: (newValue: string) => boolean | string | void;\r\n /**\r\n * Es llamado cada vez que alguien presiona el botón de eliminar fecha.\r\n */\r\n onDelete?: () => void;\r\n onError?: (error: string | null) => unknown;\r\n /**\r\n * Con esta propiedad se puede proveer una función que recibirá como\r\n * parámetro el valor actual del cmapo y debe devolver el valor a mostrar.\r\n */\r\n renderLabel?: (value: string) => string;\r\n value?: string;\r\n }\r\n> &\r\n Pick<IIconInput, 'buttonProps'>;\r\n\r\nexport const DateInput = React.forwardRef<HTMLInputElement, TDateProps>(\r\n (\r\n {\r\n allowPickBeforeToday,\r\n buttonProps: outerButtonProps,\r\n className,\r\n error,\r\n getCustomMask,\r\n isLoading,\r\n onBlur,\r\n onChange,\r\n onDelete,\r\n onError,\r\n renderLabel,\r\n value: outerValue,\r\n ...props\r\n },\r\n ref,\r\n ) => {\r\n const id = React.useMemo(uniqueId, []);\r\n const [inputValue, setInputValue] = React.useState(outerValue ?? '');\r\n const [calValue, setCalValue] = React.useState<Date>();\r\n const boxRef = React.useRef<HTMLElement | null>(null);\r\n const { show, hide, ...modalProps } = useModal({\r\n preFetcher() {\r\n globalFocus.focus = () =>\r\n boxRef.current?.querySelector('.iconButton') as HTMLElement;\r\n return new Promise((resolve) => {\r\n let currentSelectedDate = dayjs(inputValue, dateFormat);\r\n if (!currentSelectedDate.isValid())\r\n currentSelectedDate = dayjs(new Date());\r\n setCalValue(currentSelectedDate.toDate());\r\n resolve();\r\n });\r\n },\r\n });\r\n const [stateError, setError] = React.useState<null | string>(error ?? null);\r\n\r\n const lastEmittedValue = React.useRef(outerValue ?? '');\r\n useUpdateEffect(() => {\r\n setInputValue(outerValue ?? '');\r\n lastEmittedValue.current = outerValue as string;\r\n }, [outerValue]);\r\n\r\n useUpdateEffect(() => {\r\n setError(error ?? null);\r\n }, [error]);\r\n\r\n useUpdateEffect(() => {\r\n if (onError) onError(stateError);\r\n }, [stateError]);\r\n\r\n const shoutOnChange = React.useCallback(\r\n (newValue: string) => {\r\n if (newValue !== lastEmittedValue.current && onChange) {\r\n lastEmittedValue.current = newValue;\r\n return onChange(newValue);\r\n }\r\n return true;\r\n },\r\n [onChange],\r\n );\r\n\r\n const setCalendarValue = React.useCallback(\r\n (value: string, nocheck?: boolean) => {\r\n if (value === '') {\r\n void shoutOnChange('');\r\n setInputValue('');\r\n return;\r\n }\r\n let newDate: dayjs.Dayjs;\r\n if (value !== '') {\r\n // format cal needs: Tue Feb 09 2021 00:00:00 GMT-0300\r\n newDate = dayjs(value, dateFormat);\r\n if (!newDate.isValid()) newDate = dayjs(new Date());\r\n } else {\r\n newDate = dayjs(new Date());\r\n }\r\n const formattedDate = newDate.format(dateFormat);\r\n const today = new Date();\r\n today.setHours(0, 0, 0, 0);\r\n if (formattedDate !== inputValue && nocheck !== true) {\r\n void shoutOnChange('');\r\n setInputValue('');\r\n setError(window.MSG_INVALID_DATE);\r\n } else if (allowPickBeforeToday === false && newDate.isBefore(today)) {\r\n void shoutOnChange('');\r\n setInputValue('');\r\n setError(window.MSG_FEC_FIN_MAY_FEC_INI);\r\n } else {\r\n const shoutResult = shoutOnChange(value === '' ? '' : formattedDate);\r\n if (shoutResult === false) {\r\n setInputValue(shoutResult || '');\r\n setError(null);\r\n } else if (typeof shoutResult === 'string') {\r\n setInputValue('');\r\n setError(shoutResult);\r\n } else {\r\n setInputValue(formattedDate);\r\n setError(null);\r\n }\r\n }\r\n },\r\n [allowPickBeforeToday, inputValue, shoutOnChange],\r\n );\r\n\r\n const selectDate = React.useCallback(\r\n (val: Date): void => {\r\n hide();\r\n const newValue = dayjs(val).format(dateFormat);\r\n setCalendarValue(newValue, true);\r\n },\r\n [hide, setCalendarValue],\r\n );\r\n\r\n const onCloseCalendarModal = React.useCallback(() => {\r\n hide();\r\n }, [hide]);\r\n\r\n const handleBlur = React.useCallback(\r\n (ev: React.FocusEvent<HTMLInputElement>) => {\r\n if (\r\n onBlur &&\r\n !isChild(ev.relatedTarget as HTMLElement, (current) => {\r\n return (\r\n current.id === `DateModal${id}` || current.id === `DateInput${id}`\r\n );\r\n })\r\n ) {\r\n onBlur(ev);\r\n }\r\n },\r\n [id, onBlur],\r\n );\r\n\r\n const inputProps = React.useMemo(\r\n () => ({\r\n ...props,\r\n className: 'dateInput',\r\n value: renderLabel ? renderLabel(inputValue) : inputValue,\r\n ref,\r\n onChange: (ev: React.ChangeEvent<HTMLInputElement>) => {\r\n setInputValue(ev.target.value);\r\n if (\r\n getMaskForDateFormat().replaceAll('9', DEFAULT_MASK_PLACEHOLDER) !==\r\n ev.target.value &&\r\n ev.target.value !== ''\r\n )\r\n setError(null);\r\n },\r\n onBlur: (ev: React.FocusEvent<HTMLInputElement>) => {\r\n if (!(props.readOnly || getCustomMask))\r\n setCalendarValue(ev.target.value);\r\n handleBlur(ev);\r\n },\r\n onKeyDown: (ev: React.KeyboardEvent) => {\r\n if (ev.key === 'Enter') setCalendarValue(inputValue);\r\n },\r\n }),\r\n [\r\n getCustomMask,\r\n handleBlur,\r\n inputValue,\r\n props,\r\n ref,\r\n renderLabel,\r\n setCalendarValue,\r\n ],\r\n );\r\n\r\n const buttonProps = React.useMemo(\r\n () => ({\r\n disabled: props.disabled ?? props.readOnly,\r\n 'aria-label': window.LBL_PICK_DATE,\r\n ...outerButtonProps,\r\n }),\r\n [outerButtonProps, props.disabled, props.readOnly],\r\n );\r\n\r\n const additionalButtons = React.useMemo(\r\n () => (\r\n <Close\r\n className=\"delete_date_button\"\r\n onClick={() => {\r\n setCalendarValue('');\r\n onDelete?.();\r\n (\r\n document.querySelector(\r\n `#DateInput${id} input`,\r\n ) as HTMLInputElement\r\n )?.focus();\r\n }}\r\n type=\"button\"\r\n />\r\n ),\r\n [id, onDelete, setCalendarValue],\r\n );\r\n\r\n return (\r\n <>\r\n <CalendarModal\r\n {...modalProps}\r\n calValue={calValue}\r\n locale={DEFAULT_LOCALE}\r\n handleClickDay={selectDate}\r\n onCancel={onCloseCalendarModal}\r\n id={`DateModal${id}`}\r\n />\r\n <Box\r\n {...getVariant('forms.dateInput')}\r\n className={`${className ?? ''} dateInput`}\r\n id={`DateInput${id}`}\r\n ref={boxRef}\r\n >\r\n <IconInput\r\n additionalButtons={\r\n inputValue &&\r\n inputValue !==\r\n getMaskForDateFormat().replaceAll(\r\n '9',\r\n DEFAULT_MASK_PLACEHOLDER,\r\n ) &&\r\n !props.readOnly &&\r\n !props.disabled\r\n ? additionalButtons\r\n : undefined\r\n }\r\n isLoading={isLoading}\r\n maskPlaceholder={DEFAULT_MASK_PLACEHOLDER}\r\n mask={getCustomMask ? getCustomMask() : getMaskForDateFormat()}\r\n icon={icons.Calendar}\r\n onBlur={handleBlur}\r\n buttonProps={buttonProps}\r\n inputProps={inputProps}\r\n readOnly={props.readOnly}\r\n sx={getFieldErrorStyles(stateError === null)}\r\n onClick={show}\r\n />\r\n {stateError && <FieldErrorMessage>{stateError}</FieldErrorMessage>}\r\n </Box>\r\n </>\r\n );\r\n },\r\n);\r\n\r\nDateInput.displayName = 'DateInput';\r\n"],"names":["React"],"mappings":";;;;;;;;;;;;;;AA4BA,MAAM,iBAAiB,MAAO,CAAA,SAAA,CAAA;AAC9B,MAAM,wBAA2B,GAAA,GAAA,CAAA;AAEjC,MAAM,aAA0B,aAAc,EAAA,CAAA;AAE9C,MAAM,uBAAuB,MAAc;AACzC,EAAA,IAAI,UAAe,KAAA,YAAA;AAAc,IAAO,OAAA,YAAA,CAAA;AACxC,EAAO,OAAA,YAAA,CAAA;AACT,CAAA,CAAA;AAkCO,MAAM,YAAYA,cAAM,CAAA,UAAA;AAAA,EAC7B,CACE;AAAA,IACE,oBAAA;AAAA,IACA,WAAa,EAAA,gBAAA;AAAA,IACb,SAAA;AAAA,IACA,KAAA;AAAA,IACA,aAAA;AAAA,IACA,SAAA;AAAA,IACA,MAAA;AAAA,IACA,QAAA;AAAA,IACA,QAAA;AAAA,IACA,OAAA;AAAA,IACA,WAAA;AAAA,IACA,KAAO,EAAA,UAAA;AAAA,IACP,GAAG,KAAA;AAAA,KAEL,GACG,KAAA;AACH,IAAA,MAAM,EAAK,GAAAA,cAAA,CAAM,OAAQ,CAAA,QAAA,EAAU,EAAE,CAAA,CAAA;AACrC,IAAA,MAAM,CAAC,UAAY,EAAA,aAAa,IAAIA,cAAM,CAAA,QAAA,CAAS,cAAc,EAAE,CAAA,CAAA;AACnE,IAAA,MAAM,CAAC,QAAA,EAAU,WAAW,CAAA,GAAIA,eAAM,QAAe,EAAA,CAAA;AACrD,IAAM,MAAA,MAAA,GAASA,cAAM,CAAA,MAAA,CAA2B,IAAI,CAAA,CAAA;AACpD,IAAA,MAAM,EAAE,IAAM,EAAA,IAAA,EAAM,GAAG,UAAA,KAAe,QAAS,CAAA;AAAA,MAC7C,UAAa,GAAA;AACX,QAAA,WAAA,CAAY,KAAQ,GAAA,MAClB,MAAO,CAAA,OAAA,EAAS,cAAc,aAAa,CAAA,CAAA;AAC7C,QAAO,OAAA,IAAI,OAAQ,CAAA,CAAC,OAAY,KAAA;AAC9B,UAAI,IAAA,mBAAA,GAAsB,KAAM,CAAA,UAAA,EAAY,UAAU,CAAA,CAAA;AACtD,UAAI,IAAA,CAAC,oBAAoB,OAAQ,EAAA;AAC/B,YAAsB,mBAAA,GAAA,KAAA,iBAAU,IAAA,IAAA,EAAM,CAAA,CAAA;AACxC,UAAY,WAAA,CAAA,mBAAA,CAAoB,QAAQ,CAAA,CAAA;AACxC,UAAQ,OAAA,EAAA,CAAA;AAAA,SACT,CAAA,CAAA;AAAA,OACH;AAAA,KACD,CAAA,CAAA;AACD,IAAA,MAAM,CAAC,UAAY,EAAA,QAAQ,IAAIA,cAAM,CAAA,QAAA,CAAwB,SAAS,IAAI,CAAA,CAAA;AAE1E,IAAA,MAAM,gBAAmB,GAAAA,cAAA,CAAM,MAAO,CAAA,UAAA,IAAc,EAAE,CAAA,CAAA;AACtD,IAAA,eAAA,CAAgB,MAAM;AACpB,MAAA,aAAA,CAAc,cAAc,EAAE,CAAA,CAAA;AAC9B,MAAA,gBAAA,CAAiB,OAAU,GAAA,UAAA,CAAA;AAAA,KAC7B,EAAG,CAAC,UAAU,CAAC,CAAA,CAAA;AAEf,IAAA,eAAA,CAAgB,MAAM;AACpB,MAAA,QAAA,CAAS,SAAS,IAAI,CAAA,CAAA;AAAA,KACxB,EAAG,CAAC,KAAK,CAAC,CAAA,CAAA;AAEV,IAAA,eAAA,CAAgB,MAAM;AACpB,MAAI,IAAA,OAAA;AAAS,QAAA,OAAA,CAAQ,UAAU,CAAA,CAAA;AAAA,KACjC,EAAG,CAAC,UAAU,CAAC,CAAA,CAAA;AAEf,IAAA,MAAM,gBAAgBA,cAAM,CAAA,WAAA;AAAA,MAC1B,CAAC,QAAqB,KAAA;AACpB,QAAI,IAAA,QAAA,KAAa,gBAAiB,CAAA,OAAA,IAAW,QAAU,EAAA;AACrD,UAAA,gBAAA,CAAiB,OAAU,GAAA,QAAA,CAAA;AAC3B,UAAA,OAAO,SAAS,QAAQ,CAAA,CAAA;AAAA,SAC1B;AACA,QAAO,OAAA,IAAA,CAAA;AAAA,OACT;AAAA,MACA,CAAC,QAAQ,CAAA;AAAA,KACX,CAAA;AAEA,IAAA,MAAM,mBAAmBA,cAAM,CAAA,WAAA;AAAA,MAC7B,CAAC,OAAe,OAAsB,KAAA;AACpC,QAAA,IAAI,UAAU,EAAI,EAAA;AAChB,UAAA,KAAK,cAAc,EAAE,CAAA,CAAA;AACrB,UAAA,aAAA,CAAc,EAAE,CAAA,CAAA;AAChB,UAAA,OAAA;AAAA,SACF;AACA,QAAI,IAAA,OAAA,CAAA;AACJ,QAAA,IAAI,UAAU,EAAI,EAAA;AAEhB,UAAU,OAAA,GAAA,KAAA,CAAM,OAAO,UAAU,CAAA,CAAA;AACjC,UAAI,IAAA,CAAC,QAAQ,OAAQ,EAAA;AAAG,YAAU,OAAA,GAAA,KAAA,iBAAU,IAAA,IAAA,EAAM,CAAA,CAAA;AAAA,SAC7C,MAAA;AACL,UAAU,OAAA,GAAA,KAAA,iBAAU,IAAA,IAAA,EAAM,CAAA,CAAA;AAAA,SAC5B;AACA,QAAM,MAAA,aAAA,GAAgB,OAAQ,CAAA,MAAA,CAAO,UAAU,CAAA,CAAA;AAC/C,QAAM,MAAA,KAAA,uBAAY,IAAK,EAAA,CAAA;AACvB,QAAA,KAAA,CAAM,QAAS,CAAA,CAAA,EAAG,CAAG,EAAA,CAAA,EAAG,CAAC,CAAA,CAAA;AACzB,QAAI,IAAA,aAAA,KAAkB,UAAc,IAAA,OAAA,KAAY,IAAM,EAAA;AACpD,UAAA,KAAK,cAAc,EAAE,CAAA,CAAA;AACrB,UAAA,aAAA,CAAc,EAAE,CAAA,CAAA;AAChB,UAAA,QAAA,CAAS,OAAO,gBAAgB,CAAA,CAAA;AAAA,mBACvB,oBAAyB,KAAA,KAAA,IAAS,OAAQ,CAAA,QAAA,CAAS,KAAK,CAAG,EAAA;AACpE,UAAA,KAAK,cAAc,EAAE,CAAA,CAAA;AACrB,UAAA,aAAA,CAAc,EAAE,CAAA,CAAA;AAChB,UAAA,QAAA,CAAS,OAAO,uBAAuB,CAAA,CAAA;AAAA,SAClC,MAAA;AACL,UAAA,MAAM,WAAc,GAAA,aAAA,CAAc,KAAU,KAAA,EAAA,GAAK,KAAK,aAAa,CAAA,CAAA;AACnE,UAAA,IAAI,gBAAgB,KAAO,EAAA;AACzB,YAAA,aAAA,CAAc,eAAe,EAAE,CAAA,CAAA;AAC/B,YAAA,QAAA,CAAS,IAAI,CAAA,CAAA;AAAA,WACf,MAAA,IAAW,OAAO,WAAA,KAAgB,QAAU,EAAA;AAC1C,YAAA,aAAA,CAAc,EAAE,CAAA,CAAA;AAChB,YAAA,QAAA,CAAS,WAAW,CAAA,CAAA;AAAA,WACf,MAAA;AACL,YAAA,aAAA,CAAc,aAAa,CAAA,CAAA;AAC3B,YAAA,QAAA,CAAS,IAAI,CAAA,CAAA;AAAA,WACf;AAAA,SACF;AAAA,OACF;AAAA,MACA,CAAC,oBAAsB,EAAA,UAAA,EAAY,aAAa,CAAA;AAAA,KAClD,CAAA;AAEA,IAAA,MAAM,aAAaA,cAAM,CAAA,WAAA;AAAA,MACvB,CAAC,GAAoB,KAAA;AACnB,QAAK,IAAA,EAAA,CAAA;AACL,QAAA,MAAM,QAAW,GAAA,KAAA,CAAM,GAAG,CAAA,CAAE,OAAO,UAAU,CAAA,CAAA;AAC7C,QAAA,gBAAA,CAAiB,UAAU,IAAI,CAAA,CAAA;AAAA,OACjC;AAAA,MACA,CAAC,MAAM,gBAAgB,CAAA;AAAA,KACzB,CAAA;AAEA,IAAM,MAAA,oBAAA,GAAuBA,cAAM,CAAA,WAAA,CAAY,MAAM;AACnD,MAAK,IAAA,EAAA,CAAA;AAAA,KACP,EAAG,CAAC,IAAI,CAAC,CAAA,CAAA;AAET,IAAA,MAAM,aAAaA,cAAM,CAAA,WAAA;AAAA,MACvB,CAAC,EAA2C,KAAA;AAC1C,QAAA,IACE,UACA,CAAC,OAAA,CAAQ,EAAG,CAAA,aAAA,EAA8B,CAAC,OAAY,KAAA;AACrD,UACE,OAAA,OAAA,CAAQ,OAAO,CAAY,SAAA,EAAA,EAAE,MAAM,OAAQ,CAAA,EAAA,KAAO,YAAY,EAAE,CAAA,CAAA,CAAA;AAAA,SAEnE,CACD,EAAA;AACA,UAAA,MAAA,CAAO,EAAE,CAAA,CAAA;AAAA,SACX;AAAA,OACF;AAAA,MACA,CAAC,IAAI,MAAM,CAAA;AAAA,KACb,CAAA;AAEA,IAAA,MAAM,aAAaA,cAAM,CAAA,OAAA;AAAA,MACvB,OAAO;AAAA,QACL,GAAG,KAAA;AAAA,QACH,SAAW,EAAA,WAAA;AAAA,QACX,KAAO,EAAA,WAAA,GAAc,WAAY,CAAA,UAAU,CAAI,GAAA,UAAA;AAAA,QAC/C,GAAA;AAAA,QACA,QAAA,EAAU,CAAC,EAA4C,KAAA;AACrD,UAAc,aAAA,CAAA,EAAA,CAAG,OAAO,KAAK,CAAA,CAAA;AAC7B,UACE,IAAA,oBAAA,EAAuB,CAAA,UAAA,CAAW,GAAK,EAAA,wBAAwB,CAC7D,KAAA,EAAA,CAAG,MAAO,CAAA,KAAA,IACZ,EAAG,CAAA,MAAA,CAAO,KAAU,KAAA,EAAA;AAEpB,YAAA,QAAA,CAAS,IAAI,CAAA,CAAA;AAAA,SACjB;AAAA,QACA,MAAA,EAAQ,CAAC,EAA2C,KAAA;AAClD,UAAI,IAAA,EAAE,MAAM,QAAY,IAAA,aAAA,CAAA;AACtB,YAAiB,gBAAA,CAAA,EAAA,CAAG,OAAO,KAAK,CAAA,CAAA;AAClC,UAAA,UAAA,CAAW,EAAE,CAAA,CAAA;AAAA,SACf;AAAA,QACA,SAAA,EAAW,CAAC,EAA4B,KAAA;AACtC,UAAA,IAAI,GAAG,GAAQ,KAAA,OAAA;AAAS,YAAA,gBAAA,CAAiB,UAAU,CAAA,CAAA;AAAA,SACrD;AAAA,OACF,CAAA;AAAA,MACA;AAAA,QACE,aAAA;AAAA,QACA,UAAA;AAAA,QACA,UAAA;AAAA,QACA,KAAA;AAAA,QACA,GAAA;AAAA,QACA,WAAA;AAAA,QACA,gBAAA;AAAA,OACF;AAAA,KACF,CAAA;AAEA,IAAA,MAAM,cAAcA,cAAM,CAAA,OAAA;AAAA,MACxB,OAAO;AAAA,QACL,QAAA,EAAU,KAAM,CAAA,QAAA,IAAY,KAAM,CAAA,QAAA;AAAA,QAClC,cAAc,MAAO,CAAA,aAAA;AAAA,QACrB,GAAG,gBAAA;AAAA,OACL,CAAA;AAAA,MACA,CAAC,gBAAA,EAAkB,KAAM,CAAA,QAAA,EAAU,MAAM,QAAQ,CAAA;AAAA,KACnD,CAAA;AAEA,IAAA,MAAM,oBAAoBA,cAAM,CAAA,OAAA;AAAA,MAC9B,sBACE,GAAA;AAAA,QAAC,KAAA;AAAA,QAAA;AAAA,UACC,SAAU,EAAA,oBAAA;AAAA,UACV,SAAS,MAAM;AACb,YAAA,gBAAA,CAAiB,EAAE,CAAA,CAAA;AACnB,YAAW,QAAA,IAAA,CAAA;AACX,YACE,QAAS,CAAA,aAAA;AAAA,cACP,aAAa,EAAE,CAAA,MAAA,CAAA;AAAA,eAEhB,KAAM,EAAA,CAAA;AAAA,WACX;AAAA,UACA,IAAK,EAAA,QAAA;AAAA,SAAA;AAAA,OACP;AAAA,MAEF,CAAC,EAAI,EAAA,QAAA,EAAU,gBAAgB,CAAA;AAAA,KACjC,CAAA;AAEA,IAAA,uBAEI,IAAA,CAAA,QAAA,EAAA,EAAA,QAAA,EAAA;AAAA,sBAAA,GAAA;AAAA,QAAC,aAAA;AAAA,QAAA;AAAA,UACE,GAAG,UAAA;AAAA,UACJ,QAAA;AAAA,UACA,MAAQ,EAAA,cAAA;AAAA,UACR,cAAgB,EAAA,UAAA;AAAA,UAChB,QAAU,EAAA,oBAAA;AAAA,UACV,EAAA,EAAI,YAAY,EAAE,CAAA,CAAA;AAAA,SAAA;AAAA,OACpB;AAAA,sBACA,IAAA;AAAA,QAAC,GAAA;AAAA,QAAA;AAAA,UACE,GAAG,WAAW,iBAAiB,CAAA;AAAA,UAChC,SAAA,EAAW,CAAG,EAAA,SAAA,IAAa,EAAE,CAAA,UAAA,CAAA;AAAA,UAC7B,EAAA,EAAI,YAAY,EAAE,CAAA,CAAA;AAAA,UAClB,GAAK,EAAA,MAAA;AAAA,UAEL,QAAA,EAAA;AAAA,4BAAA,GAAA;AAAA,cAAC,SAAA;AAAA,cAAA;AAAA,gBACC,iBACE,EAAA,UAAA,IACA,UACE,KAAA,oBAAA,EAAuB,CAAA,UAAA;AAAA,kBACrB,GAAA;AAAA,kBACA,wBAAA;AAAA,qBAEJ,CAAC,KAAA,CAAM,YACP,CAAC,KAAA,CAAM,WACH,iBACA,GAAA,KAAA,CAAA;AAAA,gBAEN,SAAA;AAAA,gBACA,eAAiB,EAAA,wBAAA;AAAA,gBACjB,IAAM,EAAA,aAAA,GAAgB,aAAc,EAAA,GAAI,oBAAqB,EAAA;AAAA,gBAC7D,MAAM,KAAM,CAAA,QAAA;AAAA,gBACZ,MAAQ,EAAA,UAAA;AAAA,gBACR,WAAA;AAAA,gBACA,UAAA;AAAA,gBACA,UAAU,KAAM,CAAA,QAAA;AAAA,gBAChB,EAAA,EAAI,mBAAoB,CAAA,UAAA,KAAe,IAAI,CAAA;AAAA,gBAC3C,OAAS,EAAA,IAAA;AAAA,eAAA;AAAA,aACX;AAAA,YACC,UAAA,oBAAe,GAAA,CAAA,iBAAA,EAAA,EAAmB,QAAW,EAAA,UAAA,EAAA,CAAA;AAAA,WAAA;AAAA,SAAA;AAAA,OAChD;AAAA,KACF,EAAA,CAAA,CAAA;AAAA,GAEJ;AACF,EAAA;AAEA,SAAA,CAAU,WAAc,GAAA,WAAA;;;;"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
|
|
3
|
+
interface IFieldErrorMessage {
|
|
4
|
+
children: React.ReactNode | string;
|
|
5
|
+
name?: string;
|
|
6
|
+
}
|
|
7
|
+
declare const FieldErrorMessage: ({ children, name }: IFieldErrorMessage) => React.JSX.Element | null;
|
|
8
|
+
|
|
9
|
+
export { FieldErrorMessage, type IFieldErrorMessage };
|
|
10
|
+
//# sourceMappingURL=FieldErrorMessage.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FieldErrorMessage.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { jsx } from '@apia/theme/jsx-runtime';
|
|
2
|
+
import { customEvents } from '@apia/util';
|
|
3
|
+
import * as React from 'react';
|
|
4
|
+
import { Box } from '@apia/theme';
|
|
5
|
+
|
|
6
|
+
const FieldErrorMessage = ({ children, name }) => {
|
|
7
|
+
const [ref, setRef] = React.useState(null);
|
|
8
|
+
React.useEffect(() => {
|
|
9
|
+
if (children) {
|
|
10
|
+
const event = new CustomEvent(customEvents.focus, { bubbles: true });
|
|
11
|
+
ref?.dispatchEvent(event);
|
|
12
|
+
}
|
|
13
|
+
}, [children, ref]);
|
|
14
|
+
if (children) {
|
|
15
|
+
return /* @__PURE__ */ jsx(
|
|
16
|
+
Box,
|
|
17
|
+
{
|
|
18
|
+
ref: setRef,
|
|
19
|
+
role: "alert",
|
|
20
|
+
"data-testid": name ? `err_${name}` : null,
|
|
21
|
+
sx: {
|
|
22
|
+
mb: "0",
|
|
23
|
+
color: "danger",
|
|
24
|
+
pt: "2"
|
|
25
|
+
},
|
|
26
|
+
children
|
|
27
|
+
}
|
|
28
|
+
);
|
|
29
|
+
}
|
|
30
|
+
return null;
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
export { FieldErrorMessage };
|
|
34
|
+
//# sourceMappingURL=FieldErrorMessage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FieldErrorMessage.js","sources":["../../../src/components/forms/FieldErrorMessage.tsx"],"sourcesContent":["import { customEvents } from '@apia/util';\r\nimport * as React from 'react';\r\nimport { Box } from '@apia/theme';\r\n\r\nexport interface IFieldErrorMessage {\r\n children: React.ReactNode | string;\r\n name?: string;\r\n}\r\n\r\nexport const FieldErrorMessage = ({ children, name }: IFieldErrorMessage) => {\r\n const [ref, setRef] = React.useState<null | HTMLDivElement>(null);\r\n\r\n React.useEffect(() => {\r\n if (children) {\r\n const event = new CustomEvent(customEvents.focus, { bubbles: true });\r\n ref?.dispatchEvent(event);\r\n }\r\n }, [children, ref]);\r\n\r\n if (children) {\r\n return (\r\n <Box\r\n ref={setRef}\r\n role=\"alert\"\r\n data-testid={name ? `err_${name}` : null}\r\n sx={{\r\n mb: '0',\r\n color: 'danger',\r\n pt: '2',\r\n }}\r\n >\r\n {children}\r\n </Box>\r\n );\r\n }\r\n return null;\r\n};\r\n"],"names":[],"mappings":";;;;;AASO,MAAM,iBAAoB,GAAA,CAAC,EAAE,QAAA,EAAU,MAA+B,KAAA;AAC3E,EAAA,MAAM,CAAC,GAAK,EAAA,MAAM,CAAI,GAAA,KAAA,CAAM,SAAgC,IAAI,CAAA,CAAA;AAEhE,EAAA,KAAA,CAAM,UAAU,MAAM;AACpB,IAAA,IAAI,QAAU,EAAA;AACZ,MAAM,MAAA,KAAA,GAAQ,IAAI,WAAY,CAAA,YAAA,CAAa,OAAO,EAAE,OAAA,EAAS,MAAM,CAAA,CAAA;AACnE,MAAA,GAAA,EAAK,cAAc,KAAK,CAAA,CAAA;AAAA,KAC1B;AAAA,GACC,EAAA,CAAC,QAAU,EAAA,GAAG,CAAC,CAAA,CAAA;AAElB,EAAA,IAAI,QAAU,EAAA;AACZ,IACE,uBAAA,GAAA;AAAA,MAAC,GAAA;AAAA,MAAA;AAAA,QACC,GAAK,EAAA,MAAA;AAAA,QACL,IAAK,EAAA,OAAA;AAAA,QACL,aAAa,EAAA,IAAA,GAAO,CAAO,IAAA,EAAA,IAAI,CAAK,CAAA,GAAA,IAAA;AAAA,QACpC,EAAI,EAAA;AAAA,UACF,EAAI,EAAA,GAAA;AAAA,UACJ,KAAO,EAAA,QAAA;AAAA,UACP,EAAI,EAAA,GAAA;AAAA,SACN;AAAA,QAEC,QAAA;AAAA,OAAA;AAAA,KACH,CAAA;AAAA,GAEJ;AACA,EAAO,OAAA,IAAA,CAAA;AACT;;;;"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { BoxProps } from '@apia/theme';
|
|
3
|
+
|
|
4
|
+
type TFieldLabel = {
|
|
5
|
+
avoidSemicolon?: boolean;
|
|
6
|
+
/**
|
|
7
|
+
* Permite mostrar un mensaje de error debajo del campo
|
|
8
|
+
*/
|
|
9
|
+
error?: string;
|
|
10
|
+
hideRequiredMark?: boolean;
|
|
11
|
+
label: string;
|
|
12
|
+
/**
|
|
13
|
+
* La propiedad required se utiliza para mostrar el * de requerido.
|
|
14
|
+
*
|
|
15
|
+
* @see requiredMarkPosition
|
|
16
|
+
* @see hideRequiredMark
|
|
17
|
+
*/
|
|
18
|
+
required?: boolean;
|
|
19
|
+
requiredMarkPosition?: 'before' | 'after';
|
|
20
|
+
} & BoxProps;
|
|
21
|
+
declare const FieldLabel: React.ForwardRefExoticComponent<{
|
|
22
|
+
avoidSemicolon?: boolean | undefined;
|
|
23
|
+
/**
|
|
24
|
+
* Permite mostrar un mensaje de error debajo del campo
|
|
25
|
+
*/
|
|
26
|
+
error?: string | undefined;
|
|
27
|
+
hideRequiredMark?: boolean | undefined;
|
|
28
|
+
label: string;
|
|
29
|
+
/**
|
|
30
|
+
* La propiedad required se utiliza para mostrar el * de requerido.
|
|
31
|
+
*
|
|
32
|
+
* @see requiredMarkPosition
|
|
33
|
+
* @see hideRequiredMark
|
|
34
|
+
*/
|
|
35
|
+
required?: boolean | undefined;
|
|
36
|
+
requiredMarkPosition?: "after" | "before" | undefined;
|
|
37
|
+
} & BoxProps & React.RefAttributes<HTMLDivElement>>;
|
|
38
|
+
|
|
39
|
+
export { FieldLabel, type TFieldLabel };
|
|
40
|
+
//# sourceMappingURL=FieldLabel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FieldLabel.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { jsxs, jsx } from '@apia/theme/jsx-runtime';
|
|
2
|
+
import { injectStyles, Box, getVariant } from '@apia/theme';
|
|
3
|
+
import { forwardRef } from 'react';
|
|
4
|
+
import { RequiredMark } from './RequiredMark.js';
|
|
5
|
+
|
|
6
|
+
injectStyles("layout.common.components.fieldLabel", {
|
|
7
|
+
display: "flex",
|
|
8
|
+
flexDirection: "column",
|
|
9
|
+
gap: 1,
|
|
10
|
+
".fieldLabel__label": {
|
|
11
|
+
fontWeight: "bold"
|
|
12
|
+
}
|
|
13
|
+
});
|
|
14
|
+
const FieldLabel = forwardRef(
|
|
15
|
+
({
|
|
16
|
+
as,
|
|
17
|
+
avoidSemicolon,
|
|
18
|
+
children,
|
|
19
|
+
error,
|
|
20
|
+
hideRequiredMark,
|
|
21
|
+
label,
|
|
22
|
+
required,
|
|
23
|
+
requiredMarkPosition = "after",
|
|
24
|
+
...props
|
|
25
|
+
}, ref) => {
|
|
26
|
+
return /* @__PURE__ */ jsxs(
|
|
27
|
+
Box,
|
|
28
|
+
{
|
|
29
|
+
as: as ?? "label",
|
|
30
|
+
...props,
|
|
31
|
+
className: `fieldLabel ${props.className ?? ""}`,
|
|
32
|
+
...getVariant("layout.common.components.fieldLabel"),
|
|
33
|
+
"aria-label": props["aria-label"] ?? label,
|
|
34
|
+
ref,
|
|
35
|
+
children: [
|
|
36
|
+
/* @__PURE__ */ jsxs(Box, { className: "fieldLabel__label", children: [
|
|
37
|
+
requiredMarkPosition === "before" && /* @__PURE__ */ jsx(
|
|
38
|
+
RequiredMark,
|
|
39
|
+
{
|
|
40
|
+
isRequired: required,
|
|
41
|
+
isReadonly: hideRequiredMark,
|
|
42
|
+
isFormReadonly: hideRequiredMark
|
|
43
|
+
}
|
|
44
|
+
),
|
|
45
|
+
label,
|
|
46
|
+
requiredMarkPosition === "after" && /* @__PURE__ */ jsx(
|
|
47
|
+
RequiredMark,
|
|
48
|
+
{
|
|
49
|
+
isRequired: required,
|
|
50
|
+
isReadonly: hideRequiredMark,
|
|
51
|
+
isFormReadonly: hideRequiredMark
|
|
52
|
+
}
|
|
53
|
+
),
|
|
54
|
+
!avoidSemicolon && ":"
|
|
55
|
+
] }),
|
|
56
|
+
/* @__PURE__ */ jsx(Box, { children }),
|
|
57
|
+
error && /* @__PURE__ */ jsx(Box, { className: "fieldLabel__error", children: error })
|
|
58
|
+
]
|
|
59
|
+
}
|
|
60
|
+
);
|
|
61
|
+
}
|
|
62
|
+
);
|
|
63
|
+
FieldLabel.displayName = "FieldLabel";
|
|
64
|
+
|
|
65
|
+
export { FieldLabel };
|
|
66
|
+
//# sourceMappingURL=FieldLabel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FieldLabel.js","sources":["../../../src/components/forms/FieldLabel.tsx"],"sourcesContent":["import { injectStyles, getVariant, Box, BoxProps } from '@apia/theme';\r\nimport { forwardRef } from 'react';\r\nimport { RequiredMark } from './RequiredMark';\r\n\r\nexport type TFieldLabel = {\r\n avoidSemicolon?: boolean;\r\n /**\r\n * Permite mostrar un mensaje de error debajo del campo\r\n */\r\n error?: string;\r\n hideRequiredMark?: boolean;\r\n label: string;\r\n /**\r\n * La propiedad required se utiliza para mostrar el * de requerido.\r\n *\r\n * @see requiredMarkPosition\r\n * @see hideRequiredMark\r\n */\r\n required?: boolean;\r\n requiredMarkPosition?: 'before' | 'after';\r\n} & BoxProps;\r\n\r\ninjectStyles('layout.common.components.fieldLabel', {\r\n display: 'flex',\r\n flexDirection: 'column',\r\n gap: 1,\r\n\r\n '.fieldLabel__label': {\r\n fontWeight: 'bold',\r\n },\r\n});\r\n\r\nexport const FieldLabel = forwardRef<HTMLDivElement, TFieldLabel>(\r\n (\r\n {\r\n as,\r\n avoidSemicolon,\r\n children,\r\n error,\r\n hideRequiredMark,\r\n label,\r\n required,\r\n requiredMarkPosition = 'after',\r\n ...props\r\n },\r\n ref,\r\n ) => {\r\n return (\r\n <Box\r\n as={as ?? 'label'}\r\n {...props}\r\n className={`fieldLabel ${props.className ?? ''}`}\r\n {...getVariant('layout.common.components.fieldLabel')}\r\n aria-label={props['aria-label'] ?? label}\r\n ref={ref}\r\n >\r\n <Box className=\"fieldLabel__label\">\r\n {requiredMarkPosition === 'before' && (\r\n <RequiredMark\r\n isRequired={required}\r\n isReadonly={hideRequiredMark}\r\n isFormReadonly={hideRequiredMark}\r\n />\r\n )}\r\n {label}\r\n {requiredMarkPosition === 'after' && (\r\n <RequiredMark\r\n isRequired={required}\r\n isReadonly={hideRequiredMark}\r\n isFormReadonly={hideRequiredMark}\r\n />\r\n )}\r\n {!avoidSemicolon && ':'}\r\n </Box>\r\n <Box>{children}</Box>\r\n {error && <Box className=\"fieldLabel__error\">{error}</Box>}\r\n </Box>\r\n );\r\n },\r\n);\r\n\r\nFieldLabel.displayName = 'FieldLabel';\r\n"],"names":[],"mappings":";;;;;AAsBA,YAAA,CAAa,qCAAuC,EAAA;AAAA,EAClD,OAAS,EAAA,MAAA;AAAA,EACT,aAAe,EAAA,QAAA;AAAA,EACf,GAAK,EAAA,CAAA;AAAA,EAEL,oBAAsB,EAAA;AAAA,IACpB,UAAY,EAAA,MAAA;AAAA,GACd;AACF,CAAC,CAAA,CAAA;AAEM,MAAM,UAAa,GAAA,UAAA;AAAA,EACxB,CACE;AAAA,IACE,EAAA;AAAA,IACA,cAAA;AAAA,IACA,QAAA;AAAA,IACA,KAAA;AAAA,IACA,gBAAA;AAAA,IACA,KAAA;AAAA,IACA,QAAA;AAAA,IACA,oBAAuB,GAAA,OAAA;AAAA,IACvB,GAAG,KAAA;AAAA,KAEL,GACG,KAAA;AACH,IACE,uBAAA,IAAA;AAAA,MAAC,GAAA;AAAA,MAAA;AAAA,QACC,IAAI,EAAM,IAAA,OAAA;AAAA,QACT,GAAG,KAAA;AAAA,QACJ,SAAW,EAAA,CAAA,WAAA,EAAc,KAAM,CAAA,SAAA,IAAa,EAAE,CAAA,CAAA;AAAA,QAC7C,GAAG,WAAW,qCAAqC,CAAA;AAAA,QACpD,YAAA,EAAY,KAAM,CAAA,YAAY,CAAK,IAAA,KAAA;AAAA,QACnC,GAAA;AAAA,QAEA,QAAA,EAAA;AAAA,0BAAC,IAAA,CAAA,GAAA,EAAA,EAAI,WAAU,mBACZ,EAAA,QAAA,EAAA;AAAA,YAAA,oBAAA,KAAyB,QACxB,oBAAA,GAAA;AAAA,cAAC,YAAA;AAAA,cAAA;AAAA,gBACC,UAAY,EAAA,QAAA;AAAA,gBACZ,UAAY,EAAA,gBAAA;AAAA,gBACZ,cAAgB,EAAA,gBAAA;AAAA,eAAA;AAAA,aAClB;AAAA,YAED,KAAA;AAAA,YACA,yBAAyB,OACxB,oBAAA,GAAA;AAAA,cAAC,YAAA;AAAA,cAAA;AAAA,gBACC,UAAY,EAAA,QAAA;AAAA,gBACZ,UAAY,EAAA,gBAAA;AAAA,gBACZ,cAAgB,EAAA,gBAAA;AAAA,eAAA;AAAA,aAClB;AAAA,YAED,CAAC,cAAkB,IAAA,GAAA;AAAA,WACtB,EAAA,CAAA;AAAA,0BACA,GAAA,CAAC,OAAK,QAAS,EAAA,CAAA;AAAA,UACd,KAAS,oBAAA,GAAA,CAAC,GAAI,EAAA,EAAA,SAAA,EAAU,qBAAqB,QAAM,EAAA,KAAA,EAAA,CAAA;AAAA,SAAA;AAAA,OAAA;AAAA,KACtD,CAAA;AAAA,GAEJ;AACF,EAAA;AAEA,UAAA,CAAW,WAAc,GAAA,YAAA;;;;"}
|