@hashicorp/mds-react 0.9.13 → 0.9.15
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/accordion/index.d.ts +15 -0
- package/dist/components/accordion/index.d.ts.map +1 -0
- package/dist/components/accordion/item/button.d.ts +7 -0
- package/dist/components/accordion/item/button.d.ts.map +1 -0
- package/dist/components/accordion/item/index.d.ts +25 -0
- package/dist/components/accordion/item/index.d.ts.map +1 -0
- package/dist/components/accordion/item/index.js.map +1 -0
- package/dist/components/accordion/style.module.scss +110 -0
- package/dist/components/alert/alert.module.scss +227 -0
- package/dist/components/alert/icon.d.ts +10 -0
- package/dist/components/alert/icon.d.ts.map +1 -0
- package/dist/components/alert/index.d.ts +63 -0
- package/dist/components/alert/index.d.ts.map +1 -0
- package/dist/components/alert/index.js.map +1 -0
- package/dist/components/badge/index.d.ts +32 -0
- package/dist/components/badge/index.d.ts.map +1 -0
- package/dist/components/badge/index.js.map +1 -0
- package/dist/components/badge/style.module.scss +108 -0
- package/dist/components/badge-count/index.d.ts +16 -0
- package/dist/components/badge-count/index.d.ts.map +1 -0
- package/dist/components/badge-count/index.js.map +1 -0
- package/dist/components/badge-count/style.module.scss +86 -0
- package/dist/components/breadcrumbs/index.d.ts +8 -0
- package/dist/components/breadcrumbs/index.d.ts.map +1 -0
- package/dist/components/breadcrumbs/index.js.map +1 -0
- package/dist/components/breadcrumbs/item/index.d.ts +3 -0
- package/dist/components/breadcrumbs/item/index.d.ts.map +1 -0
- package/dist/components/breadcrumbs/style.module.scss +183 -0
- package/dist/components/breadcrumbs/truncation-button/index.d.ts +4 -0
- package/dist/components/breadcrumbs/truncation-button/index.d.ts.map +1 -0
- package/dist/components/breadcrumbs/types/index.d.ts +52 -0
- package/dist/components/breadcrumbs/types/index.d.ts.map +1 -0
- package/dist/components/button/button-primitive.d.ts +6 -0
- package/dist/components/button/button-primitive.d.ts.map +1 -0
- package/dist/components/button/button-primitive.js.map +1 -0
- package/dist/components/button/index.d.ts +31 -0
- package/dist/components/button/index.d.ts.map +1 -0
- package/dist/components/button/styles.module.scss +217 -0
- package/dist/components/card/card-thumbnail/index.d.ts +3 -0
- package/dist/components/card/card-thumbnail/index.d.ts.map +1 -0
- package/dist/components/card/index.d.ts +5 -0
- package/dist/components/card/index.d.ts.map +1 -0
- package/dist/components/card/index.js.map +1 -0
- package/dist/components/card/types.d.ts +54 -0
- package/dist/components/card/types.d.ts.map +1 -0
- package/dist/components/code-block/code-block.module.scss +505 -0
- package/dist/components/code-block/code-lines/index.d.ts +20 -0
- package/dist/components/code-block/code-lines/index.d.ts.map +1 -0
- package/dist/components/code-block/code-lines/utils/split-html-into-lines.d.ts +20 -0
- package/dist/components/code-block/code-lines/utils/split-html-into-lines.d.ts.map +1 -0
- package/dist/components/code-block/code-lines/utils/split-jsx-into-lines.d.ts +22 -0
- package/dist/components/code-block/code-lines/utils/split-jsx-into-lines.d.ts.map +1 -0
- package/dist/components/code-block/code-lines/utils/split-jsx-into-lines.js.map +1 -0
- package/dist/components/code-block/hidden-copy-content/index.d.ts +6 -0
- package/dist/components/code-block/hidden-copy-content/index.d.ts.map +1 -0
- package/dist/components/code-block/hidden-copy-content/index.js.map +1 -0
- package/dist/components/code-block/index.d.ts +56 -0
- package/dist/components/code-block/index.d.ts.map +1 -0
- package/dist/components/code-block/index.js.map +1 -0
- package/dist/components/code-block/utils/parse-highlighted-lines.d.ts +3 -0
- package/dist/components/code-block/utils/parse-highlighted-lines.d.ts.map +1 -0
- package/dist/components/code-block/utils/parse-highlighted-lines.js.map +1 -0
- package/dist/components/code-block/utils/process-snippet.d.ts +13 -0
- package/dist/components/code-block/utils/process-snippet.d.ts.map +1 -0
- package/dist/components/code-block/utils/shellwords.d.ts +15 -0
- package/dist/components/code-block/utils/shellwords.d.ts.map +1 -0
- package/dist/components/code-block/utils/shellwords.js.map +1 -0
- package/dist/components/combo-box-primitive/index.d.ts +69 -0
- package/dist/components/combo-box-primitive/index.d.ts.map +1 -0
- package/dist/components/combo-box-primitive/index.js.map +1 -0
- package/dist/components/dialog-primitive/index.d.ts +13 -0
- package/dist/components/dialog-primitive/index.d.ts.map +1 -0
- package/dist/components/dialog-primitive/index.js.map +1 -0
- package/dist/components/disclosure-primitive/index.d.ts +20 -0
- package/dist/components/disclosure-primitive/index.d.ts.map +1 -0
- package/dist/components/disclosure-primitive/index.js.map +1 -0
- package/dist/components/disclosure-primitive/use-disclosure-primitive.d.ts +12 -0
- package/dist/components/disclosure-primitive/use-disclosure-primitive.d.ts.map +1 -0
- package/dist/components/disclosure-primitive/use-disclosure-primitive.js.map +1 -0
- package/dist/components/dismiss-button/index.d.ts +9 -0
- package/dist/components/dismiss-button/index.d.ts.map +1 -0
- package/dist/components/dismiss-button/styles.module.scss +26 -0
- package/dist/components/dropdown/index.d.ts +73 -0
- package/dist/components/dropdown/index.d.ts.map +1 -0
- package/dist/components/dropdown/index.js.map +1 -0
- package/dist/components/dropdown/list-item/custom.d.ts +11 -0
- package/dist/components/dropdown/list-item/custom.d.ts.map +1 -0
- package/dist/components/dropdown/list-item/index.d.ts +20 -0
- package/dist/components/dropdown/list-item/index.d.ts.map +1 -0
- package/dist/components/dropdown/list-item/interactive.d.ts +30 -0
- package/dist/components/dropdown/list-item/interactive.d.ts.map +1 -0
- package/dist/components/dropdown/list-item/separator.d.ts +9 -0
- package/dist/components/dropdown/list-item/separator.d.ts.map +1 -0
- package/dist/components/dropdown/list-item/styles.module.css +218 -0
- package/dist/components/dropdown/list-item/title.d.ts +11 -0
- package/dist/components/dropdown/list-item/title.d.ts.map +1 -0
- package/dist/components/dropdown/list-item/title.js.map +1 -0
- package/dist/components/dropdown/toggle-button/index.d.ts +31 -0
- package/dist/components/dropdown/toggle-button/index.d.ts.map +1 -0
- package/dist/components/dropdown/toggle-button/index.js.map +1 -0
- package/dist/components/dropdown/toggle-button/styles.module.scss +54 -0
- package/dist/components/flight-icon/index.d.ts +45 -0
- package/dist/components/flight-icon/index.d.ts.map +1 -0
- package/dist/components/flight-icon/index.js.map +1 -0
- package/dist/components/form/checkbox/form-checkbox.module.css +81 -0
- package/dist/components/form/checkbox/index.d.ts +46 -0
- package/dist/components/form/checkbox/index.d.ts.map +1 -0
- package/dist/components/form/error/index.d.ts +17 -0
- package/dist/components/form/error/index.d.ts.map +1 -0
- package/dist/components/form/field/index.d.ts +20 -0
- package/dist/components/form/field/index.d.ts.map +1 -0
- package/dist/components/form/fieldset/index.d.ts +19 -0
- package/dist/components/form/fieldset/index.d.ts.map +1 -0
- package/dist/components/form/file-input/form-file-input.module.scss +81 -0
- package/dist/components/form/file-input/index.d.ts +28 -0
- package/dist/components/form/file-input/index.d.ts.map +1 -0
- package/dist/components/form/helper-text/index.d.ts +12 -0
- package/dist/components/form/helper-text/index.d.ts.map +1 -0
- package/dist/components/form/indicator/index.d.ts +10 -0
- package/dist/components/form/indicator/index.d.ts.map +1 -0
- package/dist/components/form/label/index.d.ts +15 -0
- package/dist/components/form/label/index.d.ts.map +1 -0
- package/dist/components/form/legend/index.d.ts +13 -0
- package/dist/components/form/legend/index.d.ts.map +1 -0
- package/dist/components/form/radio/form-radio.module.scss +71 -0
- package/dist/components/form/radio/index.d.ts +43 -0
- package/dist/components/form/radio/index.d.ts.map +1 -0
- package/dist/components/form/radio-card/description.d.ts +4 -0
- package/dist/components/form/radio-card/description.d.ts.map +1 -0
- package/dist/components/form/radio-card/form-radio-card.module.css +152 -0
- package/dist/components/form/radio-card/group.d.ts +12 -0
- package/dist/components/form/radio-card/group.d.ts.map +1 -0
- package/dist/components/form/radio-card/index.d.ts +49 -0
- package/dist/components/form/radio-card/index.d.ts.map +1 -0
- package/dist/components/form/radio-card/index.js.map +1 -0
- package/dist/components/form/radio-card/label.d.ts +4 -0
- package/dist/components/form/radio-card/label.d.ts.map +1 -0
- package/dist/components/form/select/form-select.module.css +81 -0
- package/dist/components/form/select/index.d.ts +23 -0
- package/dist/components/form/select/index.d.ts.map +1 -0
- package/dist/components/form/select/index.js.map +1 -0
- package/dist/components/form/super-select/form-super-select.module.css +149 -0
- package/dist/components/form/super-select/index.d.ts +56 -0
- package/dist/components/form/super-select/index.d.ts.map +1 -0
- package/dist/components/form/super-select/index.js.map +1 -0
- package/dist/components/form/text-input/index.d.ts +99 -0
- package/dist/components/form/text-input/index.d.ts.map +1 -0
- package/dist/components/form/text-input/index.js.map +1 -0
- package/dist/components/form/text-input/styles.module.css +144 -0
- package/dist/components/form/textarea/form-textarea.module.css +87 -0
- package/dist/components/form/textarea/index.d.ts +20 -0
- package/dist/components/form/textarea/index.d.ts.map +1 -0
- package/dist/components/form/textarea/index.js.map +1 -0
- package/dist/components/form/toggle/form-toggle.module.scss +151 -0
- package/dist/components/form/toggle/index.d.ts +79 -0
- package/dist/components/form/toggle/index.d.ts.map +1 -0
- package/dist/components/hds/wrappers/tooltip.d.ts +15 -0
- package/dist/components/hds/wrappers/tooltip.d.ts.map +1 -0
- package/dist/components/icon-tile/index.d.ts +22 -0
- package/dist/components/icon-tile/index.d.ts.map +1 -0
- package/dist/components/icon-tile/index.js.map +1 -0
- package/dist/components/icon-tile/style.module.scss +123 -0
- package/dist/components/index.d.ts +63 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/index.js +124 -0
- package/dist/components/index.js.map +1 -0
- package/dist/components/inline-link/index.d.ts +41 -0
- package/dist/components/inline-link/index.d.ts.map +1 -0
- package/dist/components/interactive/index.d.ts +27 -0
- package/dist/components/interactive/index.d.ts.map +1 -0
- package/dist/components/interactive/index.js.map +1 -0
- package/dist/components/legacy-button/index.d.ts +6 -0
- package/dist/components/legacy-button/index.d.ts.map +1 -0
- package/dist/components/legacy-button/index.js.map +1 -0
- package/dist/components/legacy-button/types.d.ts +38 -0
- package/dist/components/legacy-button/types.d.ts.map +1 -0
- package/dist/components/legacy-button/utils.d.ts +10 -0
- package/dist/components/legacy-button/utils.d.ts.map +1 -0
- package/dist/components/legacy-button/utils.js.map +1 -0
- package/dist/components/menu-primitive/index.d.ts +15 -0
- package/dist/components/menu-primitive/index.d.ts.map +1 -0
- package/dist/components/menu-primitive/index.js.map +1 -0
- package/dist/components/menu-primitive/use-menu-primitive.d.ts +10 -0
- package/dist/components/menu-primitive/use-menu-primitive.d.ts.map +1 -0
- package/dist/components/menu-primitive/use-menu-primitive.js.map +1 -0
- package/dist/components/modal/index.d.ts +14 -0
- package/dist/components/modal/index.d.ts.map +1 -0
- package/dist/components/modal/index.js.map +1 -0
- package/dist/components/modal/use-modal.d.ts +9 -0
- package/dist/components/modal/use-modal.d.ts.map +1 -0
- package/dist/components/modal/use-modal.js.map +1 -0
- package/dist/components/separator/index.d.ts +11 -0
- package/dist/components/separator/index.d.ts.map +1 -0
- package/dist/components/skeleton/index.d.ts +14 -0
- package/dist/components/skeleton/index.d.ts.map +1 -0
- package/dist/components/skeleton/index.js +30 -0
- package/dist/components/skeleton/index.js.map +1 -0
- package/dist/components/skeleton/skeleton-form/index.d.ts +8 -0
- package/dist/components/skeleton/skeleton-form/index.d.ts.map +1 -0
- package/dist/components/skeleton/skeleton-form/index.js +19 -0
- package/dist/components/skeleton/skeleton-form/index.js.map +1 -0
- package/dist/components/skeleton/skeleton-form/skeleton-form.module.css +32 -0
- package/dist/components/skeleton/skeleton-form/skeleton-form.module.css.js +11 -0
- package/dist/components/skeleton/skeleton-form/skeleton-form.module.css.js.map +1 -0
- package/dist/components/skeleton/skeleton.module.css +87 -0
- package/dist/components/skeleton/skeleton.module.css.js +19 -0
- package/dist/components/skeleton/skeleton.module.css.js.map +1 -0
- package/dist/components/standalone-link/index.d.ts +24 -0
- package/dist/components/standalone-link/index.d.ts.map +1 -0
- package/dist/components/standalone-link/index.js.map +1 -0
- package/dist/components/standalone-link/styles.module.scss +164 -0
- package/dist/components/table/index.d.ts +59 -0
- package/dist/components/table/index.d.ts.map +1 -0
- package/dist/components/table/index.js.map +1 -0
- package/dist/components/table/td.d.ts +18 -0
- package/dist/components/table/td.d.ts.map +1 -0
- package/dist/components/table/td.js.map +1 -0
- package/dist/components/table/th-button-tooltip.d.ts +7 -0
- package/dist/components/table/th-button-tooltip.d.ts.map +1 -0
- package/dist/components/table/th.d.ts +35 -0
- package/dist/components/table/th.d.ts.map +1 -0
- package/dist/components/table/th.js.map +1 -0
- package/dist/components/table/tr.d.ts +13 -0
- package/dist/components/table/tr.d.ts.map +1 -0
- package/dist/components/table/utils.d.ts +17 -0
- package/dist/components/table/utils.d.ts.map +1 -0
- package/dist/components/table/utils.js.map +1 -0
- package/dist/components/tabs/index.d.ts +22 -0
- package/dist/components/tabs/index.d.ts.map +1 -0
- package/dist/components/tabs/index.js.map +1 -0
- package/dist/components/tabs/tab-panel.d.ts +6 -0
- package/dist/components/tabs/tab-panel.d.ts.map +1 -0
- package/dist/components/tabs/tab-panel.js.map +1 -0
- package/dist/components/tabs/tab.d.ts +25 -0
- package/dist/components/tabs/tab.d.ts.map +1 -0
- package/dist/components/tabs/tab.js.map +1 -0
- package/dist/components/tabs/tabs.module.scss +120 -0
- package/dist/components/tabs/use-tabs-context.d.ts +16 -0
- package/dist/components/tabs/use-tabs-context.d.ts.map +1 -0
- package/dist/components/tabs/use-tabs-context.js.map +1 -0
- package/dist/components/text/index.d.ts +70 -0
- package/dist/components/text/index.d.ts.map +1 -0
- package/dist/components/text/index.js.map +1 -0
- package/dist/components/visualizations/bar-chart/horizontal-chart/dataset-value/index.d.ts +9 -0
- package/dist/components/visualizations/bar-chart/horizontal-chart/dataset-value/index.d.ts.map +1 -0
- package/dist/components/visualizations/bar-chart/horizontal-chart/dataset-value/index.js +63 -0
- package/dist/components/visualizations/bar-chart/horizontal-chart/dataset-value/index.js.map +1 -0
- package/dist/components/visualizations/bar-chart/horizontal-chart/index.d.ts +44 -0
- package/dist/components/visualizations/bar-chart/horizontal-chart/index.d.ts.map +1 -0
- package/dist/components/visualizations/bar-chart/horizontal-chart/index.js +104 -0
- package/dist/components/visualizations/bar-chart/horizontal-chart/index.js.map +1 -0
- package/dist/components/visualizations/bar-chart/horizontal-chart/legend/index.d.ts +11 -0
- package/dist/components/visualizations/bar-chart/horizontal-chart/legend/index.d.ts.map +1 -0
- package/dist/components/visualizations/bar-chart/horizontal-chart/style.module.css +76 -0
- package/dist/components/visualizations/bar-chart/index.d.ts +14 -0
- package/dist/components/visualizations/bar-chart/index.d.ts.map +1 -0
- package/dist/components/visualizations/bar-chart/style.module.css +37 -0
- package/dist/components/visualizations/donut-chart/components/arc-tooltip/index.d.ts +4 -0
- package/dist/components/visualizations/donut-chart/components/arc-tooltip/index.d.ts.map +1 -0
- package/dist/components/visualizations/donut-chart/components/external-arc-label/index.d.ts +4 -0
- package/dist/components/visualizations/donut-chart/components/external-arc-label/index.d.ts.map +1 -0
- package/dist/components/visualizations/donut-chart/components/index.d.ts +4 -0
- package/dist/components/visualizations/donut-chart/components/index.d.ts.map +1 -0
- package/dist/components/visualizations/donut-chart/components/internal-arc-label/index.d.ts +4 -0
- package/dist/components/visualizations/donut-chart/components/internal-arc-label/index.d.ts.map +1 -0
- package/dist/components/visualizations/donut-chart/index.d.ts +11 -0
- package/dist/components/visualizations/donut-chart/index.d.ts.map +1 -0
- package/dist/components/visualizations/donut-chart/index.js +91 -0
- package/dist/components/visualizations/donut-chart/index.js.map +1 -0
- package/dist/components/visualizations/donut-chart/styles.module.css +71 -0
- package/dist/components/visualizations/donut-chart/types.d.ts +17 -0
- package/dist/components/visualizations/donut-chart/types.d.ts.map +1 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +169 -0
- package/dist/index.js.map +1 -0
- package/dist/patterns/card/index.d.ts +6 -0
- package/dist/patterns/card/index.d.ts.map +1 -0
- package/dist/patterns/card/newsroom-card/index.d.ts +16 -0
- package/dist/patterns/card/newsroom-card/index.d.ts.map +1 -0
- package/dist/patterns/card/partner-card/index.d.ts +19 -0
- package/dist/patterns/card/partner-card/index.d.ts.map +1 -0
- package/dist/patterns/card/person-card/index.d.ts +16 -0
- package/dist/patterns/card/person-card/index.d.ts.map +1 -0
- package/dist/patterns/card/primitives.d.ts +38 -0
- package/dist/patterns/card/primitives.d.ts.map +1 -0
- package/dist/patterns/card/promo-card/index.d.ts +19 -0
- package/dist/patterns/card/promo-card/index.d.ts.map +1 -0
- package/dist/patterns/card/resource-card/index.d.ts +17 -0
- package/dist/patterns/card/resource-card/index.d.ts.map +1 -0
- package/dist/patterns/card/style.module.css +119 -0
- package/dist/patterns/card/thumbnails/index.d.ts +14 -0
- package/dist/patterns/card/thumbnails/index.d.ts.map +1 -0
- package/dist/patterns/card/types.d.ts +42 -0
- package/dist/patterns/card/types.d.ts.map +1 -0
- package/dist/patterns/card/unified-card/index.d.ts +11 -0
- package/dist/patterns/card/unified-card/index.d.ts.map +1 -0
- package/dist/patterns/card/unified-card/index.js.map +1 -0
- package/dist/patterns/copy-button/index.d.ts +20 -0
- package/dist/patterns/copy-button/index.d.ts.map +1 -0
- package/dist/patterns/copy-button/index.js +57 -0
- package/dist/patterns/copy-button/index.js.map +1 -0
- package/dist/patterns/index.d.ts +16 -0
- package/dist/patterns/index.d.ts.map +1 -0
- package/dist/patterns/layout/index.d.ts +70 -0
- package/dist/patterns/layout/index.d.ts.map +1 -0
- package/dist/patterns/layout/layout.module.css +66 -0
- package/dist/patterns/product-badge/index.d.ts +12 -0
- package/dist/patterns/product-badge/index.d.ts.map +1 -0
- package/dist/patterns/product-badge/style.module.css +3 -0
- package/dist/patterns/product-logo/index.d.ts +49 -0
- package/dist/patterns/product-logo/index.d.ts.map +1 -0
- package/dist/patterns/related-content/index.d.ts +7 -0
- package/dist/patterns/related-content/index.d.ts.map +1 -0
- package/dist/patterns/related-content/style.module.css +74 -0
- package/dist/patterns/related-content/types.d.ts +15 -0
- package/dist/patterns/related-content/types.d.ts.map +1 -0
- package/dist/style.css +1 -0
- package/dist/styles/mixins/button.scss +224 -0
- package/dist/styles/mixins/focus-ring.scss +68 -0
- package/dist/utils/clipboard.d.ts +17 -0
- package/dist/utils/clipboard.d.ts.map +1 -0
- package/dist/utils/clipboard.js +78 -0
- package/dist/utils/clipboard.js.map +1 -0
- package/dist/utils/get-contrast-yiq.d.ts +21 -0
- package/dist/utils/get-contrast-yiq.d.ts.map +1 -0
- package/dist/utils/get-contrast-yiq.js.map +1 -0
- package/dist/utils/hooks/use-media-query/index.d.ts +2 -0
- package/dist/utils/hooks/use-media-query/index.d.ts.map +1 -0
- package/dist/utils/hooks/use-media-query/index.js +16 -0
- package/dist/utils/hooks/use-media-query/index.js.map +1 -0
- package/dist/utils/hooks/use-screen-size/index.d.ts +6 -0
- package/dist/utils/hooks/use-screen-size/index.d.ts.map +1 -0
- package/dist/utils/hooks/use-screen-size/index.js +10 -0
- package/dist/utils/hooks/use-screen-size/index.js.map +1 -0
- package/dist/utils/i18n/constants/index.d.ts +15 -0
- package/dist/utils/i18n/constants/index.d.ts.map +1 -0
- package/dist/utils/i18n/constants/index.js.map +1 -0
- package/dist/utils/i18n/helpers/index.d.ts +6 -0
- package/dist/utils/i18n/helpers/index.d.ts.map +1 -0
- package/dist/utils/i18n/helpers/is-supported-local.d.ts +3 -0
- package/dist/utils/i18n/helpers/is-supported-local.d.ts.map +1 -0
- package/dist/utils/i18n/helpers/is-supported-local.js +8 -0
- package/dist/utils/i18n/helpers/is-supported-local.js.map +1 -0
- package/dist/utils/i18n/helpers/locale-provider.d.ts +15 -0
- package/dist/utils/i18n/helpers/locale-provider.d.ts.map +1 -0
- package/dist/utils/i18n/helpers/locale-provider.js +19 -0
- package/dist/utils/i18n/helpers/locale-provider.js.map +1 -0
- package/dist/utils/i18n/helpers/to-smart-sentence-case.d.ts +3 -0
- package/dist/utils/i18n/helpers/to-smart-sentence-case.d.ts.map +1 -0
- package/dist/utils/i18n/helpers/to-smart-sentence-case.js.map +1 -0
- package/dist/utils/i18n/helpers/to-smart-title-case.d.ts +3 -0
- package/dist/utils/i18n/helpers/to-smart-title-case.d.ts.map +1 -0
- package/dist/utils/i18n/helpers/to-smart-title-case.js.map +1 -0
- package/dist/utils/i18n/helpers/use-locale.d.ts +3 -0
- package/dist/utils/i18n/helpers/use-locale.d.ts.map +1 -0
- package/dist/utils/i18n/helpers/use-locale.js +14 -0
- package/dist/utils/i18n/helpers/use-locale.js.map +1 -0
- package/dist/utils/i18n/index.d.ts +12 -0
- package/dist/utils/i18n/index.d.ts.map +1 -0
- package/dist/utils/i18n/index.js.map +1 -0
- package/dist/utils/i18n/types.d.ts +3 -0
- package/dist/utils/i18n/types.d.ts.map +1 -0
- package/dist/utils/index.d.ts +6 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +16 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/make-normalizer/index.d.ts +31 -0
- package/dist/utils/make-normalizer/index.d.ts.map +1 -0
- package/dist/utils/make-normalizer/index.js.map +1 -0
- package/dist/utils/mds-context/index.d.ts +60 -0
- package/dist/utils/mds-context/index.d.ts.map +1 -0
- package/dist/utils/mds-context/index.js.map +1 -0
- package/package.json +116 -75
- package/components/accordion/index.d.ts +0 -14
- package/components/accordion/item/button.d.ts +0 -6
- package/components/accordion/item/index.d.ts +0 -24
- package/components/accordion/item/index.js.map +0 -1
- package/components/accordion/style.module.scss +0 -110
- package/components/alert/alert.module.scss +0 -229
- package/components/alert/icon.d.ts +0 -9
- package/components/alert/index.d.ts +0 -62
- package/components/alert/index.js.map +0 -1
- package/components/badge/index.d.ts +0 -31
- package/components/badge/index.js.map +0 -1
- package/components/badge/style.module.scss +0 -113
- package/components/badge-count/index.d.ts +0 -15
- package/components/badge-count/index.js.map +0 -1
- package/components/badge-count/style.module.scss +0 -91
- package/components/breadcrumbs/index.d.ts +0 -7
- package/components/breadcrumbs/index.js.map +0 -1
- package/components/breadcrumbs/item/index.d.ts +0 -2
- package/components/breadcrumbs/style.module.scss +0 -183
- package/components/breadcrumbs/truncation-button/index.d.ts +0 -3
- package/components/breadcrumbs/types/index.d.ts +0 -51
- package/components/button/button-primitive.d.ts +0 -5
- package/components/button/button-primitive.js.map +0 -1
- package/components/button/index.d.ts +0 -30
- package/components/button/styles.module.scss +0 -221
- package/components/card/card-thumbnail/index.d.ts +0 -2
- package/components/card/index.d.ts +0 -4
- package/components/card/index.js.map +0 -1
- package/components/card/types.d.ts +0 -53
- package/components/code-block/code-block.module.scss +0 -511
- package/components/code-block/code-lines/index.d.ts +0 -12
- package/components/code-block/code-lines/utils/split-html-into-lines.d.ts +0 -19
- package/components/code-block/code-lines/utils/split-jsx-into-lines.d.ts +0 -21
- package/components/code-block/code-lines/utils/split-jsx-into-lines.js.map +0 -1
- package/components/code-block/hidden-copy-content/index.d.ts +0 -5
- package/components/code-block/hidden-copy-content/index.js.map +0 -1
- package/components/code-block/index.d.ts +0 -55
- package/components/code-block/index.js.map +0 -1
- package/components/code-block/utils/parse-highlighted-lines.d.ts +0 -2
- package/components/code-block/utils/parse-highlighted-lines.js.map +0 -1
- package/components/code-block/utils/process-snippet.d.ts +0 -12
- package/components/code-block/utils/shellwords.d.ts +0 -14
- package/components/code-block/utils/shellwords.js.map +0 -1
- package/components/combo-box-primitive/index.d.ts +0 -69
- package/components/combo-box-primitive/index.js.map +0 -1
- package/components/dialog-primitive/index.d.ts +0 -12
- package/components/dialog-primitive/index.js.map +0 -1
- package/components/disclosure-primitive/index.d.ts +0 -19
- package/components/disclosure-primitive/index.js.map +0 -1
- package/components/disclosure-primitive/use-disclosure-primitive.d.ts +0 -11
- package/components/disclosure-primitive/use-disclosure-primitive.js.map +0 -1
- package/components/dismiss-button/index.d.ts +0 -9
- package/components/dismiss-button/styles.module.scss +0 -31
- package/components/dropdown/index.d.ts +0 -72
- package/components/dropdown/index.js.map +0 -1
- package/components/dropdown/list-item/custom.d.ts +0 -10
- package/components/dropdown/list-item/index.d.ts +0 -19
- package/components/dropdown/list-item/interactive.d.ts +0 -29
- package/components/dropdown/list-item/separator.d.ts +0 -8
- package/components/dropdown/list-item/styles.module.css +0 -222
- package/components/dropdown/list-item/title.d.ts +0 -10
- package/components/dropdown/list-item/title.js.map +0 -1
- package/components/dropdown/toggle-button/index.d.ts +0 -30
- package/components/dropdown/toggle-button/index.js.map +0 -1
- package/components/dropdown/toggle-button/styles.module.scss +0 -54
- package/components/flight-icon/index.d.ts +0 -44
- package/components/flight-icon/index.js.map +0 -1
- package/components/form/checkbox/form-checkbox.module.css +0 -88
- package/components/form/checkbox/index.d.ts +0 -45
- package/components/form/error/index.d.ts +0 -16
- package/components/form/field/index.d.ts +0 -19
- package/components/form/fieldset/index.d.ts +0 -18
- package/components/form/file-input/form-file-input.module.scss +0 -81
- package/components/form/file-input/index.d.ts +0 -27
- package/components/form/helper-text/index.d.ts +0 -11
- package/components/form/indicator/index.d.ts +0 -9
- package/components/form/label/index.d.ts +0 -14
- package/components/form/legend/index.d.ts +0 -12
- package/components/form/radio/form-radio.module.scss +0 -74
- package/components/form/radio/index.d.ts +0 -42
- package/components/form/radio-card/description.d.ts +0 -3
- package/components/form/radio-card/form-radio-card.module.css +0 -153
- package/components/form/radio-card/group.d.ts +0 -11
- package/components/form/radio-card/index.d.ts +0 -48
- package/components/form/radio-card/index.js.map +0 -1
- package/components/form/radio-card/label.d.ts +0 -3
- package/components/form/select/form-select.module.css +0 -89
- package/components/form/select/index.d.ts +0 -22
- package/components/form/select/index.js.map +0 -1
- package/components/form/super-select/form-super-select.module.css +0 -155
- package/components/form/super-select/index.d.ts +0 -55
- package/components/form/super-select/index.js.map +0 -1
- package/components/form/text-input/index.d.ts +0 -98
- package/components/form/text-input/index.js.map +0 -1
- package/components/form/text-input/styles.module.css +0 -158
- package/components/form/textarea/form-textarea.module.css +0 -88
- package/components/form/textarea/index.d.ts +0 -19
- package/components/form/textarea/index.js.map +0 -1
- package/components/form/toggle/form-toggle.module.scss +0 -164
- package/components/form/toggle/index.d.ts +0 -78
- package/components/hds/wrappers/tooltip.d.ts +0 -13
- package/components/icon-tile/index.d.ts +0 -21
- package/components/icon-tile/index.js.map +0 -1
- package/components/icon-tile/style.module.scss +0 -138
- package/components/index.d.ts +0 -60
- package/components/index.js +0 -120
- package/components/index.js.map +0 -1
- package/components/inline-link/index.d.ts +0 -40
- package/components/interactive/index.d.ts +0 -26
- package/components/interactive/index.js.map +0 -1
- package/components/legacy-button/index.d.ts +0 -5
- package/components/legacy-button/index.js.map +0 -1
- package/components/legacy-button/types.d.ts +0 -37
- package/components/legacy-button/utils.d.ts +0 -9
- package/components/legacy-button/utils.js.map +0 -1
- package/components/menu-primitive/index.d.ts +0 -14
- package/components/menu-primitive/index.js.map +0 -1
- package/components/menu-primitive/use-menu-primitive.d.ts +0 -9
- package/components/menu-primitive/use-menu-primitive.js.map +0 -1
- package/components/modal/index.d.ts +0 -13
- package/components/modal/index.js.map +0 -1
- package/components/modal/use-modal.d.ts +0 -8
- package/components/modal/use-modal.js.map +0 -1
- package/components/separator/index.d.ts +0 -10
- package/components/standalone-link/index.d.ts +0 -23
- package/components/standalone-link/index.js.map +0 -1
- package/components/standalone-link/styles.module.scss +0 -166
- package/components/table/index.d.ts +0 -58
- package/components/table/index.js.map +0 -1
- package/components/table/td.d.ts +0 -17
- package/components/table/td.js.map +0 -1
- package/components/table/th-button-tooltip.d.ts +0 -6
- package/components/table/th.d.ts +0 -34
- package/components/table/th.js.map +0 -1
- package/components/table/tr.d.ts +0 -12
- package/components/table/utils.d.ts +0 -16
- package/components/table/utils.js.map +0 -1
- package/components/tabs/index.d.ts +0 -21
- package/components/tabs/index.js.map +0 -1
- package/components/tabs/tab-panel.d.ts +0 -5
- package/components/tabs/tab-panel.js.map +0 -1
- package/components/tabs/tab.d.ts +0 -24
- package/components/tabs/tab.js.map +0 -1
- package/components/tabs/tabs.module.scss +0 -163
- package/components/tabs/use-tabs-context.d.ts +0 -15
- package/components/tabs/use-tabs-context.js.map +0 -1
- package/components/text/index.d.ts +0 -69
- package/components/text/index.js.map +0 -1
- package/components/visualizations/bar-chart/horizontal-chart/dataset-value/index.d.ts +0 -8
- package/components/visualizations/bar-chart/horizontal-chart/dataset-value/index.js +0 -62
- package/components/visualizations/bar-chart/horizontal-chart/dataset-value/index.js.map +0 -1
- package/components/visualizations/bar-chart/horizontal-chart/index.d.ts +0 -44
- package/components/visualizations/bar-chart/horizontal-chart/index.js +0 -104
- package/components/visualizations/bar-chart/horizontal-chart/index.js.map +0 -1
- package/components/visualizations/bar-chart/horizontal-chart/legend/index.d.ts +0 -10
- package/components/visualizations/bar-chart/horizontal-chart/style.module.css +0 -76
- package/components/visualizations/bar-chart/index.d.ts +0 -13
- package/components/visualizations/bar-chart/style.module.css +0 -39
- package/components/visualizations/donut-chart/components/arc-tooltip/index.d.ts +0 -3
- package/components/visualizations/donut-chart/components/external-arc-label/index.d.ts +0 -3
- package/components/visualizations/donut-chart/components/index.d.ts +0 -3
- package/components/visualizations/donut-chart/components/internal-arc-label/index.d.ts +0 -3
- package/components/visualizations/donut-chart/index.d.ts +0 -10
- package/components/visualizations/donut-chart/index.js +0 -90
- package/components/visualizations/donut-chart/index.js.map +0 -1
- package/components/visualizations/donut-chart/styles.module.css +0 -73
- package/components/visualizations/donut-chart/types.d.ts +0 -16
- package/hooks/use-media-query/index.js +0 -16
- package/hooks/use-media-query/index.js.map +0 -1
- package/index.d.ts +0 -3
- package/index.js +0 -163
- package/index.js.map +0 -1
- package/patterns/card/index.d.ts +0 -5
- package/patterns/card/newsroom-card/index.d.ts +0 -15
- package/patterns/card/partner-card/index.d.ts +0 -18
- package/patterns/card/person-card/index.d.ts +0 -15
- package/patterns/card/primitives.d.ts +0 -37
- package/patterns/card/promo-card/index.d.ts +0 -18
- package/patterns/card/resource-card/index.d.ts +0 -16
- package/patterns/card/style.module.css +0 -121
- package/patterns/card/thumbnails/index.d.ts +0 -13
- package/patterns/card/types.d.ts +0 -41
- package/patterns/card/unified-card/index.d.ts +0 -10
- package/patterns/card/unified-card/index.js.map +0 -1
- package/patterns/copy-button/clipboard.d.ts +0 -16
- package/patterns/copy-button/clipboard.js +0 -78
- package/patterns/copy-button/clipboard.js.map +0 -1
- package/patterns/copy-button/index.d.ts +0 -19
- package/patterns/copy-button/index.js +0 -57
- package/patterns/copy-button/index.js.map +0 -1
- package/patterns/index.d.ts +0 -15
- package/patterns/layout/index.d.ts +0 -69
- package/patterns/layout/layout.module.css +0 -72
- package/patterns/product-badge/index.d.ts +0 -11
- package/patterns/product-badge/style.module.css +0 -3
- package/patterns/product-logo/index.d.ts +0 -48
- package/patterns/related-content/index.d.ts +0 -6
- package/patterns/related-content/style.module.css +0 -74
- package/patterns/related-content/types.d.ts +0 -14
- package/style.css +0 -1
- package/styles/mixins/button.scss +0 -279
- package/styles/mixins/focus-ring.scss +0 -75
- package/utils/get-contrast-yiq.d.ts +0 -20
- package/utils/get-contrast-yiq.js.map +0 -1
- package/utils/hooks/use-screen-size.d.ts +0 -5
- package/utils/hooks/use-screen-size.js +0 -10
- package/utils/hooks/use-screen-size.js.map +0 -1
- package/utils/i18n/constants/index.js.map +0 -1
- package/utils/i18n/helpers/index.d.ts +0 -4
- package/utils/i18n/helpers/index.js +0 -8
- package/utils/i18n/helpers/index.js.map +0 -1
- package/utils/i18n/helpers/locale-provider.d.ts +0 -14
- package/utils/i18n/helpers/locale-provider.js +0 -19
- package/utils/i18n/helpers/locale-provider.js.map +0 -1
- package/utils/i18n/helpers/to-smart-sentence-case.d.ts +0 -2
- package/utils/i18n/helpers/to-smart-sentence-case.js.map +0 -1
- package/utils/i18n/helpers/to-smart-title-case.d.ts +0 -2
- package/utils/i18n/helpers/to-smart-title-case.js.map +0 -1
- package/utils/i18n/helpers/use-locale.d.ts +0 -2
- package/utils/i18n/helpers/use-locale.js +0 -14
- package/utils/i18n/helpers/use-locale.js.map +0 -1
- package/utils/i18n/index.d.ts +0 -11
- package/utils/i18n/index.js.map +0 -1
- package/utils/index.d.ts +0 -4
- package/utils/index.js +0 -14
- package/utils/index.js.map +0 -1
- package/utils/make-normalizer/index.d.ts +0 -30
- package/utils/make-normalizer/index.js.map +0 -1
- package/utils/mds-context/index.d.ts +0 -59
- package/utils/mds-context/index.js.map +0 -1
- /package/{components → dist/components}/accordion/index.js +0 -0
- /package/{components → dist/components}/accordion/index.js.map +0 -0
- /package/{components → dist/components}/accordion/item/button.js +0 -0
- /package/{components → dist/components}/accordion/item/button.js.map +0 -0
- /package/{components → dist/components}/accordion/item/index.js +0 -0
- /package/{components → dist/components}/accordion/style.module.scss.js +0 -0
- /package/{components → dist/components}/accordion/style.module.scss.js.map +0 -0
- /package/{components → dist/components}/alert/alert.module.scss.js +0 -0
- /package/{components → dist/components}/alert/alert.module.scss.js.map +0 -0
- /package/{components → dist/components}/alert/icon.js +0 -0
- /package/{components → dist/components}/alert/icon.js.map +0 -0
- /package/{components → dist/components}/alert/index.js +0 -0
- /package/{components → dist/components}/badge/index.js +0 -0
- /package/{components → dist/components}/badge/style.module.scss.js +0 -0
- /package/{components → dist/components}/badge/style.module.scss.js.map +0 -0
- /package/{components → dist/components}/badge-count/index.js +0 -0
- /package/{components → dist/components}/badge-count/style.module.scss.js +0 -0
- /package/{components → dist/components}/badge-count/style.module.scss.js.map +0 -0
- /package/{components → dist/components}/breadcrumbs/index.js +0 -0
- /package/{components → dist/components}/breadcrumbs/item/index.js +0 -0
- /package/{components → dist/components}/breadcrumbs/item/index.js.map +0 -0
- /package/{components → dist/components}/breadcrumbs/style.module.scss.js +0 -0
- /package/{components → dist/components}/breadcrumbs/style.module.scss.js.map +0 -0
- /package/{components → dist/components}/breadcrumbs/truncation-button/index.js +0 -0
- /package/{components → dist/components}/breadcrumbs/truncation-button/index.js.map +0 -0
- /package/{components → dist/components}/button/button-primitive.js +0 -0
- /package/{components → dist/components}/button/index.js +0 -0
- /package/{components → dist/components}/button/index.js.map +0 -0
- /package/{components → dist/components}/button/styles.module.scss.js +0 -0
- /package/{components → dist/components}/button/styles.module.scss.js.map +0 -0
- /package/{components → dist/components}/card/card-thumbnail/card-thumbnail.module.css +0 -0
- /package/{components → dist/components}/card/card-thumbnail/card-thumbnail.module.css.js +0 -0
- /package/{components → dist/components}/card/card-thumbnail/card-thumbnail.module.css.js.map +0 -0
- /package/{components → dist/components}/card/card-thumbnail/index.js +0 -0
- /package/{components → dist/components}/card/card-thumbnail/index.js.map +0 -0
- /package/{components → dist/components}/card/index.js +0 -0
- /package/{components → dist/components}/card/styles.module.css +0 -0
- /package/{components → dist/components}/card/styles.module.css.js +0 -0
- /package/{components → dist/components}/card/styles.module.css.js.map +0 -0
- /package/{components → dist/components}/code-block/code-block.module.scss.js +0 -0
- /package/{components → dist/components}/code-block/code-block.module.scss.js.map +0 -0
- /package/{components → dist/components}/code-block/code-lines/index.js +0 -0
- /package/{components → dist/components}/code-block/code-lines/index.js.map +0 -0
- /package/{components → dist/components}/code-block/code-lines/utils/split-html-into-lines.js +0 -0
- /package/{components → dist/components}/code-block/code-lines/utils/split-html-into-lines.js.map +0 -0
- /package/{components → dist/components}/code-block/code-lines/utils/split-jsx-into-lines.js +0 -0
- /package/{components → dist/components}/code-block/hidden-copy-content/index.js +0 -0
- /package/{components → dist/components}/code-block/index.js +0 -0
- /package/{components → dist/components}/code-block/utils/parse-highlighted-lines.js +0 -0
- /package/{components → dist/components}/code-block/utils/process-snippet.js +0 -0
- /package/{components → dist/components}/code-block/utils/process-snippet.js.map +0 -0
- /package/{components → dist/components}/code-block/utils/shellwords.js +0 -0
- /package/{components → dist/components}/combo-box-primitive/index.js +0 -0
- /package/{components → dist/components}/dialog-primitive/dialog.module.scss +0 -0
- /package/{components → dist/components}/dialog-primitive/dialog.module.scss.js +0 -0
- /package/{components → dist/components}/dialog-primitive/dialog.module.scss.js.map +0 -0
- /package/{components → dist/components}/dialog-primitive/index.js +0 -0
- /package/{components → dist/components}/disclosure-primitive/index.js +0 -0
- /package/{components → dist/components}/disclosure-primitive/styles.module.css +0 -0
- /package/{components → dist/components}/disclosure-primitive/styles.module.css.js +0 -0
- /package/{components → dist/components}/disclosure-primitive/styles.module.css.js.map +0 -0
- /package/{components → dist/components}/disclosure-primitive/use-disclosure-primitive.js +0 -0
- /package/{components → dist/components}/dismiss-button/index.js +0 -0
- /package/{components → dist/components}/dismiss-button/index.js.map +0 -0
- /package/{components → dist/components}/dismiss-button/styles.module.scss.js +0 -0
- /package/{components → dist/components}/dismiss-button/styles.module.scss.js.map +0 -0
- /package/{components → dist/components}/dropdown/index.js +0 -0
- /package/{components → dist/components}/dropdown/list-item/custom.js +0 -0
- /package/{components → dist/components}/dropdown/list-item/custom.js.map +0 -0
- /package/{components → dist/components}/dropdown/list-item/index.js +0 -0
- /package/{components → dist/components}/dropdown/list-item/index.js.map +0 -0
- /package/{components → dist/components}/dropdown/list-item/interactive.js +0 -0
- /package/{components → dist/components}/dropdown/list-item/interactive.js.map +0 -0
- /package/{components → dist/components}/dropdown/list-item/separator.js +0 -0
- /package/{components → dist/components}/dropdown/list-item/separator.js.map +0 -0
- /package/{components → dist/components}/dropdown/list-item/styles.module.css.js +0 -0
- /package/{components → dist/components}/dropdown/list-item/styles.module.css.js.map +0 -0
- /package/{components → dist/components}/dropdown/list-item/title.js +0 -0
- /package/{components → dist/components}/dropdown/styles.module.css +0 -0
- /package/{components → dist/components}/dropdown/styles.module.css.js +0 -0
- /package/{components → dist/components}/dropdown/styles.module.css.js.map +0 -0
- /package/{components → dist/components}/dropdown/toggle-button/index.js +0 -0
- /package/{components → dist/components}/dropdown/toggle-button/styles.module.scss.js +0 -0
- /package/{components → dist/components}/dropdown/toggle-button/styles.module.scss.js.map +0 -0
- /package/{components → dist/components}/flight-icon/flight-icon.module.css +0 -0
- /package/{components → dist/components}/flight-icon/flight-icon.module.css.js +0 -0
- /package/{components → dist/components}/flight-icon/flight-icon.module.css.js.map +0 -0
- /package/{components → dist/components}/flight-icon/index.js +0 -0
- /package/{components → dist/components}/form/checkbox/form-checkbox.module.css.js +0 -0
- /package/{components → dist/components}/form/checkbox/form-checkbox.module.css.js.map +0 -0
- /package/{components → dist/components}/form/checkbox/index.js +0 -0
- /package/{components → dist/components}/form/checkbox/index.js.map +0 -0
- /package/{components → dist/components}/form/error/form-error.module.css +0 -0
- /package/{components → dist/components}/form/error/form-error.module.css.js +0 -0
- /package/{components → dist/components}/form/error/form-error.module.css.js.map +0 -0
- /package/{components → dist/components}/form/error/index.js +0 -0
- /package/{components → dist/components}/form/error/index.js.map +0 -0
- /package/{components → dist/components}/form/field/form-field.module.css +0 -0
- /package/{components → dist/components}/form/field/form-field.module.css.js +0 -0
- /package/{components → dist/components}/form/field/form-field.module.css.js.map +0 -0
- /package/{components → dist/components}/form/field/index.js +0 -0
- /package/{components → dist/components}/form/field/index.js.map +0 -0
- /package/{components → dist/components}/form/fieldset/form-fieldset.module.css +0 -0
- /package/{components → dist/components}/form/fieldset/form-fieldset.module.css.js +0 -0
- /package/{components → dist/components}/form/fieldset/form-fieldset.module.css.js.map +0 -0
- /package/{components → dist/components}/form/fieldset/index.js +0 -0
- /package/{components → dist/components}/form/fieldset/index.js.map +0 -0
- /package/{components → dist/components}/form/file-input/form-file-input.module.scss.js +0 -0
- /package/{components → dist/components}/form/file-input/form-file-input.module.scss.js.map +0 -0
- /package/{components → dist/components}/form/file-input/index.js +0 -0
- /package/{components → dist/components}/form/file-input/index.js.map +0 -0
- /package/{components → dist/components}/form/helper-text/form-helper-text.module.css +0 -0
- /package/{components → dist/components}/form/helper-text/form-helper-text.module.css.js +0 -0
- /package/{components → dist/components}/form/helper-text/form-helper-text.module.css.js.map +0 -0
- /package/{components → dist/components}/form/helper-text/index.js +0 -0
- /package/{components → dist/components}/form/helper-text/index.js.map +0 -0
- /package/{components → dist/components}/form/indicator/form-indicator.module.css +0 -0
- /package/{components → dist/components}/form/indicator/form-indicator.module.css.js +0 -0
- /package/{components → dist/components}/form/indicator/form-indicator.module.css.js.map +0 -0
- /package/{components → dist/components}/form/indicator/index.js +0 -0
- /package/{components → dist/components}/form/indicator/index.js.map +0 -0
- /package/{components → dist/components}/form/label/form-label.module.css +0 -0
- /package/{components → dist/components}/form/label/form-label.module.css.js +0 -0
- /package/{components → dist/components}/form/label/form-label.module.css.js.map +0 -0
- /package/{components → dist/components}/form/label/index.js +0 -0
- /package/{components → dist/components}/form/label/index.js.map +0 -0
- /package/{components → dist/components}/form/legend/form-legend.module.css +0 -0
- /package/{components → dist/components}/form/legend/form-legend.module.css.js +0 -0
- /package/{components → dist/components}/form/legend/form-legend.module.css.js.map +0 -0
- /package/{components → dist/components}/form/legend/index.js +0 -0
- /package/{components → dist/components}/form/legend/index.js.map +0 -0
- /package/{components → dist/components}/form/radio/form-radio.module.scss.js +0 -0
- /package/{components → dist/components}/form/radio/form-radio.module.scss.js.map +0 -0
- /package/{components → dist/components}/form/radio/index.js +0 -0
- /package/{components → dist/components}/form/radio/index.js.map +0 -0
- /package/{components → dist/components}/form/radio-card/RadioCardStory.css +0 -0
- /package/{components → dist/components}/form/radio-card/description.js +0 -0
- /package/{components → dist/components}/form/radio-card/description.js.map +0 -0
- /package/{components → dist/components}/form/radio-card/form-radio-card.module.css.js +0 -0
- /package/{components → dist/components}/form/radio-card/form-radio-card.module.css.js.map +0 -0
- /package/{components → dist/components}/form/radio-card/group.js +0 -0
- /package/{components → dist/components}/form/radio-card/group.js.map +0 -0
- /package/{components → dist/components}/form/radio-card/index.js +0 -0
- /package/{components → dist/components}/form/radio-card/label.js +0 -0
- /package/{components → dist/components}/form/radio-card/label.js.map +0 -0
- /package/{components → dist/components}/form/select/form-select.module.css.js +0 -0
- /package/{components → dist/components}/form/select/form-select.module.css.js.map +0 -0
- /package/{components → dist/components}/form/select/index.js +0 -0
- /package/{components → dist/components}/form/super-select/form-super-select.module.css.js +0 -0
- /package/{components → dist/components}/form/super-select/form-super-select.module.css.js.map +0 -0
- /package/{components → dist/components}/form/super-select/index.js +0 -0
- /package/{components → dist/components}/form/text-input/index.js +0 -0
- /package/{components → dist/components}/form/text-input/styles.module.css.js +0 -0
- /package/{components → dist/components}/form/text-input/styles.module.css.js.map +0 -0
- /package/{components → dist/components}/form/textarea/form-textarea.module.css.js +0 -0
- /package/{components → dist/components}/form/textarea/form-textarea.module.css.js.map +0 -0
- /package/{components → dist/components}/form/textarea/index.js +0 -0
- /package/{components → dist/components}/form/toggle/form-toggle.module.scss.js +0 -0
- /package/{components → dist/components}/form/toggle/form-toggle.module.scss.js.map +0 -0
- /package/{components → dist/components}/form/toggle/index.js +0 -0
- /package/{components → dist/components}/form/toggle/index.js.map +0 -0
- /package/{components → dist/components}/hds/wrappers/tooltip.js +0 -0
- /package/{components → dist/components}/hds/wrappers/tooltip.js.map +0 -0
- /package/{components → dist/components}/icon-tile/index.js +0 -0
- /package/{components → dist/components}/icon-tile/style.module.scss.js +0 -0
- /package/{components → dist/components}/icon-tile/style.module.scss.js.map +0 -0
- /package/{components → dist/components}/inline-link/index.js +0 -0
- /package/{components → dist/components}/inline-link/index.js.map +0 -0
- /package/{components → dist/components}/inline-link/inline-link.module.css +0 -0
- /package/{components → dist/components}/inline-link/inline-link.module.css.js +0 -0
- /package/{components → dist/components}/inline-link/inline-link.module.css.js.map +0 -0
- /package/{components → dist/components}/interactive/index.js +0 -0
- /package/{components → dist/components}/legacy-button/index.js +0 -0
- /package/{components → dist/components}/legacy-button/utils.js +0 -0
- /package/{components → dist/components}/menu-primitive/index.js +0 -0
- /package/{components → dist/components}/menu-primitive/styles.module.css +0 -0
- /package/{components → dist/components}/menu-primitive/styles.module.css.js +0 -0
- /package/{components → dist/components}/menu-primitive/styles.module.css.js.map +0 -0
- /package/{components → dist/components}/menu-primitive/use-menu-primitive.js +0 -0
- /package/{components → dist/components}/modal/index.js +0 -0
- /package/{components → dist/components}/modal/modal.module.css +0 -0
- /package/{components → dist/components}/modal/modal.module.css.js +0 -0
- /package/{components → dist/components}/modal/modal.module.css.js.map +0 -0
- /package/{components → dist/components}/modal/use-modal.js +0 -0
- /package/{components → dist/components}/separator/index.js +0 -0
- /package/{components → dist/components}/separator/index.js.map +0 -0
- /package/{components → dist/components}/separator/separator.module.css +0 -0
- /package/{components → dist/components}/separator/separator.module.css.js +0 -0
- /package/{components → dist/components}/separator/separator.module.css.js.map +0 -0
- /package/{components → dist/components}/standalone-link/index.js +0 -0
- /package/{components → dist/components}/standalone-link/styles.module.scss.js +0 -0
- /package/{components → dist/components}/standalone-link/styles.module.scss.js.map +0 -0
- /package/{components → dist/components}/table/index.js +0 -0
- /package/{components → dist/components}/table/table.module.scss +0 -0
- /package/{components → dist/components}/table/table.module.scss.js +0 -0
- /package/{components → dist/components}/table/table.module.scss.js.map +0 -0
- /package/{components → dist/components}/table/td.js +0 -0
- /package/{components → dist/components}/table/th-button-tooltip.js +0 -0
- /package/{components → dist/components}/table/th-button-tooltip.js.map +0 -0
- /package/{components → dist/components}/table/th.js +0 -0
- /package/{components → dist/components}/table/tr.js +0 -0
- /package/{components → dist/components}/table/tr.js.map +0 -0
- /package/{components → dist/components}/table/utils.js +0 -0
- /package/{components → dist/components}/tabs/index.js +0 -0
- /package/{components → dist/components}/tabs/tab-panel.js +0 -0
- /package/{components → dist/components}/tabs/tab.js +0 -0
- /package/{components → dist/components}/tabs/tabs.module.scss.js +0 -0
- /package/{components → dist/components}/tabs/tabs.module.scss.js.map +0 -0
- /package/{components → dist/components}/tabs/use-tabs-context.js +0 -0
- /package/{components → dist/components}/text/index.js +0 -0
- /package/{components → dist/components}/text/style.module.scss +0 -0
- /package/{components → dist/components}/text/style.module.scss.js +0 -0
- /package/{components → dist/components}/text/style.module.scss.js.map +0 -0
- /package/{components → dist/components}/visualizations/bar-chart/horizontal-chart/dataset-value/style.module.css +0 -0
- /package/{components → dist/components}/visualizations/bar-chart/horizontal-chart/dataset-value/style.module.css.js +0 -0
- /package/{components → dist/components}/visualizations/bar-chart/horizontal-chart/dataset-value/style.module.css.js.map +0 -0
- /package/{components → dist/components}/visualizations/bar-chart/horizontal-chart/legend/index.js +0 -0
- /package/{components → dist/components}/visualizations/bar-chart/horizontal-chart/legend/index.js.map +0 -0
- /package/{components → dist/components}/visualizations/bar-chart/horizontal-chart/legend/style.module.css +0 -0
- /package/{components → dist/components}/visualizations/bar-chart/horizontal-chart/legend/style.module.css.js +0 -0
- /package/{components → dist/components}/visualizations/bar-chart/horizontal-chart/legend/style.module.css.js.map +0 -0
- /package/{components → dist/components}/visualizations/bar-chart/horizontal-chart/style.module.css.js +0 -0
- /package/{components → dist/components}/visualizations/bar-chart/horizontal-chart/style.module.css.js.map +0 -0
- /package/{components → dist/components}/visualizations/bar-chart/index.js +0 -0
- /package/{components → dist/components}/visualizations/bar-chart/index.js.map +0 -0
- /package/{components → dist/components}/visualizations/bar-chart/style.module.css.js +0 -0
- /package/{components → dist/components}/visualizations/bar-chart/style.module.css.js.map +0 -0
- /package/{components → dist/components}/visualizations/donut-chart/components/arc-tooltip/index.js +0 -0
- /package/{components → dist/components}/visualizations/donut-chart/components/arc-tooltip/index.js.map +0 -0
- /package/{components → dist/components}/visualizations/donut-chart/components/arc-tooltip/styles.module.css +0 -0
- /package/{components → dist/components}/visualizations/donut-chart/components/arc-tooltip/styles.module.css.js +0 -0
- /package/{components → dist/components}/visualizations/donut-chart/components/arc-tooltip/styles.module.css.js.map +0 -0
- /package/{components → dist/components}/visualizations/donut-chart/components/external-arc-label/index.js +0 -0
- /package/{components → dist/components}/visualizations/donut-chart/components/external-arc-label/index.js.map +0 -0
- /package/{components → dist/components}/visualizations/donut-chart/components/external-arc-label/styles.module.css +0 -0
- /package/{components → dist/components}/visualizations/donut-chart/components/external-arc-label/styles.module.css.js +0 -0
- /package/{components → dist/components}/visualizations/donut-chart/components/external-arc-label/styles.module.css.js.map +0 -0
- /package/{components → dist/components}/visualizations/donut-chart/components/internal-arc-label/index.js +0 -0
- /package/{components → dist/components}/visualizations/donut-chart/components/internal-arc-label/index.js.map +0 -0
- /package/{components → dist/components}/visualizations/donut-chart/components/internal-arc-label/styles.module.css +0 -0
- /package/{components → dist/components}/visualizations/donut-chart/components/internal-arc-label/styles.module.css.js +0 -0
- /package/{components → dist/components}/visualizations/donut-chart/components/internal-arc-label/styles.module.css.js.map +0 -0
- /package/{components → dist/components}/visualizations/donut-chart/styles.module.css.js +0 -0
- /package/{components → dist/components}/visualizations/donut-chart/styles.module.css.js.map +0 -0
- /package/{patterns → dist/patterns}/card/newsroom-card/index.js +0 -0
- /package/{patterns → dist/patterns}/card/newsroom-card/index.js.map +0 -0
- /package/{patterns → dist/patterns}/card/newsroom-card/style.module.css +0 -0
- /package/{patterns → dist/patterns}/card/newsroom-card/style.module.css.js +0 -0
- /package/{patterns → dist/patterns}/card/newsroom-card/style.module.css.js.map +0 -0
- /package/{patterns → dist/patterns}/card/partner-card/index.js +0 -0
- /package/{patterns → dist/patterns}/card/partner-card/index.js.map +0 -0
- /package/{patterns → dist/patterns}/card/partner-card/style.module.css +0 -0
- /package/{patterns → dist/patterns}/card/partner-card/style.module.css.js +0 -0
- /package/{patterns → dist/patterns}/card/partner-card/style.module.css.js.map +0 -0
- /package/{patterns → dist/patterns}/card/person-card/index.js +0 -0
- /package/{patterns → dist/patterns}/card/person-card/index.js.map +0 -0
- /package/{patterns → dist/patterns}/card/person-card/style.module.css +0 -0
- /package/{patterns → dist/patterns}/card/person-card/style.module.css.js +0 -0
- /package/{patterns → dist/patterns}/card/person-card/style.module.css.js.map +0 -0
- /package/{patterns → dist/patterns}/card/primitives.js +0 -0
- /package/{patterns → dist/patterns}/card/primitives.js.map +0 -0
- /package/{patterns → dist/patterns}/card/promo-card/index.js +0 -0
- /package/{patterns → dist/patterns}/card/promo-card/index.js.map +0 -0
- /package/{patterns → dist/patterns}/card/resource-card/index.js +0 -0
- /package/{patterns → dist/patterns}/card/resource-card/index.js.map +0 -0
- /package/{patterns → dist/patterns}/card/style.module.css.js +0 -0
- /package/{patterns → dist/patterns}/card/style.module.css.js.map +0 -0
- /package/{patterns → dist/patterns}/card/thumbnails/index.js +0 -0
- /package/{patterns → dist/patterns}/card/thumbnails/index.js.map +0 -0
- /package/{patterns → dist/patterns}/card/unified-card/index.js +0 -0
- /package/{patterns → dist/patterns}/copy-button/style.module.css +0 -0
- /package/{patterns → dist/patterns}/copy-button/style.module.css.js +0 -0
- /package/{patterns → dist/patterns}/copy-button/style.module.css.js.map +0 -0
- /package/{patterns → dist/patterns}/index.js +0 -0
- /package/{patterns → dist/patterns}/index.js.map +0 -0
- /package/{patterns → dist/patterns}/layout/index.js +0 -0
- /package/{patterns → dist/patterns}/layout/index.js.map +0 -0
- /package/{patterns → dist/patterns}/layout/layout.module.css.js +0 -0
- /package/{patterns → dist/patterns}/layout/layout.module.css.js.map +0 -0
- /package/{patterns → dist/patterns}/product-badge/index.js +0 -0
- /package/{patterns → dist/patterns}/product-badge/index.js.map +0 -0
- /package/{patterns → dist/patterns}/product-badge/style.module.css.js +0 -0
- /package/{patterns → dist/patterns}/product-badge/style.module.css.js.map +0 -0
- /package/{patterns → dist/patterns}/product-logo/index.js +0 -0
- /package/{patterns → dist/patterns}/product-logo/index.js.map +0 -0
- /package/{patterns → dist/patterns}/product-logo/product-logo.module.css +0 -0
- /package/{patterns → dist/patterns}/product-logo/product-logo.module.css.js +0 -0
- /package/{patterns → dist/patterns}/product-logo/product-logo.module.css.js.map +0 -0
- /package/{patterns → dist/patterns}/related-content/index.js +0 -0
- /package/{patterns → dist/patterns}/related-content/index.js.map +0 -0
- /package/{patterns → dist/patterns}/related-content/style.module.css.js +0 -0
- /package/{patterns → dist/patterns}/related-content/style.module.css.js.map +0 -0
- /package/{utils → dist/utils}/get-contrast-yiq.js +0 -0
- /package/{utils → dist/utils}/i18n/constants/index.js +0 -0
- /package/{utils → dist/utils}/i18n/helpers/to-smart-sentence-case.js +0 -0
- /package/{utils → dist/utils}/i18n/helpers/to-smart-title-case.js +0 -0
- /package/{utils → dist/utils}/i18n/index.js +0 -0
- /package/{utils → dist/utils}/make-normalizer/index.js +0 -0
- /package/{utils → dist/utils}/mds-context/index.js +0 -0
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
@use 'styles/mixins/focus-ring' as *;
|
|
2
|
+
|
|
3
|
+
$standalone-link-border-width: 1px;
|
|
4
|
+
$standalone-link-focus-border-radius: 5px;
|
|
5
|
+
|
|
6
|
+
// this is how much the focus is visually "shifted" from the bounding box of the
|
|
7
|
+
// notice: you have to take in account also the inset shadow of the focus (see Figma file and also "focus-ring" mixin)
|
|
8
|
+
$standalone-link-focus-shift: 4px;
|
|
9
|
+
|
|
10
|
+
.standalone-link {
|
|
11
|
+
display: flex;
|
|
12
|
+
gap: 0.25rem;
|
|
13
|
+
align-items: center;
|
|
14
|
+
justify-content: center;
|
|
15
|
+
width: fit-content;
|
|
16
|
+
padding-top: 4px;
|
|
17
|
+
padding-bottom: 4px;
|
|
18
|
+
font-weight: var(--mds-typography-font-weight-medium);
|
|
19
|
+
font-family: var(--mds-typography-font-stack-text);
|
|
20
|
+
background-color: transparent; // needs to exist for a11y
|
|
21
|
+
border: $standalone-link-border-width solid transparent; // needs to exist AND be transparent for a11y
|
|
22
|
+
// notice: the text decoration is applied directly to the "text" container because of a bug in Safari (see https://github.com/hashicorp/design-system-components/issues/159)
|
|
23
|
+
text-decoration-color: transparent;
|
|
24
|
+
cursor: pointer;
|
|
25
|
+
|
|
26
|
+
// the position absolute of an element is computed from the inside of the border of the container
|
|
27
|
+
// so we have to take in account the border width of the pseudo-element container itself
|
|
28
|
+
$shift: $standalone-link-focus-shift + $standalone-link-border-width;
|
|
29
|
+
// for visual/optical balance we add an extra 2px to the "shift" near the text (opposite the icon)
|
|
30
|
+
$shift-extra: $shift + 2px;
|
|
31
|
+
|
|
32
|
+
// notice: this is used not only for the focus, but also to increase the clickable area
|
|
33
|
+
@include hds-focus-ring-with-pseudo-element($right: -$shift, $left: -$shift, $radius: $standalone-link-focus-border-radius);
|
|
34
|
+
|
|
35
|
+
// we need to override a couple of values for better visual alignment
|
|
36
|
+
&.icon-position-leading::before {
|
|
37
|
+
right: -$shift-extra;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
&.icon-position-trailing::before {
|
|
41
|
+
left: -$shift-extra;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
& svg {
|
|
45
|
+
transition: color 0.15s ease-in;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
.text {
|
|
50
|
+
flex: 1 0 0;
|
|
51
|
+
text-decoration: underline;
|
|
52
|
+
text-decoration-color: transparent;
|
|
53
|
+
transition:
|
|
54
|
+
text-decoration-color 0.15s ease-in,
|
|
55
|
+
color 0.15s ease-in;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
.size-small {
|
|
59
|
+
& .text {
|
|
60
|
+
font-size: var(--mds-typography-body-100-font-size);
|
|
61
|
+
line-height: var(--mds-typography-body-100-line-height);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
.size-medium {
|
|
66
|
+
& .text {
|
|
67
|
+
font-size: var(--mds-typography-body-200-font-size);
|
|
68
|
+
line-height: var(--mds-typography-body-200-line-height);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
.size-large {
|
|
73
|
+
& .text {
|
|
74
|
+
font-size: var(--mds-typography-body-300-font-size);
|
|
75
|
+
line-height: var(--mds-typography-body-300-line-height);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
.color-primary {
|
|
80
|
+
color: var(--mds-color-foreground-action);
|
|
81
|
+
|
|
82
|
+
&:hover {
|
|
83
|
+
color: var(--mds-color-foreground-action-hover);
|
|
84
|
+
|
|
85
|
+
.text {
|
|
86
|
+
text-decoration-color: #4e81e8; // custom color by design
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
&:active {
|
|
91
|
+
color: var(--mds-color-foreground-action-active);
|
|
92
|
+
|
|
93
|
+
.text {
|
|
94
|
+
text-decoration-color: #396ed6; // custom color by design
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
&::before {
|
|
98
|
+
background-color: var(--mds-color-surface-action);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
.color-secondary {
|
|
104
|
+
color: var(--mds-color-foreground-strong);
|
|
105
|
+
|
|
106
|
+
&:hover {
|
|
107
|
+
.text {
|
|
108
|
+
text-decoration-color: #4d4d4f; // custom color by design
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
&:active {
|
|
113
|
+
color: var(--mds-color-foreground-primary);
|
|
114
|
+
|
|
115
|
+
.text {
|
|
116
|
+
text-decoration-color: #6e7075; // custom color by design
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
&::before {
|
|
120
|
+
background-color: var(--mds-color-surface-interactive-active);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
:global(.mds-dark-mode),
|
|
126
|
+
:global([data-theme='dark']) {
|
|
127
|
+
& .color-secondary {
|
|
128
|
+
&:hover {
|
|
129
|
+
.text {
|
|
130
|
+
text-decoration-color: var(--mds-color-foreground-strong);
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
&:active {
|
|
135
|
+
.text {
|
|
136
|
+
text-decoration-color: var(--mds-color-foreground-strong);
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
.color-secondary-inverted {
|
|
143
|
+
color: var(--mds-color-palette-neutral-50);
|
|
144
|
+
|
|
145
|
+
&:hover {
|
|
146
|
+
color: var(--mds-color-palette-neutral-300);
|
|
147
|
+
|
|
148
|
+
.text {
|
|
149
|
+
text-decoration-color: var(--mds-color-palette-neutral-300);
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
&:active {
|
|
154
|
+
color: var(--mds-color-palette-neutral-300);
|
|
155
|
+
|
|
156
|
+
.text {
|
|
157
|
+
text-decoration-color: var(--mds-color-palette-neutral-300);
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
&::before {
|
|
161
|
+
background-color: var(--mds-color-palette-neutral-600);
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import type { HTMLAttributes, ReactNode } from 'react';
|
|
2
|
+
import { type Density, type VerticalAlignment } from './utils';
|
|
3
|
+
export interface TableProps extends HTMLAttributes<HTMLTableElement> {
|
|
4
|
+
/**
|
|
5
|
+
* Define on the table invocation. If set to `true`, even-numbered rows will have a different background color from odd-numbered rows.
|
|
6
|
+
*/
|
|
7
|
+
isStriped?: boolean;
|
|
8
|
+
/**
|
|
9
|
+
* If set to `true`, the `table-display`(CSS) property will be set to fixed. See [MDN reference on table-layout](https://developer.mozilla.org/en-US/docs/Web/CSS/table-layout) for more details.
|
|
10
|
+
*/
|
|
11
|
+
isFixedLayout?: boolean;
|
|
12
|
+
/**
|
|
13
|
+
* If set, determines the density (height) of the table body’s rows.
|
|
14
|
+
*/
|
|
15
|
+
density?: Density;
|
|
16
|
+
/**
|
|
17
|
+
* Determines the vertical alignment for content in a table. Does not apply to table headers (`th`). See [MDN reference on vertical-align](https://developer.mozilla.org/en-US/docs/Web/CSS/vertical-align) for more details.
|
|
18
|
+
*/
|
|
19
|
+
valign?: VerticalAlignment;
|
|
20
|
+
/**
|
|
21
|
+
* Adds a (non-visible) caption for users with assistive technology. If set on a sortable table, the provided table caption is paired with the automatically generated sorted message text.
|
|
22
|
+
*/
|
|
23
|
+
caption?: string;
|
|
24
|
+
}
|
|
25
|
+
declare function Root({ caption, density, valign, isStriped, isFixedLayout, children, className, ...rest }: TableProps): import("react/jsx-runtime").JSX.Element;
|
|
26
|
+
declare namespace Root {
|
|
27
|
+
var displayName: string;
|
|
28
|
+
}
|
|
29
|
+
declare function THead({ children }: {
|
|
30
|
+
children: ReactNode;
|
|
31
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
32
|
+
declare namespace THead {
|
|
33
|
+
var displayName: string;
|
|
34
|
+
}
|
|
35
|
+
declare function TBody({ children }: {
|
|
36
|
+
children: ReactNode;
|
|
37
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
38
|
+
declare namespace TBody {
|
|
39
|
+
var displayName: string;
|
|
40
|
+
}
|
|
41
|
+
declare const Table: {
|
|
42
|
+
Root: typeof Root;
|
|
43
|
+
TR: {
|
|
44
|
+
({ children, className, ...rest }: import("./tr").TRProps): import("react/jsx-runtime").JSX.Element;
|
|
45
|
+
displayName: string;
|
|
46
|
+
};
|
|
47
|
+
THead: typeof THead;
|
|
48
|
+
TH: {
|
|
49
|
+
({ align, width, scope, tooltip, isVisuallyHidden, children, className, ...rest }: import("./th").THProps): import("react/jsx-runtime").JSX.Element;
|
|
50
|
+
displayName: string;
|
|
51
|
+
};
|
|
52
|
+
TBody: typeof TBody;
|
|
53
|
+
TD: {
|
|
54
|
+
({ align, children, className, ...rest }: import("./td").TDProps): import("react/jsx-runtime").JSX.Element;
|
|
55
|
+
displayName: string;
|
|
56
|
+
};
|
|
57
|
+
};
|
|
58
|
+
export { Table };
|
|
59
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/table/index.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AACtD,OAAO,EAGN,KAAK,OAAO,EACZ,KAAK,iBAAiB,EACtB,MAAM,SAAS,CAAA;AAGhB,MAAM,WAAW,UAAW,SAAQ,cAAc,CAAC,gBAAgB,CAAC;IACnE;;OAEG;IACH,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB;;OAEG;IACH,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB;;OAEG;IACH,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB;;OAEG;IACH,MAAM,CAAC,EAAE,iBAAiB,CAAA;IAC1B;;OAEG;IACH,OAAO,CAAC,EAAE,MAAM,CAAA;CAChB;AAED,iBAAS,IAAI,CAAC,EACb,OAAO,EACP,OAAyB,EACzB,MAAmC,EACnC,SAAS,EACT,aAAa,EACb,QAAQ,EACR,SAAS,EACT,GAAG,IAAI,EACP,EAAE,UAAU,2CAmBZ;kBA5BQ,IAAI;;;AA+Bb,iBAAS,KAAK,CAAC,EAAE,QAAQ,EAAE,EAAE;IAAE,QAAQ,EAAE,SAAS,CAAA;CAAE,2CAEnD;kBAFQ,KAAK;;;AAKd,iBAAS,KAAK,CAAC,EAAE,QAAQ,EAAE,EAAE;IAAE,QAAQ,EAAE,SAAS,CAAA;CAAE,2CAEnD;kBAFQ,KAAK;;;AAKd,QAAA,MAAM,KAAK;;;;;;;;;;;;;;;;CAAqC,CAAA;AAEhD,OAAO,EAAE,KAAK,EAAE,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../src/components/table/index.tsx"],"sourcesContent":["import classNames from 'classnames'\nimport { TD } from './td'\nimport { TH } from './th'\nimport { TR } from './tr'\nimport type { HTMLAttributes, ReactNode } from 'react'\nimport {\n\tDEFAULT_DENSITY,\n\tDEFAULT_VERTICAL_ALIGNMENT,\n\ttype Density,\n\ttype VerticalAlignment,\n} from './utils'\nimport s from './table.module.scss'\n\nexport interface TableProps extends HTMLAttributes<HTMLTableElement> {\n\t/**\n\t * Define on the table invocation. If set to `true`, even-numbered rows will have a different background color from odd-numbered rows.\n\t */\n\tisStriped?: boolean\n\t/**\n\t * If set to `true`, the `table-display`(CSS) property will be set to fixed. See [MDN reference on table-layout](https://developer.mozilla.org/en-US/docs/Web/CSS/table-layout) for more details.\n\t */\n\tisFixedLayout?: boolean\n\t/**\n\t * If set, determines the density (height) of the table body’s rows.\n\t */\n\tdensity?: Density\n\t/**\n\t * Determines the vertical alignment for content in a table. Does not apply to table headers (`th`). See [MDN reference on vertical-align](https://developer.mozilla.org/en-US/docs/Web/CSS/vertical-align) for more details.\n\t */\n\tvalign?: VerticalAlignment\n\t/**\n\t * Adds a (non-visible) caption for users with assistive technology. If set on a sortable table, the provided table caption is paired with the automatically generated sorted message text.\n\t */\n\tcaption?: string\n}\n\nfunction Root({\n\tcaption,\n\tdensity = DEFAULT_DENSITY,\n\tvalign = DEFAULT_VERTICAL_ALIGNMENT,\n\tisStriped,\n\tisFixedLayout,\n\tchildren,\n\tclassName,\n\t...rest\n}: TableProps) {\n\treturn (\n\t\t<table\n\t\t\tclassName={classNames(\n\t\t\t\ts.table,\n\t\t\t\ts[`density-${density}`],\n\t\t\t\ts[`valign-${valign}`],\n\t\t\t\t{\n\t\t\t\t\t[s.striped]: isStriped,\n\t\t\t\t\t[s['layout-fixed']]: isFixedLayout,\n\t\t\t\t},\n\t\t\t\tclassName,\n\t\t\t)}\n\t\t\t{...rest}\n\t\t>\n\t\t\t{caption && <caption className=\"sr-only\">{caption}</caption>}\n\t\t\t{children}\n\t\t</table>\n\t)\n}\nRoot.displayName = 'Table'\n\nfunction THead({ children }: { children: ReactNode }) {\n\treturn <thead className={s.thead}>{children}</thead>\n}\nTHead.displayName = 'T.Head'\n\nfunction TBody({ children }: { children: ReactNode }) {\n\treturn <tbody className={s.tbody}>{children}</tbody>\n}\nTBody.displayName = 'T.Body'\n\nconst Table = { Root, TR, THead, TH, TBody, TD }\n\nexport { Table }\n"],"names":["Root","caption","density","DEFAULT_DENSITY","valign","DEFAULT_VERTICAL_ALIGNMENT","isStriped","isFixedLayout","children","className","rest","jsxs","classNames","s","jsx","THead","TBody","Table","TR","TH","TD"],"mappings":";;;;;;;AAoCA,SAASA,EAAK;AAAA,EACb,SAAAC;AAAA,EACA,SAAAC,IAAUC;AAAA,EACV,QAAAC,IAASC;AAAA,EACT,WAAAC;AAAA,EACA,eAAAC;AAAA,EACA,UAAAC;AAAA,EACA,WAAAC;AAAA,EACA,GAAGC;AACJ,GAAe;AACd,SACC,gBAAAC;AAAA,IAAC;AAAA,IAAA;AAAA,MACA,WAAWC;AAAA,QACVC,EAAE;AAAA,QACFA,EAAE,WAAWX,CAAO,EAAE;AAAA,QACtBW,EAAE,UAAUT,CAAM,EAAE;AAAA,QACpB;AAAA,UACC,CAACS,EAAE,OAAO,GAAGP;AAAA,UACb,CAACO,EAAE,cAAc,CAAC,GAAGN;AAAA,QAAA;AAAA,QAEtBE;AAAA,MAAA;AAAA,MAEA,GAAGC;AAAA,MAEH,UAAA;AAAA,QAAAT,KAAW,gBAAAa,EAAC,WAAA,EAAQ,WAAU,WAAW,UAAAb,GAAQ;AAAA,QACjDO;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAGJ;AACAR,EAAK,cAAc;AAEnB,SAASe,EAAM,EAAE,UAAAP,KAAqC;AACrD,SAAO,gBAAAM,EAAC,SAAA,EAAM,WAAWD,EAAE,OAAQ,UAAAL,GAAS;AAC7C;AACAO,EAAM,cAAc;AAEpB,SAASC,EAAM,EAAE,UAAAR,KAAqC;AACrD,SAAO,gBAAAM,EAAC,SAAA,EAAM,WAAWD,EAAE,OAAQ,UAAAL,GAAS;AAC7C;AACAQ,EAAM,cAAc;AAEpB,MAAMC,IAAQ,EAAE,MAAAjB,GAAM,IAAAkB,GAAI,OAAAH,GAAO,IAAAI,GAAI,OAAAH,GAAO,IAAAI,EAAA;"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { type HorizontalAlignment } from './utils';
|
|
2
|
+
import type { HTMLAttributes, ReactNode } from 'react';
|
|
3
|
+
export interface TDProps extends HTMLAttributes<HTMLTableCellElement> {
|
|
4
|
+
/**
|
|
5
|
+
* Determines the horizontal content alignment (sometimes referred to as text alignment) for the cell (make sure it is also set for the column header).
|
|
6
|
+
*/
|
|
7
|
+
align?: HorizontalAlignment;
|
|
8
|
+
/**
|
|
9
|
+
* Elements passed as children are yielded as inner content of a <td> HTML element.
|
|
10
|
+
*/
|
|
11
|
+
children: ReactNode;
|
|
12
|
+
}
|
|
13
|
+
declare const TD: {
|
|
14
|
+
({ align, children, className, ...rest }: TDProps): import("react/jsx-runtime").JSX.Element;
|
|
15
|
+
displayName: string;
|
|
16
|
+
};
|
|
17
|
+
export { TD };
|
|
18
|
+
//# sourceMappingURL=td.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"td.d.ts","sourceRoot":"","sources":["../../../src/components/table/td.tsx"],"names":[],"mappings":"AACA,OAAO,EAAqB,KAAK,mBAAmB,EAAE,MAAM,SAAS,CAAA;AACrE,OAAO,KAAK,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AAGtD,MAAM,WAAW,OAAQ,SAAQ,cAAc,CAAC,oBAAoB,CAAC;IACpE;;OAEG;IACH,KAAK,CAAC,EAAE,mBAAmB,CAAA;IAC3B;;OAEG;IACH,QAAQ,EAAE,SAAS,CAAA;CACnB;AAED,QAAA,MAAM,EAAE;8CAKL,OAAO;;CAeT,CAAA;AAID,OAAO,EAAE,EAAE,EAAE,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"td.js","sources":["../../../src/components/table/td.tsx"],"sourcesContent":["import classNames from 'classnames'\nimport { DEFAULT_ALIGNMENT, type HorizontalAlignment } from './utils'\nimport type { HTMLAttributes, ReactNode } from 'react'\nimport s from './table.module.scss'\n\nexport interface TDProps extends HTMLAttributes<HTMLTableCellElement> {\n\t/**\n\t * Determines the horizontal content alignment (sometimes referred to as text alignment) for the cell (make sure it is also set for the column header).\n\t */\n\talign?: HorizontalAlignment\n\t/**\n\t * Elements passed as children are yielded as inner content of a <td> HTML element.\n\t */\n\tchildren: ReactNode\n}\n\nconst TD = ({\n\talign = DEFAULT_ALIGNMENT,\n\tchildren,\n\tclassName,\n\t...rest\n}: TDProps) => {\n\treturn (\n\t\t<td\n\t\t\tclassName={classNames(\n\t\t\t\ts.td,\n\t\t\t\ts[`align-${align}`],\n\t\t\t\t'mds-typography-legacy-body-200',\n\t\t\t\t'mds-typography-font-weight-regular',\n\t\t\t\tclassName,\n\t\t\t)}\n\t\t\t{...rest}\n\t\t>\n\t\t\t<div className={s.content}>{children}</div>\n\t\t</td>\n\t)\n}\n\nTD.displayName = 'B.Td'\n\nexport { TD }\n"],"names":["TD","align","DEFAULT_ALIGNMENT","children","className","rest","jsx","classNames","s"],"mappings":";;;;AAgBA,MAAMA,IAAK,CAAC;AAAA,EACX,OAAAC,IAAQC;AAAA,EACR,UAAAC;AAAA,EACA,WAAAC;AAAA,EACA,GAAGC;AACJ,MAEE,gBAAAC;AAAA,EAAC;AAAA,EAAA;AAAA,IACA,WAAWC;AAAA,MACVC,EAAE;AAAA,MACFA,EAAE,SAASP,CAAK,EAAE;AAAA,MAClB;AAAA,MACA;AAAA,MACAG;AAAA,IAAA;AAAA,IAEA,GAAGC;AAAA,IAEJ,UAAA,gBAAAC,EAAC,OAAA,EAAI,WAAWE,EAAE,SAAU,UAAAL,EAAA,CAAS;AAAA,EAAA;AAAA;AAKxCH,EAAG,cAAc;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"th-button-tooltip.d.ts","sourceRoot":"","sources":["../../../src/components/table/th-button-tooltip.tsx"],"names":[],"mappings":"AAKA,UAAU,YAAY;IACrB,OAAO,EAAE,MAAM,CAAA;IACf,OAAO,EAAE,MAAM,CAAA;CACf;AAED,eAAO,MAAM,eAAe,GAAI,sBAAsB,YAAY,4CAiBjE,CAAA"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { type HTMLAttributes, type ReactNode } from 'react';
|
|
2
|
+
import type { HorizontalAlignment, Scope } from './utils';
|
|
3
|
+
export interface THProps extends HTMLAttributes<HTMLTableCellElement> {
|
|
4
|
+
/**
|
|
5
|
+
* Determines the horizontal content alignment (sometimes referred to as text alignment) for the column header.
|
|
6
|
+
*/
|
|
7
|
+
align?: HorizontalAlignment;
|
|
8
|
+
/**
|
|
9
|
+
* If used as the first item in a table body’s row, scope should be set to row for accessibility purposes.
|
|
10
|
+
*/
|
|
11
|
+
scope?: Scope;
|
|
12
|
+
/**
|
|
13
|
+
* Any valid CSS
|
|
14
|
+
* If set, determines the column’s width.
|
|
15
|
+
*/
|
|
16
|
+
width?: string;
|
|
17
|
+
/**
|
|
18
|
+
* Text string which will appear in the tooltip. May contain basic HTML tags for formatting text such as strong and em tags. Not intended for multi-paragraph text or other more complex content. May not contain interactive content such as links or buttons. The placement and offset are automatically set and can’t be overwritten.
|
|
19
|
+
*/
|
|
20
|
+
tooltip?: string;
|
|
21
|
+
/**
|
|
22
|
+
* If set to `true`, it visually hides the column’s text content (it will still be available to screen readers for accessibility).
|
|
23
|
+
*/
|
|
24
|
+
isVisuallyHidden?: boolean;
|
|
25
|
+
/**
|
|
26
|
+
* Elements passed as children are yielded as inner content of a `<th>` HTML element.
|
|
27
|
+
*/
|
|
28
|
+
children: ReactNode;
|
|
29
|
+
}
|
|
30
|
+
declare const TH: {
|
|
31
|
+
({ align, width, scope, tooltip, isVisuallyHidden, children, className, ...rest }: THProps): import("react/jsx-runtime").JSX.Element;
|
|
32
|
+
displayName: string;
|
|
33
|
+
};
|
|
34
|
+
export { TH };
|
|
35
|
+
//# sourceMappingURL=th.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"th.d.ts","sourceRoot":"","sources":["../../../src/components/table/th.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAS,KAAK,cAAc,EAAE,KAAK,SAAS,EAAE,MAAM,OAAO,CAAA;AAElE,OAAO,KAAK,EAAE,mBAAmB,EAAE,KAAK,EAAE,MAAM,SAAS,CAAA;AAGzD,MAAM,WAAW,OAAQ,SAAQ,cAAc,CAAC,oBAAoB,CAAC;IACpE;;OAEG;IACH,KAAK,CAAC,EAAE,mBAAmB,CAAA;IAC3B;;OAEG;IACH,KAAK,CAAC,EAAE,KAAK,CAAA;IACb;;;OAGG;IACH,KAAK,CAAC,EAAE,MAAM,CAAA;IACd;;OAEG;IACH,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB;;OAEG;IACH,gBAAgB,CAAC,EAAE,OAAO,CAAA;IAC1B;;OAEG;IACH,QAAQ,EAAE,SAAS,CAAA;CACnB;AAED,QAAA,MAAM,EAAE;uFASL,OAAO;;CAiCT,CAAA;AAID,OAAO,EAAE,EAAE,EAAE,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"th.js","sources":["../../../src/components/table/th.tsx"],"sourcesContent":["import classNames from 'classnames'\nimport { DEFAULT_ALIGNMENT, DEFAULT_SCOPE } from './utils'\nimport { useId, type HTMLAttributes, type ReactNode } from 'react'\nimport { ThButtonTooltip } from './th-button-tooltip'\nimport type { HorizontalAlignment, Scope } from './utils'\nimport s from './table.module.scss'\n\nexport interface THProps extends HTMLAttributes<HTMLTableCellElement> {\n\t/**\n\t * Determines the horizontal content alignment (sometimes referred to as text alignment) for the column header.\n\t */\n\talign?: HorizontalAlignment\n\t/**\n\t * If used as the first item in a table body’s row, scope should be set to row for accessibility purposes.\n\t */\n\tscope?: Scope\n\t/**\n\t * Any valid CSS\n\t * If set, determines the column’s width.\n\t */\n\twidth?: string\n\t/**\n\t * Text string which will appear in the tooltip. May contain basic HTML tags for formatting text such as strong and em tags. Not intended for multi-paragraph text or other more complex content. May not contain interactive content such as links or buttons. The placement and offset are automatically set and can’t be overwritten.\n\t */\n\ttooltip?: string\n\t/**\n\t * If set to `true`, it visually hides the column’s text content (it will still be available to screen readers for accessibility).\n\t */\n\tisVisuallyHidden?: boolean\n\t/**\n\t * Elements passed as children are yielded as inner content of a `<th>` HTML element.\n\t */\n\tchildren: ReactNode\n}\n\nconst TH = ({\n\talign = DEFAULT_ALIGNMENT,\n\twidth,\n\tscope = DEFAULT_SCOPE,\n\ttooltip,\n\tisVisuallyHidden,\n\tchildren,\n\tclassName,\n\t...rest\n}: THProps) => {\n\tconst labelId = useId()\n\tlet content: React.ReactNode\n\n\tif (isVisuallyHidden) {\n\t\tcontent = <span className=\"sr-only\">{children}</span>\n\t} else if (tooltip) {\n\t\tcontent = (\n\t\t\t<div className={s.content}>\n\t\t\t\t<span id={labelId}>{children}</span>\n\t\t\t\t<ThButtonTooltip tooltip={tooltip} labelId={labelId} />\n\t\t\t</div>\n\t\t)\n\t} else {\n\t\tcontent = <div className={s.content}>{children}</div>\n\t}\n\n\treturn (\n\t\t<th\n\t\t\tclassName={classNames(\n\t\t\t\ts.th,\n\t\t\t\ts[`align-${align}`],\n\t\t\t\t'mds-typography-legacy-body-200',\n\t\t\t\t'mds-typography-font-weight-semibold',\n\t\t\t\tclassName,\n\t\t\t)}\n\t\t\tstyle={width ? { width, minWidth: width } : {}}\n\t\t\t{...rest}\n\t\t\tscope={scope}\n\t\t>\n\t\t\t{content}\n\t\t</th>\n\t)\n}\n\nTH.displayName = 'H.TH'\n\nexport { TH }\n"],"names":["TH","align","DEFAULT_ALIGNMENT","width","scope","DEFAULT_SCOPE","tooltip","isVisuallyHidden","children","className","rest","labelId","useId","content","jsx","jsxs","s","ThButtonTooltip","classNames"],"mappings":";;;;;;AAmCA,MAAMA,IAAK,CAAC;AAAA,EACX,OAAAC,IAAQC;AAAA,EACR,OAAAC;AAAA,EACA,OAAAC,IAAQC;AAAA,EACR,SAAAC;AAAA,EACA,kBAAAC;AAAA,EACA,UAAAC;AAAA,EACA,WAAAC;AAAA,EACA,GAAGC;AACJ,MAAe;AACd,QAAMC,IAAUC,EAAA;AAChB,MAAIC;AAEJ,SAAIN,IACHM,IAAU,gBAAAC,EAAC,QAAA,EAAK,WAAU,WAAW,UAAAN,GAAS,IACpCF,IACVO,IACC,gBAAAE,EAAC,OAAA,EAAI,WAAWC,EAAE,SACjB,UAAA;AAAA,IAAA,gBAAAF,EAAC,QAAA,EAAK,IAAIH,GAAU,UAAAH,EAAA,CAAS;AAAA,IAC7B,gBAAAM,EAACG,GAAA,EAAgB,SAAAX,GAAkB,SAAAK,EAAA,CAAkB;AAAA,EAAA,GACtD,IAGDE,IAAU,gBAAAC,EAAC,OAAA,EAAI,WAAWE,EAAE,SAAU,UAAAR,GAAS,GAI/C,gBAAAM;AAAA,IAAC;AAAA,IAAA;AAAA,MACA,WAAWI;AAAA,QACVF,EAAE;AAAA,QACFA,EAAE,SAASf,CAAK,EAAE;AAAA,QAClB;AAAA,QACA;AAAA,QACAQ;AAAA,MAAA;AAAA,MAED,OAAON,IAAQ,EAAE,OAAAA,GAAO,UAAUA,EAAA,IAAU,CAAA;AAAA,MAC3C,GAAGO;AAAA,MACJ,OAAAN;AAAA,MAEC,UAAAS;AAAA,IAAA;AAAA,EAAA;AAGJ;AAEAb,EAAG,cAAc;"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { HTMLAttributes, ReactNode } from 'react';
|
|
2
|
+
export interface TRProps extends HTMLAttributes<HTMLTableRowElement> {
|
|
3
|
+
/**
|
|
4
|
+
* Elements passed as children are yielded as inner content of a `<tr>` HTML element.
|
|
5
|
+
*/
|
|
6
|
+
children: ReactNode;
|
|
7
|
+
}
|
|
8
|
+
declare const TR: {
|
|
9
|
+
({ children, className, ...rest }: TRProps): import("react/jsx-runtime").JSX.Element;
|
|
10
|
+
displayName: string;
|
|
11
|
+
};
|
|
12
|
+
export { TR };
|
|
13
|
+
//# sourceMappingURL=tr.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tr.d.ts","sourceRoot":"","sources":["../../../src/components/table/tr.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AAGtD,MAAM,WAAW,OAAQ,SAAQ,cAAc,CAAC,mBAAmB,CAAC;IACnE;;OAEG;IACH,QAAQ,EAAE,SAAS,CAAA;CACnB;AAED,QAAA,MAAM,EAAE;uCAAsC,OAAO;;CAMpD,CAAA;AAID,OAAO,EAAE,EAAE,EAAE,CAAA"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export declare const DEFAULT_DENSITY = "medium";
|
|
2
|
+
export declare const DENSITIES: readonly ["default", "medium", "short", "tall"];
|
|
3
|
+
export type Density = (typeof DENSITIES)[number];
|
|
4
|
+
export declare const getDensity: (densityStr: string) => Density;
|
|
5
|
+
export declare const DEFAULT_VERTICAL_ALIGNMENT = "top";
|
|
6
|
+
export declare const VERTICAL_ALIGNMENTS: readonly ["baseline", "middle", "top"];
|
|
7
|
+
export type VerticalAlignment = (typeof VERTICAL_ALIGNMENTS)[number];
|
|
8
|
+
export declare const getVerticalAlignment: (valignStr: string) => VerticalAlignment;
|
|
9
|
+
export declare const DEFAULT_ALIGNMENT = "left";
|
|
10
|
+
export declare const ALIGNMENTS: readonly ["left", "center", "right"];
|
|
11
|
+
export type HorizontalAlignment = (typeof ALIGNMENTS)[number];
|
|
12
|
+
export declare const getHorizontalAlignment: (alignStr: string) => HorizontalAlignment;
|
|
13
|
+
export declare const DEFAULT_SCOPE = "col";
|
|
14
|
+
export declare const SCOPES: readonly ["col", "row"];
|
|
15
|
+
export type Scope = (typeof SCOPES)[number];
|
|
16
|
+
export declare const getScope: (scopeStr: string) => Scope;
|
|
17
|
+
//# sourceMappingURL=utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/components/table/utils.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,eAAe,WAAW,CAAA;AACvC,eAAO,MAAM,SAAS,iDAAkD,CAAA;AACxE,MAAM,MAAM,OAAO,GAAG,CAAC,OAAO,SAAS,CAAC,CAAC,MAAM,CAAC,CAAA;AAChD,eAAO,MAAM,UAAU,GAAI,YAAY,MAAM,KAAG,OAG/C,CAAA;AAED,eAAO,MAAM,0BAA0B,QAAQ,CAAA;AAC/C,eAAO,MAAM,mBAAmB,wCAAyC,CAAA;AACzE,MAAM,MAAM,iBAAiB,GAAG,CAAC,OAAO,mBAAmB,CAAC,CAAC,MAAM,CAAC,CAAA;AACpE,eAAO,MAAM,oBAAoB,GAAI,WAAW,MAAM,KAAG,iBAKxD,CAAA;AAED,eAAO,MAAM,iBAAiB,SAAS,CAAA;AACvC,eAAO,MAAM,UAAU,sCAAuC,CAAA;AAC9D,MAAM,MAAM,mBAAmB,GAAG,CAAC,OAAO,UAAU,CAAC,CAAC,MAAM,CAAC,CAAA;AAC7D,eAAO,MAAM,sBAAsB,GAClC,UAAU,MAAM,KACd,mBAGF,CAAA;AAED,eAAO,MAAM,aAAa,QAAQ,CAAA;AAClC,eAAO,MAAM,MAAM,yBAA0B,CAAA;AAC7C,MAAM,MAAM,KAAK,GAAG,CAAC,OAAO,MAAM,CAAC,CAAC,MAAM,CAAC,CAAA;AAC3C,eAAO,MAAM,QAAQ,GAAI,UAAU,MAAM,KAAG,KAG3C,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sources":["../../../src/components/table/utils.ts"],"sourcesContent":["export const DEFAULT_DENSITY = 'medium'\nexport const DENSITIES = ['default', 'medium', 'short', 'tall'] as const\nexport type Density = (typeof DENSITIES)[number]\nexport const getDensity = (densityStr: string): Density => {\n\tconst density = densityStr as Density\n\treturn DENSITIES.includes(density) ? density : DEFAULT_DENSITY\n}\n\nexport const DEFAULT_VERTICAL_ALIGNMENT = 'top'\nexport const VERTICAL_ALIGNMENTS = ['baseline', 'middle', 'top'] as const\nexport type VerticalAlignment = (typeof VERTICAL_ALIGNMENTS)[number]\nexport const getVerticalAlignment = (valignStr: string): VerticalAlignment => {\n\tconst valign = valignStr as VerticalAlignment\n\treturn VERTICAL_ALIGNMENTS.includes(valign)\n\t\t? valign\n\t\t: DEFAULT_VERTICAL_ALIGNMENT\n}\n\nexport const DEFAULT_ALIGNMENT = 'left'\nexport const ALIGNMENTS = ['left', 'center', 'right'] as const\nexport type HorizontalAlignment = (typeof ALIGNMENTS)[number]\nexport const getHorizontalAlignment = (\n\talignStr: string,\n): HorizontalAlignment => {\n\tconst align = alignStr as HorizontalAlignment\n\treturn ALIGNMENTS.includes(align) ? align : DEFAULT_ALIGNMENT\n}\n\nexport const DEFAULT_SCOPE = 'col'\nexport const SCOPES = ['col', 'row'] as const\nexport type Scope = (typeof SCOPES)[number]\nexport const getScope = (scopeStr: string): Scope => {\n\tconst scope = scopeStr as Scope\n\treturn SCOPES.includes(scope) ? scope : DEFAULT_SCOPE\n}\n"],"names":["DEFAULT_DENSITY","DENSITIES","getDensity","densityStr","density","DEFAULT_VERTICAL_ALIGNMENT","VERTICAL_ALIGNMENTS","getVerticalAlignment","valignStr","valign","DEFAULT_ALIGNMENT","ALIGNMENTS","getHorizontalAlignment","alignStr","align","DEFAULT_SCOPE","SCOPES","getScope","scopeStr","scope"],"mappings":"AAAO,MAAMA,IAAkB,UAClBC,IAAY,CAAC,WAAW,UAAU,SAAS,MAAM,GAEjDC,IAAa,CAACC,MAAgC;AAC1D,QAAMC,IAAUD;AAChB,SAAOF,EAAU,SAASG,CAAO,IAAIA,IAAUJ;AAChD,GAEaK,IAA6B,OAC7BC,IAAsB,CAAC,YAAY,UAAU,KAAK,GAElDC,IAAuB,CAACC,MAAyC;AAC7E,QAAMC,IAASD;AACf,SAAOF,EAAoB,SAASG,CAAM,IACvCA,IACAJ;AACJ,GAEaK,IAAoB,QACpBC,IAAa,CAAC,QAAQ,UAAU,OAAO,GAEvCC,IAAyB,CACrCC,MACyB;AACzB,QAAMC,IAAQD;AACd,SAAOF,EAAW,SAASG,CAAK,IAAIA,IAAQJ;AAC7C,GAEaK,IAAgB,OAChBC,IAAS,CAAC,OAAO,KAAK,GAEtBC,IAAW,CAACC,MAA4B;AACpD,QAAMC,IAAQD;AACd,SAAOF,EAAO,SAASG,CAAK,IAAIA,IAAQJ;AACzC;"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { type ReactNode, type HTMLAttributes, type MouseEvent } from 'react';
|
|
2
|
+
export interface TabsProps extends HTMLAttributes<HTMLDivElement> {
|
|
3
|
+
onClickTab?: (event: MouseEvent<HTMLButtonElement>, tabIndex: number) => void;
|
|
4
|
+
initialSelectedTabIndex?: number;
|
|
5
|
+
size?: 'medium' | 'large';
|
|
6
|
+
}
|
|
7
|
+
interface TabsListProps {
|
|
8
|
+
/**
|
|
9
|
+
* `<Tabs.Tab />` as children
|
|
10
|
+
*/
|
|
11
|
+
children: ReactNode;
|
|
12
|
+
className?: string;
|
|
13
|
+
}
|
|
14
|
+
declare const Tabs: {
|
|
15
|
+
Provider: ({ children, onClickTab, initialSelectedTabIndex, size, className, ...rest }: TabsProps) => import("react/jsx-runtime").JSX.Element;
|
|
16
|
+
TabList: ({ children, className }: TabsListProps) => import("react/jsx-runtime").JSX.Element;
|
|
17
|
+
Panel: ({ children, className, ...rest }: import("./tab-panel").TabPanelProps) => import("react/jsx-runtime").JSX.Element;
|
|
18
|
+
Tab: ({ count, icon, isSelected: isInitialTab, children, className, trackingKey, tabIndicatorTheme, ...rest }: import("./tab").TabProps) => import("react/jsx-runtime").JSX.Element;
|
|
19
|
+
};
|
|
20
|
+
export type { TabsListProps };
|
|
21
|
+
export { Tabs };
|
|
22
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/tabs/index.tsx"],"names":[],"mappings":"AAGA,OAAO,EACN,KAAK,SAAS,EACd,KAAK,cAAc,EAEnB,KAAK,UAAU,EAMf,MAAM,OAAO,CAAA;AAMd,MAAM,WAAW,SAAU,SAAQ,cAAc,CAAC,cAAc,CAAC;IAChE,UAAU,CAAC,EAAE,CAAC,KAAK,EAAE,UAAU,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,MAAM,KAAK,IAAI,CAAA;IAC7E,uBAAuB,CAAC,EAAE,MAAM,CAAA;IAChC,IAAI,CAAC,EAAE,QAAQ,GAAG,OAAO,CAAA;CACzB;AA4JD,UAAU,aAAa;IACtB;;OAEG;IACH,QAAQ,EAAE,SAAS,CAAA;IACnB,SAAS,CAAC,EAAE,MAAM,CAAA;CAClB;AAcD,QAAA,MAAM,IAAI;4FAvKP,SAAS;uCA2J8B,aAAa;;;CAYC,CAAA;AAExD,YAAY,EAAE,aAAa,EAAE,CAAA;AAC7B,OAAO,EAAE,IAAI,EAAE,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../src/components/tabs/index.tsx"],"sourcesContent":["'use client'\n\nimport classNames from 'classnames'\nimport {\n\ttype ReactNode,\n\ttype HTMLAttributes,\n\ttype KeyboardEvent,\n\ttype MouseEvent,\n\tuseState,\n\tuseMemo,\n\tuseRef,\n\tuseEffect,\n\tuseCallback,\n} from 'react'\nimport { TabPanel } from './tab-panel'\nimport { Tab } from './tab'\nimport { TabsContext, useTabsContext } from './use-tabs-context'\nimport s from './tabs.module.scss'\n\nexport interface TabsProps extends HTMLAttributes<HTMLDivElement> {\n\tonClickTab?: (event: MouseEvent<HTMLButtonElement>, tabIndex: number) => void\n\tinitialSelectedTabIndex?: number\n\tsize?: 'medium' | 'large'\n}\n\nconst Provider = ({\n\tchildren,\n\tonClickTab,\n\tinitialSelectedTabIndex = 0,\n\tsize = 'medium',\n\tclassName,\n\t...rest\n}: TabsProps) => {\n\tconst [selectedTabIndex, setSelectedTabIndex] = useState(\n\t\tinitialSelectedTabIndex,\n\t)\n\tconst tabNodes = useRef<Array<HTMLButtonElement>>([])\n\tconst panelNodes = useRef<Array<HTMLDivElement>>([])\n\tconst [tabIds, setTabIds] = useState<Array<string>>([])\n\tconst [panelIds, setPanelIds] = useState<Array<string>>([])\n\tconst [indicatorWidth, setIndicatorWidth] = useState(0)\n\tconst [indicatorLeftPosition, setIndicatorLeftPosition] = useState(0)\n\tconst tabsListRef = useRef<HTMLUListElement | null>(null)\n\n\tconst scrollIntoView = useCallback((tabIndex: number) => {\n\t\t// Scroll Tab into view if it's out of view\n\t\tconst parentNode = tabNodes.current[tabIndex]\n\t\t\t?.parentNode as HTMLElement | null\n\t\tif (parentNode) {\n\t\t\tparentNode.scrollIntoView({\n\t\t\t\tbehavior: 'smooth',\n\t\t\t\tblock: 'nearest',\n\t\t\t\tinline: 'nearest',\n\t\t\t})\n\t\t}\n\t}, [])\n\n\tuseEffect(() => {\n\t\tsetSelectedTabIndex(initialSelectedTabIndex)\n\t}, [initialSelectedTabIndex])\n\n\tuseEffect(() => {\n\t\tconst tabElem = tabNodes.current[selectedTabIndex]?.parentElement\n\t\tif (tabElem && tabsListRef.current) {\n\t\t\tconst tabLeftPos = tabElem.offsetLeft\n\t\t\tconst tabWidth = tabElem.offsetWidth\n\t\t\tsetIndicatorLeftPosition(tabLeftPos)\n\t\t\tsetIndicatorWidth(tabWidth)\n\t\t\ttabsListRef.current.scrollTo({\n\t\t\t\tleft: tabLeftPos,\n\t\t\t\tbehavior: 'smooth',\n\t\t\t})\n\t\t}\n\t}, [tabNodes, selectedTabIndex, scrollIntoView, tabsListRef])\n\n\tuseEffect(() => {\n\t\tsetTabIds(tabNodes.current.map((tab) => tab.id))\n\n\t\tlet selectedCount = 0\n\n\t\ttabNodes.current.forEach((tabElement) => {\n\t\t\tif (tabElement.hasAttribute('data-is-selected')) {\n\t\t\t\tselectedCount++\n\t\t\t}\n\t\t})\n\n\t\tif (selectedCount > 1) {\n\t\t\tconsole.error('Only one tab may use isSelected argument')\n\t\t}\n\t}, [tabNodes])\n\n\tuseEffect(() => {\n\t\tsetPanelIds(panelNodes.current.map((tab) => tab.id))\n\t}, [panelNodes])\n\n\tconst onClick = useCallback(\n\t\t(tabIndex: number, event: MouseEvent<HTMLButtonElement>) => {\n\t\t\tsetSelectedTabIndex(tabIndex)\n\n\t\t\tscrollIntoView(tabIndex)\n\n\t\t\t// invoke the callback function if it's provided as argument\n\t\t\tif (typeof onClickTab === 'function') {\n\t\t\t\tonClickTab(event, tabIndex)\n\t\t\t}\n\t\t},\n\t\t[onClickTab, scrollIntoView],\n\t)\n\n\t// Focus tab for keyboard & mouse navigation:\n\tconst focusTab = useCallback(\n\t\t(tabIndex: number, e: KeyboardEvent<HTMLButtonElement>) => {\n\t\t\te.preventDefault()\n\t\t\ttabNodes.current[tabIndex].focus()\n\t\t},\n\t\t[],\n\t)\n\n\tconst onKeyUp = useCallback(\n\t\t(tabIndex: number, e: KeyboardEvent<HTMLButtonElement>) => {\n\t\t\tconst leftArrow = 'ArrowLeft'\n\t\t\tconst rightArrow = 'ArrowRight'\n\t\t\tconst enterKey = 'Enter'\n\t\t\tconst spaceKey = ' '\n\n\t\t\tif (e.key === rightArrow) {\n\t\t\t\tconst nextTabIndex = (tabIndex + 1) % tabIds.length\n\t\t\t\tfocusTab(nextTabIndex, e)\n\t\t\t} else if (e.key === leftArrow) {\n\t\t\t\tconst prevTabIndex = (tabIndex + tabIds.length - 1) % tabIds.length\n\t\t\t\tfocusTab(prevTabIndex, e)\n\t\t\t} else if (e.key === enterKey || e.key === spaceKey) {\n\t\t\t\tsetSelectedTabIndex(tabIndex)\n\t\t\t}\n\t\t},\n\t\t[focusTab, tabIds.length],\n\t)\n\n\tconst contextValue = useMemo(\n\t\t() => ({\n\t\t\ttabNodes,\n\t\t\ttabIds,\n\t\t\tpanelNodes,\n\t\t\tpanelIds,\n\t\t\tselectedTabIndex,\n\t\t\tonClick,\n\t\t\tonKeyUp,\n\t\t\tsize,\n\t\t\ttabsListRef,\n\t\t}),\n\t\t[\n\t\t\ttabNodes,\n\t\t\ttabIds,\n\t\t\tpanelNodes,\n\t\t\tpanelIds,\n\t\t\tselectedTabIndex,\n\t\t\tonClick,\n\t\t\tonKeyUp,\n\t\t\tsize,\n\t\t\ttabsListRef,\n\t\t],\n\t)\n\n\treturn (\n\t\t<TabsContext.Provider value={contextValue}>\n\t\t\t<div\n\t\t\t\tclassName={classNames(s.tabs, className)}\n\t\t\t\t{...rest}\n\t\t\t\tstyle={{\n\t\t\t\t\t['--indicator-left-pos' as string]: `${indicatorLeftPosition}px`,\n\t\t\t\t\t['--indicator-width' as string]: `${indicatorWidth}px`,\n\t\t\t\t}}\n\t\t\t>\n\t\t\t\t{children}\n\t\t\t</div>\n\t\t</TabsContext.Provider>\n\t)\n}\n\ninterface TabsListProps {\n\t/**\n\t * `<Tabs.Tab />` as children\n\t */\n\tchildren: ReactNode\n\tclassName?: string\n}\n\nconst TabList = ({ children, className }: TabsListProps) => {\n\tconst { tabsListRef } = useTabsContext()\n\treturn (\n\t\t<div className={classNames(s['tablist-wrapper'], className)}>\n\t\t\t<ul className={s.tablist} role=\"tablist\" ref={tabsListRef}>\n\t\t\t\t{children}\n\t\t\t\t<li className={s.indicator} role=\"presentation\"></li>\n\t\t\t</ul>\n\t\t</div>\n\t)\n}\n\nconst Tabs = { Provider, TabList, Panel: TabPanel, Tab }\n\nexport type { TabsListProps }\nexport { Tabs }\n"],"names":["Provider","children","onClickTab","initialSelectedTabIndex","size","className","rest","selectedTabIndex","setSelectedTabIndex","useState","tabNodes","useRef","panelNodes","tabIds","setTabIds","panelIds","setPanelIds","indicatorWidth","setIndicatorWidth","indicatorLeftPosition","tabsListRef","scrollIntoView","useCallback","tabIndex","parentNode","useEffect","tabElem","tabLeftPos","tabWidth","setIndicatorLeftPosition","tab","selectedCount","onClick","event","focusTab","onKeyUp","leftArrow","rightArrow","enterKey","spaceKey","nextTabIndex","prevTabIndex","contextValue","useMemo","jsx","TabsContext","classNames","s","jsxs"],"mappings":";;;;;;;;AAyBkB,MACjBA,IAAA,CAAA;AAAA,EACA,UAAAC;AAAA,EACA,YAAAC;AAAA,EACA,yBAAAC,IAAO;AAAA,EACP,MAAAC,IAAA;AAAA,EACA,WAAAC;AAAA,EACD,GAAAC;AACC;AAAgD,QAC/C,CAAAC,GAAAC,CAAA,IAAAC;AAAA,IACDN;AAAA,EACA,GACMO,IAAAC,EAAa,CAAA,CAA8B,GAC3CC,IAASD,EAAS,CAAA,CAAI,GACtB,CAACE,GAAAC,CAAU,IAAWL,EAAI,CAAA,CAAA,GAC1B,CAACM,GAAAC,CAAgB,IAAAP,EAAiB,CAAA,CAAA,GAClC,CAACQ,GAAAC,CAAuB,IAAAT,EAAA,CAAwB,GAChD,CAAAU,IAAkD,IAAAV,EAAA,CAAA,GAElDW,IAAAT,SAELU,IAAmBC,SAChB;AACH,cAAgBZ,EAAA,QAAAa,CAAA,GAAA;AACf,IAAAC,KAA0BA,iBACf;AAAA,MACV,UAAO;AAAA,MACP,OAAA;AAAA,MACA,QAAA;AAAA,IACF,CAAA;AAAA,EAGD,GAAA,CAAA,CAAA;AACC,EAAAC,EAAA,MAAA;AACD,IAAAjB,EAAIL,CAAwB;AAAA,EAE5B,GAAA,CAAAA,CAAgB,CAAA,GACfsB,EAAM,MAAA;AACN,UAAIC,IAAWhB,EAAA,SAAqB,GAAA;AACnC,QAAAgB,KAAMN,EAAa,SAAQ;AAC3B,YAAMO,IAAWD,EAAQ,YACzBE,IAAAF,EAAyB;AACzB,MAAAG,EAAkBF,CAAQ,GAC1BT,EAAYU,IAAiBR,EACtB,QAAA,SAAA;AAAA,QACN;QACA,UAAA;AAAA,MACF,CAAA;AAAA;EAGD,GAAA,CAAAV,GAAUH,GAAMc,GAAAD,CAAA,CAAA,GACfK,EAAA,MAAU;AAEV,IAAAX,EAAIJ,EAAA,QAAgB,IAAA,CAAAoB,MAAAA,EAAA,EAAA,CAAA;AAEpB,QAAAC;AACC,IAAArB,EAAI,QAAW,eAAa;AAC3B,QAAA,aAAA,kBAAA,KACDqB;AAAA,IAGD,CAAA,GACCA,SACD,QAAA,MAAA,0CAAA;AAAA,EAGD,GAAA,CAAArB,CAAU,CAAA,GACTe,EAAA,MAAY;AACb,IAAAT,EAAcJ,EAAC,QAAA,IAAA,CAAAkB,MAAAA,EAAA,EAAA,CAAA;AAAA,EAEf,GAAA,CAAAlB,CAAM,CAAA;AAAU,QACdoB,IAAkBV;AAAA,IAClB,CAAAC,GAAAU,MAAA;AAEA,MAAAzB,EAAee,CAAQ,GAGvBF,EAAWE,IACV,OAAArB,mBACDA,EAAA+B,GAAAV,CAAA;AAAA,IAED;AAAA,IACD,CAAArB,GAAAmB,CAAA;AAAA,EAGA,GACEa,IAAkBZ;AAAA,IAClB,CAAAC,GAAE,MAAA;AACF,QAAA,eAAiB,GAClBb,EAAA,QAAAa,CAAA,EAAA,MAAA;AAAA,IACA;AAAA,IACD,CAAA;AAAA,EAEA,GACEY,IAAkBb;AAAA,IAClB,CAAAC,GAAM,MAAA;AACN,YAAMa,IAAA,aACAC,IAAW,cACXC,IAAW,SAEXC;AACL,UAAA,EAAA,QAAMF,GAAgB;AACtB,cAAAG,SAAwB,KAAA3B,EAAA;UACd2B;MACV,WAAM,EAAA,QAAAJ,GAAgB;AACtB,cAAAK,SAAwB5B,EAAA,SAAA,KAAAA,EAAA;UACd4B,GAAU,CAAA;AAAA,MACpB,MAAA,EAAA,EAAA,QAAAH,KAA4B,EAAA,QAAAC,MAC7B/B,EAAAe,CAAA;AAAA,IAED;AAAA,IACD,CAAAW,GAAArB,EAAA,MAAA;AAAA,EAEA,GACC6B,IAAOC;AAAA,IAAA,OACN;AAAA,MACA,UAAAjC;AAAA,MACA,QAAAG;AAAA,MACA,YAAAD;AAAA,MACA,UAAAG;AAAA,MACA,kBAAAR;AAAA,MACA,SAAAyB;AAAA,MACA,SAAAG;AAAA,MACA,MAAA/B;AAAA,MACD,aAAAgB;AAAA,IACA;AAAA,IAAA;AAAA,MAECV;AAAA,MACAG;AAAA,MACAD;AAAA,MACAG;AAAA,MACAR;AAAA,MACAyB;AAAA,MACAG;AAAA,MACA/B;AAAA,MAAAgB;AAAA,IAEF;AAAA,EAEA;AAEE,SAAC,gBAAAwB,EAAAC,EAAA,UAAA,EAAA,OAAAH,GAAA,UAAA,gBAAAE;AAAA,IAAA;AAAA,IAAA;AAAA,MAEC,WAAGE,EAAAC,EAAA,MAAA1C,CAAA;AAAA,MACJ;MAAO;QAEL,wBAAmC,GAAAc,CAAc;AAAA,QACnD,qBAAA,GAAAF,CAAA;AAAA,MAEC;AAAA,MAAA,UAAAhB;AAAA;EAIL,EAAA,CAAA;AAUA,OACS,CAAA,EAAA,UAAAA,sBAA+B;AACvC;AAGI,SAAA,gBAAA2C,EAAA,OAAA,EAAA,WAAAE,EAAAC,EAAA,iBAAA,GAAA1C,CAAA,GAAA,UAAA,gBAAA2C,EAAA,MAAA,EAAA,WAAAD,EAAA,SAAA,MAAA,WAAA,KAAA3B,GAAA,UAAA;AAAA,IAAAnB;AAAA,IAGH,gBAAA2C,EAAA,MAAA,EAAA,WAAAG,EAAA,WAAA,MAAA,eAAA,CAAA;AAAA,EAEF,EAAA,CAAA,EAAA,CAAA;AAEA;"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { type HTMLAttributes } from 'react';
|
|
2
|
+
type TabPanelProps = HTMLAttributes<HTMLDivElement>;
|
|
3
|
+
declare const TabPanel: ({ children, className, ...rest }: TabPanelProps) => import("react/jsx-runtime").JSX.Element;
|
|
4
|
+
export type { TabPanelProps };
|
|
5
|
+
export { TabPanel };
|
|
6
|
+
//# sourceMappingURL=tab-panel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tab-panel.d.ts","sourceRoot":"","sources":["../../../src/components/tabs/tab-panel.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAkB,KAAK,cAAc,EAAE,MAAM,OAAO,CAAA;AAK3D,KAAK,aAAa,GAAG,cAAc,CAAC,cAAc,CAAC,CAAA;AAEnD,QAAA,MAAM,QAAQ,GAAI,kCAAkC,aAAa,4CAgChE,CAAA;AAED,YAAY,EAAE,aAAa,EAAE,CAAA;AAC7B,OAAO,EAAE,QAAQ,EAAE,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tab-panel.js","sources":["../../../src/components/tabs/tab-panel.tsx"],"sourcesContent":["'use client'\n\nimport { useId, useMemo, type HTMLAttributes } from 'react'\nimport classNames from 'classnames'\nimport { useTabsContext } from './use-tabs-context'\nimport s from './tabs.module.scss'\n\ntype TabPanelProps = HTMLAttributes<HTMLDivElement>\n\nconst TabPanel = ({ children, className, ...rest }: TabPanelProps) => {\n\tconst { panelIds, tabIds, selectedTabIndex, panelNodes } = useTabsContext()\n\tconst panelId = 'panel-' + useId()\n\n\tconst nodeIndex = useMemo(\n\t\t() => panelIds.indexOf(panelId),\n\t\t[panelIds, panelId],\n\t)\n\n\tconst tabId = useMemo(\n\t\t() => (nodeIndex > -1 ? tabIds[nodeIndex] : undefined),\n\t\t[tabIds, nodeIndex],\n\t)\n\n\tconst isSelected = useMemo(\n\t\t() => nodeIndex === selectedTabIndex,\n\t\t[nodeIndex, selectedTabIndex],\n\t)\n\n\treturn (\n\t\t<section\n\t\t\tclassName={classNames(s.panel, className)}\n\t\t\t{...rest}\n\t\t\trole=\"tabpanel\"\n\t\t\taria-labelledby={tabId}\n\t\t\tid={panelId}\n\t\t\thidden={!isSelected}\n\t\t\tref={(el: HTMLDivElement) => panelNodes.current.push(el)}\n\t\t>\n\t\t\t{children}\n\t\t</section>\n\t)\n}\n\nexport type { TabPanelProps }\nexport { TabPanel }\n"],"names":["TabPanel","children","className","rest","panelIds","tabIds","panelNodes","useTabsContext","panelId","useId","useMemo","tabId","nodeIndex","isSelected","selectedTabIndex","jsx","classNames","s","el"],"mappings":";;;;;;AAUC,MAAAA,IAAQ,CAAA,EAAU,UAAAC,GAAQ,WAAAC,GAAA,GAAAC,EAAkB,MAAA;AAC5C,QAAM,EAAA,UAAAC,GAAU,QAAAC,wBAAiB,YAAAC,EAAA,IAAAC,EAAA,GAE3BC,IAAA,WAAYC,EAAA,OACFC;AAAA,IACf,MAACN,EAAU,QAAOI,CAAA;AAAA,IACnB,CAAAJ,GAAAI,CAAA;AAAA,EAEA,GACCG,IAAOD;AAAA,IACP,MAACE,IAAiB,KAAAP,EAAAO,CAAA,IAAA;AAAA,IACnB,CAAAP,GAAAO,CAAA;AAAA,EAEA,GACCC,IAAMH;AAAA,IACN,MAACE,MAAWE;AAAA,IACb,CAAAF,GAAAE,CAAA;AAAA,EAEA;AACC,SAAC,gBAAAC;AAAA,IAAA;AAAA,IAAA;AAAA,MAEC,WAAGC,EAAAC,EAAA,OAAAf,CAAA;AAAA,MACJ,GAAAC;AAAA,MACA,MAAA;AAAA,MACA,mBAAIQ;AAAA,MACJ,IAAAH;AAAA,MACA,QAAM,CAAAK;AAAA,MAEL,KAAA,CAAAK,MAAAZ,EAAA,QAAA,KAAAY,CAAA;AAAA,MAAA,UAAAjB;AAAA,IACF;AAAA,EAEF;;"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { type HTMLAttributes } from 'react';
|
|
2
|
+
import type { FlightIconName } from '../flight-icon';
|
|
3
|
+
interface TabProps extends HTMLAttributes<HTMLLIElement> {
|
|
4
|
+
tabIndicatorTheme?: 'primary' | 'secondary';
|
|
5
|
+
/**
|
|
6
|
+
* Displays a count indicator in the tab. Accepts the text value that should go in Badge Count. (optional)
|
|
7
|
+
*/
|
|
8
|
+
count?: string;
|
|
9
|
+
/**
|
|
10
|
+
* Displays an icon in the tab. (optional)
|
|
11
|
+
*/
|
|
12
|
+
icon?: FlightIconName;
|
|
13
|
+
/**
|
|
14
|
+
* Customizes the initial tab to display when the page is loaded. The first tab is selected on page load by default. (optional)
|
|
15
|
+
*/
|
|
16
|
+
isSelected?: boolean;
|
|
17
|
+
/**
|
|
18
|
+
* Used to append analytics and tracking related data attributes to any interactive element internal to this component.
|
|
19
|
+
*/
|
|
20
|
+
trackingKey?: string;
|
|
21
|
+
}
|
|
22
|
+
declare const Tab: ({ count, icon, isSelected: isInitialTab, children, className, trackingKey, tabIndicatorTheme, ...rest }: TabProps) => import("react/jsx-runtime").JSX.Element;
|
|
23
|
+
export type { TabProps };
|
|
24
|
+
export { Tab };
|
|
25
|
+
//# sourceMappingURL=tab.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tab.d.ts","sourceRoot":"","sources":["../../../src/components/tabs/tab.tsx"],"names":[],"mappings":"AAIA,OAAO,EAAS,KAAK,cAAc,EAAW,MAAM,OAAO,CAAA;AAE3D,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAIpD,UAAU,QAAS,SAAQ,cAAc,CAAC,aAAa,CAAC;IACvD,iBAAiB,CAAC,EAAE,SAAS,GAAG,WAAW,CAAA;IAC3C;;OAEG;IACH,KAAK,CAAC,EAAE,MAAM,CAAA;IACd;;OAEG;IACH,IAAI,CAAC,EAAE,cAAc,CAAA;IACrB;;OAEG;IACH,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB;;OAEG;IACH,WAAW,CAAC,EAAE,MAAM,CAAA;CACpB;AAED,QAAA,MAAM,GAAG,GAAI,yGASV,QAAQ,4CAqDV,CAAA;AAED,YAAY,EAAE,QAAQ,EAAE,CAAA;AACxB,OAAO,EAAE,GAAG,EAAE,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tab.js","sources":["../../../src/components/tabs/tab.tsx"],"sourcesContent":["'use client'\n\nimport classNames from 'classnames'\nimport { BadgeCount } from '../badge-count'\nimport { useId, type HTMLAttributes, useMemo } from 'react'\nimport { useTabsContext } from './use-tabs-context'\nimport type { FlightIconName } from '../flight-icon'\nimport { FlightIcon } from '../flight-icon'\nimport s from './tabs.module.scss'\n\ninterface TabProps extends HTMLAttributes<HTMLLIElement> {\n\ttabIndicatorTheme?: 'primary' | 'secondary'\n\t/**\n\t * Displays a count indicator in the tab. Accepts the text value that should go in Badge Count. (optional)\n\t */\n\tcount?: string\n\t/**\n\t * Displays an icon in the tab. (optional)\n\t */\n\ticon?: FlightIconName\n\t/**\n\t * Customizes the initial tab to display when the page is loaded. The first tab is selected on page load by default. (optional)\n\t */\n\tisSelected?: boolean\n\t/**\n\t * Used to append analytics and tracking related data attributes to any interactive element internal to this component.\n\t */\n\ttrackingKey?: string\n}\n\nconst Tab = ({\n\tcount,\n\ticon,\n\tisSelected: isInitialTab,\n\tchildren,\n\tclassName,\n\ttrackingKey,\n\ttabIndicatorTheme = 'primary',\n\t...rest\n}: TabProps) => {\n\tconst { tabNodes, tabIds, selectedTabIndex, onClick, onKeyUp, size } =\n\t\tuseTabsContext()\n\tconst tabId = 'tab-' + useId()\n\n\tconst nodeIndex = useMemo(() => tabIds.indexOf(tabId), [tabIds, tabId])\n\n\tconst isSelected = useMemo(\n\t\t() => nodeIndex === selectedTabIndex,\n\t\t[nodeIndex, selectedTabIndex],\n\t)\n\n\treturn (\n\t\t<li\n\t\t\tclassName={classNames(\n\t\t\t\ts.tab,\n\t\t\t\ts[tabIndicatorTheme],\n\t\t\t\t{\n\t\t\t\t\t[s.selected]: isSelected,\n\t\t\t\t},\n\t\t\t\tclassName,\n\t\t\t)}\n\t\t\t{...rest}\n\t\t\trole=\"presentation\"\n\t\t>\n\t\t\t<button\n\t\t\t\tclassName={classNames(\n\t\t\t\t\ts['tab-button'],\n\t\t\t\t\t'mds-typography-font-weight-medium',\n\t\t\t\t\t{\n\t\t\t\t\t\t['mds-typography-legacy-body-200']: size === 'medium',\n\t\t\t\t\t\t['mds-typography-legacy-body-300']: size === 'large',\n\t\t\t\t\t},\n\t\t\t\t)}\n\t\t\t\trole=\"tab\"\n\t\t\t\ttype=\"button\"\n\t\t\t\tid={tabId}\n\t\t\t\taria-selected={isSelected}\n\t\t\t\ttabIndex={!isSelected ? -1 : undefined}\n\t\t\t\tonClick={(e) => onClick(nodeIndex, e)}\n\t\t\t\tonKeyUp={(e) => onKeyUp(nodeIndex, e)}\n\t\t\t\tdata-is-selected={isInitialTab}\n\t\t\t\tdata-analytics={trackingKey}\n\t\t\t\tref={(el: HTMLButtonElement) => tabNodes.current.push(el)}\n\t\t\t>\n\t\t\t\t{icon && <FlightIcon name={icon} size={16} role=\"presentation\" />}\n\n\t\t\t\t{children}\n\n\t\t\t\t{count && <BadgeCount text={count} size=\"small\" role=\"presentation\" />}\n\t\t\t</button>\n\t\t</li>\n\t)\n}\n\nexport type { TabProps }\nexport { Tab }\n"],"names":["Tab","count","icon","isInitialTab","children","className","trackingKey","tabIndicatorTheme","rest","tabNodes","tabIds","onClick","onKeyUp","size","useTabsContext","tabId","nodeIndex","useMemo","isSelected","selectedTabIndex","jsx","classNames","s","jsxs","el","FlightIcon","BadgeCount"],"mappings":";;;;;;;;AA8Ba,MACZA,IAAA,CAAA;AAAA,EACA,OAAAC;AAAA,EACA,MAAAC;AAAA,EACA,YAAAC;AAAA,EACA,UAAAC;AAAA,EACA,WAAAC;AAAA,EACA,aAAAC;AAAA,EACA,mBAAAC,IAAG;AAAA,EACJ,GAAAC;AACC;AAEA,QAAM,EAAA,UAAAC,GAAQ,QAAAC,wBAAe,SAAAC,GAAA,SAAAC,GAAA,MAAAC,EAAA,IAAAC,EAAA,GAEvBC,IAAA,WAAoB,GAEpBC,IAAAC,EAAa,MAAAP,EAAA,QAAAK,CAAA,GAAA,CAAAL,GAAAK,CAAA,CAAA,GAClBG,IAAMD;AAAA,IACN,MAACD,MAAWG;AAAA,IACb,CAAAH,GAAAG,CAAA;AAAA,EAEA;AACC,SAAC,gBAAAC;AAAA,IAAA;AAAA,IAAA;AAAA,MACW,WACRC;AAAA,QACFC,EAAE;AAAA,QACFA,EAAAf,CAAA;AAAA,QAAA;AAAA,UAEA,CAAAe,EAAA,QAAA,GAAAJ;AAAA,QACA;AAAA,QACDb;AAAA,MACC;AAAA,MACD,GAAAG;AAAA,MAEA,MAAA;AAAA,MAAA,UAAC,gBAAAe;AAAA,QAAA;AAAA,QAAA;AAAA,UACW,WACRF;AAAA,YACFC,EAAA,YAAA;AAAA,YACA;AAAA,YAAA;AAAA,cAEE,kCAAmCT,MAAS;AAAA,cAAA,kCAAAA,MAAA;AAAA,YAE/C;AAAA,UACA;AAAA,UACA,MAAK;AAAA,UACL,MAAI;AAAA,UACJ,IAAAE;AAAA,UACA;UACA,UAAUG,IAAc,SAAA;AAAA,UACxB,SAAS,CAAC,MAAMP,EAAQK,GAAW,CAAC;AAAA,UACpC,SAAA,CAAA,MAAAJ,EAAkBI,GAAA,CAAA;AAAA,UAClB,oBAAgBb;AAAA,UAChB,kBAAgCG;AAAA,UAE/B,YAAAG,EAAA,QAAA,KAAAe,CAAA;AAAA,UAAA,UAAA;AAAA,YAEAtB,KAAA,gBAAAkB,EAAAK,GAAA,EAAA,MAAAvB,GAAA,MAAA,IAAA,MAAA,eAAA,CAAA;AAAA,YAEAE;AAAA,YAAmEH,KAAA,gBAAAmB,EAAAM,GAAA,EAAA,MAAAzB,GAAA,MAAA,SAAA,MAAA,eAAA,CAAA;AAAA,UAAA;AAAA,QAAA;AAAA,MACrE;AAAA,IACD;AAAA,EAEF;;"}
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
@use 'styles/mixins/focus-ring' as *;
|
|
2
|
+
|
|
3
|
+
.tablist-wrapper {
|
|
4
|
+
position: relative;
|
|
5
|
+
|
|
6
|
+
// bottom gray border:
|
|
7
|
+
&::before {
|
|
8
|
+
position: absolute;
|
|
9
|
+
right: 0;
|
|
10
|
+
bottom: calc((var(--mds-tabs-indicator-height) - var(--mds-tabs-divider-height)) / 2);
|
|
11
|
+
left: 0;
|
|
12
|
+
display: block;
|
|
13
|
+
border-top: var(--mds-tabs-divider-height) solid var(--mds-color-border-primary);
|
|
14
|
+
content: '';
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
.tablist {
|
|
19
|
+
position: relative;
|
|
20
|
+
display: flex;
|
|
21
|
+
margin: 0;
|
|
22
|
+
padding: 0;
|
|
23
|
+
overflow-x: auto;
|
|
24
|
+
-webkit-overflow-scrolling: touch;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
.tab {
|
|
28
|
+
position: relative;
|
|
29
|
+
display: flex;
|
|
30
|
+
align-items: center;
|
|
31
|
+
height: var(--mds-tabs-tab-height-medium);
|
|
32
|
+
margin: 0;
|
|
33
|
+
padding: var(--mds-tabs-tab-padding-vertical) var(--mds-tabs-tab-padding-horizontal-medium);
|
|
34
|
+
white-space: nowrap;
|
|
35
|
+
text-decoration: none;
|
|
36
|
+
list-style: none;
|
|
37
|
+
|
|
38
|
+
&.primary {
|
|
39
|
+
color: var(--mds-accent-tab-color-foreground, var(--mds-color-foreground-primary));
|
|
40
|
+
|
|
41
|
+
&:hover {
|
|
42
|
+
color: var(--mds-accent-tab-color-foreground-hover, var(--mds-accent-tab-color-foreground, var(--mds-color-foreground-action)));
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
&.selected {
|
|
46
|
+
color: var(--mds-accent-tab-selected-color-foreground, var(--mds-accent-tab-color-foreground, var(--mds-color-foreground-action)));
|
|
47
|
+
|
|
48
|
+
&:hover {
|
|
49
|
+
color: var(--mds-accent-tab-selected-color-foreground-hover, var(--mds-accent-tab-selected-color-foreground, var(--mds-accent-tab-color-foreground, var(--mds-color-foreground-action-hover))));
|
|
50
|
+
|
|
51
|
+
& ~ .indicator {
|
|
52
|
+
background: var(--mds-accent-tab-indicator-color, var(--mds-color-foreground-action-hover));
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
&.secondary {
|
|
59
|
+
color: var(--mds-color-foreground-faint);
|
|
60
|
+
|
|
61
|
+
&:hover {
|
|
62
|
+
color: var(--mds-color-foreground-strong);
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
&.selected {
|
|
66
|
+
color: var(--mds-color-foreground-strong);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
& ~ .indicator {
|
|
70
|
+
background: var(--mds-accent-tab-indicator-color, var(--mds-color-foreground-strong));
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
.tab-button {
|
|
76
|
+
@include hds-focus-ring-with-pseudo-element($top: var(--mds-tabs-tab-focus-inset), $right: var(--mds-tabs-tab-focus-inset), $bottom: var(--mds-tabs-tab-focus-inset), $left: var(--mds-tabs-tab-focus-inset));
|
|
77
|
+
position: static;
|
|
78
|
+
display: flex;
|
|
79
|
+
gap: var(--mds-tabs-tab-gutter);
|
|
80
|
+
align-items: center;
|
|
81
|
+
padding: 0;
|
|
82
|
+
color: inherit;
|
|
83
|
+
background-color: transparent;
|
|
84
|
+
border: none;
|
|
85
|
+
border-radius: var(--mds-tabs-tab-border-radius);
|
|
86
|
+
cursor: pointer;
|
|
87
|
+
|
|
88
|
+
// Expand click target area
|
|
89
|
+
&::after {
|
|
90
|
+
position: absolute;
|
|
91
|
+
content: '';
|
|
92
|
+
inset: 0;
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
.indicator {
|
|
97
|
+
position: absolute;
|
|
98
|
+
right: 0;
|
|
99
|
+
bottom: 0;
|
|
100
|
+
// notice: this custom prop is set dynamically via JavaScript
|
|
101
|
+
left: var(--indicator-left-pos);
|
|
102
|
+
z-index: 10;
|
|
103
|
+
display: block;
|
|
104
|
+
// notice: this custom prop is set dynamically via JavaScript
|
|
105
|
+
width: var(--indicator-width);
|
|
106
|
+
height: var(--mds-tabs-indicator-height);
|
|
107
|
+
background: var(--mds-accent-tab-indicator-color, var(--mds-color-foreground-action));
|
|
108
|
+
border-radius: var(--mds-tabs-indicator-height);
|
|
109
|
+
|
|
110
|
+
@media screen and (prefers-reduced-motion: no-preference) {
|
|
111
|
+
transition-timing-function: var(--mds-tabs-indicator-transition-function);
|
|
112
|
+
transition-duration: var(--mds-tabs-indicator-transition-duration);
|
|
113
|
+
transition-property: left, width;
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
// Prevent consumers from accidentally overriding default styling of HTML “hidden” attribute
|
|
118
|
+
.panel[hidden] {
|
|
119
|
+
display: none;
|
|
120
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { type MutableRefObject, type MouseEvent, type KeyboardEvent } from 'react';
|
|
2
|
+
interface TabsContextState {
|
|
3
|
+
tabNodes: MutableRefObject<Array<HTMLButtonElement>>;
|
|
4
|
+
panelNodes: MutableRefObject<Array<HTMLDivElement>>;
|
|
5
|
+
tabIds: Array<string>;
|
|
6
|
+
panelIds: Array<string>;
|
|
7
|
+
selectedTabIndex: number;
|
|
8
|
+
onClick: (tabIndex: number, event: MouseEvent<HTMLButtonElement>) => void;
|
|
9
|
+
onKeyUp: (tabIndex: number, event: KeyboardEvent<HTMLButtonElement>) => void;
|
|
10
|
+
size: 'medium' | 'large';
|
|
11
|
+
tabsListRef: MutableRefObject<HTMLUListElement | null>;
|
|
12
|
+
}
|
|
13
|
+
export declare const TabsContext: import("react").Context<TabsContextState | undefined>;
|
|
14
|
+
export declare function useTabsContext(): TabsContextState;
|
|
15
|
+
export {};
|
|
16
|
+
//# sourceMappingURL=use-tabs-context.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-tabs-context.d.ts","sourceRoot":"","sources":["../../../src/components/tabs/use-tabs-context.ts"],"names":[],"mappings":"AAEA,OAAO,EACN,KAAK,gBAAgB,EACrB,KAAK,UAAU,EACf,KAAK,aAAa,EAGlB,MAAM,OAAO,CAAA;AAEd,UAAU,gBAAgB;IACzB,QAAQ,EAAE,gBAAgB,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC,CAAA;IACpD,UAAU,EAAE,gBAAgB,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,CAAA;IACnD,MAAM,EAAE,KAAK,CAAC,MAAM,CAAC,CAAA;IACrB,QAAQ,EAAE,KAAK,CAAC,MAAM,CAAC,CAAA;IACvB,gBAAgB,EAAE,MAAM,CAAA;IACxB,OAAO,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,UAAU,CAAC,iBAAiB,CAAC,KAAK,IAAI,CAAA;IACzE,OAAO,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,aAAa,CAAC,iBAAiB,CAAC,KAAK,IAAI,CAAA;IAC5E,IAAI,EAAE,QAAQ,GAAG,OAAO,CAAA;IACxB,WAAW,EAAE,gBAAgB,CAAC,gBAAgB,GAAG,IAAI,CAAC,CAAA;CACtD;AAED,eAAO,MAAM,WAAW,uDAEvB,CAAA;AAED,wBAAgB,cAAc,IAAI,gBAAgB,CAMjD"}
|