@xplortech/apollo-core 2.6.0 → 2.7.1
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/.typings/apollo-components.html-data.json +626 -35
- package/build/style.css +5949 -3070
- package/dist/apollo-core/apollo-core.css +29 -19
- package/dist/apollo-core/apollo-core.esm.js +1 -1
- package/dist/apollo-core/p-0bf50890.entry.js +1 -0
- package/dist/apollo-core/p-1947e7a8.entry.js +1 -0
- package/dist/apollo-core/p-27928cb0.entry.js +1 -0
- package/dist/apollo-core/{p-5549756c.entry.js → p-34438721.entry.js} +1 -1
- package/dist/apollo-core/p-35c2f72d.entry.js +1 -0
- package/dist/apollo-core/p-368c81f1.entry.js +1 -0
- package/dist/apollo-core/{p-f5af9539.entry.js → p-36ba29da.entry.js} +1 -1
- package/dist/apollo-core/p-406b27a8.entry.js +1 -0
- package/dist/apollo-core/p-5d63b4ce.entry.js +1 -0
- package/dist/apollo-core/{p-02167464.entry.js → p-6a15f1e0.entry.js} +1 -1
- package/dist/apollo-core/p-8d692d05.entry.js +1 -0
- package/dist/apollo-core/{p-C_Z2nG0p.js → p-C7bgJs6C.js} +2 -2
- package/dist/apollo-core/{p-42016063.entry.js → p-b61d7952.entry.js} +1 -1
- package/dist/apollo-core/{p-8a1affce.entry.js → p-ca127ee8.entry.js} +1 -1
- package/dist/apollo-core/p-d1c9c233.entry.js +1 -0
- package/dist/apollo-core/p-dc205893.entry.js +1 -0
- package/dist/apollo-core/p-e2a5d41c.entry.js +1 -0
- package/dist/cjs/apollo-core.cjs.js +3 -3
- package/dist/cjs/{index-DH6pgWru.js → index-BQ97-AWw.js} +18 -7
- package/dist/cjs/loader.cjs.js +2 -2
- package/dist/cjs/xpl-accordion.cjs.entry.js +3 -3
- package/dist/cjs/xpl-application-shell.cjs.entry.js +2 -2
- package/dist/cjs/{xpl-avatar_47.cjs.entry.js → xpl-avatar_54.cjs.entry.js} +3726 -536
- package/dist/cjs/xpl-button-row.cjs.entry.js +2 -2
- package/dist/cjs/xpl-calendar.cjs.entry.js +2 -2
- package/dist/cjs/xpl-dynamic-table-cell.cjs.entry.js +3 -3
- package/dist/cjs/xpl-dynamic-table-row.cjs.entry.js +3 -3
- package/dist/cjs/xpl-dynamic-table.cjs.entry.js +2 -2
- package/dist/cjs/xpl-grid-item.cjs.entry.js +2 -2
- package/dist/cjs/xpl-grid.cjs.entry.js +2 -2
- package/dist/cjs/xpl-large-card.cjs.entry.js +2 -2
- package/dist/cjs/xpl-main-nav.cjs.entry.js +2 -2
- package/dist/cjs/xpl-table-header-cell.cjs.entry.js +1 -1
- package/dist/cjs/xpl-table-header.cjs.entry.js +2 -2
- package/dist/cjs/xpl-toggle.cjs.entry.js +4 -4
- package/dist/cjs/xpl-toolbar.cjs.entry.js +3 -3
- package/dist/collection/collection-manifest.json +11 -5
- package/dist/collection/components/xpl-accordion/xpl-accordion.js +2 -2
- package/dist/collection/components/xpl-application-shell/xpl-application-shell.js +1 -1
- package/dist/collection/components/xpl-avatar/avatar.stories.js +122 -107
- package/dist/collection/components/xpl-avatar/xpl-avatar.js +249 -15
- package/dist/collection/components/xpl-backdrop/xpl-backdrop.js +1 -1
- package/dist/collection/components/xpl-badge/badge.stories.js +1 -33
- package/dist/collection/components/xpl-badge/xpl-badge.js +1 -1
- package/dist/collection/components/xpl-banner/xpl-banner.js +4 -3
- package/dist/collection/components/xpl-breadcrumbs/xpl-breadcrumb-item/xpl-breadcrumb-item.js +1 -1
- package/dist/collection/components/xpl-breadcrumbs/xpl-breadcrumbs/xpl-breadcrumbs.js +1 -1
- package/dist/collection/components/xpl-button/xpl-button.js +21 -3
- package/dist/collection/components/xpl-button-row/xpl-button-row.js +1 -1
- package/dist/collection/components/xpl-calendar/xpl-calendar.js +1 -1
- package/dist/collection/components/xpl-checkbox/xpl-checkbox.js +25 -3
- package/dist/collection/components/xpl-choicelist/xpl-choicelist.js +1 -1
- package/dist/collection/components/xpl-content-area/xpl-content-area.js +1 -1
- package/dist/collection/components/xpl-dashboard/xpl-dashboard.js +1 -1
- package/dist/collection/components/xpl-data-card/xpl-data-card.js +2 -2
- package/dist/collection/components/xpl-divider/xpl-divider.js +1 -1
- package/dist/collection/components/xpl-dropdown/xpl-dropdown-group/xpl-dropdown-group.js +1 -1
- package/dist/collection/components/xpl-dropdown/xpl-dropdown-heading/xpl-dropdown-heading.js +1 -1
- package/dist/collection/components/xpl-dropdown/xpl-dropdown-option/xpl-dropdown-option.js +2 -2
- package/dist/collection/components/xpl-dropdown/xpl-dropdown.js +77 -7
- package/dist/collection/components/xpl-dynamic-table/xpl-dynamic-table.js +1 -1
- package/dist/collection/components/xpl-dynamic-table-cell/xpl-dynamic-table-cell.js +2 -2
- package/dist/collection/components/xpl-dynamic-table-row/xpl-dynamic-table-row.js +2 -2
- package/dist/collection/components/xpl-grid/xpl-grid.js +1 -1
- package/dist/collection/components/xpl-grid-item/xpl-grid-item.js +1 -1
- package/dist/collection/components/xpl-header-accordion/xpl-header-accordion.js +1 -1
- package/dist/collection/components/xpl-icon/xpl-icon.js +2 -2
- package/dist/collection/components/xpl-input/input.stories.js +96 -1
- package/dist/collection/components/xpl-input/xpl-input-color/xpl-input-color.js +8 -8
- package/dist/collection/components/xpl-input/xpl-input-date/xpl-input-date.js +3 -3
- package/dist/collection/components/xpl-input/xpl-input-file/xpl-input-file.js +4 -4
- package/dist/collection/components/xpl-input/xpl-input-phone/xpl-input-phone.js +5 -5
- package/dist/collection/components/xpl-input/xpl-input-search/xpl-input-search.js +485 -0
- package/dist/collection/components/xpl-input/xpl-input-time/xpl-input-time.js +2 -2
- package/dist/collection/components/xpl-input/xpl-input.js +130 -18
- package/dist/collection/components/xpl-large-card/xpl-large-card.js +1 -1
- package/dist/collection/components/xpl-list/list.stories.js +300 -63
- package/dist/collection/components/xpl-list/xpl-list-item/xpl-list-item.js +818 -0
- package/dist/collection/components/xpl-list/xpl-list.js +579 -21
- package/dist/collection/components/xpl-main-nav/xpl-main-nav.js +1 -1
- package/dist/collection/components/xpl-modal/xpl-modal.js +1 -1
- package/dist/collection/components/xpl-nav-item/xpl-nav-item.js +2 -2
- package/dist/collection/components/xpl-pagination/pagination.stories.js +18 -0
- package/dist/collection/components/xpl-pagination/xpl-pagination.js +7 -3
- package/dist/collection/components/xpl-panel/panel.stories.js +5 -3
- package/dist/collection/components/xpl-panel/xpl-panel.js +3 -3
- package/dist/collection/components/xpl-popover/xpl-popover.js +4 -4
- package/dist/collection/components/xpl-progress-bar/xpl-progress-bar.js +2 -2
- package/dist/collection/components/xpl-progress-indicator/progress-indicator.stories.js +118 -0
- package/dist/collection/components/xpl-progress-indicator/xpl-progress-indicator.js +171 -0
- package/dist/collection/components/xpl-radio/xpl-radio.js +3 -3
- package/dist/collection/components/xpl-secondary-nav/xpl-secondary-nav.js +1 -1
- package/dist/collection/components/xpl-select/xpl-select.js +58 -6
- package/dist/collection/components/xpl-side-nav/xpl-side-nav-item/xpl-side-nav-item.js +2 -2
- package/dist/collection/components/xpl-side-nav/xpl-side-nav.js +2 -2
- package/dist/collection/components/xpl-skeleton/xpl-skeleton.js +1 -1
- package/dist/collection/components/xpl-slideout/xpl-slideout.js +1 -1
- package/dist/collection/components/xpl-spotlight/spotlight.stories.js +385 -0
- package/dist/collection/components/xpl-spotlight/xpl-spotlight.js +1085 -0
- package/dist/collection/components/xpl-tab/xpl-tab.js +261 -8
- package/dist/collection/components/xpl-tab-panel/xpl-tab-panel.js +22 -15
- package/dist/collection/components/xpl-table/xpl-table.js +5 -5
- package/dist/collection/components/xpl-table-header/xpl-table-header.js +1 -1
- package/dist/collection/components/xpl-tabs/segment-control.stories.js +31 -0
- package/dist/collection/components/xpl-tabs/tabs.shared.js +156 -0
- package/dist/collection/components/xpl-tabs/tabs.stories.js +10 -60
- package/dist/collection/components/xpl-tabs/xpl-tabs.js +338 -62
- package/dist/collection/components/xpl-tag/tag.stories.js +153 -0
- package/dist/collection/components/xpl-tag/xpl-tag.js +312 -9
- package/dist/collection/components/xpl-toast/xpl-toast.js +2 -2
- package/dist/collection/components/xpl-toggle/xpl-toggle.js +3 -3
- package/dist/collection/components/xpl-toolbar/xpl-toolbar.js +2 -2
- package/dist/collection/components/xpl-tooltip/xpl-tooltip.js +1 -1
- package/dist/collection/components/xpl-top-nav/top-nav.stories.js +625 -0
- package/dist/collection/components/xpl-top-nav/xpl-nav-header-menu/xpl-nav-header-menu.js +122 -0
- package/dist/collection/components/xpl-top-nav/xpl-top-nav-item/xpl-top-nav-item.js +481 -0
- package/dist/collection/components/xpl-top-nav/xpl-top-nav.js +433 -0
- package/dist/collection/components/xpl-utility-bar/xpl-utility-bar.js +1 -1
- package/dist/collection/utils/lifecycle.js +79 -0
- package/dist/collection/utils/tab-a11y-ids.js +22 -0
- package/dist/components/floating-ui.dom.js +1 -0
- package/dist/components/index.js +1 -1
- package/dist/components/tab-a11y-ids.js +1 -0
- package/dist/components/xpl-accordion.js +1 -1
- package/dist/components/xpl-application-shell.js +1 -1
- package/dist/components/xpl-avatar2.js +1 -1
- package/dist/components/xpl-backdrop2.js +1 -1
- package/dist/components/xpl-badge2.js +1 -1
- package/dist/components/xpl-banner.js +1 -1
- package/dist/components/xpl-breadcrumb-item.js +1 -1
- package/dist/components/xpl-breadcrumbs.js +1 -1
- package/dist/components/xpl-button-row.js +1 -1
- package/dist/components/xpl-button2.js +1 -1
- package/dist/components/xpl-calendar.js +1 -1
- package/dist/components/xpl-checkbox2.js +1 -1
- package/dist/components/xpl-choicelist.js +1 -1
- package/dist/components/xpl-content-area.js +1 -1
- package/dist/components/xpl-dashboard.js +1 -1
- package/dist/components/xpl-data-card.js +1 -1
- package/dist/components/xpl-divider2.js +1 -1
- package/dist/components/xpl-dropdown-group2.js +1 -1
- package/dist/components/xpl-dropdown-heading2.js +1 -1
- package/dist/components/xpl-dropdown-option2.js +1 -1
- package/dist/components/xpl-dropdown2.js +1 -1
- package/dist/components/xpl-dynamic-table-cell.js +1 -1
- package/dist/components/xpl-dynamic-table-row.js +1 -1
- package/dist/components/xpl-dynamic-table.js +1 -1
- package/dist/components/xpl-grid-item.js +1 -1
- package/dist/components/xpl-grid.js +1 -1
- package/dist/components/xpl-header-accordion.js +1 -1
- package/dist/components/xpl-icon2.js +1 -1
- package/dist/components/xpl-input-date2.js +1 -1
- package/dist/components/xpl-input-file2.js +1 -1
- package/dist/components/xpl-input-search.d.ts +11 -0
- package/dist/components/xpl-input-search.js +1 -0
- package/dist/components/xpl-input-search2.js +1 -0
- package/dist/components/xpl-input2.js +1 -1
- package/dist/components/xpl-large-card.js +1 -1
- package/dist/components/{xpl-progress.d.ts → xpl-list-item.d.ts} +4 -4
- package/dist/components/xpl-list-item.js +1 -0
- package/dist/components/xpl-list-item2.js +1 -0
- package/dist/components/xpl-list.js +1 -1
- package/dist/components/xpl-main-nav.js +1 -1
- package/dist/components/xpl-modal.js +1 -1
- package/dist/components/xpl-nav-header-menu.d.ts +11 -0
- package/dist/components/xpl-nav-header-menu.js +1 -0
- package/dist/components/xpl-nav-item.js +1 -1
- package/dist/components/xpl-pagination.js +1 -1
- package/dist/components/xpl-panel.js +1 -1
- package/dist/components/xpl-popover2.js +1 -1
- package/dist/components/xpl-progress-bar.js +1 -1
- package/dist/components/xpl-progress-indicator.d.ts +11 -0
- package/dist/components/xpl-progress-indicator.js +1 -0
- package/dist/components/xpl-radio2.js +1 -1
- package/dist/components/xpl-secondary-nav.js +1 -1
- package/dist/components/xpl-select2.js +1 -1
- package/dist/components/xpl-side-nav-item.js +1 -1
- package/dist/components/xpl-side-nav.js +1 -1
- package/dist/components/xpl-skeleton.js +1 -1
- package/dist/components/xpl-slideout.js +1 -1
- package/dist/components/xpl-spotlight.d.ts +11 -0
- package/dist/components/xpl-spotlight.js +1 -0
- package/dist/components/xpl-tab-panel.js +1 -1
- package/dist/components/xpl-tab.js +1 -1
- package/dist/components/xpl-table-header.js +1 -1
- package/dist/components/xpl-table.js +1 -1
- package/dist/components/xpl-tabs.js +1 -1
- package/dist/components/xpl-tag2.js +1 -1
- package/dist/components/xpl-toast.js +1 -1
- package/dist/components/xpl-toggle.js +1 -1
- package/dist/components/xpl-toolbar.js +1 -1
- package/dist/components/xpl-tooltip2.js +1 -1
- package/dist/components/xpl-top-nav-item.d.ts +11 -0
- package/dist/components/xpl-top-nav-item.js +1 -0
- package/dist/components/xpl-top-nav-item2.js +1 -0
- package/dist/components/xpl-top-nav.d.ts +11 -0
- package/dist/components/xpl-top-nav.js +1 -0
- package/dist/components/xpl-utility-bar.js +1 -1
- package/dist/docs/xpl-avatar/readme.md +289 -15
- package/dist/docs/xpl-badge/readme.md +14 -9
- package/dist/docs/xpl-banner/readme.md +48 -11
- package/dist/docs/xpl-button/readme.md +28 -18
- package/dist/docs/xpl-calendar/readme.md +1 -1
- package/dist/docs/xpl-checkbox/readme.md +12 -11
- package/dist/docs/xpl-divider/readme.md +6 -4
- package/dist/docs/xpl-dropdown/readme.md +14 -12
- package/dist/docs/xpl-icon/readme.md +14 -2
- package/dist/docs/xpl-input/readme.md +66 -41
- package/dist/docs/xpl-input/xpl-input-color/readme.md +1 -0
- package/dist/docs/xpl-input/xpl-input-phone/readme.md +1 -0
- package/dist/docs/xpl-input/xpl-input-search/readme.md +175 -0
- package/dist/docs/xpl-input/xpl-input-time/readme.md +1 -0
- package/dist/docs/xpl-list/readme.md +320 -10
- package/dist/docs/xpl-list/xpl-list-item/readme.md +99 -0
- package/dist/docs/xpl-pagination/readme.md +1 -0
- package/dist/docs/xpl-panel/readme.md +108 -17
- package/dist/docs/xpl-popover/readme.md +2 -0
- package/dist/docs/xpl-progress-indicator/readme.md +234 -0
- package/dist/docs/xpl-radio/readme.md +6 -4
- package/dist/docs/xpl-select/readme.md +19 -16
- package/dist/docs/xpl-side-nav/readme.md +2 -2
- package/dist/docs/xpl-slideout/readme.md +1 -1
- package/dist/docs/xpl-spotlight/readme.md +235 -0
- package/dist/docs/xpl-tab/readme.md +43 -7
- package/dist/docs/xpl-tab-panel/readme.md +42 -0
- package/dist/docs/xpl-tabs/readme.md +62 -8
- package/dist/docs/xpl-tag/readme.md +379 -4
- package/dist/docs/xpl-toast/readme.md +1 -1
- package/dist/docs/xpl-top-nav/readme.md +179 -0
- package/dist/docs/xpl-top-nav/xpl-nav-header-menu/readme.md +81 -0
- package/dist/docs/xpl-top-nav/xpl-top-nav-item/readme.md +87 -0
- package/dist/esm/apollo-core.js +4 -4
- package/dist/esm/{index-C_Z2nG0p.js → index-C7bgJs6C.js} +18 -8
- package/dist/esm/loader.js +3 -3
- package/dist/esm/xpl-accordion.entry.js +3 -3
- package/dist/esm/xpl-application-shell.entry.js +2 -2
- package/dist/esm/{xpl-avatar_47.entry.js → xpl-avatar_54.entry.js} +3719 -536
- package/dist/esm/xpl-button-row.entry.js +2 -2
- package/dist/esm/xpl-calendar.entry.js +2 -2
- package/dist/esm/xpl-dynamic-table-cell.entry.js +3 -3
- package/dist/esm/xpl-dynamic-table-row.entry.js +3 -3
- package/dist/esm/xpl-dynamic-table.entry.js +2 -2
- package/dist/esm/xpl-grid-item.entry.js +2 -2
- package/dist/esm/xpl-grid.entry.js +2 -2
- package/dist/esm/xpl-large-card.entry.js +2 -2
- package/dist/esm/xpl-main-nav.entry.js +2 -2
- package/dist/esm/xpl-table-header-cell.entry.js +1 -1
- package/dist/esm/xpl-table-header.entry.js +2 -2
- package/dist/esm/xpl-toggle.entry.js +4 -4
- package/dist/esm/xpl-toolbar.entry.js +3 -3
- package/dist/types/components/xpl-avatar/avatar.stories.d.ts +88 -29
- package/dist/types/components/xpl-avatar/xpl-avatar.d.ts +29 -2
- package/dist/types/components/xpl-badge/badge.stories.d.ts +0 -19
- package/dist/types/components/xpl-button/xpl-button.d.ts +7 -0
- package/dist/types/components/xpl-checkbox/xpl-checkbox.d.ts +2 -1
- package/dist/types/components/xpl-dropdown/xpl-dropdown.d.ts +5 -0
- package/dist/types/components/xpl-input/input.stories.d.ts +1 -0
- package/dist/types/components/xpl-input/xpl-input-search/xpl-input-search.d.ts +39 -0
- package/dist/types/components/xpl-input/xpl-input.d.ts +13 -5
- package/dist/types/components/xpl-list/list.stories.d.ts +299 -13
- package/dist/types/components/xpl-list/listitem.d.ts +13 -0
- package/dist/types/components/xpl-list/xpl-list-item/xpl-list-item.d.ts +71 -0
- package/dist/types/components/xpl-list/xpl-list.d.ts +55 -2
- package/dist/types/components/xpl-pagination/pagination.stories.d.ts +13 -0
- package/dist/types/components/xpl-panel/panel.stories.d.ts +2 -0
- package/dist/types/components/xpl-progress-indicator/progress-indicator.stories.d.ts +62 -0
- package/dist/types/components/xpl-progress-indicator/xpl-progress-indicator.d.ts +11 -0
- package/dist/types/components/xpl-select/xpl-select.d.ts +3 -0
- package/dist/types/components/xpl-spotlight/spotlight.stories.d.ts +197 -0
- package/dist/types/components/xpl-spotlight/xpl-spotlight.d.ts +101 -0
- package/dist/types/components/xpl-tab/xpl-tab.d.ts +14 -1
- package/dist/types/components/xpl-tab-panel/xpl-tab-panel.d.ts +2 -1
- package/dist/types/components/xpl-tabs/segment-control.stories.d.ts +112 -0
- package/dist/types/components/xpl-tabs/tabs.shared.d.ts +156 -0
- package/dist/types/components/xpl-tabs/tabs.stories.d.ts +65 -12
- package/dist/types/components/xpl-tabs/xpl-tabs.d.ts +37 -18
- package/dist/types/components/xpl-tag/tag.stories.d.ts +65 -0
- package/dist/types/components/xpl-tag/xpl-tag.d.ts +36 -1
- package/dist/types/components/xpl-top-nav/top-nav.stories.d.ts +471 -0
- package/dist/types/components/xpl-top-nav/xpl-nav-header-menu/xpl-nav-header-menu.d.ts +18 -0
- package/dist/types/components/xpl-top-nav/xpl-top-nav-item/xpl-top-nav-item.d.ts +48 -0
- package/dist/types/components/xpl-top-nav/xpl-top-nav.d.ts +51 -0
- package/dist/types/components.d.ts +1521 -83
- package/dist/types/utils/lifecycle.d.ts +16 -0
- package/dist/types/utils/tab-a11y-ids.d.ts +4 -0
- package/package.json +12 -3
- package/dist/apollo-core/p-0bce3874.entry.js +0 -1
- package/dist/apollo-core/p-1fd3dc87.entry.js +0 -1
- package/dist/apollo-core/p-56fa4941.entry.js +0 -1
- package/dist/apollo-core/p-76c324da.entry.js +0 -1
- package/dist/apollo-core/p-7a3224b4.entry.js +0 -1
- package/dist/apollo-core/p-7e924697.entry.js +0 -1
- package/dist/apollo-core/p-9efca9e1.entry.js +0 -1
- package/dist/apollo-core/p-b252b380.entry.js +0 -1
- package/dist/apollo-core/p-c91daac1.entry.js +0 -1
- package/dist/apollo-core/p-d9b62508.entry.js +0 -1
- package/dist/apollo-core/p-eaea16d1.entry.js +0 -1
- package/dist/apollo-core/p-eed13bca.entry.js +0 -1
- package/dist/cjs/xpl-list.cjs.entry.js +0 -32
- package/dist/collection/components/xpl-progress/progress.stories.js +0 -106
- package/dist/collection/components/xpl-progress/xpl-progress.js +0 -60
- package/dist/components/xpl-progress.js +0 -1
- package/dist/docs/xpl-progress/readme.md +0 -22
- package/dist/esm/xpl-list.entry.js +0 -30
- package/dist/types/components/xpl-progress/progress.stories.d.ts +0 -38
- package/dist/types/components/xpl-progress/xpl-progress.d.ts +0 -6
|
@@ -37,3 +37,21 @@ Pagination.parameters = {
|
|
|
37
37
|
url: 'https://www.figma.com/design/MjjYek73MFnHmVNdm45Sd1/Apollo-Web?node-id=9-1407&p=f&t=01tbTrRZyfvVafsA-11',
|
|
38
38
|
},
|
|
39
39
|
};
|
|
40
|
+
export const PaginationWithPageControl = (args) => {
|
|
41
|
+
const { totalPages, withPageControl } = args;
|
|
42
|
+
return `
|
|
43
|
+
<div style="min-height: 120vh; display: flex; align-items: flex-end; padding: 24px;">
|
|
44
|
+
<xpl-pagination total-pages="${totalPages}" with-page-control="${withPageControl}"></xpl-pagination>
|
|
45
|
+
</div>
|
|
46
|
+
`;
|
|
47
|
+
};
|
|
48
|
+
PaginationWithPageControl.args = {
|
|
49
|
+
totalPages: 5,
|
|
50
|
+
withPageControl: true,
|
|
51
|
+
};
|
|
52
|
+
PaginationWithPageControl.parameters = {
|
|
53
|
+
layout: 'fullscreen',
|
|
54
|
+
'web-component': {
|
|
55
|
+
render: PaginationWithPageControl(PaginationWithPageControl.args),
|
|
56
|
+
},
|
|
57
|
+
};
|
|
@@ -59,19 +59,23 @@ export class Pagination {
|
|
|
59
59
|
render() {
|
|
60
60
|
const disablePrev = this.currentPage <= 1;
|
|
61
61
|
const disableNext = this.currentPage >= this.totalPages;
|
|
62
|
-
return (h(Host, { key: '
|
|
62
|
+
return (h(Host, { key: 'fad9cdff4010b4b5ac842633bf7daf09b4dbd5d4', class: {
|
|
63
|
+
'xpl-pagination': true,
|
|
64
|
+
'xpl-pagination__with-page-control': this.withPageControl,
|
|
65
|
+
'xpl-pagination__no-page-control': !this.withPageControl,
|
|
66
|
+
} }, this.withPageControl && (h("div", { key: 'eb125851b89aa1422ec3e5d5e336fcbecd07489e', class: "xpl-pagination__rows-per-page" }, h("label", { key: '5f2aa4c45d183827317a74cf4700981b6b0e7f2b', class: "xpl-pagination__rows-label" }, "Rows per page:"), h("xpl-select", { key: '7ba2987a24b3228d9b59320f29b22b5819f85546', class: "xpl-pagination__rows-per-page-select", dropdownFlipFallbackPlacements: ['bottom-start'], dropdownPlacement: "top-start", choices: this.rowsPerPageOptionsArray.map((option) => ({
|
|
63
67
|
label: option.toString(),
|
|
64
68
|
value: option.toString(),
|
|
65
69
|
isSelected: option === this.selectedRowsPerPage,
|
|
66
70
|
})), ref: (el) => {
|
|
67
71
|
this.rowsPerPageSelectRef = el;
|
|
68
|
-
} }))), h("div", { key: '
|
|
72
|
+
} }))), h("div", { key: '8bab9db1cecfdaeeb760b0e4e1afb393ff3a3fe7', class: "xpl-pagination__pager" }, h("button", { key: '19efd8a9aee2b05f875d2db34c7cdd174c845f60', class: "xpl-pagination__pager-button xpl-pagination__pager-button-prev", disabled: disablePrev, onClick: this.handlePrevPage, "aria-label": "Previous Page", tabindex: "0" }, h("xpl-icon", { key: 'a77a15c649a6f2c86b100d1687b4a099acc18602', icon: "arrow-left", size: 20 })), h("xpl-select", { key: '5778cad67d3a4b930b1f89b0e49c30e941e23259', class: "xpl-pagination__page-select", dropdownFlipFallbackPlacements: ['bottom-start'], dropdownPlacement: "top-start", choices: Array.from({ length: this.totalPages }, (_, index) => ({
|
|
69
73
|
label: `Page ${index + 1}`,
|
|
70
74
|
value: (index + 1).toString(),
|
|
71
75
|
isSelected: index + 1 === this.currentPage,
|
|
72
76
|
})), "custom-display-value": true, ref: (el) => {
|
|
73
77
|
this.pageSelectRef = el;
|
|
74
|
-
} }, h("div", { key: '
|
|
78
|
+
} }, h("div", { key: 'd0ae655a0100c2e81c8f7bdc2c8d3072f00cc7c9', slot: "custom-display-value" }, `${this.currentPage} of ${this.totalPages}`)), h("button", { key: 'ca6c7eb4fd277344f340b83673f1e43cb0c9fe99', class: "xpl-pagination__pager-button xpl-pagination__pager-button-next", disabled: disableNext, onClick: this.handleNextPage, "aria-label": "Next Page", tabindex: "0" }, h("xpl-icon", { key: 'd18efdcb7e67ab908fbf79fc475993cf656b150c', icon: "arrow-right", size: 20 })))));
|
|
75
79
|
}
|
|
76
80
|
static get is() { return "xpl-pagination"; }
|
|
77
81
|
static get properties() {
|
|
@@ -3,12 +3,14 @@ export default {
|
|
|
3
3
|
component: 'xpl-panel',
|
|
4
4
|
argTypes: {
|
|
5
5
|
accent: {
|
|
6
|
+
description: 'Top accent bar color. `none` hides the bar.',
|
|
6
7
|
options: ['none', 'primary', 'secondary', 'positive', 'negative', 'highlight'],
|
|
7
8
|
control: {
|
|
8
9
|
type: 'select',
|
|
9
10
|
},
|
|
10
11
|
},
|
|
11
12
|
padding: {
|
|
13
|
+
description: 'Content padding density; responsive steps for default/tight/loose (see readme).',
|
|
12
14
|
options: ['default', 'tight', 'loose'],
|
|
13
15
|
control: {
|
|
14
16
|
type: 'select',
|
|
@@ -18,7 +20,7 @@ export default {
|
|
|
18
20
|
};
|
|
19
21
|
export const Panel = ({ accent, padding }) => `
|
|
20
22
|
<xpl-panel accent="${accent}" padding="${padding}" style="max-width: 800px">
|
|
21
|
-
<p style="margin: 0
|
|
23
|
+
<p style="margin: 0" class="xpl-text-body">Panel content goes here. Compose other Apollo components within this slot.</p>
|
|
22
24
|
</xpl-panel>
|
|
23
25
|
`;
|
|
24
26
|
Panel.args = {
|
|
@@ -33,12 +35,12 @@ Panel.parameters = {
|
|
|
33
35
|
html: {
|
|
34
36
|
render: (({ accent, padding }) => {
|
|
35
37
|
const accentClass = accent !== 'none' ? ` xpl-panel--accent-${accent}` : '';
|
|
36
|
-
const accentBar = accent !== 'none' ? '<div class="xpl-panel__accent"></div>' : '';
|
|
38
|
+
const accentBar = accent !== 'none' ? '<div aria-hidden="true" class="xpl-panel__accent"></div>' : '';
|
|
37
39
|
return `
|
|
38
40
|
<div class="xpl-panel${accentClass} xpl-panel--padding-${padding}" style="max-width: 800px">
|
|
39
41
|
${accentBar}
|
|
40
42
|
<div class="xpl-panel__content">
|
|
41
|
-
<p
|
|
43
|
+
<p class="xpl-text-body" style="margin: 0">Panel content goes here. Compose other Apollo components within this slot.</p>
|
|
42
44
|
</div>
|
|
43
45
|
</div>
|
|
44
46
|
`;
|
|
@@ -6,11 +6,11 @@ export class XplPanel {
|
|
|
6
6
|
}
|
|
7
7
|
render() {
|
|
8
8
|
const hasAccent = this.accent !== 'none';
|
|
9
|
-
return (h(Host, { key: '
|
|
9
|
+
return (h(Host, { key: 'e9a747ba679f6f9f907d13217f329947bff93e31', class: {
|
|
10
10
|
'xpl-panel': true,
|
|
11
11
|
[`xpl-panel--accent-${this.accent}`]: hasAccent,
|
|
12
12
|
[`xpl-panel--padding-${this.padding}`]: true,
|
|
13
|
-
} }, hasAccent && h("div", { key: '
|
|
13
|
+
} }, hasAccent && h("div", { key: 'b777fd4a81574ff9276582b256b673cccfc63a34', "aria-hidden": "true", class: "xpl-panel__accent" }), h("div", { key: '5fa5ba4c2bfa13d7dcaee603e96ec9b77d103b13', class: "xpl-panel__content" }, h("slot", { key: 'c99b797e076c2641ae205181479dabb38f9ea009' }))));
|
|
14
14
|
}
|
|
15
15
|
static get is() { return "xpl-panel"; }
|
|
16
16
|
static get properties() {
|
|
@@ -47,7 +47,7 @@ export class XplPanel {
|
|
|
47
47
|
"optional": false,
|
|
48
48
|
"docs": {
|
|
49
49
|
"tags": [],
|
|
50
|
-
"text": "Padding density applied to the content area.\
|
|
50
|
+
"text": "Padding density applied to the content area.\n(default and tight keep desktop padding through tablet; mobile \u2264480px).\n\n- `default` \u2013 24 px desktop & tablet / 16 px mobile\n- `tight` \u2013 16 px desktop & tablet / 8 px mobile\n- `loose` \u2013 40 px desktop / 32 px tablet / 24 px mobile"
|
|
51
51
|
},
|
|
52
52
|
"getter": false,
|
|
53
53
|
"setter": false,
|
|
@@ -206,16 +206,16 @@ export class Popover {
|
|
|
206
206
|
});
|
|
207
207
|
}
|
|
208
208
|
render() {
|
|
209
|
-
return (h(Host, { key: '
|
|
209
|
+
return (h(Host, { key: '6fe479a39ee565772785c7b540c4e0915c5403e4' }, h("div", { key: '350452ca097bab13e7f06b3d1aa5e2774d80104b', class: {
|
|
210
210
|
'xpl-popover': true,
|
|
211
211
|
[`xpl-popover--${this.actualPosition}`]: true,
|
|
212
212
|
'xpl-popover--is-open': this.isOpenState,
|
|
213
|
-
} }, h("span", { key: '
|
|
213
|
+
} }, h("span", { key: '0a9365be21ef70855bd7d304a77fc80d19ba16d3', role: "button", tabindex: "0", "aria-haspopup": "dialog", "aria-expanded": this.isOpenState ? 'true' : 'false', onClick: this.togglePopover, ref: (el) => {
|
|
214
214
|
this.triggerRef = el;
|
|
215
|
-
} }, h("slot", { key: '
|
|
215
|
+
} }, h("slot", { key: 'df227b5bb7683599b4f82ef2a8c9d840b4920a61', name: "trigger" })), this.display === 'arrow' && (h("div", { key: 'dbf0b6998b3aa6ae40089e13bef86878037bbe24', class: "xpl-popover__arrow" }, h("svg", { key: '2bf57b69abc556ba9a86b59f6347a2c8d81a67c3', width: "17", height: "14", xmlns: "http://www.w3.org/2000/svg" }, h("path", { key: '36fef83ea3e2d3d4b388f5bdfe74d0bdc034be9d', d: "M0 5h15l-7.5 7.5L0 5Z", fill: "white", stroke: "none", class: "arrow-fill" }), h("path", { key: '1187a6ec22457ab6086753cf199398705541b1b4', d: "M0 5 L7.5 12.5 L15 5", fill: "none", stroke: "black", "stroke-width": "1", class: "arrow-stroke" })))), h("div", { key: '7c6f063094de1462629a0db380597374c4231855', class: {
|
|
216
216
|
'xpl-popover__content': true,
|
|
217
217
|
[`xpl-popover__content--display-${this.display}`]: true,
|
|
218
|
-
}, ref: (el) => (this.contentRef = el) }, h("slot", { key: '
|
|
218
|
+
}, ref: (el) => (this.contentRef = el) }, h("slot", { key: '41062b776eed58b98452bb5a8d3b7099ac1138d2' })))));
|
|
219
219
|
}
|
|
220
220
|
static get is() { return "xpl-popover"; }
|
|
221
221
|
static get properties() {
|
|
@@ -25,12 +25,12 @@ export class ProgressBar {
|
|
|
25
25
|
return this.variant === 'indeterminate';
|
|
26
26
|
}
|
|
27
27
|
render() {
|
|
28
|
-
return (h(Host, { key: '
|
|
28
|
+
return (h(Host, { key: 'e5cc7a2231ed74242241723c9f0a57444a8000bb', class: {
|
|
29
29
|
'xpl-progress-bar': true,
|
|
30
30
|
[`xpl-progress-bar--${this.size}`]: true,
|
|
31
31
|
[`xpl-progress-bar--${this.variant}`]: true,
|
|
32
32
|
'xpl-progress-bar--complete': this.isComplete,
|
|
33
|
-
} }, h("div", { key: '
|
|
33
|
+
} }, h("div", { key: '3212fdea66e2cd3edffc36f99c9edc197f15bcee', class: "xpl-progress-bar__wrapper" }, (this.label || this.showStatusIcon) && (h("div", { key: '004c0b9203df13c6818fdbb8c928a47d86e7388e', class: "xpl-progress-bar__header" }, this.label && h("div", { key: 'ce735edff19cc004f979a582618c968260cd23c3', class: "xpl-progress-bar__label" }, this.label), this.showStatusIcon && (h("div", { key: '3a9f143b79152aa3208593c9249a62d819c2967a', class: "xpl-progress-bar__icon" }, this.isError ? (h("xpl-icon", { icon: "circle-xmark-1" })) : (h("xpl-icon", { icon: "circle-check-1" })))))), h("div", { key: '517787d0ff39c082a3d4763b78b16a9ce9235b4b', class: "xpl-progress-bar__row" }, this.isIndeterminate ? (h("div", { class: "xpl-progress-bar__track xpl-progress-bar__track--indeterminate", role: "progressbar", "aria-label": this.label || 'Progress' }, h("div", { class: "xpl-progress-bar__indeterminate" }))) : (h("progress", { class: "xpl-progress-bar__progress", value: this.clampedValue, max: this.max, "aria-label": this.label || 'Progress' }))), this.helperText && (h("div", { key: '488c5092b96a1e9a5a08f9b090f94fe66f6f1490', class: "xpl-progress-bar__helper" }, this.helperText)))));
|
|
34
34
|
}
|
|
35
35
|
static get is() { return "xpl-progress-bar"; }
|
|
36
36
|
static get properties() {
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
export default {
|
|
2
|
+
title: 'Components/Progress Indicator',
|
|
3
|
+
component: 'xpl-progress-indicator',
|
|
4
|
+
argTypes: {
|
|
5
|
+
steps: { control: { type: 'object' } },
|
|
6
|
+
currentStep: { control: { type: 'number' } },
|
|
7
|
+
layout: { control: { type: 'select' }, options: ['horizontal', 'vertical'] },
|
|
8
|
+
showNumbers: { control: { type: 'boolean' } },
|
|
9
|
+
showLabels: { control: { type: 'boolean' } },
|
|
10
|
+
},
|
|
11
|
+
tags: ['beta'],
|
|
12
|
+
};
|
|
13
|
+
const defaultSteps = ['Details', 'Location', 'Instructor', 'Customers'];
|
|
14
|
+
export const ProgressIndicator = ({ steps = defaultSteps, currentStep = 1, layout = 'horizontal', showNumbers = true, showLabels = true, }) => {
|
|
15
|
+
const id = 'progress-indicator-stepper';
|
|
16
|
+
const stepsJson = JSON.stringify(steps);
|
|
17
|
+
let attrs = '';
|
|
18
|
+
attrs += ` current-step="${currentStep}"`;
|
|
19
|
+
if (layout !== 'horizontal')
|
|
20
|
+
attrs += ` layout="${layout}"`;
|
|
21
|
+
if (!showNumbers)
|
|
22
|
+
attrs += ` show-numbers="false"`;
|
|
23
|
+
if (!showLabels)
|
|
24
|
+
attrs += ` show-labels="false"`;
|
|
25
|
+
return `
|
|
26
|
+
<div class="h-96" style="padding: var(--xpl-space-24); width: 100%; height: 300px">
|
|
27
|
+
<xpl-progress-indicator id="${id}"${attrs}></xpl-progress-indicator>
|
|
28
|
+
|
|
29
|
+
<div style="margin-top: var(--xpl-space-32); display: flex; gap: var(--xpl-space-10);">
|
|
30
|
+
<xpl-button id="${id}-prev" variant="secondary">Previous</xpl-button>
|
|
31
|
+
<xpl-button id="${id}-next">Next</xpl-button>
|
|
32
|
+
</div>
|
|
33
|
+
|
|
34
|
+
<script>
|
|
35
|
+
(function() {
|
|
36
|
+
const progress = document.getElementById('${id}');
|
|
37
|
+
progress.steps = ${stepsJson};
|
|
38
|
+
|
|
39
|
+
const prevBtn = document.getElementById('${id}-prev');
|
|
40
|
+
const nextBtn = document.getElementById('${id}-next');
|
|
41
|
+
const totalSteps = ${steps.length};
|
|
42
|
+
|
|
43
|
+
let currentStep = ${currentStep};
|
|
44
|
+
|
|
45
|
+
const updateButtons = () => {
|
|
46
|
+
prevBtn.disabled = currentStep === 0;
|
|
47
|
+
nextBtn.disabled = currentStep === totalSteps;
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
updateButtons();
|
|
51
|
+
|
|
52
|
+
prevBtn.onclick = () => {
|
|
53
|
+
if (currentStep > 0) {
|
|
54
|
+
currentStep--;
|
|
55
|
+
progress.currentStep = currentStep;
|
|
56
|
+
updateButtons();
|
|
57
|
+
}
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
nextBtn.onclick = () => {
|
|
61
|
+
if (currentStep < totalSteps) {
|
|
62
|
+
currentStep++;
|
|
63
|
+
progress.currentStep = currentStep;
|
|
64
|
+
updateButtons();
|
|
65
|
+
}
|
|
66
|
+
};
|
|
67
|
+
})();
|
|
68
|
+
</script>
|
|
69
|
+
</div>
|
|
70
|
+
`;
|
|
71
|
+
};
|
|
72
|
+
ProgressIndicator.args = {
|
|
73
|
+
steps: defaultSteps,
|
|
74
|
+
currentStep: 1,
|
|
75
|
+
layout: 'horizontal',
|
|
76
|
+
showNumbers: true,
|
|
77
|
+
showLabels: true,
|
|
78
|
+
};
|
|
79
|
+
ProgressIndicator.parameters = {
|
|
80
|
+
'web-component': {
|
|
81
|
+
render: ProgressIndicator(ProgressIndicator.args),
|
|
82
|
+
},
|
|
83
|
+
html: {
|
|
84
|
+
render: `
|
|
85
|
+
<div style="padding: var(--xpl-space-24);">
|
|
86
|
+
<div class="xpl-progress-indicator xpl-progress-indicator-horizontal">
|
|
87
|
+
<div class="xpl-progress-indicator-container">
|
|
88
|
+
${defaultSteps
|
|
89
|
+
.map((step, index) => `
|
|
90
|
+
<div class="xpl-progress-indicator-step ${index === 1
|
|
91
|
+
? 'xpl-progress-indicator-step-active'
|
|
92
|
+
: index < 1
|
|
93
|
+
? 'xpl-progress-indicator-step-finished'
|
|
94
|
+
: ''}">
|
|
95
|
+
<div class="xpl-progress-indicator-step-content">
|
|
96
|
+
<div class="xpl-progress-indicator-step-circle">${index < 1
|
|
97
|
+
? '<xpl-icon icon="check-2" size="20" class="xpl-progress-indicator-step-checkmark"></xpl-icon>'
|
|
98
|
+
: `<span class="xpl-progress-indicator-step-number">${index + 1}</span>`}</div>
|
|
99
|
+
<div class="xpl-progress-indicator-step-text">${step}</div>
|
|
100
|
+
</div>
|
|
101
|
+
</div>
|
|
102
|
+
`)
|
|
103
|
+
.join('')}
|
|
104
|
+
</div>
|
|
105
|
+
</div>
|
|
106
|
+
|
|
107
|
+
<div style="margin-top: var(--xpl-space-32); display: flex; gap: var(--xpl-space-10);">
|
|
108
|
+
<button class="xpl-button xpl-button--secondary">Previous</button>
|
|
109
|
+
<button class="xpl-button">Next</button>
|
|
110
|
+
</div>
|
|
111
|
+
</div>
|
|
112
|
+
`,
|
|
113
|
+
},
|
|
114
|
+
design: {
|
|
115
|
+
type: 'figma',
|
|
116
|
+
url: 'https://www.figma.com/design/MjjYek73MFnHmVNdm45Sd1/Apollo-Web?node-id=12762-3404',
|
|
117
|
+
},
|
|
118
|
+
};
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
import { Host, h } from "@stencil/core";
|
|
2
|
+
export class ProgressIndicator {
|
|
3
|
+
constructor() {
|
|
4
|
+
this.currentStep = 0;
|
|
5
|
+
this.layout = 'horizontal';
|
|
6
|
+
this.showLabels = true;
|
|
7
|
+
this.showNumbers = true;
|
|
8
|
+
}
|
|
9
|
+
validateCurrentStep() {
|
|
10
|
+
if (!this.steps || this.steps.length === 0)
|
|
11
|
+
return;
|
|
12
|
+
const max = this.steps.length;
|
|
13
|
+
if (this.currentStep < 0) {
|
|
14
|
+
this.currentStep = 0;
|
|
15
|
+
}
|
|
16
|
+
else if (this.currentStep > max) {
|
|
17
|
+
this.currentStep = max;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
renderStepContent(index, isFinished) {
|
|
21
|
+
if (isFinished) {
|
|
22
|
+
return (h("xpl-icon", { icon: "check-2", size: 20, class: "xpl-progress-indicator-step-checkmark" }));
|
|
23
|
+
}
|
|
24
|
+
if (!this.showNumbers) {
|
|
25
|
+
return h("span", { class: "xpl-progress-indicator-step-dot" });
|
|
26
|
+
}
|
|
27
|
+
return h("span", { class: "xpl-progress-indicator-step-number" }, index + 1);
|
|
28
|
+
}
|
|
29
|
+
renderStep(step, index) {
|
|
30
|
+
const isFinished = this.currentStep > index;
|
|
31
|
+
const isActive = this.currentStep === index;
|
|
32
|
+
const isHorizontal = this.layout === 'horizontal';
|
|
33
|
+
const circle = (h("div", { class: "xpl-progress-indicator-step-circle" }, this.renderStepContent(index, isFinished)));
|
|
34
|
+
const label = this.showLabels && h("div", { class: "xpl-progress-indicator-step-text" }, step);
|
|
35
|
+
const content = isHorizontal ? (h("div", { class: "xpl-progress-indicator-step-content" }, circle, label)) : ([circle, label]);
|
|
36
|
+
return (h("div", { class: {
|
|
37
|
+
'xpl-progress-indicator-step': true,
|
|
38
|
+
'xpl-progress-indicator-step-active': isActive,
|
|
39
|
+
'xpl-progress-indicator-step-finished': isFinished,
|
|
40
|
+
}, role: "listitem", "aria-label": `${step}, ${isFinished ? 'completed' : isActive ? 'current' : 'upcoming'}`, "aria-current": isActive ? 'step' : undefined }, content));
|
|
41
|
+
}
|
|
42
|
+
render() {
|
|
43
|
+
const steps = this.steps || [];
|
|
44
|
+
const hostClasses = {
|
|
45
|
+
'xpl-progress-indicator': true,
|
|
46
|
+
'xpl-progress-indicator-horizontal': this.layout === 'horizontal',
|
|
47
|
+
'xpl-progress-indicator-vertical': this.layout === 'vertical',
|
|
48
|
+
'xpl-progress-indicator-no-labels': !this.showLabels,
|
|
49
|
+
};
|
|
50
|
+
const totalSteps = steps.length;
|
|
51
|
+
const allComplete = this.currentStep >= totalSteps;
|
|
52
|
+
const currentStepNumber = Math.min(this.currentStep + 1, totalSteps);
|
|
53
|
+
const ariaLabel = totalSteps > 0
|
|
54
|
+
? allComplete
|
|
55
|
+
? `Progress: all ${totalSteps} ${totalSteps === 1 ? 'step' : 'steps'} complete`
|
|
56
|
+
: `Progress: step ${currentStepNumber} of ${totalSteps}`
|
|
57
|
+
: 'Progress';
|
|
58
|
+
return (h(Host, { key: '3a6f253693fd47f982541099a1729ca36d0ce64a', class: hostClasses, role: "group", "aria-label": ariaLabel }, h("div", { key: 'c25b47994c43135ed3147ca579bdc3d8124d7c8a', class: "xpl-progress-indicator-container", role: "list" }, steps.map((step, index) => this.renderStep(step, index)))));
|
|
59
|
+
}
|
|
60
|
+
static get is() { return "xpl-progress-indicator"; }
|
|
61
|
+
static get properties() {
|
|
62
|
+
return {
|
|
63
|
+
"currentStep": {
|
|
64
|
+
"type": "number",
|
|
65
|
+
"mutable": true,
|
|
66
|
+
"complexType": {
|
|
67
|
+
"original": "number",
|
|
68
|
+
"resolved": "number",
|
|
69
|
+
"references": {}
|
|
70
|
+
},
|
|
71
|
+
"required": false,
|
|
72
|
+
"optional": false,
|
|
73
|
+
"docs": {
|
|
74
|
+
"tags": [],
|
|
75
|
+
"text": "Current step index. Steps with index < currentStep are \"finished\",\nthe step at currentStep is \"active\", and steps beyond are \"waiting\".\nSet to steps.length to mark all steps as finished.\nAutomatically clamped to [0, steps.length]."
|
|
76
|
+
},
|
|
77
|
+
"getter": false,
|
|
78
|
+
"setter": false,
|
|
79
|
+
"reflect": false,
|
|
80
|
+
"attribute": "current-step",
|
|
81
|
+
"defaultValue": "0"
|
|
82
|
+
},
|
|
83
|
+
"layout": {
|
|
84
|
+
"type": "string",
|
|
85
|
+
"mutable": false,
|
|
86
|
+
"complexType": {
|
|
87
|
+
"original": "'horizontal' | 'vertical'",
|
|
88
|
+
"resolved": "\"horizontal\" | \"vertical\"",
|
|
89
|
+
"references": {}
|
|
90
|
+
},
|
|
91
|
+
"required": false,
|
|
92
|
+
"optional": false,
|
|
93
|
+
"docs": {
|
|
94
|
+
"tags": [],
|
|
95
|
+
"text": "Layout direction - 'horizontal' or 'vertical'"
|
|
96
|
+
},
|
|
97
|
+
"getter": false,
|
|
98
|
+
"setter": false,
|
|
99
|
+
"reflect": false,
|
|
100
|
+
"attribute": "layout",
|
|
101
|
+
"defaultValue": "'horizontal'"
|
|
102
|
+
},
|
|
103
|
+
"showLabels": {
|
|
104
|
+
"type": "boolean",
|
|
105
|
+
"mutable": false,
|
|
106
|
+
"complexType": {
|
|
107
|
+
"original": "boolean",
|
|
108
|
+
"resolved": "boolean",
|
|
109
|
+
"references": {}
|
|
110
|
+
},
|
|
111
|
+
"required": false,
|
|
112
|
+
"optional": false,
|
|
113
|
+
"docs": {
|
|
114
|
+
"tags": [],
|
|
115
|
+
"text": "Whether to show step labels"
|
|
116
|
+
},
|
|
117
|
+
"getter": false,
|
|
118
|
+
"setter": false,
|
|
119
|
+
"reflect": false,
|
|
120
|
+
"attribute": "show-labels",
|
|
121
|
+
"defaultValue": "true"
|
|
122
|
+
},
|
|
123
|
+
"showNumbers": {
|
|
124
|
+
"type": "boolean",
|
|
125
|
+
"mutable": false,
|
|
126
|
+
"complexType": {
|
|
127
|
+
"original": "boolean",
|
|
128
|
+
"resolved": "boolean",
|
|
129
|
+
"references": {}
|
|
130
|
+
},
|
|
131
|
+
"required": false,
|
|
132
|
+
"optional": false,
|
|
133
|
+
"docs": {
|
|
134
|
+
"tags": [],
|
|
135
|
+
"text": "Whether to show step numbers inside circles"
|
|
136
|
+
},
|
|
137
|
+
"getter": false,
|
|
138
|
+
"setter": false,
|
|
139
|
+
"reflect": false,
|
|
140
|
+
"attribute": "show-numbers",
|
|
141
|
+
"defaultValue": "true"
|
|
142
|
+
},
|
|
143
|
+
"steps": {
|
|
144
|
+
"type": "unknown",
|
|
145
|
+
"mutable": false,
|
|
146
|
+
"complexType": {
|
|
147
|
+
"original": "string[]",
|
|
148
|
+
"resolved": "string[]",
|
|
149
|
+
"references": {}
|
|
150
|
+
},
|
|
151
|
+
"required": false,
|
|
152
|
+
"optional": true,
|
|
153
|
+
"docs": {
|
|
154
|
+
"tags": [],
|
|
155
|
+
"text": "The steps is an array of the steps name."
|
|
156
|
+
},
|
|
157
|
+
"getter": false,
|
|
158
|
+
"setter": false
|
|
159
|
+
}
|
|
160
|
+
};
|
|
161
|
+
}
|
|
162
|
+
static get watchers() {
|
|
163
|
+
return [{
|
|
164
|
+
"propName": "steps",
|
|
165
|
+
"methodName": "validateCurrentStep"
|
|
166
|
+
}, {
|
|
167
|
+
"propName": "currentStep",
|
|
168
|
+
"methodName": "validateCurrentStep"
|
|
169
|
+
}];
|
|
170
|
+
}
|
|
171
|
+
}
|
|
@@ -14,14 +14,14 @@ export class Radio {
|
|
|
14
14
|
};
|
|
15
15
|
}
|
|
16
16
|
render() {
|
|
17
|
-
return (h(Host, { key: '
|
|
17
|
+
return (h(Host, { key: '959940093b1988f6e362c17e463fe2139cd828c5', class: {
|
|
18
18
|
'xpl-checkbox-radio-container': true,
|
|
19
19
|
styled: this.styled,
|
|
20
20
|
disabled: this.disabled,
|
|
21
|
-
} }, h("input", { key: '
|
|
21
|
+
} }, h("input", { key: 'cccccd581ee84a2c5c39a625565877cc080e9702', class: "xpl-radio", type: "radio", checked: this.checked, disabled: this.disabled, id: this.id, name: this.name, required: this.required, onChange: this.onChange, value: this.value }), h("label", { key: '3dd39b409818d7f2921c6dc7dc2c3d790a088833', class: {
|
|
22
22
|
'xpl-label': true,
|
|
23
23
|
'xpl-label--disabled': this.disabled,
|
|
24
|
-
}, htmlFor: this.id }, h("slot", { key: '
|
|
24
|
+
}, htmlFor: this.id }, h("slot", { key: '0e0af25e2b1679bef0aa053d20df8f0ec7390d18' }), this.description && (h("small", { key: 'dcc8791c823ec66dcdb806ae4aeaf7daf6c72298', class: {
|
|
25
25
|
'xpl-description': true,
|
|
26
26
|
'xpl-description--disabled': this.disabled,
|
|
27
27
|
} }, this.description)))));
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Host, h } from "@stencil/core";
|
|
2
2
|
export class SecondaryNav {
|
|
3
3
|
render() {
|
|
4
|
-
return (h(Host, { key: '
|
|
4
|
+
return (h(Host, { key: 'f4fdd93b13c1dc779c84e8b00b12caeff58df960', class: "xpl-secondary-nav" }, h("nav", { key: '4092d23357761026ad5fddfbc32a221d957cce1e', "aria-label": "Secondary Nav" }, h("slot", { key: 'c3ae9f1821a6d22babece27971cc1faf15037cdb' }))));
|
|
5
5
|
}
|
|
6
6
|
static get is() { return "xpl-secondary-nav"; }
|
|
7
7
|
}
|
|
@@ -16,6 +16,7 @@ export class Select {
|
|
|
16
16
|
constructor() {
|
|
17
17
|
this.choices = [];
|
|
18
18
|
this.selectIcon = 'chevron-down';
|
|
19
|
+
this.dropdownPlacement = 'bottom-start';
|
|
19
20
|
this.mode = 'single';
|
|
20
21
|
this.truncate = true;
|
|
21
22
|
this.active = false;
|
|
@@ -222,21 +223,21 @@ export class Select {
|
|
|
222
223
|
this.truncate &&
|
|
223
224
|
!this.customDisplayValue;
|
|
224
225
|
const truncatedText = `+ ${Math.abs(this.choicesState.filter((a) => a.isSelected).length - this.visibleChoices)} more`;
|
|
225
|
-
return (h(Host, { key: '
|
|
226
|
+
return (h(Host, { key: '09d3587fa268cb0621ea293d246e23cde93d75df', class: {
|
|
226
227
|
'xpl-select': true,
|
|
227
228
|
'xpl-select--disabled': this.disabled,
|
|
228
229
|
'xpl-select--no-truncate': !this.truncate,
|
|
229
230
|
[(_c = this.classNames) !== null && _c !== void 0 ? _c : '']: !!this.classNames,
|
|
230
231
|
}, onKeyDown: this.handleTabKeyDown, ref: (el) => {
|
|
231
232
|
this.container = el;
|
|
232
|
-
} }, this.renderLabel(), h("div", { key: '
|
|
233
|
+
} }, this.renderLabel(), h("div", { key: '007a61cc60c948d0691d6983cb197652084e417d', class: {
|
|
233
234
|
'xpl-input': true,
|
|
234
235
|
'xpl-input--disabled': this.disabled,
|
|
235
236
|
'xpl-input--error': ((_d = this.error) === null || _d === void 0 ? void 0 : _d.length) >= 0,
|
|
236
|
-
} }, h("div", { key: '
|
|
237
|
+
} }, h("div", { key: 'e1edfe6e4b205bd6332f07031ee51ef7f9f6ac91', class: "xpl-input-wrapper" }, h("button", { key: '53d079f28b8a1bcdd5498287dfd88bb7a3ba7b50', class: "xpl-select__trigger", disabled: this.disabled, id: this.id, onKeyDown: this.handleTabKeyDown, onClick: (e) => {
|
|
237
238
|
e.preventDefault();
|
|
238
239
|
this.handleDropdownTrigger();
|
|
239
|
-
}, type: "button" }, h("div", { key: '
|
|
240
|
+
}, type: "button" }, h("div", { key: '5cfec98b2e829ea48e96b373e09e740d5bf02ef6', class: {
|
|
240
241
|
'xpl-select-value': true,
|
|
241
242
|
'xpl-select-value--active': this.mode === 'multi' && this.value.length > 0,
|
|
242
243
|
'has-value': this.value.length > 0,
|
|
@@ -256,7 +257,7 @@ export class Select {
|
|
|
256
257
|
return this.renderSelectedTags();
|
|
257
258
|
}
|
|
258
259
|
return this.placeholder;
|
|
259
|
-
})(), isTextTruncated && truncatedText), h("xpl-icon", { key: '
|
|
260
|
+
})(), isTextTruncated && truncatedText), h("xpl-icon", { key: '8bb01d1e8b206fb3c1963cdebcd293eeb2277e05', class: "xpl-select__chevron-down", icon: this.selectIcon }))), !this.disabled && (h("xpl-dropdown", { key: 'f5e770c4b26449f3025d172d768d6df69bd0ae03', ref: (el) => {
|
|
260
261
|
this.dropdown = el;
|
|
261
262
|
}, isOpen: this.dropdownOpenState, options: this.choicesState, selectedValues: this.selectedValues, mode: this.mode, triggerId: this.id, update: (_e, { component }) => {
|
|
262
263
|
const { options } = component;
|
|
@@ -265,7 +266,7 @@ export class Select {
|
|
|
265
266
|
}
|
|
266
267
|
}, onIsOpenChange: (e) => {
|
|
267
268
|
this.dropdownOpenState = e.detail;
|
|
268
|
-
}, onWheel: this.handleDropdownScroll, anchorToTrigger: true })), this.renderError()), h("input", { key: '
|
|
269
|
+
}, onWheel: this.handleDropdownScroll, anchorToTrigger: true, flipFallbackPlacements: this.dropdownFlipFallbackPlacements, placement: this.dropdownPlacement })), this.renderError()), h("input", { key: 'fe84c16780622e730100a58a948fc4fe27f6ddb5', type: "hidden", name: this.name, value: this.value })));
|
|
269
270
|
}
|
|
270
271
|
static get is() { return "xpl-select"; }
|
|
271
272
|
static get properties() {
|
|
@@ -353,6 +354,57 @@ export class Select {
|
|
|
353
354
|
"reflect": false,
|
|
354
355
|
"attribute": "disabled"
|
|
355
356
|
},
|
|
357
|
+
"dropdownFlipFallbackPlacements": {
|
|
358
|
+
"type": "unknown",
|
|
359
|
+
"mutable": false,
|
|
360
|
+
"complexType": {
|
|
361
|
+
"original": "Placement[]",
|
|
362
|
+
"resolved": "Placement[]",
|
|
363
|
+
"references": {
|
|
364
|
+
"Placement": {
|
|
365
|
+
"location": "import",
|
|
366
|
+
"path": "@floating-ui/dom",
|
|
367
|
+
"id": "../../node_modules/@floating-ui/dom/dist/floating-ui.dom.d.mts::Placement",
|
|
368
|
+
"referenceLocation": "Placement"
|
|
369
|
+
}
|
|
370
|
+
}
|
|
371
|
+
},
|
|
372
|
+
"required": false,
|
|
373
|
+
"optional": true,
|
|
374
|
+
"docs": {
|
|
375
|
+
"tags": [],
|
|
376
|
+
"text": "Additional placements to try for the options panel when the default\n`dropdownPlacement` does not fit. Passed to `xpl-dropdown` / Floating UI `flip`."
|
|
377
|
+
},
|
|
378
|
+
"getter": false,
|
|
379
|
+
"setter": false
|
|
380
|
+
},
|
|
381
|
+
"dropdownPlacement": {
|
|
382
|
+
"type": "string",
|
|
383
|
+
"mutable": false,
|
|
384
|
+
"complexType": {
|
|
385
|
+
"original": "Placement",
|
|
386
|
+
"resolved": "\"bottom\" | \"bottom-end\" | \"bottom-start\" | \"left\" | \"left-end\" | \"left-start\" | \"right\" | \"right-end\" | \"right-start\" | \"top\" | \"top-end\" | \"top-start\"",
|
|
387
|
+
"references": {
|
|
388
|
+
"Placement": {
|
|
389
|
+
"location": "import",
|
|
390
|
+
"path": "@floating-ui/dom",
|
|
391
|
+
"id": "../../node_modules/@floating-ui/dom/dist/floating-ui.dom.d.mts::Placement",
|
|
392
|
+
"referenceLocation": "Placement"
|
|
393
|
+
}
|
|
394
|
+
}
|
|
395
|
+
},
|
|
396
|
+
"required": false,
|
|
397
|
+
"optional": false,
|
|
398
|
+
"docs": {
|
|
399
|
+
"tags": [],
|
|
400
|
+
"text": "Initial Floating UI placement for the options panel (e.g. `top-start`, `bottom-start`).\nForwarded to the inner `xpl-dropdown` when the menu is open."
|
|
401
|
+
},
|
|
402
|
+
"getter": false,
|
|
403
|
+
"setter": false,
|
|
404
|
+
"reflect": false,
|
|
405
|
+
"attribute": "dropdown-placement",
|
|
406
|
+
"defaultValue": "'bottom-start'"
|
|
407
|
+
},
|
|
356
408
|
"error": {
|
|
357
409
|
"type": "string",
|
|
358
410
|
"mutable": false,
|
|
@@ -45,10 +45,10 @@ export class SideNavItem {
|
|
|
45
45
|
expanded: this.expanded,
|
|
46
46
|
selected: this.selected,
|
|
47
47
|
};
|
|
48
|
-
return (h(Host, { key: '
|
|
48
|
+
return (h(Host, { key: 'a621f4f9c04d79de708a34a4f4eab06e523a299a', class: {
|
|
49
49
|
'xpl-side-nav-item': true,
|
|
50
50
|
'xpl-side-nav-item--link-disabled': this.link && this.disabled,
|
|
51
|
-
} }, this.link ? (h("slot", null)) : (h("button", { type: "button", class: linkClass, "aria-current": this.selected ? 'page' : undefined, "aria-expanded": this.hasChildren ? (this.expanded ? 'true' : 'false') : undefined, onClick: this.handleClick, disabled: this.disabled }, this.hasChildren && (h("span", { class: `xpl-side-nav-item__arrow ${this.expanded ? 'expanded' : ''}` }, h("xpl-icon", { icon: "chevron-down", size: 16 }))), !this.hasChildren && (h("span", { class: "xpl-side-nav-item__icon" }, h("slot", { name: "icon" }, this.icon ? (h("xpl-icon", { icon: this.icon, size: 16 })) : null))), h("span", { class: "xpl-side-nav-item__label" }, (_a = this.label) !== null && _a !== void 0 ? _a : ''))), this.hasChildren && !this.link && (h("div", { key: '
|
|
51
|
+
} }, this.link ? (h("slot", null)) : (h("button", { type: "button", class: linkClass, "aria-current": this.selected ? 'page' : undefined, "aria-expanded": this.hasChildren ? (this.expanded ? 'true' : 'false') : undefined, onClick: this.handleClick, disabled: this.disabled }, this.hasChildren && (h("span", { class: `xpl-side-nav-item__arrow ${this.expanded ? 'expanded' : ''}` }, h("xpl-icon", { icon: "chevron-down", size: 16 }))), !this.hasChildren && (h("span", { class: "xpl-side-nav-item__icon" }, h("slot", { name: "icon" }, this.icon ? (h("xpl-icon", { icon: this.icon, size: 16 })) : null))), h("span", { class: "xpl-side-nav-item__label" }, (_a = this.label) !== null && _a !== void 0 ? _a : ''))), this.hasChildren && !this.link && (h("div", { key: '3e22894c0bd9427f568b86bba00cdab822921997', class: `xpl-side-nav-item__children ${this.expanded ? 'expanded' : ''}`, inert: !this.expanded ? true : undefined }, h("div", { key: '41486a4241e4402232531d140e972b39d863ffd9', class: "xpl-side-nav-item__children-inner" }, h("slot", { key: 'd334c6ecac7dd1dd12602a461db444cd1ccefc86' }))))));
|
|
52
52
|
}
|
|
53
53
|
static get is() { return "xpl-side-nav-item"; }
|
|
54
54
|
static get properties() {
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { Host, h } from "@stencil/core";
|
|
2
2
|
export class SideNav {
|
|
3
3
|
render() {
|
|
4
|
-
return (h(Host, { key: '
|
|
4
|
+
return (h(Host, { key: 'd01e8e27671eabc92613a803818b4351334011ac', class: {
|
|
5
5
|
'xpl-side-nav': true,
|
|
6
|
-
} }, h("div", { key: '
|
|
6
|
+
} }, h("div", { key: '92c9f31fa0d9d564164cde99d17e30562c30abb7', class: "xpl-side-nav__wrapper" }, h("nav", { key: '5ddd8b18d4f74bb752b747ec4e1c48780a0738de', class: "xpl-side-nav__content", "aria-label": this.label }, h("div", { key: '8b830945bf6ec1da8ab2e2c955c10a1077652590', class: "xpl-side-nav__section" }, h("slot", { key: '66e5cd33c23bdc8963d661e0741d34f80a0640fb', name: "section" })), h("div", { key: 'f0da4e3c25822453efcbfb3c6f8ea7ec328e717d', class: "xpl-side-nav__footer" }, h("slot", { key: '76b829e978361be9fd62bd412489ea4559852c3f', name: "nav-footer" }))))));
|
|
7
7
|
}
|
|
8
8
|
static get is() { return "xpl-side-nav"; }
|
|
9
9
|
static get properties() {
|