ui-lab-registry 0.3.44 → 0.3.45
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/Anchor/examples/01-inline-text.d.ts +6 -0
- package/dist/components/Anchor/examples/01-inline-text.d.ts.map +1 -0
- package/dist/components/Anchor/examples/01-inline-text.js +10 -0
- package/dist/components/Anchor/examples/01-inline-text.js.map +1 -0
- package/dist/components/Anchor/examples/02-underline-variants.d.ts +6 -0
- package/dist/components/Anchor/examples/02-underline-variants.d.ts.map +1 -0
- package/dist/components/Anchor/examples/02-underline-variants.js +10 -0
- package/dist/components/Anchor/examples/02-underline-variants.js.map +1 -0
- package/dist/components/Anchor/examples/03-preview-tooltip.d.ts +6 -0
- package/dist/components/Anchor/examples/03-preview-tooltip.d.ts.map +1 -0
- package/dist/components/Anchor/examples/03-preview-tooltip.js +10 -0
- package/dist/components/Anchor/examples/03-preview-tooltip.js.map +1 -0
- package/dist/components/Anchor/examples/04-breadcrumb.d.ts +6 -0
- package/dist/components/Anchor/examples/04-breadcrumb.d.ts.map +1 -0
- package/dist/components/Anchor/examples/04-breadcrumb.js +15 -0
- package/dist/components/Anchor/examples/04-breadcrumb.js.map +1 -0
- package/dist/components/Anchor/examples/index.d.ts +8 -1
- package/dist/components/Anchor/examples/index.d.ts.map +1 -1
- package/dist/components/Anchor/examples/index.js +8 -1
- package/dist/components/Anchor/examples/index.js.map +1 -1
- package/dist/components/Anchor/examples.json +19 -4
- package/dist/components/Anchor/index.d.ts.map +1 -1
- package/dist/components/Anchor/index.js +8 -2
- package/dist/components/Anchor/index.js.map +1 -1
- package/dist/components/Badge/examples/01-status-badges.d.ts +6 -0
- package/dist/components/Badge/examples/01-status-badges.d.ts.map +1 -0
- package/dist/components/Badge/examples/01-status-badges.js +10 -0
- package/dist/components/Badge/examples/01-status-badges.js.map +1 -0
- package/dist/components/Badge/examples/02-icon-position.d.ts +6 -0
- package/dist/components/Badge/examples/02-icon-position.d.ts.map +1 -0
- package/dist/components/Badge/examples/02-icon-position.js +11 -0
- package/dist/components/Badge/examples/02-icon-position.js.map +1 -0
- package/dist/components/Badge/examples/02-variants-and-sizes.d.ts.map +1 -1
- package/dist/components/Badge/examples/02-variants-and-sizes.js +3 -3
- package/dist/components/Badge/examples/02-variants-and-sizes.js.map +1 -1
- package/dist/components/Badge/examples/03-selectable-tags.d.ts +6 -0
- package/dist/components/Badge/examples/03-selectable-tags.d.ts.map +1 -0
- package/dist/components/Badge/examples/03-selectable-tags.js +21 -0
- package/dist/components/Badge/examples/03-selectable-tags.js.map +1 -0
- package/dist/components/Badge/examples/04-dismissible.d.ts +6 -0
- package/dist/components/Badge/examples/04-dismissible.d.ts.map +1 -0
- package/dist/components/Badge/examples/04-dismissible.js +14 -0
- package/dist/components/Badge/examples/04-dismissible.js.map +1 -0
- package/dist/components/Badge/examples/05-semantic-colors.d.ts +6 -0
- package/dist/components/Badge/examples/05-semantic-colors.d.ts.map +1 -0
- package/dist/components/Badge/examples/05-semantic-colors.js +10 -0
- package/dist/components/Badge/examples/05-semantic-colors.js.map +1 -0
- package/dist/components/Badge/examples/index.d.ts +10 -4
- package/dist/components/Badge/examples/index.d.ts.map +1 -1
- package/dist/components/Badge/examples/index.js +10 -4
- package/dist/components/Badge/examples/index.js.map +1 -1
- package/dist/components/Badge/examples.json +24 -9
- package/dist/components/Badge/index.d.ts.map +1 -1
- package/dist/components/Badge/index.js +12 -15
- package/dist/components/Badge/index.js.map +1 -1
- package/dist/components/Banner/examples/01-variants.d.ts +6 -0
- package/dist/components/Banner/examples/01-variants.d.ts.map +1 -0
- package/dist/components/Banner/examples/01-variants.js +10 -0
- package/dist/components/Banner/examples/01-variants.js.map +1 -0
- package/dist/components/Banner/examples/02-dismissible.d.ts +6 -0
- package/dist/components/Banner/examples/02-dismissible.d.ts.map +1 -0
- package/dist/components/Banner/examples/02-dismissible.js +13 -0
- package/dist/components/Banner/examples/02-dismissible.js.map +1 -0
- package/dist/components/Banner/examples/03-form-feedback.d.ts +6 -0
- package/dist/components/Banner/examples/03-form-feedback.d.ts.map +1 -0
- package/dist/components/Banner/examples/03-form-feedback.js +21 -0
- package/dist/components/Banner/examples/03-form-feedback.js.map +1 -0
- package/dist/components/Banner/examples/04-settings-panel.d.ts +6 -0
- package/dist/components/Banner/examples/04-settings-panel.d.ts.map +1 -0
- package/dist/components/Banner/examples/04-settings-panel.js +10 -0
- package/dist/components/Banner/examples/04-settings-panel.js.map +1 -0
- package/dist/components/Banner/examples/05-body-only.d.ts +6 -0
- package/dist/components/Banner/examples/05-body-only.d.ts.map +1 -0
- package/dist/components/Banner/examples/05-body-only.js +10 -0
- package/dist/components/Banner/examples/05-body-only.js.map +1 -0
- package/dist/components/Banner/examples/index.d.ts +10 -2
- package/dist/components/Banner/examples/index.d.ts.map +1 -1
- package/dist/components/Banner/examples/index.js +10 -2
- package/dist/components/Banner/examples/index.js.map +1 -1
- package/dist/components/Banner/examples.json +24 -4
- package/dist/components/Banner/index.d.ts.map +1 -1
- package/dist/components/Banner/index.js +13 -16
- package/dist/components/Banner/index.js.map +1 -1
- package/dist/components/Button/examples/01-variants.d.ts.map +1 -1
- package/dist/components/Button/examples/01-variants.js +12 -4
- package/dist/components/Button/examples/01-variants.js.map +1 -1
- package/dist/components/Button/examples/02-multi-actions.d.ts.map +1 -1
- package/dist/components/Button/examples/02-multi-actions.js.map +1 -1
- package/dist/components/Button/examples/04-sub-stack-actions.js +1 -1
- package/dist/components/Button/examples/04-sub-stack-actions.js.map +1 -1
- package/dist/components/Button/examples/06-icons.d.ts +6 -0
- package/dist/components/Button/examples/06-icons.d.ts.map +1 -0
- package/dist/components/Button/examples/06-icons.js +11 -0
- package/dist/components/Button/examples/06-icons.js.map +1 -0
- package/dist/components/Button/examples/07-split-button.d.ts +6 -0
- package/dist/components/Button/examples/07-split-button.d.ts.map +1 -0
- package/dist/components/Button/examples/07-split-button.js +20 -0
- package/dist/components/Button/examples/07-split-button.js.map +1 -0
- package/dist/components/Button/examples/08-button-group.d.ts +6 -0
- package/dist/components/Button/examples/08-button-group.d.ts.map +1 -0
- package/dist/components/Button/examples/08-button-group.js +14 -0
- package/dist/components/Button/examples/08-button-group.js.map +1 -0
- package/dist/components/Button/examples/index.d.ts +6 -0
- package/dist/components/Button/examples/index.d.ts.map +1 -1
- package/dist/components/Button/examples/index.js +6 -0
- package/dist/components/Button/examples/index.js.map +1 -1
- package/dist/components/Button/examples.json +19 -4
- package/dist/components/Button/index.d.ts.map +1 -1
- package/dist/components/Button/index.js +6 -0
- package/dist/components/Button/index.js.map +1 -1
- package/dist/components/Card/examples/01-notification.d.ts +6 -0
- package/dist/components/Card/examples/01-notification.d.ts.map +1 -0
- package/dist/components/Card/examples/01-notification.js +13 -0
- package/dist/components/Card/examples/01-notification.js.map +1 -0
- package/dist/components/Card/examples/02-settings-panel.d.ts +6 -0
- package/dist/components/Card/examples/02-settings-panel.d.ts.map +1 -0
- package/dist/components/Card/examples/02-settings-panel.js +18 -0
- package/dist/components/Card/examples/02-settings-panel.js.map +1 -0
- package/dist/components/Card/examples/03-task-progress.d.ts +6 -0
- package/dist/components/Card/examples/03-task-progress.d.ts.map +1 -0
- package/dist/components/Card/examples/03-task-progress.js +17 -0
- package/dist/components/Card/examples/03-task-progress.js.map +1 -0
- package/dist/components/Card/examples/index.d.ts +6 -2
- package/dist/components/Card/examples/index.d.ts.map +1 -1
- package/dist/components/Card/examples/index.js +6 -2
- package/dist/components/Card/examples/index.js.map +1 -1
- package/dist/components/Card/examples.json +14 -4
- package/dist/components/Card/index.d.ts.map +1 -1
- package/dist/components/Card/index.js +6 -2
- package/dist/components/Card/index.js.map +1 -1
- package/dist/components/Checkbox/examples/01-basic-states.d.ts +6 -0
- package/dist/components/Checkbox/examples/01-basic-states.d.ts.map +1 -0
- package/dist/components/Checkbox/examples/01-basic-states.js +10 -0
- package/dist/components/Checkbox/examples/01-basic-states.js.map +1 -0
- package/dist/components/Checkbox/examples/02-helper-text.d.ts +6 -0
- package/dist/components/Checkbox/examples/02-helper-text.d.ts.map +1 -0
- package/dist/components/Checkbox/examples/02-helper-text.js +10 -0
- package/dist/components/Checkbox/examples/02-helper-text.js.map +1 -0
- package/dist/components/Checkbox/examples/03-controlled.d.ts +6 -0
- package/dist/components/Checkbox/examples/03-controlled.d.ts.map +1 -0
- package/dist/components/Checkbox/examples/03-controlled.js +13 -0
- package/dist/components/Checkbox/examples/03-controlled.js.map +1 -0
- package/dist/components/Checkbox/examples/04-group.d.ts +6 -0
- package/dist/components/Checkbox/examples/04-group.d.ts.map +1 -0
- package/dist/components/Checkbox/examples/04-group.js +25 -0
- package/dist/components/Checkbox/examples/04-group.js.map +1 -0
- package/dist/components/Checkbox/examples/05-indeterminate.d.ts +6 -0
- package/dist/components/Checkbox/examples/05-indeterminate.d.ts.map +1 -0
- package/dist/components/Checkbox/examples/05-indeterminate.js +26 -0
- package/dist/components/Checkbox/examples/05-indeterminate.js.map +1 -0
- package/dist/components/Checkbox/examples/06-consent-form.d.ts +6 -0
- package/dist/components/Checkbox/examples/06-consent-form.d.ts.map +1 -0
- package/dist/components/Checkbox/examples/06-consent-form.js +14 -0
- package/dist/components/Checkbox/examples/06-consent-form.js.map +1 -0
- package/dist/components/Checkbox/examples/index.d.ts +12 -4
- package/dist/components/Checkbox/examples/index.d.ts.map +1 -1
- package/dist/components/Checkbox/examples/index.js +12 -4
- package/dist/components/Checkbox/examples/index.js.map +1 -1
- package/dist/components/Checkbox/examples.json +29 -9
- package/dist/components/Checkbox/index.d.ts.map +1 -1
- package/dist/components/Checkbox/index.js +13 -16
- package/dist/components/Checkbox/index.js.map +1 -1
- package/dist/components/Color/examples/01-basic-color-picker.d.ts +6 -0
- package/dist/components/Color/examples/01-basic-color-picker.d.ts.map +1 -0
- package/dist/components/Color/examples/01-basic-color-picker.js +11 -0
- package/dist/components/Color/examples/01-basic-color-picker.js.map +1 -0
- package/dist/components/Color/examples/02-color-picker-opacity.d.ts +6 -0
- package/dist/components/Color/examples/02-color-picker-opacity.d.ts.map +1 -0
- package/dist/components/Color/examples/02-color-picker-opacity.js +13 -0
- package/dist/components/Color/examples/02-color-picker-opacity.js.map +1 -0
- package/dist/components/Color/examples/03-color-picker-preview.d.ts +6 -0
- package/dist/components/Color/examples/03-color-picker-preview.d.ts.map +1 -0
- package/dist/components/Color/examples/03-color-picker-preview.js +13 -0
- package/dist/components/Color/examples/03-color-picker-preview.js.map +1 -0
- package/dist/components/Color/examples/04-color-slider-primitive.d.ts +6 -0
- package/dist/components/Color/examples/04-color-slider-primitive.d.ts.map +1 -0
- package/dist/components/Color/examples/04-color-slider-primitive.js +16 -0
- package/dist/components/Color/examples/04-color-slider-primitive.js.map +1 -0
- package/dist/components/Color/examples/index.d.ts +8 -3
- package/dist/components/Color/examples/index.d.ts.map +1 -1
- package/dist/components/Color/examples/index.js +8 -3
- package/dist/components/Color/examples/index.js.map +1 -1
- package/dist/components/Color/examples.json +18 -8
- package/dist/components/Color/index.d.ts.map +1 -1
- package/dist/components/Color/index.js +8 -4
- package/dist/components/Color/index.js.map +1 -1
- package/dist/components/Expand/examples/01-basic.d.ts +6 -0
- package/dist/components/Expand/examples/01-basic.d.ts.map +1 -0
- package/dist/components/Expand/examples/01-basic.js +10 -0
- package/dist/components/Expand/examples/01-basic.js.map +1 -0
- package/dist/components/Expand/examples/02-accordion.d.ts +6 -0
- package/dist/components/Expand/examples/02-accordion.d.ts.map +1 -0
- package/dist/components/Expand/examples/02-accordion.js +30 -0
- package/dist/components/Expand/examples/02-accordion.js.map +1 -0
- package/dist/components/Expand/examples/03-custom-trigger.d.ts +6 -0
- package/dist/components/Expand/examples/03-custom-trigger.d.ts.map +1 -0
- package/dist/components/Expand/examples/03-custom-trigger.js +11 -0
- package/dist/components/Expand/examples/03-custom-trigger.js.map +1 -0
- package/dist/components/Expand/examples/04-directions.d.ts +6 -0
- package/dist/components/Expand/examples/04-directions.d.ts.map +1 -0
- package/dist/components/Expand/examples/04-directions.js +10 -0
- package/dist/components/Expand/examples/04-directions.js.map +1 -0
- package/dist/components/Expand/examples/05-settings-panel.d.ts +6 -0
- package/dist/components/Expand/examples/05-settings-panel.d.ts.map +1 -0
- package/dist/components/Expand/examples/05-settings-panel.js +11 -0
- package/dist/components/Expand/examples/05-settings-panel.js.map +1 -0
- package/dist/components/Expand/examples/06-disabled.d.ts +6 -0
- package/dist/components/Expand/examples/06-disabled.d.ts.map +1 -0
- package/dist/components/Expand/examples/06-disabled.js +10 -0
- package/dist/components/Expand/examples/06-disabled.js.map +1 -0
- package/dist/components/Expand/examples/07-inline-info.d.ts +6 -0
- package/dist/components/Expand/examples/07-inline-info.d.ts.map +1 -0
- package/dist/components/Expand/examples/07-inline-info.js +11 -0
- package/dist/components/Expand/examples/07-inline-info.js.map +1 -0
- package/dist/components/Expand/examples/index.d.ts +14 -2
- package/dist/components/Expand/examples/index.d.ts.map +1 -1
- package/dist/components/Expand/examples/index.js +14 -2
- package/dist/components/Expand/examples/index.js.map +1 -1
- package/dist/components/Expand/examples.json +34 -4
- package/dist/components/Expand/index.d.ts.map +1 -1
- package/dist/components/Expand/index.js +14 -2
- package/dist/components/Expand/index.js.map +1 -1
- package/dist/components/Flex/examples/01-axis-control.d.ts +11 -0
- package/dist/components/Flex/examples/01-axis-control.d.ts.map +1 -0
- package/dist/components/Flex/examples/01-axis-control.js +149 -0
- package/dist/components/Flex/examples/01-axis-control.js.map +1 -0
- package/dist/components/Flex/examples/02-wrap-overflow.d.ts +11 -0
- package/dist/components/Flex/examples/02-wrap-overflow.d.ts.map +1 -0
- package/dist/components/Flex/examples/02-wrap-overflow.js +147 -0
- package/dist/components/Flex/examples/02-wrap-overflow.js.map +1 -0
- package/dist/components/Flex/examples/03-container-query-reflow.d.ts +11 -0
- package/dist/components/Flex/examples/03-container-query-reflow.d.ts.map +1 -0
- package/dist/components/Flex/examples/03-container-query-reflow.js +151 -0
- package/dist/components/Flex/examples/03-container-query-reflow.js.map +1 -0
- package/dist/components/Flex/examples/index.d.ts +6 -2
- package/dist/components/Flex/examples/index.d.ts.map +1 -1
- package/dist/components/Flex/examples/index.js +6 -2
- package/dist/components/Flex/examples/index.js.map +1 -1
- package/dist/components/Flex/examples.json +14 -4
- package/dist/components/Flex/index.d.ts.map +1 -1
- package/dist/components/Flex/index.js +12 -8
- package/dist/components/Flex/index.js.map +1 -1
- package/dist/components/Gallery/examples/01-grid-composition.d.ts +11 -0
- package/dist/components/Gallery/examples/01-grid-composition.d.ts.map +1 -0
- package/dist/components/Gallery/examples/01-grid-composition.js +95 -0
- package/dist/components/Gallery/examples/01-grid-composition.js.map +1 -0
- package/dist/components/Gallery/examples/02-item-orientation.d.ts +11 -0
- package/dist/components/Gallery/examples/02-item-orientation.d.ts.map +1 -0
- package/dist/components/Gallery/examples/02-item-orientation.js +106 -0
- package/dist/components/Gallery/examples/02-item-orientation.js.map +1 -0
- package/dist/components/Gallery/examples/03-span-layout.d.ts +11 -0
- package/dist/components/Gallery/examples/03-span-layout.d.ts.map +1 -0
- package/dist/components/Gallery/examples/03-span-layout.js +95 -0
- package/dist/components/Gallery/examples/03-span-layout.js.map +1 -0
- package/dist/components/Gallery/examples/index.d.ts +6 -2
- package/dist/components/Gallery/examples/index.d.ts.map +1 -1
- package/dist/components/Gallery/examples/index.js +6 -2
- package/dist/components/Gallery/examples/index.js.map +1 -1
- package/dist/components/Gallery/examples.json +14 -4
- package/dist/components/Gallery/index.d.ts.map +1 -1
- package/dist/components/Gallery/index.js +6 -2
- package/dist/components/Gallery/index.js.map +1 -1
- package/dist/components/Grid/examples/02-track-placement.d.ts +11 -0
- package/dist/components/Grid/examples/02-track-placement.d.ts.map +1 -0
- package/dist/components/Grid/examples/02-track-placement.js +181 -0
- package/dist/components/Grid/examples/02-track-placement.js.map +1 -0
- package/dist/components/Grid/examples/03-editorial-spans.d.ts +11 -0
- package/dist/components/Grid/examples/03-editorial-spans.d.ts.map +1 -0
- package/dist/components/Grid/examples/03-editorial-spans.js +167 -0
- package/dist/components/Grid/examples/03-editorial-spans.js.map +1 -0
- package/dist/components/Grid/examples/04-responsive-card-rail.d.ts +11 -0
- package/dist/components/Grid/examples/04-responsive-card-rail.d.ts.map +1 -0
- package/dist/components/Grid/examples/04-responsive-card-rail.js +126 -0
- package/dist/components/Grid/examples/04-responsive-card-rail.js.map +1 -0
- package/dist/components/Grid/examples/index.d.ts +6 -0
- package/dist/components/Grid/examples/index.d.ts.map +1 -1
- package/dist/components/Grid/examples/index.js +6 -0
- package/dist/components/Grid/examples/index.js.map +1 -1
- package/dist/components/Grid/examples.json +15 -0
- package/dist/components/Grid/index.d.ts.map +1 -1
- package/dist/components/Grid/index.js +6 -0
- package/dist/components/Grid/index.js.map +1 -1
- package/dist/components/Group/examples/02-create-project.d.ts +6 -0
- package/dist/components/Group/examples/02-create-project.d.ts.map +1 -0
- package/dist/components/Group/examples/02-create-project.js +11 -0
- package/dist/components/Group/examples/02-create-project.js.map +1 -0
- package/dist/components/Group/examples/03-filter-bar.d.ts +6 -0
- package/dist/components/Group/examples/03-filter-bar.d.ts.map +1 -0
- package/dist/components/Group/examples/03-filter-bar.js +14 -0
- package/dist/components/Group/examples/03-filter-bar.js.map +1 -0
- package/dist/components/Group/examples/04-documentation-search.d.ts +6 -0
- package/dist/components/Group/examples/04-documentation-search.d.ts.map +1 -0
- package/dist/components/Group/examples/04-documentation-search.js +11 -0
- package/dist/components/Group/examples/04-documentation-search.js.map +1 -0
- package/dist/components/Group/examples/05-email-signup.d.ts +6 -0
- package/dist/components/Group/examples/05-email-signup.d.ts.map +1 -0
- package/dist/components/Group/examples/05-email-signup.js +11 -0
- package/dist/components/Group/examples/05-email-signup.js.map +1 -0
- package/dist/components/Group/examples/06-copy-command.d.ts +6 -0
- package/dist/components/Group/examples/06-copy-command.d.ts.map +1 -0
- package/dist/components/Group/examples/06-copy-command.js +11 -0
- package/dist/components/Group/examples/06-copy-command.js.map +1 -0
- package/dist/components/Group/examples/07-delete-confirmation.d.ts +6 -0
- package/dist/components/Group/examples/07-delete-confirmation.d.ts.map +1 -0
- package/dist/components/Group/examples/07-delete-confirmation.js +11 -0
- package/dist/components/Group/examples/07-delete-confirmation.js.map +1 -0
- package/dist/components/Group/examples/08-slider-integration.d.ts +6 -0
- package/dist/components/Group/examples/08-slider-integration.d.ts.map +1 -0
- package/dist/components/Group/examples/08-slider-integration.js +19 -0
- package/dist/components/Group/examples/08-slider-integration.js.map +1 -0
- package/dist/components/Group/examples/index.d.ts +14 -0
- package/dist/components/Group/examples/index.d.ts.map +1 -1
- package/dist/components/Group/examples/index.js +14 -0
- package/dist/components/Group/examples/index.js.map +1 -1
- package/dist/components/Group/examples.json +35 -0
- package/dist/components/Group/index.d.ts.map +1 -1
- package/dist/components/Group/index.js +14 -0
- package/dist/components/Group/index.js.map +1 -1
- package/dist/components/Input/examples/03-sign-in.d.ts +6 -0
- package/dist/components/Input/examples/03-sign-in.d.ts.map +1 -0
- package/dist/components/Input/examples/03-sign-in.js +22 -0
- package/dist/components/Input/examples/03-sign-in.js.map +1 -0
- package/dist/components/Input/examples/04-search.d.ts +6 -0
- package/dist/components/Input/examples/04-search.d.ts.map +1 -0
- package/dist/components/Input/examples/04-search.js +16 -0
- package/dist/components/Input/examples/04-search.js.map +1 -0
- package/dist/components/Input/examples/05-user-handle.d.ts +6 -0
- package/dist/components/Input/examples/05-user-handle.d.ts.map +1 -0
- package/dist/components/Input/examples/05-user-handle.js +27 -0
- package/dist/components/Input/examples/05-user-handle.js.map +1 -0
- package/dist/components/Input/examples/06-api-key.d.ts +6 -0
- package/dist/components/Input/examples/06-api-key.d.ts.map +1 -0
- package/dist/components/Input/examples/06-api-key.js +35 -0
- package/dist/components/Input/examples/06-api-key.js.map +1 -0
- package/dist/components/Input/examples/07-url-validation.d.ts +6 -0
- package/dist/components/Input/examples/07-url-validation.d.ts.map +1 -0
- package/dist/components/Input/examples/07-url-validation.js +23 -0
- package/dist/components/Input/examples/07-url-validation.js.map +1 -0
- package/dist/components/Input/examples/08-quantity.d.ts +6 -0
- package/dist/components/Input/examples/08-quantity.d.ts.map +1 -0
- package/dist/components/Input/examples/08-quantity.js +13 -0
- package/dist/components/Input/examples/08-quantity.js.map +1 -0
- package/dist/components/Input/examples/index.d.ts +12 -0
- package/dist/components/Input/examples/index.d.ts.map +1 -1
- package/dist/components/Input/examples/index.js +12 -0
- package/dist/components/Input/examples/index.js.map +1 -1
- package/dist/components/Input/examples.json +30 -0
- package/dist/components/Input/index.d.ts.map +1 -1
- package/dist/components/Input/index.js +12 -0
- package/dist/components/Input/index.js.map +1 -1
- package/dist/components/List/examples/02-review-queue.d.ts +6 -0
- package/dist/components/List/examples/02-review-queue.d.ts.map +1 -0
- package/dist/components/List/examples/02-review-queue.js +32 -0
- package/dist/components/List/examples/02-review-queue.js.map +1 -0
- package/dist/components/List/examples/03-notification-rules.d.ts +6 -0
- package/dist/components/List/examples/03-notification-rules.d.ts.map +1 -0
- package/dist/components/List/examples/03-notification-rules.js +40 -0
- package/dist/components/List/examples/03-notification-rules.js.map +1 -0
- package/dist/components/List/examples/04-quota-editor.d.ts +6 -0
- package/dist/components/List/examples/04-quota-editor.d.ts.map +1 -0
- package/dist/components/List/examples/04-quota-editor.js +40 -0
- package/dist/components/List/examples/04-quota-editor.js.map +1 -0
- package/dist/components/List/examples/05-permissions-matrix.d.ts +6 -0
- package/dist/components/List/examples/05-permissions-matrix.d.ts.map +1 -0
- package/dist/components/List/examples/05-permissions-matrix.js +39 -0
- package/dist/components/List/examples/05-permissions-matrix.js.map +1 -0
- package/dist/components/List/examples/index.d.ts +8 -0
- package/dist/components/List/examples/index.d.ts.map +1 -1
- package/dist/components/List/examples/index.js +8 -0
- package/dist/components/List/examples/index.js.map +1 -1
- package/dist/components/List/examples.json +20 -0
- package/dist/components/List/index.d.ts.map +1 -1
- package/dist/components/List/index.js +10 -2
- package/dist/components/List/index.js.map +1 -1
- package/dist/components/Menu/examples/03-toolbar-dropdown.d.ts +6 -0
- package/dist/components/Menu/examples/03-toolbar-dropdown.d.ts.map +1 -0
- package/dist/components/Menu/examples/03-toolbar-dropdown.js +11 -0
- package/dist/components/Menu/examples/03-toolbar-dropdown.js.map +1 -0
- package/dist/components/Menu/examples/04-table-row-actions.d.ts +6 -0
- package/dist/components/Menu/examples/04-table-row-actions.d.ts.map +1 -0
- package/dist/components/Menu/examples/04-table-row-actions.js +16 -0
- package/dist/components/Menu/examples/04-table-row-actions.js.map +1 -0
- package/dist/components/Menu/examples/05-context-menu.d.ts +6 -0
- package/dist/components/Menu/examples/05-context-menu.d.ts.map +1 -0
- package/dist/components/Menu/examples/05-context-menu.js +10 -0
- package/dist/components/Menu/examples/05-context-menu.js.map +1 -0
- package/dist/components/Menu/examples/06-view-options.d.ts +6 -0
- package/dist/components/Menu/examples/06-view-options.d.ts.map +1 -0
- package/dist/components/Menu/examples/06-view-options.js +15 -0
- package/dist/components/Menu/examples/06-view-options.js.map +1 -0
- package/dist/components/Menu/examples/index.d.ts +8 -0
- package/dist/components/Menu/examples/index.d.ts.map +1 -1
- package/dist/components/Menu/examples/index.js +8 -0
- package/dist/components/Menu/examples/index.js.map +1 -1
- package/dist/components/Menu/examples.json +20 -0
- package/dist/components/Menu/index.d.ts.map +1 -1
- package/dist/components/Menu/index.js +8 -0
- package/dist/components/Menu/index.js.map +1 -1
- package/dist/components/Modal/examples/02-form-modal.js +1 -1
- package/dist/components/Modal/examples/02-form-modal.js.map +1 -1
- package/dist/components/Modal/examples/03-delete-confirmation.d.ts +6 -0
- package/dist/components/Modal/examples/03-delete-confirmation.d.ts.map +1 -0
- package/dist/components/Modal/examples/03-delete-confirmation.js +13 -0
- package/dist/components/Modal/examples/03-delete-confirmation.js.map +1 -0
- package/dist/components/Modal/examples/04-create-api-key.d.ts +6 -0
- package/dist/components/Modal/examples/04-create-api-key.d.ts.map +1 -0
- package/dist/components/Modal/examples/04-create-api-key.js +14 -0
- package/dist/components/Modal/examples/04-create-api-key.js.map +1 -0
- package/dist/components/Modal/examples/05-notification-settings.d.ts +6 -0
- package/dist/components/Modal/examples/05-notification-settings.d.ts.map +1 -0
- package/dist/components/Modal/examples/05-notification-settings.js +19 -0
- package/dist/components/Modal/examples/05-notification-settings.js.map +1 -0
- package/dist/components/Modal/examples/index.d.ts +6 -0
- package/dist/components/Modal/examples/index.d.ts.map +1 -1
- package/dist/components/Modal/examples/index.js +6 -0
- package/dist/components/Modal/examples/index.js.map +1 -1
- package/dist/components/Modal/examples.json +16 -1
- package/dist/components/Modal/index.d.ts.map +1 -1
- package/dist/components/Modal/index.js +8 -0
- package/dist/components/Modal/index.js.map +1 -1
- package/dist/components/Panel/examples/01-sidebar-toggle.d.ts +6 -0
- package/dist/components/Panel/examples/01-sidebar-toggle.d.ts.map +1 -0
- package/dist/components/Panel/examples/01-sidebar-toggle.js +10 -0
- package/dist/components/Panel/examples/01-sidebar-toggle.js.map +1 -0
- package/dist/components/Panel/examples/index.d.ts +3 -0
- package/dist/components/Panel/examples/index.d.ts.map +1 -0
- package/dist/components/Panel/examples/index.js +3 -0
- package/dist/components/Panel/examples/index.js.map +1 -0
- package/dist/components/Panel/examples.json +7 -0
- package/dist/components/Panel/index.d.ts +1 -0
- package/dist/components/Panel/index.d.ts.map +1 -1
- package/dist/components/Panel/index.js +8 -0
- package/dist/components/Panel/index.js.map +1 -1
- package/dist/components/Path/examples/01-basic-path.js +2 -2
- package/dist/components/Path/examples/01-basic-path.js.map +1 -1
- package/dist/components/Path/examples/02-custom-separator.d.ts +6 -0
- package/dist/components/Path/examples/02-custom-separator.d.ts.map +1 -0
- package/dist/components/Path/examples/02-custom-separator.js +11 -0
- package/dist/components/Path/examples/02-custom-separator.js.map +1 -0
- package/dist/components/Path/examples/03-collapsed-breadcrumb.d.ts +6 -0
- package/dist/components/Path/examples/03-collapsed-breadcrumb.d.ts.map +1 -0
- package/dist/components/Path/examples/03-collapsed-breadcrumb.js +16 -0
- package/dist/components/Path/examples/03-collapsed-breadcrumb.js.map +1 -0
- package/dist/components/Path/examples/index.d.ts +4 -0
- package/dist/components/Path/examples/index.d.ts.map +1 -1
- package/dist/components/Path/examples/index.js +4 -0
- package/dist/components/Path/examples/index.js.map +1 -1
- package/dist/components/Path/examples.json +11 -1
- package/dist/components/Path/index.d.ts.map +1 -1
- package/dist/components/Path/index.js +11 -7
- package/dist/components/Path/index.js.map +1 -1
- package/dist/components/Popover/examples/01-basic-popover.d.ts.map +1 -1
- package/dist/components/Popover/examples/01-basic-popover.js +5 -4
- package/dist/components/Popover/examples/01-basic-popover.js.map +1 -1
- package/dist/components/Popover/examples/02-toggleable-options.d.ts +6 -0
- package/dist/components/Popover/examples/02-toggleable-options.d.ts.map +1 -0
- package/dist/components/Popover/examples/02-toggleable-options.js +23 -0
- package/dist/components/Popover/examples/02-toggleable-options.js.map +1 -0
- package/dist/components/Popover/examples/03-table-row-actions.d.ts +6 -0
- package/dist/components/Popover/examples/03-table-row-actions.d.ts.map +1 -0
- package/dist/components/Popover/examples/03-table-row-actions.js +17 -0
- package/dist/components/Popover/examples/03-table-row-actions.js.map +1 -0
- package/dist/components/Popover/examples/04-input-form.d.ts +6 -0
- package/dist/components/Popover/examples/04-input-form.d.ts.map +1 -0
- package/dist/components/Popover/examples/04-input-form.js +14 -0
- package/dist/components/Popover/examples/04-input-form.js.map +1 -0
- package/dist/components/Popover/examples/05-arrow-positions.d.ts +6 -0
- package/dist/components/Popover/examples/05-arrow-positions.d.ts.map +1 -0
- package/dist/components/Popover/examples/05-arrow-positions.js +11 -0
- package/dist/components/Popover/examples/05-arrow-positions.js.map +1 -0
- package/dist/components/Popover/examples/index.d.ts +8 -0
- package/dist/components/Popover/examples/index.d.ts.map +1 -1
- package/dist/components/Popover/examples/index.js +8 -0
- package/dist/components/Popover/examples/index.js.map +1 -1
- package/dist/components/Popover/examples.json +23 -3
- package/dist/components/Popover/index.d.ts.map +1 -1
- package/dist/components/Popover/index.js +8 -0
- package/dist/components/Popover/index.js.map +1 -1
- package/dist/components/Progress/examples/01-basic-progress.d.ts.map +1 -1
- package/dist/components/Progress/examples/01-basic-progress.js +20 -5
- package/dist/components/Progress/examples/01-basic-progress.js.map +1 -1
- package/dist/components/Progress/examples/02-storage-quota.d.ts +6 -0
- package/dist/components/Progress/examples/02-storage-quota.d.ts.map +1 -0
- package/dist/components/Progress/examples/02-storage-quota.js +12 -0
- package/dist/components/Progress/examples/02-storage-quota.js.map +1 -0
- package/dist/components/Progress/examples/03-onboarding-steps.d.ts +6 -0
- package/dist/components/Progress/examples/03-onboarding-steps.d.ts.map +1 -0
- package/dist/components/Progress/examples/03-onboarding-steps.js +14 -0
- package/dist/components/Progress/examples/03-onboarding-steps.js.map +1 -0
- package/dist/components/Progress/examples/04-indeterminate.d.ts +6 -0
- package/dist/components/Progress/examples/04-indeterminate.d.ts.map +1 -0
- package/dist/components/Progress/examples/04-indeterminate.js +19 -0
- package/dist/components/Progress/examples/04-indeterminate.js.map +1 -0
- package/dist/components/Progress/examples/05-skill-levels.d.ts +6 -0
- package/dist/components/Progress/examples/05-skill-levels.d.ts.map +1 -0
- package/dist/components/Progress/examples/05-skill-levels.js +15 -0
- package/dist/components/Progress/examples/05-skill-levels.js.map +1 -0
- package/dist/components/Progress/examples/index.d.ts +8 -0
- package/dist/components/Progress/examples/index.d.ts.map +1 -1
- package/dist/components/Progress/examples/index.js +8 -0
- package/dist/components/Progress/examples/index.js.map +1 -1
- package/dist/components/Progress/examples.json +23 -3
- package/dist/components/Progress/index.d.ts.map +1 -1
- package/dist/components/Progress/index.js +11 -14
- package/dist/components/Progress/index.js.map +1 -1
- package/dist/components/Scroll/examples/01-basic-scroll.d.ts.map +1 -1
- package/dist/components/Scroll/examples/01-basic-scroll.js +29 -3
- package/dist/components/Scroll/examples/01-basic-scroll.js.map +1 -1
- package/dist/components/Scroll/examples/02-settings-panel.d.ts +6 -0
- package/dist/components/Scroll/examples/02-settings-panel.d.ts.map +1 -0
- package/dist/components/Scroll/examples/02-settings-panel.js +21 -0
- package/dist/components/Scroll/examples/02-settings-panel.js.map +1 -0
- package/dist/components/Scroll/examples/03-horizontal-tags.d.ts +6 -0
- package/dist/components/Scroll/examples/03-horizontal-tags.d.ts.map +1 -0
- package/dist/components/Scroll/examples/03-horizontal-tags.js +24 -0
- package/dist/components/Scroll/examples/03-horizontal-tags.js.map +1 -0
- package/dist/components/Scroll/examples/index.d.ts +4 -0
- package/dist/components/Scroll/examples/index.d.ts.map +1 -1
- package/dist/components/Scroll/examples/index.js +4 -0
- package/dist/components/Scroll/examples/index.js.map +1 -1
- package/dist/components/Scroll/examples.json +13 -3
- package/dist/components/Scroll/index.d.ts.map +1 -1
- package/dist/components/Scroll/index.js +4 -0
- package/dist/components/Scroll/index.js.map +1 -1
- package/dist/components/Select/examples/03-country-select.d.ts +6 -0
- package/dist/components/Select/examples/03-country-select.d.ts.map +1 -0
- package/dist/components/Select/examples/03-country-select.js +28 -0
- package/dist/components/Select/examples/03-country-select.js.map +1 -0
- package/dist/components/Select/examples/index.d.ts +2 -0
- package/dist/components/Select/examples/index.d.ts.map +1 -1
- package/dist/components/Select/examples/index.js +2 -0
- package/dist/components/Select/examples/index.js.map +1 -1
- package/dist/components/Select/examples.json +5 -0
- package/dist/components/Select/index.d.ts.map +1 -1
- package/dist/components/Select/index.js +2 -0
- package/dist/components/Select/index.js.map +1 -1
- package/dist/components/Slider/examples/01-basic-slider.d.ts.map +1 -1
- package/dist/components/Slider/examples/01-basic-slider.js +7 -4
- package/dist/components/Slider/examples/01-basic-slider.js.map +1 -1
- package/dist/components/Slider/examples/02-settings-panel.d.ts +6 -0
- package/dist/components/Slider/examples/02-settings-panel.d.ts.map +1 -0
- package/dist/components/Slider/examples/02-settings-panel.js +20 -0
- package/dist/components/Slider/examples/02-settings-panel.js.map +1 -0
- package/dist/components/Slider/examples/03-price-range.d.ts +6 -0
- package/dist/components/Slider/examples/03-price-range.d.ts.map +1 -0
- package/dist/components/Slider/examples/03-price-range.js +13 -0
- package/dist/components/Slider/examples/03-price-range.js.map +1 -0
- package/dist/components/Slider/examples/04-step-slider.d.ts +6 -0
- package/dist/components/Slider/examples/04-step-slider.d.ts.map +1 -0
- package/dist/components/Slider/examples/04-step-slider.js +13 -0
- package/dist/components/Slider/examples/04-step-slider.js.map +1 -0
- package/dist/components/Slider/examples/05-disabled-state.d.ts +6 -0
- package/dist/components/Slider/examples/05-disabled-state.d.ts.map +1 -0
- package/dist/components/Slider/examples/05-disabled-state.js +10 -0
- package/dist/components/Slider/examples/05-disabled-state.js.map +1 -0
- package/dist/components/Slider/examples/06-vertical-mixer.d.ts +6 -0
- package/dist/components/Slider/examples/06-vertical-mixer.d.ts.map +1 -0
- package/dist/components/Slider/examples/06-vertical-mixer.js +17 -0
- package/dist/components/Slider/examples/06-vertical-mixer.js.map +1 -0
- package/dist/components/Slider/examples/index.d.ts +10 -0
- package/dist/components/Slider/examples/index.d.ts.map +1 -1
- package/dist/components/Slider/examples/index.js +10 -0
- package/dist/components/Slider/examples/index.js.map +1 -1
- package/dist/components/Slider/examples.json +28 -3
- package/dist/components/Slider/index.d.ts.map +1 -1
- package/dist/components/Slider/index.js +10 -0
- package/dist/components/Slider/index.js.map +1 -1
- package/dist/components/Switch/examples/01-basic-switch.d.ts.map +1 -1
- package/dist/components/Switch/examples/01-basic-switch.js +7 -4
- package/dist/components/Switch/examples/01-basic-switch.js.map +1 -1
- package/dist/components/Switch/examples/02-settings-panel.d.ts +6 -0
- package/dist/components/Switch/examples/02-settings-panel.d.ts.map +1 -0
- package/dist/components/Switch/examples/02-settings-panel.js +20 -0
- package/dist/components/Switch/examples/02-settings-panel.js.map +1 -0
- package/dist/components/Switch/examples/03-disabled-state.d.ts +6 -0
- package/dist/components/Switch/examples/03-disabled-state.d.ts.map +1 -0
- package/dist/components/Switch/examples/03-disabled-state.js +10 -0
- package/dist/components/Switch/examples/03-disabled-state.js.map +1 -0
- package/dist/components/Switch/examples/04-small-size.d.ts +6 -0
- package/dist/components/Switch/examples/04-small-size.d.ts.map +1 -0
- package/dist/components/Switch/examples/04-small-size.js +13 -0
- package/dist/components/Switch/examples/04-small-size.js.map +1 -0
- package/dist/components/Switch/examples/05-controlled-toggle.d.ts +6 -0
- package/dist/components/Switch/examples/05-controlled-toggle.d.ts.map +1 -0
- package/dist/components/Switch/examples/05-controlled-toggle.js +13 -0
- package/dist/components/Switch/examples/05-controlled-toggle.js.map +1 -0
- package/dist/components/Switch/examples/index.d.ts +8 -0
- package/dist/components/Switch/examples/index.d.ts.map +1 -1
- package/dist/components/Switch/examples/index.js +8 -0
- package/dist/components/Switch/examples/index.js.map +1 -1
- package/dist/components/Switch/examples.json +23 -3
- package/dist/components/Switch/index.d.ts.map +1 -1
- package/dist/components/Switch/index.js +8 -0
- package/dist/components/Switch/index.js.map +1 -1
- package/dist/components/Table/index.d.ts.map +1 -1
- package/dist/components/Table/index.js.map +1 -1
- package/dist/components/Tabs/examples/03-underline-tabs.d.ts +6 -0
- package/dist/components/Tabs/examples/03-underline-tabs.d.ts.map +1 -0
- package/dist/components/Tabs/examples/03-underline-tabs.js +13 -0
- package/dist/components/Tabs/examples/03-underline-tabs.js.map +1 -0
- package/dist/components/Tabs/examples/04-vertical-underline-tabs.d.ts +6 -0
- package/dist/components/Tabs/examples/04-vertical-underline-tabs.d.ts.map +1 -0
- package/dist/components/Tabs/examples/04-vertical-underline-tabs.js +13 -0
- package/dist/components/Tabs/examples/04-vertical-underline-tabs.js.map +1 -0
- package/dist/components/Tabs/examples/index.d.ts +4 -0
- package/dist/components/Tabs/examples/index.d.ts.map +1 -1
- package/dist/components/Tabs/examples/index.js +4 -0
- package/dist/components/Tabs/examples/index.js.map +1 -1
- package/dist/components/Tabs/examples.json +10 -0
- package/dist/components/Tabs/index.d.ts.map +1 -1
- package/dist/components/Tabs/index.js +4 -0
- package/dist/components/Tabs/index.js.map +1 -1
- package/dist/components/Textarea/examples/01-basic-textarea.d.ts.map +1 -1
- package/dist/components/Textarea/examples/01-basic-textarea.js +8 -5
- package/dist/components/Textarea/examples/01-basic-textarea.js.map +1 -1
- package/dist/components/Textarea/examples/02-bio-settings.d.ts +6 -0
- package/dist/components/Textarea/examples/02-bio-settings.d.ts.map +1 -0
- package/dist/components/Textarea/examples/02-bio-settings.js +13 -0
- package/dist/components/Textarea/examples/02-bio-settings.js.map +1 -0
- package/dist/components/Textarea/examples/03-error-state.d.ts +6 -0
- package/dist/components/Textarea/examples/03-error-state.d.ts.map +1 -0
- package/dist/components/Textarea/examples/03-error-state.js +14 -0
- package/dist/components/Textarea/examples/03-error-state.js.map +1 -0
- package/dist/components/Textarea/examples/04-disabled-readonly.d.ts +6 -0
- package/dist/components/Textarea/examples/04-disabled-readonly.d.ts.map +1 -0
- package/dist/components/Textarea/examples/04-disabled-readonly.js +10 -0
- package/dist/components/Textarea/examples/04-disabled-readonly.js.map +1 -0
- package/dist/components/Textarea/examples/05-scrolling.d.ts +6 -0
- package/dist/components/Textarea/examples/05-scrolling.d.ts.map +1 -0
- package/dist/components/Textarea/examples/05-scrolling.js +13 -0
- package/dist/components/Textarea/examples/05-scrolling.js.map +1 -0
- package/dist/components/Textarea/examples/index.d.ts +8 -0
- package/dist/components/Textarea/examples/index.d.ts.map +1 -1
- package/dist/components/Textarea/examples/index.js +8 -0
- package/dist/components/Textarea/examples/index.js.map +1 -1
- package/dist/components/Textarea/examples.json +23 -3
- package/dist/components/Textarea/index.d.ts.map +1 -1
- package/dist/components/Textarea/index.js +8 -0
- package/dist/components/Textarea/index.js.map +1 -1
- package/dist/components/Toast/index.d.ts.map +1 -1
- package/dist/components/Toast/index.js +1 -1
- package/dist/components/Toast/index.js.map +1 -1
- package/dist/generated-data.d.ts.map +1 -1
- package/dist/generated-data.js +999 -429
- package/dist/generated-data.js.map +1 -1
- package/dist/generated-styles.d.ts.map +1 -1
- package/dist/generated-styles.js +1135 -203
- package/dist/generated-styles.js.map +1 -1
- package/dist/generated-styles.json +1135 -203
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js.map +1 -1
- package/dist/patterns/data/badge-row/variations/main/index.js +1 -1
- package/dist/patterns/data/badge-row/variations/main/index.js.map +1 -1
- package/dist/patterns/data/badge-row/variations/mixed/index.js +1 -1
- package/dist/patterns/data/badge-row/variations/mixed/index.js.map +1 -1
- package/dist/patterns/data/badge-row/variations/outline/index.js +1 -1
- package/dist/patterns/data/badge-row/variations/outline/index.js.map +1 -1
- package/dist/patterns/data/data-table-row/variations/expandable/index.js +1 -1
- package/dist/patterns/data/data-table-row/variations/expandable/index.js.map +1 -1
- package/dist/patterns/data/data-table-row/variations/main/index.js +1 -1
- package/dist/patterns/data/data-table-row/variations/main/index.js.map +1 -1
- package/dist/patterns/data/data-table-row/variations/selectable/index.js +1 -1
- package/dist/patterns/data/data-table-row/variations/selectable/index.js.map +1 -1
- package/dist/patterns/interaction/tab-content-header/variations/with-badge/index.js +1 -1
- package/dist/patterns/interaction/tab-content-header/variations/with-badge/index.js.map +1 -1
- package/dist/patterns/layout/split-row/variations/main/index.js +1 -1
- package/dist/patterns/layout/split-row/variations/main/index.js.map +1 -1
- package/dist/registry.d.ts.map +1 -1
- package/dist/registry.js +536 -61
- package/dist/registry.js.map +1 -1
- package/dist/types.d.ts +18 -1
- package/dist/types.d.ts.map +1 -1
- package/dist/utils/load-component-examples.d.ts +4 -7
- package/dist/utils/load-component-examples.d.ts.map +1 -1
- package/dist/utils/load-component-examples.js +4 -7
- package/dist/utils/load-component-examples.js.map +1 -1
- package/package.json +2 -2
- package/src/components/Anchor/examples/01-inline-text.tsx +22 -0
- package/src/components/Anchor/examples/02-underline-variants.tsx +24 -0
- package/src/components/Anchor/examples/03-preview-tooltip.tsx +27 -0
- package/src/components/Anchor/examples/04-breadcrumb.tsx +29 -0
- package/src/components/Anchor/examples/index.ts +11 -1
- package/src/components/Anchor/examples.json +19 -4
- package/src/components/Anchor/index.tsx +8 -2
- package/src/components/Badge/examples/01-status-badges.tsx +17 -0
- package/src/components/Badge/examples/02-icon-position.tsx +18 -0
- package/src/components/Badge/examples/03-selectable-tags.tsx +40 -0
- package/src/components/Badge/examples/04-dismissible.tsx +37 -0
- package/src/components/Badge/examples/05-semantic-colors.tsx +18 -0
- package/src/components/Badge/examples/index.ts +13 -4
- package/src/components/Badge/examples.json +24 -9
- package/src/components/Badge/index.tsx +11 -15
- package/src/components/Banner/examples/01-variants.tsx +33 -0
- package/src/components/Banner/examples/02-dismissible.tsx +31 -0
- package/src/components/Banner/examples/03-form-feedback.tsx +47 -0
- package/src/components/Banner/examples/04-settings-panel.tsx +21 -0
- package/src/components/Banner/examples/05-body-only.tsx +22 -0
- package/src/components/Banner/examples/index.ts +14 -2
- package/src/components/Banner/examples.json +24 -4
- package/src/components/Banner/index.tsx +12 -16
- package/src/components/Button/examples/01-variants.tsx +18 -52
- package/src/components/Button/examples/02-multi-actions.tsx +0 -1
- package/src/components/Button/examples/04-sub-stack-actions.tsx +1 -1
- package/src/components/Button/examples/06-icons.tsx +25 -0
- package/src/components/Button/examples/07-split-button.tsx +47 -0
- package/src/components/Button/examples/08-button-group.tsx +30 -0
- package/src/components/Button/examples/index.ts +6 -0
- package/src/components/Button/examples.json +19 -4
- package/src/components/Button/index.tsx +6 -0
- package/src/components/Card/examples/01-notification.tsx +37 -0
- package/src/components/Card/examples/02-settings-panel.tsx +48 -0
- package/src/components/Card/examples/03-task-progress.tsx +43 -0
- package/src/components/Card/examples/index.ts +8 -2
- package/src/components/Card/examples.json +14 -4
- package/src/components/Card/index.tsx +6 -2
- package/src/components/Card/metadata.json +42 -0
- package/src/components/Checkbox/examples/01-basic-states.tsx +17 -0
- package/src/components/Checkbox/examples/02-helper-text.tsx +26 -0
- package/src/components/Checkbox/examples/03-controlled.tsx +28 -0
- package/src/components/Checkbox/examples/04-group.tsx +49 -0
- package/src/components/Checkbox/examples/05-indeterminate.tsx +56 -0
- package/src/components/Checkbox/examples/06-consent-form.tsx +35 -0
- package/src/components/Checkbox/examples/index.ts +16 -4
- package/src/components/Checkbox/examples.json +29 -9
- package/src/components/Checkbox/index.tsx +12 -16
- package/src/components/Color/examples/01-basic-color-picker.tsx +18 -0
- package/src/components/Color/examples/02-color-picker-opacity.tsx +29 -0
- package/src/components/Color/examples/03-color-picker-preview.tsx +27 -0
- package/src/components/Color/examples/04-color-slider-primitive.tsx +47 -0
- package/src/components/Color/examples/index.ts +11 -3
- package/src/components/Color/examples.json +18 -8
- package/src/components/Color/index.tsx +8 -4
- package/src/components/Expand/examples/01-basic.tsx +18 -0
- package/src/components/Expand/examples/02-accordion.tsx +46 -0
- package/src/components/Expand/examples/03-custom-trigger.tsx +30 -0
- package/src/components/Expand/examples/04-directions.tsx +33 -0
- package/src/components/Expand/examples/05-settings-panel.tsx +54 -0
- package/src/components/Expand/examples/06-disabled.tsx +19 -0
- package/src/components/Expand/examples/07-inline-info.tsx +29 -0
- package/src/components/Expand/examples/index.ts +20 -2
- package/src/components/Expand/examples.json +34 -4
- package/src/components/Expand/index.tsx +14 -2
- package/src/components/Flex/examples/01-axis-control.tsx +199 -0
- package/src/components/Flex/examples/02-wrap-overflow.tsx +183 -0
- package/src/components/Flex/examples/03-container-query-reflow.tsx +198 -0
- package/src/components/Flex/examples/index.ts +8 -2
- package/src/components/Flex/examples.json +14 -4
- package/src/components/Flex/index.tsx +12 -8
- package/src/components/Gallery/examples/01-grid-composition.tsx +121 -0
- package/src/components/Gallery/examples/02-item-orientation.tsx +133 -0
- package/src/components/Gallery/examples/03-span-layout.tsx +130 -0
- package/src/components/Gallery/examples/index.ts +8 -2
- package/src/components/Gallery/examples.json +14 -4
- package/src/components/Gallery/index.tsx +6 -2
- package/src/components/Grid/examples/02-track-placement.tsx +210 -0
- package/src/components/Grid/examples/03-editorial-spans.tsx +196 -0
- package/src/components/Grid/examples/04-responsive-card-rail.tsx +153 -0
- package/src/components/Grid/examples/index.ts +6 -0
- package/src/components/Grid/examples.json +15 -0
- package/src/components/Grid/index.tsx +6 -0
- package/src/components/Group/examples/02-create-project.tsx +19 -0
- package/src/components/Group/examples/03-filter-bar.tsx +34 -0
- package/src/components/Group/examples/04-documentation-search.tsx +21 -0
- package/src/components/Group/examples/05-email-signup.tsx +21 -0
- package/src/components/Group/examples/06-copy-command.tsx +17 -0
- package/src/components/Group/examples/07-delete-confirmation.tsx +19 -0
- package/src/components/Group/examples/08-slider-integration.tsx +30 -0
- package/src/components/Group/examples/index.ts +14 -0
- package/src/components/Group/examples.json +35 -0
- package/src/components/Group/index.tsx +14 -0
- package/src/components/Input/examples/03-sign-in.tsx +41 -0
- package/src/components/Input/examples/04-search.tsx +31 -0
- package/src/components/Input/examples/05-user-handle.tsx +40 -0
- package/src/components/Input/examples/06-api-key.tsx +48 -0
- package/src/components/Input/examples/07-url-validation.tsx +36 -0
- package/src/components/Input/examples/08-quantity.tsx +26 -0
- package/src/components/Input/examples/index.ts +12 -0
- package/src/components/Input/examples.json +30 -0
- package/src/components/Input/index.tsx +12 -0
- package/src/components/List/examples/02-review-queue.tsx +54 -0
- package/src/components/List/examples/03-notification-rules.tsx +80 -0
- package/src/components/List/examples/04-quota-editor.tsx +71 -0
- package/src/components/List/examples/05-permissions-matrix.tsx +91 -0
- package/src/components/List/examples/index.ts +8 -0
- package/src/components/List/examples.json +20 -0
- package/src/components/List/index.tsx +10 -2
- package/src/components/Menu/examples/03-toolbar-dropdown.tsx +35 -0
- package/src/components/Menu/examples/04-table-row-actions.tsx +60 -0
- package/src/components/Menu/examples/05-context-menu.tsx +36 -0
- package/src/components/Menu/examples/06-view-options.tsx +39 -0
- package/src/components/Menu/examples/index.ts +8 -0
- package/src/components/Menu/examples.json +20 -0
- package/src/components/Menu/index.tsx +8 -0
- package/src/components/Modal/examples/02-form-modal.tsx +1 -1
- package/src/components/Modal/examples/03-delete-confirmation.tsx +42 -0
- package/src/components/Modal/examples/04-create-api-key.tsx +54 -0
- package/src/components/Modal/examples/05-notification-settings.tsx +58 -0
- package/src/components/Modal/examples/index.ts +6 -0
- package/src/components/Modal/examples.json +16 -1
- package/src/components/Modal/index.tsx +8 -0
- package/src/components/Modal/metadata.json +41 -1
- package/src/components/Panel/examples/01-sidebar-toggle.tsx +20 -0
- package/src/components/Panel/examples/index.ts +2 -0
- package/src/components/Panel/examples.json +7 -1
- package/src/components/Panel/index.tsx +9 -0
- package/src/components/Path/examples/01-basic-path.tsx +5 -5
- package/src/components/Path/examples/02-custom-separator.tsx +17 -0
- package/src/components/Path/examples/03-collapsed-breadcrumb.tsx +37 -0
- package/src/components/Path/examples/index.ts +4 -0
- package/src/components/Path/examples.json +11 -1
- package/src/components/Path/index.tsx +15 -11
- package/src/components/Popover/examples/01-basic-popover.tsx +24 -5
- package/src/components/Popover/examples/02-toggleable-options.tsx +58 -0
- package/src/components/Popover/examples/03-table-row-actions.tsx +64 -0
- package/src/components/Popover/examples/04-input-form.tsx +46 -0
- package/src/components/Popover/examples/05-arrow-positions.tsx +27 -0
- package/src/components/Popover/examples/index.ts +8 -0
- package/src/components/Popover/examples.json +23 -3
- package/src/components/Popover/index.tsx +8 -0
- package/src/components/Progress/examples/01-basic-progress.tsx +34 -5
- package/src/components/Progress/examples/02-storage-quota.tsx +22 -0
- package/src/components/Progress/examples/03-onboarding-steps.tsx +34 -0
- package/src/components/Progress/examples/04-indeterminate.tsx +33 -0
- package/src/components/Progress/examples/05-skill-levels.tsx +22 -0
- package/src/components/Progress/examples/index.ts +8 -0
- package/src/components/Progress/examples.json +23 -3
- package/src/components/Progress/index.tsx +10 -14
- package/src/components/Scroll/examples/01-basic-scroll.tsx +45 -12
- package/src/components/Scroll/examples/02-settings-panel.tsx +40 -0
- package/src/components/Scroll/examples/03-horizontal-tags.tsx +38 -0
- package/src/components/Scroll/examples/index.ts +4 -0
- package/src/components/Scroll/examples.json +13 -3
- package/src/components/Scroll/index.tsx +4 -0
- package/src/components/Select/examples/03-country-select.tsx +55 -0
- package/src/components/Select/examples/index.ts +2 -0
- package/src/components/Select/examples.json +5 -0
- package/src/components/Select/index.tsx +2 -0
- package/src/components/Slider/examples/01-basic-slider.tsx +19 -4
- package/src/components/Slider/examples/02-settings-panel.tsx +33 -0
- package/src/components/Slider/examples/03-price-range.tsx +34 -0
- package/src/components/Slider/examples/04-step-slider.tsx +35 -0
- package/src/components/Slider/examples/05-disabled-state.tsx +21 -0
- package/src/components/Slider/examples/06-vertical-mixer.tsx +34 -0
- package/src/components/Slider/examples/index.ts +10 -0
- package/src/components/Slider/examples.json +28 -3
- package/src/components/Slider/index.tsx +10 -0
- package/src/components/Switch/examples/01-basic-switch.tsx +20 -4
- package/src/components/Switch/examples/02-settings-panel.tsx +32 -0
- package/src/components/Switch/examples/03-disabled-state.tsx +21 -0
- package/src/components/Switch/examples/04-small-size.tsx +25 -0
- package/src/components/Switch/examples/05-controlled-toggle.tsx +32 -0
- package/src/components/Switch/examples/index.ts +8 -0
- package/src/components/Switch/examples.json +23 -3
- package/src/components/Switch/index.tsx +8 -0
- package/src/components/Table/index.tsx +0 -1
- package/src/components/Tabs/examples/03-underline-tabs.tsx +23 -0
- package/src/components/Tabs/examples/04-vertical-underline-tabs.tsx +23 -0
- package/src/components/Tabs/examples/index.ts +4 -0
- package/src/components/Tabs/examples.json +10 -0
- package/src/components/Tabs/index.tsx +4 -0
- package/src/components/Textarea/examples/01-basic-textarea.tsx +21 -8
- package/src/components/Textarea/examples/02-bio-settings.tsx +30 -0
- package/src/components/Textarea/examples/03-error-state.tsx +31 -0
- package/src/components/Textarea/examples/04-disabled-readonly.tsx +25 -0
- package/src/components/Textarea/examples/05-scrolling.tsx +26 -0
- package/src/components/Textarea/examples/index.ts +8 -0
- package/src/components/Textarea/examples.json +23 -3
- package/src/components/Textarea/index.tsx +8 -0
- package/src/components/Toast/index.tsx +1 -4
- package/src/generated-data.ts +999 -429
- package/src/generated-styles.ts +1135 -203
- package/src/index.ts +2 -0
- package/src/patterns/data/badge-row/variations/main/index.tsx +1 -1
- package/src/patterns/data/badge-row/variations/mixed/index.tsx +1 -1
- package/src/patterns/data/badge-row/variations/outline/index.tsx +1 -1
- package/src/patterns/data/data-table-row/variations/expandable/index.tsx +1 -1
- package/src/patterns/data/data-table-row/variations/main/index.tsx +1 -1
- package/src/patterns/data/data-table-row/variations/selectable/index.tsx +1 -1
- package/src/patterns/interaction/tab-content-header/variations/with-badge/index.tsx +1 -1
- package/src/patterns/layout/split-row/variations/main/index.tsx +1 -1
- package/src/registry.ts +536 -61
- package/src/types.ts +20 -1
- package/src/utils/load-component-examples.ts +8 -7
- package/src/components/Anchor/examples/01-basic-anchor.tsx +0 -18
- package/src/components/Badge/examples/01-basic-badge.tsx +0 -11
- package/src/components/Badge/examples/02-variants-and-sizes.tsx +0 -71
- package/src/components/Banner/examples/01-basic-banner.tsx +0 -15
- package/src/components/Card/examples/01-basic-card.tsx +0 -22
- package/src/components/Checkbox/examples/01-basic-checkbox.tsx +0 -21
- package/src/components/Checkbox/examples/02-checkbox-group-with-descriptions.tsx +0 -59
- package/src/components/Color/examples/01-basic-color.tsx +0 -25
- package/src/components/Color/examples/02-opacity-slider.tsx +0 -26
- package/src/components/Color/examples/03-format-switching.tsx +0 -46
- package/src/components/Expand/examples/01-basic-expand.tsx +0 -18
- package/src/components/Flex/examples/01-basic-flex.tsx +0 -17
- package/src/components/Gallery/examples/01-basic-gallery.tsx +0 -28
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
|
|
3
|
+
import { useState } from "react";
|
|
4
|
+
import { Modal, Button, Input, Label } from "ui-lab-components";
|
|
5
|
+
|
|
6
|
+
export const metadata = {
|
|
7
|
+
title: "Create API Key",
|
|
8
|
+
description: "Form modal with a single required input. The primary action stays disabled until the field has a value.",
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
export default function Example() {
|
|
12
|
+
const [isOpen, setIsOpen] = useState(false);
|
|
13
|
+
const [name, setName] = useState("");
|
|
14
|
+
|
|
15
|
+
return (
|
|
16
|
+
<>
|
|
17
|
+
<Button onClick={() => setIsOpen(true)}>New API key</Button>
|
|
18
|
+
|
|
19
|
+
<Modal
|
|
20
|
+
isOpen={isOpen}
|
|
21
|
+
onOpenChange={setIsOpen}
|
|
22
|
+
title="New API key"
|
|
23
|
+
footer={
|
|
24
|
+
<>
|
|
25
|
+
<Button variant="ghost" onClick={() => setIsOpen(false)}>
|
|
26
|
+
Cancel
|
|
27
|
+
</Button>
|
|
28
|
+
<Button
|
|
29
|
+
onClick={() => setIsOpen(false)}
|
|
30
|
+
isDisabled={!name.trim()}
|
|
31
|
+
>
|
|
32
|
+
Create
|
|
33
|
+
</Button>
|
|
34
|
+
</>
|
|
35
|
+
}
|
|
36
|
+
>
|
|
37
|
+
<div className="flex flex-col gap-4 px-6 py-4">
|
|
38
|
+
<div className="flex flex-col gap-1.5">
|
|
39
|
+
<Label htmlFor="key-name">Name</Label>
|
|
40
|
+
<Input
|
|
41
|
+
id="key-name"
|
|
42
|
+
placeholder="e.g. CI deploy key"
|
|
43
|
+
value={name}
|
|
44
|
+
onChange={(e) => setName(e.target.value)}
|
|
45
|
+
/>
|
|
46
|
+
</div>
|
|
47
|
+
<p className="text-xs text-foreground-400">
|
|
48
|
+
The key will only be shown once after creation.
|
|
49
|
+
</p>
|
|
50
|
+
</div>
|
|
51
|
+
</Modal>
|
|
52
|
+
</>
|
|
53
|
+
);
|
|
54
|
+
}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
|
|
3
|
+
import { useState } from "react";
|
|
4
|
+
import { Modal, Button, Switch } from "ui-lab-components";
|
|
5
|
+
|
|
6
|
+
export const metadata = {
|
|
7
|
+
title: "Notification Settings",
|
|
8
|
+
description: "Settings panel using the compound Modal.Header / Modal.Body / Modal.Footer API with toggle rows.",
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
export default function Example() {
|
|
12
|
+
const [isOpen, setIsOpen] = useState(false);
|
|
13
|
+
const [prefs, setPrefs] = useState({ email: true, push: false, marketing: false });
|
|
14
|
+
|
|
15
|
+
const toggle = (key: keyof typeof prefs) =>
|
|
16
|
+
setPrefs((p) => ({ ...p, [key]: !p[key] }));
|
|
17
|
+
|
|
18
|
+
return (
|
|
19
|
+
<>
|
|
20
|
+
<Button variant="ghost" onClick={() => setIsOpen(true)}>
|
|
21
|
+
Notification settings
|
|
22
|
+
</Button>
|
|
23
|
+
|
|
24
|
+
<Modal isOpen={isOpen} onOpenChange={setIsOpen}>
|
|
25
|
+
<Modal.Header>
|
|
26
|
+
<span className="text-sm font-semibold text-foreground-100">Notification preferences</span>
|
|
27
|
+
</Modal.Header>
|
|
28
|
+
|
|
29
|
+
<Modal.Body>
|
|
30
|
+
<div className="flex flex-col divide-y divide-border px-6">
|
|
31
|
+
{(
|
|
32
|
+
[
|
|
33
|
+
{ key: "email", label: "Email notifications", description: "Receive updates and alerts by email" },
|
|
34
|
+
{ key: "push", label: "Push notifications", description: "Browser and mobile push alerts" },
|
|
35
|
+
{ key: "marketing", label: "Product updates", description: "New features and announcements" },
|
|
36
|
+
] as const
|
|
37
|
+
).map(({ key, label, description }) => (
|
|
38
|
+
<div key={key} className="flex items-center justify-between py-4">
|
|
39
|
+
<div className="flex flex-col gap-0.5">
|
|
40
|
+
<span className="text-sm text-foreground-100">{label}</span>
|
|
41
|
+
<span className="text-xs text-foreground-400">{description}</span>
|
|
42
|
+
</div>
|
|
43
|
+
<Switch isSelected={prefs[key]} onChange={() => toggle(key)} />
|
|
44
|
+
</div>
|
|
45
|
+
))}
|
|
46
|
+
</div>
|
|
47
|
+
</Modal.Body>
|
|
48
|
+
|
|
49
|
+
<Modal.Footer>
|
|
50
|
+
<Button variant="ghost" onClick={() => setIsOpen(false)}>
|
|
51
|
+
Cancel
|
|
52
|
+
</Button>
|
|
53
|
+
<Button onClick={() => setIsOpen(false)}>Save</Button>
|
|
54
|
+
</Modal.Footer>
|
|
55
|
+
</Modal>
|
|
56
|
+
</>
|
|
57
|
+
);
|
|
58
|
+
}
|
|
@@ -2,3 +2,9 @@ export { default as Example1 } from './01-basic-modal.js';
|
|
|
2
2
|
export { metadata as metadata1 } from './01-basic-modal.js';
|
|
3
3
|
export { default as Example2 } from './02-form-modal.js';
|
|
4
4
|
export { metadata as metadata2 } from './02-form-modal.js';
|
|
5
|
+
export { default as Example3 } from './03-delete-confirmation.js';
|
|
6
|
+
export { metadata as metadata3 } from './03-delete-confirmation.js';
|
|
7
|
+
export { default as Example4 } from './04-create-api-key.js';
|
|
8
|
+
export { metadata as metadata4 } from './04-create-api-key.js';
|
|
9
|
+
export { default as Example5 } from './05-notification-settings.js';
|
|
10
|
+
export { metadata as metadata5 } from './05-notification-settings.js';
|
|
@@ -7,6 +7,21 @@
|
|
|
7
7
|
"02-form-modal": {
|
|
8
8
|
"title": "Form Modal",
|
|
9
9
|
"description": "A modal dialog containing a form for editing user profile settings. Demonstrates using form inputs, labels, and action buttons within a modal.",
|
|
10
|
-
"code": "'use client';\n\nimport React from 'react';\nimport { Modal, Button, Input, Label, TextArea, Flex } from 'ui-lab-components';\n\nexport default function Example() {\n const [isOpen, setIsOpen] = React.useState(false);\n const [formData, setFormData] = React.useState({\n name: 'John Doe',\n email: 'john.doe@example.com',\n bio: 'Software developer passionate about building great user experiences.',\n });\n\n const handleSubmit = (e: React.FormEvent) => {\n e.preventDefault();\n // Handle form submission\n setIsOpen(false);\n };\n\n return (\n <>\n <Button onClick={() => setIsOpen(true)}>Edit Profile</Button>\n <Modal isOpen={isOpen} onOpenChange={setIsOpen} size=\"auto\">\n <Modal.Header>Edit Profile</Modal.Header>\n <Modal.Body>\n <form id=\"profile-form\" onSubmit={handleSubmit}>\n <Flex direction=\"column\" gap=\"md\">\n <div>\n <Label htmlFor=\"name\" required>\n Full Name\n </Label>\n <Input\n id=\"name\"\n value={formData.name}\n onChange={(e) =>\n setFormData({ ...formData, name: e.target.value })\n }\n placeholder=\"Enter your name\"\n />\n </div>\n <div>\n <Label htmlFor=\"email\" required>\n Email Address\n </Label>\n <Input\n id=\"email\"\n type=\"email\"\n value={formData.email}\n onChange={(e) =>\n setFormData({ ...formData, email: e.target.value })\n }\n placeholder=\"Enter your email\"\n />\n </div>\n <div>\n <Label htmlFor=\"bio\">Bio</Label>\n <TextArea\n id=\"bio\"\n value={formData.bio}\n onChange={(e) =>\n setFormData({ ...formData, bio: e.target.value })\n }\n placeholder=\"Tell us about yourself\"\n rows={3}\n />\n </div>\n </Flex>\n </form>\n </Modal.Body>\n <Modal.Footer>\n <Flex gap=\"sm\" justify=\"
|
|
10
|
+
"code": "'use client';\n\nimport React from 'react';\nimport { Modal, Button, Input, Label, TextArea, Flex } from 'ui-lab-components';\n\nexport default function Example() {\n const [isOpen, setIsOpen] = React.useState(false);\n const [formData, setFormData] = React.useState({\n name: 'John Doe',\n email: 'john.doe@example.com',\n bio: 'Software developer passionate about building great user experiences.',\n });\n\n const handleSubmit = (e: React.FormEvent) => {\n e.preventDefault();\n // Handle form submission\n setIsOpen(false);\n };\n\n return (\n <>\n <Button onClick={() => setIsOpen(true)}>Edit Profile</Button>\n <Modal isOpen={isOpen} onOpenChange={setIsOpen} size=\"auto\">\n <Modal.Header>Edit Profile</Modal.Header>\n <Modal.Body>\n <form id=\"profile-form\" onSubmit={handleSubmit}>\n <Flex direction=\"column\" gap=\"md\">\n <div>\n <Label htmlFor=\"name\" required>\n Full Name\n </Label>\n <Input\n id=\"name\"\n value={formData.name}\n onChange={(e) =>\n setFormData({ ...formData, name: e.target.value })\n }\n placeholder=\"Enter your name\"\n />\n </div>\n <div>\n <Label htmlFor=\"email\" required>\n Email Address\n </Label>\n <Input\n id=\"email\"\n type=\"email\"\n value={formData.email}\n onChange={(e) =>\n setFormData({ ...formData, email: e.target.value })\n }\n placeholder=\"Enter your email\"\n />\n </div>\n <div>\n <Label htmlFor=\"bio\">Bio</Label>\n <TextArea\n id=\"bio\"\n value={formData.bio}\n onChange={(e) =>\n setFormData({ ...formData, bio: e.target.value })\n }\n placeholder=\"Tell us about yourself\"\n rows={3}\n />\n </div>\n </Flex>\n </form>\n </Modal.Body>\n <Modal.Footer>\n <Flex gap=\"sm\" justify=\"end\">\n <Button variant=\"ghost\" onClick={() => setIsOpen(false)}>\n Cancel\n </Button>\n <Button type=\"submit\" form=\"profile-form\">\n Save Changes\n </Button>\n </Flex>\n </Modal.Footer>\n </Modal>\n </>\n );\n}"
|
|
11
|
+
},
|
|
12
|
+
"03-delete-confirmation": {
|
|
13
|
+
"title": "Delete Confirmation",
|
|
14
|
+
"description": "Destructive action dialog that blocks the user until they explicitly confirm or cancel.",
|
|
15
|
+
"code": "\"use client\";\n\nimport { useState } from \"react\";\nimport { Modal, Button } from \"ui-lab-components\";\n\nexport default function Example() {\n const [isOpen, setIsOpen] = useState(false);\n\n return (\n <>\n <Button variant=\"destructive\" onClick={() => setIsOpen(true)}>\n Delete workspace\n </Button>\n\n <Modal\n isOpen={isOpen}\n onOpenChange={setIsOpen}\n title=\"Delete workspace\"\n footer={\n <>\n <Button variant=\"ghost\" onClick={() => setIsOpen(false)}>\n Cancel\n </Button>\n <Button variant=\"destructive\" onClick={() => setIsOpen(false)}>\n Delete\n </Button>\n </>\n }\n >\n <p className=\"text-sm text-foreground-300\">\n This will permanently delete <strong className=\"text-foreground-100\">acme-corp</strong> and all\n its data. This action cannot be undone.\n </p>\n </Modal>\n </>\n );\n}"
|
|
16
|
+
},
|
|
17
|
+
"04-create-api-key": {
|
|
18
|
+
"title": "Create API Key",
|
|
19
|
+
"description": "Form modal with a single required input. The primary action stays disabled until the field has a value.",
|
|
20
|
+
"code": "\"use client\";\n\nimport { useState } from \"react\";\nimport { Modal, Button, Input, Label } from \"ui-lab-components\";\n\nexport default function Example() {\n const [isOpen, setIsOpen] = useState(false);\n const [name, setName] = useState(\"\");\n\n return (\n <>\n <Button onClick={() => setIsOpen(true)}>New API key</Button>\n\n <Modal\n isOpen={isOpen}\n onOpenChange={setIsOpen}\n title=\"New API key\"\n footer={\n <>\n <Button variant=\"ghost\" onClick={() => setIsOpen(false)}>\n Cancel\n </Button>\n <Button\n onClick={() => setIsOpen(false)}\n isDisabled={!name.trim()}\n >\n Create\n </Button>\n </>\n }\n >\n <div className=\"flex flex-col gap-4 px-6 py-4\">\n <div className=\"flex flex-col gap-1.5\">\n <Label htmlFor=\"key-name\">Name</Label>\n <Input\n id=\"key-name\"\n placeholder=\"e.g. CI deploy key\"\n value={name}\n onChange={(e) => setName(e.target.value)}\n />\n </div>\n <p className=\"text-xs text-foreground-400\">\n The key will only be shown once after creation.\n </p>\n </div>\n </Modal>\n </>\n );\n}"
|
|
21
|
+
},
|
|
22
|
+
"05-notification-settings": {
|
|
23
|
+
"title": "Notification Settings",
|
|
24
|
+
"description": "Settings panel using the compound Modal.Header / Modal.Body / Modal.Footer API with toggle rows.",
|
|
25
|
+
"code": "\"use client\";\n\nimport { useState } from \"react\";\nimport { Modal, Button, Switch } from \"ui-lab-components\";\n\nexport default function Example() {\n const [isOpen, setIsOpen] = useState(false);\n const [prefs, setPrefs] = useState({ email: true, push: false, marketing: false });\n\n const toggle = (key: keyof typeof prefs) =>\n setPrefs((p) => ({ ...p, [key]: !p[key] }));\n\n return (\n <>\n <Button variant=\"ghost\" onClick={() => setIsOpen(true)}>\n Notification settings\n </Button>\n\n <Modal isOpen={isOpen} onOpenChange={setIsOpen}>\n <Modal.Header>\n <span className=\"text-sm font-semibold text-foreground-100\">Notification preferences</span>\n </Modal.Header>\n\n <Modal.Body>\n <div className=\"flex flex-col divide-y divide-border px-6\">\n {(\n [\n { key: \"email\", label: \"Email notifications\", description: \"Receive updates and alerts by email\" },\n { key: \"push\", label: \"Push notifications\", description: \"Browser and mobile push alerts\" },\n { key: \"marketing\", label: \"Product updates\", description: \"New features and announcements\" },\n ] as const\n ).map(({ key, label, description }) => (\n <div key={key} className=\"flex items-center justify-between py-4\">\n <div className=\"flex flex-col gap-0.5\">\n <span className=\"text-sm text-foreground-100\">{label}</span>\n <span className=\"text-xs text-foreground-400\">{description}</span>\n </div>\n <Switch isSelected={prefs[key]} onChange={() => toggle(key)} />\n </div>\n ))}\n </div>\n </Modal.Body>\n\n <Modal.Footer>\n <Button variant=\"ghost\" onClick={() => setIsOpen(false)}>\n Cancel\n </Button>\n <Button onClick={() => setIsOpen(false)}>Save</Button>\n </Modal.Footer>\n </Modal>\n </>\n );\n}"
|
|
11
26
|
}
|
|
12
27
|
}
|
|
@@ -3,11 +3,19 @@ import { Modal, Button } from 'ui-lab-components';
|
|
|
3
3
|
import { ControlDef, ComponentDetail } from '@/types';
|
|
4
4
|
import { FaWindowRestore, FaX } from 'react-icons/fa6';
|
|
5
5
|
import Example1, { metadata as metadata1 } from './examples/01-basic-modal.js';
|
|
6
|
+
import Example2, { metadata as metadata2 } from './examples/02-form-modal.js';
|
|
7
|
+
import Example3, { metadata as metadata3 } from './examples/03-delete-confirmation.js';
|
|
8
|
+
import Example4, { metadata as metadata4 } from './examples/04-create-api-key.js';
|
|
9
|
+
import Example5, { metadata as metadata5 } from './examples/05-notification-settings.js';
|
|
6
10
|
import examplesJson from './examples.json' with { type: 'json' };
|
|
7
11
|
import { loadComponentExamples } from '../../utils/load-component-examples.js';
|
|
8
12
|
|
|
9
13
|
const examplesData = [
|
|
10
14
|
{ id: '01-basic-modal', Component: Example1, metadata: metadata1 },
|
|
15
|
+
{ id: '02-form-modal', Component: Example2, metadata: metadata2 },
|
|
16
|
+
{ id: '03-delete-confirmation', Component: Example3, metadata: metadata3 },
|
|
17
|
+
{ id: '04-create-api-key', Component: Example4, metadata: metadata4 },
|
|
18
|
+
{ id: '05-notification-settings', Component: Example5, metadata: metadata5 },
|
|
11
19
|
];
|
|
12
20
|
|
|
13
21
|
const modalControls: ControlDef[] = [
|
|
@@ -25,5 +25,45 @@
|
|
|
25
25
|
"Keyboard dismissal",
|
|
26
26
|
"ARIA dialog role"
|
|
27
27
|
]
|
|
28
|
+
},
|
|
29
|
+
"usage": {
|
|
30
|
+
"summary": "Use Modal for short, focused dialog tasks that need a dedicated overlay surface and clear dismissal path.",
|
|
31
|
+
"whenToUse": [
|
|
32
|
+
"Interruptive tasks that need focused attention",
|
|
33
|
+
"Short forms, confirmations, or contextual workflows that should not navigate away",
|
|
34
|
+
"Situations where the dialog itself should provide the only surfaced container"
|
|
35
|
+
],
|
|
36
|
+
"whenNotToUse": [
|
|
37
|
+
"Long, browse-heavy, or primary page flows",
|
|
38
|
+
"Cases where inline expansion or a dedicated page would be clearer",
|
|
39
|
+
"Layouts that require another nested surface just to hold the content"
|
|
40
|
+
],
|
|
41
|
+
"rules": [
|
|
42
|
+
{
|
|
43
|
+
"type": "do",
|
|
44
|
+
"title": "Let Modal be the surface",
|
|
45
|
+
"description": "Use the modal shell, title, content area, and footer as the dialog structure instead of wrapping the body in another surface component."
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
"type": "avoid",
|
|
49
|
+
"title": "Avoid nested surfaced containers",
|
|
50
|
+
"description": "Do not place Card or other panel-like surfaces inside the modal body unless there is a strong semantic need for a distinct sub-region.",
|
|
51
|
+
"relatedComponents": [
|
|
52
|
+
"card",
|
|
53
|
+
"panel",
|
|
54
|
+
"confirm"
|
|
55
|
+
]
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
"type": "prefer",
|
|
59
|
+
"title": "Prefer direct content plus layout primitives",
|
|
60
|
+
"description": "Arrange modal content with Flex, Grid, Group, and Modal footer slots so the hierarchy stays shallow and the dialog reads as a single unit.",
|
|
61
|
+
"relatedComponents": [
|
|
62
|
+
"flex",
|
|
63
|
+
"grid",
|
|
64
|
+
"group"
|
|
65
|
+
]
|
|
66
|
+
}
|
|
67
|
+
]
|
|
28
68
|
}
|
|
29
|
-
}
|
|
69
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Panel } from "ui-lab-components";
|
|
2
|
+
|
|
3
|
+
export const metadata = {
|
|
4
|
+
title: "Sidebar with Toggle",
|
|
5
|
+
description: "Left sidebar that collapses and expands via a toggle button in the content area.",
|
|
6
|
+
};
|
|
7
|
+
|
|
8
|
+
export default function Example() {
|
|
9
|
+
return (
|
|
10
|
+
<Panel style={{ height: "400px" }} className="w-full border border-background-700 rounded-lg bg-background-900">
|
|
11
|
+
<Panel.Sidebar side="left" defaultOpen width="200px" collapsedWidth="0">
|
|
12
|
+
</Panel.Sidebar>
|
|
13
|
+
<Panel.Content>
|
|
14
|
+
<Panel.Toggle>
|
|
15
|
+
<button>☰</button>
|
|
16
|
+
</Panel.Toggle>
|
|
17
|
+
</Panel.Content>
|
|
18
|
+
</Panel>
|
|
19
|
+
);
|
|
20
|
+
}
|
|
@@ -1 +1,7 @@
|
|
|
1
|
-
{
|
|
1
|
+
{
|
|
2
|
+
"01-sidebar-toggle": {
|
|
3
|
+
"title": "Sidebar with Toggle",
|
|
4
|
+
"description": "Left sidebar that collapses and expands via a toggle button in the content area.",
|
|
5
|
+
"code": "import { Panel } from \"ui-lab-components\";\n\nexport default function Example() {\n return (\n <Panel style={{ height: \"400px\" }} className=\"w-full border border-background-700 rounded-lg bg-background-900\">\n <Panel.Sidebar side=\"left\" defaultOpen width=\"200px\" collapsedWidth=\"0\">\n </Panel.Sidebar>\n <Panel.Content>\n <Panel.Toggle>\n <button>☰</button>\n </Panel.Toggle>\n </Panel.Content>\n </Panel>\n );\n}"
|
|
6
|
+
}
|
|
7
|
+
}
|
|
@@ -1,6 +1,13 @@
|
|
|
1
1
|
import React from 'react'
|
|
2
2
|
import { Panel } from 'ui-lab-components'
|
|
3
3
|
import { ControlDef, ComponentDetail } from '@/types'
|
|
4
|
+
import Example1, { metadata as metadata1 } from './examples/01-sidebar-toggle.js';
|
|
5
|
+
import examplesJson from './examples.json' with { type: 'json' };
|
|
6
|
+
import { loadComponentExamples } from '../../utils/load-component-examples.js';
|
|
7
|
+
|
|
8
|
+
const examplesData = [
|
|
9
|
+
{ id: '01-sidebar-toggle', Component: Example1, metadata: metadata1 },
|
|
10
|
+
];
|
|
4
11
|
|
|
5
12
|
const panelControls: ControlDef[] = [
|
|
6
13
|
{
|
|
@@ -140,7 +147,9 @@ export const panelDetail: ComponentDetail = {
|
|
|
140
147
|
</div>
|
|
141
148
|
),
|
|
142
149
|
},
|
|
150
|
+
...loadComponentExamples(examplesData, examplesJson),
|
|
143
151
|
],
|
|
144
152
|
}
|
|
145
153
|
|
|
146
154
|
export { panelControls }
|
|
155
|
+
export * from './examples/index.js';
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Path
|
|
1
|
+
import { Path } from 'ui-lab-components';
|
|
2
2
|
|
|
3
3
|
export const metadata = {
|
|
4
4
|
title: 'Basic Path',
|
|
@@ -8,10 +8,10 @@ export const metadata = {
|
|
|
8
8
|
export default function Example() {
|
|
9
9
|
return (
|
|
10
10
|
<Path>
|
|
11
|
-
<
|
|
12
|
-
<
|
|
13
|
-
<
|
|
14
|
-
<
|
|
11
|
+
<Path.Item href="/">Home</Path.Item>
|
|
12
|
+
<Path.Item href="/products">Products</Path.Item>
|
|
13
|
+
<Path.Item href="/products/electronics">Electronics</Path.Item>
|
|
14
|
+
<Path.Item>Laptop</Path.Item>
|
|
15
15
|
</Path>
|
|
16
16
|
);
|
|
17
17
|
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Path } from "ui-lab-components";
|
|
2
|
+
import { FaChevronRight } from "react-icons/fa6";
|
|
3
|
+
|
|
4
|
+
export const metadata = {
|
|
5
|
+
title: "Custom Separator",
|
|
6
|
+
description: "Pass any node via the separator prop to replace the default slash.",
|
|
7
|
+
};
|
|
8
|
+
|
|
9
|
+
export default function Example() {
|
|
10
|
+
return (
|
|
11
|
+
<Path separator={<FaChevronRight className="w-3 h-3 text-foreground-400" />}>
|
|
12
|
+
<Path.Item href="/projects">Projects</Path.Item>
|
|
13
|
+
<Path.Item href="/projects/ui-lab">ui-lab</Path.Item>
|
|
14
|
+
<Path.Item>components</Path.Item>
|
|
15
|
+
</Path>
|
|
16
|
+
);
|
|
17
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { Path, Menu, Button } from "ui-lab-components";
|
|
2
|
+
import { FaEllipsis } from "react-icons/fa6";
|
|
3
|
+
|
|
4
|
+
export const metadata = {
|
|
5
|
+
title: "Collapsed Breadcrumb",
|
|
6
|
+
description: "Deep paths collapse intermediate crumbs into an ellipsis menu — Path.Item wraps the Menu trigger directly.",
|
|
7
|
+
};
|
|
8
|
+
|
|
9
|
+
const collapsed = [
|
|
10
|
+
{ label: "Projects", href: "/projects" },
|
|
11
|
+
{ label: "ui-lab", href: "/projects/ui-lab" },
|
|
12
|
+
{ label: "packages", href: "/projects/ui-lab/packages" },
|
|
13
|
+
];
|
|
14
|
+
|
|
15
|
+
export default function Example() {
|
|
16
|
+
return (
|
|
17
|
+
<Path>
|
|
18
|
+
<Path.Item href="/">Home</Path.Item>
|
|
19
|
+
<Path.Item>
|
|
20
|
+
<Menu type="pop-over">
|
|
21
|
+
<Menu.Trigger>
|
|
22
|
+
<Button icon={<FaEllipsis />} styles="p-2" size="icon" variant="ghost" aria-label="Show collapsed path" />
|
|
23
|
+
</Menu.Trigger>
|
|
24
|
+
<Menu.Content align="start">
|
|
25
|
+
{collapsed.map((crumb) => (
|
|
26
|
+
<Menu.Item key={crumb.href} onSelect={() => {}}>
|
|
27
|
+
{crumb.label}
|
|
28
|
+
</Menu.Item>
|
|
29
|
+
))}
|
|
30
|
+
</Menu.Content>
|
|
31
|
+
</Menu>
|
|
32
|
+
</Path.Item>
|
|
33
|
+
<Path.Item href="/projects/ui-lab/packages/@ui">@ui</Path.Item>
|
|
34
|
+
<Path.Item>Path.tsx</Path.Item>
|
|
35
|
+
</Path>
|
|
36
|
+
);
|
|
37
|
+
}
|
|
@@ -1,2 +1,6 @@
|
|
|
1
1
|
export { default as Example1 } from './01-basic-path.js';
|
|
2
2
|
export { metadata as metadata1 } from './01-basic-path.js';
|
|
3
|
+
export { default as Example2 } from './02-custom-separator.js';
|
|
4
|
+
export { metadata as metadata2 } from './02-custom-separator.js';
|
|
5
|
+
export { default as Example3 } from './03-collapsed-breadcrumb.js';
|
|
6
|
+
export { metadata as metadata3 } from './03-collapsed-breadcrumb.js';
|
|
@@ -2,6 +2,16 @@
|
|
|
2
2
|
"01-basic-path": {
|
|
3
3
|
"title": "Basic Path",
|
|
4
4
|
"description": "A simple path navigation showing the current page location. Use this to help users understand their position in the site hierarchy.",
|
|
5
|
-
"code": "import { Path
|
|
5
|
+
"code": "import { Path } from 'ui-lab-components';\n\nexport default function Example() {\n return (\n <Path>\n <Path.Item href=\"/\">Home</Path.Item>\n <Path.Item href=\"/products\">Products</Path.Item>\n <Path.Item href=\"/products/electronics\">Electronics</Path.Item>\n <Path.Item>Laptop</Path.Item>\n </Path>\n );\n}"
|
|
6
|
+
},
|
|
7
|
+
"02-custom-separator": {
|
|
8
|
+
"title": "Custom Separator",
|
|
9
|
+
"description": "Pass any node via the separator prop to replace the default slash.",
|
|
10
|
+
"code": "import { Path } from \"ui-lab-components\";\nimport { FaChevronRight } from \"react-icons/fa6\";\n\nexport default function Example() {\n return (\n <Path separator={<FaChevronRight className=\"w-3 h-3 text-foreground-400\" />}>\n <Path.Item href=\"/projects\">Projects</Path.Item>\n <Path.Item href=\"/projects/ui-lab\">ui-lab</Path.Item>\n <Path.Item>components</Path.Item>\n </Path>\n );\n}"
|
|
11
|
+
},
|
|
12
|
+
"03-collapsed-breadcrumb": {
|
|
13
|
+
"title": "Collapsed Breadcrumb",
|
|
14
|
+
"description": "Deep paths collapse intermediate crumbs into an ellipsis menu — Path.Item wraps the Menu trigger directly.",
|
|
15
|
+
"code": "import { Path, Menu, Button } from \"ui-lab-components\";\nimport { FaEllipsis } from \"react-icons/fa6\";\n\nconst collapsed = [\n { label: \"Projects\", href: \"/projects\" },\n { label: \"ui-lab\", href: \"/projects/ui-lab\" },\n { label: \"packages\", href: \"/projects/ui-lab/packages\" },\n];\n\nexport default function Example() {\n return (\n <Path>\n <Path.Item href=\"/\">Home</Path.Item>\n <Path.Item>\n <Menu type=\"pop-over\">\n <Menu.Trigger>\n <Button icon={<FaEllipsis />} styles=\"p-2\" size=\"icon\" variant=\"ghost\" aria-label=\"Show collapsed path\" />\n </Menu.Trigger>\n <Menu.Content align=\"start\">\n {collapsed.map((crumb) => (\n <Menu.Item key={crumb.href} onSelect={() => {}}>\n {crumb.label}\n </Menu.Item>\n ))}\n </Menu.Content>\n </Menu>\n </Path.Item>\n <Path.Item href=\"/projects/ui-lab/packages/@ui\">@ui</Path.Item>\n <Path.Item>Path.tsx</Path.Item>\n </Path>\n );\n}"
|
|
6
16
|
}
|
|
7
17
|
}
|
|
@@ -1,22 +1,26 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import { Path
|
|
2
|
+
import { Path } from 'ui-lab-components';
|
|
3
3
|
import { ComponentDetail } from '@/types';
|
|
4
4
|
import Example1, { metadata as metadata1 } from './examples/01-basic-path.js';
|
|
5
|
+
import Example2, { metadata as metadata2 } from './examples/02-custom-separator.js';
|
|
6
|
+
import Example3, { metadata as metadata3 } from './examples/03-collapsed-breadcrumb.js';
|
|
5
7
|
import examplesJson from './examples.json' with { type: 'json' };
|
|
6
8
|
import { loadComponentExamples } from '../../utils/load-component-examples.js';
|
|
7
9
|
|
|
8
10
|
const examplesData = [
|
|
9
11
|
{ id: '01-basic-path', Component: Example1, metadata: metadata1 },
|
|
12
|
+
{ id: '02-custom-separator', Component: Example2, metadata: metadata2 },
|
|
13
|
+
{ id: '03-collapsed-breadcrumb', Component: Example3, metadata: metadata3 },
|
|
10
14
|
];
|
|
11
15
|
|
|
12
|
-
const pathBasicCode = `import { Path
|
|
16
|
+
const pathBasicCode = `import { Path } from "ui-lab-components";
|
|
13
17
|
|
|
14
18
|
export function Example() {
|
|
15
19
|
return (
|
|
16
20
|
<Path>
|
|
17
|
-
<
|
|
18
|
-
<
|
|
19
|
-
<
|
|
21
|
+
<Path.Item href="/">Home</Path.Item>
|
|
22
|
+
<Path.Item href="/products">Products</Path.Item>
|
|
23
|
+
<Path.Item>Electronics</Path.Item>
|
|
20
24
|
</Path>
|
|
21
25
|
);
|
|
22
26
|
}`;
|
|
@@ -43,9 +47,9 @@ export const pathDetail: ComponentDetail = {
|
|
|
43
47
|
code: pathBasicCode,
|
|
44
48
|
preview: (
|
|
45
49
|
<Path>
|
|
46
|
-
<
|
|
47
|
-
<
|
|
48
|
-
<
|
|
50
|
+
<Path.Item href="/">Home</Path.Item>
|
|
51
|
+
<Path.Item href="/products">Products</Path.Item>
|
|
52
|
+
<Path.Item>Electronics</Path.Item>
|
|
49
53
|
</Path>
|
|
50
54
|
),
|
|
51
55
|
},
|
|
@@ -59,9 +63,9 @@ export const pathDetail: ComponentDetail = {
|
|
|
59
63
|
code: pathBasicCode,
|
|
60
64
|
preview: (
|
|
61
65
|
<Path>
|
|
62
|
-
<
|
|
63
|
-
<
|
|
64
|
-
<
|
|
66
|
+
<Path.Item href="/">Home</Path.Item>
|
|
67
|
+
<Path.Item href="/products">Products</Path.Item>
|
|
68
|
+
<Path.Item>Electronics</Path.Item>
|
|
65
69
|
</Path>
|
|
66
70
|
),
|
|
67
71
|
},
|
|
@@ -1,15 +1,34 @@
|
|
|
1
|
-
|
|
1
|
+
"use client";
|
|
2
|
+
|
|
2
3
|
import { Popover, Button } from 'ui-lab-components';
|
|
3
4
|
|
|
4
5
|
export const metadata = {
|
|
5
|
-
title: 'Basic
|
|
6
|
-
description: '
|
|
6
|
+
title: 'Basic',
|
|
7
|
+
description: 'Default popover with a short note and two clear actions.'
|
|
7
8
|
};
|
|
8
9
|
|
|
9
10
|
export default function Example() {
|
|
10
11
|
return (
|
|
11
|
-
<Popover
|
|
12
|
-
|
|
12
|
+
<Popover
|
|
13
|
+
content={
|
|
14
|
+
<div className="w-64 space-y-3">
|
|
15
|
+
<div className="space-y-1">
|
|
16
|
+
<div className="text-sm font-medium">Quick note</div>
|
|
17
|
+
<p>A popover works best when it adds one small piece of context, one simple choice, or one short action.</p>
|
|
18
|
+
</div>
|
|
19
|
+
|
|
20
|
+
<div className="flex items-center gap-2">
|
|
21
|
+
<Button variant="ghost" size="sm">
|
|
22
|
+
Dismiss
|
|
23
|
+
</Button>
|
|
24
|
+
<Button size="sm">
|
|
25
|
+
Continue
|
|
26
|
+
</Button>
|
|
27
|
+
</div>
|
|
28
|
+
</div>
|
|
29
|
+
}
|
|
30
|
+
>
|
|
31
|
+
<Button>Show info</Button>
|
|
13
32
|
</Popover>
|
|
14
33
|
);
|
|
15
34
|
}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
|
|
3
|
+
import { useState } from 'react';
|
|
4
|
+
import { Popover, Button, List } from 'ui-lab-components';
|
|
5
|
+
|
|
6
|
+
export const metadata = {
|
|
7
|
+
title: 'Toggleable Options',
|
|
8
|
+
description: 'Popover containing a list of toggleable options using List.Item and List.Switch.'
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
const toggleableItems = [
|
|
12
|
+
{ id: "notifications", label: "Notifications", desc: "Push and email alerts" },
|
|
13
|
+
{ id: "autoSave", label: "Auto-save", desc: "Save changes automatically" },
|
|
14
|
+
{ id: "darkMode", label: "Dark mode", desc: "Use dark color scheme" },
|
|
15
|
+
];
|
|
16
|
+
|
|
17
|
+
export default function Example() {
|
|
18
|
+
const [enabled, setEnabled] = useState<Set<string>>(
|
|
19
|
+
() => new Set(["notifications", "darkMode"])
|
|
20
|
+
);
|
|
21
|
+
|
|
22
|
+
const toggle = (id: string) =>
|
|
23
|
+
setEnabled((prev) => {
|
|
24
|
+
const next = new Set(prev);
|
|
25
|
+
next.has(id) ? next.delete(id) : next.add(id);
|
|
26
|
+
return next;
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
return (
|
|
30
|
+
<Popover
|
|
31
|
+
position="bottom"
|
|
32
|
+
content={
|
|
33
|
+
<List items={toggleableItems} spacing="sm" style={{ width: 280 }}>
|
|
34
|
+
{toggleableItems.map((item) => (
|
|
35
|
+
<List.Item
|
|
36
|
+
key={item.id}
|
|
37
|
+
value={item.id}
|
|
38
|
+
interactive
|
|
39
|
+
onClick={() => toggle(item.id)}
|
|
40
|
+
>
|
|
41
|
+
<div className="min-w-0 flex-1">
|
|
42
|
+
<List.Title>{item.label}</List.Title>
|
|
43
|
+
<List.Desc>{item.desc}</List.Desc>
|
|
44
|
+
</div>
|
|
45
|
+
<List.Switch
|
|
46
|
+
isSelected={enabled.has(item.id)}
|
|
47
|
+
onChange={() => toggle(item.id)}
|
|
48
|
+
aria-label={item.label}
|
|
49
|
+
/>
|
|
50
|
+
</List.Item>
|
|
51
|
+
))}
|
|
52
|
+
</List>
|
|
53
|
+
}
|
|
54
|
+
>
|
|
55
|
+
<Button>Options</Button>
|
|
56
|
+
</Popover>
|
|
57
|
+
);
|
|
58
|
+
}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
|
|
3
|
+
import { Popover, Button, List } from 'ui-lab-components';
|
|
4
|
+
import { FaEllipsis } from 'react-icons/fa6';
|
|
5
|
+
|
|
6
|
+
export const metadata = {
|
|
7
|
+
title: 'Table Row Actions',
|
|
8
|
+
description: 'Per-row action menu in a data table, anchored to the overflow button.'
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
const rows = [
|
|
12
|
+
{ id: "usr_1", name: "Alice", role: "Admin", status: "Active" },
|
|
13
|
+
{ id: "usr_2", name: "Bob", role: "Member", status: "Invited" },
|
|
14
|
+
{ id: "usr_3", name: "Carol", role: "Viewer", status: "Active" },
|
|
15
|
+
];
|
|
16
|
+
|
|
17
|
+
export default function Example() {
|
|
18
|
+
return (
|
|
19
|
+
<table className="w-full text-sm border-collapse">
|
|
20
|
+
<thead>
|
|
21
|
+
<tr className="border-b border-background-700">
|
|
22
|
+
<th className="text-left py-2 px-3 font-medium text-foreground-200">Name</th>
|
|
23
|
+
<th className="text-left py-2 px-3 font-medium text-foreground-200">Role</th>
|
|
24
|
+
<th className="text-left py-2 px-3 font-medium text-foreground-200">Status</th>
|
|
25
|
+
<th className="py-2 px-3" />
|
|
26
|
+
</tr>
|
|
27
|
+
</thead>
|
|
28
|
+
<tbody>
|
|
29
|
+
{rows.map((row) => (
|
|
30
|
+
<tr key={row.id} className="border-b border-background-700 last:border-0">
|
|
31
|
+
<td className="py-2 px-3">{row.name}</td>
|
|
32
|
+
<td className="py-2 px-3 text-foreground-200">{row.role}</td>
|
|
33
|
+
<td className="py-2 px-3 text-foreground-200">{row.status}</td>
|
|
34
|
+
<td className="py-2 px-3 text-right">
|
|
35
|
+
<Popover
|
|
36
|
+
position="left"
|
|
37
|
+
content={
|
|
38
|
+
<List gap="sm" styles={{ root: "w-full" }}>
|
|
39
|
+
<Button
|
|
40
|
+
variant="ghost"
|
|
41
|
+
size="sm"
|
|
42
|
+
styles={{ root: "justify-start" }}
|
|
43
|
+
>
|
|
44
|
+
Edit {row.name}
|
|
45
|
+
</Button>
|
|
46
|
+
<Button
|
|
47
|
+
variant="danger"
|
|
48
|
+
size="sm"
|
|
49
|
+
styles={{ root: "justify-start" }}
|
|
50
|
+
>
|
|
51
|
+
Remove {row.name}
|
|
52
|
+
</Button>
|
|
53
|
+
</List>
|
|
54
|
+
}
|
|
55
|
+
>
|
|
56
|
+
<Button icon={<FaEllipsis />} styles="p-2" size="icon" variant="ghost" aria-label={`Row actions for ${row.name}`} />
|
|
57
|
+
</Popover>
|
|
58
|
+
</td>
|
|
59
|
+
</tr>
|
|
60
|
+
))}
|
|
61
|
+
</tbody>
|
|
62
|
+
</table>
|
|
63
|
+
);
|
|
64
|
+
}
|