@smwb/ui-solid 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +148 -0
- package/dist/assets/styles/less/components/accordion/accordion.entry.css +1 -0
- package/dist/assets/styles/less/components/appBar/appBar.entry.css +1 -0
- package/dist/assets/styles/less/components/appLayout/appLayout.entry.css +1 -0
- package/dist/assets/styles/less/components/avatar/avatar.entry.css +1 -0
- package/dist/assets/styles/less/components/badge/badge.entry.css +1 -0
- package/dist/assets/styles/less/components/bottomBar/bottomBar.entry.css +1 -0
- package/dist/assets/styles/less/components/breadcrumbs/breadcrumbs.entry.css +1 -0
- package/dist/assets/styles/less/components/button/button.entry.css +1 -0
- package/dist/assets/styles/less/components/buttonGroup/buttonGroup.entry.css +1 -0
- package/dist/assets/styles/less/components/card/card.entry.css +1 -0
- package/dist/assets/styles/less/components/carousel/carousel.entry.css +1 -0
- package/dist/assets/styles/less/components/chat/chat.entry.css +1 -0
- package/dist/assets/styles/less/components/checkbox/checkbox.entry.css +1 -0
- package/dist/assets/styles/less/components/chip/chip.entry.css +1 -0
- package/dist/assets/styles/less/components/datePicker/dataPicker.entry.css +1 -0
- package/dist/assets/styles/less/components/divider/divider.entry.css +1 -0
- package/dist/assets/styles/less/components/expansionPanel/expansionPanel.entry.css +1 -0
- package/dist/assets/styles/less/components/fileDrop/fileDrop.entry.css +1 -0
- package/dist/assets/styles/less/components/fileInput/fileInput.entry.css +1 -0
- package/dist/assets/styles/less/components/floatingButton/floatingButton.entry.css +1 -0
- package/dist/assets/styles/less/components/grid/grid.entry.css +1 -0
- package/dist/assets/styles/less/components/icon/icon.entry.css +1 -0
- package/dist/assets/styles/less/components/imagesList/imagesList.entry.css +1 -0
- package/dist/assets/styles/less/components/imagesList/imagesListItem/imagesListItem.entry.css +1 -0
- package/dist/assets/styles/less/components/list/list.entry.css +1 -0
- package/dist/assets/styles/less/components/menu/menu.entry.css +1 -0
- package/dist/assets/styles/less/components/message/message.entry.css +1 -0
- package/dist/assets/styles/less/components/modal/modal.entry.css +1 -0
- package/dist/assets/styles/less/components/page/page.entry.css +1 -0
- package/dist/assets/styles/less/components/pageHeader/pageHeader.entry.css +1 -0
- package/dist/assets/styles/less/components/pagination/pagination.entry.css +1 -0
- package/dist/assets/styles/less/components/progressIndicator/progressIndicator.entry.css +1 -0
- package/dist/assets/styles/less/components/radioButton/radioButton.entry.css +1 -0
- package/dist/assets/styles/less/components/rating/rating.entry.css +1 -0
- package/dist/assets/styles/less/components/ripple/ripple.entry.css +1 -0
- package/dist/assets/styles/less/components/screenDivider/screenDivider.entry.css +1 -0
- package/dist/assets/styles/less/components/selectField/selectField.entry.css +1 -0
- package/dist/assets/styles/less/components/sheet/sheet.entry.css +1 -0
- package/dist/assets/styles/less/components/sidebar/sidebar.entry.css +1 -0
- package/dist/assets/styles/less/components/skeleton/skeleton.entry.css +1 -0
- package/dist/assets/styles/less/components/slider/slider.entry.css +1 -0
- package/dist/assets/styles/less/components/snackbar/snackbar.entry.css +1 -0
- package/dist/assets/styles/less/components/stack/stack.entry.css +1 -0
- package/dist/assets/styles/less/components/stepper/stepper.entry.css +1 -0
- package/dist/assets/styles/less/components/table/table.entry.css +1 -0
- package/dist/assets/styles/less/components/table/tablePagination/tablePagination.entry.css +1 -0
- package/dist/assets/styles/less/components/tabs/tab/tab.entry.css +1 -0
- package/dist/assets/styles/less/components/tabs/tabs.entry.css +1 -0
- package/dist/assets/styles/less/components/textField/textField.entry.css +1 -0
- package/dist/assets/styles/less/components/timePicker/timePicker.entry.css +1 -0
- package/dist/assets/styles/less/components/toggle/toggle.entry.css +1 -0
- package/dist/assets/styles/less/components/tooltip/tooltip.entry.css +1 -0
- package/dist/assets/styles/less/components/treeView/treeView.entry.css +1 -0
- package/dist/assets/styles/less/components/typography/typography.entry.css +1 -0
- package/dist/components/base/animateHeight/animateHeight.d.ts +30 -0
- package/dist/components/base/animateHeight/animateHeight.js +113 -0
- package/dist/components/base/animateHeight/animateHeight.js.map +1 -0
- package/dist/components/base/animateHeight/index.d.ts +2 -0
- package/dist/components/base/icon/icon.d.ts +29 -0
- package/dist/components/base/icon/icon.js +47 -0
- package/dist/components/base/icon/icon.js.map +1 -0
- package/dist/components/base/icon/index.d.ts +2 -0
- package/dist/components/base/ripple/index.d.ts +2 -0
- package/dist/components/base/ripple/ripple.d.ts +26 -0
- package/dist/components/base/ripple/ripple.js +58 -0
- package/dist/components/base/ripple/ripple.js.map +1 -0
- package/dist/components/clickAwayListener/clickAwayListener.d.ts +19 -0
- package/dist/components/clickAwayListener/clickAwayListener.js +61 -0
- package/dist/components/clickAwayListener/clickAwayListener.js.map +1 -0
- package/dist/components/clickAwayListener/index.d.ts +2 -0
- package/dist/components/dataDisplay/accordion/accordion.d.ts +25 -0
- package/dist/components/dataDisplay/accordion/accordion.js +83 -0
- package/dist/components/dataDisplay/accordion/accordion.js.map +1 -0
- package/dist/components/dataDisplay/accordion/index.d.ts +2 -0
- package/dist/components/dataDisplay/avatar/avatar.d.ts +28 -0
- package/dist/components/dataDisplay/avatar/avatar.js +105 -0
- package/dist/components/dataDisplay/avatar/avatar.js.map +1 -0
- package/dist/components/dataDisplay/avatar/index.d.ts +2 -0
- package/dist/components/dataDisplay/badge/badge.d.ts +18 -0
- package/dist/components/dataDisplay/badge/badge.js +41 -0
- package/dist/components/dataDisplay/badge/badge.js.map +1 -0
- package/dist/components/dataDisplay/badge/index.d.ts +2 -0
- package/dist/components/dataDisplay/card/card.d.ts +12 -0
- package/dist/components/dataDisplay/card/card.js +59 -0
- package/dist/components/dataDisplay/card/card.js.map +1 -0
- package/dist/components/dataDisplay/card/index.d.ts +2 -0
- package/dist/components/dataDisplay/carousel/carousel.d.ts +20 -0
- package/dist/components/dataDisplay/carousel/carousel.js +176 -0
- package/dist/components/dataDisplay/carousel/carousel.js.map +1 -0
- package/dist/components/dataDisplay/carousel/index.d.ts +2 -0
- package/dist/components/dataDisplay/carousel/utils.d.ts +12 -0
- package/dist/components/dataDisplay/carousel/utils.js +52 -0
- package/dist/components/dataDisplay/carousel/utils.js.map +1 -0
- package/dist/components/dataDisplay/chat/chat.d.ts +45 -0
- package/dist/components/dataDisplay/chat/chat.js +222 -0
- package/dist/components/dataDisplay/chat/chat.js.map +1 -0
- package/dist/components/dataDisplay/chat/chatAttachmentImage.d.ts +8 -0
- package/dist/components/dataDisplay/chat/chatAttachmentImage.js +63 -0
- package/dist/components/dataDisplay/chat/chatAttachmentImage.js.map +1 -0
- package/dist/components/dataDisplay/chat/chatAttachments.d.ts +9 -0
- package/dist/components/dataDisplay/chat/chatAttachments.js +48 -0
- package/dist/components/dataDisplay/chat/chatAttachments.js.map +1 -0
- package/dist/components/dataDisplay/chat/chatComposer.d.ts +16 -0
- package/dist/components/dataDisplay/chat/chatComposer.js +208 -0
- package/dist/components/dataDisplay/chat/chatComposer.js.map +1 -0
- package/dist/components/dataDisplay/chat/chatHeader.d.ts +14 -0
- package/dist/components/dataDisplay/chat/chatHeader.js +89 -0
- package/dist/components/dataDisplay/chat/chatHeader.js.map +1 -0
- package/dist/components/dataDisplay/chat/chatIconButton.d.ts +9 -0
- package/dist/components/dataDisplay/chat/chatIconButton.js +42 -0
- package/dist/components/dataDisplay/chat/chatIconButton.js.map +1 -0
- package/dist/components/dataDisplay/chat/chatLayout.d.ts +19 -0
- package/dist/components/dataDisplay/chat/chatLayout.js +147 -0
- package/dist/components/dataDisplay/chat/chatLayout.js.map +1 -0
- package/dist/components/dataDisplay/chat/chatMessageAvatar.d.ts +9 -0
- package/dist/components/dataDisplay/chat/chatMessageAvatar.js +32 -0
- package/dist/components/dataDisplay/chat/chatMessageAvatar.js.map +1 -0
- package/dist/components/dataDisplay/chat/chatMessageBubble.d.ts +20 -0
- package/dist/components/dataDisplay/chat/chatMessageBubble.js +122 -0
- package/dist/components/dataDisplay/chat/chatMessageBubble.js.map +1 -0
- package/dist/components/dataDisplay/chat/chatMessageIncoming.d.ts +8 -0
- package/dist/components/dataDisplay/chat/chatMessageIncoming.js +36 -0
- package/dist/components/dataDisplay/chat/chatMessageIncoming.js.map +1 -0
- package/dist/components/dataDisplay/chat/chatMessageItem.d.ts +9 -0
- package/dist/components/dataDisplay/chat/chatMessageItem.js +103 -0
- package/dist/components/dataDisplay/chat/chatMessageItem.js.map +1 -0
- package/dist/components/dataDisplay/chat/chatMessageOutgoing.d.ts +8 -0
- package/dist/components/dataDisplay/chat/chatMessageOutgoing.js +48 -0
- package/dist/components/dataDisplay/chat/chatMessageOutgoing.js.map +1 -0
- package/dist/components/dataDisplay/chat/chatMessageSkeleton.d.ts +9 -0
- package/dist/components/dataDisplay/chat/chatMessageSkeleton.js +59 -0
- package/dist/components/dataDisplay/chat/chatMessageSkeleton.js.map +1 -0
- package/dist/components/dataDisplay/chat/chatMessageStatus.d.ts +11 -0
- package/dist/components/dataDisplay/chat/chatMessageStatus.js +51 -0
- package/dist/components/dataDisplay/chat/chatMessageStatus.js.map +1 -0
- package/dist/components/dataDisplay/chat/chatMessageSystem.d.ts +8 -0
- package/dist/components/dataDisplay/chat/chatMessageSystem.js +26 -0
- package/dist/components/dataDisplay/chat/chatMessageSystem.js.map +1 -0
- package/dist/components/dataDisplay/chat/chatMessages.d.ts +14 -0
- package/dist/components/dataDisplay/chat/chatMessages.js +90 -0
- package/dist/components/dataDisplay/chat/chatMessages.js.map +1 -0
- package/dist/components/dataDisplay/chat/chatOverlayLayout.d.ts +16 -0
- package/dist/components/dataDisplay/chat/chatOverlayLayout.js +52 -0
- package/dist/components/dataDisplay/chat/chatOverlayLayout.js.map +1 -0
- package/dist/components/dataDisplay/chat/chatShell.d.ts +16 -0
- package/dist/components/dataDisplay/chat/chatShell.js +82 -0
- package/dist/components/dataDisplay/chat/chatShell.js.map +1 -0
- package/dist/components/dataDisplay/chat/index.d.ts +46 -0
- package/dist/components/dataDisplay/chat/types.d.ts +53 -0
- package/dist/components/dataDisplay/chat/types.js +19 -0
- package/dist/components/dataDisplay/chat/types.js.map +1 -0
- package/dist/components/dataDisplay/chat/useChatFileUpload.d.ts +35 -0
- package/dist/components/dataDisplay/chat/useChatFileUpload.js +39 -0
- package/dist/components/dataDisplay/chat/useChatFileUpload.js.map +1 -0
- package/dist/components/dataDisplay/chat/useChatInfiniteScroll.d.ts +14 -0
- package/dist/components/dataDisplay/chat/useChatInfiniteScroll.js +20 -0
- package/dist/components/dataDisplay/chat/useChatInfiniteScroll.js.map +1 -0
- package/dist/components/dataDisplay/chat/useChatStickToBottom.d.ts +15 -0
- package/dist/components/dataDisplay/chat/useChatStickToBottom.js +36 -0
- package/dist/components/dataDisplay/chat/useChatStickToBottom.js.map +1 -0
- package/dist/components/dataDisplay/chat/utils.d.ts +26 -0
- package/dist/components/dataDisplay/chat/utils.js +59 -0
- package/dist/components/dataDisplay/chat/utils.js.map +1 -0
- package/dist/components/dataDisplay/chip/chip.d.ts +28 -0
- package/dist/components/dataDisplay/chip/chip.js +125 -0
- package/dist/components/dataDisplay/chip/chip.js.map +1 -0
- package/dist/components/dataDisplay/chip/index.d.ts +2 -0
- package/dist/components/dataDisplay/expansionPanel/expansionPanel.d.ts +42 -0
- package/dist/components/dataDisplay/expansionPanel/expansionPanel.js +174 -0
- package/dist/components/dataDisplay/expansionPanel/expansionPanel.js.map +1 -0
- package/dist/components/dataDisplay/expansionPanel/index.d.ts +2 -0
- package/dist/components/dataDisplay/imagesList/imagesList.d.ts +14 -0
- package/dist/components/dataDisplay/imagesList/imagesList.js +41 -0
- package/dist/components/dataDisplay/imagesList/imagesList.js.map +1 -0
- package/dist/components/dataDisplay/imagesList/imagesList.types.d.ts +6 -0
- package/dist/components/dataDisplay/imagesList/imagesListContext.d.ts +6 -0
- package/dist/components/dataDisplay/imagesList/imagesListContext.js +7 -0
- package/dist/components/dataDisplay/imagesList/imagesListContext.js.map +1 -0
- package/dist/components/dataDisplay/imagesList/imagesListItem/imagesListItem.d.ts +14 -0
- package/dist/components/dataDisplay/imagesList/imagesListItem/imagesListItem.js +61 -0
- package/dist/components/dataDisplay/imagesList/imagesListItem/imagesListItem.js.map +1 -0
- package/dist/components/dataDisplay/imagesList/imagesListItem/imagesListItemModal.d.ts +8 -0
- package/dist/components/dataDisplay/imagesList/imagesListItem/imagesListItemModal.js +46 -0
- package/dist/components/dataDisplay/imagesList/imagesListItem/imagesListItemModal.js.map +1 -0
- package/dist/components/dataDisplay/imagesList/index.d.ts +9 -0
- package/dist/components/dataDisplay/list/index.d.ts +4 -0
- package/dist/components/dataDisplay/list/list.d.ts +11 -0
- package/dist/components/dataDisplay/list/list.js +33 -0
- package/dist/components/dataDisplay/list/list.js.map +1 -0
- package/dist/components/dataDisplay/list/listItem.d.ts +17 -0
- package/dist/components/dataDisplay/list/listItem.js +35 -0
- package/dist/components/dataDisplay/list/listItem.js.map +1 -0
- package/dist/components/dataDisplay/table/index.d.ts +14 -0
- package/dist/components/dataDisplay/table/table.d.ts +16 -0
- package/dist/components/dataDisplay/table/table.js +49 -0
- package/dist/components/dataDisplay/table/table.js.map +1 -0
- package/dist/components/dataDisplay/table/tableBody.d.ts +7 -0
- package/dist/components/dataDisplay/table/tableBody.js +20 -0
- package/dist/components/dataDisplay/table/tableBody.js.map +1 -0
- package/dist/components/dataDisplay/table/tableCell.d.ts +8 -0
- package/dist/components/dataDisplay/table/tableCell.js +25 -0
- package/dist/components/dataDisplay/table/tableCell.js.map +1 -0
- package/dist/components/dataDisplay/table/tableHead.d.ts +7 -0
- package/dist/components/dataDisplay/table/tableHead.js +20 -0
- package/dist/components/dataDisplay/table/tableHead.js.map +1 -0
- package/dist/components/dataDisplay/table/tableHeadCell.d.ts +19 -0
- package/dist/components/dataDisplay/table/tableHeadCell.js +44 -0
- package/dist/components/dataDisplay/table/tableHeadCell.js.map +1 -0
- package/dist/components/dataDisplay/table/tablePagination/tablePagination.d.ts +20 -0
- package/dist/components/dataDisplay/table/tablePagination/tablePagination.js +55 -0
- package/dist/components/dataDisplay/table/tablePagination/tablePagination.js.map +1 -0
- package/dist/components/dataDisplay/table/tableRow.d.ts +11 -0
- package/dist/components/dataDisplay/table/tableRow.js +30 -0
- package/dist/components/dataDisplay/table/tableRow.js.map +1 -0
- package/dist/components/dataDisplay/treeView/index.d.ts +2 -0
- package/dist/components/dataDisplay/treeView/treeView.d.ts +31 -0
- package/dist/components/dataDisplay/treeView/treeView.js +177 -0
- package/dist/components/dataDisplay/treeView/treeView.js.map +1 -0
- package/dist/components/dataDisplay/typography/index.d.ts +2 -0
- package/dist/components/dataDisplay/typography/typography.d.ts +18 -0
- package/dist/components/dataDisplay/typography/typography.js +49 -0
- package/dist/components/dataDisplay/typography/typography.js.map +1 -0
- package/dist/components/feedBack/message/index.d.ts +2 -0
- package/dist/components/feedBack/message/message.d.ts +20 -0
- package/dist/components/feedBack/message/message.js +54 -0
- package/dist/components/feedBack/message/message.js.map +1 -0
- package/dist/components/feedBack/modal/index.d.ts +2 -0
- package/dist/components/feedBack/modal/modal.d.ts +34 -0
- package/dist/components/feedBack/modal/modal.js +117 -0
- package/dist/components/feedBack/modal/modal.js.map +1 -0
- package/dist/components/feedBack/progressIndicator/index.d.ts +2 -0
- package/dist/components/feedBack/progressIndicator/progressIndicator.d.ts +21 -0
- package/dist/components/feedBack/progressIndicator/progressIndicator.js +80 -0
- package/dist/components/feedBack/progressIndicator/progressIndicator.js.map +1 -0
- package/dist/components/feedBack/skeleton/index.d.ts +2 -0
- package/dist/components/feedBack/skeleton/skeleton.d.ts +21 -0
- package/dist/components/feedBack/skeleton/skeleton.js +74 -0
- package/dist/components/feedBack/skeleton/skeleton.js.map +1 -0
- package/dist/components/feedBack/snackbar/index.d.ts +2 -0
- package/dist/components/feedBack/snackbar/snackbar.d.ts +50 -0
- package/dist/components/feedBack/snackbar/snackbar.js +222 -0
- package/dist/components/feedBack/snackbar/snackbar.js.map +1 -0
- package/dist/components/feedBack/snackbar/useSnackbarsPortal.d.ts +6 -0
- package/dist/components/feedBack/snackbar/useSnackbarsPortal.js +15 -0
- package/dist/components/feedBack/snackbar/useSnackbarsPortal.js.map +1 -0
- package/dist/components/feedBack/tooltip/index.d.ts +2 -0
- package/dist/components/feedBack/tooltip/tooltip.d.ts +22 -0
- package/dist/components/feedBack/tooltip/tooltip.js +70 -0
- package/dist/components/feedBack/tooltip/tooltip.js.map +1 -0
- package/dist/components/inputs/button/button.d.ts +32 -0
- package/dist/components/inputs/button/button.js +89 -0
- package/dist/components/inputs/button/button.js.map +1 -0
- package/dist/components/inputs/button/index.d.ts +2 -0
- package/dist/components/inputs/buttonGroups/buttonGroup.d.ts +16 -0
- package/dist/components/inputs/buttonGroups/buttonGroup.js +53 -0
- package/dist/components/inputs/buttonGroups/buttonGroup.js.map +1 -0
- package/dist/components/inputs/buttonGroups/buttonGroupContext.d.ts +15 -0
- package/dist/components/inputs/buttonGroups/buttonGroupContext.js +7 -0
- package/dist/components/inputs/buttonGroups/buttonGroupContext.js.map +1 -0
- package/dist/components/inputs/buttonGroups/index.d.ts +4 -0
- package/dist/components/inputs/checkbox/checkbox.d.ts +26 -0
- package/dist/components/inputs/checkbox/checkbox.js +104 -0
- package/dist/components/inputs/checkbox/checkbox.js.map +1 -0
- package/dist/components/inputs/checkbox/index.d.ts +2 -0
- package/dist/components/inputs/datePicker/dataPickerDays.d.ts +21 -0
- package/dist/components/inputs/datePicker/dataPickerDays.js +67 -0
- package/dist/components/inputs/datePicker/dataPickerDays.js.map +1 -0
- package/dist/components/inputs/datePicker/dataPickerHeader.d.ts +12 -0
- package/dist/components/inputs/datePicker/dataPickerHeader.js +66 -0
- package/dist/components/inputs/datePicker/dataPickerHeader.js.map +1 -0
- package/dist/components/inputs/datePicker/dataPickerInput.d.ts +9 -0
- package/dist/components/inputs/datePicker/dataPickerInput.js +80 -0
- package/dist/components/inputs/datePicker/dataPickerInput.js.map +1 -0
- package/dist/components/inputs/datePicker/dateFormat.d.ts +3 -0
- package/dist/components/inputs/datePicker/dateFormat.js +58 -0
- package/dist/components/inputs/datePicker/dateFormat.js.map +1 -0
- package/dist/components/inputs/datePicker/datePicker.d.ts +40 -0
- package/dist/components/inputs/datePicker/datePicker.js +258 -0
- package/dist/components/inputs/datePicker/datePicker.js.map +1 -0
- package/dist/components/inputs/datePicker/datePickerActionLabel.d.ts +13 -0
- package/dist/components/inputs/datePicker/datePickerActionLabel.js +59 -0
- package/dist/components/inputs/datePicker/datePickerActionLabel.js.map +1 -0
- package/dist/components/inputs/datePicker/datePickerDay.d.ts +13 -0
- package/dist/components/inputs/datePicker/datePickerDay.js +56 -0
- package/dist/components/inputs/datePicker/datePickerDay.js.map +1 -0
- package/dist/components/inputs/datePicker/datePickerIconButton.d.ts +9 -0
- package/dist/components/inputs/datePicker/datePickerIconButton.js +47 -0
- package/dist/components/inputs/datePicker/datePickerIconButton.js.map +1 -0
- package/dist/components/inputs/datePicker/datePickerList.d.ts +12 -0
- package/dist/components/inputs/datePicker/datePickerList.js +64 -0
- package/dist/components/inputs/datePicker/datePickerList.js.map +1 -0
- package/dist/components/inputs/datePicker/dateUtils.d.ts +41 -0
- package/dist/components/inputs/datePicker/dateUtils.js +179 -0
- package/dist/components/inputs/datePicker/dateUtils.js.map +1 -0
- package/dist/components/inputs/datePicker/index.d.ts +19 -0
- package/dist/components/inputs/datePicker/openView.d.ts +5 -0
- package/dist/components/inputs/datePicker/openView.js +5 -0
- package/dist/components/inputs/datePicker/openView.js.map +1 -0
- package/dist/components/inputs/datePicker/useDateInput.d.ts +19 -0
- package/dist/components/inputs/datePicker/useDateInput.js +29 -0
- package/dist/components/inputs/datePicker/useDateInput.js.map +1 -0
- package/dist/components/inputs/dateTimePicker/dateTimeFormat.d.ts +3 -0
- package/dist/components/inputs/dateTimePicker/dateTimeFormat.js +73 -0
- package/dist/components/inputs/dateTimePicker/dateTimeFormat.js.map +1 -0
- package/dist/components/inputs/dateTimePicker/dateTimePicker.d.ts +30 -0
- package/dist/components/inputs/dateTimePicker/dateTimePicker.js +198 -0
- package/dist/components/inputs/dateTimePicker/dateTimePicker.js.map +1 -0
- package/dist/components/inputs/dateTimePicker/dateTimePickerInput.d.ts +9 -0
- package/dist/components/inputs/dateTimePicker/dateTimePickerInput.js +80 -0
- package/dist/components/inputs/dateTimePicker/dateTimePickerInput.js.map +1 -0
- package/dist/components/inputs/dateTimePicker/index.d.ts +7 -0
- package/dist/components/inputs/dateTimePicker/useDateTimeInput.d.ts +21 -0
- package/dist/components/inputs/dateTimePicker/useDateTimeInput.js +53 -0
- package/dist/components/inputs/dateTimePicker/useDateTimeInput.js.map +1 -0
- package/dist/components/inputs/fileDrop/countPreview.d.ts +9 -0
- package/dist/components/inputs/fileDrop/countPreview.js +24 -0
- package/dist/components/inputs/fileDrop/countPreview.js.map +1 -0
- package/dist/components/inputs/fileDrop/fileDrop.d.ts +18 -0
- package/dist/components/inputs/fileDrop/fileDrop.js +84 -0
- package/dist/components/inputs/fileDrop/fileDrop.js.map +1 -0
- package/dist/components/inputs/fileDrop/index.d.ts +9 -0
- package/dist/components/inputs/fileDrop/preview.d.ts +10 -0
- package/dist/components/inputs/fileDrop/preview.js +70 -0
- package/dist/components/inputs/fileDrop/preview.js.map +1 -0
- package/dist/components/inputs/fileDrop/previewWrapper.d.ts +11 -0
- package/dist/components/inputs/fileDrop/previewWrapper.js +47 -0
- package/dist/components/inputs/fileDrop/previewWrapper.js.map +1 -0
- package/dist/components/inputs/fileDrop/utils.d.ts +1 -0
- package/dist/components/inputs/fileDrop/utils.js +7 -0
- package/dist/components/inputs/fileDrop/utils.js.map +1 -0
- package/dist/components/inputs/fileInput/fileInput.d.ts +20 -0
- package/dist/components/inputs/fileInput/fileInput.js +47 -0
- package/dist/components/inputs/fileInput/fileInput.js.map +1 -0
- package/dist/components/inputs/fileInput/index.d.ts +2 -0
- package/dist/components/inputs/floatingButton/floatingButton.d.ts +12 -0
- package/dist/components/inputs/floatingButton/floatingButton.js +34 -0
- package/dist/components/inputs/floatingButton/floatingButton.js.map +1 -0
- package/dist/components/inputs/floatingButton/index.d.ts +2 -0
- package/dist/components/inputs/radioButton/index.d.ts +2 -0
- package/dist/components/inputs/radioButton/radioButton.d.ts +21 -0
- package/dist/components/inputs/radioButton/radioButton.js +89 -0
- package/dist/components/inputs/radioButton/radioButton.js.map +1 -0
- package/dist/components/inputs/rating/index.d.ts +2 -0
- package/dist/components/inputs/rating/rating.d.ts +33 -0
- package/dist/components/inputs/rating/rating.js +108 -0
- package/dist/components/inputs/rating/rating.js.map +1 -0
- package/dist/components/inputs/selectField/dropdownMenu.d.ts +43 -0
- package/dist/components/inputs/selectField/dropdownMenu.js +202 -0
- package/dist/components/inputs/selectField/dropdownMenu.js.map +1 -0
- package/dist/components/inputs/selectField/index.d.ts +4 -0
- package/dist/components/inputs/selectField/selectField.d.ts +53 -0
- package/dist/components/inputs/selectField/selectField.js +249 -0
- package/dist/components/inputs/selectField/selectField.js.map +1 -0
- package/dist/components/inputs/slider/index.d.ts +2 -0
- package/dist/components/inputs/slider/slider.d.ts +34 -0
- package/dist/components/inputs/slider/slider.js +358 -0
- package/dist/components/inputs/slider/slider.js.map +1 -0
- package/dist/components/inputs/slider/utils.d.ts +10 -0
- package/dist/components/inputs/slider/utils.js +40 -0
- package/dist/components/inputs/slider/utils.js.map +1 -0
- package/dist/components/inputs/textField/index.d.ts +7 -0
- package/dist/components/inputs/textField/textField.d.ts +35 -0
- package/dist/components/inputs/textField/textField.js +143 -0
- package/dist/components/inputs/textField/textField.js.map +1 -0
- package/dist/components/inputs/textField/textFieldAdornment.d.ts +12 -0
- package/dist/components/inputs/textField/textFieldAdornment.js +15 -0
- package/dist/components/inputs/textField/textFieldAdornment.js.map +1 -0
- package/dist/components/inputs/textField/textFieldWrapper.d.ts +21 -0
- package/dist/components/inputs/textField/textFieldWrapper.js +105 -0
- package/dist/components/inputs/textField/textFieldWrapper.js.map +1 -0
- package/dist/components/inputs/textField/types.d.ts +1 -0
- package/dist/components/inputs/textField/utils.d.ts +5 -0
- package/dist/components/inputs/textField/utils.js +11 -0
- package/dist/components/inputs/textField/utils.js.map +1 -0
- package/dist/components/inputs/timePicker/index.d.ts +9 -0
- package/dist/components/inputs/timePicker/timeFormat.d.ts +4 -0
- package/dist/components/inputs/timePicker/timeFormat.js +58 -0
- package/dist/components/inputs/timePicker/timeFormat.js.map +1 -0
- package/dist/components/inputs/timePicker/timePicker.d.ts +19 -0
- package/dist/components/inputs/timePicker/timePicker.js +109 -0
- package/dist/components/inputs/timePicker/timePicker.js.map +1 -0
- package/dist/components/inputs/timePicker/timePickerColumns.d.ts +9 -0
- package/dist/components/inputs/timePicker/timePickerColumns.js +49 -0
- package/dist/components/inputs/timePicker/timePickerColumns.js.map +1 -0
- package/dist/components/inputs/timePicker/timePickerInput.d.ts +9 -0
- package/dist/components/inputs/timePicker/timePickerInput.js +80 -0
- package/dist/components/inputs/timePicker/timePickerInput.js.map +1 -0
- package/dist/components/inputs/timePicker/timePickerList.d.ts +12 -0
- package/dist/components/inputs/timePicker/timePickerList.js +33 -0
- package/dist/components/inputs/timePicker/timePickerList.js.map +1 -0
- package/dist/components/inputs/timePicker/timeUtils.d.ts +23 -0
- package/dist/components/inputs/timePicker/timeUtils.js +82 -0
- package/dist/components/inputs/timePicker/timeUtils.js.map +1 -0
- package/dist/components/inputs/timePicker/useTimeInput.d.ts +19 -0
- package/dist/components/inputs/timePicker/useTimeInput.js +29 -0
- package/dist/components/inputs/timePicker/useTimeInput.js.map +1 -0
- package/dist/components/inputs/toggle/index.d.ts +2 -0
- package/dist/components/inputs/toggle/toggle.d.ts +21 -0
- package/dist/components/inputs/toggle/toggle.js +83 -0
- package/dist/components/inputs/toggle/toggle.js.map +1 -0
- package/dist/components/layout/appLayout/appLayout.d.ts +31 -0
- package/dist/components/layout/appLayout/appLayout.js +103 -0
- package/dist/components/layout/appLayout/appLayout.js.map +1 -0
- package/dist/components/layout/appLayout/index.d.ts +2 -0
- package/dist/components/layout/divider/divider.d.ts +20 -0
- package/dist/components/layout/divider/divider.js +68 -0
- package/dist/components/layout/divider/divider.js.map +1 -0
- package/dist/components/layout/divider/index.d.ts +2 -0
- package/dist/components/layout/grid/grid.d.ts +52 -0
- package/dist/components/layout/grid/grid.js +93 -0
- package/dist/components/layout/grid/grid.js.map +1 -0
- package/dist/components/layout/grid/index.d.ts +2 -0
- package/dist/components/layout/page/index.d.ts +2 -0
- package/dist/components/layout/page/page.d.ts +14 -0
- package/dist/components/layout/page/page.js +36 -0
- package/dist/components/layout/page/page.js.map +1 -0
- package/dist/components/layout/pageHeader/index.d.ts +2 -0
- package/dist/components/layout/pageHeader/pageHeader.d.ts +15 -0
- package/dist/components/layout/pageHeader/pageHeader.js +77 -0
- package/dist/components/layout/pageHeader/pageHeader.js.map +1 -0
- package/dist/components/layout/screenDivider/index.d.ts +2 -0
- package/dist/components/layout/screenDivider/screenDivider.d.ts +17 -0
- package/dist/components/layout/screenDivider/screenDivider.js +80 -0
- package/dist/components/layout/screenDivider/screenDivider.js.map +1 -0
- package/dist/components/layout/sheet/index.d.ts +2 -0
- package/dist/components/layout/sheet/sheet.d.ts +32 -0
- package/dist/components/layout/sheet/sheet.js +261 -0
- package/dist/components/layout/sheet/sheet.js.map +1 -0
- package/dist/components/layout/stack/index.d.ts +2 -0
- package/dist/components/layout/stack/stack.d.ts +16 -0
- package/dist/components/layout/stack/stack.js +60 -0
- package/dist/components/layout/stack/stack.js.map +1 -0
- package/dist/components/navigation/appBar/appBar.d.ts +18 -0
- package/dist/components/navigation/appBar/appBar.js +58 -0
- package/dist/components/navigation/appBar/appBar.js.map +1 -0
- package/dist/components/navigation/appBar/index.d.ts +2 -0
- package/dist/components/navigation/bottomBar/bottomBar.d.ts +15 -0
- package/dist/components/navigation/bottomBar/bottomBar.js +197 -0
- package/dist/components/navigation/bottomBar/bottomBar.js.map +1 -0
- package/dist/components/navigation/bottomBar/index.d.ts +2 -0
- package/dist/components/navigation/breadcrumbs/breadcrumbs.d.ts +21 -0
- package/dist/components/navigation/breadcrumbs/breadcrumbs.js +57 -0
- package/dist/components/navigation/breadcrumbs/breadcrumbs.js.map +1 -0
- package/dist/components/navigation/breadcrumbs/index.d.ts +2 -0
- package/dist/components/navigation/menu/index.d.ts +18 -0
- package/dist/components/navigation/menu/menu.d.ts +8 -0
- package/dist/components/navigation/menu/menu.js +38 -0
- package/dist/components/navigation/menu/menu.js.map +1 -0
- package/dist/components/navigation/menu/menuComponent.d.ts +4 -0
- package/dist/components/navigation/menu/menuComponent.js +34 -0
- package/dist/components/navigation/menu/menuComponent.js.map +1 -0
- package/dist/components/navigation/menu/menuContext.d.ts +7 -0
- package/dist/components/navigation/menu/menuContext.js +15 -0
- package/dist/components/navigation/menu/menuContext.js.map +1 -0
- package/dist/components/navigation/menu/menuDivider.d.ts +7 -0
- package/dist/components/navigation/menu/menuDivider.js +21 -0
- package/dist/components/navigation/menu/menuDivider.js.map +1 -0
- package/dist/components/navigation/menu/menuFloating.d.ts +15 -0
- package/dist/components/navigation/menu/menuFloating.js +70 -0
- package/dist/components/navigation/menu/menuFloating.js.map +1 -0
- package/dist/components/navigation/menu/menuItem.d.ts +15 -0
- package/dist/components/navigation/menu/menuItem.js +81 -0
- package/dist/components/navigation/menu/menuItem.js.map +1 -0
- package/dist/components/navigation/menu/menuItemIcon.d.ts +8 -0
- package/dist/components/navigation/menu/menuItemIcon.js +25 -0
- package/dist/components/navigation/menu/menuItemIcon.js.map +1 -0
- package/dist/components/navigation/menu/menuItemText.d.ts +8 -0
- package/dist/components/navigation/menu/menuItemText.js +26 -0
- package/dist/components/navigation/menu/menuItemText.js.map +1 -0
- package/dist/components/navigation/menu/menuList.d.ts +7 -0
- package/dist/components/navigation/menu/menuList.js +27 -0
- package/dist/components/navigation/menu/menuList.js.map +1 -0
- package/dist/components/navigation/menu/menuSubmenu.d.ts +21 -0
- package/dist/components/navigation/menu/menuSubmenu.js +85 -0
- package/dist/components/navigation/menu/menuSubmenu.js.map +1 -0
- package/dist/components/navigation/pagination/index.d.ts +2 -0
- package/dist/components/navigation/pagination/pagination.d.ts +28 -0
- package/dist/components/navigation/pagination/pagination.js +90 -0
- package/dist/components/navigation/pagination/pagination.js.map +1 -0
- package/dist/components/navigation/sidebar/index.d.ts +2 -0
- package/dist/components/navigation/sidebar/sidebar.d.ts +35 -0
- package/dist/components/navigation/sidebar/sidebar.js +134 -0
- package/dist/components/navigation/sidebar/sidebar.js.map +1 -0
- package/dist/components/navigation/stepper/index.d.ts +2 -0
- package/dist/components/navigation/stepper/stepper.d.ts +26 -0
- package/dist/components/navigation/stepper/stepper.js +96 -0
- package/dist/components/navigation/stepper/stepper.js.map +1 -0
- package/dist/components/navigation/tabs/index.d.ts +6 -0
- package/dist/components/navigation/tabs/tab/tab.d.ts +14 -0
- package/dist/components/navigation/tabs/tab/tab.js +86 -0
- package/dist/components/navigation/tabs/tab/tab.js.map +1 -0
- package/dist/components/navigation/tabs/tabs.d.ts +20 -0
- package/dist/components/navigation/tabs/tabs.js +135 -0
- package/dist/components/navigation/tabs/tabs.js.map +1 -0
- package/dist/components/navigation/tabs/tabsContext.d.ts +14 -0
- package/dist/components/navigation/tabs/tabsContext.js +7 -0
- package/dist/components/navigation/tabs/tabsContext.js.map +1 -0
- package/dist/headless/components/base/animateHeight/animateHeight.js +113 -0
- package/dist/headless/components/base/animateHeight/animateHeight.js.map +1 -0
- package/dist/headless/components/base/icon/icon.js +46 -0
- package/dist/headless/components/base/icon/icon.js.map +1 -0
- package/dist/headless/components/base/ripple/ripple.js +57 -0
- package/dist/headless/components/base/ripple/ripple.js.map +1 -0
- package/dist/headless/components/clickAwayListener/clickAwayListener.js +61 -0
- package/dist/headless/components/clickAwayListener/clickAwayListener.js.map +1 -0
- package/dist/headless/components/dataDisplay/accordion/accordion.js +82 -0
- package/dist/headless/components/dataDisplay/accordion/accordion.js.map +1 -0
- package/dist/headless/components/dataDisplay/avatar/avatar.js +104 -0
- package/dist/headless/components/dataDisplay/avatar/avatar.js.map +1 -0
- package/dist/headless/components/dataDisplay/badge/badge.js +40 -0
- package/dist/headless/components/dataDisplay/badge/badge.js.map +1 -0
- package/dist/headless/components/dataDisplay/card/card.js +58 -0
- package/dist/headless/components/dataDisplay/card/card.js.map +1 -0
- package/dist/headless/components/dataDisplay/carousel/carousel.js +175 -0
- package/dist/headless/components/dataDisplay/carousel/carousel.js.map +1 -0
- package/dist/headless/components/dataDisplay/carousel/utils.js +52 -0
- package/dist/headless/components/dataDisplay/carousel/utils.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/chat.js +221 -0
- package/dist/headless/components/dataDisplay/chat/chat.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/chatAttachmentImage.js +63 -0
- package/dist/headless/components/dataDisplay/chat/chatAttachmentImage.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/chatAttachments.js +48 -0
- package/dist/headless/components/dataDisplay/chat/chatAttachments.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/chatComposer.js +208 -0
- package/dist/headless/components/dataDisplay/chat/chatComposer.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/chatHeader.js +89 -0
- package/dist/headless/components/dataDisplay/chat/chatHeader.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/chatIconButton.js +42 -0
- package/dist/headless/components/dataDisplay/chat/chatIconButton.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/chatLayout.js +147 -0
- package/dist/headless/components/dataDisplay/chat/chatLayout.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/chatMessageAvatar.js +32 -0
- package/dist/headless/components/dataDisplay/chat/chatMessageAvatar.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/chatMessageBubble.js +122 -0
- package/dist/headless/components/dataDisplay/chat/chatMessageBubble.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/chatMessageIncoming.js +36 -0
- package/dist/headless/components/dataDisplay/chat/chatMessageIncoming.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/chatMessageItem.js +103 -0
- package/dist/headless/components/dataDisplay/chat/chatMessageItem.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/chatMessageOutgoing.js +48 -0
- package/dist/headless/components/dataDisplay/chat/chatMessageOutgoing.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/chatMessageSkeleton.js +59 -0
- package/dist/headless/components/dataDisplay/chat/chatMessageSkeleton.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/chatMessageStatus.js +51 -0
- package/dist/headless/components/dataDisplay/chat/chatMessageStatus.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/chatMessageSystem.js +26 -0
- package/dist/headless/components/dataDisplay/chat/chatMessageSystem.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/chatMessages.js +90 -0
- package/dist/headless/components/dataDisplay/chat/chatMessages.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/chatOverlayLayout.js +52 -0
- package/dist/headless/components/dataDisplay/chat/chatOverlayLayout.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/chatShell.js +82 -0
- package/dist/headless/components/dataDisplay/chat/chatShell.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/types.js +19 -0
- package/dist/headless/components/dataDisplay/chat/types.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/useChatFileUpload.js +39 -0
- package/dist/headless/components/dataDisplay/chat/useChatFileUpload.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/useChatInfiniteScroll.js +20 -0
- package/dist/headless/components/dataDisplay/chat/useChatInfiniteScroll.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/useChatStickToBottom.js +36 -0
- package/dist/headless/components/dataDisplay/chat/useChatStickToBottom.js.map +1 -0
- package/dist/headless/components/dataDisplay/chat/utils.js +59 -0
- package/dist/headless/components/dataDisplay/chat/utils.js.map +1 -0
- package/dist/headless/components/dataDisplay/chip/chip.js +124 -0
- package/dist/headless/components/dataDisplay/chip/chip.js.map +1 -0
- package/dist/headless/components/dataDisplay/expansionPanel/expansionPanel.js +173 -0
- package/dist/headless/components/dataDisplay/expansionPanel/expansionPanel.js.map +1 -0
- package/dist/headless/components/dataDisplay/imagesList/imagesList.js +40 -0
- package/dist/headless/components/dataDisplay/imagesList/imagesList.js.map +1 -0
- package/dist/headless/components/dataDisplay/imagesList/imagesListContext.js +7 -0
- package/dist/headless/components/dataDisplay/imagesList/imagesListContext.js.map +1 -0
- package/dist/headless/components/dataDisplay/imagesList/imagesListItem/imagesListItem.js +60 -0
- package/dist/headless/components/dataDisplay/imagesList/imagesListItem/imagesListItem.js.map +1 -0
- package/dist/headless/components/dataDisplay/imagesList/imagesListItem/imagesListItemModal.js +46 -0
- package/dist/headless/components/dataDisplay/imagesList/imagesListItem/imagesListItemModal.js.map +1 -0
- package/dist/headless/components/dataDisplay/list/list.js +32 -0
- package/dist/headless/components/dataDisplay/list/list.js.map +1 -0
- package/dist/headless/components/dataDisplay/list/listItem.js +35 -0
- package/dist/headless/components/dataDisplay/list/listItem.js.map +1 -0
- package/dist/headless/components/dataDisplay/table/table.js +48 -0
- package/dist/headless/components/dataDisplay/table/table.js.map +1 -0
- package/dist/headless/components/dataDisplay/table/tableBody.js +20 -0
- package/dist/headless/components/dataDisplay/table/tableBody.js.map +1 -0
- package/dist/headless/components/dataDisplay/table/tableCell.js +25 -0
- package/dist/headless/components/dataDisplay/table/tableCell.js.map +1 -0
- package/dist/headless/components/dataDisplay/table/tableHead.js +20 -0
- package/dist/headless/components/dataDisplay/table/tableHead.js.map +1 -0
- package/dist/headless/components/dataDisplay/table/tableHeadCell.js +44 -0
- package/dist/headless/components/dataDisplay/table/tableHeadCell.js.map +1 -0
- package/dist/headless/components/dataDisplay/table/tablePagination/tablePagination.js +54 -0
- package/dist/headless/components/dataDisplay/table/tablePagination/tablePagination.js.map +1 -0
- package/dist/headless/components/dataDisplay/table/tableRow.js +30 -0
- package/dist/headless/components/dataDisplay/table/tableRow.js.map +1 -0
- package/dist/headless/components/dataDisplay/treeView/treeView.js +176 -0
- package/dist/headless/components/dataDisplay/treeView/treeView.js.map +1 -0
- package/dist/headless/components/dataDisplay/typography/typography.js +48 -0
- package/dist/headless/components/dataDisplay/typography/typography.js.map +1 -0
- package/dist/headless/components/feedBack/message/message.js +53 -0
- package/dist/headless/components/feedBack/message/message.js.map +1 -0
- package/dist/headless/components/feedBack/modal/modal.js +116 -0
- package/dist/headless/components/feedBack/modal/modal.js.map +1 -0
- package/dist/headless/components/feedBack/progressIndicator/progressIndicator.js +79 -0
- package/dist/headless/components/feedBack/progressIndicator/progressIndicator.js.map +1 -0
- package/dist/headless/components/feedBack/skeleton/skeleton.js +73 -0
- package/dist/headless/components/feedBack/skeleton/skeleton.js.map +1 -0
- package/dist/headless/components/feedBack/snackbar/snackbar.js +221 -0
- package/dist/headless/components/feedBack/snackbar/snackbar.js.map +1 -0
- package/dist/headless/components/feedBack/snackbar/useSnackbarsPortal.js +15 -0
- package/dist/headless/components/feedBack/snackbar/useSnackbarsPortal.js.map +1 -0
- package/dist/headless/components/feedBack/tooltip/tooltip.js +69 -0
- package/dist/headless/components/feedBack/tooltip/tooltip.js.map +1 -0
- package/dist/headless/components/inputs/button/button.js +88 -0
- package/dist/headless/components/inputs/button/button.js.map +1 -0
- package/dist/headless/components/inputs/buttonGroups/buttonGroup.js +52 -0
- package/dist/headless/components/inputs/buttonGroups/buttonGroup.js.map +1 -0
- package/dist/headless/components/inputs/buttonGroups/buttonGroupContext.js +7 -0
- package/dist/headless/components/inputs/buttonGroups/buttonGroupContext.js.map +1 -0
- package/dist/headless/components/inputs/checkbox/checkbox.js +103 -0
- package/dist/headless/components/inputs/checkbox/checkbox.js.map +1 -0
- package/dist/headless/components/inputs/datePicker/dataPickerDays.js +67 -0
- package/dist/headless/components/inputs/datePicker/dataPickerDays.js.map +1 -0
- package/dist/headless/components/inputs/datePicker/dataPickerHeader.js +66 -0
- package/dist/headless/components/inputs/datePicker/dataPickerHeader.js.map +1 -0
- package/dist/headless/components/inputs/datePicker/dataPickerInput.js +80 -0
- package/dist/headless/components/inputs/datePicker/dataPickerInput.js.map +1 -0
- package/dist/headless/components/inputs/datePicker/dateFormat.js +58 -0
- package/dist/headless/components/inputs/datePicker/dateFormat.js.map +1 -0
- package/dist/headless/components/inputs/datePicker/datePicker.js +257 -0
- package/dist/headless/components/inputs/datePicker/datePicker.js.map +1 -0
- package/dist/headless/components/inputs/datePicker/datePickerActionLabel.js +59 -0
- package/dist/headless/components/inputs/datePicker/datePickerActionLabel.js.map +1 -0
- package/dist/headless/components/inputs/datePicker/datePickerDay.js +56 -0
- package/dist/headless/components/inputs/datePicker/datePickerDay.js.map +1 -0
- package/dist/headless/components/inputs/datePicker/datePickerIconButton.js +47 -0
- package/dist/headless/components/inputs/datePicker/datePickerIconButton.js.map +1 -0
- package/dist/headless/components/inputs/datePicker/datePickerList.js +64 -0
- package/dist/headless/components/inputs/datePicker/datePickerList.js.map +1 -0
- package/dist/headless/components/inputs/datePicker/dateUtils.js +179 -0
- package/dist/headless/components/inputs/datePicker/dateUtils.js.map +1 -0
- package/dist/headless/components/inputs/datePicker/openView.js +5 -0
- package/dist/headless/components/inputs/datePicker/openView.js.map +1 -0
- package/dist/headless/components/inputs/datePicker/useDateInput.js +29 -0
- package/dist/headless/components/inputs/datePicker/useDateInput.js.map +1 -0
- package/dist/headless/components/inputs/dateTimePicker/dateTimeFormat.js +73 -0
- package/dist/headless/components/inputs/dateTimePicker/dateTimeFormat.js.map +1 -0
- package/dist/headless/components/inputs/dateTimePicker/dateTimePicker.js +198 -0
- package/dist/headless/components/inputs/dateTimePicker/dateTimePicker.js.map +1 -0
- package/dist/headless/components/inputs/dateTimePicker/dateTimePickerInput.js +80 -0
- package/dist/headless/components/inputs/dateTimePicker/dateTimePickerInput.js.map +1 -0
- package/dist/headless/components/inputs/dateTimePicker/useDateTimeInput.js +53 -0
- package/dist/headless/components/inputs/dateTimePicker/useDateTimeInput.js.map +1 -0
- package/dist/headless/components/inputs/fileDrop/countPreview.js +24 -0
- package/dist/headless/components/inputs/fileDrop/countPreview.js.map +1 -0
- package/dist/headless/components/inputs/fileDrop/fileDrop.js +83 -0
- package/dist/headless/components/inputs/fileDrop/fileDrop.js.map +1 -0
- package/dist/headless/components/inputs/fileDrop/preview.js +70 -0
- package/dist/headless/components/inputs/fileDrop/preview.js.map +1 -0
- package/dist/headless/components/inputs/fileDrop/previewWrapper.js +47 -0
- package/dist/headless/components/inputs/fileDrop/previewWrapper.js.map +1 -0
- package/dist/headless/components/inputs/fileDrop/utils.js +7 -0
- package/dist/headless/components/inputs/fileDrop/utils.js.map +1 -0
- package/dist/headless/components/inputs/fileInput/fileInput.js +46 -0
- package/dist/headless/components/inputs/fileInput/fileInput.js.map +1 -0
- package/dist/headless/components/inputs/floatingButton/floatingButton.js +33 -0
- package/dist/headless/components/inputs/floatingButton/floatingButton.js.map +1 -0
- package/dist/headless/components/inputs/radioButton/radioButton.js +88 -0
- package/dist/headless/components/inputs/radioButton/radioButton.js.map +1 -0
- package/dist/headless/components/inputs/rating/rating.js +107 -0
- package/dist/headless/components/inputs/rating/rating.js.map +1 -0
- package/dist/headless/components/inputs/selectField/dropdownMenu.js +202 -0
- package/dist/headless/components/inputs/selectField/dropdownMenu.js.map +1 -0
- package/dist/headless/components/inputs/selectField/selectField.js +248 -0
- package/dist/headless/components/inputs/selectField/selectField.js.map +1 -0
- package/dist/headless/components/inputs/slider/slider.js +357 -0
- package/dist/headless/components/inputs/slider/slider.js.map +1 -0
- package/dist/headless/components/inputs/slider/utils.js +40 -0
- package/dist/headless/components/inputs/slider/utils.js.map +1 -0
- package/dist/headless/components/inputs/textField/textField.js +142 -0
- package/dist/headless/components/inputs/textField/textField.js.map +1 -0
- package/dist/headless/components/inputs/textField/textFieldAdornment.js +15 -0
- package/dist/headless/components/inputs/textField/textFieldAdornment.js.map +1 -0
- package/dist/headless/components/inputs/textField/textFieldWrapper.js +105 -0
- package/dist/headless/components/inputs/textField/textFieldWrapper.js.map +1 -0
- package/dist/headless/components/inputs/textField/utils.js +11 -0
- package/dist/headless/components/inputs/textField/utils.js.map +1 -0
- package/dist/headless/components/inputs/timePicker/timeFormat.js +58 -0
- package/dist/headless/components/inputs/timePicker/timeFormat.js.map +1 -0
- package/dist/headless/components/inputs/timePicker/timePicker.js +108 -0
- package/dist/headless/components/inputs/timePicker/timePicker.js.map +1 -0
- package/dist/headless/components/inputs/timePicker/timePickerColumns.js +49 -0
- package/dist/headless/components/inputs/timePicker/timePickerColumns.js.map +1 -0
- package/dist/headless/components/inputs/timePicker/timePickerInput.js +80 -0
- package/dist/headless/components/inputs/timePicker/timePickerInput.js.map +1 -0
- package/dist/headless/components/inputs/timePicker/timePickerList.js +33 -0
- package/dist/headless/components/inputs/timePicker/timePickerList.js.map +1 -0
- package/dist/headless/components/inputs/timePicker/timeUtils.js +82 -0
- package/dist/headless/components/inputs/timePicker/timeUtils.js.map +1 -0
- package/dist/headless/components/inputs/timePicker/useTimeInput.js +29 -0
- package/dist/headless/components/inputs/timePicker/useTimeInput.js.map +1 -0
- package/dist/headless/components/inputs/toggle/toggle.js +82 -0
- package/dist/headless/components/inputs/toggle/toggle.js.map +1 -0
- package/dist/headless/components/layout/appLayout/appLayout.js +102 -0
- package/dist/headless/components/layout/appLayout/appLayout.js.map +1 -0
- package/dist/headless/components/layout/divider/divider.js +67 -0
- package/dist/headless/components/layout/divider/divider.js.map +1 -0
- package/dist/headless/components/layout/grid/grid.js +92 -0
- package/dist/headless/components/layout/grid/grid.js.map +1 -0
- package/dist/headless/components/layout/page/page.js +35 -0
- package/dist/headless/components/layout/page/page.js.map +1 -0
- package/dist/headless/components/layout/pageHeader/pageHeader.js +76 -0
- package/dist/headless/components/layout/pageHeader/pageHeader.js.map +1 -0
- package/dist/headless/components/layout/screenDivider/screenDivider.js +79 -0
- package/dist/headless/components/layout/screenDivider/screenDivider.js.map +1 -0
- package/dist/headless/components/layout/sheet/sheet.js +260 -0
- package/dist/headless/components/layout/sheet/sheet.js.map +1 -0
- package/dist/headless/components/layout/stack/stack.js +59 -0
- package/dist/headless/components/layout/stack/stack.js.map +1 -0
- package/dist/headless/components/navigation/appBar/appBar.js +57 -0
- package/dist/headless/components/navigation/appBar/appBar.js.map +1 -0
- package/dist/headless/components/navigation/bottomBar/bottomBar.js +196 -0
- package/dist/headless/components/navigation/bottomBar/bottomBar.js.map +1 -0
- package/dist/headless/components/navigation/breadcrumbs/breadcrumbs.js +56 -0
- package/dist/headless/components/navigation/breadcrumbs/breadcrumbs.js.map +1 -0
- package/dist/headless/components/navigation/menu/menu.js +37 -0
- package/dist/headless/components/navigation/menu/menu.js.map +1 -0
- package/dist/headless/components/navigation/menu/menuComponent.js +34 -0
- package/dist/headless/components/navigation/menu/menuComponent.js.map +1 -0
- package/dist/headless/components/navigation/menu/menuContext.js +15 -0
- package/dist/headless/components/navigation/menu/menuContext.js.map +1 -0
- package/dist/headless/components/navigation/menu/menuDivider.js +21 -0
- package/dist/headless/components/navigation/menu/menuDivider.js.map +1 -0
- package/dist/headless/components/navigation/menu/menuFloating.js +70 -0
- package/dist/headless/components/navigation/menu/menuFloating.js.map +1 -0
- package/dist/headless/components/navigation/menu/menuItem.js +81 -0
- package/dist/headless/components/navigation/menu/menuItem.js.map +1 -0
- package/dist/headless/components/navigation/menu/menuItemIcon.js +25 -0
- package/dist/headless/components/navigation/menu/menuItemIcon.js.map +1 -0
- package/dist/headless/components/navigation/menu/menuItemText.js +26 -0
- package/dist/headless/components/navigation/menu/menuItemText.js.map +1 -0
- package/dist/headless/components/navigation/menu/menuList.js +27 -0
- package/dist/headless/components/navigation/menu/menuList.js.map +1 -0
- package/dist/headless/components/navigation/menu/menuSubmenu.js +85 -0
- package/dist/headless/components/navigation/menu/menuSubmenu.js.map +1 -0
- package/dist/headless/components/navigation/pagination/pagination.js +89 -0
- package/dist/headless/components/navigation/pagination/pagination.js.map +1 -0
- package/dist/headless/components/navigation/sidebar/sidebar.js +133 -0
- package/dist/headless/components/navigation/sidebar/sidebar.js.map +1 -0
- package/dist/headless/components/navigation/stepper/stepper.js +95 -0
- package/dist/headless/components/navigation/stepper/stepper.js.map +1 -0
- package/dist/headless/components/navigation/tabs/tab/tab.js +85 -0
- package/dist/headless/components/navigation/tabs/tab/tab.js.map +1 -0
- package/dist/headless/components/navigation/tabs/tabs.js +134 -0
- package/dist/headless/components/navigation/tabs/tabs.js.map +1 -0
- package/dist/headless/components/navigation/tabs/tabsContext.js +7 -0
- package/dist/headless/components/navigation/tabs/tabsContext.js.map +1 -0
- package/dist/headless/index.js +294 -0
- package/dist/headless/index.js.map +1 -0
- package/dist/headless/primitives/callHandler.js +7 -0
- package/dist/headless/primitives/callHandler.js.map +1 -0
- package/dist/headless/primitives/createControllableState.js +12 -0
- package/dist/headless/primitives/createControllableState.js.map +1 -0
- package/dist/headless/primitives/createCssTransition.js +40 -0
- package/dist/headless/primitives/createCssTransition.js.map +1 -0
- package/dist/headless/primitives/createDropzone.js +36 -0
- package/dist/headless/primitives/createDropzone.js.map +1 -0
- package/dist/headless/primitives/createFloating.js +31 -0
- package/dist/headless/primitives/createFloating.js.map +1 -0
- package/dist/headless/primitives/createFocusTrap.js +31 -0
- package/dist/headless/primitives/createFocusTrap.js.map +1 -0
- package/dist/headless/primitives/createId.js +9 -0
- package/dist/headless/primitives/createId.js.map +1 -0
- package/dist/headless/primitives/createMaskedInput.js +27 -0
- package/dist/headless/primitives/createMaskedInput.js.map +1 -0
- package/dist/headless/primitives/createTheme.js +38 -0
- package/dist/headless/primitives/createTheme.js.map +1 -0
- package/dist/headless/primitives/createVirtualList.js +11 -0
- package/dist/headless/primitives/createVirtualList.js.map +1 -0
- package/dist/headless/primitives/mergeRefs.js +10 -0
- package/dist/headless/primitives/mergeRefs.js.map +1 -0
- package/dist/headless/utils/animate.js +28 -0
- package/dist/headless/utils/animate.js.map +1 -0
- package/dist/headless/utils/debounce.js +15 -0
- package/dist/headless/utils/debounce.js.map +1 -0
- package/dist/headless/utils/floating.js +31 -0
- package/dist/headless/utils/floating.js.map +1 -0
- package/dist/headless/utils/throttle.js +18 -0
- package/dist/headless/utils/throttle.js.map +1 -0
- package/dist/index.d.ts +128 -0
- package/dist/index.js +294 -0
- package/dist/index.js.map +1 -0
- package/dist/primitives/callHandler.d.ts +10 -0
- package/dist/primitives/callHandler.js +7 -0
- package/dist/primitives/callHandler.js.map +1 -0
- package/dist/primitives/createControllableState.d.ts +19 -0
- package/dist/primitives/createControllableState.js +12 -0
- package/dist/primitives/createControllableState.js.map +1 -0
- package/dist/primitives/createCssTransition.d.ts +36 -0
- package/dist/primitives/createCssTransition.js +40 -0
- package/dist/primitives/createCssTransition.js.map +1 -0
- package/dist/primitives/createDropzone.d.ts +40 -0
- package/dist/primitives/createDropzone.js +36 -0
- package/dist/primitives/createDropzone.js.map +1 -0
- package/dist/primitives/createFloating.d.ts +28 -0
- package/dist/primitives/createFloating.js +31 -0
- package/dist/primitives/createFloating.js.map +1 -0
- package/dist/primitives/createFocusTrap.d.ts +17 -0
- package/dist/primitives/createFocusTrap.js +31 -0
- package/dist/primitives/createFocusTrap.js.map +1 -0
- package/dist/primitives/createId.d.ts +12 -0
- package/dist/primitives/createId.js +9 -0
- package/dist/primitives/createId.js.map +1 -0
- package/dist/primitives/createMaskedInput.d.ts +23 -0
- package/dist/primitives/createMaskedInput.js +27 -0
- package/dist/primitives/createMaskedInput.js.map +1 -0
- package/dist/primitives/createTheme.d.ts +10 -0
- package/dist/primitives/createTheme.js +38 -0
- package/dist/primitives/createTheme.js.map +1 -0
- package/dist/primitives/createVirtualList.d.ts +28 -0
- package/dist/primitives/createVirtualList.js +11 -0
- package/dist/primitives/createVirtualList.js.map +1 -0
- package/dist/primitives/mergeRefs.d.ts +10 -0
- package/dist/primitives/mergeRefs.js +10 -0
- package/dist/primitives/mergeRefs.js.map +1 -0
- package/dist/utils/animate.d.ts +10 -0
- package/dist/utils/animate.js +28 -0
- package/dist/utils/animate.js.map +1 -0
- package/dist/utils/debounce.d.ts +5 -0
- package/dist/utils/debounce.js +15 -0
- package/dist/utils/debounce.js.map +1 -0
- package/dist/utils/floating.d.ts +9 -0
- package/dist/utils/floating.js +31 -0
- package/dist/utils/floating.js.map +1 -0
- package/dist/utils/throttle.d.ts +5 -0
- package/dist/utils/throttle.js +18 -0
- package/dist/utils/throttle.js.map +1 -0
- package/package.json +87 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"menuFloating.js","sources":["../../../../src/components/navigation/menu/menuFloating.tsx"],"sourcesContent":["import { type JSX, type ParentProps, Show, createEffect, createSignal, mergeProps, onCleanup, splitProps } from \"solid-js\";\nimport type { Middleware } from \"@floating-ui/dom\";\nimport { buildFloatingMiddleware, type Placement, resolvePlacement, type ResolvedPlacement } from \"../../../utils/floating\";\nimport { createFloating } from \"../../../primitives/createFloating\";\nimport { ClickAwayListener } from \"../../clickAwayListener\";\nimport { MenuList } from \"./menuList\";\nimport { mergeRefs, type Ref } from \"../../../primitives/mergeRefs\";\n\nexport function buildMenuFloatingMiddleware(resolved: ResolvedPlacement, custom?: Middleware[]): Middleware[] {\n return buildFloatingMiddleware(resolved, custom);\n}\n\nexport interface MenuFloatingProps extends JSX.HTMLAttributes<HTMLDivElement> {\n anchorElement?: Element | null | undefined;\n isOpen?: boolean;\n onClose?: () => void;\n placement?: Placement;\n middleware?: Middleware[] | undefined;\n ref?: Ref<HTMLDivElement>;\n}\n\nconst FADE_MS = 150;\n\nexport function MenuFloating(props: ParentProps<MenuFloatingProps>): JSX.Element {\n const merged = mergeProps({ placement: \"bottom-start\" as Placement }, props);\n const [local, rest] = splitProps(merged, [\n \"anchorElement\",\n \"isOpen\",\n \"onClose\",\n \"placement\",\n \"middleware\",\n \"style\",\n \"children\",\n \"ref\",\n ]);\n\n let menuEl: HTMLElement | undefined;\n const resolved = (): ResolvedPlacement => resolvePlacement(local.placement);\n const floating = createFloating({\n placement: () => resolved().placement,\n middleware: () => buildMenuFloatingMiddleware(resolved(), local.middleware),\n });\n\n createEffect(() => {\n floating.setReference(local.anchorElement ?? null);\n });\n\n // mountOnEnter + unmountOnExit fade lifecycle (replaces RTG Transition).\n const [mounted, setMounted] = createSignal(Boolean(local.isOpen));\n const [shown, setShown] = createSignal(false);\n let raf: number | undefined;\n let timer: ReturnType<typeof setTimeout> | undefined;\n\n createEffect(() => {\n const open = Boolean(local.isOpen);\n if (open) {\n if (timer !== undefined) {\n clearTimeout(timer);\n timer = undefined;\n }\n setMounted(true);\n raf = requestAnimationFrame(() => setShown(true));\n } else {\n setShown(false);\n if (mounted()) {\n timer = setTimeout(() => setMounted(false), FADE_MS);\n }\n }\n });\n onCleanup(() => {\n if (raf !== undefined) cancelAnimationFrame(raf);\n if (timer !== undefined) clearTimeout(timer);\n });\n\n const onAwayClick = (event: MouseEvent | TouchEvent): void => {\n if (!local.isOpen || !local.onClose || !menuEl) return;\n const target = event.target as HTMLElement;\n if (menuEl.contains(target) || (local.anchorElement as HTMLElement | null)?.contains(target)) {\n return;\n }\n local.onClose();\n };\n\n const style = (): JSX.CSSProperties => ({\n ...floating.floatingStyles(),\n ...(typeof local.style === \"object\" && local.style ? local.style : {}),\n transition: `opacity ${FADE_MS}ms ease-in-out`,\n opacity: shown() ? 1 : 0,\n });\n\n return (\n <Show when={mounted()}>\n <ClickAwayListener onClickAway={onAwayClick}>\n <MenuList {...rest} ref={mergeRefs(local.ref, floating.setFloating, (el) => (menuEl = el))} style={style()}>\n {local.children}\n </MenuList>\n </ClickAwayListener>\n </Show>\n );\n}\n\nexport default MenuFloating;\n"],"names":["buildMenuFloatingMiddleware","resolved","custom","buildFloatingMiddleware","FADE_MS","MenuFloating","props","merged","mergeProps","placement","local","rest","splitProps","menuEl","resolvePlacement","floating","createFloating","middleware","createEffect","setReference","anchorElement","mounted","setMounted","createSignal","Boolean","isOpen","shown","setShown","raf","timer","undefined","clearTimeout","requestAnimationFrame","setTimeout","onCleanup","cancelAnimationFrame","onAwayClick","event","onClose","target","contains","style","floatingStyles","transition","opacity","_$createComponent","Show","when","children","ClickAwayListener","onClickAway","MenuList","_$mergeProps","ref","r$","_ref$","mergeRefs","setFloating","el"],"mappings":";;;;;;;AAQO,SAASA,EAA4BC,GAA6BC,GAAqC;AAC5G,SAAOC,EAAwBF,GAAUC,CAAM;AACjD;AAWA,MAAME,IAAU;AAET,SAASC,EAAaC,GAAoD;AAC/E,QAAMC,IAASC,EAAW;AAAA,IAAEC,WAAW;AAAA,EAAA,GAA+BH,CAAK,GACrE,CAACI,GAAOC,CAAI,IAAIC,EAAWL,GAAQ,CACvC,iBACA,UACA,WACA,aACA,cACA,SACA,YACA,KAAK,CACN;AAED,MAAIM;AACJ,QAAMZ,IAAWA,MAAyBa,EAAiBJ,EAAMD,SAAS,GACpEM,IAAWC,EAAe;AAAA,IAC9BP,WAAWA,MAAMR,EAAAA,EAAWQ;AAAAA,IAC5BQ,YAAYA,MAAMjB,EAA4BC,EAAAA,GAAYS,EAAMO,UAAU;AAAA,EAAA,CAC3E;AAEDC,EAAAA,EAAa,MAAM;AACjBH,IAAAA,EAASI,aAAaT,EAAMU,iBAAiB,IAAI;AAAA,EACnD,CAAC;AAGD,QAAM,CAACC,GAASC,CAAU,IAAIC,EAAaC,EAAQd,EAAMe,MAAO,GAC1D,CAACC,GAAOC,CAAQ,IAAIJ,EAAa,EAAK;AAC5C,MAAIK,GACAC;AAEJX,EAAAA,EAAa,MAAM;AAEjB,IADaM,EAAQd,EAAMe,UAErBI,MAAUC,WACZC,aAAaF,CAAK,GAClBA,IAAQC,SAEVR,EAAW,EAAI,GACfM,IAAMI,sBAAsB,MAAML,EAAS,EAAI,CAAC,MAEhDA,EAAS,EAAK,GACVN,QACFQ,IAAQI,WAAW,MAAMX,EAAW,EAAK,GAAGlB,CAAO;AAAA,EAGzD,CAAC,GACD8B,EAAU,MAAM;AACd,IAAIN,MAAQE,UAAWK,qBAAqBP,CAAG,GAC3CC,MAAUC,UAAWC,aAAaF,CAAK;AAAA,EAC7C,CAAC;AAED,QAAMO,IAAcA,CAACC,MAAyC;AAC5D,QAAI,CAAC3B,EAAMe,UAAU,CAACf,EAAM4B,WAAW,CAACzB,EAAQ;AAChD,UAAM0B,IAASF,EAAME;AACrB,IAAI1B,EAAO2B,SAASD,CAAM,KAAM7B,EAAMU,eAAsCoB,SAASD,CAAM,KAG3F7B,EAAM4B,QAAAA;AAAAA,EACR,GAEMG,IAAQA,OAA0B;AAAA,IACtC,GAAG1B,EAAS2B,eAAAA;AAAAA,IACZ,GAAI,OAAOhC,EAAM+B,SAAU,YAAY/B,EAAM+B,QAAQ/B,EAAM+B,QAAQ,CAAA;AAAA,IACnEE,YAAY,WAAWvC,CAAO;AAAA,IAC9BwC,SAASlB,EAAAA,IAAU,IAAI;AAAA,EAAA;AAGzB,SAAAmB,EACGC,GAAI;AAAA,IAAA,IAACC,OAAI;AAAA,aAAE1B,EAAAA;AAAAA,IAAS;AAAA,IAAA,IAAA2B,WAAA;AAAA,aAAAH,EAClBI,GAAiB;AAAA,QAACC,aAAad;AAAAA,QAAW,IAAAY,WAAA;AAAA,iBAAAH,EACxCM,GAAQC,EAAKzC,GAAI;AAAA,YAAA0C,IAAAC,GAAA;AAAA,kBAAAC,IAAOC,EAAU9C,EAAM2C,KAAKtC,EAAS0C,aAAcC,CAAAA,MAAQ7C,IAAS6C,CAAG;AAAC,qBAAAH,KAAA,cAAAA,EAAAD,CAAA;AAAA,YAAA;AAAA,YAAA,IAAEb,QAAK;AAAA,qBAAEA,EAAAA;AAAAA,YAAO;AAAA,YAAA,IAAAO,WAAA;AAAA,qBACvGtC,EAAMsC;AAAAA,YAAQ;AAAA,UAAA,CAAA,CAAA;AAAA,QAAA;AAAA,MAAA,CAAA;AAAA,IAAA;AAAA,EAAA,CAAA;AAKzB;"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { type JSX, type ParentProps } from "solid-js";
|
|
2
|
+
import { type Ref } from "../../../primitives/mergeRefs";
|
|
3
|
+
export interface MenuItemProps extends JSX.HTMLAttributes<HTMLLIElement> {
|
|
4
|
+
disabled?: boolean | undefined;
|
|
5
|
+
selected?: boolean | undefined;
|
|
6
|
+
href?: string | undefined;
|
|
7
|
+
linkElement?: string;
|
|
8
|
+
linkProps?: JSX.AnchorHTMLAttributes<HTMLAnchorElement>;
|
|
9
|
+
value?: unknown;
|
|
10
|
+
optionRenderer?: ((args: MenuItemProps) => JSX.Element) | undefined;
|
|
11
|
+
onClick?: JSX.EventHandlerUnion<HTMLLIElement, MouseEvent>;
|
|
12
|
+
ref?: Ref<HTMLLIElement>;
|
|
13
|
+
}
|
|
14
|
+
export declare function MenuItem(props: ParentProps<MenuItemProps>): JSX.Element;
|
|
15
|
+
export default MenuItem;
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { createComponent as t, use as b, spread as h, mergeProps as a, insert as l, Dynamic as g, memo as w, template as i } from "solid-js/web";
|
|
2
|
+
import { splitProps as k, Show as c } from "solid-js";
|
|
3
|
+
import v from "clsx";
|
|
4
|
+
import { useMenuContext as R } from "./menuContext.js";
|
|
5
|
+
import { mergeRefs as C } from "../../../primitives/mergeRefs.js";
|
|
6
|
+
import { callHandler as P } from "../../../primitives/callHandler.js";
|
|
7
|
+
import { Ripple as $ } from "../../base/ripple/ripple.js";
|
|
8
|
+
var x = /* @__PURE__ */ i("<span class=smwb-menu__item__helper-text>"), D = /* @__PURE__ */ i("<li>"), y = /* @__PURE__ */ i("<span class=smwb-menu__item-inner>");
|
|
9
|
+
function q(o) {
|
|
10
|
+
const u = R(), [e, p] = k(o, ["children", "class", "disabled", "selected", "onClick", "href", "linkElement", "linkProps", "value", "optionRenderer", "ref"]);
|
|
11
|
+
let s;
|
|
12
|
+
const d = (r) => {
|
|
13
|
+
if (e.disabled) {
|
|
14
|
+
e.href && r.preventDefault();
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
P(e.onClick, r);
|
|
18
|
+
}, f = (r) => {
|
|
19
|
+
e.disabled || s?.onRipple(r);
|
|
20
|
+
}, _ = () => v("smwb-menu__item", e.class, {
|
|
21
|
+
"smwb-menu__item--dense": u.dense,
|
|
22
|
+
"smwb-menu__item--disabled": e.disabled,
|
|
23
|
+
"smwb-menu__item--selected": e.selected
|
|
24
|
+
});
|
|
25
|
+
return t(c, {
|
|
26
|
+
get when() {
|
|
27
|
+
return !e.optionRenderer;
|
|
28
|
+
},
|
|
29
|
+
get fallback() {
|
|
30
|
+
return e.optionRenderer?.(o);
|
|
31
|
+
},
|
|
32
|
+
get children() {
|
|
33
|
+
var r = D(), m = C(e.ref);
|
|
34
|
+
return typeof m == "function" && b(m, r), h(r, a(p, {
|
|
35
|
+
role: "menuitem",
|
|
36
|
+
get class() {
|
|
37
|
+
return _();
|
|
38
|
+
},
|
|
39
|
+
get tabindex() {
|
|
40
|
+
return e.disabled ? void 0 : 0;
|
|
41
|
+
},
|
|
42
|
+
onClick: d,
|
|
43
|
+
get "data-value"() {
|
|
44
|
+
return e.value;
|
|
45
|
+
},
|
|
46
|
+
onPointerDown: f
|
|
47
|
+
}), !1, !0), l(r, t(c, {
|
|
48
|
+
get when() {
|
|
49
|
+
return e.href;
|
|
50
|
+
},
|
|
51
|
+
get fallback() {
|
|
52
|
+
return (() => {
|
|
53
|
+
var n = y();
|
|
54
|
+
return l(n, () => e.children), n;
|
|
55
|
+
})();
|
|
56
|
+
},
|
|
57
|
+
get children() {
|
|
58
|
+
return t(g, a({
|
|
59
|
+
get component() {
|
|
60
|
+
return e.linkElement ?? "a";
|
|
61
|
+
},
|
|
62
|
+
class: "smwb-menu__item-inner",
|
|
63
|
+
get href() {
|
|
64
|
+
return e.href;
|
|
65
|
+
}
|
|
66
|
+
}, () => e.linkProps ?? {}, {
|
|
67
|
+
get children() {
|
|
68
|
+
return [w(() => e.children), x()];
|
|
69
|
+
}
|
|
70
|
+
}));
|
|
71
|
+
}
|
|
72
|
+
}), null), l(r, t($, {
|
|
73
|
+
actionRef: (n) => s = n
|
|
74
|
+
}), null), r;
|
|
75
|
+
}
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
export {
|
|
79
|
+
q as MenuItem
|
|
80
|
+
};
|
|
81
|
+
//# sourceMappingURL=menuItem.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"menuItem.js","sources":["../../../../src/components/navigation/menu/menuItem.tsx"],"sourcesContent":["import { type JSX, type ParentProps, Show, splitProps } from \"solid-js\";\nimport { Dynamic } from \"solid-js/web\";\nimport cn from \"clsx\";\nimport { useMenuContext } from \"./menuContext\";\nimport { Ripple, type RippleActionsRef } from \"../../base/ripple\";\nimport { mergeRefs, type Ref } from \"../../../primitives/mergeRefs\";\nimport { callHandler } from \"../../../primitives/callHandler\";\n\nexport interface MenuItemProps extends JSX.HTMLAttributes<HTMLLIElement> {\n disabled?: boolean | undefined;\n selected?: boolean | undefined;\n href?: string | undefined;\n linkElement?: string;\n linkProps?: JSX.AnchorHTMLAttributes<HTMLAnchorElement>;\n value?: unknown;\n optionRenderer?: ((args: MenuItemProps) => JSX.Element) | undefined;\n onClick?: JSX.EventHandlerUnion<HTMLLIElement, MouseEvent>;\n ref?: Ref<HTMLLIElement>;\n}\n\nexport function MenuItem(props: ParentProps<MenuItemProps>): JSX.Element {\n const ctx = useMenuContext();\n const [local, rest] = splitProps(props, [\n \"children\",\n \"class\",\n \"disabled\",\n \"selected\",\n \"onClick\",\n \"href\",\n \"linkElement\",\n \"linkProps\",\n \"value\",\n \"optionRenderer\",\n \"ref\",\n ]);\n\n let rippleActions: RippleActionsRef | undefined;\n\n const onClick: JSX.EventHandler<HTMLLIElement, MouseEvent> = (event) => {\n if (local.disabled) {\n if (local.href) event.preventDefault();\n return;\n }\n callHandler(local.onClick, event);\n };\n\n const onPointerDown = (event: PointerEvent): void => {\n if (!local.disabled) rippleActions?.onRipple(event);\n };\n\n const classes = (): string =>\n cn(\"smwb-menu__item\", local.class, {\n \"smwb-menu__item--dense\": ctx.dense,\n \"smwb-menu__item--disabled\": local.disabled,\n \"smwb-menu__item--selected\": local.selected,\n });\n\n return (\n <Show when={!local.optionRenderer} fallback={local.optionRenderer?.(props)}>\n <li\n {...rest}\n role=\"menuitem\"\n ref={mergeRefs(local.ref)}\n class={classes()}\n tabindex={local.disabled ? undefined : 0}\n onClick={onClick}\n data-value={local.value as string | number | undefined}\n onPointerDown={onPointerDown}\n >\n <Show\n when={local.href}\n fallback={<span class=\"smwb-menu__item-inner\">{local.children}</span>}\n >\n <Dynamic component={local.linkElement ?? \"a\"} class=\"smwb-menu__item-inner\" href={local.href} {...(local.linkProps ?? {})}>\n {local.children}\n <span class=\"smwb-menu__item__helper-text\" />\n </Dynamic>\n </Show>\n <Ripple actionRef={(actions) => (rippleActions = actions)} />\n </li>\n </Show>\n );\n}\n\nexport default MenuItem;\n"],"names":["MenuItem","props","ctx","useMenuContext","local","rest","splitProps","rippleActions","onClick","event","disabled","href","preventDefault","callHandler","onPointerDown","onRipple","classes","cn","class","dense","selected","_$createComponent","Show","when","optionRenderer","fallback","children","_el$","_tmpl$2","_ref$","mergeRefs","ref","_$use","_$spread","_$mergeProps","tabindex","undefined","value","_$insert","_el$3","_tmpl$3","Dynamic","component","linkElement","linkProps","_$memo","_tmpl$","Ripple","actionRef","actions"],"mappings":";;;;;;;;AAoBO,SAASA,EAASC,GAAgD;AACvE,QAAMC,IAAMC,EAAAA,GACN,CAACC,GAAOC,CAAI,IAAIC,EAAWL,GAAO,CACtC,YACA,SACA,YACA,YACA,WACA,QACA,eACA,aACA,SACA,kBACA,KAAK,CACN;AAED,MAAIM;AAEJ,QAAMC,IAAwDC,CAAAA,MAAU;AACtE,QAAIL,EAAMM,UAAU;AAClB,MAAIN,EAAMO,QAAMF,EAAMG,eAAAA;AACtB;AAAA,IACF;AACAC,IAAAA,EAAYT,EAAMI,SAASC,CAAK;AAAA,EAClC,GAEMK,IAAgBA,CAACL,MAA8B;AACnD,IAAKL,EAAMM,YAAUH,GAAeQ,SAASN,CAAK;AAAA,EACpD,GAEMO,IAAUA,MACdC,EAAG,mBAAmBb,EAAMc,OAAO;AAAA,IACjC,0BAA0BhB,EAAIiB;AAAAA,IAC9B,6BAA6Bf,EAAMM;AAAAA,IACnC,6BAA6BN,EAAMgB;AAAAA,EAAAA,CACpC;AAEH,SAAAC,EACGC,GAAI;AAAA,IAAA,IAACC,OAAI;AAAA,aAAE,CAACnB,EAAMoB;AAAAA,IAAc;AAAA,IAAA,IAAEC,WAAQ;AAAA,aAAErB,EAAMoB,iBAAiBvB,CAAK;AAAA,IAAC;AAAA,IAAA,IAAAyB,WAAA;AAAA,UAAAC,IAAAC,EAAAA,GAAAC,IAIjEC,EAAU1B,EAAM2B,GAAG;AAAC,oBAAAF,KAAA,cAAAG,EAAAH,GAAAF,CAAA,GAAAM,EAAAN,GAAAO,EAFrB7B,GAAI;AAAA,QAAA,MACH;AAAA,QAAU,IAAA,QAAA;AAAA,iBAERW,EAAAA;AAAAA,QAAS;AAAA,QAAA,IAChBmB,WAAQ;AAAA,iBAAE/B,EAAMM,WAAW0B,SAAY;AAAA,QAAC;AAAA,QAAA,SAC/B5B;AAAAA,QAAO,IAAA,eAAA;AAAA,iBACJJ,EAAMiC;AAAAA,QAAoC;AAAA,QAAA,eACvCvB;AAAAA,MAAAA,CAAa,GAAA,IAAA,EAAA,GAAAwB,EAAAX,GAAAN,EAE3BC,GAAI;AAAA,QAAA,IACHC,OAAI;AAAA,iBAAEnB,EAAMO;AAAAA,QAAI;AAAA,QAAA,IAChBc,WAAQ;AAAA,kBAAA,MAAA;AAAA,gBAAAc,IAAAC,EAAAA;AAAAF,mBAAAA,EAAAC,GAAA,MAAuCnC,EAAMsB,QAAQ,GAAAa;AAAAA,UAAA,GAAA;AAAA,QAAA;AAAA,QAAA,IAAAb,WAAA;AAAA,iBAAAL,EAE5DoB,GAAOP,EAAA;AAAA,YAAA,IAACQ,YAAS;AAAA,qBAAEtC,EAAMuC,eAAe;AAAA,YAAG;AAAA,YAAA,OAAA;AAAA,YAAA,IAAgChC,OAAI;AAAA,qBAAEP,EAAMO;AAAAA,YAAI;AAAA,UAAA,GAAA,MAAOP,EAAMwC,aAAa,IAAE;AAAA,YAAA,IAAAlB,WAAA;AAAA,qBAAA,CAAAmB,EAAA,MACrHzC,EAAMsB,QAAQ,GAAAoB,GAAA;AAAA,YAAA;AAAA,UAAA,CAAA,CAAA;AAAA,QAAA;AAAA,MAAA,CAAA,GAAA,IAAA,GAAAR,EAAAX,GAAAN,EAIlB0B,GAAM;AAAA,QAACC,WAAYC,OAAa1C,IAAgB0C;AAAAA,MAAAA,CAAQ,GAAA,IAAA,GAAAtB;AAAAA,IAAA;AAAA,EAAA,CAAA;AAIjE;"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { type JSX, type ParentProps } from "solid-js";
|
|
2
|
+
import { type Ref } from "../../../primitives/mergeRefs";
|
|
3
|
+
export interface MenuItemIconProps extends JSX.HTMLAttributes<HTMLSpanElement> {
|
|
4
|
+
edge?: "start" | "end";
|
|
5
|
+
ref?: Ref<HTMLSpanElement>;
|
|
6
|
+
}
|
|
7
|
+
export declare function MenuItemIcon(props: ParentProps<MenuItemIconProps>): JSX.Element;
|
|
8
|
+
export default MenuItemIcon;
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { use as m, spread as c, mergeProps as i, insert as p, template as u } from "solid-js/web";
|
|
2
|
+
import { splitProps as a } from "solid-js";
|
|
3
|
+
import f from "clsx";
|
|
4
|
+
import { useMenuContext as l } from "./menuContext.js";
|
|
5
|
+
import { mergeRefs as _ } from "../../../primitives/mergeRefs.js";
|
|
6
|
+
var d = /* @__PURE__ */ u("<span>");
|
|
7
|
+
function $(t) {
|
|
8
|
+
const s = l(), [e, o] = a(t, ["children", "class", "edge", "ref"]);
|
|
9
|
+
return (() => {
|
|
10
|
+
var r = d(), n = _(e.ref);
|
|
11
|
+
return typeof n == "function" && m(n, r), c(r, i(o, {
|
|
12
|
+
get class() {
|
|
13
|
+
return f("smwb-menu__icon", e.class, {
|
|
14
|
+
"smwb-menu__icon--dense": s.dense,
|
|
15
|
+
"smwb-menu__icon--start": e.edge === "start",
|
|
16
|
+
"smwb-menu__icon--end": e.edge === "end"
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
}), !1, !0), p(r, () => e.children), r;
|
|
20
|
+
})();
|
|
21
|
+
}
|
|
22
|
+
export {
|
|
23
|
+
$ as MenuItemIcon
|
|
24
|
+
};
|
|
25
|
+
//# sourceMappingURL=menuItemIcon.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"menuItemIcon.js","sources":["../../../../src/components/navigation/menu/menuItemIcon.tsx"],"sourcesContent":["import { type JSX, type ParentProps, splitProps } from \"solid-js\";\nimport cn from \"clsx\";\nimport { useMenuContext } from \"./menuContext\";\nimport { mergeRefs, type Ref } from \"../../../primitives/mergeRefs\";\n\nexport interface MenuItemIconProps extends JSX.HTMLAttributes<HTMLSpanElement> {\n edge?: \"start\" | \"end\";\n ref?: Ref<HTMLSpanElement>;\n}\n\nexport function MenuItemIcon(props: ParentProps<MenuItemIconProps>): JSX.Element {\n const ctx = useMenuContext();\n const [local, rest] = splitProps(props, [\"children\", \"class\", \"edge\", \"ref\"]);\n return (\n <span\n {...rest}\n ref={mergeRefs(local.ref)}\n class={cn(\"smwb-menu__icon\", local.class, {\n \"smwb-menu__icon--dense\": ctx.dense,\n \"smwb-menu__icon--start\": local.edge === \"start\",\n \"smwb-menu__icon--end\": local.edge === \"end\",\n })}\n >\n {local.children}\n </span>\n );\n}\n\nexport default MenuItemIcon;\n"],"names":["MenuItemIcon","props","ctx","useMenuContext","local","rest","splitProps","_el$","_tmpl$","_ref$","mergeRefs","ref","_$use","_$spread","_$mergeProps","cn","class","dense","edge","_$insert","children"],"mappings":";;;;;;AAUO,SAASA,EAAaC,GAAoD;AAC/E,QAAMC,IAAMC,EAAAA,GACN,CAACC,GAAOC,CAAI,IAAIC,EAAWL,GAAO,CAAC,YAAY,SAAS,QAAQ,KAAK,CAAC;AAC5E,UAAA,MAAA;AAAA,QAAAM,IAAAC,EAAAA,GAAAC,IAGSC,EAAUN,EAAMO,GAAG;AAAC,kBAAAF,KAAA,cAAAG,EAAAH,GAAAF,CAAA,GAAAM,EAAAN,GAAAO,EADrBT,GAAI;AAAA,MAAA,IAAA,QAAA;AAAA,eAEDU,EAAG,mBAAmBX,EAAMY,OAAO;AAAA,UACxC,0BAA0Bd,EAAIe;AAAAA,UAC9B,0BAA0Bb,EAAMc,SAAS;AAAA,UACzC,wBAAwBd,EAAMc,SAAS;AAAA,QAAA,CACxC;AAAA,MAAC;AAAA,IAAA,CAAA,GAAA,IAAA,EAAA,GAAAC,EAAAZ,GAAA,MAEDH,EAAMgB,QAAQ,GAAAb;AAAAA,EAAA,GAAA;AAGrB;"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { type JSX, type ParentProps } from "solid-js";
|
|
2
|
+
import { type Ref } from "../../../primitives/mergeRefs";
|
|
3
|
+
export interface MenuItemTextProps extends JSX.HTMLAttributes<HTMLSpanElement> {
|
|
4
|
+
inset?: boolean;
|
|
5
|
+
ref?: Ref<HTMLSpanElement>;
|
|
6
|
+
}
|
|
7
|
+
export declare function MenuItemText(props: ParentProps<MenuItemTextProps>): JSX.Element;
|
|
8
|
+
export default MenuItemText;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { use as p, spread as i, mergeProps as f, insert as a, template as c } from "solid-js/web";
|
|
2
|
+
import { mergeProps as l, splitProps as u } from "solid-js";
|
|
3
|
+
import _ from "clsx";
|
|
4
|
+
import { useMenuContext as x } from "./menuContext.js";
|
|
5
|
+
import { mergeRefs as d } from "../../../primitives/mergeRefs.js";
|
|
6
|
+
var g = /* @__PURE__ */ c("<span>");
|
|
7
|
+
function h(s) {
|
|
8
|
+
const n = x(), m = l({
|
|
9
|
+
inset: !1
|
|
10
|
+
}, s), [e, o] = u(m, ["children", "class", "inset", "ref"]);
|
|
11
|
+
return (() => {
|
|
12
|
+
var r = g(), t = d(e.ref);
|
|
13
|
+
return typeof t == "function" && p(t, r), i(r, f(o, {
|
|
14
|
+
get class() {
|
|
15
|
+
return _("smwb-menu__text", e.class, {
|
|
16
|
+
"smwb-menu__text--inset": e.inset,
|
|
17
|
+
"smwb-menu__text--dense": n.dense
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
}), !1, !0), a(r, () => e.children), r;
|
|
21
|
+
})();
|
|
22
|
+
}
|
|
23
|
+
export {
|
|
24
|
+
h as MenuItemText
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=menuItemText.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"menuItemText.js","sources":["../../../../src/components/navigation/menu/menuItemText.tsx"],"sourcesContent":["import { type JSX, type ParentProps, mergeProps, splitProps } from \"solid-js\";\nimport cn from \"clsx\";\nimport { useMenuContext } from \"./menuContext\";\nimport { mergeRefs, type Ref } from \"../../../primitives/mergeRefs\";\n\nexport interface MenuItemTextProps extends JSX.HTMLAttributes<HTMLSpanElement> {\n inset?: boolean;\n ref?: Ref<HTMLSpanElement>;\n}\n\nexport function MenuItemText(props: ParentProps<MenuItemTextProps>): JSX.Element {\n const ctx = useMenuContext();\n const merged = mergeProps({ inset: false }, props);\n const [local, rest] = splitProps(merged, [\"children\", \"class\", \"inset\", \"ref\"]);\n return (\n <span\n {...rest}\n ref={mergeRefs(local.ref)}\n class={cn(\"smwb-menu__text\", local.class, {\n \"smwb-menu__text--inset\": local.inset,\n \"smwb-menu__text--dense\": ctx.dense,\n })}\n >\n {local.children}\n </span>\n );\n}\n\nexport default MenuItemText;\n"],"names":["MenuItemText","props","ctx","useMenuContext","merged","mergeProps","inset","local","rest","splitProps","_el$","_tmpl$","_ref$","mergeRefs","ref","_$use","_$spread","_$mergeProps","cn","class","dense","_$insert","children"],"mappings":";;;;;;AAUO,SAASA,EAAaC,GAAoD;AAC/E,QAAMC,IAAMC,EAAAA,GACNC,IAASC,EAAW;AAAA,IAAEC,OAAO;AAAA,EAAA,GAASL,CAAK,GAC3C,CAACM,GAAOC,CAAI,IAAIC,EAAWL,GAAQ,CAAC,YAAY,SAAS,SAAS,KAAK,CAAC;AAC9E,UAAA,MAAA;AAAA,QAAAM,IAAAC,EAAAA,GAAAC,IAGSC,EAAUN,EAAMO,GAAG;AAAC,kBAAAF,KAAA,cAAAG,EAAAH,GAAAF,CAAA,GAAAM,EAAAN,GAAAO,EADrBT,GAAI;AAAA,MAAA,IAAA,QAAA;AAAA,eAEDU,EAAG,mBAAmBX,EAAMY,OAAO;AAAA,UACxC,0BAA0BZ,EAAMD;AAAAA,UAChC,0BAA0BJ,EAAIkB;AAAAA,QAAAA,CAC/B;AAAA,MAAC;AAAA,IAAA,CAAA,GAAA,IAAA,EAAA,GAAAC,EAAAX,GAAA,MAEDH,EAAMe,QAAQ,GAAAZ;AAAAA,EAAA,GAAA;AAGrB;"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { type JSX, type ParentProps } from "solid-js";
|
|
2
|
+
import { type Ref } from "../../../primitives/mergeRefs";
|
|
3
|
+
export interface MenuListProps extends JSX.HTMLAttributes<HTMLDivElement> {
|
|
4
|
+
ref?: Ref<HTMLDivElement>;
|
|
5
|
+
}
|
|
6
|
+
export declare function MenuList(props: ParentProps<MenuListProps>): JSX.Element;
|
|
7
|
+
export default MenuList;
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { use as f, spread as m, mergeProps as u, insert as c, effect as p, className as d, template as g, delegateEvents as y } from "solid-js/web";
|
|
2
|
+
import { splitProps as w } from "solid-js";
|
|
3
|
+
import s from "clsx";
|
|
4
|
+
import { useMenuContext as h } from "./menuContext.js";
|
|
5
|
+
import { mergeRefs as _ } from "../../../primitives/mergeRefs.js";
|
|
6
|
+
var $ = /* @__PURE__ */ g("<div><ul role=menu aria-orientation=vertical>");
|
|
7
|
+
function A(l) {
|
|
8
|
+
const n = h(), [o, i] = w(l, ["children", "class", "ref"]), a = (e) => {
|
|
9
|
+
const r = Array.from(e.currentTarget.querySelectorAll('[role="menuitem"]:not([aria-disabled="true"])'));
|
|
10
|
+
if (r.length === 0) return;
|
|
11
|
+
const t = r.indexOf(document.activeElement);
|
|
12
|
+
e.key === "ArrowDown" ? (e.preventDefault(), r[(t + 1 + r.length) % r.length]?.focus()) : e.key === "ArrowUp" ? (e.preventDefault(), r[(t - 1 + r.length) % r.length]?.focus()) : e.key === "Home" ? (e.preventDefault(), r[0]?.focus()) : e.key === "End" ? (e.preventDefault(), r[r.length - 1]?.focus()) : e.key === "Escape" && n.onClose();
|
|
13
|
+
};
|
|
14
|
+
return (() => {
|
|
15
|
+
var e = $(), r = e.firstChild, t = _(o.ref);
|
|
16
|
+
return typeof t == "function" && f(t, e), m(e, u(i, {
|
|
17
|
+
get class() {
|
|
18
|
+
return s("smwb-menu", o.class, `smwb-menu--${n.variant}`);
|
|
19
|
+
}
|
|
20
|
+
}), !1, !0), r.$$keydown = a, c(r, () => o.children), p(() => d(r, s("smwb-menu__list", `smwb-menu__list--${n.variant}`))), e;
|
|
21
|
+
})();
|
|
22
|
+
}
|
|
23
|
+
y(["keydown"]);
|
|
24
|
+
export {
|
|
25
|
+
A as MenuList
|
|
26
|
+
};
|
|
27
|
+
//# sourceMappingURL=menuList.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"menuList.js","sources":["../../../../src/components/navigation/menu/menuList.tsx"],"sourcesContent":["import { type JSX, type ParentProps, splitProps } from \"solid-js\";\nimport cn from \"clsx\";\nimport { useMenuContext } from \"./menuContext\";\nimport { mergeRefs, type Ref } from \"../../../primitives/mergeRefs\";\n\nexport interface MenuListProps extends JSX.HTMLAttributes<HTMLDivElement> {\n ref?: Ref<HTMLDivElement>;\n}\n\nexport function MenuList(props: ParentProps<MenuListProps>): JSX.Element {\n const ctx = useMenuContext();\n const [local, rest] = splitProps(props, [\"children\", \"class\", \"ref\"]);\n\n const onKeyDown: JSX.EventHandler<HTMLUListElement, KeyboardEvent> = (event) => {\n const items = Array.from(\n event.currentTarget.querySelectorAll<HTMLElement>('[role=\"menuitem\"]:not([aria-disabled=\"true\"])')\n );\n if (items.length === 0) return;\n const currentIndex = items.indexOf(document.activeElement as HTMLElement);\n\n if (event.key === \"ArrowDown\") {\n event.preventDefault();\n items[(currentIndex + 1 + items.length) % items.length]?.focus();\n } else if (event.key === \"ArrowUp\") {\n event.preventDefault();\n items[(currentIndex - 1 + items.length) % items.length]?.focus();\n } else if (event.key === \"Home\") {\n event.preventDefault();\n items[0]?.focus();\n } else if (event.key === \"End\") {\n event.preventDefault();\n items[items.length - 1]?.focus();\n } else if (event.key === \"Escape\") {\n ctx.onClose();\n }\n };\n\n return (\n <div {...rest} ref={mergeRefs(local.ref)} class={cn(\"smwb-menu\", local.class, `smwb-menu--${ctx.variant}`)}>\n <ul\n class={cn(\"smwb-menu__list\", `smwb-menu__list--${ctx.variant}`)}\n role=\"menu\"\n aria-orientation=\"vertical\"\n onKeyDown={onKeyDown}\n >\n {local.children}\n </ul>\n </div>\n );\n}\n\nexport default MenuList;\n"],"names":["MenuList","props","ctx","useMenuContext","local","rest","splitProps","onKeyDown","event","items","Array","from","currentTarget","querySelectorAll","length","currentIndex","indexOf","document","activeElement","key","preventDefault","focus","onClose","_el$","_tmpl$","_el$2","firstChild","_ref$","mergeRefs","ref","_$use","_$spread","_$mergeProps","cn","class","variant","$$keydown","_$insert","children","_$effect","_$className","_$delegateEvents"],"mappings":";;;;;;AASO,SAASA,EAASC,GAAgD;AACvE,QAAMC,IAAMC,EAAAA,GACN,CAACC,GAAOC,CAAI,IAAIC,EAAWL,GAAO,CAAC,YAAY,SAAS,KAAK,CAAC,GAE9DM,IAAgEC,CAAAA,MAAU;AAC9E,UAAMC,IAAQC,MAAMC,KAClBH,EAAMI,cAAcC,iBAA8B,+CAA+C,CACnG;AACA,QAAIJ,EAAMK,WAAW,EAAG;AACxB,UAAMC,IAAeN,EAAMO,QAAQC,SAASC,aAA4B;AAExE,IAAIV,EAAMW,QAAQ,eAChBX,EAAMY,eAAAA,GACNX,GAAOM,IAAe,IAAIN,EAAMK,UAAUL,EAAMK,MAAM,GAAGO,MAAAA,KAChDb,EAAMW,QAAQ,aACvBX,EAAMY,eAAAA,GACNX,GAAOM,IAAe,IAAIN,EAAMK,UAAUL,EAAMK,MAAM,GAAGO,MAAAA,KAChDb,EAAMW,QAAQ,UACvBX,EAAMY,eAAAA,GACNX,EAAM,CAAC,GAAGY,MAAAA,KACDb,EAAMW,QAAQ,SACvBX,EAAMY,eAAAA,GACNX,EAAMA,EAAMK,SAAS,CAAC,GAAGO,MAAAA,KAChBb,EAAMW,QAAQ,YACvBjB,EAAIoB,QAAAA;AAAAA,EAER;AAEA,UAAA,MAAA;AAAA,QAAAC,IAAAC,EAAAA,GAAAC,IAAAF,EAAAG,YAAAC,IACsBC,EAAUxB,EAAMyB,GAAG;AAAC,kBAAAF,KAAA,cAAAG,EAAAH,GAAAJ,CAAA,GAAAQ,EAAAR,GAAAS,EAA/B3B,GAAI;AAAA,MAAA,IAAA,QAAA;AAAA,eAAoC4B,EAAG,aAAa7B,EAAM8B,OAAO,cAAchC,EAAIiC,OAAO,EAAE;AAAA,MAAC;AAAA,IAAA,CAAA,GAAA,IAAA,EAAA,GAAAV,EAAAW,YAK3F7B,GAAS8B,EAAAZ,GAAA,MAEnBrB,EAAMkC,QAAQ,GAAAC,EAAA,MAAAC,EAAAf,GALRQ,EAAG,mBAAmB,oBAAoB/B,EAAIiC,OAAO,EAAE,CAAC,CAAA,GAAAZ;AAAAA,EAAA,GAAA;AASvE;AAEwBkB,EAAA,CAAA,SAAA,CAAA;"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { type JSX, type ParentProps } from "solid-js";
|
|
2
|
+
import type { Placement } from "../../../utils/floating";
|
|
3
|
+
export interface MenuSubmenuProps {
|
|
4
|
+
placement?: Placement;
|
|
5
|
+
onClose?: () => void;
|
|
6
|
+
/** Content of the toggle row (e.g. an icon + <MenuItemText/>). */
|
|
7
|
+
toggleElement?: JSX.Element;
|
|
8
|
+
/** Items and/or nested `MenuSubmenu` elements (multi-level supported). */
|
|
9
|
+
children: JSX.Element;
|
|
10
|
+
/** Open the submenu on pointer hover in addition to click. */
|
|
11
|
+
openOnHover?: boolean;
|
|
12
|
+
class?: string;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Solid redesign of MenuSubmenu. React injected props into a cloned toggle and
|
|
16
|
+
* cloned each child's onClick; Solid renders its own toggle row and closes the
|
|
17
|
+
* menu chain via click delegation on the floating content (leaf menuitems close,
|
|
18
|
+
* nested submenu toggles — which carry `aria-haspopup` — do not).
|
|
19
|
+
*/
|
|
20
|
+
export declare function MenuSubmenu(props: ParentProps<MenuSubmenuProps>): JSX.Element;
|
|
21
|
+
export default MenuSubmenu;
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import { createComponent as m, addEventListener as v, use as A, insert as w, effect as b, className as y, setAttribute as E, template as _, delegateEvents as O } from "solid-js/web";
|
|
2
|
+
import { splitProps as $, createSignal as u } from "solid-js";
|
|
3
|
+
import { offset as M } from "@floating-ui/dom";
|
|
4
|
+
import D from "clsx";
|
|
5
|
+
import { useMenuContext as H, MenuContext as L } from "./menuContext.js";
|
|
6
|
+
import { MenuFloating as P } from "./menuFloating.js";
|
|
7
|
+
var S = /* @__PURE__ */ _("<li role=menuitem tabindex=0 aria-haspopup=menu><span class=smwb-menu__item-inner>");
|
|
8
|
+
function j(p) {
|
|
9
|
+
const l = H(), [t] = $(p, ["placement", "onClose", "toggleElement", "children", "openOnHover", "class"]), [s, r] = u(!1), [d, f] = u(null), g = [M(({
|
|
10
|
+
placement: e
|
|
11
|
+
}) => {
|
|
12
|
+
switch (e) {
|
|
13
|
+
case "right-start":
|
|
14
|
+
case "left-start":
|
|
15
|
+
return {
|
|
16
|
+
crossAxis: -8,
|
|
17
|
+
mainAxis: 0
|
|
18
|
+
};
|
|
19
|
+
case "right-end":
|
|
20
|
+
case "left-end":
|
|
21
|
+
return {
|
|
22
|
+
crossAxis: 8,
|
|
23
|
+
mainAxis: 0
|
|
24
|
+
};
|
|
25
|
+
default:
|
|
26
|
+
return {
|
|
27
|
+
crossAxis: 0,
|
|
28
|
+
mainAxis: 0
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
})], h = (e) => {
|
|
32
|
+
e.button === 0 && r((n) => !n);
|
|
33
|
+
}, i = () => {
|
|
34
|
+
r(!1), t.onClose?.();
|
|
35
|
+
}, C = (e) => {
|
|
36
|
+
e.key === "ArrowRight" || e.key === "Enter" || e.key === " " ? (e.preventDefault(), r(!0)) : (e.key === "ArrowLeft" || e.key === "Escape") && r(!1);
|
|
37
|
+
}, x = (e) => {
|
|
38
|
+
const n = e.target.closest('[role="menuitem"]');
|
|
39
|
+
n && !n.hasAttribute("aria-haspopup") && (i(), l.onClose());
|
|
40
|
+
}, k = {
|
|
41
|
+
get dense() {
|
|
42
|
+
return l.dense;
|
|
43
|
+
},
|
|
44
|
+
variant: "floating",
|
|
45
|
+
onClose: i
|
|
46
|
+
};
|
|
47
|
+
return m(L.Provider, {
|
|
48
|
+
value: k,
|
|
49
|
+
get children() {
|
|
50
|
+
return [(() => {
|
|
51
|
+
var e = S(), n = e.firstChild;
|
|
52
|
+
return v(e, "mouseenter", t.openOnHover ? () => r(!0) : void 0), e.$$keydown = C, e.$$click = h, A(f, e), w(n, () => t.toggleElement), b((o) => {
|
|
53
|
+
var a = D("smwb-menu__item", t.class, {
|
|
54
|
+
"smwb-menu__item--selected": s()
|
|
55
|
+
}), c = s();
|
|
56
|
+
return a !== o.e && y(e, o.e = a), c !== o.t && E(e, "aria-expanded", o.t = c), o;
|
|
57
|
+
}, {
|
|
58
|
+
e: void 0,
|
|
59
|
+
t: void 0
|
|
60
|
+
}), e;
|
|
61
|
+
})(), m(P, {
|
|
62
|
+
get placement() {
|
|
63
|
+
return t.placement ?? "right-start";
|
|
64
|
+
},
|
|
65
|
+
get isOpen() {
|
|
66
|
+
return s();
|
|
67
|
+
},
|
|
68
|
+
onClose: i,
|
|
69
|
+
get anchorElement() {
|
|
70
|
+
return d();
|
|
71
|
+
},
|
|
72
|
+
middleware: g,
|
|
73
|
+
onClick: x,
|
|
74
|
+
get children() {
|
|
75
|
+
return t.children;
|
|
76
|
+
}
|
|
77
|
+
})];
|
|
78
|
+
}
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
O(["click", "keydown"]);
|
|
82
|
+
export {
|
|
83
|
+
j as MenuSubmenu
|
|
84
|
+
};
|
|
85
|
+
//# sourceMappingURL=menuSubmenu.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"menuSubmenu.js","sources":["../../../../src/components/navigation/menu/menuSubmenu.tsx"],"sourcesContent":["import { type JSX, type ParentProps, createSignal, splitProps } from \"solid-js\";\nimport { type Middleware, offset } from \"@floating-ui/dom\";\nimport cn from \"clsx\";\nimport { MenuContext, useMenuContext } from \"./menuContext\";\nimport { MenuFloating } from \"./menuFloating\";\nimport type { Placement } from \"../../../utils/floating\";\n\nexport interface MenuSubmenuProps {\n placement?: Placement;\n onClose?: () => void;\n /** Content of the toggle row (e.g. an icon + <MenuItemText/>). */\n toggleElement?: JSX.Element;\n /** Items and/or nested `MenuSubmenu` elements (multi-level supported). */\n children: JSX.Element;\n /** Open the submenu on pointer hover in addition to click. */\n openOnHover?: boolean;\n class?: string;\n}\n\n/**\n * Solid redesign of MenuSubmenu. React injected props into a cloned toggle and\n * cloned each child's onClick; Solid renders its own toggle row and closes the\n * menu chain via click delegation on the floating content (leaf menuitems close,\n * nested submenu toggles — which carry `aria-haspopup` — do not).\n */\nexport function MenuSubmenu(props: ParentProps<MenuSubmenuProps>): JSX.Element {\n const parentCtx = useMenuContext();\n const [local] = splitProps(props, [\"placement\", \"onClose\", \"toggleElement\", \"children\", \"openOnHover\", \"class\"]);\n const [isOpen, setIsOpen] = createSignal(false);\n const [anchor, setAnchor] = createSignal<HTMLElement | null>(null);\n\n const middleware: Middleware[] = [\n offset(({ placement }) => {\n switch (placement) {\n case \"right-start\":\n case \"left-start\":\n return { crossAxis: -8, mainAxis: 0 };\n case \"right-end\":\n case \"left-end\":\n return { crossAxis: 8, mainAxis: 0 };\n default:\n return { crossAxis: 0, mainAxis: 0 };\n }\n }),\n ];\n\n const onToggle: JSX.EventHandler<HTMLLIElement, MouseEvent> = (event) => {\n if (event.button !== 0) return;\n setIsOpen((prev) => !prev);\n };\n\n const close = (): void => {\n setIsOpen(false);\n local.onClose?.();\n };\n\n const onToggleKeyDown: JSX.EventHandler<HTMLLIElement, KeyboardEvent> = (event) => {\n if (event.key === \"ArrowRight\" || event.key === \"Enter\" || event.key === \" \") {\n event.preventDefault();\n setIsOpen(true);\n } else if (event.key === \"ArrowLeft\" || event.key === \"Escape\") {\n setIsOpen(false);\n }\n };\n\n const onContentClick: JSX.EventHandler<HTMLDivElement, MouseEvent> = (event) => {\n const item = (event.target as HTMLElement).closest('[role=\"menuitem\"]');\n if (item && !item.hasAttribute(\"aria-haspopup\")) {\n close();\n parentCtx.onClose();\n }\n };\n\n const value = {\n get dense() {\n return parentCtx.dense;\n },\n variant: \"floating\" as const,\n onClose: close,\n };\n\n return (\n <MenuContext.Provider value={value}>\n <li\n role=\"menuitem\"\n ref={setAnchor}\n class={cn(\"smwb-menu__item\", local.class, { \"smwb-menu__item--selected\": isOpen() })}\n tabindex={0}\n aria-haspopup=\"menu\"\n aria-expanded={isOpen()}\n onClick={onToggle}\n onKeyDown={onToggleKeyDown}\n onMouseEnter={local.openOnHover ? () => setIsOpen(true) : undefined}\n >\n <span class=\"smwb-menu__item-inner\">{local.toggleElement}</span>\n </li>\n <MenuFloating\n placement={local.placement ?? \"right-start\"}\n isOpen={isOpen()}\n onClose={close}\n anchorElement={anchor()}\n middleware={middleware}\n onClick={onContentClick}\n >\n {local.children}\n </MenuFloating>\n </MenuContext.Provider>\n );\n}\n\nexport default MenuSubmenu;\n"],"names":["MenuSubmenu","props","parentCtx","useMenuContext","local","splitProps","isOpen","setIsOpen","createSignal","anchor","setAnchor","middleware","offset","placement","crossAxis","mainAxis","onToggle","event","button","prev","close","onClose","onToggleKeyDown","key","preventDefault","onContentClick","item","target","closest","hasAttribute","value","dense","variant","_$createComponent","MenuContext","Provider","children","_el$","_tmpl$","_el$2","firstChild","_$addEventListener","openOnHover","undefined","$$keydown","$$click","_$use","_$insert","toggleElement","_$effect","_p$","_v$","cn","class","_v$2","e","_$className","t","_$setAttribute","MenuFloating","anchorElement","onClick","_$delegateEvents"],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { type JSX } from "solid-js";
|
|
2
|
+
import { type Ref } from "../../../primitives/mergeRefs";
|
|
3
|
+
export type PaginationColor = "default" | "primary" | "secondary" | "error" | "success" | "warning" | "info";
|
|
4
|
+
export interface PaginationProps extends Omit<JSX.HTMLAttributes<HTMLElement>, "onChange"> {
|
|
5
|
+
/** Total number of pages. */
|
|
6
|
+
count: number;
|
|
7
|
+
/** Current page (1-based). */
|
|
8
|
+
page: number;
|
|
9
|
+
/** Pages shown on each side of the current page. */
|
|
10
|
+
siblingCount?: number;
|
|
11
|
+
/** Pages always shown at the start and end. */
|
|
12
|
+
boundaryCount?: number;
|
|
13
|
+
size?: "small" | "medium";
|
|
14
|
+
/** Item style. */
|
|
15
|
+
variant?: "filled" | "outlined";
|
|
16
|
+
/** Item shape. */
|
|
17
|
+
shape?: "rounded" | "circular";
|
|
18
|
+
color?: PaginationColor;
|
|
19
|
+
disabled?: boolean;
|
|
20
|
+
showFirstButton?: boolean;
|
|
21
|
+
showLastButton?: boolean;
|
|
22
|
+
hidePrevButton?: boolean;
|
|
23
|
+
hideNextButton?: boolean;
|
|
24
|
+
onChange?: (page: number) => void;
|
|
25
|
+
ref?: Ref<HTMLElement>;
|
|
26
|
+
}
|
|
27
|
+
export declare function Pagination(props: PaginationProps): JSX.Element;
|
|
28
|
+
export default Pagination;
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { use as A, spread as E, mergeProps as L, insert as m, createComponent as _, effect as x, className as y, setAttribute as k, template as w, delegateEvents as z } from "solid-js/web";
|
|
2
|
+
import '../../../assets/styles/less/components/pagination/pagination.entry.css';/* empty css */
|
|
3
|
+
import { mergeProps as F, splitProps as N, For as R, Show as P } from "solid-js";
|
|
4
|
+
import M from "clsx";
|
|
5
|
+
import { mergeRefs as S } from "../../../primitives/mergeRefs.js";
|
|
6
|
+
import { Icon as D } from "../../base/icon/icon.js";
|
|
7
|
+
var H = /* @__PURE__ */ w('<li><button type=button class="smwb-pagination__item smwb-pagination__nav">'), I = /* @__PURE__ */ w("<nav><ul class=smwb-pagination__list>"), q = /* @__PURE__ */ w("<li><button type=button>"), K = /* @__PURE__ */ w("<li class=smwb-pagination__ellipsis aria-hidden=true>…");
|
|
8
|
+
const b = (n, c) => Array.from({
|
|
9
|
+
length: Math.max(c - n + 1, 0)
|
|
10
|
+
}, (e, t) => n + t), O = (n, c, e, t) => {
|
|
11
|
+
const d = b(1, Math.min(t, n)), p = b(Math.max(n - t + 1, t + 1), n), h = Math.max(Math.min(c - e, n - t - e * 2 - 1), t + 2), f = Math.min(Math.max(c + e, t + e * 2 + 2), p.length > 0 ? p[0] - 2 : n - 1);
|
|
12
|
+
return [...d, ...h > t + 2 ? ["start-ellipsis"] : t + 1 < n - t ? [t + 1] : [], ...b(h, f), ...f < n - t - 1 ? ["end-ellipsis"] : n - t > t ? [n - t] : [], ...p];
|
|
13
|
+
};
|
|
14
|
+
function V(n) {
|
|
15
|
+
const c = F({
|
|
16
|
+
siblingCount: 1,
|
|
17
|
+
boundaryCount: 1,
|
|
18
|
+
size: "medium",
|
|
19
|
+
variant: "filled",
|
|
20
|
+
shape: "circular",
|
|
21
|
+
color: "default",
|
|
22
|
+
disabled: !1,
|
|
23
|
+
showFirstButton: !1,
|
|
24
|
+
showLastButton: !1,
|
|
25
|
+
hidePrevButton: !1,
|
|
26
|
+
hideNextButton: !1
|
|
27
|
+
}, n), [e, t] = N(c, ["class", "count", "page", "siblingCount", "boundaryCount", "size", "variant", "shape", "color", "disabled", "showFirstButton", "showLastButton", "hidePrevButton", "hideNextButton", "onChange", "ref"]);
|
|
28
|
+
let d;
|
|
29
|
+
const p = (a) => {
|
|
30
|
+
e.disabled || a === e.page || a < 1 || a > e.count || e.onChange?.(a);
|
|
31
|
+
}, h = (a) => {
|
|
32
|
+
if (!["ArrowLeft", "ArrowRight", "Home", "End"].includes(a.key)) return;
|
|
33
|
+
const i = Array.from(d?.querySelectorAll("button.smwb-pagination__item:not(:disabled)") ?? []);
|
|
34
|
+
if (i.length === 0) return;
|
|
35
|
+
const r = i.indexOf(document.activeElement);
|
|
36
|
+
let s = r;
|
|
37
|
+
a.key === "ArrowRight" ? s = Math.min(r + 1, i.length - 1) : a.key === "ArrowLeft" ? s = Math.max(r - 1, 0) : a.key === "Home" ? s = 0 : a.key === "End" && (s = i.length - 1), a.preventDefault(), i[s]?.focus();
|
|
38
|
+
}, f = () => O(e.count, e.page, e.siblingCount, e.boundaryCount), u = (a, i, r, s) => _(P, {
|
|
39
|
+
when: !s,
|
|
40
|
+
get children() {
|
|
41
|
+
var g = H(), l = g.firstChild;
|
|
42
|
+
return l.$$click = () => p(i), k(l, "aria-label", a), m(l, _(D, {
|
|
43
|
+
name: r,
|
|
44
|
+
get size() {
|
|
45
|
+
return e.size === "small" ? 16 : 18;
|
|
46
|
+
}
|
|
47
|
+
})), x(() => l.disabled = e.disabled || i < 1 || i > e.count), g;
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
return (() => {
|
|
51
|
+
var a = I(), i = a.firstChild, r = S(e.ref, (s) => d = s);
|
|
52
|
+
return typeof r == "function" && A(r, a), E(a, L(t, {
|
|
53
|
+
"data-testid": "pagination",
|
|
54
|
+
"aria-label": "pagination",
|
|
55
|
+
get class() {
|
|
56
|
+
return M("smwb-pagination", `smwb-pagination_${e.size}`, `smwb-pagination_${e.variant}`, `smwb-pagination_shape-${e.shape}`, e.color !== "default" && `smwb-pagination_color-${e.color}`, {
|
|
57
|
+
"smwb-pagination_disabled": e.disabled
|
|
58
|
+
}, e.class);
|
|
59
|
+
}
|
|
60
|
+
}), !1, !0), i.$$keydown = h, m(i, () => u("First page", 1, "first_page", !e.showFirstButton), null), m(i, () => u("Previous page", e.page - 1, "chevron_left", e.hidePrevButton), null), m(i, _(R, {
|
|
61
|
+
get each() {
|
|
62
|
+
return f();
|
|
63
|
+
},
|
|
64
|
+
children: (s) => _(P, {
|
|
65
|
+
when: typeof s == "number",
|
|
66
|
+
get fallback() {
|
|
67
|
+
return K();
|
|
68
|
+
},
|
|
69
|
+
get children() {
|
|
70
|
+
var g = q(), l = g.firstChild;
|
|
71
|
+
return l.$$click = () => p(s), m(l, s), x((o) => {
|
|
72
|
+
var v = M("smwb-pagination__item", {
|
|
73
|
+
"smwb-pagination__item_selected": s === e.page
|
|
74
|
+
}), $ = s === e.page ? "page" : void 0, B = e.disabled;
|
|
75
|
+
return v !== o.e && y(l, o.e = v), $ !== o.t && k(l, "aria-current", o.t = $), B !== o.a && (l.disabled = o.a = B), o;
|
|
76
|
+
}, {
|
|
77
|
+
e: void 0,
|
|
78
|
+
t: void 0,
|
|
79
|
+
a: void 0
|
|
80
|
+
}), g;
|
|
81
|
+
}
|
|
82
|
+
})
|
|
83
|
+
}), null), m(i, () => u("Next page", e.page + 1, "chevron_right", e.hideNextButton), null), m(i, () => u("Last page", e.count, "last_page", !e.showLastButton), null), a;
|
|
84
|
+
})();
|
|
85
|
+
}
|
|
86
|
+
z(["click", "keydown"]);
|
|
87
|
+
export {
|
|
88
|
+
V as Pagination
|
|
89
|
+
};
|
|
90
|
+
//# sourceMappingURL=pagination.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pagination.js","sources":["../../../../src/components/navigation/pagination/pagination.tsx"],"sourcesContent":["import { type JSX, For, Show, mergeProps, splitProps } from \"solid-js\";\nimport cn from \"clsx\";\nimport { Icon } from \"../../base/icon\";\nimport { mergeRefs, type Ref } from \"../../../primitives/mergeRefs\";\n\nexport type PaginationColor = \"default\" | \"primary\" | \"secondary\" | \"error\" | \"success\" | \"warning\" | \"info\";\n\nexport interface PaginationProps extends Omit<JSX.HTMLAttributes<HTMLElement>, \"onChange\"> {\n /** Total number of pages. */\n count: number;\n /** Current page (1-based). */\n page: number;\n /** Pages shown on each side of the current page. */\n siblingCount?: number;\n /** Pages always shown at the start and end. */\n boundaryCount?: number;\n size?: \"small\" | \"medium\";\n /** Item style. */\n variant?: \"filled\" | \"outlined\";\n /** Item shape. */\n shape?: \"rounded\" | \"circular\";\n color?: PaginationColor;\n disabled?: boolean;\n showFirstButton?: boolean;\n showLastButton?: boolean;\n hidePrevButton?: boolean;\n hideNextButton?: boolean;\n onChange?: (page: number) => void;\n ref?: Ref<HTMLElement>;\n}\n\ntype PaginationItem = number | \"start-ellipsis\" | \"end-ellipsis\";\n\nconst range = (start: number, end: number): number[] =>\n Array.from({ length: Math.max(end - start + 1, 0) }, (_, i) => start + i);\n\nconst buildItems = (count: number, page: number, siblingCount: number, boundaryCount: number): PaginationItem[] => {\n const startPages = range(1, Math.min(boundaryCount, count));\n const endPages = range(Math.max(count - boundaryCount + 1, boundaryCount + 1), count);\n\n const siblingsStart = Math.max(\n Math.min(page - siblingCount, count - boundaryCount - siblingCount * 2 - 1),\n boundaryCount + 2\n );\n const siblingsEnd = Math.min(\n Math.max(page + siblingCount, boundaryCount + siblingCount * 2 + 2),\n endPages.length > 0 ? endPages[0]! - 2 : count - 1\n );\n\n return [\n ...startPages,\n ...(siblingsStart > boundaryCount + 2\n ? ([\"start-ellipsis\"] as PaginationItem[])\n : boundaryCount + 1 < count - boundaryCount\n ? [boundaryCount + 1]\n : []),\n ...range(siblingsStart, siblingsEnd),\n ...(siblingsEnd < count - boundaryCount - 1\n ? ([\"end-ellipsis\"] as PaginationItem[])\n : count - boundaryCount > boundaryCount\n ? [count - boundaryCount]\n : []),\n ...endPages,\n ];\n};\n\nexport function Pagination(props: PaginationProps): JSX.Element {\n const merged = mergeProps(\n {\n siblingCount: 1,\n boundaryCount: 1,\n size: \"medium\" as const,\n variant: \"filled\" as const,\n shape: \"circular\" as const,\n color: \"default\" as PaginationColor,\n disabled: false,\n showFirstButton: false,\n showLastButton: false,\n hidePrevButton: false,\n hideNextButton: false,\n },\n props\n );\n const [local, rest] = splitProps(merged, [\n \"class\",\n \"count\",\n \"page\",\n \"siblingCount\",\n \"boundaryCount\",\n \"size\",\n \"variant\",\n \"shape\",\n \"color\",\n \"disabled\",\n \"showFirstButton\",\n \"showLastButton\",\n \"hidePrevButton\",\n \"hideNextButton\",\n \"onChange\",\n \"ref\",\n ]);\n\n let navEl: HTMLElement | undefined;\n\n const go = (target: number): void => {\n if (local.disabled || target === local.page || target < 1 || target > local.count) return;\n local.onChange?.(target);\n };\n\n const onKeyDown: JSX.EventHandler<HTMLUListElement, KeyboardEvent> = (event) => {\n if (![\"ArrowLeft\", \"ArrowRight\", \"Home\", \"End\"].includes(event.key)) return;\n const buttons = Array.from(\n navEl?.querySelectorAll<HTMLButtonElement>(\"button.smwb-pagination__item:not(:disabled)\") ?? []\n );\n if (buttons.length === 0) return;\n const current = buttons.indexOf(document.activeElement as HTMLButtonElement);\n let next = current;\n if (event.key === \"ArrowRight\") next = Math.min(current + 1, buttons.length - 1);\n else if (event.key === \"ArrowLeft\") next = Math.max(current - 1, 0);\n else if (event.key === \"Home\") next = 0;\n else if (event.key === \"End\") next = buttons.length - 1;\n event.preventDefault();\n buttons[next]?.focus();\n };\n\n const items = (): PaginationItem[] => buildItems(local.count, local.page, local.siblingCount, local.boundaryCount);\n\n const navButton = (label: string, target: number, iconName: string, hidden?: boolean): JSX.Element => (\n <Show when={!hidden}>\n <li>\n <button\n type=\"button\"\n class=\"smwb-pagination__item smwb-pagination__nav\"\n aria-label={label}\n disabled={local.disabled || target < 1 || target > local.count}\n onClick={() => go(target)}\n >\n <Icon name={iconName} size={local.size === \"small\" ? 16 : 18} />\n </button>\n </li>\n </Show>\n );\n\n return (\n <nav\n {...rest}\n ref={mergeRefs(local.ref, (el) => (navEl = el))}\n data-testid=\"pagination\"\n aria-label=\"pagination\"\n class={cn(\n \"smwb-pagination\",\n `smwb-pagination_${local.size}`,\n `smwb-pagination_${local.variant}`,\n `smwb-pagination_shape-${local.shape}`,\n local.color !== \"default\" && `smwb-pagination_color-${local.color}`,\n { \"smwb-pagination_disabled\": local.disabled },\n local.class\n )}\n >\n <ul class=\"smwb-pagination__list\" onKeyDown={onKeyDown}>\n {navButton(\"First page\", 1, \"first_page\", !local.showFirstButton)}\n {navButton(\"Previous page\", local.page - 1, \"chevron_left\", local.hidePrevButton)}\n <For each={items()}>\n {(item) => (\n <Show\n when={typeof item === \"number\"}\n fallback={\n <li class=\"smwb-pagination__ellipsis\" aria-hidden=\"true\">\n …\n </li>\n }\n >\n <li>\n <button\n type=\"button\"\n class={cn(\"smwb-pagination__item\", { \"smwb-pagination__item_selected\": item === local.page })}\n aria-current={item === local.page ? \"page\" : undefined}\n disabled={local.disabled}\n onClick={() => go(item as number)}\n >\n {item}\n </button>\n </li>\n </Show>\n )}\n </For>\n {navButton(\"Next page\", local.page + 1, \"chevron_right\", local.hideNextButton)}\n {navButton(\"Last page\", local.count, \"last_page\", !local.showLastButton)}\n </ul>\n </nav>\n );\n}\n\nexport default Pagination;\n"],"names":["range","start","end","Array","from","length","Math","max","_","i","buildItems","count","page","siblingCount","boundaryCount","startPages","min","endPages","siblingsStart","siblingsEnd","Pagination","props","merged","mergeProps","size","variant","shape","color","disabled","showFirstButton","showLastButton","hidePrevButton","hideNextButton","local","rest","splitProps","navEl","go","target","onChange","onKeyDown","event","includes","key","buttons","querySelectorAll","current","indexOf","document","activeElement","next","preventDefault","focus","items","navButton","label","iconName","hidden","_$createComponent","Show","when","children","_el$","_tmpl$","_el$2","firstChild","$$click","_$setAttribute","_$insert","Icon","name","_$effect","_el$3","_tmpl$2","_el$4","_ref$","mergeRefs","ref","el","_$use","_$spread","_$mergeProps","cn","class","$$keydown","For","each","item","fallback","_tmpl$4","_el$5","_tmpl$3","_el$6","_p$","_v$","_v$2","undefined","_v$3","e","_$className","t","a","_$delegateEvents"],"mappings":"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"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { type JSX } from "solid-js";
|
|
2
|
+
import { type Ref } from "../../../primitives/mergeRefs";
|
|
3
|
+
export type SidebarVariant = "compact" | "default" | "compactMini";
|
|
4
|
+
export interface SidebarMenuItemProps extends Omit<JSX.HTMLAttributes<HTMLDivElement>, "title"> {
|
|
5
|
+
icon?: JSX.Element;
|
|
6
|
+
title: string;
|
|
7
|
+
isActive?: boolean;
|
|
8
|
+
onClick?: JSX.EventHandlerUnion<HTMLDivElement, MouseEvent>;
|
|
9
|
+
as?: string | undefined;
|
|
10
|
+
href?: string | undefined;
|
|
11
|
+
variant?: SidebarVariant | undefined;
|
|
12
|
+
}
|
|
13
|
+
export interface SidebarProps extends JSX.HTMLAttributes<HTMLElement> {
|
|
14
|
+
variant?: SidebarVariant;
|
|
15
|
+
menuItems?: SidebarMenuItemProps[];
|
|
16
|
+
/** Controlled index of the active menu item. */
|
|
17
|
+
activeItem?: number | null;
|
|
18
|
+
/** Default active index (uncontrolled). */
|
|
19
|
+
defaultActiveItem?: number | null;
|
|
20
|
+
/** Called with the index of the activated item. */
|
|
21
|
+
onActiveItemChange?: (index: number) => void;
|
|
22
|
+
/** Render a built-in toggle that collapses the rail to an icon-only mini rail. */
|
|
23
|
+
collapsible?: boolean;
|
|
24
|
+
/** Controlled collapsed state. */
|
|
25
|
+
collapsed?: boolean;
|
|
26
|
+
/** Initial collapsed state (uncontrolled). */
|
|
27
|
+
defaultCollapsed?: boolean;
|
|
28
|
+
/** Called whenever the collapsed state changes. */
|
|
29
|
+
onCollapsedChange?: (collapsed: boolean) => void;
|
|
30
|
+
/** Accessible label for the built-in collapse toggle. */
|
|
31
|
+
collapseToggleAriaLabel?: string;
|
|
32
|
+
ref?: Ref<HTMLElement>;
|
|
33
|
+
}
|
|
34
|
+
export declare function Sidebar(props: SidebarProps): JSX.Element;
|
|
35
|
+
export default Sidebar;
|