@lumx/vue 4.17.1-alpha.2 → 4.17.1-alpha.3
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/README.md +31 -0
- package/_internal/_virtual/_rolldown/runtime.js +34 -0
- package/_internal/components/alert-dialog/AlertDialog.d.ts +45 -0
- package/_internal/components/alert-dialog/AlertDialog.js +79 -0
- package/_internal/components/alert-dialog/index.d.ts +1 -0
- package/_internal/components/avatar/Avatar.d.ts +30 -0
- package/_internal/components/avatar/Avatar.js +50 -0
- package/_internal/components/avatar/index.d.ts +2 -0
- package/_internal/components/badge/Badge.d.ts +16 -0
- package/_internal/components/badge/Badge.js +25 -0
- package/_internal/components/badge/BadgeWrapper.d.ts +10 -0
- package/_internal/components/badge/BadgeWrapper.js +22 -0
- package/_internal/components/badge/index.d.ts +2 -0
- package/_internal/components/button/Button.d.ts +18 -0
- package/_internal/components/button/Button.js +66 -0
- package/_internal/components/button/ButtonGroup.d.ts +16 -0
- package/_internal/components/button/ButtonGroup.js +25 -0
- package/_internal/components/button/IconButton.d.ts +33 -0
- package/_internal/components/button/IconButton.js +53 -0
- package/_internal/components/button/index.d.ts +4 -0
- package/_internal/components/checkbox/Checkbox.d.ts +20 -0
- package/_internal/components/checkbox/Checkbox.js +55 -0
- package/_internal/components/checkbox/index.d.ts +1 -0
- package/_internal/components/chip/Chip.d.ts +26 -0
- package/_internal/components/chip/Chip.js +74 -0
- package/_internal/components/chip/ChipGroup.d.ts +10 -0
- package/_internal/components/chip/ChipGroup.js +19 -0
- package/_internal/components/chip/SelectionChipGroup.d.ts +48 -0
- package/_internal/components/chip/SelectionChipGroup.js +91 -0
- package/_internal/components/chip/index.d.ts +3 -0
- package/_internal/components/combobox/ComboboxButton.d.ts +15 -0
- package/_internal/components/combobox/ComboboxButton.js +63 -0
- package/_internal/components/combobox/ComboboxInput.d.ts +20 -0
- package/_internal/components/combobox/ComboboxInput.js +97 -0
- package/_internal/components/combobox/ComboboxList.d.ts +7 -0
- package/_internal/components/combobox/ComboboxList.js +54 -0
- package/_internal/components/combobox/ComboboxOption.d.ts +11 -0
- package/_internal/components/combobox/ComboboxOption.js +79 -0
- package/_internal/components/combobox/ComboboxOptionAction.d.ts +9 -0
- package/_internal/components/combobox/ComboboxOptionAction.js +40 -0
- package/_internal/components/combobox/ComboboxOptionMoreInfo.d.ts +9 -0
- package/_internal/components/combobox/ComboboxOptionMoreInfo.js +78 -0
- package/_internal/components/combobox/ComboboxOptionSkeleton.d.ts +7 -0
- package/_internal/components/combobox/ComboboxOptionSkeleton.js +37 -0
- package/_internal/components/combobox/ComboboxPopover.d.ts +13 -0
- package/_internal/components/combobox/ComboboxPopover.js +46 -0
- package/_internal/components/combobox/ComboboxProvider.d.ts +7 -0
- package/_internal/components/combobox/ComboboxProvider.js +46 -0
- package/_internal/components/combobox/ComboboxSection.d.ts +7 -0
- package/_internal/components/combobox/ComboboxSection.js +51 -0
- package/_internal/components/combobox/ComboboxState.d.ts +7 -0
- package/_internal/components/combobox/ComboboxState.js +61 -0
- package/_internal/components/combobox/context/ComboboxContext.js +21 -0
- package/_internal/components/combobox/context/ComboboxListContext.js +19 -0
- package/_internal/components/combobox/context/ComboboxOptionContext.js +22 -0
- package/_internal/components/combobox/context/useComboboxEvent.js +20 -0
- package/_internal/components/combobox/context/useComboboxOpen.js +17 -0
- package/_internal/components/combobox/index.d.ts +115 -0
- package/_internal/components/combobox/index.js +44 -0
- package/_internal/components/combobox/useWrappedRenderOptionSlot.js +46 -0
- package/_internal/components/combobox/useWrappedRenderSectionTitleSlot.js +18 -0
- package/_internal/components/dialog/Dialog.d.ts +42 -0
- package/_internal/components/dialog/Dialog.js +109 -0
- package/_internal/components/dialog/index.d.ts +2 -0
- package/_internal/components/divider/Divider.d.ts +16 -0
- package/_internal/components/divider/Divider.js +29 -0
- package/_internal/components/divider/index.d.ts +1 -0
- package/_internal/components/drag-handle/DragHandle.d.ts +16 -0
- package/_internal/components/drag-handle/DragHandle.js +29 -0
- package/_internal/components/drag-handle/index.d.ts +1 -0
- package/_internal/components/expansion-panel/ExpansionPanel.d.ts +34 -0
- package/_internal/components/expansion-panel/ExpansionPanel.js +86 -0
- package/_internal/components/expansion-panel/index.d.ts +1 -0
- package/_internal/components/flag/Flag.d.ts +16 -0
- package/_internal/components/flag/Flag.js +30 -0
- package/_internal/components/flag/index.d.ts +2 -0
- package/_internal/components/flex-box/FlexBox.d.ts +24 -0
- package/_internal/components/flex-box/FlexBox.js +30 -0
- package/_internal/components/flex-box/index.d.ts +2 -0
- package/_internal/components/generic-block/GenericBlock.d.ts +59 -0
- package/_internal/components/generic-block/GenericBlock.js +55 -0
- package/_internal/components/generic-block/index.d.ts +2 -0
- package/_internal/components/grid-column/GridColumn.d.ts +9 -0
- package/_internal/components/grid-column/GridColumn.js +19 -0
- package/_internal/components/grid-column/index.d.ts +2 -0
- package/_internal/components/heading/Heading.d.ts +16 -0
- package/_internal/components/heading/Heading.js +36 -0
- package/_internal/components/heading/HeadingLevelProvider.d.ts +14 -0
- package/_internal/components/heading/HeadingLevelProvider.js +29 -0
- package/_internal/components/heading/context.js +4 -0
- package/_internal/components/heading/index.d.ts +4 -0
- package/_internal/components/heading/useHeadingLevel.d.ts +11 -0
- package/_internal/components/heading/useHeadingLevel.js +14 -0
- package/_internal/components/icon/Icon.d.ts +16 -0
- package/_internal/components/icon/Icon.js +27 -0
- package/_internal/components/icon/index.d.ts +2 -0
- package/_internal/components/image-block/ImageBlock.d.ts +19 -0
- package/_internal/components/image-block/ImageBlock.js +38 -0
- package/_internal/components/image-block/ImageCaption.js +30 -0
- package/_internal/components/image-block/index.d.ts +2 -0
- package/_internal/components/inline-list/InlineList.d.ts +16 -0
- package/_internal/components/inline-list/InlineList.js +25 -0
- package/_internal/components/inline-list/index.d.ts +1 -0
- package/_internal/components/input-helper/InputHelper.d.ts +16 -0
- package/_internal/components/input-helper/InputHelper.js +28 -0
- package/_internal/components/input-helper/index.d.ts +1 -0
- package/_internal/components/input-label/InputLabel.d.ts +16 -0
- package/_internal/components/input-label/InputLabel.js +28 -0
- package/_internal/components/input-label/index.d.ts +1 -0
- package/_internal/components/lightbox/Lightbox.d.ts +22 -0
- package/_internal/components/lightbox/Lightbox.js +63 -0
- package/_internal/components/lightbox/index.d.ts +1 -0
- package/_internal/components/link/Link.d.ts +20 -0
- package/_internal/components/link/Link.js +43 -0
- package/_internal/components/link/index.d.ts +1 -0
- package/_internal/components/link-preview/LinkPreview.d.ts +20 -0
- package/_internal/components/link-preview/LinkPreview.js +36 -0
- package/_internal/components/link-preview/index.d.ts +1 -0
- package/_internal/components/list/List.d.ts +16 -0
- package/_internal/components/list/List.js +25 -0
- package/_internal/components/list/ListDivider.d.ts +16 -0
- package/_internal/components/list/ListDivider.js +22 -0
- package/_internal/components/list/ListItem.d.ts +27 -0
- package/_internal/components/list/ListItem.js +47 -0
- package/_internal/components/list/ListItemAction.d.ts +27 -0
- package/_internal/components/list/ListItemAction.js +41 -0
- package/_internal/components/list/ListSection.d.ts +16 -0
- package/_internal/components/list/ListSection.js +30 -0
- package/_internal/components/list/index.d.ts +6 -0
- package/_internal/components/menu-button/MenuButton.d.ts +48 -0
- package/_internal/components/menu-button/MenuButton.js +59 -0
- package/_internal/components/menu-button/MenuItem.d.ts +40 -0
- package/_internal/components/menu-button/MenuItem.js +86 -0
- package/_internal/components/menu-button/MenuList.js +43 -0
- package/_internal/components/menu-button/MenuPopover.d.ts +8 -0
- package/_internal/components/menu-button/MenuPopover.js +36 -0
- package/_internal/components/menu-button/MenuProvider.js +49 -0
- package/_internal/components/menu-button/MenuTrigger.js +52 -0
- package/_internal/components/menu-button/context.js +15 -0
- package/_internal/components/menu-button/index.d.ts +3 -0
- package/_internal/components/menu-button/useMenuEvent.js +17 -0
- package/_internal/components/menu-button/useMenuOpen.js +11 -0
- package/_internal/components/message/Message.d.ts +22 -0
- package/_internal/components/message/Message.js +31 -0
- package/_internal/components/message/index.d.ts +1 -0
- package/_internal/components/mosaic/Mosaic.d.ts +28 -0
- package/_internal/components/mosaic/Mosaic.js +36 -0
- package/_internal/components/mosaic/index.d.ts +1 -0
- package/_internal/components/popover/Popover.d.ts +35 -0
- package/_internal/components/popover/Popover.js +76 -0
- package/_internal/components/popover/index.d.ts +3 -0
- package/_internal/components/popover/usePopoverStyle.js +55 -0
- package/_internal/components/popover-dialog/PopoverDialog.d.ts +28 -0
- package/_internal/components/popover-dialog/PopoverDialog.js +34 -0
- package/_internal/components/popover-dialog/index.d.ts +1 -0
- package/_internal/components/progress/ProgressCircular.d.ts +10 -0
- package/_internal/components/progress/ProgressCircular.js +28 -0
- package/_internal/components/progress/ProgressLinear.d.ts +10 -0
- package/_internal/components/progress/ProgressLinear.js +23 -0
- package/_internal/components/progress/index.d.ts +3 -0
- package/_internal/components/radio-button/RadioButton.d.ts +20 -0
- package/_internal/components/radio-button/RadioButton.js +50 -0
- package/_internal/components/radio-button/RadioGroup.d.ts +15 -0
- package/_internal/components/radio-button/RadioGroup.js +25 -0
- package/_internal/components/radio-button/index.d.ts +2 -0
- package/_internal/components/select-button/SelectButton.d.ts +172 -0
- package/_internal/components/select-button/SelectButton.js +164 -0
- package/_internal/components/select-button/index.d.ts +21 -0
- package/_internal/components/select-button/index.js +7 -0
- package/_internal/components/select-text-field/SelectTextField.d.ts +122 -0
- package/_internal/components/select-text-field/SelectTextField.js +195 -0
- package/_internal/components/select-text-field/index.d.ts +51 -0
- package/_internal/components/select-text-field/index.js +19 -0
- package/_internal/components/skeleton/SkeletonCircle.d.ts +15 -0
- package/_internal/components/skeleton/SkeletonCircle.js +29 -0
- package/_internal/components/skeleton/SkeletonRectangle.d.ts +15 -0
- package/_internal/components/skeleton/SkeletonRectangle.js +29 -0
- package/_internal/components/skeleton/SkeletonTypography.d.ts +15 -0
- package/_internal/components/skeleton/SkeletonTypography.js +29 -0
- package/_internal/components/skeleton/index.d.ts +4 -0
- package/_internal/components/switch/Switch.d.ts +20 -0
- package/_internal/components/switch/Switch.js +50 -0
- package/_internal/components/switch/index.d.ts +1 -0
- package/_internal/components/table/Table.d.ts +10 -0
- package/_internal/components/table/Table.js +24 -0
- package/_internal/components/table/TableBody.d.ts +10 -0
- package/_internal/components/table/TableBody.js +21 -0
- package/_internal/components/table/TableCell.d.ts +17 -0
- package/_internal/components/table/TableCell.js +28 -0
- package/_internal/components/table/TableHeader.d.ts +10 -0
- package/_internal/components/table/TableHeader.js +21 -0
- package/_internal/components/table/TableRow.d.ts +14 -0
- package/_internal/components/table/TableRow.js +28 -0
- package/_internal/components/table/index.d.ts +6 -0
- package/_internal/components/tabs/Tab.d.ts +16 -0
- package/_internal/components/tabs/Tab.js +52 -0
- package/_internal/components/tabs/TabList.d.ts +22 -0
- package/_internal/components/tabs/TabList.js +42 -0
- package/_internal/components/tabs/TabPanel.d.ts +18 -0
- package/_internal/components/tabs/TabPanel.js +36 -0
- package/_internal/components/tabs/TabProvider.d.ts +25 -0
- package/_internal/components/tabs/TabProvider.js +60 -0
- package/_internal/components/tabs/index.d.ts +5 -0
- package/_internal/components/tabs/state.js +53 -0
- package/_internal/components/text/Text.d.ts +16 -0
- package/_internal/components/text/Text.js +50 -0
- package/_internal/components/text/index.d.ts +1 -0
- package/_internal/components/text-field/RawInputText.d.ts +27 -0
- package/_internal/components/text-field/RawInputText.js +55 -0
- package/_internal/components/text-field/RawInputTextarea.d.ts +27 -0
- package/_internal/components/text-field/RawInputTextarea.js +59 -0
- package/_internal/components/text-field/TextField.d.ts +52 -0
- package/_internal/components/text-field/TextField.js +123 -0
- package/_internal/components/text-field/index.d.ts +3 -0
- package/_internal/components/text-field/useFitRowsToContent.js +25 -0
- package/_internal/components/thumbnail/Thumbnail.d.ts +29 -0
- package/_internal/components/thumbnail/Thumbnail.js +89 -0
- package/_internal/components/thumbnail/index.d.ts +2 -0
- package/_internal/components/thumbnail/useFocusPointStyle.js +50 -0
- package/_internal/components/thumbnail/useImageLoad.js +38 -0
- package/_internal/components/time-picker-field/TimePickerField.d.ts +37 -0
- package/_internal/components/time-picker-field/TimePickerField.js +104 -0
- package/_internal/components/time-picker-field/index.d.ts +2 -0
- package/_internal/components/toolbar/Toolbar.d.ts +10 -0
- package/_internal/components/toolbar/Toolbar.js +23 -0
- package/_internal/components/toolbar/index.d.ts +2 -0
- package/_internal/components/tooltip/Tooltip.d.ts +18 -0
- package/_internal/components/tooltip/Tooltip.js +77 -0
- package/_internal/components/tooltip/context.js +20 -0
- package/_internal/components/tooltip/index.d.ts +2 -0
- package/_internal/components/tooltip/useInjectTooltipRef.js +46 -0
- package/_internal/components/tooltip/useTooltipOpen.js +39 -0
- package/_internal/components/uploader/Uploader.d.ts +30 -0
- package/_internal/components/uploader/Uploader.js +77 -0
- package/_internal/components/uploader/index.d.ts +2 -0
- package/_internal/components/user-block/UserBlock.d.ts +31 -0
- package/_internal/components/user-block/UserBlock.js +120 -0
- package/_internal/components/user-block/index.d.ts +2 -0
- package/_internal/composables/useAttrFallback.js +39 -0
- package/_internal/composables/useCallbackOnEscape.js +42 -0
- package/_internal/composables/useClassName.js +21 -0
- package/_internal/composables/useDisableBodyScroll.js +17 -0
- package/_internal/composables/useDisableStateProps.js +36 -0
- package/_internal/composables/useDisabledState.js +8 -0
- package/_internal/composables/useFocus.js +23 -0
- package/_internal/composables/useFocusTrap.js +38 -0
- package/_internal/composables/useHasEventListener.js +13 -0
- package/_internal/composables/useId.js +14 -0
- package/_internal/composables/useOverflowTooltipLabel.js +28 -0
- package/_internal/composables/useRestoreFocusOnClose.js +37 -0
- package/_internal/composables/useRovingTabIndexContainer.js +26 -0
- package/_internal/composables/useSlot.js +15 -0
- package/_internal/composables/useTransitionVisibility.js +40 -0
- package/_internal/composables/useWatchDisposable.js +24 -0
- package/_internal/node_modules/@floating-ui/core/dist/floating-ui.core.js +536 -0
- package/_internal/node_modules/@floating-ui/dom/dist/floating-ui.dom.js +528 -0
- package/_internal/node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.js +144 -0
- package/_internal/node_modules/@floating-ui/utils/dist/floating-ui.utils.js +135 -0
- package/_internal/node_modules/@floating-ui/vue/dist/floating-ui.vue.js +145 -0
- package/_internal/node_modules/@vue/reactivity/dist/reactivity.d.ts +104 -0
- package/_internal/node_modules/@vue/runtime-core/dist/runtime-core.d.ts +1179 -0
- package/_internal/node_modules/@vue/runtime-dom/dist/runtime-dom.d.ts +90 -0
- package/_internal/node_modules/@vue/shared/dist/shared.d.ts +7 -0
- package/_internal/node_modules/@vueuse/core/dist/index.js +289 -0
- package/_internal/node_modules/@vueuse/shared/dist/index.js +49 -0
- package/_internal/node_modules/classnames/index.js +45 -0
- package/_internal/node_modules/lodash/_DataView.js +10 -0
- package/_internal/node_modules/lodash/_Hash.js +34 -0
- package/_internal/node_modules/lodash/_ListCache.js +34 -0
- package/_internal/node_modules/lodash/_Map.js +10 -0
- package/_internal/node_modules/lodash/_MapCache.js +34 -0
- package/_internal/node_modules/lodash/_Promise.js +10 -0
- package/_internal/node_modules/lodash/_Set.js +10 -0
- package/_internal/node_modules/lodash/_Symbol.js +9 -0
- package/_internal/node_modules/lodash/_WeakMap.js +10 -0
- package/_internal/node_modules/lodash/_apply.js +27 -0
- package/_internal/node_modules/lodash/_arrayMap.js +22 -0
- package/_internal/node_modules/lodash/_arrayPush.js +21 -0
- package/_internal/node_modules/lodash/_assignValue.js +27 -0
- package/_internal/node_modules/lodash/_assocIndexOf.js +23 -0
- package/_internal/node_modules/lodash/_baseAssignValue.js +28 -0
- package/_internal/node_modules/lodash/_baseFindIndex.js +24 -0
- package/_internal/node_modules/lodash/_baseFlatten.js +34 -0
- package/_internal/node_modules/lodash/_baseGet.js +25 -0
- package/_internal/node_modules/lodash/_baseGetTag.js +27 -0
- package/_internal/node_modules/lodash/_baseHasIn.js +19 -0
- package/_internal/node_modules/lodash/_baseIndexOf.js +24 -0
- package/_internal/node_modules/lodash/_baseIndexOfWith.js +23 -0
- package/_internal/node_modules/lodash/_baseIsArguments.js +23 -0
- package/_internal/node_modules/lodash/_baseIsNaN.js +18 -0
- package/_internal/node_modules/lodash/_baseIsNative.js +40 -0
- package/_internal/node_modules/lodash/_baseIsTypedArray.js +29 -0
- package/_internal/node_modules/lodash/_baseKeys.js +26 -0
- package/_internal/node_modules/lodash/_basePick.js +25 -0
- package/_internal/node_modules/lodash/_basePickBy.js +29 -0
- package/_internal/node_modules/lodash/_basePullAll.js +40 -0
- package/_internal/node_modules/lodash/_baseRest.js +23 -0
- package/_internal/node_modules/lodash/_baseSet.js +41 -0
- package/_internal/node_modules/lodash/_baseSetToString.js +19 -0
- package/_internal/node_modules/lodash/_baseSlice.js +28 -0
- package/_internal/node_modules/lodash/_baseToString.js +32 -0
- package/_internal/node_modules/lodash/_baseTrim.js +22 -0
- package/_internal/node_modules/lodash/_baseUnary.js +20 -0
- package/_internal/node_modules/lodash/_castPath.js +25 -0
- package/_internal/node_modules/lodash/_copyArray.js +22 -0
- package/_internal/node_modules/lodash/_coreJsData.js +9 -0
- package/_internal/node_modules/lodash/_defineProperty.js +16 -0
- package/_internal/node_modules/lodash/_flatRest.js +22 -0
- package/_internal/node_modules/lodash/_freeGlobal.js +8 -0
- package/_internal/node_modules/lodash/_getMapData.js +22 -0
- package/_internal/node_modules/lodash/_getNative.js +23 -0
- package/_internal/node_modules/lodash/_getRawTag.js +40 -0
- package/_internal/node_modules/lodash/_getTag.js +40 -0
- package/_internal/node_modules/lodash/_getValue.js +19 -0
- package/_internal/node_modules/lodash/_hasPath.js +36 -0
- package/_internal/node_modules/lodash/_hashClear.js +21 -0
- package/_internal/node_modules/lodash/_hashDelete.js +23 -0
- package/_internal/node_modules/lodash/_hashGet.js +31 -0
- package/_internal/node_modules/lodash/_hashHas.js +25 -0
- package/_internal/node_modules/lodash/_hashSet.js +28 -0
- package/_internal/node_modules/lodash/_isFlattenable.js +24 -0
- package/_internal/node_modules/lodash/_isIndex.js +25 -0
- package/_internal/node_modules/lodash/_isKey.js +27 -0
- package/_internal/node_modules/lodash/_isKeyable.js +19 -0
- package/_internal/node_modules/lodash/_isMasked.js +25 -0
- package/_internal/node_modules/lodash/_isPrototype.js +21 -0
- package/_internal/node_modules/lodash/_listCacheClear.js +19 -0
- package/_internal/node_modules/lodash/_listCacheDelete.js +29 -0
- package/_internal/node_modules/lodash/_listCacheGet.js +23 -0
- package/_internal/node_modules/lodash/_listCacheHas.js +22 -0
- package/_internal/node_modules/lodash/_listCacheSet.js +28 -0
- package/_internal/node_modules/lodash/_mapCacheClear.js +27 -0
- package/_internal/node_modules/lodash/_mapCacheDelete.js +24 -0
- package/_internal/node_modules/lodash/_mapCacheGet.js +22 -0
- package/_internal/node_modules/lodash/_mapCacheHas.js +22 -0
- package/_internal/node_modules/lodash/_mapCacheSet.js +26 -0
- package/_internal/node_modules/lodash/_memoizeCapped.js +28 -0
- package/_internal/node_modules/lodash/_nativeCreate.js +9 -0
- package/_internal/node_modules/lodash/_nativeKeys.js +9 -0
- package/_internal/node_modules/lodash/_nodeUtil.js +22 -0
- package/_internal/node_modules/lodash/_objectToString.js +24 -0
- package/_internal/node_modules/lodash/_overArg.js +21 -0
- package/_internal/node_modules/lodash/_overRest.js +32 -0
- package/_internal/node_modules/lodash/_root.js +12 -0
- package/_internal/node_modules/lodash/_setToString.js +11 -0
- package/_internal/node_modules/lodash/_shortOut.js +31 -0
- package/_internal/node_modules/lodash/_strictIndexOf.js +23 -0
- package/_internal/node_modules/lodash/_stringToPath.js +21 -0
- package/_internal/node_modules/lodash/_toKey.js +24 -0
- package/_internal/node_modules/lodash/_toSource.js +28 -0
- package/_internal/node_modules/lodash/_trimmedEndIndex.js +23 -0
- package/_internal/node_modules/lodash/castArray.js +48 -0
- package/_internal/node_modules/lodash/constant.js +32 -0
- package/_internal/node_modules/lodash/eq.js +43 -0
- package/_internal/node_modules/lodash/flatten.js +27 -0
- package/_internal/node_modules/lodash/hasIn.js +40 -0
- package/_internal/node_modules/lodash/identity.js +27 -0
- package/_internal/node_modules/lodash/isArguments.js +21 -0
- package/_internal/node_modules/lodash/isArray.js +8 -0
- package/_internal/node_modules/lodash/isArrayLike.js +39 -0
- package/_internal/node_modules/lodash/isBuffer.js +17 -0
- package/_internal/node_modules/lodash/isEmpty.js +63 -0
- package/_internal/node_modules/lodash/isFunction.js +35 -0
- package/_internal/node_modules/lodash/isInteger.js +39 -0
- package/_internal/node_modules/lodash/isLength.js +39 -0
- package/_internal/node_modules/lodash/isObject.js +37 -0
- package/_internal/node_modules/lodash/isObjectLike.js +35 -0
- package/_internal/node_modules/lodash/isSymbol.js +33 -0
- package/_internal/node_modules/lodash/isTypedArray.js +13 -0
- package/_internal/node_modules/lodash/last.js +26 -0
- package/_internal/node_modules/lodash/memoize.js +69 -0
- package/_internal/node_modules/lodash/pick.js +13 -0
- package/_internal/node_modules/lodash/pull.js +10 -0
- package/_internal/node_modules/lodash/pullAll.js +33 -0
- package/_internal/node_modules/lodash/set.js +41 -0
- package/_internal/node_modules/lodash/stubFalse.js +24 -0
- package/_internal/node_modules/lodash/take.js +41 -0
- package/_internal/node_modules/lodash/toFinite.js +41 -0
- package/_internal/node_modules/lodash/toInteger.js +40 -0
- package/_internal/node_modules/lodash/toNumber.js +57 -0
- package/_internal/node_modules/lodash/toString.js +34 -0
- package/_internal/node_modules/vue/jsx-runtime/index.d.ts +1 -0
- package/_internal/node_modules/vue-demi/lib/index.js +34 -0
- package/_internal/packages/lumx-core/src/js/components/AlertDialog/index.d.ts +15 -0
- package/_internal/packages/lumx-core/src/js/components/AlertDialog/index.js +107 -0
- package/_internal/packages/lumx-core/src/js/components/Avatar/index.d.ts +27 -0
- package/_internal/packages/lumx-core/src/js/components/Avatar/index.js +29 -0
- package/_internal/packages/lumx-core/src/js/components/Badge/BadgeWrapper.d.ts +14 -0
- package/_internal/packages/lumx-core/src/js/components/Badge/BadgeWrapper.js +12 -0
- package/_internal/packages/lumx-core/src/js/components/Badge/index.d.ts +18 -0
- package/_internal/packages/lumx-core/src/js/components/Badge/index.js +36 -0
- package/_internal/packages/lumx-core/src/js/components/Button/Button.d.ts +19 -0
- package/_internal/packages/lumx-core/src/js/components/Button/Button.js +49 -0
- package/_internal/packages/lumx-core/src/js/components/Button/ButtonGroup.d.ts +17 -0
- package/_internal/packages/lumx-core/src/js/components/Button/ButtonGroup.js +33 -0
- package/_internal/packages/lumx-core/src/js/components/Button/ButtonRoot.d.ts +46 -0
- package/_internal/packages/lumx-core/src/js/components/Button/ButtonRoot.js +77 -0
- package/_internal/packages/lumx-core/src/js/components/Button/IconButton.d.ts +24 -0
- package/_internal/packages/lumx-core/src/js/components/Button/IconButton.js +46 -0
- package/_internal/packages/lumx-core/src/js/components/Checkbox/index.d.ts +35 -0
- package/_internal/packages/lumx-core/src/js/components/Checkbox/index.js +60 -0
- package/_internal/packages/lumx-core/src/js/components/Chip/ChipGroup.d.ts +21 -0
- package/_internal/packages/lumx-core/src/js/components/Chip/ChipGroup.js +19 -0
- package/_internal/packages/lumx-core/src/js/components/Chip/SelectionChipGroup.d.ts +29 -0
- package/_internal/packages/lumx-core/src/js/components/Chip/SelectionChipGroup.js +66 -0
- package/_internal/packages/lumx-core/src/js/components/Chip/index.d.ts +63 -0
- package/_internal/packages/lumx-core/src/js/components/Chip/index.js +65 -0
- package/_internal/packages/lumx-core/src/js/components/Chip/setupSelectionChipGroupEvents.js +97 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxButton.d.ts +34 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxButton.js +58 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxInput.d.ts +34 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxInput.js +47 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxList.d.ts +36 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxList.js +30 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxOption.d.ts +53 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxOption.js +75 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxOptionAction.d.ts +20 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxOptionAction.js +29 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxOptionMoreInfo.d.ts +29 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxOptionMoreInfo.js +60 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxOptionSkeleton.d.ts +32 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxOptionSkeleton.js +40 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxPopover.d.ts +16 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxPopover.js +52 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxSection.d.ts +36 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxSection.js +43 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxState.d.ts +64 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxState.js +85 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/constants.js +4 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/setupCombobox.js +350 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/setupComboboxButton.js +84 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/setupComboboxInput.js +95 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/setupListbox.js +84 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/subscribeComboboxState.js +43 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/types.d.ts +142 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/utils.js +63 -0
- package/_internal/packages/lumx-core/src/js/components/Dialog/index.d.ts +20 -0
- package/_internal/packages/lumx-core/src/js/components/Dialog/index.js +59 -0
- package/_internal/packages/lumx-core/src/js/components/Divider/index.d.ts +13 -0
- package/_internal/packages/lumx-core/src/js/components/Divider/index.js +21 -0
- package/_internal/packages/lumx-core/src/js/components/DragHandle/index.d.ts +13 -0
- package/_internal/packages/lumx-core/src/js/components/DragHandle/index.js +28 -0
- package/_internal/packages/lumx-core/src/js/components/ExpansionPanel/index.d.ts +51 -0
- package/_internal/packages/lumx-core/src/js/components/ExpansionPanel/index.js +63 -0
- package/_internal/packages/lumx-core/src/js/components/Flag/index.d.ts +24 -0
- package/_internal/packages/lumx-core/src/js/components/Flag/index.js +36 -0
- package/_internal/packages/lumx-core/src/js/components/FlexBox/index.d.ts +34 -0
- package/_internal/packages/lumx-core/src/js/components/FlexBox/index.js +37 -0
- package/_internal/packages/lumx-core/src/js/components/FlexBox/types.d.ts +9 -0
- package/_internal/packages/lumx-core/src/js/components/GenericBlock/constants.d.ts +22 -0
- package/_internal/packages/lumx-core/src/js/components/GenericBlock/constants.js +15 -0
- package/_internal/packages/lumx-core/src/js/components/GenericBlock/index.d.ts +60 -0
- package/_internal/packages/lumx-core/src/js/components/GenericBlock/index.js +45 -0
- package/_internal/packages/lumx-core/src/js/components/GridColumn/GridColumn.d.ts +27 -0
- package/_internal/packages/lumx-core/src/js/components/GridColumn/GridColumn.js +50 -0
- package/_internal/packages/lumx-core/src/js/components/GridColumn/index.d.ts +1 -0
- package/_internal/packages/lumx-core/src/js/components/Heading/constants.d.ts +10 -0
- package/_internal/packages/lumx-core/src/js/components/Heading/constants.js +19 -0
- package/_internal/packages/lumx-core/src/js/components/Heading/index.d.ts +14 -0
- package/_internal/packages/lumx-core/src/js/components/Heading/index.js +26 -0
- package/_internal/packages/lumx-core/src/js/components/Heading/utils.js +14 -0
- package/_internal/packages/lumx-core/src/js/components/Icon/constants.d.ts +4 -0
- package/_internal/packages/lumx-core/src/js/components/Icon/index.d.ts +34 -0
- package/_internal/packages/lumx-core/src/js/components/Icon/index.js +63 -0
- package/_internal/packages/lumx-core/src/js/components/ImageBlock/ImageCaption.d.ts +19 -0
- package/_internal/packages/lumx-core/src/js/components/ImageBlock/ImageCaption.js +52 -0
- package/_internal/packages/lumx-core/src/js/components/ImageBlock/index.d.ts +52 -0
- package/_internal/packages/lumx-core/src/js/components/ImageBlock/index.js +67 -0
- package/_internal/packages/lumx-core/src/js/components/InlineList/index.d.ts +34 -0
- package/_internal/packages/lumx-core/src/js/components/InlineList/index.js +48 -0
- package/_internal/packages/lumx-core/src/js/components/InputHelper/constants.js +9 -0
- package/_internal/packages/lumx-core/src/js/components/InputHelper/index.d.ts +21 -0
- package/_internal/packages/lumx-core/src/js/components/InputHelper/index.js +32 -0
- package/_internal/packages/lumx-core/src/js/components/InputLabel/index.d.ts +24 -0
- package/_internal/packages/lumx-core/src/js/components/InputLabel/index.js +31 -0
- package/_internal/packages/lumx-core/src/js/components/Lightbox/index.d.ts +14 -0
- package/_internal/packages/lumx-core/src/js/components/Lightbox/index.js +46 -0
- package/_internal/packages/lumx-core/src/js/components/Link/index.d.ts +34 -0
- package/_internal/packages/lumx-core/src/js/components/Link/index.js +36 -0
- package/_internal/packages/lumx-core/src/js/components/LinkPreview/index.d.ts +35 -0
- package/_internal/packages/lumx-core/src/js/components/LinkPreview/index.js +64 -0
- package/_internal/packages/lumx-core/src/js/components/List/ListDivider.d.ts +12 -0
- package/_internal/packages/lumx-core/src/js/components/List/ListDivider.js +37 -0
- package/_internal/packages/lumx-core/src/js/components/List/ListItem.d.ts +40 -0
- package/_internal/packages/lumx-core/src/js/components/List/ListItem.js +56 -0
- package/_internal/packages/lumx-core/src/js/components/List/ListItemAction.js +27 -0
- package/_internal/packages/lumx-core/src/js/components/List/ListSection.d.ts +27 -0
- package/_internal/packages/lumx-core/src/js/components/List/ListSection.js +46 -0
- package/_internal/packages/lumx-core/src/js/components/List/index.d.ts +20 -0
- package/_internal/packages/lumx-core/src/js/components/List/index.js +39 -0
- package/_internal/packages/lumx-core/src/js/components/Menu/MenuButton.d.ts +28 -0
- package/_internal/packages/lumx-core/src/js/components/Menu/MenuButton.js +21 -0
- package/_internal/packages/lumx-core/src/js/components/Menu/MenuItem.d.ts +27 -0
- package/_internal/packages/lumx-core/src/js/components/Menu/MenuItem.js +33 -0
- package/_internal/packages/lumx-core/src/js/components/Menu/MenuList.js +19 -0
- package/_internal/packages/lumx-core/src/js/components/Menu/MenuPopover.d.ts +12 -0
- package/_internal/packages/lumx-core/src/js/components/Menu/MenuPopover.js +33 -0
- package/_internal/packages/lumx-core/src/js/components/Menu/MenuTrigger.js +21 -0
- package/_internal/packages/lumx-core/src/js/components/Menu/setupMenu.js +256 -0
- package/_internal/packages/lumx-core/src/js/components/Menu/utils.js +16 -0
- package/_internal/packages/lumx-core/src/js/components/Message/index.d.ts +31 -0
- package/_internal/packages/lumx-core/src/js/components/Message/index.js +83 -0
- package/_internal/packages/lumx-core/src/js/components/Mosaic/index.d.ts +18 -0
- package/_internal/packages/lumx-core/src/js/components/Mosaic/index.js +48 -0
- package/_internal/packages/lumx-core/src/js/components/Popover/constants.d.ts +39 -0
- package/_internal/packages/lumx-core/src/js/components/Popover/constants.js +37 -0
- package/_internal/packages/lumx-core/src/js/components/Popover/index.d.ts +65 -0
- package/_internal/packages/lumx-core/src/js/components/Popover/index.js +71 -0
- package/_internal/packages/lumx-core/src/js/components/Popover/types.d.ts +39 -0
- package/_internal/packages/lumx-core/src/js/components/Popover/utils/buildPopoverMiddleware.js +53 -0
- package/_internal/packages/lumx-core/src/js/components/Popover/utils/computeArrowStyles.js +13 -0
- package/_internal/packages/lumx-core/src/js/components/Popover/utils/getFloatingPlacement.js +10 -0
- package/_internal/packages/lumx-core/src/js/components/Popover/utils/parseAutoPlacement.js +21 -0
- package/_internal/packages/lumx-core/src/js/components/Popover/utils/parseFitWidth.js +12 -0
- package/_internal/packages/lumx-core/src/js/components/PopoverDialog/index.d.ts +13 -0
- package/_internal/packages/lumx-core/src/js/components/PopoverDialog/index.js +15 -0
- package/_internal/packages/lumx-core/src/js/components/ProgressCircular/index.d.ts +32 -0
- package/_internal/packages/lumx-core/src/js/components/ProgressCircular/index.js +43 -0
- package/_internal/packages/lumx-core/src/js/components/ProgressLinear/index.d.ts +13 -0
- package/_internal/packages/lumx-core/src/js/components/ProgressLinear/index.js +21 -0
- package/_internal/packages/lumx-core/src/js/components/RadioButton/index.d.ts +35 -0
- package/_internal/packages/lumx-core/src/js/components/RadioButton/index.js +51 -0
- package/_internal/packages/lumx-core/src/js/components/RadioGroup/index.d.ts +1 -0
- package/_internal/packages/lumx-core/src/js/components/RadioGroup/index.js +33 -0
- package/_internal/packages/lumx-core/src/js/components/RawClickable/index.d.ts +14 -0
- package/_internal/packages/lumx-core/src/js/components/RawClickable/index.js +33 -0
- package/_internal/packages/lumx-core/src/js/components/SelectButton/index.d.ts +58 -0
- package/_internal/packages/lumx-core/src/js/components/SelectButton/index.js +85 -0
- package/_internal/packages/lumx-core/src/js/components/SelectTextField/index.js +70 -0
- package/_internal/packages/lumx-core/src/js/components/Skeleton/SkeletonCircle.d.ts +18 -0
- package/_internal/packages/lumx-core/src/js/components/Skeleton/SkeletonCircle.js +25 -0
- package/_internal/packages/lumx-core/src/js/components/Skeleton/SkeletonRectangle.d.ts +34 -0
- package/_internal/packages/lumx-core/src/js/components/Skeleton/SkeletonRectangle.js +40 -0
- package/_internal/packages/lumx-core/src/js/components/Skeleton/SkeletonTypography.d.ts +24 -0
- package/_internal/packages/lumx-core/src/js/components/Skeleton/SkeletonTypography.js +31 -0
- package/_internal/packages/lumx-core/src/js/components/Skeleton/index.d.ts +3 -0
- package/_internal/packages/lumx-core/src/js/components/Switch/index.d.ts +37 -0
- package/_internal/packages/lumx-core/src/js/components/Switch/index.js +58 -0
- package/_internal/packages/lumx-core/src/js/components/Table/TableBody.d.ts +15 -0
- package/_internal/packages/lumx-core/src/js/components/Table/TableBody.js +20 -0
- package/_internal/packages/lumx-core/src/js/components/Table/TableCell.d.ts +42 -0
- package/_internal/packages/lumx-core/src/js/components/Table/TableCell.js +79 -0
- package/_internal/packages/lumx-core/src/js/components/Table/TableHeader.d.ts +15 -0
- package/_internal/packages/lumx-core/src/js/components/Table/TableHeader.js +20 -0
- package/_internal/packages/lumx-core/src/js/components/Table/TableRow.d.ts +22 -0
- package/_internal/packages/lumx-core/src/js/components/Table/TableRow.js +25 -0
- package/_internal/packages/lumx-core/src/js/components/Table/constants.d.ts +1 -0
- package/_internal/packages/lumx-core/src/js/components/Table/constants.js +7 -0
- package/_internal/packages/lumx-core/src/js/components/Table/index.d.ts +20 -0
- package/_internal/packages/lumx-core/src/js/components/Table/index.js +22 -0
- package/_internal/packages/lumx-core/src/js/components/Tabs/Tab.d.ts +54 -0
- package/_internal/packages/lumx-core/src/js/components/Tabs/Tab.js +66 -0
- package/_internal/packages/lumx-core/src/js/components/Tabs/TabList.d.ts +27 -0
- package/_internal/packages/lumx-core/src/js/components/Tabs/TabList.js +42 -0
- package/_internal/packages/lumx-core/src/js/components/Tabs/TabPanel.d.ts +26 -0
- package/_internal/packages/lumx-core/src/js/components/Tabs/TabPanel.js +28 -0
- package/_internal/packages/lumx-core/src/js/components/Tabs/constants.js +7 -0
- package/_internal/packages/lumx-core/src/js/components/Tabs/state.js +53 -0
- package/_internal/packages/lumx-core/src/js/components/Text/index.d.ts +55 -0
- package/_internal/packages/lumx-core/src/js/components/Text/index.js +37 -0
- package/_internal/packages/lumx-core/src/js/components/TextField/RawInputText.d.ts +21 -0
- package/_internal/packages/lumx-core/src/js/components/TextField/RawInputText.js +42 -0
- package/_internal/packages/lumx-core/src/js/components/TextField/RawInputTextarea.d.ts +19 -0
- package/_internal/packages/lumx-core/src/js/components/TextField/RawInputTextarea.js +42 -0
- package/_internal/packages/lumx-core/src/js/components/TextField/TextField.d.ts +70 -0
- package/_internal/packages/lumx-core/src/js/components/TextField/TextField.js +127 -0
- package/_internal/packages/lumx-core/src/js/components/TextField/constants.d.ts +1 -0
- package/_internal/packages/lumx-core/src/js/components/TextField/constants.js +11 -0
- package/_internal/packages/lumx-core/src/js/components/Thumbnail/index.d.ts +60 -0
- package/_internal/packages/lumx-core/src/js/components/Thumbnail/index.js +99 -0
- package/_internal/packages/lumx-core/src/js/components/Thumbnail/types.d.ts +47 -0
- package/_internal/packages/lumx-core/src/js/components/Thumbnail/types.js +18 -0
- package/_internal/packages/lumx-core/src/js/components/Thumbnail/utils.d.ts +1 -0
- package/_internal/packages/lumx-core/src/js/components/Thumbnail/utils.js +76 -0
- package/_internal/packages/lumx-core/src/js/components/TimePickerField/index.d.ts +61 -0
- package/_internal/packages/lumx-core/src/js/components/TimePickerField/index.js +72 -0
- package/_internal/packages/lumx-core/src/js/components/Toolbar/index.d.ts +23 -0
- package/_internal/packages/lumx-core/src/js/components/Toolbar/index.js +36 -0
- package/_internal/packages/lumx-core/src/js/components/Tooltip/constants.d.ts +4 -0
- package/_internal/packages/lumx-core/src/js/components/Tooltip/constants.js +8 -0
- package/_internal/packages/lumx-core/src/js/components/Tooltip/index.d.ts +25 -0
- package/_internal/packages/lumx-core/src/js/components/Tooltip/index.js +56 -0
- package/_internal/packages/lumx-core/src/js/components/Tooltip/tooltipOpenManager.js +93 -0
- package/_internal/packages/lumx-core/src/js/components/Uploader/index.d.ts +59 -0
- package/_internal/packages/lumx-core/src/js/components/Uploader/index.js +64 -0
- package/_internal/packages/lumx-core/src/js/components/UserBlock/index.d.ts +124 -0
- package/_internal/packages/lumx-core/src/js/components/UserBlock/index.js +88 -0
- package/_internal/packages/lumx-core/src/js/constants/browser/index.js +7 -0
- package/_internal/packages/lumx-core/src/js/constants/components/index.js +19 -0
- package/_internal/packages/lumx-core/src/js/constants/enums/index.d.ts +184 -0
- package/_internal/packages/lumx-core/src/js/constants/enums/index.js +140 -0
- package/_internal/packages/lumx-core/src/js/constants/index.d.ts +1 -0
- package/_internal/packages/lumx-core/src/js/types/AriaAttributes.d.ts +32 -0
- package/_internal/packages/lumx-core/src/js/types/Booleanish.d.ts +4 -0
- package/_internal/packages/lumx-core/src/js/types/CommonRef.d.ts +4 -0
- package/_internal/packages/lumx-core/src/js/types/GenericProps.d.ts +14 -0
- package/_internal/packages/lumx-core/src/js/types/HasAriaDisabled.d.ts +9 -0
- package/_internal/packages/lumx-core/src/js/types/HasAriaLabelOrLabelledBy.d.ts +19 -0
- package/_internal/packages/lumx-core/src/js/types/HasChecked.d.ts +9 -0
- package/_internal/packages/lumx-core/src/js/types/HasClassName.d.ts +9 -0
- package/_internal/packages/lumx-core/src/js/types/HasCloseMode.d.ts +10 -0
- package/_internal/packages/lumx-core/src/js/types/HasDisabled.d.ts +9 -0
- package/_internal/packages/lumx-core/src/js/types/HasPolymorphicAs.d.ts +12 -0
- package/_internal/packages/lumx-core/src/js/types/HasRequiredLinkHref.d.ts +6 -0
- package/_internal/packages/lumx-core/src/js/types/HasTheme.d.ts +10 -0
- package/_internal/packages/lumx-core/src/js/types/HeadingElement.d.ts +5 -0
- package/_internal/packages/lumx-core/src/js/types/JSXElement.d.ts +13 -0
- package/_internal/packages/lumx-core/src/js/types/Selector.d.ts +11 -0
- package/_internal/packages/lumx-core/src/js/types/TextElement.d.ts +7 -0
- package/_internal/packages/lumx-core/src/js/types/ValueOf.d.ts +5 -0
- package/_internal/packages/lumx-core/src/js/types/index.d.ts +17 -0
- package/_internal/packages/lumx-core/src/js/utils/ClickAway/index.d.ts +7 -0
- package/_internal/packages/lumx-core/src/js/utils/ClickAway/index.js +37 -0
- package/_internal/packages/lumx-core/src/js/utils/InfiniteScroll/index.d.ts +9 -0
- package/_internal/packages/lumx-core/src/js/utils/InfiniteScroll/index.js +21 -0
- package/_internal/packages/lumx-core/src/js/utils/InfiniteScroll/setupInfiniteScrollObserver.js +18 -0
- package/_internal/packages/lumx-core/src/js/utils/Portal/index.d.ts +28 -0
- package/_internal/packages/lumx-core/src/js/utils/_internal/color/resolveColorWithVariants.js +9 -0
- package/_internal/packages/lumx-core/src/js/utils/browser/createSelectorTreeWalker.js +20 -0
- package/_internal/packages/lumx-core/src/js/utils/browser/css/combineSize.js +14 -0
- package/_internal/packages/lumx-core/src/js/utils/browser/css/resolveCssSize.js +8 -0
- package/_internal/packages/lumx-core/src/js/utils/browser/css/types.d.ts +7 -0
- package/_internal/packages/lumx-core/src/js/utils/browser/isFocusVisible.js +11 -0
- package/_internal/packages/lumx-core/src/js/utils/browser/isHoverNotSupported.js +5 -0
- package/_internal/packages/lumx-core/src/js/utils/browser/isPrintableKey.js +12 -0
- package/_internal/packages/lumx-core/src/js/utils/browser/lastDescendant.js +9 -0
- package/_internal/packages/lumx-core/src/js/utils/browser/querySelectorInclusive.js +18 -0
- package/_internal/packages/lumx-core/src/js/utils/browser/trackContainerFocus.js +28 -0
- package/_internal/packages/lumx-core/src/js/utils/classNames/action-area/index.js +22 -0
- package/_internal/packages/lumx-core/src/js/utils/classNames/bem/block.js +18 -0
- package/_internal/packages/lumx-core/src/js/utils/classNames/bem/element.js +7 -0
- package/_internal/packages/lumx-core/src/js/utils/classNames/bem/index.js +22 -0
- package/_internal/packages/lumx-core/src/js/utils/classNames/bem/modifier.js +19 -0
- package/_internal/packages/lumx-core/src/js/utils/classNames/color/index.js +38 -0
- package/_internal/packages/lumx-core/src/js/utils/classNames/index.js +12 -0
- package/_internal/packages/lumx-core/src/js/utils/classNames/spacing/index.js +31 -0
- package/_internal/packages/lumx-core/src/js/utils/classNames/typography/index.js +10 -0
- package/_internal/packages/lumx-core/src/js/utils/classNames/visually-hidden/index.js +9 -0
- package/_internal/packages/lumx-core/src/js/utils/disabledState/index.js +13 -0
- package/_internal/packages/lumx-core/src/js/utils/events/keyboard.js +27 -0
- package/_internal/packages/lumx-core/src/js/utils/focus/constants.js +13 -0
- package/_internal/packages/lumx-core/src/js/utils/focus/getFirstAndLastFocusable.js +20 -0
- package/_internal/packages/lumx-core/src/js/utils/focus/getFocusableElements.js +8 -0
- package/_internal/packages/lumx-core/src/js/utils/focus/setupFocusTrap.js +83 -0
- package/_internal/packages/lumx-core/src/js/utils/focusNavigation/createActiveItemState.js +38 -0
- package/_internal/packages/lumx-core/src/js/utils/focusNavigation/createGridFocusNavigation.js +182 -0
- package/_internal/packages/lumx-core/src/js/utils/focusNavigation/createListFocusNavigation.js +151 -0
- package/_internal/packages/lumx-core/src/js/utils/focusNavigation/createPendingNavigation.js +23 -0
- package/_internal/packages/lumx-core/src/js/utils/focusNavigation/setupRovingTabIndex.js +167 -0
- package/_internal/packages/lumx-core/src/js/utils/focusNavigation/types.d.ts +40 -0
- package/_internal/packages/lumx-core/src/js/utils/function/listenerTower.js +28 -0
- package/_internal/packages/lumx-core/src/js/utils/iterable/first.js +8 -0
- package/_internal/packages/lumx-core/src/js/utils/locale/getCurrentLocale.js +10 -0
- package/_internal/packages/lumx-core/src/js/utils/select/findOptionById.js +19 -0
- package/_internal/packages/lumx-core/src/js/utils/select/getOptionDisplayName.js +19 -0
- package/_internal/packages/lumx-core/src/js/utils/select/renderSelectOptions.js +55 -0
- package/_internal/packages/lumx-core/src/js/utils/select/toggleSelection.js +39 -0
- package/_internal/packages/lumx-core/src/js/utils/select/types.d.ts +224 -0
- package/_internal/packages/lumx-core/src/js/utils/selectors/getWithSelector.js +9 -0
- package/_internal/packages/lumx-core/src/js/utils/selectors/groupBySelector.js +21 -0
- package/_internal/packages/lumx-core/src/js/utils/time/buildTimeList.js +36 -0
- package/_internal/packages/lumx-core/src/js/utils/time/formatTime.js +14 -0
- package/_internal/packages/lumx-core/src/js/utils/time/getDateAtTime.js +12 -0
- package/_internal/packages/lumx-core/src/js/utils/time/isDateOnTime.js +10 -0
- package/_internal/packages/lumx-core/src/js/utils/time/parseTimeInput.js +46 -0
- package/_internal/packages/lumx-core/src/js/utils/time/snapTimeToBounds.js +21 -0
- package/_internal/packages/lumx-core/src/js/utils/time/timeOfDayMinutes.js +9 -0
- package/_internal/packages/lumx-core/src/js/utils/typeahead/index.js +77 -0
- package/_internal/utils/ClickAway/ClickAwayProvider.d.ts +19 -0
- package/_internal/utils/ClickAway/ClickAwayProvider.js +58 -0
- package/_internal/utils/ClickAway/index.d.ts +2 -0
- package/_internal/utils/ClickAway/useClickAway.d.ts +25 -0
- package/_internal/utils/ClickAway/useClickAway.js +25 -0
- package/_internal/utils/InfiniteScroll/InfiniteScroll.d.ts +9 -0
- package/_internal/utils/InfiniteScroll/InfiniteScroll.js +23 -0
- package/_internal/utils/InfiniteScroll/index.d.ts +2 -0
- package/_internal/utils/Portal/Portal.d.ts +10 -0
- package/_internal/utils/Portal/Portal.js +37 -0
- package/_internal/utils/Portal/PortalProvider.d.ts +8 -0
- package/_internal/utils/Portal/PortalProvider.js +19 -0
- package/_internal/utils/Portal/index.d.ts +3 -0
- package/_internal/utils/VueToJSX.d.ts +38 -0
- package/_internal/utils/VueToJSX.js +11 -0
- package/_internal/utils/isComponentType.js +9 -0
- package/_internal/utils/theme/ResetTheme.js +11 -0
- package/_internal/utils/theme/ThemeProvider.d.ts +14 -0
- package/_internal/utils/theme/ThemeProvider.js +18 -0
- package/_internal/utils/theme/index.d.ts +2 -0
- package/_internal/utils/theme/useTheme.d.ts +14 -0
- package/_internal/utils/theme/useTheme.js +14 -0
- package/_internal/utils/wrapChildrenIconWithSpaces.js +37 -0
- package/index.d.ts +114 -48
- package/index.js +83 -11709
- package/package.json +6 -9
- package/utils/index.d.ts +10 -7
- package/utils/index.js +8 -24
- package/_internal/CHaqSUjw.js +0 -159
- package/_internal/CHaqSUjw.js.map +0 -1
- package/components/alert-dialog/AlertDialog.d.ts +0 -45
- package/components/alert-dialog/AlertDialog.stories.d.ts +0 -104
- package/components/alert-dialog/index.d.ts +0 -1
- package/components/avatar/Avatar.d.ts +0 -42
- package/components/avatar/Avatar.stories.d.ts +0 -146
- package/components/avatar/index.d.ts +0 -1
- package/components/badge/Badge.d.ts +0 -13
- package/components/badge/Badge.stories.d.ts +0 -34
- package/components/badge/BadgeWrapper.d.ts +0 -8
- package/components/badge/BadgeWrapper.stories.d.ts +0 -18
- package/components/badge/index.d.ts +0 -4
- package/components/button/Button.d.ts +0 -19
- package/components/button/ButtonGroup.d.ts +0 -13
- package/components/button/IconButton.d.ts +0 -35
- package/components/button/index.d.ts +0 -6
- package/components/checkbox/Checkbox.d.ts +0 -21
- package/components/checkbox/index.d.ts +0 -3
- package/components/chip/Chip.d.ts +0 -30
- package/components/chip/Chip.stories.d.ts +0 -121
- package/components/chip/ChipGroup.d.ts +0 -7
- package/components/chip/ChipGroup.stories.d.ts +0 -12
- package/components/chip/SelectionChipGroup.d.ts +0 -51
- package/components/chip/SelectionChipGroup.stories.d.ts +0 -66
- package/components/chip/Stories/CustomRender.vue.d.ts +0 -2
- package/components/chip/Stories/InTextField.vue.d.ts +0 -2
- package/components/chip/index.d.ts +0 -3
- package/components/combobox/Combobox.stories.d.ts +0 -153
- package/components/combobox/Combobox.test.stories.d.ts +0 -165
- package/components/combobox/ComboboxButton.d.ts +0 -48
- package/components/combobox/ComboboxInput.d.ts +0 -41
- package/components/combobox/ComboboxList.d.ts +0 -15
- package/components/combobox/ComboboxOption.d.ts +0 -32
- package/components/combobox/ComboboxOption.test.d.ts +0 -1
- package/components/combobox/ComboboxOptionAction.d.ts +0 -20
- package/components/combobox/ComboboxOptionMoreInfo.d.ts +0 -29
- package/components/combobox/ComboboxOptionSkeleton.d.ts +0 -14
- package/components/combobox/ComboboxPopover.d.ts +0 -20
- package/components/combobox/ComboboxProvider.d.ts +0 -20
- package/components/combobox/ComboboxSection.d.ts +0 -14
- package/components/combobox/ComboboxState.d.ts +0 -14
- package/components/combobox/context/ComboboxContext.d.ts +0 -23
- package/components/combobox/context/ComboboxListContext.d.ts +0 -14
- package/components/combobox/context/ComboboxOptionContext.d.ts +0 -16
- package/components/combobox/context/useComboboxEvent.d.ts +0 -7
- package/components/combobox/context/useComboboxOpen.d.ts +0 -7
- package/components/combobox/index.d.ts +0 -112
- package/components/combobox/useWrappedRenderOptionSlot.d.ts +0 -11
- package/components/combobox/useWrappedRenderSectionTitleSlot.d.ts +0 -10
- package/components/dialog/Dialog.d.ts +0 -67
- package/components/dialog/Dialog.stories.d.ts +0 -106
- package/components/dialog/index.d.ts +0 -2
- package/components/divider/Divider.d.ts +0 -14
- package/components/divider/index.d.ts +0 -2
- package/components/drag-handle/DragHandle.d.ts +0 -14
- package/components/drag-handle/index.d.ts +0 -2
- package/components/expansion-panel/ExpansionPanel.d.ts +0 -39
- package/components/expansion-panel/ExpansionPanel.stories.d.ts +0 -54
- package/components/expansion-panel/index.d.ts +0 -1
- package/components/flag/Flag.d.ts +0 -13
- package/components/flag/Flag.stories.d.ts +0 -108
- package/components/flag/index.d.ts +0 -4
- package/components/flex-box/FlexBox.d.ts +0 -28
- package/components/flex-box/index.d.ts +0 -4
- package/components/generic-block/GenericBlock.d.ts +0 -62
- package/components/generic-block/GenericBlock.stories.d.ts +0 -65
- package/components/generic-block/index.d.ts +0 -4
- package/components/grid-column/GridColumn.d.ts +0 -9
- package/components/grid-column/GridColumn.stories.d.ts +0 -42
- package/components/grid-column/index.d.ts +0 -2
- package/components/heading/Heading.d.ts +0 -13
- package/components/heading/HeadingLevelProvider.d.ts +0 -12
- package/components/heading/context.d.ts +0 -3
- package/components/heading/index.d.ts +0 -6
- package/components/heading/useHeadingLevel.d.ts +0 -7
- package/components/icon/Icon.d.ts +0 -13
- package/components/icon/index.d.ts +0 -4
- package/components/image-block/ImageBlock.d.ts +0 -19
- package/components/image-block/ImageBlock.stories.d.ts +0 -178
- package/components/image-block/ImageCaption.d.ts +0 -19
- package/components/image-block/index.d.ts +0 -1
- package/components/inline-list/InlineList.d.ts +0 -13
- package/components/inline-list/InlineList.stories.d.ts +0 -53
- package/components/inline-list/index.d.ts +0 -3
- package/components/input-helper/InputHelper.d.ts +0 -13
- package/components/input-helper/index.d.ts +0 -3
- package/components/input-label/InputLabel.d.ts +0 -13
- package/components/input-label/index.d.ts +0 -3
- package/components/lightbox/Lightbox.d.ts +0 -28
- package/components/lightbox/Lightbox.stories.d.ts +0 -27
- package/components/lightbox/index.d.ts +0 -1
- package/components/link/Link.d.ts +0 -20
- package/components/link/Link.stories.d.ts +0 -268
- package/components/link/index.d.ts +0 -3
- package/components/link-preview/LinkPreview.d.ts +0 -20
- package/components/link-preview/LinkPreview.stories.d.ts +0 -55
- package/components/link-preview/index.d.ts +0 -3
- package/components/list/List.d.ts +0 -13
- package/components/list/List.stories.d.ts +0 -24
- package/components/list/ListDivider.d.ts +0 -13
- package/components/list/ListDivider.stories.d.ts +0 -7
- package/components/list/ListItem.d.ts +0 -26
- package/components/list/ListItem.stories.d.ts +0 -80
- package/components/list/ListItemAction.d.ts +0 -31
- package/components/list/ListSection.d.ts +0 -13
- package/components/list/ListSection.stories.d.ts +0 -112
- package/components/list/index.d.ts +0 -5
- package/components/menu-button/MenuButton.d.ts +0 -52
- package/components/menu-button/MenuButton.stories.d.ts +0 -46
- package/components/menu-button/MenuButton.test.d.ts +0 -1
- package/components/menu-button/MenuButton.test.stories.d.ts +0 -26
- package/components/menu-button/MenuItem.d.ts +0 -44
- package/components/menu-button/MenuItem.test.d.ts +0 -1
- package/components/menu-button/MenuList.d.ts +0 -15
- package/components/menu-button/MenuPopover.d.ts +0 -15
- package/components/menu-button/MenuProvider.d.ts +0 -15
- package/components/menu-button/MenuTrigger.d.ts +0 -15
- package/components/menu-button/Stories/WithLinkItems.vue.d.ts +0 -8
- package/components/menu-button/context.d.ts +0 -13
- package/components/menu-button/index.d.ts +0 -3
- package/components/menu-button/useMenuEvent.d.ts +0 -3
- package/components/menu-button/useMenuOpen.d.ts +0 -2
- package/components/message/Message.d.ts +0 -25
- package/components/message/index.d.ts +0 -3
- package/components/mosaic/Mosaic.d.ts +0 -30
- package/components/mosaic/Mosaic.stories.d.ts +0 -93
- package/components/mosaic/index.d.ts +0 -1
- package/components/popover/Popover.d.ts +0 -47
- package/components/popover/Popover.stories.d.ts +0 -138
- package/components/popover/Popover.test.stories.d.ts +0 -26
- package/components/popover/index.d.ts +0 -3
- package/components/popover/usePopoverStyle.d.ts +0 -31
- package/components/popover-dialog/PopoverDialog.d.ts +0 -27
- package/components/popover-dialog/PopoverDialog.stories.d.ts +0 -32
- package/components/popover-dialog/PopoverDialog.test.stories.d.ts +0 -99
- package/components/popover-dialog/index.d.ts +0 -1
- package/components/progress/ProgressCircular.d.ts +0 -9
- package/components/progress/ProgressCircular.stories.d.ts +0 -22
- package/components/progress/ProgressLinear.d.ts +0 -8
- package/components/progress/index.d.ts +0 -4
- package/components/radio-button/RadioButton.d.ts +0 -21
- package/components/radio-button/RadioGroup.d.ts +0 -15
- package/components/radio-button/index.d.ts +0 -4
- package/components/select-button/SelectButton.d.ts +0 -176
- package/components/select-button/SelectButton.stories.d.ts +0 -126
- package/components/select-button/SelectButton.test.d.ts +0 -1
- package/components/select-button/SelectButton.test.stories.d.ts +0 -41
- package/components/select-button/Stories/CustomRender.vue.d.ts +0 -2
- package/components/select-button/Stories/WithInfiniteScroll.vue.d.ts +0 -2
- package/components/select-button/index.d.ts +0 -13
- package/components/select-text-field/SelectTextField.d.ts +0 -133
- package/components/select-text-field/SelectTextField.stories.d.ts +0 -203
- package/components/select-text-field/SelectTextField.test.d.ts +0 -1
- package/components/select-text-field/SelectTextField.test.stories.d.ts +0 -37
- package/components/select-text-field/Stories/CustomRender.vue.d.ts +0 -2
- package/components/select-text-field/Stories/MultipleWithSearch.vue.d.ts +0 -2
- package/components/select-text-field/Stories/WithCreatableOptions.vue.d.ts +0 -2
- package/components/select-text-field/Stories/WithInfiniteScroll.vue.d.ts +0 -2
- package/components/select-text-field/Stories/WithSearch.vue.d.ts +0 -2
- package/components/select-text-field/index.d.ts +0 -36
- package/components/skeleton/SkeletonCircle.d.ts +0 -14
- package/components/skeleton/SkeletonRectangle.d.ts +0 -14
- package/components/skeleton/SkeletonTypography.d.ts +0 -14
- package/components/skeleton/index.d.ts +0 -10
- package/components/switch/Switch.d.ts +0 -21
- package/components/switch/index.d.ts +0 -2
- package/components/table/Table.d.ts +0 -7
- package/components/table/TableBody.d.ts +0 -7
- package/components/table/TableCell.d.ts +0 -16
- package/components/table/TableHeader.d.ts +0 -7
- package/components/table/TableRow.d.ts +0 -13
- package/components/table/index.d.ts +0 -10
- package/components/tabs/Tab.d.ts +0 -26
- package/components/tabs/TabList.d.ts +0 -21
- package/components/tabs/TabPanel.d.ts +0 -16
- package/components/tabs/TabProvider.d.ts +0 -26
- package/components/tabs/TabProvider.stories.d.ts +0 -53
- package/components/tabs/TabProvider.test.d.ts +0 -1
- package/components/tabs/index.d.ts +0 -4
- package/components/tabs/state.d.ts +0 -19
- package/components/text/Text.d.ts +0 -13
- package/components/text/index.d.ts +0 -3
- package/components/text-field/RawInputText.d.ts +0 -30
- package/components/text-field/RawInputText.stories.d.ts +0 -13
- package/components/text-field/RawInputTextarea.d.ts +0 -30
- package/components/text-field/RawInputTextarea.stories.d.ts +0 -18
- package/components/text-field/Stories/WithChips.vue.d.ts +0 -2
- package/components/text-field/TextField.d.ts +0 -75
- package/components/text-field/TextField.stories.d.ts +0 -101
- package/components/text-field/index.d.ts +0 -3
- package/components/text-field/useFitRowsToContent.d.ts +0 -5
- package/components/thumbnail/Stories/ThumbnailClickable.vue.d.ts +0 -20
- package/components/thumbnail/Thumbnail.d.ts +0 -35
- package/components/thumbnail/Thumbnail.stories.d.ts +0 -169
- package/components/thumbnail/index.d.ts +0 -4
- package/components/thumbnail/useFocusPointStyle.d.ts +0 -20
- package/components/thumbnail/useImageLoad.d.ts +0 -10
- package/components/time-picker-field/TimePickerField.d.ts +0 -45
- package/components/time-picker-field/TimePickerField.stories.d.ts +0 -54
- package/components/time-picker-field/TimePickerField.test.d.ts +0 -1
- package/components/time-picker-field/index.d.ts +0 -2
- package/components/toolbar/Toolbar.d.ts +0 -8
- package/components/toolbar/Toolbar.stories.d.ts +0 -19
- package/components/toolbar/index.d.ts +0 -3
- package/components/tooltip/Tooltip.d.ts +0 -15
- package/components/tooltip/Tooltip.stories.d.ts +0 -51
- package/components/tooltip/Tooltip.test.stories.d.ts +0 -63
- package/components/tooltip/context.d.ts +0 -13
- package/components/tooltip/index.d.ts +0 -1
- package/components/tooltip/useInjectTooltipRef.d.ts +0 -22
- package/components/tooltip/useTooltipOpen.d.ts +0 -14
- package/components/uploader/Uploader.d.ts +0 -38
- package/components/uploader/index.d.ts +0 -2
- package/components/user-block/UserBlock.d.ts +0 -39
- package/components/user-block/UserBlock.stories.d.ts +0 -151
- package/components/user-block/index.d.ts +0 -1
- package/composables/useAttrFallback.d.ts +0 -28
- package/composables/useCallbackOnEscape.d.ts +0 -13
- package/composables/useClassName.d.ts +0 -16
- package/composables/useDisableBodyScroll.d.ts +0 -8
- package/composables/useDisableStateProps.d.ts +0 -16
- package/composables/useDisabledState.d.ts +0 -3
- package/composables/useFocus.d.ts +0 -9
- package/composables/useFocusTrap.d.ts +0 -13
- package/composables/useHasEventListener.d.ts +0 -7
- package/composables/useId.d.ts +0 -7
- package/composables/useOverflowTooltipLabel.d.ts +0 -7
- package/composables/useRestoreFocusOnClose.d.ts +0 -15
- package/composables/useRovingTabIndexContainer.d.ts +0 -32
- package/composables/useSlot.d.ts +0 -6
- package/composables/useTheme.d.ts +0 -1
- package/composables/useTransitionVisibility.d.ts +0 -11
- package/composables/useWatchDisposable.d.ts +0 -19
- package/index.js.map +0 -1
- package/stories/decorators/withChromaticForceScreenSize.d.ts +0 -2
- package/stories/decorators/withCombinations.d.ts +0 -6
- package/stories/decorators/withNestedProps.d.ts +0 -10
- package/stories/decorators/withResizableBox.d.ts +0 -12
- package/stories/decorators/withThemedBackground.d.ts +0 -12
- package/stories/decorators/withTheming.d.ts +0 -26
- package/stories/decorators/withValueOnChange.d.ts +0 -12
- package/stories/decorators/withWrapper.d.ts +0 -10
- package/stories/utils/CustomLink.vue.d.ts +0 -29
- package/stories/utils/useAttrsWithoutHandlers.d.ts +0 -27
- package/stories/utils/withRender.d.ts +0 -54
- package/utils/ClickAway/ClickAwayProvider.d.ts +0 -21
- package/utils/ClickAway/ClickAwayProvider.stories.d.ts +0 -25
- package/utils/ClickAway/index.d.ts +0 -2
- package/utils/ClickAway/useClickAway.d.ts +0 -18
- package/utils/InfiniteScroll/InfiniteScroll.d.ts +0 -7
- package/utils/InfiniteScroll/InfiniteScroll.test.stories.d.ts +0 -39
- package/utils/InfiniteScroll/index.d.ts +0 -1
- package/utils/Portal/Portal.d.ts +0 -7
- package/utils/Portal/PortalProvider.d.ts +0 -9
- package/utils/Portal/PortalProvider.stories.d.ts +0 -19
- package/utils/Portal/index.d.ts +0 -2
- package/utils/VueToJSX.d.ts +0 -40
- package/utils/action-area/ActionArea.stories.d.ts +0 -28
- package/utils/index.js.map +0 -1
- package/utils/isComponentType.d.ts +0 -6
- package/utils/theme/ResetTheme.d.ts +0 -3
- package/utils/theme/ThemeProvider.d.ts +0 -10
- package/utils/theme/index.d.ts +0 -3
- package/utils/theme/useTheme.d.ts +0 -10
- package/utils/wrapChildrenIconWithSpaces.d.ts +0 -3
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { bem } from "../../utils/classNames/bem/index.js";
|
|
2
|
+
import { import_classnames } from "../../utils/classNames/index.js";
|
|
3
|
+
import { INPUT_NATIVE_CLASSNAME } from "./constants.js";
|
|
4
|
+
import { createVNode, mergeProps } from "vue";
|
|
5
|
+
//#region ../lumx-core/src/js/components/TextField/RawInputText.tsx
|
|
6
|
+
var { block } = bem(INPUT_NATIVE_CLASSNAME);
|
|
7
|
+
/**
|
|
8
|
+
* Defines the props of the component.
|
|
9
|
+
*/
|
|
10
|
+
/**
|
|
11
|
+
* Component default props.
|
|
12
|
+
*/
|
|
13
|
+
var DEFAULT_PROPS = { type: "text" };
|
|
14
|
+
/**
|
|
15
|
+
* Raw input text component
|
|
16
|
+
* (input element without any decoration)
|
|
17
|
+
*/
|
|
18
|
+
var RawInputText = (props) => {
|
|
19
|
+
const { className, theme, value, handleChange, handleInput, handleFocus, handleBlur, type = DEFAULT_PROPS.type, name, ref, ...forwardedProps } = props;
|
|
20
|
+
const handleOnChange = (evt) => {
|
|
21
|
+
handleChange?.(evt.target.value, name, evt);
|
|
22
|
+
};
|
|
23
|
+
const handleOnInput = (evt) => {
|
|
24
|
+
handleInput?.(evt.target.value, name, evt);
|
|
25
|
+
};
|
|
26
|
+
return createVNode("input", mergeProps(forwardedProps, {
|
|
27
|
+
"name": name,
|
|
28
|
+
"type": type,
|
|
29
|
+
"ref": ref,
|
|
30
|
+
"className": import_classnames.default(className, block({
|
|
31
|
+
[`theme-${theme}`]: Boolean(theme),
|
|
32
|
+
text: true
|
|
33
|
+
})),
|
|
34
|
+
"onChange": handleOnChange,
|
|
35
|
+
"onInput": handleOnInput,
|
|
36
|
+
"onFocus": handleFocus,
|
|
37
|
+
"onBlur": handleBlur,
|
|
38
|
+
"value": value
|
|
39
|
+
}), null);
|
|
40
|
+
};
|
|
41
|
+
//#endregion
|
|
42
|
+
export { RawInputText };
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { HasClassName } from "../../types/HasClassName.js";
|
|
2
|
+
import { HasTheme } from "../../types/HasTheme.js";
|
|
3
|
+
import { CommonRef } from "../../types/CommonRef.js";
|
|
4
|
+
//#region ../lumx-core/src/js/components/TextField/RawInputTextarea.d.ts
|
|
5
|
+
/**
|
|
6
|
+
* Defines the props of the component.
|
|
7
|
+
*/
|
|
8
|
+
interface RawInputTextareaProps extends HasTheme, HasClassName {
|
|
9
|
+
value?: string;
|
|
10
|
+
rows?: number;
|
|
11
|
+
name?: string | undefined;
|
|
12
|
+
ref?: CommonRef;
|
|
13
|
+
handleChange?: (value: string, name?: string, event?: any) => void;
|
|
14
|
+
handleInput?: (value: string, name?: string, event?: any) => void;
|
|
15
|
+
handleFocus?: (event?: any) => void;
|
|
16
|
+
handleBlur?: (event?: any) => void;
|
|
17
|
+
}
|
|
18
|
+
//#endregion
|
|
19
|
+
export { RawInputTextareaProps };
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { bem } from "../../utils/classNames/bem/index.js";
|
|
2
|
+
import { import_classnames } from "../../utils/classNames/index.js";
|
|
3
|
+
import { INPUT_NATIVE_CLASSNAME } from "./constants.js";
|
|
4
|
+
import { createVNode, mergeProps } from "vue";
|
|
5
|
+
//#region ../lumx-core/src/js/components/TextField/RawInputTextarea.tsx
|
|
6
|
+
var { block } = bem(INPUT_NATIVE_CLASSNAME);
|
|
7
|
+
/**
|
|
8
|
+
* Defines the props of the component.
|
|
9
|
+
*/
|
|
10
|
+
/**
|
|
11
|
+
* Component default props.
|
|
12
|
+
*/
|
|
13
|
+
var DEFAULT_PROPS = { rows: 2 };
|
|
14
|
+
/**
|
|
15
|
+
* Raw input textarea component
|
|
16
|
+
* (textarea element without any decoration)
|
|
17
|
+
*/
|
|
18
|
+
var RawInputTextarea = (props) => {
|
|
19
|
+
const { className, theme, value, handleChange, handleInput, handleFocus, handleBlur, rows = DEFAULT_PROPS.rows, name, ref, ...forwardedProps } = props;
|
|
20
|
+
const handleOnChange = (evt) => {
|
|
21
|
+
handleChange?.(evt.target.value, name, evt);
|
|
22
|
+
};
|
|
23
|
+
const handleOnInput = (evt) => {
|
|
24
|
+
handleInput?.(evt.target.value, name, evt);
|
|
25
|
+
};
|
|
26
|
+
return createVNode("textarea", mergeProps(forwardedProps, {
|
|
27
|
+
"name": name,
|
|
28
|
+
"ref": ref,
|
|
29
|
+
"className": import_classnames.default(className, block({
|
|
30
|
+
[`theme-${theme}`]: Boolean(theme),
|
|
31
|
+
textarea: true
|
|
32
|
+
})),
|
|
33
|
+
"onChange": handleOnChange,
|
|
34
|
+
"onInput": handleOnInput,
|
|
35
|
+
"onFocus": handleFocus,
|
|
36
|
+
"onBlur": handleBlur,
|
|
37
|
+
"value": value,
|
|
38
|
+
"rows": rows
|
|
39
|
+
}), null);
|
|
40
|
+
};
|
|
41
|
+
//#endregion
|
|
42
|
+
export { DEFAULT_PROPS, RawInputTextarea };
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { HasClassName } from "../../types/HasClassName.js";
|
|
2
|
+
import { HasTheme } from "../../types/HasTheme.js";
|
|
3
|
+
import { GenericProps } from "../../types/GenericProps.js";
|
|
4
|
+
import { JSXElement } from "../../types/JSXElement.js";
|
|
5
|
+
import { CommonRef } from "../../types/CommonRef.js";
|
|
6
|
+
import { HasAriaDisabled } from "../../types/HasAriaDisabled.js";
|
|
7
|
+
import { HasDisabled } from "../../types/HasDisabled.js";
|
|
8
|
+
import { InputLabelProps } from "../InputLabel/index.js";
|
|
9
|
+
|
|
10
|
+
//#region ../lumx-core/src/js/components/TextField/TextField.d.ts
|
|
11
|
+
/**
|
|
12
|
+
* Defines the props of the component.
|
|
13
|
+
*/
|
|
14
|
+
interface TextFieldProps extends HasClassName, HasTheme, HasAriaDisabled, HasDisabled {
|
|
15
|
+
/** Chip Group to be rendered before the main text input. */
|
|
16
|
+
chips?: JSXElement;
|
|
17
|
+
/** Props to pass to the clear button (minus those already set by the TextField props). If not specified, the button won't be displayed. */
|
|
18
|
+
clearButtonProps?: GenericProps;
|
|
19
|
+
/** Error message. */
|
|
20
|
+
error?: string | JSXElement;
|
|
21
|
+
/** Whether we force the focus style or not. */
|
|
22
|
+
forceFocusStyle?: boolean;
|
|
23
|
+
/** Whether the text field is displayed with error style or not. */
|
|
24
|
+
hasError?: boolean;
|
|
25
|
+
/** Additional element to put at the end of the text field. */
|
|
26
|
+
afterElement?: JSXElement;
|
|
27
|
+
/** Helper text. */
|
|
28
|
+
helper?: string | JSXElement;
|
|
29
|
+
/** Icon (SVG path). */
|
|
30
|
+
icon?: string;
|
|
31
|
+
/** Native input id property (generated if not provided to link the label element). */
|
|
32
|
+
id?: string;
|
|
33
|
+
/** Generated helper id for accessibility attributes. */
|
|
34
|
+
helperId?: string;
|
|
35
|
+
/** Generated error id for accessibility attributes. */
|
|
36
|
+
errorId?: string;
|
|
37
|
+
/** Generated label id for accessibility attributes (used to link the clear button to the field label). */
|
|
38
|
+
labelId?: string;
|
|
39
|
+
/** Whether the component is required or not. */
|
|
40
|
+
isRequired?: boolean;
|
|
41
|
+
/** Whether the text field is displayed with valid style or not. */
|
|
42
|
+
isValid?: boolean;
|
|
43
|
+
/** Label text. */
|
|
44
|
+
label?: string;
|
|
45
|
+
/** Additional label props. */
|
|
46
|
+
labelProps?: InputLabelProps;
|
|
47
|
+
/** Max string length the input accepts (constrains the input and displays a character counter). */
|
|
48
|
+
maxLength?: number;
|
|
49
|
+
/** Whether the text field is a textarea or an input. */
|
|
50
|
+
multiline?: boolean;
|
|
51
|
+
/** Placeholder text. */
|
|
52
|
+
placeholder?: string;
|
|
53
|
+
/** Reference to the wrapper. */
|
|
54
|
+
textFieldRef?: CommonRef;
|
|
55
|
+
/** Value. */
|
|
56
|
+
value?: string;
|
|
57
|
+
/** Whether any part is disabled. */
|
|
58
|
+
isAnyDisabled?: boolean;
|
|
59
|
+
/** The input element (input or textarea). */
|
|
60
|
+
input: JSXElement;
|
|
61
|
+
/** Whether the input is focused. */
|
|
62
|
+
isFocus?: boolean;
|
|
63
|
+
/** IconButton component. */
|
|
64
|
+
IconButton: (props: Record<string, any>) => any;
|
|
65
|
+
/** Ref to the component root. */
|
|
66
|
+
ref?: CommonRef;
|
|
67
|
+
}
|
|
68
|
+
type TextFieldPropsToOverride = 'input' | 'IconButton' | 'labelProps' | 'textFieldRef' | 'clearButtonProps' | 'helperId' | 'errorId' | 'labelId' | 'isAnyDisabled' | 'isFocus';
|
|
69
|
+
//#endregion
|
|
70
|
+
export { TextFieldProps, TextFieldPropsToOverride };
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import { Emphasis, Kind, Size, Theme } from "../../constants/enums/index.js";
|
|
2
|
+
import { bem } from "../../utils/classNames/bem/index.js";
|
|
3
|
+
import { import_classnames } from "../../utils/classNames/index.js";
|
|
4
|
+
import { Icon } from "../Icon/index.js";
|
|
5
|
+
import { CLASSNAME } from "./constants.js";
|
|
6
|
+
import { InputLabel } from "../InputLabel/index.js";
|
|
7
|
+
import { InputHelper } from "../InputHelper/index.js";
|
|
8
|
+
import { createVNode, mergeProps } from "vue";
|
|
9
|
+
import { mdiAlertCircle } from "@lumx/icons/esm/alert-circle.js";
|
|
10
|
+
import { mdiCheckCircle } from "@lumx/icons/esm/check-circle.js";
|
|
11
|
+
import { mdiCloseCircle } from "@lumx/icons/esm/close-circle.js";
|
|
12
|
+
//#region ../lumx-core/src/js/components/TextField/TextField.tsx
|
|
13
|
+
var { block, element } = bem(CLASSNAME);
|
|
14
|
+
/**
|
|
15
|
+
* Defines the props of the component.
|
|
16
|
+
*/
|
|
17
|
+
/**
|
|
18
|
+
* Generate unique accessibility IDs for helper and error texts.
|
|
19
|
+
* Combines them with any existing aria-describedby in priority order (error > helper > existing).
|
|
20
|
+
*
|
|
21
|
+
* @param helper Helper text content
|
|
22
|
+
* @param error Error text content
|
|
23
|
+
* @param generatedId Unique ID for this text field instance
|
|
24
|
+
* @param existingAriaDescribedBy Existing aria-describedby value to merge
|
|
25
|
+
* @return Object containing helperId, errorId, and combined describedById
|
|
26
|
+
*/
|
|
27
|
+
function generateAccessibilityIds(helper, error, generatedId, existingAriaDescribedBy, label) {
|
|
28
|
+
const helperId = helper ? `text-field-helper-${generatedId}` : void 0;
|
|
29
|
+
const errorId = error ? `text-field-error-${generatedId}` : void 0;
|
|
30
|
+
const labelId = label ? `text-field-label-${generatedId}` : void 0;
|
|
31
|
+
const describedByIds = [
|
|
32
|
+
errorId,
|
|
33
|
+
helperId,
|
|
34
|
+
existingAriaDescribedBy
|
|
35
|
+
].filter(Boolean);
|
|
36
|
+
return {
|
|
37
|
+
helperId,
|
|
38
|
+
errorId,
|
|
39
|
+
describedById: describedByIds.length === 0 ? void 0 : describedByIds.join(" "),
|
|
40
|
+
labelId
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* TextField component.
|
|
45
|
+
*
|
|
46
|
+
* @param props Component props.
|
|
47
|
+
* @param ref Component ref.
|
|
48
|
+
* @return React element.
|
|
49
|
+
*/
|
|
50
|
+
var TextField = (props) => {
|
|
51
|
+
const { chips, className, clearButtonProps, error, forceFocusStyle, hasError, helper, icon, id: textFieldId, isRequired, isValid, label, labelProps, isAnyDisabled, maxLength, multiline, placeholder, textFieldRef, helperId, errorId, labelId, theme, value, afterElement, input, isFocus, IconButton, ref } = props;
|
|
52
|
+
const valueLength = (value || "").length;
|
|
53
|
+
const isNotEmpty = valueLength > 0;
|
|
54
|
+
return createVNode("div", {
|
|
55
|
+
"ref": ref,
|
|
56
|
+
"className": import_classnames.default(className, block({
|
|
57
|
+
"has-chips": Boolean(chips),
|
|
58
|
+
"has-error": !isValid && hasError,
|
|
59
|
+
"has-icon": Boolean(icon),
|
|
60
|
+
"has-input": !multiline,
|
|
61
|
+
"has-input-clear": Boolean(clearButtonProps && isNotEmpty),
|
|
62
|
+
"has-label": Boolean(label),
|
|
63
|
+
"has-placeholder": Boolean(placeholder),
|
|
64
|
+
"has-textarea": multiline,
|
|
65
|
+
"has-value": Boolean(value),
|
|
66
|
+
"is-disabled": isAnyDisabled,
|
|
67
|
+
"is-focus": isFocus || forceFocusStyle,
|
|
68
|
+
"is-valid": isValid,
|
|
69
|
+
[`theme-${theme}`]: Boolean(theme)
|
|
70
|
+
}))
|
|
71
|
+
}, [
|
|
72
|
+
(label || maxLength) && createVNode("div", { "className": element("header") }, [label && InputLabel({
|
|
73
|
+
...labelProps,
|
|
74
|
+
id: labelId,
|
|
75
|
+
htmlFor: textFieldId,
|
|
76
|
+
className: element("label"),
|
|
77
|
+
isRequired,
|
|
78
|
+
theme,
|
|
79
|
+
children: label
|
|
80
|
+
}), maxLength && createVNode("div", { "className": element("char-counter") }, [createVNode("span", null, [maxLength - valueLength]), maxLength - valueLength === 0 && Icon({
|
|
81
|
+
icon: mdiAlertCircle,
|
|
82
|
+
size: Size.xxs
|
|
83
|
+
})])]),
|
|
84
|
+
createVNode("div", {
|
|
85
|
+
"className": element("wrapper"),
|
|
86
|
+
"ref": textFieldRef
|
|
87
|
+
}, [
|
|
88
|
+
icon && Icon({
|
|
89
|
+
className: element("input-icon"),
|
|
90
|
+
color: theme === Theme.dark ? "light" : void 0,
|
|
91
|
+
icon,
|
|
92
|
+
size: Size.xs
|
|
93
|
+
}),
|
|
94
|
+
chips ? createVNode("div", { "className": element("chips") }, [chips, input]) : createVNode("div", { "className": element("input-wrapper") }, [input]),
|
|
95
|
+
(isValid || hasError) && Icon({
|
|
96
|
+
className: element("input-validity"),
|
|
97
|
+
color: theme === Theme.dark ? "light" : void 0,
|
|
98
|
+
icon: isValid ? mdiCheckCircle : mdiAlertCircle,
|
|
99
|
+
size: Size.xxs
|
|
100
|
+
}),
|
|
101
|
+
clearButtonProps && isNotEmpty && !isAnyDisabled && createVNode(IconButton, mergeProps({ "aria-describedby": labelId }, clearButtonProps, {
|
|
102
|
+
"className": element("input-clear"),
|
|
103
|
+
"icon": mdiCloseCircle,
|
|
104
|
+
"emphasis": Emphasis.low,
|
|
105
|
+
"size": Size.s,
|
|
106
|
+
"theme": theme,
|
|
107
|
+
"type": "button"
|
|
108
|
+
}), null),
|
|
109
|
+
afterElement && createVNode("div", { "className": element("after-element") }, [afterElement])
|
|
110
|
+
]),
|
|
111
|
+
hasError && error && InputHelper({
|
|
112
|
+
children: error,
|
|
113
|
+
className: element("helper"),
|
|
114
|
+
kind: Kind.error,
|
|
115
|
+
theme,
|
|
116
|
+
id: errorId
|
|
117
|
+
}),
|
|
118
|
+
helper && InputHelper({
|
|
119
|
+
className: element("helper"),
|
|
120
|
+
theme,
|
|
121
|
+
id: helperId,
|
|
122
|
+
children: helper
|
|
123
|
+
})
|
|
124
|
+
]);
|
|
125
|
+
};
|
|
126
|
+
//#endregion
|
|
127
|
+
export { TextField, generateAccessibilityIds };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
//#region ../lumx-core/src/js/components/TextField/constants.ts
|
|
2
|
+
/**
|
|
3
|
+
* Component default class name and class prefix.
|
|
4
|
+
*/
|
|
5
|
+
var CLASSNAME = "lumx-text-field";
|
|
6
|
+
/**
|
|
7
|
+
* Input native element class name.
|
|
8
|
+
*/
|
|
9
|
+
var INPUT_NATIVE_CLASSNAME = `${CLASSNAME}__input-native`;
|
|
10
|
+
//#endregion
|
|
11
|
+
export { CLASSNAME, INPUT_NATIVE_CLASSNAME };
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { ThumbnailObjectFit, ThumbnailSize, ThumbnailVariant } from "./types.js";
|
|
2
|
+
import { AspectRatio, HorizontalAlignment } from "@lumx/core/js/constants";
|
|
3
|
+
import { CommonRef, GenericProps, HasClassName, HasTheme, JSXElement } from "@lumx/core/js/types";
|
|
4
|
+
import { ImgHTMLAttributes } from "react";
|
|
5
|
+
|
|
6
|
+
//#region ../lumx-core/src/js/components/Thumbnail/index.d.ts
|
|
7
|
+
type ImgHTMLProps = ImgHTMLAttributes<HTMLImageElement>;
|
|
8
|
+
/**
|
|
9
|
+
* Defines the props of the component.
|
|
10
|
+
*/
|
|
11
|
+
interface ThumbnailProps extends HasTheme, HasClassName {
|
|
12
|
+
/** Alignment of the thumbnail in it's parent (requires flex parent). */
|
|
13
|
+
align?: HorizontalAlignment;
|
|
14
|
+
/** Image alternative text. */
|
|
15
|
+
alt: string;
|
|
16
|
+
/** Image aspect ratio. */
|
|
17
|
+
aspectRatio?: AspectRatio;
|
|
18
|
+
/** Badge. */
|
|
19
|
+
badge?: JSXElement;
|
|
20
|
+
/** Image cross origin resource policy. */
|
|
21
|
+
crossOrigin?: ImgHTMLProps['crossOrigin'];
|
|
22
|
+
/** Fallback icon (SVG path) or react node when image fails to load. */
|
|
23
|
+
fallback?: string | JSXElement;
|
|
24
|
+
/** Whether the thumbnail should fill it's parent size (requires flex parent) or not. */
|
|
25
|
+
fillHeight?: boolean;
|
|
26
|
+
/** Image URL. */
|
|
27
|
+
image: string;
|
|
28
|
+
loadingState: string;
|
|
29
|
+
/** Props to inject into the native <img> element. */
|
|
30
|
+
imgProps?: ImgHTMLProps;
|
|
31
|
+
/** Reference to the native <img> element. */
|
|
32
|
+
imgRef?: CommonRef;
|
|
33
|
+
ref?: CommonRef;
|
|
34
|
+
/** Set to true to force the display of the loading skeleton. */
|
|
35
|
+
isLoading?: boolean;
|
|
36
|
+
/** Set how the image should fit when its aspect ratio is constrained */
|
|
37
|
+
objectFit?: ThumbnailObjectFit;
|
|
38
|
+
/** Size variant of the component. */
|
|
39
|
+
size?: ThumbnailSize;
|
|
40
|
+
/** Image loading mode. */
|
|
41
|
+
loading?: 'eager' | 'lazy';
|
|
42
|
+
/** Ref of an existing placeholder image to display while loading. */
|
|
43
|
+
loadingPlaceholderImageRef?: React.RefObject<HTMLImageElement>;
|
|
44
|
+
/** On click callback. */
|
|
45
|
+
handleClick?: (event: any) => void;
|
|
46
|
+
/** On key press callback. */
|
|
47
|
+
handleKeyPress?: (event: any) => void;
|
|
48
|
+
/** Variant of the component. */
|
|
49
|
+
variant?: ThumbnailVariant;
|
|
50
|
+
/** Props to pass to the link wrapping the thumbnail. */
|
|
51
|
+
linkProps?: GenericProps;
|
|
52
|
+
focusPointStyle?: GenericProps;
|
|
53
|
+
disabledStateProps?: GenericProps;
|
|
54
|
+
isAnyDisabled?: boolean;
|
|
55
|
+
/** Custom react component for the link (can be used to inject react router Link). */
|
|
56
|
+
linkAs?: 'a' | any;
|
|
57
|
+
'aria-label'?: string;
|
|
58
|
+
}
|
|
59
|
+
//#endregion
|
|
60
|
+
export { ThumbnailProps };
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
import { RawClickable } from "../RawClickable/index.js";
|
|
2
|
+
import { Icon } from "../Icon/index.js";
|
|
3
|
+
import "./utils.js";
|
|
4
|
+
import { AspectRatio, Size } from "@lumx/core/js/constants";
|
|
5
|
+
import { Fragment, createVNode, mergeProps } from "vue";
|
|
6
|
+
import { classNames } from "@lumx/core/js/utils";
|
|
7
|
+
import { mdiImageBroken } from "@lumx/icons/esm/image-broken.js";
|
|
8
|
+
//#region ../lumx-core/src/js/components/Thumbnail/index.tsx
|
|
9
|
+
/**
|
|
10
|
+
* Component default class name and class prefix.
|
|
11
|
+
*/
|
|
12
|
+
var CLASSNAME = "lumx-thumbnail";
|
|
13
|
+
var { block, element } = classNames.bem(CLASSNAME);
|
|
14
|
+
/**
|
|
15
|
+
* Component default props.
|
|
16
|
+
*/
|
|
17
|
+
var DEFAULT_PROPS = {
|
|
18
|
+
fallback: mdiImageBroken,
|
|
19
|
+
loading: "lazy"
|
|
20
|
+
};
|
|
21
|
+
/**
|
|
22
|
+
* Thumbnail component.
|
|
23
|
+
*
|
|
24
|
+
* @param props Component props.
|
|
25
|
+
* @param ref Component ref.
|
|
26
|
+
* @return React element.
|
|
27
|
+
*/
|
|
28
|
+
var Thumbnail = (props) => {
|
|
29
|
+
const { align, alt, aspectRatio = AspectRatio.original, badge, className, crossOrigin, ref, fallback = DEFAULT_PROPS.fallback, focusPointStyle, fillHeight, image, imgProps, imgRef: propImgRef, isLoading: isLoadingProp, objectFit, loading = DEFAULT_PROPS.loading, loadingPlaceholderImageRef, isAnyDisabled, disabledStateProps, size, theme, loadingState, variant, linkProps, linkAs, handleClick, handleKeyPress, ...forwardedProps } = props;
|
|
30
|
+
const isLoading = isLoadingProp || loadingState === "isLoading";
|
|
31
|
+
const hasError = loadingState === "hasError";
|
|
32
|
+
const hasIconErrorFallback = hasError && typeof fallback === "string";
|
|
33
|
+
const hasCustomErrorFallback = hasError && !hasIconErrorFallback;
|
|
34
|
+
const imageErrorStyle = {};
|
|
35
|
+
if (hasIconErrorFallback) imageErrorStyle.visibility = "hidden";
|
|
36
|
+
else if (hasCustomErrorFallback) imageErrorStyle.display = "none";
|
|
37
|
+
const isLink = Boolean(linkProps?.href || linkAs);
|
|
38
|
+
const isClickable = !isAnyDisabled && Boolean(isLink || !!handleClick || !!handleKeyPress);
|
|
39
|
+
const wrapperProps = { ...forwardedProps };
|
|
40
|
+
if (isClickable) {
|
|
41
|
+
Object.assign(wrapperProps, { as: linkAs || (linkProps?.href ? "a" : "button") }, disabledStateProps);
|
|
42
|
+
if (isLink) Object.assign(wrapperProps, linkProps);
|
|
43
|
+
else wrapperProps["aria-label"] = forwardedProps["aria-label"] || alt;
|
|
44
|
+
}
|
|
45
|
+
const wrapperClassName = classNames.join(linkProps?.className, className, block({
|
|
46
|
+
[`align-${align}`]: Boolean(align),
|
|
47
|
+
[`aspect-ratio-${aspectRatio}`]: Boolean(aspectRatio),
|
|
48
|
+
[`size-${size}`]: Boolean(size),
|
|
49
|
+
[`theme-${theme}`]: Boolean(theme),
|
|
50
|
+
[`variant-${variant}`]: Boolean(variant),
|
|
51
|
+
"is-clickable": isClickable,
|
|
52
|
+
"has-error": hasError,
|
|
53
|
+
"has-icon-error-fallback": hasIconErrorFallback,
|
|
54
|
+
"has-custom-error-fallback": hasCustomErrorFallback,
|
|
55
|
+
"is-loading": isLoading,
|
|
56
|
+
[`object-fit-${objectFit}`]: Boolean(objectFit),
|
|
57
|
+
"has-badge": !!badge,
|
|
58
|
+
"fill-height": fillHeight
|
|
59
|
+
}));
|
|
60
|
+
const loadingPlaceholderImage = isLoading && loadingPlaceholderImageRef?.current?.complete && loadingPlaceholderImageRef?.current || void 0;
|
|
61
|
+
const loadingStyle = loadingPlaceholderImage ? { backgroundImage: `url(${loadingPlaceholderImage.src})` } : void 0;
|
|
62
|
+
const innerImage = createVNode(Fragment, null, [createVNode("span", { "className": element("background") }, [createVNode("img", mergeProps({
|
|
63
|
+
"width": loadingPlaceholderImage?.naturalWidth,
|
|
64
|
+
"height": loadingPlaceholderImage?.naturalHeight
|
|
65
|
+
}, imgProps, {
|
|
66
|
+
"style": {
|
|
67
|
+
width: isLoading ? imgProps?.width || loadingPlaceholderImage?.naturalWidth : void 0,
|
|
68
|
+
...imgProps?.style,
|
|
69
|
+
...imageErrorStyle,
|
|
70
|
+
...focusPointStyle,
|
|
71
|
+
...loadingStyle
|
|
72
|
+
},
|
|
73
|
+
"ref": propImgRef,
|
|
74
|
+
"className": classNames.join(element("image", {
|
|
75
|
+
"is-loading": isLoading,
|
|
76
|
+
"has-defined-size": Boolean(imgProps?.height && imgProps.width)
|
|
77
|
+
}), imgProps?.className),
|
|
78
|
+
"crossOrigin": crossOrigin,
|
|
79
|
+
"src": image,
|
|
80
|
+
"alt": alt,
|
|
81
|
+
"loading": loading
|
|
82
|
+
}), null), !isLoading && hasError && createVNode("span", { "className": element("fallback") }, [hasIconErrorFallback ? Icon({
|
|
83
|
+
icon: fallback,
|
|
84
|
+
size: Size.xxs,
|
|
85
|
+
theme
|
|
86
|
+
}) : fallback])]), badge]);
|
|
87
|
+
/** Render `RawClickable` as a function since it is a core component which needs to be treated as such */
|
|
88
|
+
if (isClickable) return RawClickable({
|
|
89
|
+
ref,
|
|
90
|
+
...wrapperProps,
|
|
91
|
+
className: wrapperClassName,
|
|
92
|
+
children: innerImage,
|
|
93
|
+
handleClick,
|
|
94
|
+
handleKeyPress
|
|
95
|
+
});
|
|
96
|
+
return createVNode("div", mergeProps({ "ref": ref }, wrapperProps, { "className": wrapperClassName }), [innerImage]);
|
|
97
|
+
};
|
|
98
|
+
//#endregion
|
|
99
|
+
export { CLASSNAME, DEFAULT_PROPS, Thumbnail, element };
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { Size } from "../../constants/enums/index.js";
|
|
2
|
+
import { ValueOf } from "../../types/ValueOf.js";
|
|
3
|
+
//#region ../lumx-core/src/js/components/Thumbnail/types.d.ts
|
|
4
|
+
/**
|
|
5
|
+
* Focal point using vertical alignment, horizontal alignment or coordinates (from -1 to 1).
|
|
6
|
+
*/
|
|
7
|
+
type FocusPoint = {
|
|
8
|
+
x?: number;
|
|
9
|
+
y?: number;
|
|
10
|
+
};
|
|
11
|
+
/**
|
|
12
|
+
* Loading attribute is not yet supported in typescript, so we need
|
|
13
|
+
* to add it in order to avoid a ts error.
|
|
14
|
+
* https://github.com/typescript-cheatsheets/react-typescript-cheatsheet/blob/master/ADVANCED.md#adding-non-standard-attributes
|
|
15
|
+
*/
|
|
16
|
+
declare module 'react' {
|
|
17
|
+
interface ImgHTMLAttributes<T> extends React.HTMLAttributes<T> {
|
|
18
|
+
loading?: 'eager' | 'lazy';
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* All available aspect ratios.
|
|
23
|
+
* @deprecated
|
|
24
|
+
*/
|
|
25
|
+
/**
|
|
26
|
+
* Thumbnail sizes.
|
|
27
|
+
*/
|
|
28
|
+
type ThumbnailSize = Extract<Size, 'xxs' | 'xs' | 's' | 'm' | 'l' | 'xl' | 'xxl'>;
|
|
29
|
+
/**
|
|
30
|
+
* Thumbnail variants.
|
|
31
|
+
*/
|
|
32
|
+
declare const ThumbnailVariant: {
|
|
33
|
+
readonly squared: "squared";
|
|
34
|
+
readonly rounded: "rounded";
|
|
35
|
+
};
|
|
36
|
+
type ThumbnailVariant = ValueOf<typeof ThumbnailVariant>;
|
|
37
|
+
/**
|
|
38
|
+
* Thumbnail object fit.
|
|
39
|
+
*/
|
|
40
|
+
declare const ThumbnailObjectFit: {
|
|
41
|
+
readonly cover: "cover";
|
|
42
|
+
readonly contain: "contain";
|
|
43
|
+
};
|
|
44
|
+
type ThumbnailObjectFit = ValueOf<typeof ThumbnailObjectFit>;
|
|
45
|
+
type LoadingState = 'isLoading' | 'isLoaded' | 'hasError';
|
|
46
|
+
//#endregion
|
|
47
|
+
export { FocusPoint, LoadingState, ThumbnailObjectFit, ThumbnailSize, ThumbnailVariant };
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { AspectRatio } from "../../constants/enums/index.js";
|
|
2
|
+
({ ...AspectRatio });
|
|
3
|
+
/**
|
|
4
|
+
* Thumbnail variants.
|
|
5
|
+
*/
|
|
6
|
+
var ThumbnailVariant = {
|
|
7
|
+
squared: "squared",
|
|
8
|
+
rounded: "rounded"
|
|
9
|
+
};
|
|
10
|
+
/**
|
|
11
|
+
* Thumbnail object fit.
|
|
12
|
+
*/
|
|
13
|
+
var ThumbnailObjectFit = {
|
|
14
|
+
cover: "cover",
|
|
15
|
+
contain: "contain"
|
|
16
|
+
};
|
|
17
|
+
//#endregion
|
|
18
|
+
export { ThumbnailObjectFit, ThumbnailVariant };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import { CSSProperties } from "react";
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { AspectRatio } from "../../constants/enums/index.js";
|
|
2
|
+
//#region ../lumx-core/src/js/components/Thumbnail/utils.ts
|
|
3
|
+
/**
|
|
4
|
+
* Determines the loading state of an HTML image element.
|
|
5
|
+
*
|
|
6
|
+
* @param img - The HTML image element to check
|
|
7
|
+
* @param event - Optional event (load or error) that triggered the state check
|
|
8
|
+
* @returns The current loading state: 'hasError', 'isLoading', or 'isLoaded'
|
|
9
|
+
*/
|
|
10
|
+
function getImageLoadingState(img, event) {
|
|
11
|
+
if (event?.type === "error" || img?.complete && !img.getAttribute("src")) return "hasError";
|
|
12
|
+
if (!img || !img.complete) return "isLoading";
|
|
13
|
+
return "isLoaded";
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Gets the natural image size from props or element.
|
|
17
|
+
* Returns undefined if focus point is not applicable or size cannot be determined.
|
|
18
|
+
*
|
|
19
|
+
* @param params - Image size parameters
|
|
20
|
+
* @returns Image size or undefined
|
|
21
|
+
*/
|
|
22
|
+
function getImageSize({ image, aspectRatio, focusPoint, width, height, element, isLoaded }) {
|
|
23
|
+
if (!image || aspectRatio === AspectRatio.original || !focusPoint?.x && !focusPoint?.y) return;
|
|
24
|
+
if (typeof width === "number" && typeof height === "number") return {
|
|
25
|
+
width,
|
|
26
|
+
height
|
|
27
|
+
};
|
|
28
|
+
if (element && isLoaded) return {
|
|
29
|
+
width: element.naturalWidth,
|
|
30
|
+
height: element.naturalHeight
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Calculate shift position to center the focus point in the container.
|
|
35
|
+
*
|
|
36
|
+
* This function computes the percentage offset needed to position an image
|
|
37
|
+
* such that a specific focus point on the image aligns with the center of
|
|
38
|
+
* the container, taking into account the image's scale.
|
|
39
|
+
*
|
|
40
|
+
* @param params - Focus point shift calculation parameters
|
|
41
|
+
* @returns Percentage shift (0-100) for CSS positioning
|
|
42
|
+
*/
|
|
43
|
+
function shiftPosition({ scale, focusPoint, imageSize, containerSize }) {
|
|
44
|
+
const scaledSize = imageSize / scale;
|
|
45
|
+
if (scaledSize === containerSize) return 0;
|
|
46
|
+
const shift = (focusPoint * scaledSize - containerSize / 2) / (scaledSize - containerSize);
|
|
47
|
+
return Math.floor(Math.max(Math.min(shift, 1), 0) * 100);
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Calculates CSS style for applying focus point positioning.
|
|
51
|
+
*
|
|
52
|
+
* @param params - Focus point style parameters
|
|
53
|
+
* @returns CSS properties to apply to the image
|
|
54
|
+
*/
|
|
55
|
+
function calculateFocusPointStyle({ image, aspectRatio, focusPoint, element, imageSize, containerSize }) {
|
|
56
|
+
if (!image || aspectRatio === AspectRatio.original || !focusPoint?.x && !focusPoint?.y) return {};
|
|
57
|
+
if (!element || !imageSize) return { visibility: "hidden" };
|
|
58
|
+
if (!containerSize || !imageSize.height || !imageSize.width) return {};
|
|
59
|
+
const heightScale = imageSize.height / containerSize.height;
|
|
60
|
+
const widthScale = imageSize.width / containerSize.width;
|
|
61
|
+
const scale = Math.min(widthScale, heightScale);
|
|
62
|
+
const y = shiftPosition({
|
|
63
|
+
scale,
|
|
64
|
+
focusPoint: Math.abs((focusPoint?.y || 0) - 1) / 2,
|
|
65
|
+
imageSize: imageSize.height,
|
|
66
|
+
containerSize: containerSize.height
|
|
67
|
+
});
|
|
68
|
+
return { objectPosition: `${shiftPosition({
|
|
69
|
+
scale,
|
|
70
|
+
focusPoint: Math.abs((focusPoint?.x || 0) + 1) / 2,
|
|
71
|
+
imageSize: imageSize.width,
|
|
72
|
+
containerSize: containerSize.width
|
|
73
|
+
})}% ${y}%` };
|
|
74
|
+
}
|
|
75
|
+
//#endregion
|
|
76
|
+
export { calculateFocusPointStyle, getImageLoadingState, getImageSize, shiftPosition };
|