@apia/components 2.0.7 → 2.0.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.ts +1658 -68
- package/dist/index.js +7198 -58
- package/dist/index.js.map +1 -1
- package/package.json +8 -8
- package/dist/components/IconsList/Icon.js +0 -42
- package/dist/components/IconsList/Icon.js.map +0 -1
- package/dist/components/IconsList/IconWrapper.js +0 -24
- package/dist/components/IconsList/IconWrapper.js.map +0 -1
- package/dist/components/IconsList/KeyHandler.js +0 -147
- package/dist/components/IconsList/KeyHandler.js.map +0 -1
- package/dist/components/IconsList/context.js +0 -14
- package/dist/components/IconsList/context.js.map +0 -1
- package/dist/components/IconsList/index.d.ts +0 -12
- package/dist/components/IconsList/index.d.ts.map +0 -1
- package/dist/components/IconsList/index.js +0 -119
- package/dist/components/IconsList/index.js.map +0 -1
- package/dist/components/IconsList/renderers/DefaultIconRenderer.d.ts +0 -7
- package/dist/components/IconsList/renderers/DefaultIconRenderer.d.ts.map +0 -1
- package/dist/components/IconsList/renderers/DefaultIconRenderer.js +0 -30
- package/dist/components/IconsList/renderers/DefaultIconRenderer.js.map +0 -1
- package/dist/components/IconsList/store/context.js +0 -9
- package/dist/components/IconsList/store/context.js.map +0 -1
- package/dist/components/IconsList/store/distinctors.js +0 -42
- package/dist/components/IconsList/store/distinctors.js.map +0 -1
- package/dist/components/IconsList/store/keysMaker.js +0 -8
- package/dist/components/IconsList/store/keysMaker.js.map +0 -1
- package/dist/components/IconsList/store/operations.js +0 -138
- package/dist/components/IconsList/store/operations.js.map +0 -1
- package/dist/components/IconsList/store/state.js +0 -9
- package/dist/components/IconsList/store/state.js.map +0 -1
- package/dist/components/IconsList/store/useStore.js +0 -52
- package/dist/components/IconsList/store/useStore.js.map +0 -1
- package/dist/components/IconsList/styles.js +0 -48
- package/dist/components/IconsList/styles.js.map +0 -1
- package/dist/components/IconsList/types.d.ts +0 -98
- package/dist/components/IconsList/types.d.ts.map +0 -1
- package/dist/components/IconsList/util.js +0 -46
- package/dist/components/IconsList/util.js.map +0 -1
- package/dist/components/ListBox/Combobox.js +0 -52
- package/dist/components/ListBox/Combobox.js.map +0 -1
- package/dist/components/ListBox/ListboxContext.d.ts +0 -35
- package/dist/components/ListBox/ListboxContext.d.ts.map +0 -1
- package/dist/components/ListBox/ListboxContext.js +0 -6
- package/dist/components/ListBox/ListboxContext.js.map +0 -1
- package/dist/components/ListBox/ListboxItem.d.ts +0 -17
- package/dist/components/ListBox/ListboxItem.d.ts.map +0 -1
- package/dist/components/ListBox/ListboxItem.js +0 -67
- package/dist/components/ListBox/ListboxItem.js.map +0 -1
- package/dist/components/ListBox/ListboxKeyhandler.js +0 -154
- package/dist/components/ListBox/ListboxKeyhandler.js.map +0 -1
- package/dist/components/ListBox/common.d.ts +0 -46
- package/dist/components/ListBox/common.d.ts.map +0 -1
- package/dist/components/ListBox/common.js +0 -118
- package/dist/components/ListBox/common.js.map +0 -1
- package/dist/components/ListBox/index.d.ts +0 -21
- package/dist/components/ListBox/index.d.ts.map +0 -1
- package/dist/components/ListBox/index.js +0 -71
- package/dist/components/ListBox/index.js.map +0 -1
- package/dist/components/ListBox/listbox.js +0 -46
- package/dist/components/ListBox/listbox.js.map +0 -1
- package/dist/components/ListBox/operations.js +0 -330
- package/dist/components/ListBox/operations.js.map +0 -1
- package/dist/components/ListBox/useIndexedChildren.js +0 -25
- package/dist/components/ListBox/useIndexedChildren.js.map +0 -1
- package/dist/components/ListBox/useListboxAutofocus.js +0 -48
- package/dist/components/ListBox/useListboxAutofocus.js.map +0 -1
- package/dist/components/ListBox/useListboxContextValue.js +0 -8
- package/dist/components/ListBox/useListboxContextValue.js.map +0 -1
- package/dist/components/ListBox/useShoutSelectionChange.js +0 -26
- package/dist/components/ListBox/useShoutSelectionChange.js.map +0 -1
- package/dist/components/ListBox/useStore.js +0 -36
- package/dist/components/ListBox/useStore.js.map +0 -1
- package/dist/components/ListBox/useUpdateRowCount.js +0 -19
- package/dist/components/ListBox/useUpdateRowCount.js.map +0 -1
- package/dist/components/SortableList/SortableListHandler.js +0 -161
- package/dist/components/SortableList/SortableListHandler.js.map +0 -1
- package/dist/components/SortableList/SortableListItem.d.ts +0 -14
- package/dist/components/SortableList/SortableListItem.d.ts.map +0 -1
- package/dist/components/SortableList/SortableListItem.js +0 -24
- package/dist/components/SortableList/SortableListItem.js.map +0 -1
- package/dist/components/SortableList/index.d.ts +0 -21
- package/dist/components/SortableList/index.d.ts.map +0 -1
- package/dist/components/SortableList/index.js +0 -53
- package/dist/components/SortableList/index.js.map +0 -1
- package/dist/components/Toolbar/ToolbarController.d.ts +0 -24
- package/dist/components/Toolbar/ToolbarController.d.ts.map +0 -1
- package/dist/components/Toolbar/ToolbarController.js +0 -50
- package/dist/components/Toolbar/ToolbarController.js.map +0 -1
- package/dist/components/Toolbar/ToolbarIconButton.d.ts +0 -7
- package/dist/components/Toolbar/ToolbarIconButton.d.ts.map +0 -1
- package/dist/components/Toolbar/ToolbarIconButton.js +0 -108
- package/dist/components/Toolbar/ToolbarIconButton.js.map +0 -1
- package/dist/components/Toolbar/ToolbarInput.d.ts +0 -7
- package/dist/components/Toolbar/ToolbarInput.d.ts.map +0 -1
- package/dist/components/Toolbar/ToolbarInput.js +0 -13
- package/dist/components/Toolbar/ToolbarInput.js.map +0 -1
- package/dist/components/Toolbar/ToolbarSelect.d.ts +0 -7
- package/dist/components/Toolbar/ToolbarSelect.d.ts.map +0 -1
- package/dist/components/Toolbar/ToolbarSelect.js +0 -17
- package/dist/components/Toolbar/ToolbarSelect.js.map +0 -1
- package/dist/components/Toolbar/ToolbarSeparator.d.ts +0 -6
- package/dist/components/Toolbar/ToolbarSeparator.d.ts.map +0 -1
- package/dist/components/Toolbar/ToolbarSeparator.js +0 -9
- package/dist/components/Toolbar/ToolbarSeparator.js.map +0 -1
- package/dist/components/Toolbar/ToolbarTextButton.d.ts +0 -9
- package/dist/components/Toolbar/ToolbarTextButton.d.ts.map +0 -1
- package/dist/components/Toolbar/ToolbarTextButton.js +0 -18
- package/dist/components/Toolbar/ToolbarTextButton.js.map +0 -1
- package/dist/components/Toolbar/index.d.ts +0 -19
- package/dist/components/Toolbar/index.d.ts.map +0 -1
- package/dist/components/Toolbar/index.js +0 -23
- package/dist/components/Toolbar/index.js.map +0 -1
- package/dist/components/Toolbar/styles.js +0 -84
- package/dist/components/Toolbar/styles.js.map +0 -1
- package/dist/components/Toolbar/types.d.ts +0 -39
- package/dist/components/Toolbar/types.d.ts.map +0 -1
- package/dist/components/accordion/Accordion.d.ts +0 -20
- package/dist/components/accordion/Accordion.d.ts.map +0 -1
- package/dist/components/accordion/Accordion.js +0 -60
- package/dist/components/accordion/Accordion.js.map +0 -1
- package/dist/components/accordion/AccordionItem.d.ts +0 -19
- package/dist/components/accordion/AccordionItem.d.ts.map +0 -1
- package/dist/components/accordion/AccordionItem.js +0 -22
- package/dist/components/accordion/AccordionItem.js.map +0 -1
- package/dist/components/accordion/AccordionItemButton.d.ts +0 -10
- package/dist/components/accordion/AccordionItemButton.d.ts.map +0 -1
- package/dist/components/accordion/AccordionItemButton.js +0 -8
- package/dist/components/accordion/AccordionItemButton.js.map +0 -1
- package/dist/components/accordion/AccordionItemContent.d.ts +0 -7
- package/dist/components/accordion/AccordionItemContent.d.ts.map +0 -1
- package/dist/components/accordion/AccordionItemContent.js +0 -50
- package/dist/components/accordion/AccordionItemContent.js.map +0 -1
- package/dist/components/accordion/KeyHandler.js +0 -77
- package/dist/components/accordion/KeyHandler.js.map +0 -1
- package/dist/components/accordion/context.d.ts +0 -10
- package/dist/components/accordion/context.d.ts.map +0 -1
- package/dist/components/accordion/context.js +0 -13
- package/dist/components/accordion/context.js.map +0 -1
- package/dist/components/accordion/defaultElements/Checkbox.js +0 -22
- package/dist/components/accordion/defaultElements/Checkbox.js.map +0 -1
- package/dist/components/accordion/defaultElements/DefaultAccordionItemButton.d.ts +0 -40
- package/dist/components/accordion/defaultElements/DefaultAccordionItemButton.d.ts.map +0 -1
- package/dist/components/accordion/defaultElements/DefaultAccordionItemButton.js +0 -79
- package/dist/components/accordion/defaultElements/DefaultAccordionItemButton.js.map +0 -1
- package/dist/components/accordion/defaultElements/useIsChecked.js +0 -25
- package/dist/components/accordion/defaultElements/useIsChecked.js.map +0 -1
- package/dist/components/accordion/handler.d.ts +0 -40
- package/dist/components/accordion/handler.d.ts.map +0 -1
- package/dist/components/accordion/handler.js +0 -118
- package/dist/components/accordion/handler.js.map +0 -1
- package/dist/components/accordion/index.d.ts +0 -8
- package/dist/components/accordion/index.d.ts.map +0 -1
- package/dist/components/accordion/types.d.ts +0 -11
- package/dist/components/accordion/types.d.ts.map +0 -1
- package/dist/components/apia/ApiaDateFilter.js +0 -57
- package/dist/components/apia/ApiaDateFilter.js.map +0 -1
- package/dist/components/apia/ApiaFilter.d.ts +0 -13
- package/dist/components/apia/ApiaFilter.d.ts.map +0 -1
- package/dist/components/apia/ApiaFilter.js +0 -128
- package/dist/components/apia/ApiaFilter.js.map +0 -1
- package/dist/components/buttons/useOtherTagButton.d.ts +0 -28
- package/dist/components/buttons/useOtherTagButton.d.ts.map +0 -1
- package/dist/components/buttons/useOtherTagButton.js +0 -38
- package/dist/components/buttons/useOtherTagButton.js.map +0 -1
- package/dist/components/collapsiblePanel/index.d.ts +0 -7
- package/dist/components/collapsiblePanel/index.d.ts.map +0 -1
- package/dist/components/collapsiblePanel/index.js +0 -130
- package/dist/components/collapsiblePanel/index.js.map +0 -1
- package/dist/components/collapsiblePanel/styles.js +0 -4
- package/dist/components/collapsiblePanel/styles.js.map +0 -1
- package/dist/components/collapsiblePanel/types.d.ts +0 -23
- package/dist/components/collapsiblePanel/types.d.ts.map +0 -1
- package/dist/components/dialogs/AlertModal.d.ts +0 -11
- package/dist/components/dialogs/AlertModal.d.ts.map +0 -1
- package/dist/components/dialogs/AlertModal.js +0 -42
- package/dist/components/dialogs/AlertModal.js.map +0 -1
- package/dist/components/dialogs/ConfirmModal.d.ts +0 -25
- package/dist/components/dialogs/ConfirmModal.d.ts.map +0 -1
- package/dist/components/dialogs/ConfirmModal.js +0 -45
- package/dist/components/dialogs/ConfirmModal.js.map +0 -1
- package/dist/components/forms/Captcha.d.ts +0 -12
- package/dist/components/forms/Captcha.d.ts.map +0 -1
- package/dist/components/forms/Captcha.js +0 -66
- package/dist/components/forms/Captcha.js.map +0 -1
- package/dist/components/forms/Checkbox.d.ts +0 -21
- package/dist/components/forms/Checkbox.d.ts.map +0 -1
- package/dist/components/forms/Checkbox.js +0 -124
- package/dist/components/forms/Checkbox.js.map +0 -1
- package/dist/components/forms/DateInput.d.ts +0 -44
- package/dist/components/forms/DateInput.d.ts.map +0 -1
- package/dist/components/forms/DateInput.js +0 -246
- package/dist/components/forms/DateInput.js.map +0 -1
- package/dist/components/forms/FieldErrorMessage.d.ts +0 -10
- package/dist/components/forms/FieldErrorMessage.d.ts.map +0 -1
- package/dist/components/forms/FieldErrorMessage.js +0 -34
- package/dist/components/forms/FieldErrorMessage.js.map +0 -1
- package/dist/components/forms/FieldLabel.d.ts +0 -40
- package/dist/components/forms/FieldLabel.d.ts.map +0 -1
- package/dist/components/forms/FieldLabel.js +0 -66
- package/dist/components/forms/FieldLabel.js.map +0 -1
- package/dist/components/forms/IconInput.d.ts +0 -28
- package/dist/components/forms/IconInput.d.ts.map +0 -1
- package/dist/components/forms/IconInput.js +0 -80
- package/dist/components/forms/IconInput.js.map +0 -1
- package/dist/components/forms/NumberInput.d.ts +0 -37
- package/dist/components/forms/NumberInput.d.ts.map +0 -1
- package/dist/components/forms/NumberInput.js +0 -149
- package/dist/components/forms/NumberInput.js.map +0 -1
- package/dist/components/forms/RequiredMark.d.ts +0 -14
- package/dist/components/forms/RequiredMark.d.ts.map +0 -1
- package/dist/components/forms/RequiredMark.js +0 -13
- package/dist/components/forms/RequiredMark.js.map +0 -1
- package/dist/components/forms/buttons/BaseButton.d.ts +0 -24
- package/dist/components/forms/buttons/BaseButton.d.ts.map +0 -1
- package/dist/components/forms/buttons/BaseButton.js +0 -58
- package/dist/components/forms/buttons/BaseButton.js.map +0 -1
- package/dist/components/forms/buttons/IconButton.d.ts +0 -37
- package/dist/components/forms/buttons/IconButton.d.ts.map +0 -1
- package/dist/components/forms/buttons/IconButton.js +0 -79
- package/dist/components/forms/buttons/IconButton.js.map +0 -1
- package/dist/components/forms/buttons/SimpleButton.d.ts +0 -21
- package/dist/components/forms/buttons/SimpleButton.d.ts.map +0 -1
- package/dist/components/forms/buttons/SimpleButton.js +0 -94
- package/dist/components/forms/buttons/SimpleButton.js.map +0 -1
- package/dist/components/forms/util/style.d.ts +0 -7
- package/dist/components/forms/util/style.d.ts.map +0 -1
- package/dist/components/forms/util/style.js +0 -17
- package/dist/components/forms/util/style.js.map +0 -1
- package/dist/components/importComponent.d.ts +0 -11
- package/dist/components/importComponent.d.ts.map +0 -1
- package/dist/components/importComponent.js +0 -25
- package/dist/components/importComponent.js.map +0 -1
- package/dist/components/loaders/LinearLoader.d.ts +0 -6
- package/dist/components/loaders/LinearLoader.d.ts.map +0 -1
- package/dist/components/loaders/LinearLoader.js +0 -33
- package/dist/components/loaders/LinearLoader.js.map +0 -1
- package/dist/components/loaders/LoaderSpinner.d.ts +0 -10
- package/dist/components/loaders/LoaderSpinner.d.ts.map +0 -1
- package/dist/components/loaders/LoaderSpinner.js +0 -26
- package/dist/components/loaders/LoaderSpinner.js.map +0 -1
- package/dist/components/loaders/ProgressBar.d.ts +0 -11
- package/dist/components/loaders/ProgressBar.d.ts.map +0 -1
- package/dist/components/loaders/ProgressBar.js +0 -39
- package/dist/components/loaders/ProgressBar.js.map +0 -1
- package/dist/components/modals/CalendarModal.d.ts +0 -13
- package/dist/components/modals/CalendarModal.d.ts.map +0 -1
- package/dist/components/modals/CalendarModal.js +0 -43
- package/dist/components/modals/CalendarModal.js.map +0 -1
- package/dist/components/modals/Modal.d.ts +0 -152
- package/dist/components/modals/Modal.d.ts.map +0 -1
- package/dist/components/modals/Modal.js +0 -17
- package/dist/components/modals/Modal.js.map +0 -1
- package/dist/components/modals/ModalContext.d.ts +0 -9
- package/dist/components/modals/ModalContext.d.ts.map +0 -1
- package/dist/components/modals/ModalContext.js +0 -12
- package/dist/components/modals/ModalContext.js.map +0 -1
- package/dist/components/modals/Overlay.d.ts +0 -21
- package/dist/components/modals/Overlay.d.ts.map +0 -1
- package/dist/components/modals/Overlay.js +0 -74
- package/dist/components/modals/Overlay.js.map +0 -1
- package/dist/components/modals/StaticModal.js +0 -203
- package/dist/components/modals/StaticModal.js.map +0 -1
- package/dist/components/modals/WindowModal.js +0 -8
- package/dist/components/modals/WindowModal.js.map +0 -1
- package/dist/components/modals/hooks/useModal.d.ts +0 -97
- package/dist/components/modals/hooks/useModal.d.ts.map +0 -1
- package/dist/components/modals/hooks/useModal.js +0 -73
- package/dist/components/modals/hooks/useModal.js.map +0 -1
- package/dist/components/modals/layout/Confirm.d.ts +0 -7
- package/dist/components/modals/layout/Confirm.d.ts.map +0 -1
- package/dist/components/modals/layout/Confirm.js +0 -96
- package/dist/components/modals/layout/Confirm.js.map +0 -1
- package/dist/components/modals/layout/DialogButtonBar.d.ts +0 -10
- package/dist/components/modals/layout/DialogButtonBar.d.ts.map +0 -1
- package/dist/components/modals/layout/DialogButtonBar.js +0 -19
- package/dist/components/modals/layout/DialogButtonBar.js.map +0 -1
- package/dist/components/modals/layout/DialogHeader.d.ts +0 -18
- package/dist/components/modals/layout/DialogHeader.d.ts.map +0 -1
- package/dist/components/modals/layout/DialogHeader.js +0 -117
- package/dist/components/modals/layout/DialogHeader.js.map +0 -1
- package/dist/components/responsive/AutoEllipsis.d.ts +0 -21
- package/dist/components/responsive/AutoEllipsis.d.ts.map +0 -1
- package/dist/components/responsive/AutoEllipsis.js +0 -128
- package/dist/components/responsive/AutoEllipsis.js.map +0 -1
- package/dist/components/responsive/makeResponsiveComponent.d.ts +0 -38
- package/dist/components/responsive/makeResponsiveComponent.d.ts.map +0 -1
- package/dist/components/responsive/makeResponsiveComponent.js +0 -88
- package/dist/components/responsive/makeResponsiveComponent.js.map +0 -1
- package/dist/components/types.d.ts +0 -5
- package/dist/components/types.d.ts.map +0 -1
- package/dist/components/waiAriaHelpers/typeAhead.d.ts +0 -44
- package/dist/components/waiAriaHelpers/typeAhead.d.ts.map +0 -1
- package/dist/components/waiAriaHelpers/typeAhead.js +0 -75
- package/dist/components/waiAriaHelpers/typeAhead.js.map +0 -1
- package/dist/globalFocus.js +0 -95
- package/dist/globalFocus.js.map +0 -1
- package/dist/hooks/useBodyScrollLock.js +0 -106
- package/dist/hooks/useBodyScrollLock.js.map +0 -1
- package/dist/objects/ApiaUtil/dialogs/ApiaUtilDialogs.d.ts +0 -18
- package/dist/objects/ApiaUtil/dialogs/ApiaUtilDialogs.d.ts.map +0 -1
- package/dist/objects/ApiaUtil/dialogs/ApiaUtilDialogs.js +0 -116
- package/dist/objects/ApiaUtil/dialogs/ApiaUtilDialogs.js.map +0 -1
- package/dist/objects/ApiaUtil/index.d.ts +0 -27
- package/dist/objects/ApiaUtil/index.d.ts.map +0 -1
- package/dist/objects/ApiaUtil/index.js +0 -89
- package/dist/objects/ApiaUtil/index.js.map +0 -1
- package/dist/objects/ApiaUtil/menu/ApiaUtilMenu.d.ts +0 -23
- package/dist/objects/ApiaUtil/menu/ApiaUtilMenu.d.ts.map +0 -1
- package/dist/objects/ApiaUtil/menu/ApiaUtilMenu.js +0 -108
- package/dist/objects/ApiaUtil/menu/ApiaUtilMenu.js.map +0 -1
- package/dist/objects/ApiaUtil/modals/ApiaUtilModals.d.ts +0 -17
- package/dist/objects/ApiaUtil/modals/ApiaUtilModals.d.ts.map +0 -1
- package/dist/objects/ApiaUtil/modals/ApiaUtilModals.js +0 -111
- package/dist/objects/ApiaUtil/modals/ApiaUtilModals.js.map +0 -1
- package/dist/objects/ApiaUtil/modals/OpenModal.d.ts +0 -8
- package/dist/objects/ApiaUtil/modals/OpenModal.d.ts.map +0 -1
- package/dist/objects/ApiaUtil/modals/OpenModal.js +0 -19
- package/dist/objects/ApiaUtil/modals/OpenModal.js.map +0 -1
- package/dist/objects/ApiaUtil/mouse/ApiaUtilMouse.d.ts +0 -19
- package/dist/objects/ApiaUtil/mouse/ApiaUtilMouse.d.ts.map +0 -1
- package/dist/objects/ApiaUtil/mouse/ApiaUtilMouse.js +0 -26
- package/dist/objects/ApiaUtil/mouse/ApiaUtilMouse.js.map +0 -1
- package/dist/objects/ApiaUtil/notifications/ApiaUtilNotifications.d.ts +0 -14
- package/dist/objects/ApiaUtil/notifications/ApiaUtilNotifications.d.ts.map +0 -1
- package/dist/objects/ApiaUtil/notifications/ApiaUtilNotifications.js +0 -33
- package/dist/objects/ApiaUtil/notifications/ApiaUtilNotifications.js.map +0 -1
- package/dist/objects/ApiaUtil/parsers/ApiaUtilParsers.d.ts +0 -23
- package/dist/objects/ApiaUtil/parsers/ApiaUtilParsers.d.ts.map +0 -1
- package/dist/objects/ApiaUtil/parsers/ApiaUtilParsers.js +0 -79
- package/dist/objects/ApiaUtil/parsers/ApiaUtilParsers.js.map +0 -1
- package/dist/objects/ApiaUtil/tabs/ApiaUtilCurrentTab.d.ts +0 -33
- package/dist/objects/ApiaUtil/tabs/ApiaUtilCurrentTab.d.ts.map +0 -1
- package/dist/objects/ApiaUtil/tabs/ApiaUtilCurrentTab.js +0 -50
- package/dist/objects/ApiaUtil/tabs/ApiaUtilCurrentTab.js.map +0 -1
- package/dist/objects/ApiaUtil/tabs/ApiaUtilTabsController.d.ts +0 -20
- package/dist/objects/ApiaUtil/tabs/ApiaUtilTabsController.d.ts.map +0 -1
- package/dist/objects/ApiaUtil/tabs/ApiaUtilTabsController.js +0 -37
- package/dist/objects/ApiaUtil/tabs/ApiaUtilTabsController.js.map +0 -1
- package/dist/objects/ApiaUtil/tabs/util.js +0 -17
- package/dist/objects/ApiaUtil/tabs/util.js.map +0 -1
- package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltip.d.ts +0 -11
- package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltip.d.ts.map +0 -1
- package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltip.js +0 -17
- package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltip.js.map +0 -1
- package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltips.d.ts +0 -22
- package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltips.d.ts.map +0 -1
- package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltips.js +0 -104
- package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltips.js.map +0 -1
- package/dist/objects/ApiaUtil/tooltips/AutomaticTooltip.d.ts +0 -13
- package/dist/objects/ApiaUtil/tooltips/AutomaticTooltip.d.ts.map +0 -1
- package/dist/objects/ApiaUtil/tooltips/AutomaticTooltip.js +0 -79
- package/dist/objects/ApiaUtil/tooltips/AutomaticTooltip.js.map +0 -1
- package/dist/objects/ApiaUtil/tooltips/tooltip/Tooltip.js +0 -62
- package/dist/objects/ApiaUtil/tooltips/tooltip/Tooltip.js.map +0 -1
- package/dist/objects/ApiaUtil/tooltips/tooltip/types.d.ts +0 -117
- package/dist/objects/ApiaUtil/tooltips/tooltip/types.d.ts.map +0 -1
- package/dist/objects/ApiaUtil/tooltips/tooltip/util.js +0 -273
- package/dist/objects/ApiaUtil/tooltips/tooltip/util.js.map +0 -1
- package/dist/objects/ScreenLocker/index.d.ts +0 -37
- package/dist/objects/ScreenLocker/index.d.ts.map +0 -1
- package/dist/objects/ScreenLocker/index.js +0 -92
- package/dist/objects/ScreenLocker/index.js.map +0 -1
- package/dist/tabs/Content.d.ts +0 -7
- package/dist/tabs/Content.d.ts.map +0 -1
- package/dist/tabs/Content.js +0 -52
- package/dist/tabs/Content.js.map +0 -1
- package/dist/tabs/ContextMenu.js +0 -77
- package/dist/tabs/ContextMenu.js.map +0 -1
- package/dist/tabs/Item.js +0 -64
- package/dist/tabs/Item.js.map +0 -1
- package/dist/tabs/Tabs.d.ts +0 -8
- package/dist/tabs/Tabs.d.ts.map +0 -1
- package/dist/tabs/Tabs.js +0 -78
- package/dist/tabs/Tabs.js.map +0 -1
- package/dist/tabs/TabsList.d.ts +0 -8
- package/dist/tabs/TabsList.d.ts.map +0 -1
- package/dist/tabs/TabsList.js +0 -138
- package/dist/tabs/TabsList.js.map +0 -1
- package/dist/tabs/renderers/DefaultTabsLabelRenderer.d.ts +0 -6
- package/dist/tabs/renderers/DefaultTabsLabelRenderer.d.ts.map +0 -1
- package/dist/tabs/renderers/DefaultTabsLabelRenderer.js +0 -71
- package/dist/tabs/renderers/DefaultTabsLabelRenderer.js.map +0 -1
- package/dist/tabs/tabsController.d.ts +0 -41
- package/dist/tabs/tabsController.d.ts.map +0 -1
- package/dist/tabs/tabsController.js +0 -303
- package/dist/tabs/tabsController.js.map +0 -1
- package/dist/tabs/types.d.ts +0 -115
- package/dist/tabs/types.d.ts.map +0 -1
- package/dist/tabs/useTabsList.js +0 -20
- package/dist/tabs/useTabsList.js.map +0 -1
- package/dist/tabs/util.js +0 -11
- package/dist/tabs/util.js.map +0 -1
|
@@ -1,117 +0,0 @@
|
|
|
1
|
-
import { jsx, jsxs } from '@apia/theme/jsx-runtime';
|
|
2
|
-
import { useBreakpointIndex, Close, Box, responsive, spacing, Heading } from '@apia/theme';
|
|
3
|
-
import React__default from 'react';
|
|
4
|
-
|
|
5
|
-
const DialogHeader = ({
|
|
6
|
-
className,
|
|
7
|
-
close,
|
|
8
|
-
hideCloseButton,
|
|
9
|
-
id,
|
|
10
|
-
NavBar,
|
|
11
|
-
title = ""
|
|
12
|
-
}) => {
|
|
13
|
-
const breakpointIndex = useBreakpointIndex();
|
|
14
|
-
const Title = /* @__PURE__ */ jsx(
|
|
15
|
-
Heading,
|
|
16
|
-
{
|
|
17
|
-
as: "h3",
|
|
18
|
-
sx: {
|
|
19
|
-
wordBreak: "break-word",
|
|
20
|
-
m: "0",
|
|
21
|
-
flex: "2 0",
|
|
22
|
-
color: "title"
|
|
23
|
-
},
|
|
24
|
-
className: "modal__title",
|
|
25
|
-
id: id ? `modal-${id}-title` : "",
|
|
26
|
-
children: title
|
|
27
|
-
}
|
|
28
|
-
);
|
|
29
|
-
const CloseButton = React__default.useMemo(
|
|
30
|
-
() => hideCloseButton ? null : /* @__PURE__ */ jsx(
|
|
31
|
-
Close,
|
|
32
|
-
{
|
|
33
|
-
role: "button",
|
|
34
|
-
type: "button",
|
|
35
|
-
"aria-label": window.BTN_CLOSE,
|
|
36
|
-
onClick: close,
|
|
37
|
-
title: window.BTN_CLOSE,
|
|
38
|
-
sx: {
|
|
39
|
-
mr: "unset"
|
|
40
|
-
},
|
|
41
|
-
className: "modal__closeButton"
|
|
42
|
-
}
|
|
43
|
-
),
|
|
44
|
-
[close, hideCloseButton]
|
|
45
|
-
);
|
|
46
|
-
const NavBarElement = NavBar && /* @__PURE__ */ jsx(
|
|
47
|
-
Box,
|
|
48
|
-
{
|
|
49
|
-
sx: {
|
|
50
|
-
display: "flex",
|
|
51
|
-
gap: responsive({ 0: 2, 1: "3px", 2: 2 }),
|
|
52
|
-
justifyContent: "end",
|
|
53
|
-
flexDirection: responsive({ 0: "row", 1: "column", 3: "row" }),
|
|
54
|
-
width: responsive({ 0: "auto", 1: "100%", 2: "auto" }),
|
|
55
|
-
flexBasis: "max-content",
|
|
56
|
-
height: "100%"
|
|
57
|
-
},
|
|
58
|
-
className: "modal__headerBar",
|
|
59
|
-
children: NavBar
|
|
60
|
-
}
|
|
61
|
-
);
|
|
62
|
-
return breakpointIndex > 3 ? /* @__PURE__ */ jsxs(
|
|
63
|
-
Box,
|
|
64
|
-
{
|
|
65
|
-
className,
|
|
66
|
-
sx: {
|
|
67
|
-
display: "flex",
|
|
68
|
-
flexDirection: "row",
|
|
69
|
-
alignItems: "start",
|
|
70
|
-
mb: spacing(0),
|
|
71
|
-
justifyContent: "space-between",
|
|
72
|
-
width: "100%",
|
|
73
|
-
gap: spacing(2),
|
|
74
|
-
flexWrap: "nowrap"
|
|
75
|
-
},
|
|
76
|
-
children: [
|
|
77
|
-
Title,
|
|
78
|
-
NavBarElement,
|
|
79
|
-
CloseButton
|
|
80
|
-
]
|
|
81
|
-
}
|
|
82
|
-
) : /* @__PURE__ */ jsxs(
|
|
83
|
-
Box,
|
|
84
|
-
{
|
|
85
|
-
className,
|
|
86
|
-
sx: {
|
|
87
|
-
display: "flex",
|
|
88
|
-
flexDirection: "column",
|
|
89
|
-
alignItems: responsive({ 0: "center", 2: "end" }),
|
|
90
|
-
mb: spacing(0),
|
|
91
|
-
justifyContent: "space-between",
|
|
92
|
-
width: "100%",
|
|
93
|
-
gap: spacing(2)
|
|
94
|
-
},
|
|
95
|
-
children: [
|
|
96
|
-
/* @__PURE__ */ jsxs(
|
|
97
|
-
Box,
|
|
98
|
-
{
|
|
99
|
-
sx: {
|
|
100
|
-
display: "flex",
|
|
101
|
-
width: "100%"
|
|
102
|
-
},
|
|
103
|
-
children: [
|
|
104
|
-
Title,
|
|
105
|
-
CloseButton
|
|
106
|
-
]
|
|
107
|
-
}
|
|
108
|
-
),
|
|
109
|
-
NavBarElement
|
|
110
|
-
]
|
|
111
|
-
}
|
|
112
|
-
);
|
|
113
|
-
};
|
|
114
|
-
var DialogHeader$1 = DialogHeader;
|
|
115
|
-
|
|
116
|
-
export { DialogHeader$1 as default };
|
|
117
|
-
//# sourceMappingURL=DialogHeader.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"DialogHeader.js","sources":["../../../../src/components/modals/layout/DialogHeader.tsx"],"sourcesContent":["import { Box, Close, Heading, useBreakpointIndex } from '@apia/theme';\nimport React, { FC } from 'react';\nimport { responsive, spacing } from '@apia/theme';\n\nexport interface IDialogHeader {\n className?: string;\n close: () => void;\n hideCloseButton?: boolean;\n id?: string;\n NavBar?: React.ReactNode;\n title?: string;\n}\n\ndeclare global {\n interface Window {\n BTN_CLOSE: string;\n }\n}\n\nconst DialogHeader: FC<IDialogHeader> = ({\n className,\n close,\n hideCloseButton,\n id,\n NavBar,\n title = '',\n}) => {\n const breakpointIndex = useBreakpointIndex();\n\n const Title = (\n <Heading\n as=\"h3\"\n sx={{\n wordBreak: 'break-word',\n m: '0',\n flex: '2 0',\n color: 'title',\n }}\n className=\"modal__title\"\n id={id ? `modal-${id}-title` : ''}\n >\n {title}\n </Heading>\n );\n\n const CloseButton = React.useMemo(\n () =>\n hideCloseButton ? null : (\n <Close\n role=\"button\"\n type=\"button\"\n aria-label={window.BTN_CLOSE}\n onClick={close}\n title={window.BTN_CLOSE}\n sx={{\n mr: 'unset',\n }}\n className=\"modal__closeButton\"\n />\n ),\n [close, hideCloseButton],\n );\n\n const NavBarElement = NavBar && (\n <Box\n sx={{\n display: 'flex',\n gap: responsive({ 0: 2, 1: '3px', 2: 2 }),\n justifyContent: 'end',\n flexDirection: responsive({ 0: 'row', 1: 'column', 3: 'row' }),\n width: responsive({ 0: 'auto', 1: '100%', 2: 'auto' }),\n flexBasis: 'max-content',\n height: '100%',\n }}\n className=\"modal__headerBar\"\n >\n {NavBar}\n </Box>\n );\n\n return breakpointIndex > 3 ? (\n <Box\n className={className}\n sx={{\n display: 'flex',\n flexDirection: 'row',\n alignItems: 'start',\n mb: spacing(0),\n justifyContent: 'space-between',\n width: '100%',\n gap: spacing(2),\n flexWrap: 'nowrap',\n }}\n >\n {Title}\n {NavBarElement}\n {CloseButton}\n </Box>\n ) : (\n <Box\n className={className}\n sx={{\n display: 'flex',\n flexDirection: 'column',\n alignItems: responsive({ 0: 'center', 2: 'end' }),\n mb: spacing(0),\n justifyContent: 'space-between',\n width: '100%',\n gap: spacing(2),\n }}\n >\n <Box\n sx={{\n display: 'flex',\n width: '100%',\n }}\n >\n {Title}\n {CloseButton}\n </Box>\n {NavBarElement}\n </Box>\n );\n};\n\nexport default DialogHeader;\n"],"names":["React"],"mappings":"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"}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
import { ReactNode } from 'react';
|
|
3
|
-
|
|
4
|
-
declare const AutoEllipsis: ({ children, findParent, overrideStyles, }: {
|
|
5
|
-
children: ReactNode;
|
|
6
|
-
/**
|
|
7
|
-
* Si se pasa el método findParent, será invocado con el nodo de AutoEllipsis
|
|
8
|
-
* para dar control sobre cuál es el elemento al que se le clonarán los
|
|
9
|
-
* estilos.
|
|
10
|
-
*/
|
|
11
|
-
findParent?: ((currentElement: HTMLElement) => HTMLElement) | undefined;
|
|
12
|
-
/**
|
|
13
|
-
* Si se pasa overrideStyles, será invocado con el nodo actual de
|
|
14
|
-
* AutoEllipsis para tomar decisiones acerca de cuáles estilos serán
|
|
15
|
-
* aplicados.
|
|
16
|
-
*/
|
|
17
|
-
overrideStyles?: ((currentElement: HTMLElement) => Partial<CSSStyleDeclaration>) | undefined;
|
|
18
|
-
}) => React.JSX.Element;
|
|
19
|
-
|
|
20
|
-
export { AutoEllipsis };
|
|
21
|
-
//# sourceMappingURL=AutoEllipsis.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AutoEllipsis.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
|
|
@@ -1,128 +0,0 @@
|
|
|
1
|
-
import { jsx } from '@apia/theme/jsx-runtime';
|
|
2
|
-
import { isChild } from '@apia/util';
|
|
3
|
-
import { useRef, useCallback, useEffect } from 'react';
|
|
4
|
-
import { Box } from '@apia/theme';
|
|
5
|
-
|
|
6
|
-
const AutoEllipsis = ({
|
|
7
|
-
children,
|
|
8
|
-
findParent,
|
|
9
|
-
overrideStyles
|
|
10
|
-
}) => {
|
|
11
|
-
const unsuscribe = useRef(() => {
|
|
12
|
-
});
|
|
13
|
-
const clone = useRef(null);
|
|
14
|
-
const timeout = useRef(0);
|
|
15
|
-
const ref = useCallback(
|
|
16
|
-
(el) => {
|
|
17
|
-
if (!el)
|
|
18
|
-
return;
|
|
19
|
-
unsuscribe.current();
|
|
20
|
-
function showBox() {
|
|
21
|
-
clone.current = el.cloneNode(true);
|
|
22
|
-
Object.entries(window.getComputedStyle(findParent?.(el) ?? el)).forEach(
|
|
23
|
-
([name, value]) => {
|
|
24
|
-
if (name.match(/webkit/))
|
|
25
|
-
return;
|
|
26
|
-
try {
|
|
27
|
-
clone.current.style[name] = value;
|
|
28
|
-
} catch (e) {
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
);
|
|
32
|
-
const bound = el.getBoundingClientRect();
|
|
33
|
-
clone.current.style.position = "fixed";
|
|
34
|
-
clone.current.style.left = `${bound.left - 1}px`;
|
|
35
|
-
clone.current.style.top = `${bound.top - 1}px`;
|
|
36
|
-
clone.current.style.width = `${bound.width + 8}px`;
|
|
37
|
-
clone.current.style.whiteSpace = "break-spaces";
|
|
38
|
-
clone.current.style.overflow = "visible";
|
|
39
|
-
clone.current.style.textOverflow = "unset";
|
|
40
|
-
clone.current.style.background = "var(--theme-ui-colors-palette-background-paper)";
|
|
41
|
-
clone.current.style.color = "var(--theme-ui-colors-palette-text-primary)";
|
|
42
|
-
clone.current.style.border = "1px solid";
|
|
43
|
-
clone.current.style.borderColor = "var(--theme-ui-colors-palette-border-field)";
|
|
44
|
-
clone.current.style.zIndex = "1000000";
|
|
45
|
-
clone.current.style.height = "auto";
|
|
46
|
-
clone.current.style.fill = "var(--theme-ui-colors-palette-text-primary)";
|
|
47
|
-
clone.current.style.pointerEvents = "none";
|
|
48
|
-
const overridenStyles = overrideStyles?.(el);
|
|
49
|
-
if (overridenStyles) {
|
|
50
|
-
Object.entries(overridenStyles).forEach(([name, value]) => {
|
|
51
|
-
if (name.match(/webkit/))
|
|
52
|
-
return;
|
|
53
|
-
try {
|
|
54
|
-
clone.current.style[name] = value;
|
|
55
|
-
} catch (e) {
|
|
56
|
-
}
|
|
57
|
-
});
|
|
58
|
-
}
|
|
59
|
-
clone.current.addEventListener("mouseleave", (ev) => {
|
|
60
|
-
if (isChild(
|
|
61
|
-
ev.relatedTarget,
|
|
62
|
-
(current) => current === el
|
|
63
|
-
))
|
|
64
|
-
return;
|
|
65
|
-
clone.current?.remove();
|
|
66
|
-
});
|
|
67
|
-
function close() {
|
|
68
|
-
clone.current?.remove();
|
|
69
|
-
document.removeEventListener("scroll", close);
|
|
70
|
-
}
|
|
71
|
-
document.addEventListener("scroll", close);
|
|
72
|
-
document.body.append(clone.current);
|
|
73
|
-
const cloneBounding = clone.current.getBoundingClientRect();
|
|
74
|
-
const difX = Math.abs(cloneBounding.width - bound.width);
|
|
75
|
-
const difY = Math.abs(cloneBounding.height - bound.height);
|
|
76
|
-
if (difX < 50 && difY < 10) {
|
|
77
|
-
clone.current.remove();
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
function hideBox(ev) {
|
|
81
|
-
if (isChild(
|
|
82
|
-
ev.relatedTarget,
|
|
83
|
-
(current) => current === clone.current
|
|
84
|
-
))
|
|
85
|
-
return;
|
|
86
|
-
clone.current?.remove();
|
|
87
|
-
}
|
|
88
|
-
function handleMouseEnter() {
|
|
89
|
-
timeout.current = setTimeout(() => {
|
|
90
|
-
showBox();
|
|
91
|
-
}, 500);
|
|
92
|
-
}
|
|
93
|
-
function handleMouseLeave(ev) {
|
|
94
|
-
clearTimeout(timeout.current);
|
|
95
|
-
hideBox(ev);
|
|
96
|
-
}
|
|
97
|
-
el.addEventListener("mouseenter", handleMouseEnter);
|
|
98
|
-
el.addEventListener("mouseleave", handleMouseLeave);
|
|
99
|
-
unsuscribe.current = () => {
|
|
100
|
-
el.removeEventListener("mouseenter", handleMouseEnter);
|
|
101
|
-
el.removeEventListener("mouseleave", handleMouseLeave);
|
|
102
|
-
clearTimeout(timeout.current);
|
|
103
|
-
};
|
|
104
|
-
},
|
|
105
|
-
[findParent, overrideStyles]
|
|
106
|
-
);
|
|
107
|
-
useEffect(() => {
|
|
108
|
-
return () => {
|
|
109
|
-
clone.current?.remove();
|
|
110
|
-
};
|
|
111
|
-
}, []);
|
|
112
|
-
return /* @__PURE__ */ jsx(
|
|
113
|
-
Box,
|
|
114
|
-
{
|
|
115
|
-
ref,
|
|
116
|
-
sx: {
|
|
117
|
-
overflow: "hidden",
|
|
118
|
-
textOverflow: "ellipsis",
|
|
119
|
-
whiteSpace: "nowrap"
|
|
120
|
-
},
|
|
121
|
-
className: "autoellipsis__container",
|
|
122
|
-
children
|
|
123
|
-
}
|
|
124
|
-
);
|
|
125
|
-
};
|
|
126
|
-
|
|
127
|
-
export { AutoEllipsis };
|
|
128
|
-
//# sourceMappingURL=AutoEllipsis.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AutoEllipsis.js","sources":["../../../src/components/responsive/AutoEllipsis.tsx"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport { isChild } from '@apia/util';\nimport { useEffect, ReactNode, useRef, useCallback } from 'react';\nimport { Box } from '@apia/theme';\n\nexport const AutoEllipsis = ({\n children,\n findParent,\n overrideStyles,\n}: {\n children: ReactNode;\n /**\n * Si se pasa el método findParent, será invocado con el nodo de AutoEllipsis\n * para dar control sobre cuál es el elemento al que se le clonarán los\n * estilos.\n */\n findParent?: (currentElement: HTMLElement) => HTMLElement;\n /**\n * Si se pasa overrideStyles, será invocado con el nodo actual de\n * AutoEllipsis para tomar decisiones acerca de cuáles estilos serán\n * aplicados.\n */\n overrideStyles?: (\n currentElement: HTMLElement,\n ) => Partial<CSSStyleDeclaration>;\n}) => {\n const unsuscribe = useRef(() => {});\n const clone = useRef<HTMLElement | null>(null);\n const timeout = useRef(0);\n const ref = useCallback(\n (el: HTMLElement) => {\n if (!el) return;\n\n unsuscribe.current();\n\n function showBox() {\n clone.current = el.cloneNode(true) as HTMLElement;\n Object.entries(window.getComputedStyle(findParent?.(el) ?? el)).forEach(\n ([name, value]) => {\n if (name.match(/webkit/)) return;\n try {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-explicit-any\n (clone.current as HTMLElement).style[name as any] = value;\n } catch (e) {}\n },\n );\n\n const bound = el.getBoundingClientRect();\n clone.current.style.position = 'fixed';\n clone.current.style.left = `${bound.left - 1}px`;\n clone.current.style.top = `${bound.top - 1}px`;\n clone.current.style.width = `${bound.width + 8}px`;\n clone.current.style.whiteSpace = 'break-spaces';\n clone.current.style.overflow = 'visible';\n clone.current.style.textOverflow = 'unset';\n clone.current.style.background =\n 'var(--theme-ui-colors-palette-background-paper)';\n clone.current.style.color =\n 'var(--theme-ui-colors-palette-text-primary)';\n clone.current.style.border = '1px solid';\n clone.current.style.borderColor =\n 'var(--theme-ui-colors-palette-border-field)';\n clone.current.style.zIndex = '1000000';\n clone.current.style.height = 'auto';\n clone.current.style.fill =\n 'var(--theme-ui-colors-palette-text-primary)';\n clone.current.style.pointerEvents = 'none';\n\n const overridenStyles = overrideStyles?.(el);\n\n if (overridenStyles) {\n Object.entries(overridenStyles).forEach(([name, value]) => {\n if (name.match(/webkit/)) return;\n\n try {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-explicit-any\n (clone.current as HTMLElement).style[name as any] =\n value as string;\n } catch (e) {}\n });\n }\n\n clone.current.addEventListener('mouseleave', (ev) => {\n if (\n isChild(\n ev.relatedTarget as HTMLElement,\n (current) => current === el,\n )\n )\n return;\n\n clone.current?.remove();\n });\n\n function close() {\n clone.current?.remove();\n document.removeEventListener('scroll', close);\n }\n document.addEventListener('scroll', close);\n document.body.append(clone.current);\n\n const cloneBounding = clone.current.getBoundingClientRect();\n\n const difX = Math.abs(cloneBounding.width - bound.width);\n const difY = Math.abs(cloneBounding.height - bound.height);\n\n if (difX < 50 && difY < 10) {\n clone.current.remove();\n }\n }\n\n function hideBox(ev: MouseEvent) {\n if (\n isChild(\n ev.relatedTarget as HTMLElement,\n (current) => current === clone.current,\n )\n )\n return;\n\n clone.current?.remove();\n }\n\n function handleMouseEnter() {\n timeout.current = setTimeout(() => {\n showBox();\n }, 500) as unknown as number;\n }\n function handleMouseLeave(ev: MouseEvent) {\n clearTimeout(timeout.current);\n hideBox(ev);\n }\n\n el.addEventListener('mouseenter', handleMouseEnter);\n el.addEventListener('mouseleave', handleMouseLeave);\n\n unsuscribe.current = () => {\n el.removeEventListener('mouseenter', handleMouseEnter);\n el.removeEventListener('mouseleave', handleMouseLeave);\n clearTimeout(timeout.current);\n };\n },\n [findParent, overrideStyles],\n );\n\n useEffect(() => {\n return () => {\n clone.current?.remove();\n };\n }, []);\n\n return (\n <Box\n ref={ref}\n sx={{\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n }}\n className=\"autoellipsis__container\"\n >\n {children}\n </Box>\n );\n};\n"],"names":[],"mappings":"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"}
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
import { FC, FunctionComponent } from 'react';
|
|
2
|
-
|
|
3
|
-
interface IMakeResponsiveComponent<P extends Record<string, unknown>> {
|
|
4
|
-
breakPoints: number[];
|
|
5
|
-
Component: FunctionComponent<P & {
|
|
6
|
-
breakPoint: number;
|
|
7
|
-
breakPointWidth: number;
|
|
8
|
-
containerWidth: number;
|
|
9
|
-
}>;
|
|
10
|
-
/**
|
|
11
|
-
* Este HOC hace un setState cada vez que cambia el ancho del contenedor. Hay
|
|
12
|
-
* situaciones en las que es deseable agregar un debounce a este
|
|
13
|
-
* comportamiento para mejorar la performance. *Por defecto usa 100*
|
|
14
|
-
*/
|
|
15
|
-
debounce?: number;
|
|
16
|
-
/**
|
|
17
|
-
* Por defecto usa 4.
|
|
18
|
-
*/
|
|
19
|
-
defaultBreakpoint?: number;
|
|
20
|
-
}
|
|
21
|
-
interface IResponsiveComponent<P> extends FC<P> {
|
|
22
|
-
setBreakpoints: {
|
|
23
|
-
current: (breakPoints: number[]) => void;
|
|
24
|
-
};
|
|
25
|
-
}
|
|
26
|
-
/**
|
|
27
|
-
* El método makeResponsiveComponent agrega un wrapper alrededor de un
|
|
28
|
-
* componente para conocer el ancho del contenedor del mismo. De esta forma, es
|
|
29
|
-
* fácil predecir qué ancho dispone el mismo para renderizarse y de esa forma
|
|
30
|
-
* poder tomar decisiones de responsividad que no dependen del ancho de la
|
|
31
|
-
* pantalla sino del espacio donde se encuentra.
|
|
32
|
-
*/
|
|
33
|
-
declare const makeResponsiveComponent: <P extends Record<string, unknown>>({ breakPoints, Component, defaultBreakpoint, }: IMakeResponsiveComponent<P>) => IResponsiveComponent<P & {
|
|
34
|
-
breakPoints?: number[] | undefined;
|
|
35
|
-
}>;
|
|
36
|
-
|
|
37
|
-
export { type IResponsiveComponent, makeResponsiveComponent };
|
|
38
|
-
//# sourceMappingURL=makeResponsiveComponent.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"makeResponsiveComponent.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
|
|
@@ -1,88 +0,0 @@
|
|
|
1
|
-
import { jsx } from '@apia/theme/jsx-runtime';
|
|
2
|
-
import { useState, useRef, useTransition, useCallback, useEffect, useDeferredValue } from 'react';
|
|
3
|
-
import { Box } from '@apia/theme';
|
|
4
|
-
|
|
5
|
-
function calcBreakPoint(currentWidth, breakPoints) {
|
|
6
|
-
let currentIndex = 0;
|
|
7
|
-
while (currentIndex < breakPoints.length && currentWidth > breakPoints[currentIndex])
|
|
8
|
-
currentIndex++;
|
|
9
|
-
return currentIndex;
|
|
10
|
-
}
|
|
11
|
-
const makeResponsiveComponent = ({
|
|
12
|
-
breakPoints,
|
|
13
|
-
Component,
|
|
14
|
-
defaultBreakpoint
|
|
15
|
-
}) => {
|
|
16
|
-
const setBreakpoints = {
|
|
17
|
-
current: () => {
|
|
18
|
-
}
|
|
19
|
-
};
|
|
20
|
-
return Object.assign(
|
|
21
|
-
function ResponsiveComponent(props) {
|
|
22
|
-
const [breakPoint, setCurrentBreakpoint] = useState(
|
|
23
|
-
defaultBreakpoint ?? 4
|
|
24
|
-
);
|
|
25
|
-
const [innerBreakpoints, setInnerBreakpoints] = useState(
|
|
26
|
-
props.breakPoints ?? breakPoints
|
|
27
|
-
);
|
|
28
|
-
setBreakpoints.current = setInnerBreakpoints;
|
|
29
|
-
const [containerWidth, setContainerWidth] = useState(
|
|
30
|
-
breakPoints[defaultBreakpoint ?? 4]
|
|
31
|
-
);
|
|
32
|
-
const observer = useRef(null);
|
|
33
|
-
const shouldDisconnect = useRef(false);
|
|
34
|
-
const [hasRendered, setHasRendered] = useState(false);
|
|
35
|
-
const [, startTransition] = useTransition();
|
|
36
|
-
const ref = useCallback(
|
|
37
|
-
(element) => {
|
|
38
|
-
if (!element)
|
|
39
|
-
return;
|
|
40
|
-
observer.current?.disconnect();
|
|
41
|
-
observer.current = new ResizeObserver((resizeProps) => {
|
|
42
|
-
if (resizeProps[0].contentRect.width === 0)
|
|
43
|
-
return;
|
|
44
|
-
startTransition(() => {
|
|
45
|
-
setContainerWidth(resizeProps[0].contentRect.width);
|
|
46
|
-
setCurrentBreakpoint(
|
|
47
|
-
calcBreakPoint(
|
|
48
|
-
resizeProps[0].contentRect.width,
|
|
49
|
-
innerBreakpoints
|
|
50
|
-
)
|
|
51
|
-
);
|
|
52
|
-
setHasRendered(true);
|
|
53
|
-
});
|
|
54
|
-
});
|
|
55
|
-
if (element)
|
|
56
|
-
observer.current.observe(element);
|
|
57
|
-
},
|
|
58
|
-
[innerBreakpoints]
|
|
59
|
-
);
|
|
60
|
-
useEffect(() => {
|
|
61
|
-
shouldDisconnect.current = false;
|
|
62
|
-
return () => {
|
|
63
|
-
shouldDisconnect.current = true;
|
|
64
|
-
setTimeout(() => {
|
|
65
|
-
if (shouldDisconnect.current) {
|
|
66
|
-
observer.current?.disconnect();
|
|
67
|
-
}
|
|
68
|
-
}, 2e3);
|
|
69
|
-
};
|
|
70
|
-
}, [innerBreakpoints]);
|
|
71
|
-
const deferBreakPoint = useDeferredValue(breakPoint);
|
|
72
|
-
const deferContainerWidth = useDeferredValue(containerWidth);
|
|
73
|
-
return /* @__PURE__ */ jsx(Box, { ref, children: hasRendered ? /* @__PURE__ */ jsx(
|
|
74
|
-
Component,
|
|
75
|
-
{
|
|
76
|
-
...props,
|
|
77
|
-
breakPoint: deferBreakPoint,
|
|
78
|
-
breakPointWidth: breakPoints[deferBreakPoint],
|
|
79
|
-
containerWidth: deferContainerWidth
|
|
80
|
-
}
|
|
81
|
-
) : null });
|
|
82
|
-
},
|
|
83
|
-
{ setBreakpoints }
|
|
84
|
-
);
|
|
85
|
-
};
|
|
86
|
-
|
|
87
|
-
export { makeResponsiveComponent };
|
|
88
|
-
//# sourceMappingURL=makeResponsiveComponent.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"makeResponsiveComponent.js","sources":["../../../src/components/responsive/makeResponsiveComponent.tsx"],"sourcesContent":["import {\n FC,\n FunctionComponent,\n useCallback,\n useDeferredValue,\n useEffect,\n useRef,\n useState,\n useTransition,\n} from 'react';\nimport { Box } from '@apia/theme';\n\ninterface IMakeResponsiveComponent<P extends Record<string, unknown>> {\n breakPoints: number[];\n Component: FunctionComponent<\n P & { breakPoint: number; breakPointWidth: number; containerWidth: number }\n >;\n /**\n * Este HOC hace un setState cada vez que cambia el ancho del contenedor. Hay\n * situaciones en las que es deseable agregar un debounce a este\n * comportamiento para mejorar la performance. *Por defecto usa 100*\n */\n debounce?: number;\n /**\n * Por defecto usa 4.\n */\n defaultBreakpoint?: number;\n}\n\nfunction calcBreakPoint(currentWidth: number, breakPoints: number[]) {\n let currentIndex = 0;\n\n while (\n currentIndex < breakPoints.length &&\n currentWidth > breakPoints[currentIndex]\n )\n currentIndex++;\n\n return currentIndex;\n}\n\nexport interface IResponsiveComponent<P> extends FC<P> {\n setBreakpoints: { current: (breakPoints: number[]) => void };\n}\n\n/**\n * El método makeResponsiveComponent agrega un wrapper alrededor de un\n * componente para conocer el ancho del contenedor del mismo. De esta forma, es\n * fácil predecir qué ancho dispone el mismo para renderizarse y de esa forma\n * poder tomar decisiones de responsividad que no dependen del ancho de la\n * pantalla sino del espacio donde se encuentra.\n */\nexport const makeResponsiveComponent = <P extends Record<string, unknown>>({\n breakPoints,\n Component,\n defaultBreakpoint,\n}: IMakeResponsiveComponent<P>): IResponsiveComponent<\n P & {\n breakPoints?: number[];\n }\n> => {\n const setBreakpoints: { current: (b: number[]) => void } = {\n current: () => {},\n };\n\n return Object.assign(\n function ResponsiveComponent(\n props: P & {\n breakPoints?: number[];\n },\n ) {\n const [breakPoint, setCurrentBreakpoint] = useState<number>(\n defaultBreakpoint ?? 4,\n );\n\n const [innerBreakpoints, setInnerBreakpoints] = useState(\n props.breakPoints ?? breakPoints,\n );\n setBreakpoints.current = setInnerBreakpoints;\n\n const [containerWidth, setContainerWidth] = useState(\n breakPoints[defaultBreakpoint ?? 4],\n );\n const observer = useRef<ResizeObserver | null>(null);\n const shouldDisconnect = useRef(false);\n\n const [hasRendered, setHasRendered] = useState(false);\n const [, startTransition] = useTransition();\n\n const ref = useCallback(\n (element: HTMLElement) => {\n if (!element) return;\n\n observer.current?.disconnect();\n observer.current = new ResizeObserver((resizeProps) => {\n if (resizeProps[0].contentRect.width === 0) return;\n\n startTransition(() => {\n setContainerWidth(resizeProps[0].contentRect.width);\n setCurrentBreakpoint(\n calcBreakPoint(\n resizeProps[0].contentRect.width,\n innerBreakpoints,\n ),\n );\n setHasRendered(true);\n });\n });\n\n if (element) observer.current.observe(element);\n },\n [innerBreakpoints],\n );\n\n useEffect(() => {\n shouldDisconnect.current = false;\n\n return () => {\n shouldDisconnect.current = true;\n setTimeout(() => {\n if (shouldDisconnect.current) {\n observer.current?.disconnect();\n }\n /**\n * El timeout tiene un tiempo arbitrariamente alto ya que de esta\n * forma el observer se va a desconectar una vez que el componente\n * se desmonte. Si pusiera un tiempo menor, caería en el riesgo de\n * que se desconecte aún cuando el componente está montado\n */\n }, 2000);\n };\n }, [innerBreakpoints]);\n\n const deferBreakPoint = useDeferredValue(breakPoint);\n const deferContainerWidth = useDeferredValue(containerWidth);\n\n return (\n <Box ref={ref}>\n {hasRendered ? (\n <Component\n {...props}\n breakPoint={deferBreakPoint}\n breakPointWidth={breakPoints[deferBreakPoint]}\n containerWidth={deferContainerWidth}\n />\n ) : null}\n </Box>\n );\n },\n { setBreakpoints },\n );\n};\n"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
type TModalSize = 'editGrid' | 'sm' | 'md' | 'md-fixed' | 'lg' | 'lg-fixed' | 'xl' | 'xl-fixed' | 'xxl' | 'xxxl' | 'xxxl-fixed' | 'flex' | 'cal' | 'finder';
|
|
2
|
-
type TApiaButtonType = 'primary' | 'primary-sm' | 'secondary' | 'light-secondary' | 'secondary-sm' | 'danger' | 'danger-sm' | 'outline' | 'outline-sm' | 'warning' | 'warning-sm' | 'link';
|
|
3
|
-
|
|
4
|
-
export type { TApiaButtonType, TModalSize };
|
|
5
|
-
//# sourceMappingURL=types.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
|
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
import { EventEmitter } from '@apia/util';
|
|
2
|
-
import { KeyboardEvent } from 'react';
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* Type-ahead is a behavior pattern which helps the user in the lists and trees
|
|
6
|
-
* (and literally says: "especially those with more than seven options")
|
|
7
|
-
* navigation. The literal description in Wai-Aria documentation is:
|
|
8
|
-
*
|
|
9
|
-
* - Type a character: focus moves to the next item with a name that starts
|
|
10
|
-
* with the typed character.
|
|
11
|
-
*
|
|
12
|
-
* - Type multiple characters in rapid succession:
|
|
13
|
-
* focus moves to the next item with a name that starts with the string of
|
|
14
|
-
* characters typed.
|
|
15
|
-
*
|
|
16
|
-
* It is a little arbitrary what is rapid succession. As I couln't find any
|
|
17
|
-
* documentation about what rapid succession means, I will make some tests in
|
|
18
|
-
* order to determine what is more comfortable to accomplish one situation or
|
|
19
|
-
* the other.
|
|
20
|
-
*
|
|
21
|
-
* To callibrate this function it is suficient to override the frequency
|
|
22
|
-
* parameter, which after some tests I understand is best at 2.5 (keys per
|
|
23
|
-
* second).
|
|
24
|
-
*/
|
|
25
|
-
|
|
26
|
-
declare class WaiTypeAhead extends EventEmitter<{
|
|
27
|
-
multipleKeys: string;
|
|
28
|
-
singleKey: string;
|
|
29
|
-
typeUpdate: string;
|
|
30
|
-
}> {
|
|
31
|
-
#private;
|
|
32
|
-
frequency: number;
|
|
33
|
-
timeout: number;
|
|
34
|
-
typing: string;
|
|
35
|
-
constructor(props?: {
|
|
36
|
-
onMultipleKeys?: (value: string) => unknown;
|
|
37
|
-
onSingleKey?: (value: string) => unknown;
|
|
38
|
-
onTypeUpdate?: (value: string) => unknown;
|
|
39
|
-
});
|
|
40
|
-
type(ev: KeyboardEvent): void;
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
export { WaiTypeAhead };
|
|
44
|
-
//# sourceMappingURL=typeAhead.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"typeAhead.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
|
|
@@ -1,75 +0,0 @@
|
|
|
1
|
-
import { EventEmitter } from '@apia/util';
|
|
2
|
-
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
5
|
-
var __publicField = (obj, key, value) => {
|
|
6
|
-
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
7
|
-
return value;
|
|
8
|
-
};
|
|
9
|
-
var __accessCheck = (obj, member, msg) => {
|
|
10
|
-
if (!member.has(obj))
|
|
11
|
-
throw TypeError("Cannot " + msg);
|
|
12
|
-
};
|
|
13
|
-
var __privateAdd = (obj, member, value) => {
|
|
14
|
-
if (member.has(obj))
|
|
15
|
-
throw TypeError("Cannot add the same private member more than once");
|
|
16
|
-
member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
|
|
17
|
-
};
|
|
18
|
-
var __privateMethod = (obj, member, method) => {
|
|
19
|
-
__accessCheck(obj, member, "access private method");
|
|
20
|
-
return method;
|
|
21
|
-
};
|
|
22
|
-
var _restoreTimeout, restoreTimeout_fn, _shout, shout_fn;
|
|
23
|
-
class WaiTypeAhead extends EventEmitter {
|
|
24
|
-
constructor(props) {
|
|
25
|
-
super();
|
|
26
|
-
__privateAdd(this, _restoreTimeout);
|
|
27
|
-
__privateAdd(this, _shout);
|
|
28
|
-
__publicField(this, "frequency", 2.5);
|
|
29
|
-
// Keys per second
|
|
30
|
-
__publicField(this, "timeout", 0);
|
|
31
|
-
__publicField(this, "typing", "");
|
|
32
|
-
const { onMultipleKeys, onSingleKey, onTypeUpdate } = props ?? {};
|
|
33
|
-
if (onMultipleKeys)
|
|
34
|
-
this.on("multipleKeys", onMultipleKeys);
|
|
35
|
-
if (onSingleKey)
|
|
36
|
-
this.on("singleKey", onSingleKey);
|
|
37
|
-
if (onTypeUpdate)
|
|
38
|
-
this.on("typeUpdate", onTypeUpdate);
|
|
39
|
-
}
|
|
40
|
-
type(ev) {
|
|
41
|
-
if (ev.key.match(/^[\p{L}\d ]$/u)) {
|
|
42
|
-
ev.preventDefault();
|
|
43
|
-
this.typing = this.typing + ev.key;
|
|
44
|
-
this.emit("typeUpdate", this.typing);
|
|
45
|
-
__privateMethod(this, _restoreTimeout, restoreTimeout_fn).call(this);
|
|
46
|
-
} else if (ev.code === "Backspace") {
|
|
47
|
-
ev.preventDefault();
|
|
48
|
-
this.typing = this.typing.slice(0, -1);
|
|
49
|
-
this.emit("typeUpdate", this.typing);
|
|
50
|
-
__privateMethod(this, _restoreTimeout, restoreTimeout_fn).call(this);
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
_restoreTimeout = new WeakSet();
|
|
55
|
-
restoreTimeout_fn = function() {
|
|
56
|
-
clearTimeout(this.timeout);
|
|
57
|
-
this.timeout = setTimeout(
|
|
58
|
-
__privateMethod(this, _shout, shout_fn).bind(this),
|
|
59
|
-
1e3 / this.frequency
|
|
60
|
-
);
|
|
61
|
-
};
|
|
62
|
-
_shout = new WeakSet();
|
|
63
|
-
shout_fn = function({ clear } = { clear: true }) {
|
|
64
|
-
if (this.typing.length === 1) {
|
|
65
|
-
this.emit("singleKey", this.typing);
|
|
66
|
-
} else if (this.typing.length > 1) {
|
|
67
|
-
this.emit("multipleKeys", this.typing);
|
|
68
|
-
}
|
|
69
|
-
if (clear) {
|
|
70
|
-
this.typing = "";
|
|
71
|
-
}
|
|
72
|
-
};
|
|
73
|
-
|
|
74
|
-
export { WaiTypeAhead };
|
|
75
|
-
//# sourceMappingURL=typeAhead.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"typeAhead.js","sources":["../../../src/components/waiAriaHelpers/typeAhead.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\n/**\n * Type-ahead is a behavior pattern which helps the user in the lists and trees\n * (and literally says: \"especially those with more than seven options\")\n * navigation. The literal description in Wai-Aria documentation is:\n *\n * - Type a character: focus moves to the next item with a name that starts\n * with the typed character.\n *\n * - Type multiple characters in rapid succession:\n * focus moves to the next item with a name that starts with the string of\n * characters typed.\n *\n * It is a little arbitrary what is rapid succession. As I couln't find any\n * documentation about what rapid succession means, I will make some tests in\n * order to determine what is more comfortable to accomplish one situation or\n * the other.\n *\n * To callibrate this function it is suficient to override the frequency\n * parameter, which after some tests I understand is best at 2.5 (keys per\n * second).\n */\n\nimport { EventEmitter } from '@apia/util';\nimport { KeyboardEvent } from 'react';\n\nclass WaiTypeAhead extends EventEmitter<{\n multipleKeys: string;\n singleKey: string;\n typeUpdate: string;\n}> {\n frequency = 2.5; // Keys per second\n timeout = 0;\n typing = '';\n\n constructor(props?: {\n onMultipleKeys?: (value: string) => unknown;\n onSingleKey?: (value: string) => unknown;\n onTypeUpdate?: (value: string) => unknown;\n }) {\n super();\n\n const { onMultipleKeys, onSingleKey, onTypeUpdate } = props ?? {};\n\n if (onMultipleKeys) this.on('multipleKeys', onMultipleKeys);\n if (onSingleKey) this.on('singleKey', onSingleKey);\n if (onTypeUpdate) this.on('typeUpdate', onTypeUpdate);\n }\n\n #restoreTimeout() {\n clearTimeout(this.timeout);\n\n this.timeout = setTimeout(\n this.#shout.bind(this),\n 1000 / this.frequency,\n ) as any;\n }\n\n #shout({ clear } = { clear: true }) {\n if (this.typing.length === 1) {\n this.emit('singleKey', this.typing);\n } else if (this.typing.length > 1) {\n this.emit('multipleKeys', this.typing);\n }\n if (clear) {\n this.typing = '';\n }\n }\n\n type(ev: KeyboardEvent) {\n if (ev.key.match(/^[\\p{L}\\d ]$/u)) {\n ev.preventDefault();\n this.typing = this.typing + ev.key;\n this.emit('typeUpdate', this.typing);\n this.#restoreTimeout();\n } else if (ev.code === 'Backspace') {\n ev.preventDefault();\n this.typing = this.typing.slice(0, -1);\n this.emit('typeUpdate', this.typing);\n this.#restoreTimeout();\n }\n }\n}\n\nexport { WaiTypeAhead };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA,IAAA,eAAA,EAAA,iBAAA,EAAA,MAAA,EAAA,QAAA,CAAA;AA0BA,MAAM,qBAAqB,YAIxB,CAAA;AAAA,EAKD,YAAY,KAIT,EAAA;AACD,IAAM,KAAA,EAAA,CAAA;AASR,IAAA,YAAA,CAAA,IAAA,EAAA,eAAA,CAAA,CAAA;AASA,IAAA,YAAA,CAAA,IAAA,EAAA,MAAA,CAAA,CAAA;AA3BA,IAAY,aAAA,CAAA,IAAA,EAAA,WAAA,EAAA,GAAA,CAAA,CAAA;AACZ;AAAA,IAAU,aAAA,CAAA,IAAA,EAAA,SAAA,EAAA,CAAA,CAAA,CAAA;AACV,IAAS,aAAA,CAAA,IAAA,EAAA,QAAA,EAAA,EAAA,CAAA,CAAA;AASP,IAAA,MAAM,EAAE,cAAgB,EAAA,WAAA,EAAa,YAAa,EAAA,GAAI,SAAS,EAAC,CAAA;AAEhE,IAAI,IAAA,cAAA;AAAgB,MAAK,IAAA,CAAA,EAAA,CAAG,gBAAgB,cAAc,CAAA,CAAA;AAC1D,IAAI,IAAA,WAAA;AAAa,MAAK,IAAA,CAAA,EAAA,CAAG,aAAa,WAAW,CAAA,CAAA;AACjD,IAAI,IAAA,YAAA;AAAc,MAAK,IAAA,CAAA,EAAA,CAAG,cAAc,YAAY,CAAA,CAAA;AAAA,GACtD;AAAA,EAsBA,KAAK,EAAmB,EAAA;AACtB,IAAA,IAAI,EAAG,CAAA,GAAA,CAAI,KAAM,CAAA,eAAe,CAAG,EAAA;AACjC,MAAA,EAAA,CAAG,cAAe,EAAA,CAAA;AAClB,MAAK,IAAA,CAAA,MAAA,GAAS,IAAK,CAAA,MAAA,GAAS,EAAG,CAAA,GAAA,CAAA;AAC/B,MAAK,IAAA,CAAA,IAAA,CAAK,YAAc,EAAA,IAAA,CAAK,MAAM,CAAA,CAAA;AACnC,MAAA,eAAA,CAAA,IAAA,EAAK,eAAL,EAAA,iBAAA,CAAA,CAAA,IAAA,CAAA,IAAA,CAAA,CAAA;AAAA,KACF,MAAA,IAAW,EAAG,CAAA,IAAA,KAAS,WAAa,EAAA;AAClC,MAAA,EAAA,CAAG,cAAe,EAAA,CAAA;AAClB,MAAA,IAAA,CAAK,MAAS,GAAA,IAAA,CAAK,MAAO,CAAA,KAAA,CAAM,GAAG,CAAE,CAAA,CAAA,CAAA;AACrC,MAAK,IAAA,CAAA,IAAA,CAAK,YAAc,EAAA,IAAA,CAAK,MAAM,CAAA,CAAA;AACnC,MAAA,eAAA,CAAA,IAAA,EAAK,eAAL,EAAA,iBAAA,CAAA,CAAA,IAAA,CAAA,IAAA,CAAA,CAAA;AAAA,KACF;AAAA,GACF;AACF,CAAA;AAjCE,eAAA,GAAA,IAAA,OAAA,EAAA,CAAA;AAAA,iBAAA,GAAe,WAAG;AAChB,EAAA,YAAA,CAAa,KAAK,OAAO,CAAA,CAAA;AAEzB,EAAA,IAAA,CAAK,OAAU,GAAA,UAAA;AAAA,IACb,eAAA,CAAA,IAAA,EAAK,MAAO,EAAA,QAAA,CAAA,CAAA,IAAA,CAAK,IAAI,CAAA;AAAA,IACrB,MAAO,IAAK,CAAA,SAAA;AAAA,GACd,CAAA;AACF,CAAA,CAAA;AAEA,MAAA,GAAA,IAAA,OAAA,EAAA,CAAA;AAAA,QAAA,GAAM,SAAC,EAAE,KAAA,KAAU,EAAE,KAAA,EAAO,MAAQ,EAAA;AAClC,EAAI,IAAA,IAAA,CAAK,MAAO,CAAA,MAAA,KAAW,CAAG,EAAA;AAC5B,IAAK,IAAA,CAAA,IAAA,CAAK,WAAa,EAAA,IAAA,CAAK,MAAM,CAAA,CAAA;AAAA,GACzB,MAAA,IAAA,IAAA,CAAK,MAAO,CAAA,MAAA,GAAS,CAAG,EAAA;AACjC,IAAK,IAAA,CAAA,IAAA,CAAK,cAAgB,EAAA,IAAA,CAAK,MAAM,CAAA,CAAA;AAAA,GACvC;AACA,EAAA,IAAI,KAAO,EAAA;AACT,IAAA,IAAA,CAAK,MAAS,GAAA,EAAA,CAAA;AAAA,GAChB;AACF,CAAA;;;;"}
|