@tessera-ui/core 0.4.0 → 0.5.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/README.md +21 -12
- package/dist/components/index.js +1 -1
- package/dist/components/{p-O8aQgWRZ.js → p-2ydrBbXU.js} +2 -2
- package/dist/components/p-A0saON5E.js +2 -0
- package/dist/components/p-B046Q9mB.js +2 -0
- package/dist/components/{p-C7JaUlNB.js → p-B4_cDa1A.js} +2 -2
- package/dist/components/{p-BdzH6wlc.js → p-BCv5H01l.js} +2 -2
- package/dist/components/p-BGnwokOT.js +2 -0
- package/dist/components/p-BMu62WKn.js +2 -0
- package/dist/components/p-BT1uIgln.js +2 -0
- package/dist/components/p-BUWioFPq.js +2 -0
- package/dist/components/{p-v-L32wKy.js → p-BdeYJARM.js} +2 -2
- package/dist/components/{p-DhQ7X_TL.js → p-BnX1KON4.js} +2 -2
- package/dist/components/{p-DwJ7Jt3k.js → p-BsX7YKf7.js} +2 -2
- package/dist/components/p-BzSptDZ8.js +2 -0
- package/dist/components/p-C4C_ntgI.js +2 -0
- package/dist/components/p-C4jvuley.js +2 -0
- package/dist/components/{p-BP-fZfRb.js → p-CGcBFblJ.js} +2 -2
- package/dist/components/p-CJvp9tpd.js +2 -0
- package/dist/components/{p-DD986daz.js → p-COpYtD-7.js} +2 -2
- package/dist/components/{p-C8wd1644.js → p-CV-_3uEV.js} +2 -2
- package/dist/components/p-CXpxj5LF.js +2 -0
- package/dist/components/{p-CEQXPxzU.js → p-Ccf23RDb.js} +2 -2
- package/dist/components/{p-SopsdO_f.js → p-Ccpbt1Ou.js} +2 -2
- package/dist/components/{p-DMPxu5Po.js → p-CgLMjfKE.js} +2 -2
- package/dist/components/p-D2rKVDAH.js +2 -0
- package/dist/components/{p-zveaarwa.js → p-D33ZtGZF.js} +2 -2
- package/dist/components/{p-Fot2uNwg.js → p-DHBR8Qn_.js} +2 -2
- package/dist/components/{p-faVXXwqR.js → p-DOtFbUdh.js} +2 -2
- package/dist/components/{p-BjiDgszq.js → p-DelBi-6m.js} +2 -2
- package/dist/components/{p-Cy_Ad-Jy.js → p-DgbNUE6a.js} +2 -2
- package/dist/components/{p-DTAVTqnc.js → p-I5_iFNxb.js} +2 -2
- package/dist/components/p-IZ8R1wr2.js +2 -0
- package/dist/components/{p-B_NL55YI.js → p-LcG5Mdyq.js} +2 -2
- package/dist/components/{p-BcoU0ISN.js → p-XuOQBHK0.js} +2 -2
- package/dist/components/p-_EbBBIv1.js +2 -0
- package/dist/components/p-_vCbug8y.js +2 -0
- package/dist/components/{p-B0ZXNFSa.js → p-b-zWbmXM.js} +2 -2
- package/dist/components/{p-DwUH8YQW.js → p-e-hrdd0t.js} +2 -2
- package/dist/components/p-gtluIo4p.js +2 -0
- package/dist/components/p-o-GUod2W.js +2 -0
- package/dist/components/{p-DooMF1E0.js → p-w9y5VC-3.js} +2 -2
- package/dist/components/ts-accordion-item.js +1 -1
- package/dist/components/ts-accordion.js +1 -1
- package/dist/components/ts-alert.js +1 -1
- package/dist/components/ts-avatar.js +1 -1
- package/dist/components/ts-badge.js +1 -1
- package/dist/components/ts-banner.js +1 -1
- package/dist/components/ts-breadcrumb-item.js +1 -1
- package/dist/components/ts-breadcrumb.js +1 -1
- package/dist/components/ts-button.js +1 -1
- package/dist/components/ts-card.js +1 -1
- package/dist/components/ts-checkbox.js +1 -1
- package/dist/components/ts-chip.js +1 -1
- package/dist/components/ts-container.js +1 -1
- package/dist/components/ts-date-picker.js +1 -1
- package/dist/components/ts-dialog.js +1 -1
- package/dist/components/ts-divider.js +1 -1
- package/dist/components/ts-drawer.js +1 -1
- package/dist/components/ts-empty-state.js +1 -1
- package/dist/components/ts-file-upload.js +1 -1
- package/dist/components/ts-grid.js +1 -1
- package/dist/components/ts-icon.js +1 -1
- package/dist/components/ts-input.js +1 -1
- package/dist/components/ts-menu-item.js +1 -1
- package/dist/components/ts-menu.js +1 -1
- package/dist/components/ts-modal.js +1 -1
- package/dist/components/ts-nav-item.js +1 -1
- package/dist/components/ts-nav.js +1 -1
- package/dist/components/ts-pagination.js +1 -1
- package/dist/components/ts-popover.js +1 -1
- package/dist/components/ts-progress.js +1 -1
- package/dist/components/ts-radio.js +1 -1
- package/dist/components/ts-row.js +1 -1
- package/dist/components/ts-select.js +1 -1
- package/dist/components/ts-skeleton.js +1 -1
- package/dist/components/ts-slider.js +1 -1
- package/dist/components/ts-spacer.js +1 -1
- package/dist/components/ts-spinner.js +1 -1
- package/dist/components/ts-stack.js +1 -1
- package/dist/components/ts-step.js +1 -1
- package/dist/components/ts-stepper.js +1 -1
- package/dist/components/ts-switch-group.js +1 -1
- package/dist/components/ts-switch-option.js +1 -1
- package/dist/components/ts-tab-panel.js +1 -1
- package/dist/components/ts-table.js +1 -1
- package/dist/components/ts-tabs.js +1 -1
- package/dist/components/ts-textarea.js +1 -1
- package/dist/components/ts-toast.js +1 -1
- package/dist/components/ts-toggle.js +1 -1
- package/dist/components/ts-toolbar.js +1 -1
- package/dist/components/ts-tooltip.js +1 -1
- package/dist/components/ts-tree-item.js +1 -1
- package/dist/components/ts-tree.js +1 -1
- package/package.json +24 -3
- package/dist/cjs/aria-CeYIvz3U.js.map +0 -1
- package/dist/cjs/index-Bel_x2OU.js.map +0 -1
- package/dist/cjs/index.cjs.js.map +0 -1
- package/dist/cjs/loader.cjs.js.map +0 -1
- package/dist/cjs/lucide-B1gCqJ3G.js.map +0 -1
- package/dist/cjs/tessera-ui.cjs.js.map +0 -1
- package/dist/cjs/ts-accordion-item.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-accordion.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-alert.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-avatar.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-badge.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-banner.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-breadcrumb-item.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-breadcrumb.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-button.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-card.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-checkbox.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-chip.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-container.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-date-picker.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-dialog.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-divider.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-drawer.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-empty-state.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-file-upload.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-grid.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-icon-CfbhgAgr.js.map +0 -1
- package/dist/cjs/ts-icon.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-input.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-menu-item.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-menu.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-modal.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-nav-item.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-nav.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-pagination.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-popover.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-progress.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-radio.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-row.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-select.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-skeleton.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-slider.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-spacer.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-spinner.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-stack.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-step.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-stepper.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-switch-group.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-switch-option.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-tab-panel.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-table.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-tabs.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-textarea.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-toast.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-toggle.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-toolbar.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-tooltip.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-tree-item.cjs.entry.js.map +0 -1
- package/dist/cjs/ts-tree.cjs.entry.js.map +0 -1
- package/dist/collection/components/accordion/accordion-item.js.map +0 -1
- package/dist/collection/components/accordion/accordion-item.stories.js +0 -4
- package/dist/collection/components/accordion/accordion-item.stories.js.map +0 -1
- package/dist/collection/components/accordion/accordion.js.map +0 -1
- package/dist/collection/components/accordion/accordion.stories.js +0 -90
- package/dist/collection/components/accordion/accordion.stories.js.map +0 -1
- package/dist/collection/components/alert/alert.js.map +0 -1
- package/dist/collection/components/alert/alert.stories.js +0 -128
- package/dist/collection/components/alert/alert.stories.js.map +0 -1
- package/dist/collection/components/avatar/avatar.js.map +0 -1
- package/dist/collection/components/avatar/avatar.stories.js +0 -138
- package/dist/collection/components/avatar/avatar.stories.js.map +0 -1
- package/dist/collection/components/badge/badge.js.map +0 -1
- package/dist/collection/components/badge/badge.stories.js +0 -193
- package/dist/collection/components/badge/badge.stories.js.map +0 -1
- package/dist/collection/components/banner/banner.js.map +0 -1
- package/dist/collection/components/banner/banner.stories.js +0 -92
- package/dist/collection/components/banner/banner.stories.js.map +0 -1
- package/dist/collection/components/breadcrumb/breadcrumb-item.js.map +0 -1
- package/dist/collection/components/breadcrumb/breadcrumb-item.stories.js +0 -4
- package/dist/collection/components/breadcrumb/breadcrumb-item.stories.js.map +0 -1
- package/dist/collection/components/breadcrumb/breadcrumb.js.map +0 -1
- package/dist/collection/components/breadcrumb/breadcrumb.stories.js +0 -88
- package/dist/collection/components/breadcrumb/breadcrumb.stories.js.map +0 -1
- package/dist/collection/components/button/button.js.map +0 -1
- package/dist/collection/components/button/button.stories.js +0 -219
- package/dist/collection/components/button/button.stories.js.map +0 -1
- package/dist/collection/components/card/card.js.map +0 -1
- package/dist/collection/components/card/card.stories.js +0 -221
- package/dist/collection/components/card/card.stories.js.map +0 -1
- package/dist/collection/components/checkbox/checkbox.js.map +0 -1
- package/dist/collection/components/checkbox/checkbox.stories.js +0 -90
- package/dist/collection/components/checkbox/checkbox.stories.js.map +0 -1
- package/dist/collection/components/chip/chip.js.map +0 -1
- package/dist/collection/components/chip/chip.stories.js +0 -139
- package/dist/collection/components/chip/chip.stories.js.map +0 -1
- package/dist/collection/components/container/container.js.map +0 -1
- package/dist/collection/components/container/container.stories.js +0 -138
- package/dist/collection/components/container/container.stories.js.map +0 -1
- package/dist/collection/components/date-picker/date-picker.js.map +0 -1
- package/dist/collection/components/date-picker/date-picker.stories.js +0 -119
- package/dist/collection/components/date-picker/date-picker.stories.js.map +0 -1
- package/dist/collection/components/dialog/dialog.js.map +0 -1
- package/dist/collection/components/dialog/dialog.stories.js +0 -147
- package/dist/collection/components/dialog/dialog.stories.js.map +0 -1
- package/dist/collection/components/divider/divider.js.map +0 -1
- package/dist/collection/components/divider/divider.stories.js +0 -94
- package/dist/collection/components/divider/divider.stories.js.map +0 -1
- package/dist/collection/components/drawer/drawer.js.map +0 -1
- package/dist/collection/components/drawer/drawer.stories.js +0 -143
- package/dist/collection/components/drawer/drawer.stories.js.map +0 -1
- package/dist/collection/components/empty-state/empty-state.js.map +0 -1
- package/dist/collection/components/empty-state/empty-state.stories.js +0 -113
- package/dist/collection/components/empty-state/empty-state.stories.js.map +0 -1
- package/dist/collection/components/file-upload/file-upload.js.map +0 -1
- package/dist/collection/components/file-upload/file-upload.stories.js +0 -107
- package/dist/collection/components/file-upload/file-upload.stories.js.map +0 -1
- package/dist/collection/components/grid/grid.js.map +0 -1
- package/dist/collection/components/grid/grid.stories.js +0 -134
- package/dist/collection/components/grid/grid.stories.js.map +0 -1
- package/dist/collection/components/icon/icon-registry.js.map +0 -1
- package/dist/collection/components/icon/icon.js.map +0 -1
- package/dist/collection/components/icon/icon.stories.js +0 -119
- package/dist/collection/components/icon/icon.stories.js.map +0 -1
- package/dist/collection/components/input/input.js.map +0 -1
- package/dist/collection/components/input/input.stories.js +0 -151
- package/dist/collection/components/input/input.stories.js.map +0 -1
- package/dist/collection/components/menu/menu-item.js.map +0 -1
- package/dist/collection/components/menu/menu-item.stories.js +0 -4
- package/dist/collection/components/menu/menu-item.stories.js.map +0 -1
- package/dist/collection/components/menu/menu.js.map +0 -1
- package/dist/collection/components/menu/menu.stories.js +0 -126
- package/dist/collection/components/menu/menu.stories.js.map +0 -1
- package/dist/collection/components/modal/modal.js.map +0 -1
- package/dist/collection/components/modal/modal.stories.js +0 -233
- package/dist/collection/components/modal/modal.stories.js.map +0 -1
- package/dist/collection/components/nav/nav-item.js.map +0 -1
- package/dist/collection/components/nav/nav-item.stories.js +0 -4
- package/dist/collection/components/nav/nav-item.stories.js.map +0 -1
- package/dist/collection/components/nav/nav.js.map +0 -1
- package/dist/collection/components/nav/nav.stories.js +0 -106
- package/dist/collection/components/nav/nav.stories.js.map +0 -1
- package/dist/collection/components/pagination/pagination.js.map +0 -1
- package/dist/collection/components/pagination/pagination.stories.js +0 -92
- package/dist/collection/components/pagination/pagination.stories.js.map +0 -1
- package/dist/collection/components/popover/popover.js.map +0 -1
- package/dist/collection/components/popover/popover.stories.js +0 -112
- package/dist/collection/components/popover/popover.stories.js.map +0 -1
- package/dist/collection/components/progress/progress.js.map +0 -1
- package/dist/collection/components/progress/progress.stories.js +0 -132
- package/dist/collection/components/progress/progress.stories.js.map +0 -1
- package/dist/collection/components/radio/radio.js.map +0 -1
- package/dist/collection/components/radio/radio.stories.js +0 -77
- package/dist/collection/components/radio/radio.stories.js.map +0 -1
- package/dist/collection/components/row/row.js.map +0 -1
- package/dist/collection/components/row/row.stories.js +0 -172
- package/dist/collection/components/row/row.stories.js.map +0 -1
- package/dist/collection/components/select/select.js.map +0 -1
- package/dist/collection/components/select/select.stories.js +0 -138
- package/dist/collection/components/select/select.stories.js.map +0 -1
- package/dist/collection/components/skeleton/skeleton.js.map +0 -1
- package/dist/collection/components/skeleton/skeleton.stories.js +0 -140
- package/dist/collection/components/skeleton/skeleton.stories.js.map +0 -1
- package/dist/collection/components/slider/slider.js.map +0 -1
- package/dist/collection/components/slider/slider.stories.js +0 -100
- package/dist/collection/components/slider/slider.stories.js.map +0 -1
- package/dist/collection/components/spacer/spacer.js.map +0 -1
- package/dist/collection/components/spacer/spacer.stories.js +0 -90
- package/dist/collection/components/spacer/spacer.stories.js.map +0 -1
- package/dist/collection/components/spinner/spinner.js.map +0 -1
- package/dist/collection/components/spinner/spinner.stories.js +0 -88
- package/dist/collection/components/spinner/spinner.stories.js.map +0 -1
- package/dist/collection/components/stack/stack.js.map +0 -1
- package/dist/collection/components/stack/stack.stories.js +0 -121
- package/dist/collection/components/stack/stack.stories.js.map +0 -1
- package/dist/collection/components/stepper/step.js.map +0 -1
- package/dist/collection/components/stepper/step.stories.js +0 -4
- package/dist/collection/components/stepper/step.stories.js.map +0 -1
- package/dist/collection/components/stepper/stepper.js.map +0 -1
- package/dist/collection/components/stepper/stepper.stories.js +0 -130
- package/dist/collection/components/stepper/stepper.stories.js.map +0 -1
- package/dist/collection/components/switch-group/switch-group.js.map +0 -1
- package/dist/collection/components/switch-group/switch-group.stories.js +0 -132
- package/dist/collection/components/switch-group/switch-group.stories.js.map +0 -1
- package/dist/collection/components/switch-group/switch-option.js.map +0 -1
- package/dist/collection/components/switch-group/switch-option.stories.js +0 -4
- package/dist/collection/components/switch-group/switch-option.stories.js.map +0 -1
- package/dist/collection/components/table/table.js.map +0 -1
- package/dist/collection/components/table/table.stories.js +0 -147
- package/dist/collection/components/table/table.stories.js.map +0 -1
- package/dist/collection/components/tabs/tab-panel.js.map +0 -1
- package/dist/collection/components/tabs/tab-panel.stories.js +0 -4
- package/dist/collection/components/tabs/tab-panel.stories.js.map +0 -1
- package/dist/collection/components/tabs/tabs.js.map +0 -1
- package/dist/collection/components/tabs/tabs.stories.js +0 -187
- package/dist/collection/components/tabs/tabs.stories.js.map +0 -1
- package/dist/collection/components/textarea/textarea.js.map +0 -1
- package/dist/collection/components/textarea/textarea.stories.js +0 -130
- package/dist/collection/components/textarea/textarea.stories.js.map +0 -1
- package/dist/collection/components/toast/toast.js.map +0 -1
- package/dist/collection/components/toast/toast.stories.js +0 -91
- package/dist/collection/components/toast/toast.stories.js.map +0 -1
- package/dist/collection/components/toggle/toggle.js.map +0 -1
- package/dist/collection/components/toggle/toggle.stories.js +0 -145
- package/dist/collection/components/toggle/toggle.stories.js.map +0 -1
- package/dist/collection/components/toolbar/toolbar.js.map +0 -1
- package/dist/collection/components/toolbar/toolbar.stories.js +0 -131
- package/dist/collection/components/toolbar/toolbar.stories.js.map +0 -1
- package/dist/collection/components/tooltip/tooltip.js.map +0 -1
- package/dist/collection/components/tooltip/tooltip.stories.js +0 -186
- package/dist/collection/components/tooltip/tooltip.stories.js.map +0 -1
- package/dist/collection/components/tree/tree-item.js.map +0 -1
- package/dist/collection/components/tree/tree-item.stories.js +0 -4
- package/dist/collection/components/tree/tree-item.stories.js.map +0 -1
- package/dist/collection/components/tree/tree.js.map +0 -1
- package/dist/collection/components/tree/tree.stories.js +0 -121
- package/dist/collection/components/tree/tree.stories.js.map +0 -1
- package/dist/collection/index.js.map +0 -1
- package/dist/collection/theme/tokens.js.map +0 -1
- package/dist/collection/types/index.js.map +0 -1
- package/dist/collection/utils/aria.js.map +0 -1
- package/dist/collection/utils/dom.js.map +0 -1
- package/dist/collection/utils/events.js.map +0 -1
- package/dist/components/index.js.map +0 -1
- package/dist/components/p-6RDSLDuS.js +0 -2
- package/dist/components/p-6RDSLDuS.js.map +0 -1
- package/dist/components/p-B0ZXNFSa.js.map +0 -1
- package/dist/components/p-BCgm2utU.js +0 -2
- package/dist/components/p-BCgm2utU.js.map +0 -1
- package/dist/components/p-BFN5hUo4.js +0 -2
- package/dist/components/p-BFN5hUo4.js.map +0 -1
- package/dist/components/p-BOxYojS-.js.map +0 -1
- package/dist/components/p-BP-fZfRb.js.map +0 -1
- package/dist/components/p-B_NL55YI.js.map +0 -1
- package/dist/components/p-BcoU0ISN.js.map +0 -1
- package/dist/components/p-BdzH6wlc.js.map +0 -1
- package/dist/components/p-BeErYjKz.js +0 -2
- package/dist/components/p-BeErYjKz.js.map +0 -1
- package/dist/components/p-BjiDgszq.js.map +0 -1
- package/dist/components/p-BjyTgfXe.js +0 -2
- package/dist/components/p-BjyTgfXe.js.map +0 -1
- package/dist/components/p-BlZHjan9.js +0 -2
- package/dist/components/p-BlZHjan9.js.map +0 -1
- package/dist/components/p-C7JaUlNB.js.map +0 -1
- package/dist/components/p-C8wd1644.js.map +0 -1
- package/dist/components/p-CEQXPxzU.js.map +0 -1
- package/dist/components/p-CGh7W07E.js +0 -2
- package/dist/components/p-CGh7W07E.js.map +0 -1
- package/dist/components/p-CHtE5caV.js +0 -2
- package/dist/components/p-CHtE5caV.js.map +0 -1
- package/dist/components/p-CSNeA_zh.js +0 -2
- package/dist/components/p-CSNeA_zh.js.map +0 -1
- package/dist/components/p-CbHlJvjF.js +0 -2
- package/dist/components/p-CbHlJvjF.js.map +0 -1
- package/dist/components/p-CkQOAizb.js +0 -2
- package/dist/components/p-CkQOAizb.js.map +0 -1
- package/dist/components/p-Cy_Ad-Jy.js.map +0 -1
- package/dist/components/p-DD986daz.js.map +0 -1
- package/dist/components/p-DFnNsZtI.js +0 -2
- package/dist/components/p-DFnNsZtI.js.map +0 -1
- package/dist/components/p-DMPxu5Po.js.map +0 -1
- package/dist/components/p-DMuI5d5r.js +0 -2
- package/dist/components/p-DMuI5d5r.js.map +0 -1
- package/dist/components/p-DPQ1o4MP.js +0 -2
- package/dist/components/p-DPQ1o4MP.js.map +0 -1
- package/dist/components/p-DTAVTqnc.js.map +0 -1
- package/dist/components/p-DhQ7X_TL.js.map +0 -1
- package/dist/components/p-DkpyRqHf.js.map +0 -1
- package/dist/components/p-DlB-KfKY.js +0 -2
- package/dist/components/p-DlB-KfKY.js.map +0 -1
- package/dist/components/p-DooMF1E0.js.map +0 -1
- package/dist/components/p-DwJ7Jt3k.js.map +0 -1
- package/dist/components/p-DwUH8YQW.js.map +0 -1
- package/dist/components/p-Fot2uNwg.js.map +0 -1
- package/dist/components/p-O8aQgWRZ.js.map +0 -1
- package/dist/components/p-SopsdO_f.js.map +0 -1
- package/dist/components/p-TFHAUMKT.js +0 -2
- package/dist/components/p-TFHAUMKT.js.map +0 -1
- package/dist/components/p-faVXXwqR.js.map +0 -1
- package/dist/components/p-lpqZSiIf.js.map +0 -1
- package/dist/components/p-mfB_pP4L.js +0 -2
- package/dist/components/p-mfB_pP4L.js.map +0 -1
- package/dist/components/p-v-L32wKy.js.map +0 -1
- package/dist/components/p-zveaarwa.js.map +0 -1
- package/dist/components/ts-accordion-item.js.map +0 -1
- package/dist/components/ts-accordion.js.map +0 -1
- package/dist/components/ts-alert.js.map +0 -1
- package/dist/components/ts-avatar.js.map +0 -1
- package/dist/components/ts-badge.js.map +0 -1
- package/dist/components/ts-banner.js.map +0 -1
- package/dist/components/ts-breadcrumb-item.js.map +0 -1
- package/dist/components/ts-breadcrumb.js.map +0 -1
- package/dist/components/ts-button.js.map +0 -1
- package/dist/components/ts-card.js.map +0 -1
- package/dist/components/ts-checkbox.js.map +0 -1
- package/dist/components/ts-chip.js.map +0 -1
- package/dist/components/ts-container.js.map +0 -1
- package/dist/components/ts-date-picker.js.map +0 -1
- package/dist/components/ts-dialog.js.map +0 -1
- package/dist/components/ts-divider.js.map +0 -1
- package/dist/components/ts-drawer.js.map +0 -1
- package/dist/components/ts-empty-state.js.map +0 -1
- package/dist/components/ts-file-upload.js.map +0 -1
- package/dist/components/ts-grid.js.map +0 -1
- package/dist/components/ts-icon.js.map +0 -1
- package/dist/components/ts-input.js.map +0 -1
- package/dist/components/ts-menu-item.js.map +0 -1
- package/dist/components/ts-menu.js.map +0 -1
- package/dist/components/ts-modal.js.map +0 -1
- package/dist/components/ts-nav-item.js.map +0 -1
- package/dist/components/ts-nav.js.map +0 -1
- package/dist/components/ts-pagination.js.map +0 -1
- package/dist/components/ts-popover.js.map +0 -1
- package/dist/components/ts-progress.js.map +0 -1
- package/dist/components/ts-radio.js.map +0 -1
- package/dist/components/ts-row.js.map +0 -1
- package/dist/components/ts-select.js.map +0 -1
- package/dist/components/ts-skeleton.js.map +0 -1
- package/dist/components/ts-slider.js.map +0 -1
- package/dist/components/ts-spacer.js.map +0 -1
- package/dist/components/ts-spinner.js.map +0 -1
- package/dist/components/ts-stack.js.map +0 -1
- package/dist/components/ts-step.js.map +0 -1
- package/dist/components/ts-stepper.js.map +0 -1
- package/dist/components/ts-switch-group.js.map +0 -1
- package/dist/components/ts-switch-option.js.map +0 -1
- package/dist/components/ts-tab-panel.js.map +0 -1
- package/dist/components/ts-table.js.map +0 -1
- package/dist/components/ts-tabs.js.map +0 -1
- package/dist/components/ts-textarea.js.map +0 -1
- package/dist/components/ts-toast.js.map +0 -1
- package/dist/components/ts-toggle.js.map +0 -1
- package/dist/components/ts-toolbar.js.map +0 -1
- package/dist/components/ts-tooltip.js.map +0 -1
- package/dist/components/ts-tree-item.js.map +0 -1
- package/dist/components/ts-tree.js.map +0 -1
- package/dist/components.json +0 -12678
- package/dist/esm/aria-lpqZSiIf.js.map +0 -1
- package/dist/esm/index-V8-ENixA.js.map +0 -1
- package/dist/esm/index.js.map +0 -1
- package/dist/esm/loader.js.map +0 -1
- package/dist/esm/lucide-BOxYojS-.js.map +0 -1
- package/dist/esm/tessera-ui.js.map +0 -1
- package/dist/esm/ts-accordion-item.entry.js.map +0 -1
- package/dist/esm/ts-accordion.entry.js.map +0 -1
- package/dist/esm/ts-alert.entry.js.map +0 -1
- package/dist/esm/ts-avatar.entry.js.map +0 -1
- package/dist/esm/ts-badge.entry.js.map +0 -1
- package/dist/esm/ts-banner.entry.js.map +0 -1
- package/dist/esm/ts-breadcrumb-item.entry.js.map +0 -1
- package/dist/esm/ts-breadcrumb.entry.js.map +0 -1
- package/dist/esm/ts-button.entry.js.map +0 -1
- package/dist/esm/ts-card.entry.js.map +0 -1
- package/dist/esm/ts-checkbox.entry.js.map +0 -1
- package/dist/esm/ts-chip.entry.js.map +0 -1
- package/dist/esm/ts-container.entry.js.map +0 -1
- package/dist/esm/ts-date-picker.entry.js.map +0 -1
- package/dist/esm/ts-dialog.entry.js.map +0 -1
- package/dist/esm/ts-divider.entry.js.map +0 -1
- package/dist/esm/ts-drawer.entry.js.map +0 -1
- package/dist/esm/ts-empty-state.entry.js.map +0 -1
- package/dist/esm/ts-file-upload.entry.js.map +0 -1
- package/dist/esm/ts-grid.entry.js.map +0 -1
- package/dist/esm/ts-icon-Jz9ioZag.js.map +0 -1
- package/dist/esm/ts-icon.entry.js.map +0 -1
- package/dist/esm/ts-input.entry.js.map +0 -1
- package/dist/esm/ts-menu-item.entry.js.map +0 -1
- package/dist/esm/ts-menu.entry.js.map +0 -1
- package/dist/esm/ts-modal.entry.js.map +0 -1
- package/dist/esm/ts-nav-item.entry.js.map +0 -1
- package/dist/esm/ts-nav.entry.js.map +0 -1
- package/dist/esm/ts-pagination.entry.js.map +0 -1
- package/dist/esm/ts-popover.entry.js.map +0 -1
- package/dist/esm/ts-progress.entry.js.map +0 -1
- package/dist/esm/ts-radio.entry.js.map +0 -1
- package/dist/esm/ts-row.entry.js.map +0 -1
- package/dist/esm/ts-select.entry.js.map +0 -1
- package/dist/esm/ts-skeleton.entry.js.map +0 -1
- package/dist/esm/ts-slider.entry.js.map +0 -1
- package/dist/esm/ts-spacer.entry.js.map +0 -1
- package/dist/esm/ts-spinner.entry.js.map +0 -1
- package/dist/esm/ts-stack.entry.js.map +0 -1
- package/dist/esm/ts-step.entry.js.map +0 -1
- package/dist/esm/ts-stepper.entry.js.map +0 -1
- package/dist/esm/ts-switch-group.entry.js.map +0 -1
- package/dist/esm/ts-switch-option.entry.js.map +0 -1
- package/dist/esm/ts-tab-panel.entry.js.map +0 -1
- package/dist/esm/ts-table.entry.js.map +0 -1
- package/dist/esm/ts-tabs.entry.js.map +0 -1
- package/dist/esm/ts-textarea.entry.js.map +0 -1
- package/dist/esm/ts-toast.entry.js.map +0 -1
- package/dist/esm/ts-toggle.entry.js.map +0 -1
- package/dist/esm/ts-toolbar.entry.js.map +0 -1
- package/dist/esm/ts-tooltip.entry.js.map +0 -1
- package/dist/esm/ts-tree-item.entry.js.map +0 -1
- package/dist/esm/ts-tree.entry.js.map +0 -1
- package/dist/tessera-ui/index.esm.js.map +0 -1
- package/dist/tessera-ui/p-0424cd55.entry.js.map +0 -1
- package/dist/tessera-ui/p-04522bf9.entry.js.map +0 -1
- package/dist/tessera-ui/p-04aa8b90.entry.js.map +0 -1
- package/dist/tessera-ui/p-080eaf89.entry.js.map +0 -1
- package/dist/tessera-ui/p-0ec061e5.entry.js.map +0 -1
- package/dist/tessera-ui/p-122e43b7.entry.js.map +0 -1
- package/dist/tessera-ui/p-16bb8ca8.entry.js.map +0 -1
- package/dist/tessera-ui/p-16fc632b.entry.js.map +0 -1
- package/dist/tessera-ui/p-1d73f6c9.entry.js.map +0 -1
- package/dist/tessera-ui/p-24305379.entry.js.map +0 -1
- package/dist/tessera-ui/p-25f77cc9.entry.js.map +0 -1
- package/dist/tessera-ui/p-35eb8496.entry.js.map +0 -1
- package/dist/tessera-ui/p-3aec66b4.entry.js.map +0 -1
- package/dist/tessera-ui/p-4277460b.entry.js.map +0 -1
- package/dist/tessera-ui/p-441310f7.entry.js.map +0 -1
- package/dist/tessera-ui/p-491e1a75.entry.js.map +0 -1
- package/dist/tessera-ui/p-50d092ce.entry.js.map +0 -1
- package/dist/tessera-ui/p-50efadf3.entry.js.map +0 -1
- package/dist/tessera-ui/p-53846d59.entry.js.map +0 -1
- package/dist/tessera-ui/p-56f2b070.entry.js.map +0 -1
- package/dist/tessera-ui/p-6760f922.entry.js.map +0 -1
- package/dist/tessera-ui/p-69bb11ed.entry.js.map +0 -1
- package/dist/tessera-ui/p-6d35a60c.entry.js.map +0 -1
- package/dist/tessera-ui/p-6ec285ad.entry.js.map +0 -1
- package/dist/tessera-ui/p-708d4eb5.entry.js.map +0 -1
- package/dist/tessera-ui/p-79ff8ceb.entry.js.map +0 -1
- package/dist/tessera-ui/p-7e531195.entry.js.map +0 -1
- package/dist/tessera-ui/p-7fa64f00.entry.js.map +0 -1
- package/dist/tessera-ui/p-829c4307.entry.js.map +0 -1
- package/dist/tessera-ui/p-91ccef3f.entry.js.map +0 -1
- package/dist/tessera-ui/p-9209e603.entry.js.map +0 -1
- package/dist/tessera-ui/p-97a9def7.entry.js.map +0 -1
- package/dist/tessera-ui/p-9b41b538.entry.js.map +0 -1
- package/dist/tessera-ui/p-9c0504fd.entry.js.map +0 -1
- package/dist/tessera-ui/p-BOxYojS-.js.map +0 -1
- package/dist/tessera-ui/p-StBQmS8h.js.map +0 -1
- package/dist/tessera-ui/p-V8-ENixA.js.map +0 -1
- package/dist/tessera-ui/p-a120b5d6.entry.js.map +0 -1
- package/dist/tessera-ui/p-a55a5695.entry.js.map +0 -1
- package/dist/tessera-ui/p-a83d903e.entry.js.map +0 -1
- package/dist/tessera-ui/p-adc807dc.entry.js.map +0 -1
- package/dist/tessera-ui/p-b09f202c.entry.js.map +0 -1
- package/dist/tessera-ui/p-b1182592.entry.js.map +0 -1
- package/dist/tessera-ui/p-b3f60955.entry.js.map +0 -1
- package/dist/tessera-ui/p-bb9ebbd8.entry.js.map +0 -1
- package/dist/tessera-ui/p-bce40715.entry.js.map +0 -1
- package/dist/tessera-ui/p-c35c7049.entry.js.map +0 -1
- package/dist/tessera-ui/p-c59ecffa.entry.js.map +0 -1
- package/dist/tessera-ui/p-d318774a.entry.js.map +0 -1
- package/dist/tessera-ui/p-d5cbadd6.entry.js.map +0 -1
- package/dist/tessera-ui/p-e1d2b141.entry.js.map +0 -1
- package/dist/tessera-ui/p-f0bf6408.entry.js.map +0 -1
- package/dist/tessera-ui/p-f639213a.entry.js.map +0 -1
- package/dist/tessera-ui/p-fd2376e0.entry.js.map +0 -1
- package/dist/tessera-ui/p-fef9a993.entry.js.map +0 -1
- package/dist/tessera-ui/p-lpqZSiIf.js.map +0 -1
- package/dist/tessera-ui/tessera-ui.esm.js.map +0 -1
- package/dist/types/components/accordion/accordion-item.stories.d.ts +0 -5
- package/dist/types/components/accordion/accordion.stories.d.ts +0 -21
- package/dist/types/components/alert/alert.stories.d.ts +0 -34
- package/dist/types/components/avatar/avatar.stories.d.ts +0 -51
- package/dist/types/components/badge/badge.stories.d.ts +0 -50
- package/dist/types/components/banner/banner.stories.d.ts +0 -40
- package/dist/types/components/breadcrumb/breadcrumb-item.stories.d.ts +0 -5
- package/dist/types/components/breadcrumb/breadcrumb.stories.d.ts +0 -20
- package/dist/types/components/button/button.stories.d.ts +0 -73
- package/dist/types/components/card/card.stories.d.ts +0 -46
- package/dist/types/components/checkbox/checkbox.stories.d.ts +0 -58
- package/dist/types/components/chip/chip.stories.d.ts +0 -54
- package/dist/types/components/container/container.stories.d.ts +0 -21
- package/dist/types/components/date-picker/date-picker.stories.d.ts +0 -62
- package/dist/types/components/dialog/dialog.stories.d.ts +0 -39
- package/dist/types/components/divider/divider.stories.d.ts +0 -33
- package/dist/types/components/drawer/drawer.stories.d.ts +0 -43
- package/dist/types/components/empty-state/empty-state.stories.d.ts +0 -37
- package/dist/types/components/file-upload/file-upload.stories.d.ts +0 -43
- package/dist/types/components/grid/grid.stories.d.ts +0 -30
- package/dist/types/components/icon/icon.stories.d.ts +0 -42
- package/dist/types/components/input/input.stories.d.ts +0 -77
- package/dist/types/components/menu/menu-item.stories.d.ts +0 -5
- package/dist/types/components/menu/menu.stories.d.ts +0 -36
- package/dist/types/components/modal/modal.stories.d.ts +0 -47
- package/dist/types/components/nav/nav-item.stories.d.ts +0 -5
- package/dist/types/components/nav/nav.stories.d.ts +0 -27
- package/dist/types/components/pagination/pagination.stories.d.ts +0 -42
- package/dist/types/components/popover/popover.stories.d.ts +0 -38
- package/dist/types/components/progress/progress.stories.d.ts +0 -59
- package/dist/types/components/radio/radio.stories.d.ts +0 -48
- package/dist/types/components/row/row.stories.d.ts +0 -52
- package/dist/types/components/select/select.stories.d.ts +0 -73
- package/dist/types/components/skeleton/skeleton.stories.d.ts +0 -44
- package/dist/types/components/slider/slider.stories.d.ts +0 -62
- package/dist/types/components/spacer/spacer.stories.d.ts +0 -28
- package/dist/types/components/spinner/spinner.stories.d.ts +0 -33
- package/dist/types/components/stack/stack.stories.d.ts +0 -28
- package/dist/types/components/stepper/step.stories.d.ts +0 -5
- package/dist/types/components/stepper/stepper.stories.d.ts +0 -36
- package/dist/types/components/switch-group/switch-group.stories.d.ts +0 -37
- package/dist/types/components/switch-group/switch-option.stories.d.ts +0 -5
- package/dist/types/components/table/table.stories.d.ts +0 -45
- package/dist/types/components/tabs/tab-panel.stories.d.ts +0 -5
- package/dist/types/components/tabs/tabs.stories.d.ts +0 -34
- package/dist/types/components/textarea/textarea.stories.d.ts +0 -88
- package/dist/types/components/toast/toast.stories.d.ts +0 -48
- package/dist/types/components/toggle/toggle.stories.d.ts +0 -46
- package/dist/types/components/toolbar/toolbar.stories.d.ts +0 -28
- package/dist/types/components/tooltip/tooltip.stories.d.ts +0 -43
- package/dist/types/components/tree/tree-item.stories.d.ts +0 -5
- package/dist/types/components/tree/tree.stories.d.ts +0 -21
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"select.js","sourceRoot":"","sources":["../../../src/components/select/select.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAG/F,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAQ9C;;;;;;;;;;GAUG;AAMH,MAAM,OAAO,QAAQ;IACR,MAAM,CAAe;IAExB,OAAO,GAAG,UAAU,CAAC,WAAW,CAAC,CAAC;IAClC,SAAS,CAAe;IAEhC,yBAAyB;IACe,KAAK,GAAG,EAAE,CAAC;IAEnD,kDAAkD;IAC1C,WAAW,CAAU;IAE7B,sCAAsC;IACb,QAAQ,GAAG,KAAK,CAAC;IAE1C,uBAAuB;IACE,IAAI,GAAW,IAAI,CAAC;IAE7C,6CAA6C;IACrC,KAAK,CAAU;IAEvB,4CAA4C;IACpC,QAAQ,CAAU;IAE1B,4CAA4C;IACnB,KAAK,GAAG,KAAK,CAAC;IAEvC,gDAAgD;IACxC,YAAY,CAAU;IAE9B,iCAAiC;IACR,QAAQ,GAAG,KAAK,CAAC;IAE1C,0CAA0C;IAClC,IAAI,CAAU;IAEtB,iCAAiC;IACR,QAAQ,GAAG,KAAK,CAAC;IAE1C,oCAAoC;IAC3B,MAAM,GAAG,KAAK,CAAC;IAExB,iDAAiD;IACxC,YAAY,GAAG,CAAC,CAAC,CAAC;IAE3B,qDAAqD;IAC5C,OAAO,GAAmB,EAAE,CAAC;IAEtC,sCAAsC;IACJ,QAAQ,CAA2C;IAErF,2CAA2C;IACV,OAAO,CAAsB;IAE9D,2CAA2C;IACX,MAAM,CAAsB;IAG5D,iBAAiB;QACf,qDAAqD;IACvD,CAAC;IAGD,mBAAmB,CAAC,KAAiB;QACnC,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAc,CAAC,EAAE,CAAC;YAC/D,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,CAAC;IACH,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,gBAAgB;QACd,2CAA2C;QAC3C,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,2BAA2B,CAAC,CAAC;QAChF,IAAI,EAAE,gBAAgB,CAAC,YAAY,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;IAClE,CAAC;IAEO,YAAY;QAClB,MAAM,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;QAC9D,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;YACtD,KAAK,EAAE,GAAG,CAAC,KAAK;YAChB,KAAK,EAAE,GAAG,CAAC,WAAW,EAAE,IAAI,EAAE,IAAI,GAAG,CAAC,KAAK;YAC3C,QAAQ,EAAE,GAAG,CAAC,QAAQ;SACvB,CAAC,CAAC,CAAC;IACN,CAAC;IAEO,IAAI;QACV,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC1B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1E,IAAI,IAAI,CAAC,YAAY,GAAG,CAAC;YAAE,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;IACnD,CAAC;IAEO,KAAK;QACX,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC;QACvB,IAAI,CAAC,SAAS,EAAE,KAAK,EAAE,CAAC;IAC1B,CAAC;IAEO,YAAY,CAAC,MAAoB;QACvC,IAAI,MAAM,CAAC,QAAQ;YAAE,OAAO;QAC5B,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC;QAC1B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;QAC1C,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAEO,kBAAkB,GAAG,GAAS,EAAE;QACtC,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,IAAI,EAAE,CAAC;QACd,CAAC;IACH,CAAC,CAAC;IAEM,oBAAoB,GAAG,CAAC,KAAoB,EAAQ,EAAE;QAC5D,QAAQ,KAAK,CAAC,GAAG,EAAE,CAAC;YAClB,KAAK,OAAO,CAAC;YACb,KAAK,GAAG,CAAC;YACT,KAAK,WAAW;gBACd,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;oBACjB,IAAI,CAAC,IAAI,EAAE,CAAC;gBACd,CAAC;qBAAM,IAAI,KAAK,CAAC,GAAG,KAAK,OAAO,IAAI,KAAK,CAAC,GAAG,KAAK,GAAG,EAAE,CAAC;oBACtD,IAAI,IAAI,CAAC,YAAY,IAAI,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC;wBAC9D,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;oBACrD,CAAC;gBACH,CAAC;gBACD,MAAM;YACR,KAAK,SAAS;gBACZ,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;oBACjB,IAAI,CAAC,IAAI,EAAE,CAAC;gBACd,CAAC;gBACD,MAAM;YACR,KAAK,QAAQ;gBACX,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;oBAChB,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,IAAI,CAAC,KAAK,EAAE,CAAC;gBACf,CAAC;gBACD,MAAM;QACV,CAAC;IACH,CAAC,CAAC;IAEM,qBAAqB,GAAG,CAAC,KAAoB,EAAQ,EAAE;QAC7D,MAAM,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;QAC/D,QAAQ,KAAK,CAAC,GAAG,EAAE,CAAC;YAClB,KAAK,WAAW;gBACd,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;gBAClB,MAAM;YACR,KAAK,SAAS;gBACZ,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;gBACnB,MAAM;YACR,KAAK,OAAO,CAAC;YACb,KAAK,GAAG;gBACN,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,IAAI,CAAC,YAAY,IAAI,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,QAAQ,EAAE,CAAC;oBAC3G,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;gBACrD,CAAC;gBACD,MAAM;YACR,KAAK,QAAQ;gBACX,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,KAAK,EAAE,CAAC;gBACb,MAAM;YACR,KAAK,MAAM;gBACT,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,YAAY,GAAG,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBAC5F,MAAM;YACR,KAAK,KAAK;gBACR,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,YAAY,GAAG,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,cAAc,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC;gBAC1I,MAAM;QACV,CAAC;IACH,CAAC,CAAC;IAEM,SAAS,CAAC,SAAiB;QACjC,IAAI,IAAI,GAAG,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;QACzC,OAAO,IAAI,IAAI,CAAC,IAAI,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,CAAC;YAC9E,IAAI,IAAI,SAAS,CAAC;QACpB,CAAC;QACD,IAAI,IAAI,IAAI,CAAC,IAAI,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;YAC5C,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QAC3B,CAAC;IACH,CAAC;IAEO,WAAW,GAAG,GAAS,EAAE;QAC/B,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;IACtB,CAAC,CAAC;IAEM,UAAU,GAAG,GAAS,EAAE;QAC9B,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IACrB,CAAC,CAAC;IAEM,cAAc;QACpB,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,CAAC,CAAC;QAClE,OAAO,QAAQ,EAAE,KAAK,IAAI,EAAE,CAAC;IAC/B,CAAC;IAED,4EAA4E;IAC5E,MAAM;QACJ,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC;QACnD,MAAM,OAAO,GAAG,GAAG,IAAI,CAAC,OAAO,QAAQ,CAAC;QACxC,MAAM,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,OAAO,CAAC;QACtC,MAAM,OAAO,GAAG,GAAG,IAAI,CAAC,OAAO,QAAQ,CAAC;QACxC,MAAM,SAAS,GAAG,GAAG,IAAI,CAAC,OAAO,UAAU,CAAC;QAC5C,MAAM,WAAW,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QAE1C,OAAO,CACL,EAAC,IAAI,qDACH,KAAK,EAAE;gBACL,WAAW,EAAE,IAAI;gBACjB,CAAC,cAAc,IAAI,CAAC,IAAI,EAAE,CAAC,EAAE,IAAI;gBACjC,iBAAiB,EAAE,IAAI,CAAC,MAAM;gBAC9B,qBAAqB,EAAE,IAAI,CAAC,QAAQ;gBACpC,kBAAkB,EAAE,IAAI,CAAC,KAAK;aAC/B;YAEA,IAAI,CAAC,KAAK,IAAI,CACb,8DAAO,KAAK,EAAC,eAAe,EAAC,IAAI,EAAC,OAAO,EAAC,EAAE,EAAE,OAAO;gBAClD,IAAI,CAAC,KAAK;gBACV,IAAI,CAAC,QAAQ,IAAI,6DAAM,KAAK,EAAC,kBAAkB,iBAAa,MAAM,SAAU,CACvE,CACT;YAED,4DAAK,KAAK,EAAC,mBAAmB;gBAC5B,+DACE,GAAG,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC,EAClC,KAAK,EAAE;wBACL,iBAAiB,EAAE,IAAI;wBACvB,uBAAuB,EAAE,IAAI,CAAC,MAAM;wBACpC,wBAAwB,EAAE,IAAI,CAAC,KAAK;wBACpC,2BAA2B,EAAE,IAAI,CAAC,QAAQ;qBAC3C,EACD,IAAI,EAAC,SAAS,EACd,IAAI,EAAC,QAAQ,EACb,IAAI,EAAC,UAAU,mBACA,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,mBAC/B,SAAS,mBACR,SAAS,qBACP,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,kBACnC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,mBAC9B,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,EACjD,QAAQ,EAAE,IAAI,CAAC,QAAQ,EACvB,OAAO,EAAE,IAAI,CAAC,kBAAkB,EAChC,SAAS,EAAE,IAAI,CAAC,oBAAoB,EACpC,OAAO,EAAE,IAAI,CAAC,WAAW,EACzB,MAAM,EAAE,IAAI,CAAC,UAAU;oBAEvB,6DAAM,KAAK,EAAE,EAAE,iBAAiB,EAAE,IAAI,EAAE,8BAA8B,EAAE,CAAC,WAAW,EAAE,IACnF,WAAW,IAAI,IAAI,CAAC,WAAW,IAAI,QAAQ,CACvC;oBACP,4DAAK,KAAK,EAAC,iBAAiB,EAAC,OAAO,EAAC,WAAW,EAAC,IAAI,EAAC,MAAM,iBAAa,MAAM;wBAC7E,6DAAM,CAAC,EAAC,gBAAgB,EAAC,MAAM,EAAC,cAAc,kBAAc,GAAG,oBAAgB,OAAO,qBAAiB,OAAO,GAAG,CAC7G,CACC;gBAER,IAAI,CAAC,MAAM,IAAI,CACd,4DACE,KAAK,EAAC,kBAAkB,EACxB,IAAI,EAAC,UAAU,EACf,IAAI,EAAC,SAAS,EACd,EAAE,EAAE,SAAS,qBACI,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,EACjD,SAAS,EAAE,IAAI,CAAC,qBAAqB,IAEpC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC,CACnC,WACE,KAAK,EAAE;wBACL,gBAAgB,EAAE,IAAI;wBACtB,0BAA0B,EAAE,MAAM,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK;wBACvD,yBAAyB,EAAE,KAAK,KAAK,IAAI,CAAC,YAAY;wBACtD,0BAA0B,EAAE,MAAM,CAAC,QAAQ;qBAC5C,EACD,IAAI,EAAC,QAAQ,EACb,IAAI,EAAC,QAAQ,mBACE,MAAM,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,mBAC9C,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,EACnD,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,IAEvC,MAAM,CAAC,KAAK,CACT,CACP,CAAC,CACE,CACP,CACG;YAGN,4DAAK,KAAK,EAAC,qBAAqB;gBAC9B,8DAAQ,CACJ;YAEL,QAAQ,IAAI,CACX,4DAAK,KAAK,EAAC,eAAe,EAAC,IAAI,EAAC,YAAY,EAAC,EAAE,EAAE,OAAO,EAAE,IAAI,EAAC,OAAO,IACnE,IAAI,CAAC,YAAY,CACd,CACP;YAEA,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,IAAI,CAC7B,4DAAK,KAAK,EAAC,cAAc,EAAC,IAAI,EAAC,WAAW,EAAC,EAAE,EAAE,MAAM,IAClD,IAAI,CAAC,QAAQ,CACV,CACP,CACI,CACR,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, Prop, State, Event, Watch, h, Host, Element, Listen } from '@stencil/core';\nimport type { EventEmitter } from '@stencil/core';\nimport type { TsSize, TsSelectChangeEventDetail } from '../../types';\nimport { generateId } from '../../utils/aria';\n\ninterface SelectOption {\n value: string;\n label: string;\n disabled: boolean;\n}\n\n/**\n * @slot - Default slot for `<option>` elements.\n *\n * @part base - The outer wrapper.\n * @part label - The label element.\n * @part trigger - The select trigger button.\n * @part dropdown - The dropdown panel.\n * @part option - An option in the dropdown list.\n * @part help-text - The help text wrapper.\n * @part error-text - The error message wrapper.\n */\n@Component({\n tag: 'ts-select',\n styleUrl: 'select.css',\n shadow: true,\n})\nexport class TsSelect {\n @Element() hostEl!: HTMLElement;\n\n private inputId = generateId('ts-select');\n private triggerEl?: HTMLElement;\n\n /** The current value. */\n @Prop({ mutable: true, reflect: true }) value = '';\n\n /** Placeholder text when no value is selected. */\n @Prop() placeholder?: string;\n\n /** Renders the select as disabled. */\n @Prop({ reflect: true }) disabled = false;\n\n /** The select size. */\n @Prop({ reflect: true }) size: TsSize = 'md';\n\n /** Label text displayed above the select. */\n @Prop() label?: string;\n\n /** Help text displayed below the select. */\n @Prop() helpText?: string;\n\n /** Renders the select in an error state. */\n @Prop({ reflect: true }) error = false;\n\n /** Error message displayed below the select. */\n @Prop() errorMessage?: string;\n\n /** Makes the select required. */\n @Prop({ reflect: true }) required = false;\n\n /** Name attribute for form submission. */\n @Prop() name?: string;\n\n /** Allow multiple selections. */\n @Prop({ reflect: true }) multiple = false;\n\n /** Whether the dropdown is open. */\n @State() isOpen = false;\n\n /** The index of the currently focused option. */\n @State() focusedIndex = -1;\n\n /** Parsed options from slotted <option> elements. */\n @State() options: SelectOption[] = [];\n\n /** Emitted when the value changes. */\n @Event({ eventName: 'tsChange' }) tsChange!: EventEmitter<TsSelectChangeEventDetail>;\n\n /** Emitted when the select gains focus. */\n @Event({ eventName: 'tsFocus' }) tsFocus!: EventEmitter<void>;\n\n /** Emitted when the select loses focus. */\n @Event({ eventName: 'tsBlur' }) tsBlur!: EventEmitter<void>;\n\n @Watch('value')\n handleValueChange(): void {\n // Value was changed externally; ensure UI is in sync\n }\n\n @Listen('click', { target: 'document' })\n handleDocumentClick(event: MouseEvent): void {\n if (this.isOpen && !this.hostEl.contains(event.target as Node)) {\n this.close();\n }\n }\n\n componentWillLoad(): void {\n this.parseOptions();\n }\n\n componentDidLoad(): void {\n // Observe slot changes to re-parse options\n const slot = this.hostEl.shadowRoot?.querySelector('.select__hidden-slot slot');\n slot?.addEventListener('slotchange', () => this.parseOptions());\n }\n\n private parseOptions(): void {\n const slottedOptions = this.hostEl.querySelectorAll('option');\n this.options = Array.from(slottedOptions).map((opt) => ({\n value: opt.value,\n label: opt.textContent?.trim() ?? opt.value,\n disabled: opt.disabled,\n }));\n }\n\n private open(): void {\n if (this.disabled) return;\n this.isOpen = true;\n this.focusedIndex = this.options.findIndex((o) => o.value === this.value);\n if (this.focusedIndex < 0) this.focusedIndex = 0;\n }\n\n private close(): void {\n this.isOpen = false;\n this.focusedIndex = -1;\n this.triggerEl?.focus();\n }\n\n private selectOption(option: SelectOption): void {\n if (option.disabled) return;\n this.value = option.value;\n this.tsChange.emit({ value: this.value });\n this.close();\n }\n\n private handleTriggerClick = (): void => {\n if (this.isOpen) {\n this.close();\n } else {\n this.open();\n }\n };\n\n private handleTriggerKeydown = (event: KeyboardEvent): void => {\n switch (event.key) {\n case 'Enter':\n case ' ':\n case 'ArrowDown':\n event.preventDefault();\n if (!this.isOpen) {\n this.open();\n } else if (event.key === 'Enter' || event.key === ' ') {\n if (this.focusedIndex >= 0 && this.options[this.focusedIndex]) {\n this.selectOption(this.options[this.focusedIndex]);\n }\n }\n break;\n case 'ArrowUp':\n event.preventDefault();\n if (!this.isOpen) {\n this.open();\n }\n break;\n case 'Escape':\n if (this.isOpen) {\n event.preventDefault();\n this.close();\n }\n break;\n }\n };\n\n private handleDropdownKeydown = (event: KeyboardEvent): void => {\n const enabledOptions = this.options.filter((o) => !o.disabled);\n switch (event.key) {\n case 'ArrowDown':\n event.preventDefault();\n this.moveFocus(1);\n break;\n case 'ArrowUp':\n event.preventDefault();\n this.moveFocus(-1);\n break;\n case 'Enter':\n case ' ':\n event.preventDefault();\n if (this.focusedIndex >= 0 && this.options[this.focusedIndex] && !this.options[this.focusedIndex].disabled) {\n this.selectOption(this.options[this.focusedIndex]);\n }\n break;\n case 'Escape':\n event.preventDefault();\n this.close();\n break;\n case 'Home':\n event.preventDefault();\n this.focusedIndex = enabledOptions.length > 0 ? this.options.indexOf(enabledOptions[0]) : 0;\n break;\n case 'End':\n event.preventDefault();\n this.focusedIndex = enabledOptions.length > 0 ? this.options.indexOf(enabledOptions[enabledOptions.length - 1]) : this.options.length - 1;\n break;\n }\n };\n\n private moveFocus(direction: number): void {\n let next = this.focusedIndex + direction;\n while (next >= 0 && next < this.options.length && this.options[next].disabled) {\n next += direction;\n }\n if (next >= 0 && next < this.options.length) {\n this.focusedIndex = next;\n }\n }\n\n private handleFocus = (): void => {\n this.tsFocus.emit();\n };\n\n private handleBlur = (): void => {\n this.tsBlur.emit();\n };\n\n private getDisplayText(): string {\n const selected = this.options.find((o) => o.value === this.value);\n return selected?.label ?? '';\n }\n\n // eslint-disable-next-line @typescript-eslint/explicit-function-return-type\n render() {\n const hasError = this.error && !!this.errorMessage;\n const labelId = `${this.inputId}-label`;\n const helpId = `${this.inputId}-help`;\n const errorId = `${this.inputId}-error`;\n const listboxId = `${this.inputId}-listbox`;\n const displayText = this.getDisplayText();\n\n return (\n <Host\n class={{\n 'ts-select': true,\n [`ts-select--${this.size}`]: true,\n 'ts-select--open': this.isOpen,\n 'ts-select--disabled': this.disabled,\n 'ts-select--error': this.error,\n }}\n >\n {this.label && (\n <label class=\"select__label\" part=\"label\" id={labelId}>\n {this.label}\n {this.required && <span class=\"select__required\" aria-hidden=\"true\"> *</span>}\n </label>\n )}\n\n <div class=\"select__container\">\n <button\n ref={(el) => (this.triggerEl = el)}\n class={{\n 'select__trigger': true,\n 'select__trigger--open': this.isOpen,\n 'select__trigger--error': this.error,\n 'select__trigger--disabled': this.disabled,\n }}\n part=\"trigger\"\n type=\"button\"\n role=\"combobox\"\n aria-expanded={this.isOpen ? 'true' : 'false'}\n aria-haspopup=\"listbox\"\n aria-controls={listboxId}\n aria-labelledby={this.label ? labelId : undefined}\n aria-invalid={this.error ? 'true' : undefined}\n aria-required={this.required ? 'true' : undefined}\n disabled={this.disabled}\n onClick={this.handleTriggerClick}\n onKeyDown={this.handleTriggerKeydown}\n onFocus={this.handleFocus}\n onBlur={this.handleBlur}\n >\n <span class={{ 'select__display': true, 'select__display--placeholder': !displayText }}>\n {displayText || this.placeholder || '\\u00A0'}\n </span>\n <svg class=\"select__chevron\" viewBox=\"0 0 16 16\" fill=\"none\" aria-hidden=\"true\">\n <path d=\"M4 6L8 10L12 6\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n </button>\n\n {this.isOpen && (\n <div\n class=\"select__dropdown\"\n part=\"dropdown\"\n role=\"listbox\"\n id={listboxId}\n aria-labelledby={this.label ? labelId : undefined}\n onKeyDown={this.handleDropdownKeydown}\n >\n {this.options.map((option, index) => (\n <div\n class={{\n 'select__option': true,\n 'select__option--selected': option.value === this.value,\n 'select__option--focused': index === this.focusedIndex,\n 'select__option--disabled': option.disabled,\n }}\n part=\"option\"\n role=\"option\"\n aria-selected={option.value === this.value ? 'true' : 'false'}\n aria-disabled={option.disabled ? 'true' : undefined}\n onClick={() => this.selectOption(option)}\n >\n {option.label}\n </div>\n ))}\n </div>\n )}\n </div>\n\n {/* Hidden slot to capture <option> elements */}\n <div class=\"select__hidden-slot\">\n <slot />\n </div>\n\n {hasError && (\n <div class=\"select__error\" part=\"error-text\" id={errorId} role=\"alert\">\n {this.errorMessage}\n </div>\n )}\n\n {!hasError && this.helpText && (\n <div class=\"select__help\" part=\"help-text\" id={helpId}>\n {this.helpText}\n </div>\n )}\n </Host>\n );\n }\n}\n"]}
|
|
@@ -1,138 +0,0 @@
|
|
|
1
|
-
// Hand-written stories for ts-select
|
|
2
|
-
export default {
|
|
3
|
-
title: 'Components/Select',
|
|
4
|
-
tags: ['autodocs'],
|
|
5
|
-
argTypes: {
|
|
6
|
-
value: { control: 'text', description: 'The current value.' },
|
|
7
|
-
placeholder: { control: 'text', description: 'Placeholder text when no value is selected.' },
|
|
8
|
-
disabled: { control: 'boolean', description: 'Renders the select as disabled.' },
|
|
9
|
-
size: {
|
|
10
|
-
control: 'select',
|
|
11
|
-
options: ['sm', 'md', 'lg'],
|
|
12
|
-
description: 'The select size.',
|
|
13
|
-
},
|
|
14
|
-
label: { control: 'text', description: 'Label text displayed above the select.' },
|
|
15
|
-
helpText: { control: 'text', description: 'Help text displayed below the select.' },
|
|
16
|
-
error: { control: 'boolean', description: 'Renders the select in an error state.' },
|
|
17
|
-
errorMessage: { control: 'text', description: 'Error message displayed below the select.' },
|
|
18
|
-
required: { control: 'boolean', description: 'Makes the select required.' },
|
|
19
|
-
name: { control: 'text', description: 'Name attribute for form submission.' },
|
|
20
|
-
multiple: { control: 'boolean', description: 'Allow multiple selections.' },
|
|
21
|
-
},
|
|
22
|
-
};
|
|
23
|
-
const Template = (args) => {
|
|
24
|
-
const attrs = [];
|
|
25
|
-
if (args.value !== undefined && args.value !== null && args.value !== '')
|
|
26
|
-
attrs.push(`value="${args.value}"`);
|
|
27
|
-
if (args.placeholder !== undefined && args.placeholder !== null)
|
|
28
|
-
attrs.push(`placeholder="${args.placeholder}"`);
|
|
29
|
-
if (args.disabled)
|
|
30
|
-
attrs.push('disabled');
|
|
31
|
-
if (args.size !== undefined && args.size !== null)
|
|
32
|
-
attrs.push(`size="${args.size}"`);
|
|
33
|
-
if (args.label !== undefined && args.label !== null)
|
|
34
|
-
attrs.push(`label="${args.label}"`);
|
|
35
|
-
if (args.helpText !== undefined && args.helpText !== null)
|
|
36
|
-
attrs.push(`help-text="${args.helpText}"`);
|
|
37
|
-
if (args.error)
|
|
38
|
-
attrs.push('error');
|
|
39
|
-
if (args.errorMessage !== undefined && args.errorMessage !== null)
|
|
40
|
-
attrs.push(`error-message="${args.errorMessage}"`);
|
|
41
|
-
if (args.required)
|
|
42
|
-
attrs.push('required');
|
|
43
|
-
if (args.name !== undefined && args.name !== null)
|
|
44
|
-
attrs.push(`name="${args.name}"`);
|
|
45
|
-
if (args.multiple)
|
|
46
|
-
attrs.push('multiple');
|
|
47
|
-
return `
|
|
48
|
-
<ts-select ${attrs.join(' ')}>
|
|
49
|
-
<option value="us">United States</option>
|
|
50
|
-
<option value="uk">United Kingdom</option>
|
|
51
|
-
<option value="ca">Canada</option>
|
|
52
|
-
<option value="au">Australia</option>
|
|
53
|
-
<option value="de">Germany</option>
|
|
54
|
-
</ts-select>
|
|
55
|
-
`;
|
|
56
|
-
};
|
|
57
|
-
export const Default = Object.assign(Template.bind({}), {
|
|
58
|
-
args: {
|
|
59
|
-
value: '',
|
|
60
|
-
placeholder: 'Select a country',
|
|
61
|
-
disabled: false,
|
|
62
|
-
size: 'md',
|
|
63
|
-
label: 'Country',
|
|
64
|
-
helpText: 'Select your country of residence.',
|
|
65
|
-
error: false,
|
|
66
|
-
errorMessage: '',
|
|
67
|
-
required: false,
|
|
68
|
-
name: 'country',
|
|
69
|
-
multiple: false,
|
|
70
|
-
},
|
|
71
|
-
});
|
|
72
|
-
export const Sizes = () => `
|
|
73
|
-
<div style="display: flex; flex-direction: column; gap: 16px; max-width: 320px;">
|
|
74
|
-
<ts-select size="sm" label="Small" placeholder="Choose...">
|
|
75
|
-
<option value="admin">Admin</option>
|
|
76
|
-
<option value="editor">Editor</option>
|
|
77
|
-
<option value="viewer">Viewer</option>
|
|
78
|
-
</ts-select>
|
|
79
|
-
<ts-select size="md" label="Medium" placeholder="Choose...">
|
|
80
|
-
<option value="admin">Admin</option>
|
|
81
|
-
<option value="editor">Editor</option>
|
|
82
|
-
<option value="viewer">Viewer</option>
|
|
83
|
-
</ts-select>
|
|
84
|
-
<ts-select size="lg" label="Large" placeholder="Choose...">
|
|
85
|
-
<option value="admin">Admin</option>
|
|
86
|
-
<option value="editor">Editor</option>
|
|
87
|
-
<option value="viewer">Viewer</option>
|
|
88
|
-
</ts-select>
|
|
89
|
-
</div>
|
|
90
|
-
`;
|
|
91
|
-
export const States = () => `
|
|
92
|
-
<div style="display: flex; flex-direction: column; gap: 16px; max-width: 320px;">
|
|
93
|
-
<ts-select label="Default" placeholder="Select an option">
|
|
94
|
-
<option value="a">Option A</option>
|
|
95
|
-
<option value="b">Option B</option>
|
|
96
|
-
</ts-select>
|
|
97
|
-
<ts-select label="With value" value="editor" placeholder="Select a role">
|
|
98
|
-
<option value="admin">Admin</option>
|
|
99
|
-
<option value="editor">Editor</option>
|
|
100
|
-
<option value="viewer">Viewer</option>
|
|
101
|
-
</ts-select>
|
|
102
|
-
<ts-select label="Disabled" disabled placeholder="Cannot select">
|
|
103
|
-
<option value="a">Option A</option>
|
|
104
|
-
</ts-select>
|
|
105
|
-
<ts-select label="Required" required placeholder="Must select" help-text="This field is required.">
|
|
106
|
-
<option value="a">Option A</option>
|
|
107
|
-
<option value="b">Option B</option>
|
|
108
|
-
</ts-select>
|
|
109
|
-
<ts-select label="Error" error error-message="Please select a valid category." placeholder="Select a category">
|
|
110
|
-
<option value="tech">Technology</option>
|
|
111
|
-
<option value="science">Science</option>
|
|
112
|
-
</ts-select>
|
|
113
|
-
</div>
|
|
114
|
-
`;
|
|
115
|
-
export const RoleSelector = () => `
|
|
116
|
-
<div style="max-width: 320px;">
|
|
117
|
-
<ts-select label="User Role" placeholder="Assign a role" help-text="Determines access permissions." required name="role">
|
|
118
|
-
<option value="owner">Owner</option>
|
|
119
|
-
<option value="admin">Administrator</option>
|
|
120
|
-
<option value="editor">Editor</option>
|
|
121
|
-
<option value="viewer">Viewer</option>
|
|
122
|
-
<option value="guest" disabled>Guest (deprecated)</option>
|
|
123
|
-
</ts-select>
|
|
124
|
-
</div>
|
|
125
|
-
`;
|
|
126
|
-
export const CategoryFilter = () => `
|
|
127
|
-
<div style="max-width: 320px;">
|
|
128
|
-
<ts-select label="Category" placeholder="Filter by category" name="category">
|
|
129
|
-
<option value="electronics">Electronics</option>
|
|
130
|
-
<option value="clothing">Clothing</option>
|
|
131
|
-
<option value="books">Books</option>
|
|
132
|
-
<option value="home">Home & Garden</option>
|
|
133
|
-
<option value="sports">Sports & Outdoors</option>
|
|
134
|
-
<option value="toys">Toys & Games</option>
|
|
135
|
-
</ts-select>
|
|
136
|
-
</div>
|
|
137
|
-
`;
|
|
138
|
-
//# sourceMappingURL=select.stories.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"select.stories.js","sourceRoot":"","sources":["../../../src/components/select/select.stories.ts"],"names":[],"mappings":"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","sourcesContent":["// Hand-written stories for ts-select\n\nexport default {\n title: 'Components/Select',\n tags: ['autodocs'],\n argTypes: {\n value: { control: 'text', description: 'The current value.' },\n placeholder: { control: 'text', description: 'Placeholder text when no value is selected.' },\n disabled: { control: 'boolean', description: 'Renders the select as disabled.' },\n size: {\n control: 'select',\n options: ['sm', 'md', 'lg'],\n description: 'The select size.',\n },\n label: { control: 'text', description: 'Label text displayed above the select.' },\n helpText: { control: 'text', description: 'Help text displayed below the select.' },\n error: { control: 'boolean', description: 'Renders the select in an error state.' },\n errorMessage: { control: 'text', description: 'Error message displayed below the select.' },\n required: { control: 'boolean', description: 'Makes the select required.' },\n name: { control: 'text', description: 'Name attribute for form submission.' },\n multiple: { control: 'boolean', description: 'Allow multiple selections.' },\n },\n};\n\nconst Template = (args: Record<string, unknown>): string => {\n const attrs: string[] = [];\n if (args.value !== undefined && args.value !== null && args.value !== '') attrs.push(`value=\"${args.value}\"`);\n if (args.placeholder !== undefined && args.placeholder !== null) attrs.push(`placeholder=\"${args.placeholder}\"`);\n if (args.disabled) attrs.push('disabled');\n if (args.size !== undefined && args.size !== null) attrs.push(`size=\"${args.size}\"`);\n if (args.label !== undefined && args.label !== null) attrs.push(`label=\"${args.label}\"`);\n if (args.helpText !== undefined && args.helpText !== null) attrs.push(`help-text=\"${args.helpText}\"`);\n if (args.error) attrs.push('error');\n if (args.errorMessage !== undefined && args.errorMessage !== null) attrs.push(`error-message=\"${args.errorMessage}\"`);\n if (args.required) attrs.push('required');\n if (args.name !== undefined && args.name !== null) attrs.push(`name=\"${args.name}\"`);\n if (args.multiple) attrs.push('multiple');\n return `\n <ts-select ${attrs.join(' ')}>\n <option value=\"us\">United States</option>\n <option value=\"uk\">United Kingdom</option>\n <option value=\"ca\">Canada</option>\n <option value=\"au\">Australia</option>\n <option value=\"de\">Germany</option>\n </ts-select>\n `;\n};\n\nexport const Default = Object.assign(Template.bind({}) as typeof Template & { args: Record<string, unknown> }, {\n args: {\n value: '',\n placeholder: 'Select a country',\n disabled: false,\n size: 'md',\n label: 'Country',\n helpText: 'Select your country of residence.',\n error: false,\n errorMessage: '',\n required: false,\n name: 'country',\n multiple: false,\n },\n});\n\nexport const Sizes = (): string => `\n <div style=\"display: flex; flex-direction: column; gap: 16px; max-width: 320px;\">\n <ts-select size=\"sm\" label=\"Small\" placeholder=\"Choose...\">\n <option value=\"admin\">Admin</option>\n <option value=\"editor\">Editor</option>\n <option value=\"viewer\">Viewer</option>\n </ts-select>\n <ts-select size=\"md\" label=\"Medium\" placeholder=\"Choose...\">\n <option value=\"admin\">Admin</option>\n <option value=\"editor\">Editor</option>\n <option value=\"viewer\">Viewer</option>\n </ts-select>\n <ts-select size=\"lg\" label=\"Large\" placeholder=\"Choose...\">\n <option value=\"admin\">Admin</option>\n <option value=\"editor\">Editor</option>\n <option value=\"viewer\">Viewer</option>\n </ts-select>\n </div>\n`;\n\nexport const States = (): string => `\n <div style=\"display: flex; flex-direction: column; gap: 16px; max-width: 320px;\">\n <ts-select label=\"Default\" placeholder=\"Select an option\">\n <option value=\"a\">Option A</option>\n <option value=\"b\">Option B</option>\n </ts-select>\n <ts-select label=\"With value\" value=\"editor\" placeholder=\"Select a role\">\n <option value=\"admin\">Admin</option>\n <option value=\"editor\">Editor</option>\n <option value=\"viewer\">Viewer</option>\n </ts-select>\n <ts-select label=\"Disabled\" disabled placeholder=\"Cannot select\">\n <option value=\"a\">Option A</option>\n </ts-select>\n <ts-select label=\"Required\" required placeholder=\"Must select\" help-text=\"This field is required.\">\n <option value=\"a\">Option A</option>\n <option value=\"b\">Option B</option>\n </ts-select>\n <ts-select label=\"Error\" error error-message=\"Please select a valid category.\" placeholder=\"Select a category\">\n <option value=\"tech\">Technology</option>\n <option value=\"science\">Science</option>\n </ts-select>\n </div>\n`;\n\nexport const RoleSelector = (): string => `\n <div style=\"max-width: 320px;\">\n <ts-select label=\"User Role\" placeholder=\"Assign a role\" help-text=\"Determines access permissions.\" required name=\"role\">\n <option value=\"owner\">Owner</option>\n <option value=\"admin\">Administrator</option>\n <option value=\"editor\">Editor</option>\n <option value=\"viewer\">Viewer</option>\n <option value=\"guest\" disabled>Guest (deprecated)</option>\n </ts-select>\n </div>\n`;\n\nexport const CategoryFilter = (): string => `\n <div style=\"max-width: 320px;\">\n <ts-select label=\"Category\" placeholder=\"Filter by category\" name=\"category\">\n <option value=\"electronics\">Electronics</option>\n <option value=\"clothing\">Clothing</option>\n <option value=\"books\">Books</option>\n <option value=\"home\">Home & Garden</option>\n <option value=\"sports\">Sports & Outdoors</option>\n <option value=\"toys\">Toys & Games</option>\n </ts-select>\n </div>\n`;\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"skeleton.js","sourceRoot":"","sources":["../../../src/components/skeleton/skeleton.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAEzD;;;GAGG;AAMH,MAAM,OAAO,UAAU;IACrB,kCAAkC;IACT,OAAO,GAAwC,MAAM,CAAC;IAE/E,iCAAiC;IACzB,KAAK,GAAG,MAAM,CAAC;IAEvB,kCAAkC;IAC1B,MAAM,CAAU;IAExB,qDAAqD;IAC7C,KAAK,GAAG,CAAC,CAAC;IAElB,uBAAuB;IACE,SAAS,GAA8B,OAAO,CAAC;IAExE,4EAA4E;IAC5E,MAAM;QACJ,MAAM,KAAK,GAA2B,EAAE,CAAC;QACzC,IAAI,IAAI,CAAC,KAAK;YAAE,KAAK,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC;QAC5C,IAAI,IAAI,CAAC,MAAM;YAAE,KAAK,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC;QAE/C,IAAI,IAAI,CAAC,OAAO,KAAK,MAAM,EAAE,CAAC;YAC5B,MAAM,YAAY,GAAG,EAAE,CAAC;YACxB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC;gBACpC,MAAM,MAAM,GAAG,CAAC,KAAK,IAAI,CAAC,KAAK,GAAG,CAAC,IAAI,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;gBACtD,YAAY,CAAC,IAAI,CACf,WACE,KAAK,EAAE;wBACL,gBAAgB,EAAE,IAAI;wBACtB,sBAAsB,EAAE,MAAM;qBAC/B,EACD,IAAI,EAAC,MAAM,GACX,CACH,CAAC;YACJ,CAAC;YAED,OAAO,CACL,EAAC,IAAI,IACH,KAAK,EAAE;oBACL,aAAa,EAAE,IAAI;oBACnB,CAAC,gBAAgB,IAAI,CAAC,OAAO,EAAE,CAAC,EAAE,IAAI;oBACtC,CAAC,gBAAgB,IAAI,CAAC,SAAS,EAAE,CAAC,EAAE,IAAI;iBACzC,EACD,KAAK,EAAE,KAAK,iBACA,MAAM;gBAElB,WAAK,KAAK,EAAC,gBAAgB,EAAC,IAAI,EAAC,MAAM,IACpC,YAAY,CACT,CACD,CACR,CAAC;QACJ,CAAC;QAED,OAAO,CACL,EAAC,IAAI,IACH,KAAK,EAAE;gBACL,aAAa,EAAE,IAAI;gBACnB,CAAC,gBAAgB,IAAI,CAAC,OAAO,EAAE,CAAC,EAAE,IAAI;gBACtC,CAAC,gBAAgB,IAAI,CAAC,SAAS,EAAE,CAAC,EAAE,IAAI;aACzC,EACD,KAAK,EAAE,KAAK,iBACA,MAAM;YAElB,WAAK,KAAK,EAAC,gBAAgB,EAAC,IAAI,EAAC,MAAM,GAAG,CACrC,CACR,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, Prop, h, Host } from '@stencil/core';\n\n/**\n * @part base - The skeleton element container.\n * @part line - Individual skeleton line (text variant).\n */\n@Component({\n tag: 'ts-skeleton',\n styleUrl: 'skeleton.css',\n shadow: true,\n})\nexport class TsSkeleton {\n /** The skeleton shape variant. */\n @Prop({ reflect: true }) variant: 'text' | 'circular' | 'rectangular' = 'text';\n\n /** CSS width of the skeleton. */\n @Prop() width = '100%';\n\n /** CSS height of the skeleton. */\n @Prop() height?: string;\n\n /** Number of lines to render (text variant only). */\n @Prop() lines = 1;\n\n /** Animation style. */\n @Prop({ reflect: true }) animation: 'pulse' | 'wave' | 'none' = 'pulse';\n\n // eslint-disable-next-line @typescript-eslint/explicit-function-return-type\n render() {\n const style: Record<string, string> = {};\n if (this.width) style['width'] = this.width;\n if (this.height) style['height'] = this.height;\n\n if (this.variant === 'text') {\n const lineElements = [];\n for (let i = 0; i < this.lines; i++) {\n const isLast = i === this.lines - 1 && this.lines > 1;\n lineElements.push(\n <div\n class={{\n 'skeleton__line': true,\n 'skeleton__line--last': isLast,\n }}\n part=\"line\"\n />,\n );\n }\n\n return (\n <Host\n class={{\n 'ts-skeleton': true,\n [`ts-skeleton--${this.variant}`]: true,\n [`ts-skeleton--${this.animation}`]: true,\n }}\n style={style}\n aria-hidden=\"true\"\n >\n <div class=\"skeleton__base\" part=\"base\">\n {lineElements}\n </div>\n </Host>\n );\n }\n\n return (\n <Host\n class={{\n 'ts-skeleton': true,\n [`ts-skeleton--${this.variant}`]: true,\n [`ts-skeleton--${this.animation}`]: true,\n }}\n style={style}\n aria-hidden=\"true\"\n >\n <div class=\"skeleton__base\" part=\"base\" />\n </Host>\n );\n }\n}\n"]}
|
|
@@ -1,140 +0,0 @@
|
|
|
1
|
-
// Hand-written stories for ts-skeleton
|
|
2
|
-
export default {
|
|
3
|
-
title: 'Components/Skeleton',
|
|
4
|
-
tags: ['autodocs'],
|
|
5
|
-
argTypes: {
|
|
6
|
-
variant: {
|
|
7
|
-
control: 'select',
|
|
8
|
-
options: ['text', 'circular', 'rectangular'],
|
|
9
|
-
description: 'The skeleton shape variant.',
|
|
10
|
-
},
|
|
11
|
-
width: {
|
|
12
|
-
control: 'text',
|
|
13
|
-
description: 'CSS width of the skeleton.',
|
|
14
|
-
},
|
|
15
|
-
height: {
|
|
16
|
-
control: 'text',
|
|
17
|
-
description: 'CSS height of the skeleton.',
|
|
18
|
-
},
|
|
19
|
-
lines: {
|
|
20
|
-
control: 'number',
|
|
21
|
-
description: 'Number of lines to render (text variant only).',
|
|
22
|
-
},
|
|
23
|
-
animation: {
|
|
24
|
-
control: 'select',
|
|
25
|
-
options: ['pulse', 'wave', 'none'],
|
|
26
|
-
description: 'Animation style.',
|
|
27
|
-
},
|
|
28
|
-
},
|
|
29
|
-
};
|
|
30
|
-
const Template = (args) => {
|
|
31
|
-
const attrs = [];
|
|
32
|
-
if (args.variant !== undefined)
|
|
33
|
-
attrs.push(`variant="${args.variant}"`);
|
|
34
|
-
if (args.width !== undefined)
|
|
35
|
-
attrs.push(`width="${args.width}"`);
|
|
36
|
-
if (args.height !== undefined)
|
|
37
|
-
attrs.push(`height="${args.height}"`);
|
|
38
|
-
if (args.lines !== undefined)
|
|
39
|
-
attrs.push(`lines="${args.lines}"`);
|
|
40
|
-
if (args.animation !== undefined)
|
|
41
|
-
attrs.push(`animation="${args.animation}"`);
|
|
42
|
-
return `<ts-skeleton ${attrs.join(' ')}></ts-skeleton>`;
|
|
43
|
-
};
|
|
44
|
-
export const Default = Object.assign(Template.bind({}), {
|
|
45
|
-
args: {
|
|
46
|
-
variant: 'text',
|
|
47
|
-
width: '100%',
|
|
48
|
-
lines: 3,
|
|
49
|
-
animation: 'pulse',
|
|
50
|
-
},
|
|
51
|
-
});
|
|
52
|
-
export const Variants = () => `
|
|
53
|
-
<div style="display: flex; flex-direction: column; gap: 24px; max-width: 400px;">
|
|
54
|
-
<div>
|
|
55
|
-
<p style="margin: 0 0 8px; font-family: sans-serif; font-size: 14px; color: #666;">Text (3 lines)</p>
|
|
56
|
-
<ts-skeleton variant="text" lines="3"></ts-skeleton>
|
|
57
|
-
</div>
|
|
58
|
-
<div>
|
|
59
|
-
<p style="margin: 0 0 8px; font-family: sans-serif; font-size: 14px; color: #666;">Circular (avatar)</p>
|
|
60
|
-
<ts-skeleton variant="circular" width="48px" height="48px"></ts-skeleton>
|
|
61
|
-
</div>
|
|
62
|
-
<div>
|
|
63
|
-
<p style="margin: 0 0 8px; font-family: sans-serif; font-size: 14px; color: #666;">Rectangular (image)</p>
|
|
64
|
-
<ts-skeleton variant="rectangular" width="100%" height="200px"></ts-skeleton>
|
|
65
|
-
</div>
|
|
66
|
-
</div>
|
|
67
|
-
`;
|
|
68
|
-
export const States = () => `
|
|
69
|
-
<div style="display: flex; flex-direction: column; gap: 24px; max-width: 400px;">
|
|
70
|
-
<div>
|
|
71
|
-
<p style="margin: 0 0 8px; font-family: sans-serif; font-size: 14px; color: #666;">Pulse animation (default)</p>
|
|
72
|
-
<ts-skeleton variant="text" lines="2" animation="pulse"></ts-skeleton>
|
|
73
|
-
</div>
|
|
74
|
-
<div>
|
|
75
|
-
<p style="margin: 0 0 8px; font-family: sans-serif; font-size: 14px; color: #666;">Wave animation</p>
|
|
76
|
-
<ts-skeleton variant="text" lines="2" animation="wave"></ts-skeleton>
|
|
77
|
-
</div>
|
|
78
|
-
<div>
|
|
79
|
-
<p style="margin: 0 0 8px; font-family: sans-serif; font-size: 14px; color: #666;">No animation</p>
|
|
80
|
-
<ts-skeleton variant="text" lines="2" animation="none"></ts-skeleton>
|
|
81
|
-
</div>
|
|
82
|
-
</div>
|
|
83
|
-
`;
|
|
84
|
-
export const LoadingCard = () => `
|
|
85
|
-
<div style="max-width: 320px; border: 1px solid #e2e8f0; border-radius: 8px; padding: 16px; display: flex; flex-direction: column; gap: 12px;">
|
|
86
|
-
<ts-skeleton variant="rectangular" width="100%" height="180px"></ts-skeleton>
|
|
87
|
-
<ts-skeleton variant="text" width="60%" lines="1"></ts-skeleton>
|
|
88
|
-
<ts-skeleton variant="text" lines="3"></ts-skeleton>
|
|
89
|
-
<div style="display: flex; gap: 8px;">
|
|
90
|
-
<ts-skeleton variant="rectangular" width="80px" height="32px"></ts-skeleton>
|
|
91
|
-
<ts-skeleton variant="rectangular" width="80px" height="32px"></ts-skeleton>
|
|
92
|
-
</div>
|
|
93
|
-
</div>
|
|
94
|
-
`;
|
|
95
|
-
export const LoadingList = () => `
|
|
96
|
-
<div style="max-width: 400px; display: flex; flex-direction: column; gap: 16px;">
|
|
97
|
-
<div style="display: flex; gap: 12px; align-items: center;">
|
|
98
|
-
<ts-skeleton variant="circular" width="40px" height="40px"></ts-skeleton>
|
|
99
|
-
<div style="flex: 1;">
|
|
100
|
-
<ts-skeleton variant="text" width="70%" lines="1"></ts-skeleton>
|
|
101
|
-
<ts-skeleton variant="text" width="40%" lines="1"></ts-skeleton>
|
|
102
|
-
</div>
|
|
103
|
-
</div>
|
|
104
|
-
<div style="display: flex; gap: 12px; align-items: center;">
|
|
105
|
-
<ts-skeleton variant="circular" width="40px" height="40px"></ts-skeleton>
|
|
106
|
-
<div style="flex: 1;">
|
|
107
|
-
<ts-skeleton variant="text" width="70%" lines="1"></ts-skeleton>
|
|
108
|
-
<ts-skeleton variant="text" width="40%" lines="1"></ts-skeleton>
|
|
109
|
-
</div>
|
|
110
|
-
</div>
|
|
111
|
-
<div style="display: flex; gap: 12px; align-items: center;">
|
|
112
|
-
<ts-skeleton variant="circular" width="40px" height="40px"></ts-skeleton>
|
|
113
|
-
<div style="flex: 1;">
|
|
114
|
-
<ts-skeleton variant="text" width="70%" lines="1"></ts-skeleton>
|
|
115
|
-
<ts-skeleton variant="text" width="40%" lines="1"></ts-skeleton>
|
|
116
|
-
</div>
|
|
117
|
-
</div>
|
|
118
|
-
<div style="display: flex; gap: 12px; align-items: center;">
|
|
119
|
-
<ts-skeleton variant="circular" width="40px" height="40px"></ts-skeleton>
|
|
120
|
-
<div style="flex: 1;">
|
|
121
|
-
<ts-skeleton variant="text" width="70%" lines="1"></ts-skeleton>
|
|
122
|
-
<ts-skeleton variant="text" width="40%" lines="1"></ts-skeleton>
|
|
123
|
-
</div>
|
|
124
|
-
</div>
|
|
125
|
-
</div>
|
|
126
|
-
`;
|
|
127
|
-
export const Composition = () => `
|
|
128
|
-
<div style="max-width: 400px; display: flex; flex-direction: column; gap: 16px;">
|
|
129
|
-
<div style="display: flex; gap: 12px; align-items: center;">
|
|
130
|
-
<ts-skeleton variant="circular" width="56px" height="56px"></ts-skeleton>
|
|
131
|
-
<div style="flex: 1;">
|
|
132
|
-
<ts-skeleton variant="text" width="50%" lines="1"></ts-skeleton>
|
|
133
|
-
<ts-skeleton variant="text" width="30%" lines="1"></ts-skeleton>
|
|
134
|
-
</div>
|
|
135
|
-
</div>
|
|
136
|
-
<ts-skeleton variant="rectangular" width="100%" height="240px"></ts-skeleton>
|
|
137
|
-
<ts-skeleton variant="text" lines="4"></ts-skeleton>
|
|
138
|
-
</div>
|
|
139
|
-
`;
|
|
140
|
-
//# sourceMappingURL=skeleton.stories.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"skeleton.stories.js","sourceRoot":"","sources":["../../../src/components/skeleton/skeleton.stories.ts"],"names":[],"mappings":"AAAA,uCAAuC;AAEvC,eAAe;IACb,KAAK,EAAE,qBAAqB;IAC5B,IAAI,EAAE,CAAC,UAAU,CAAC;IAClB,QAAQ,EAAE;QACR,OAAO,EAAE;YACP,OAAO,EAAE,QAAQ;YACjB,OAAO,EAAE,CAAC,MAAM,EAAE,UAAU,EAAE,aAAa,CAAC;YAC5C,WAAW,EAAE,6BAA6B;SAC3C;QACD,KAAK,EAAE;YACL,OAAO,EAAE,MAAM;YACf,WAAW,EAAE,4BAA4B;SAC1C;QACD,MAAM,EAAE;YACN,OAAO,EAAE,MAAM;YACf,WAAW,EAAE,6BAA6B;SAC3C;QACD,KAAK,EAAE;YACL,OAAO,EAAE,QAAQ;YACjB,WAAW,EAAE,gDAAgD;SAC9D;QACD,SAAS,EAAE;YACT,OAAO,EAAE,QAAQ;YACjB,OAAO,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC;YAClC,WAAW,EAAE,kBAAkB;SAChC;KACF;CACF,CAAC;AAEF,MAAM,QAAQ,GAAG,CAAC,IAA6B,EAAU,EAAE;IACzD,MAAM,KAAK,GAAa,EAAE,CAAC;IAC3B,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS;QAAE,KAAK,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;IACxE,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS;QAAE,KAAK,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;IAClE,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS;QAAE,KAAK,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;IACrE,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS;QAAE,KAAK,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;IAClE,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS;QAAE,KAAK,CAAC,IAAI,CAAC,cAAc,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;IAC9E,OAAO,gBAAgB,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,iBAAiB,CAAC;AAC1D,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAwD,EAAE;IAC7G,IAAI,EAAE;QACJ,OAAO,EAAE,MAAM;QACf,KAAK,EAAE,MAAM;QACb,KAAK,EAAE,CAAC;QACR,SAAS,EAAE,OAAO;KACnB;CACF,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,QAAQ,GAAG,GAAW,EAAE,CAAC;;;;;;;;;;;;;;;CAerC,CAAC;AAEF,MAAM,CAAC,MAAM,MAAM,GAAG,GAAW,EAAE,CAAC;;;;;;;;;;;;;;;CAenC,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAG,GAAW,EAAE,CAAC;;;;;;;;;;CAUxC,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAG,GAAW,EAAE,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA+BxC,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAG,GAAW,EAAE,CAAC;;;;;;;;;;;;CAYxC,CAAC","sourcesContent":["// Hand-written stories for ts-skeleton\n\nexport default {\n title: 'Components/Skeleton',\n tags: ['autodocs'],\n argTypes: {\n variant: {\n control: 'select',\n options: ['text', 'circular', 'rectangular'],\n description: 'The skeleton shape variant.',\n },\n width: {\n control: 'text',\n description: 'CSS width of the skeleton.',\n },\n height: {\n control: 'text',\n description: 'CSS height of the skeleton.',\n },\n lines: {\n control: 'number',\n description: 'Number of lines to render (text variant only).',\n },\n animation: {\n control: 'select',\n options: ['pulse', 'wave', 'none'],\n description: 'Animation style.',\n },\n },\n};\n\nconst Template = (args: Record<string, unknown>): string => {\n const attrs: string[] = [];\n if (args.variant !== undefined) attrs.push(`variant=\"${args.variant}\"`);\n if (args.width !== undefined) attrs.push(`width=\"${args.width}\"`);\n if (args.height !== undefined) attrs.push(`height=\"${args.height}\"`);\n if (args.lines !== undefined) attrs.push(`lines=\"${args.lines}\"`);\n if (args.animation !== undefined) attrs.push(`animation=\"${args.animation}\"`);\n return `<ts-skeleton ${attrs.join(' ')}></ts-skeleton>`;\n};\n\nexport const Default = Object.assign(Template.bind({}) as typeof Template & { args: Record<string, unknown> }, {\n args: {\n variant: 'text',\n width: '100%',\n lines: 3,\n animation: 'pulse',\n },\n});\n\nexport const Variants = (): string => `\n <div style=\"display: flex; flex-direction: column; gap: 24px; max-width: 400px;\">\n <div>\n <p style=\"margin: 0 0 8px; font-family: sans-serif; font-size: 14px; color: #666;\">Text (3 lines)</p>\n <ts-skeleton variant=\"text\" lines=\"3\"></ts-skeleton>\n </div>\n <div>\n <p style=\"margin: 0 0 8px; font-family: sans-serif; font-size: 14px; color: #666;\">Circular (avatar)</p>\n <ts-skeleton variant=\"circular\" width=\"48px\" height=\"48px\"></ts-skeleton>\n </div>\n <div>\n <p style=\"margin: 0 0 8px; font-family: sans-serif; font-size: 14px; color: #666;\">Rectangular (image)</p>\n <ts-skeleton variant=\"rectangular\" width=\"100%\" height=\"200px\"></ts-skeleton>\n </div>\n </div>\n`;\n\nexport const States = (): string => `\n <div style=\"display: flex; flex-direction: column; gap: 24px; max-width: 400px;\">\n <div>\n <p style=\"margin: 0 0 8px; font-family: sans-serif; font-size: 14px; color: #666;\">Pulse animation (default)</p>\n <ts-skeleton variant=\"text\" lines=\"2\" animation=\"pulse\"></ts-skeleton>\n </div>\n <div>\n <p style=\"margin: 0 0 8px; font-family: sans-serif; font-size: 14px; color: #666;\">Wave animation</p>\n <ts-skeleton variant=\"text\" lines=\"2\" animation=\"wave\"></ts-skeleton>\n </div>\n <div>\n <p style=\"margin: 0 0 8px; font-family: sans-serif; font-size: 14px; color: #666;\">No animation</p>\n <ts-skeleton variant=\"text\" lines=\"2\" animation=\"none\"></ts-skeleton>\n </div>\n </div>\n`;\n\nexport const LoadingCard = (): string => `\n <div style=\"max-width: 320px; border: 1px solid #e2e8f0; border-radius: 8px; padding: 16px; display: flex; flex-direction: column; gap: 12px;\">\n <ts-skeleton variant=\"rectangular\" width=\"100%\" height=\"180px\"></ts-skeleton>\n <ts-skeleton variant=\"text\" width=\"60%\" lines=\"1\"></ts-skeleton>\n <ts-skeleton variant=\"text\" lines=\"3\"></ts-skeleton>\n <div style=\"display: flex; gap: 8px;\">\n <ts-skeleton variant=\"rectangular\" width=\"80px\" height=\"32px\"></ts-skeleton>\n <ts-skeleton variant=\"rectangular\" width=\"80px\" height=\"32px\"></ts-skeleton>\n </div>\n </div>\n`;\n\nexport const LoadingList = (): string => `\n <div style=\"max-width: 400px; display: flex; flex-direction: column; gap: 16px;\">\n <div style=\"display: flex; gap: 12px; align-items: center;\">\n <ts-skeleton variant=\"circular\" width=\"40px\" height=\"40px\"></ts-skeleton>\n <div style=\"flex: 1;\">\n <ts-skeleton variant=\"text\" width=\"70%\" lines=\"1\"></ts-skeleton>\n <ts-skeleton variant=\"text\" width=\"40%\" lines=\"1\"></ts-skeleton>\n </div>\n </div>\n <div style=\"display: flex; gap: 12px; align-items: center;\">\n <ts-skeleton variant=\"circular\" width=\"40px\" height=\"40px\"></ts-skeleton>\n <div style=\"flex: 1;\">\n <ts-skeleton variant=\"text\" width=\"70%\" lines=\"1\"></ts-skeleton>\n <ts-skeleton variant=\"text\" width=\"40%\" lines=\"1\"></ts-skeleton>\n </div>\n </div>\n <div style=\"display: flex; gap: 12px; align-items: center;\">\n <ts-skeleton variant=\"circular\" width=\"40px\" height=\"40px\"></ts-skeleton>\n <div style=\"flex: 1;\">\n <ts-skeleton variant=\"text\" width=\"70%\" lines=\"1\"></ts-skeleton>\n <ts-skeleton variant=\"text\" width=\"40%\" lines=\"1\"></ts-skeleton>\n </div>\n </div>\n <div style=\"display: flex; gap: 12px; align-items: center;\">\n <ts-skeleton variant=\"circular\" width=\"40px\" height=\"40px\"></ts-skeleton>\n <div style=\"flex: 1;\">\n <ts-skeleton variant=\"text\" width=\"70%\" lines=\"1\"></ts-skeleton>\n <ts-skeleton variant=\"text\" width=\"40%\" lines=\"1\"></ts-skeleton>\n </div>\n </div>\n </div>\n`;\n\nexport const Composition = (): string => `\n <div style=\"max-width: 400px; display: flex; flex-direction: column; gap: 16px;\">\n <div style=\"display: flex; gap: 12px; align-items: center;\">\n <ts-skeleton variant=\"circular\" width=\"56px\" height=\"56px\"></ts-skeleton>\n <div style=\"flex: 1;\">\n <ts-skeleton variant=\"text\" width=\"50%\" lines=\"1\"></ts-skeleton>\n <ts-skeleton variant=\"text\" width=\"30%\" lines=\"1\"></ts-skeleton>\n </div>\n </div>\n <ts-skeleton variant=\"rectangular\" width=\"100%\" height=\"240px\"></ts-skeleton>\n <ts-skeleton variant=\"text\" lines=\"4\"></ts-skeleton>\n </div>\n`;\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"slider.js","sourceRoot":"","sources":["../../../src/components/slider/slider.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Prop, Event, State, h, Host, Element } from '@stencil/core';\nimport type { EventEmitter } from '@stencil/core';\nimport type { TsSize } from '../../types';\n\n/**\n * @part track - The slider track.\n * @part fill - The filled portion of the track.\n * @part thumb - The draggable thumb.\n * @part label - The value label.\n */\n@Component({\n tag: 'ts-slider',\n styleUrl: 'slider.css',\n shadow: true,\n})\nexport class TsSlider {\n @Element() hostEl!: HTMLElement;\n\n private trackEl?: HTMLElement;\n\n @State() dragging = false;\n\n /** Current slider value. */\n @Prop({ mutable: true, reflect: true }) value = 0;\n\n /** Minimum value. */\n @Prop() min = 0;\n\n /** Maximum value. */\n @Prop() max = 100;\n\n /** Step increment. */\n @Prop() step = 1;\n\n /** Disables the slider. */\n @Prop({ reflect: true }) disabled = false;\n\n /** Accessible label. */\n @Prop() label?: string;\n\n /** Whether to display the current value. */\n @Prop({ reflect: true }) showValue = false;\n\n /** The size of the slider. */\n @Prop({ reflect: true }) size: TsSize = 'md';\n\n /** Emitted continuously during drag. */\n @Event({ eventName: 'tsInput' }) tsInput!: EventEmitter<{ value: number }>;\n\n /** Emitted when drag ends (value committed). */\n @Event({ eventName: 'tsChange' }) tsChange!: EventEmitter<{ value: number }>;\n\n private get percentage(): number {\n const range = this.max - this.min;\n if (range <= 0) return 0;\n return ((this.value - this.min) / range) * 100;\n }\n\n private clampAndStep(val: number): number {\n // Snap to step\n const stepped = Math.round((val - this.min) / this.step) * this.step + this.min;\n // Clamp\n return Math.min(this.max, Math.max(this.min, stepped));\n }\n\n private updateValueFromPosition(clientX: number): void {\n if (!this.trackEl) return;\n const rect = this.trackEl.getBoundingClientRect();\n const ratio = (clientX - rect.left) / rect.width;\n const rawValue = this.min + ratio * (this.max - this.min);\n this.value = this.clampAndStep(rawValue);\n }\n\n private handleMouseDown = (event: MouseEvent): void => {\n if (this.disabled) return;\n event.preventDefault();\n this.dragging = true;\n this.updateValueFromPosition(event.clientX);\n this.tsInput.emit({ value: this.value });\n\n const handleMouseMove = (e: MouseEvent): void => {\n this.updateValueFromPosition(e.clientX);\n this.tsInput.emit({ value: this.value });\n };\n\n const handleMouseUp = (): void => {\n this.dragging = false;\n this.tsChange.emit({ value: this.value });\n document.removeEventListener('mousemove', handleMouseMove);\n document.removeEventListener('mouseup', handleMouseUp);\n };\n\n document.addEventListener('mousemove', handleMouseMove);\n document.addEventListener('mouseup', handleMouseUp);\n };\n\n private handleKeyDown = (event: KeyboardEvent): void => {\n if (this.disabled) return;\n\n let newValue = this.value;\n const bigStep = this.step * 10;\n\n switch (event.key) {\n case 'ArrowRight':\n case 'ArrowUp':\n event.preventDefault();\n newValue = this.clampAndStep(this.value + this.step);\n break;\n case 'ArrowLeft':\n case 'ArrowDown':\n event.preventDefault();\n newValue = this.clampAndStep(this.value - this.step);\n break;\n case 'PageUp':\n event.preventDefault();\n newValue = this.clampAndStep(this.value + bigStep);\n break;\n case 'PageDown':\n event.preventDefault();\n newValue = this.clampAndStep(this.value - bigStep);\n break;\n case 'Home':\n event.preventDefault();\n newValue = this.min;\n break;\n case 'End':\n event.preventDefault();\n newValue = this.max;\n break;\n default:\n return;\n }\n\n if (newValue !== this.value) {\n this.value = newValue;\n this.tsInput.emit({ value: this.value });\n this.tsChange.emit({ value: this.value });\n }\n };\n\n // eslint-disable-next-line @typescript-eslint/explicit-function-return-type\n render() {\n const percent = this.percentage;\n\n return (\n <Host\n class={{\n 'ts-slider': true,\n [`ts-slider--${this.size}`]: true,\n 'ts-slider--disabled': this.disabled,\n }}\n >\n {this.label && (\n <label class=\"slider__label\" part=\"label\">\n {this.label}\n {this.showValue && <span class=\"slider__value\">{this.value}</span>}\n </label>\n )}\n {!this.label && this.showValue && (\n <span class=\"slider__value\" part=\"label\" aria-hidden=\"true\">\n {this.value}\n </span>\n )}\n <div\n class=\"slider__track\"\n part=\"track\"\n ref={(el) => (this.trackEl = el)}\n onMouseDown={this.handleMouseDown}\n >\n <div\n class=\"slider__fill\"\n part=\"fill\"\n style={{ width: `${percent}%` }}\n />\n <div\n class=\"slider__thumb\"\n part=\"thumb\"\n role=\"slider\"\n tabindex={this.disabled ? -1 : 0}\n aria-valuenow={this.value}\n aria-valuemin={this.min}\n aria-valuemax={this.max}\n aria-label={this.label || undefined}\n aria-disabled={this.disabled ? 'true' : undefined}\n style={{ insetInlineStart: `${percent}%` }}\n onKeyDown={this.handleKeyDown}\n />\n </div>\n </Host>\n );\n }\n}\n"]}
|
|
@@ -1,100 +0,0 @@
|
|
|
1
|
-
// Hand-written stories for ts-slider
|
|
2
|
-
export default {
|
|
3
|
-
title: 'Components/Slider',
|
|
4
|
-
tags: ['autodocs'],
|
|
5
|
-
argTypes: {
|
|
6
|
-
value: {
|
|
7
|
-
control: { type: 'range', min: 0, max: 100, step: 1 },
|
|
8
|
-
description: 'Current slider value.',
|
|
9
|
-
},
|
|
10
|
-
min: {
|
|
11
|
-
control: 'number',
|
|
12
|
-
description: 'Minimum value.',
|
|
13
|
-
},
|
|
14
|
-
max: {
|
|
15
|
-
control: 'number',
|
|
16
|
-
description: 'Maximum value.',
|
|
17
|
-
},
|
|
18
|
-
step: {
|
|
19
|
-
control: 'number',
|
|
20
|
-
description: 'Step increment.',
|
|
21
|
-
},
|
|
22
|
-
disabled: {
|
|
23
|
-
control: 'boolean',
|
|
24
|
-
description: 'Disables the slider.',
|
|
25
|
-
},
|
|
26
|
-
label: {
|
|
27
|
-
control: 'text',
|
|
28
|
-
description: 'Accessible label.',
|
|
29
|
-
},
|
|
30
|
-
showValue: {
|
|
31
|
-
control: 'boolean',
|
|
32
|
-
description: 'Whether to display the current value.',
|
|
33
|
-
},
|
|
34
|
-
size: {
|
|
35
|
-
control: 'select',
|
|
36
|
-
options: ['sm', 'md', 'lg'],
|
|
37
|
-
description: 'The size of the slider.',
|
|
38
|
-
},
|
|
39
|
-
},
|
|
40
|
-
};
|
|
41
|
-
const Template = (args) => {
|
|
42
|
-
const attrs = [];
|
|
43
|
-
if (args.value !== undefined)
|
|
44
|
-
attrs.push(`value="${args.value}"`);
|
|
45
|
-
if (args.min !== undefined)
|
|
46
|
-
attrs.push(`min="${args.min}"`);
|
|
47
|
-
if (args.max !== undefined)
|
|
48
|
-
attrs.push(`max="${args.max}"`);
|
|
49
|
-
if (args.step !== undefined)
|
|
50
|
-
attrs.push(`step="${args.step}"`);
|
|
51
|
-
if (args.disabled)
|
|
52
|
-
attrs.push('disabled');
|
|
53
|
-
if (args.label !== undefined)
|
|
54
|
-
attrs.push(`label="${args.label}"`);
|
|
55
|
-
if (args.showValue)
|
|
56
|
-
attrs.push('show-value');
|
|
57
|
-
if (args.size !== undefined)
|
|
58
|
-
attrs.push(`size="${args.size}"`);
|
|
59
|
-
return `<div style="max-width: 400px;"><ts-slider ${attrs.join(' ')}></ts-slider></div>`;
|
|
60
|
-
};
|
|
61
|
-
export const Default = Object.assign(Template.bind({}), {
|
|
62
|
-
args: {
|
|
63
|
-
value: 50,
|
|
64
|
-
min: 0,
|
|
65
|
-
max: 100,
|
|
66
|
-
step: 1,
|
|
67
|
-
disabled: false,
|
|
68
|
-
label: 'Volume',
|
|
69
|
-
showValue: true,
|
|
70
|
-
size: 'md',
|
|
71
|
-
},
|
|
72
|
-
});
|
|
73
|
-
export const Sizes = () => `
|
|
74
|
-
<div style="display: flex; flex-direction: column; gap: 24px; max-width: 400px;">
|
|
75
|
-
<ts-slider value="50" label="Small" show-value size="sm"></ts-slider>
|
|
76
|
-
<ts-slider value="50" label="Medium" show-value size="md"></ts-slider>
|
|
77
|
-
<ts-slider value="50" label="Large" show-value size="lg"></ts-slider>
|
|
78
|
-
</div>
|
|
79
|
-
`;
|
|
80
|
-
export const States = () => `
|
|
81
|
-
<div style="display: flex; flex-direction: column; gap: 24px; max-width: 400px;">
|
|
82
|
-
<ts-slider value="70" label="Volume" show-value></ts-slider>
|
|
83
|
-
<ts-slider value="50" label="Disabled slider" show-value disabled></ts-slider>
|
|
84
|
-
</div>
|
|
85
|
-
`;
|
|
86
|
-
export const Composition = () => `
|
|
87
|
-
<div style="max-width: 400px; font-family: sans-serif;">
|
|
88
|
-
<div style="border: 1px solid #e2e8f0; border-radius: 8px; padding: 20px; display: flex; flex-direction: column; gap: 20px;">
|
|
89
|
-
<h4 style="margin: 0;">Audio Settings</h4>
|
|
90
|
-
<ts-slider value="75" label="Volume" show-value min="0" max="100"></ts-slider>
|
|
91
|
-
<ts-slider value="50" label="Brightness" show-value min="0" max="100"></ts-slider>
|
|
92
|
-
<ts-slider value="25" label="Bass" show-value min="0" max="100" step="5"></ts-slider>
|
|
93
|
-
<div>
|
|
94
|
-
<p style="margin: 0 0 8px; font-size: 14px; color: #666;">Price range ($0 - $500)</p>
|
|
95
|
-
<ts-slider value="250" label="Price range" show-value min="0" max="500" step="10"></ts-slider>
|
|
96
|
-
</div>
|
|
97
|
-
</div>
|
|
98
|
-
</div>
|
|
99
|
-
`;
|
|
100
|
-
//# sourceMappingURL=slider.stories.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"slider.stories.js","sourceRoot":"","sources":["../../../src/components/slider/slider.stories.ts"],"names":[],"mappings":"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","sourcesContent":["// Hand-written stories for ts-slider\n\nexport default {\n title: 'Components/Slider',\n tags: ['autodocs'],\n argTypes: {\n value: {\n control: { type: 'range', min: 0, max: 100, step: 1 },\n description: 'Current slider value.',\n },\n min: {\n control: 'number',\n description: 'Minimum value.',\n },\n max: {\n control: 'number',\n description: 'Maximum value.',\n },\n step: {\n control: 'number',\n description: 'Step increment.',\n },\n disabled: {\n control: 'boolean',\n description: 'Disables the slider.',\n },\n label: {\n control: 'text',\n description: 'Accessible label.',\n },\n showValue: {\n control: 'boolean',\n description: 'Whether to display the current value.',\n },\n size: {\n control: 'select',\n options: ['sm', 'md', 'lg'],\n description: 'The size of the slider.',\n },\n },\n};\n\nconst Template = (args: Record<string, unknown>): string => {\n const attrs: string[] = [];\n if (args.value !== undefined) attrs.push(`value=\"${args.value}\"`);\n if (args.min !== undefined) attrs.push(`min=\"${args.min}\"`);\n if (args.max !== undefined) attrs.push(`max=\"${args.max}\"`);\n if (args.step !== undefined) attrs.push(`step=\"${args.step}\"`);\n if (args.disabled) attrs.push('disabled');\n if (args.label !== undefined) attrs.push(`label=\"${args.label}\"`);\n if (args.showValue) attrs.push('show-value');\n if (args.size !== undefined) attrs.push(`size=\"${args.size}\"`);\n return `<div style=\"max-width: 400px;\"><ts-slider ${attrs.join(' ')}></ts-slider></div>`;\n};\n\nexport const Default = Object.assign(Template.bind({}) as typeof Template & { args: Record<string, unknown> }, {\n args: {\n value: 50,\n min: 0,\n max: 100,\n step: 1,\n disabled: false,\n label: 'Volume',\n showValue: true,\n size: 'md',\n },\n});\n\nexport const Sizes = (): string => `\n <div style=\"display: flex; flex-direction: column; gap: 24px; max-width: 400px;\">\n <ts-slider value=\"50\" label=\"Small\" show-value size=\"sm\"></ts-slider>\n <ts-slider value=\"50\" label=\"Medium\" show-value size=\"md\"></ts-slider>\n <ts-slider value=\"50\" label=\"Large\" show-value size=\"lg\"></ts-slider>\n </div>\n`;\n\nexport const States = (): string => `\n <div style=\"display: flex; flex-direction: column; gap: 24px; max-width: 400px;\">\n <ts-slider value=\"70\" label=\"Volume\" show-value></ts-slider>\n <ts-slider value=\"50\" label=\"Disabled slider\" show-value disabled></ts-slider>\n </div>\n`;\n\nexport const Composition = (): string => `\n <div style=\"max-width: 400px; font-family: sans-serif;\">\n <div style=\"border: 1px solid #e2e8f0; border-radius: 8px; padding: 20px; display: flex; flex-direction: column; gap: 20px;\">\n <h4 style=\"margin: 0;\">Audio Settings</h4>\n <ts-slider value=\"75\" label=\"Volume\" show-value min=\"0\" max=\"100\"></ts-slider>\n <ts-slider value=\"50\" label=\"Brightness\" show-value min=\"0\" max=\"100\"></ts-slider>\n <ts-slider value=\"25\" label=\"Bass\" show-value min=\"0\" max=\"100\" step=\"5\"></ts-slider>\n <div>\n <p style=\"margin: 0 0 8px; font-size: 14px; color: #666;\">Price range ($0 - $500)</p>\n <ts-slider value=\"250\" label=\"Price range\" show-value min=\"0\" max=\"500\" step=\"10\"></ts-slider>\n </div>\n </div>\n </div>\n`;\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"spacer.js","sourceRoot":"","sources":["../../../src/components/spacer/spacer.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAEzD;;GAEG;AAMH,MAAM,OAAO,QAAQ;IACnB,+DAA+D;IACtC,IAAI,GAAW,GAAG,CAAC;IAE5C,kDAAkD;IACzB,IAAI,GAA8B,UAAU,CAAC;IAEtE,4EAA4E;IAC5E,MAAM;QACJ,MAAM,KAAK,GACT,IAAI,CAAC,IAAI,KAAK,YAAY;YACxB,CAAC,CAAC,EAAE,KAAK,EAAE,oBAAoB,IAAI,CAAC,IAAI,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE;YAC7D,CAAC,CAAC,EAAE,MAAM,EAAE,oBAAoB,IAAI,CAAC,IAAI,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC;QAElE,OAAO,EAAC,IAAI,qDAAC,KAAK,EAAE,KAAK,GAAS,CAAC;IACrC,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, Prop, h, Host } from '@stencil/core';\n\n/**\n * An explicit spacing element for adding vertical or horizontal space.\n */\n@Component({\n tag: 'ts-spacer',\n styleUrl: 'spacer.css',\n shadow: true,\n})\nexport class TsSpacer {\n /** Spacing token number controlling the size of the spacer. */\n @Prop({ reflect: true }) size: string = '4';\n\n /** The axis along which the spacer adds space. */\n @Prop({ reflect: true }) axis: 'vertical' | 'horizontal' = 'vertical';\n\n // eslint-disable-next-line @typescript-eslint/explicit-function-return-type\n render() {\n const style =\n this.axis === 'horizontal'\n ? { width: `var(--ts-spacing-${this.size})`, height: '100%' }\n : { height: `var(--ts-spacing-${this.size})`, width: '100%' };\n\n return <Host style={style}></Host>;\n }\n}\n"]}
|
|
@@ -1,90 +0,0 @@
|
|
|
1
|
-
// Hand-written stories for ts-spacer
|
|
2
|
-
export default {
|
|
3
|
-
title: 'Layout/Spacer',
|
|
4
|
-
tags: ['autodocs'],
|
|
5
|
-
argTypes: {
|
|
6
|
-
size: {
|
|
7
|
-
control: 'select',
|
|
8
|
-
options: ['0', '1', '2', '3', '4', '5', '6', '8', '10', '12', '16'],
|
|
9
|
-
description: 'Spacing token number controlling the size of the spacer.',
|
|
10
|
-
},
|
|
11
|
-
axis: {
|
|
12
|
-
control: 'select',
|
|
13
|
-
options: ['vertical', 'horizontal'],
|
|
14
|
-
description: 'The axis along which the spacer adds space.',
|
|
15
|
-
},
|
|
16
|
-
},
|
|
17
|
-
};
|
|
18
|
-
const Template = (args) => {
|
|
19
|
-
const attrs = [];
|
|
20
|
-
if (args.size !== undefined)
|
|
21
|
-
attrs.push(`size="${args.size}"`);
|
|
22
|
-
if (args.axis !== undefined)
|
|
23
|
-
attrs.push(`axis="${args.axis}"`);
|
|
24
|
-
return `
|
|
25
|
-
<div style="font-family: sans-serif;">
|
|
26
|
-
<div style="padding: 12px; background: #e2e8f0; border-radius: 4px;">Above spacer</div>
|
|
27
|
-
<ts-spacer ${attrs.join(' ')} style="background: rgba(59, 130, 246, 0.15);"></ts-spacer>
|
|
28
|
-
<div style="padding: 12px; background: #e2e8f0; border-radius: 4px;">Below spacer</div>
|
|
29
|
-
</div>
|
|
30
|
-
`;
|
|
31
|
-
};
|
|
32
|
-
export const Default = Object.assign(Template.bind({}), {
|
|
33
|
-
args: {
|
|
34
|
-
size: '4',
|
|
35
|
-
axis: 'vertical',
|
|
36
|
-
},
|
|
37
|
-
});
|
|
38
|
-
export const Vertical = () => `
|
|
39
|
-
<div style="font-family: sans-serif; max-width: 400px;">
|
|
40
|
-
<h2 style="margin: 0;">First Section</h2>
|
|
41
|
-
<p style="margin: 0; color: #64748b;">Some content in the first section.</p>
|
|
42
|
-
<ts-spacer size="6" style="background: rgba(59, 130, 246, 0.1);"></ts-spacer>
|
|
43
|
-
<h2 style="margin: 0;">Second Section</h2>
|
|
44
|
-
<p style="margin: 0; color: #64748b;">Some content in the second section.</p>
|
|
45
|
-
<ts-spacer size="6" style="background: rgba(59, 130, 246, 0.1);"></ts-spacer>
|
|
46
|
-
<h2 style="margin: 0;">Third Section</h2>
|
|
47
|
-
<p style="margin: 0; color: #64748b;">Some content in the third section.</p>
|
|
48
|
-
</div>
|
|
49
|
-
`;
|
|
50
|
-
export const Horizontal = () => `
|
|
51
|
-
<div style="display: flex; align-items: center; font-family: sans-serif;">
|
|
52
|
-
<span style="padding: 8px 16px; background: #e2e8f0; border-radius: 4px;">Left</span>
|
|
53
|
-
<ts-spacer axis="horizontal" size="4" style="background: rgba(59, 130, 246, 0.15);"></ts-spacer>
|
|
54
|
-
<span style="padding: 8px 16px; background: #e2e8f0; border-radius: 4px;">Middle</span>
|
|
55
|
-
<ts-spacer axis="horizontal" size="8" style="background: rgba(59, 130, 246, 0.15);"></ts-spacer>
|
|
56
|
-
<span style="padding: 8px 16px; background: #e2e8f0; border-radius: 4px;">Right</span>
|
|
57
|
-
</div>
|
|
58
|
-
`;
|
|
59
|
-
export const Sizes = () => `
|
|
60
|
-
<div style="font-family: sans-serif;">
|
|
61
|
-
<p style="margin: 0 0 16px; font-size: 14px; color: #666;">Different vertical spacer sizes (highlighted in blue)</p>
|
|
62
|
-
<div style="display: flex; gap: 32px;">
|
|
63
|
-
<div style="flex: 1;">
|
|
64
|
-
<p style="margin: 0 0 4px; font-size: 12px; color: #999;">size="1"</p>
|
|
65
|
-
<div style="padding: 8px; background: #e2e8f0; border-radius: 4px;">Top</div>
|
|
66
|
-
<ts-spacer size="1" style="background: rgba(59, 130, 246, 0.2);"></ts-spacer>
|
|
67
|
-
<div style="padding: 8px; background: #e2e8f0; border-radius: 4px;">Bottom</div>
|
|
68
|
-
</div>
|
|
69
|
-
<div style="flex: 1;">
|
|
70
|
-
<p style="margin: 0 0 4px; font-size: 12px; color: #999;">size="4"</p>
|
|
71
|
-
<div style="padding: 8px; background: #e2e8f0; border-radius: 4px;">Top</div>
|
|
72
|
-
<ts-spacer size="4" style="background: rgba(59, 130, 246, 0.2);"></ts-spacer>
|
|
73
|
-
<div style="padding: 8px; background: #e2e8f0; border-radius: 4px;">Bottom</div>
|
|
74
|
-
</div>
|
|
75
|
-
<div style="flex: 1;">
|
|
76
|
-
<p style="margin: 0 0 4px; font-size: 12px; color: #999;">size="8"</p>
|
|
77
|
-
<div style="padding: 8px; background: #e2e8f0; border-radius: 4px;">Top</div>
|
|
78
|
-
<ts-spacer size="8" style="background: rgba(59, 130, 246, 0.2);"></ts-spacer>
|
|
79
|
-
<div style="padding: 8px; background: #e2e8f0; border-radius: 4px;">Bottom</div>
|
|
80
|
-
</div>
|
|
81
|
-
<div style="flex: 1;">
|
|
82
|
-
<p style="margin: 0 0 4px; font-size: 12px; color: #999;">size="12"</p>
|
|
83
|
-
<div style="padding: 8px; background: #e2e8f0; border-radius: 4px;">Top</div>
|
|
84
|
-
<ts-spacer size="12" style="background: rgba(59, 130, 246, 0.2);"></ts-spacer>
|
|
85
|
-
<div style="padding: 8px; background: #e2e8f0; border-radius: 4px;">Bottom</div>
|
|
86
|
-
</div>
|
|
87
|
-
</div>
|
|
88
|
-
</div>
|
|
89
|
-
`;
|
|
90
|
-
//# sourceMappingURL=spacer.stories.js.map
|