@spw-ds/spw-stencil-library 0.0.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/LICENSE +21 -0
- package/README.md +16 -0
- package/dist/cjs/app-globals-3a1e7e63.js +7 -0
- package/dist/cjs/app-globals-3a1e7e63.js.map +1 -0
- package/dist/cjs/index-55fbdb28.js +1956 -0
- package/dist/cjs/index-55fbdb28.js.map +1 -0
- package/dist/cjs/index.cjs.js +4 -0
- package/dist/cjs/index.cjs.js.map +1 -0
- package/dist/cjs/loader.cjs.js +17 -0
- package/dist/cjs/loader.cjs.js.map +1 -0
- package/dist/cjs/spw-accordion_58.cjs.entry.js +5955 -0
- package/dist/cjs/spw-accordion_58.cjs.entry.js.map +1 -0
- package/dist/cjs/spw-stencil-library.cjs.js +27 -0
- package/dist/cjs/spw-stencil-library.cjs.js.map +1 -0
- package/dist/collection/assets/images/logo.svg +3 -0
- package/dist/collection/collection-manifest.json +69 -0
- package/dist/collection/components/spw-accordion/spw-accordion-content/spw-accordion-content.css +2 -0
- package/dist/collection/components/spw-accordion/spw-accordion-content/spw-accordion-content.js +91 -0
- package/dist/collection/components/spw-accordion/spw-accordion-content/spw-accordion-content.js.map +1 -0
- package/dist/collection/components/spw-accordion/spw-accordion-item/spw-accordion-item.css +2 -0
- package/dist/collection/components/spw-accordion/spw-accordion-item/spw-accordion-item.js +146 -0
- package/dist/collection/components/spw-accordion/spw-accordion-item/spw-accordion-item.js.map +1 -0
- package/dist/collection/components/spw-accordion/spw-accordion-title/spw-accordion-title.css +2 -0
- package/dist/collection/components/spw-accordion/spw-accordion-title/spw-accordion-title.js +64 -0
- package/dist/collection/components/spw-accordion/spw-accordion-title/spw-accordion-title.js.map +1 -0
- package/dist/collection/components/spw-accordion/spw-accordion.css +2 -0
- package/dist/collection/components/spw-accordion/spw-accordion.js +19 -0
- package/dist/collection/components/spw-accordion/spw-accordion.js.map +1 -0
- package/dist/collection/components/spw-breadcrumb/spw-breadcrumb-item/spw-breadcrumb-item.css +2 -0
- package/dist/collection/components/spw-breadcrumb/spw-breadcrumb-item/spw-breadcrumb-item.js +83 -0
- package/dist/collection/components/spw-breadcrumb/spw-breadcrumb-item/spw-breadcrumb-item.js.map +1 -0
- package/dist/collection/components/spw-breadcrumb/spw-breadcrumb.css +2 -0
- package/dist/collection/components/spw-breadcrumb/spw-breadcrumb.js +97 -0
- package/dist/collection/components/spw-breadcrumb/spw-breadcrumb.js.map +1 -0
- package/dist/collection/components/spw-button/spw-button.css +2 -0
- package/dist/collection/components/spw-button/spw-button.js +444 -0
- package/dist/collection/components/spw-button/spw-button.js.map +1 -0
- package/dist/collection/components/spw-card/spw-card-content/spw-card-content.css +2 -0
- package/dist/collection/components/spw-card/spw-card-content/spw-card-content.js +69 -0
- package/dist/collection/components/spw-card/spw-card-content/spw-card-content.js.map +1 -0
- package/dist/collection/components/spw-card/spw-card-excerpt/spw-card-excerpt.css +2 -0
- package/dist/collection/components/spw-card/spw-card-excerpt/spw-card-excerpt.js +52 -0
- package/dist/collection/components/spw-card/spw-card-excerpt/spw-card-excerpt.js.map +1 -0
- package/dist/collection/components/spw-card/spw-card-image/spw-card-image.css +2 -0
- package/dist/collection/components/spw-card/spw-card-image/spw-card-image.js +62 -0
- package/dist/collection/components/spw-card/spw-card-image/spw-card-image.js.map +1 -0
- package/dist/collection/components/spw-card/spw-card-subtag-item/spw-card-subtag-item.css +2 -0
- package/dist/collection/components/spw-card/spw-card-subtag-item/spw-card-subtag-item.js +54 -0
- package/dist/collection/components/spw-card/spw-card-subtag-item/spw-card-subtag-item.js.map +1 -0
- package/dist/collection/components/spw-card/spw-card-subtags/spw-card-subtags.css +2 -0
- package/dist/collection/components/spw-card/spw-card-subtags/spw-card-subtags.js +62 -0
- package/dist/collection/components/spw-card/spw-card-subtags/spw-card-subtags.js.map +1 -0
- package/dist/collection/components/spw-card/spw-card-title/spw-card-title.css +2 -0
- package/dist/collection/components/spw-card/spw-card-title/spw-card-title.js +19 -0
- package/dist/collection/components/spw-card/spw-card-title/spw-card-title.js.map +1 -0
- package/dist/collection/components/spw-card/spw-card.css +2 -0
- package/dist/collection/components/spw-card/spw-card.js +314 -0
- package/dist/collection/components/spw-card/spw-card.js.map +1 -0
- package/dist/collection/components/spw-checkbox/spw-checkbox.css +2 -0
- package/dist/collection/components/spw-checkbox/spw-checkbox.js +238 -0
- package/dist/collection/components/spw-checkbox/spw-checkbox.js.map +1 -0
- package/dist/collection/components/spw-cookies/spw-cookies.css +2 -0
- package/dist/collection/components/spw-cookies/spw-cookies.js +166 -0
- package/dist/collection/components/spw-cookies/spw-cookies.js.map +1 -0
- package/dist/collection/components/spw-custom-select/spw-custom-select.css +2 -0
- package/dist/collection/components/spw-custom-select/spw-custom-select.js +680 -0
- package/dist/collection/components/spw-custom-select/spw-custom-select.js.map +1 -0
- package/dist/collection/components/spw-field-label/spw-field-label.css +2 -0
- package/dist/collection/components/spw-field-label/spw-field-label.js +89 -0
- package/dist/collection/components/spw-field-label/spw-field-label.js.map +1 -0
- package/dist/collection/components/spw-field-message/spw-field-message.css +2 -0
- package/dist/collection/components/spw-field-message/spw-field-message.js +80 -0
- package/dist/collection/components/spw-field-message/spw-field-message.js.map +1 -0
- package/dist/collection/components/spw-file-upload/spw-file-upload.css +2 -0
- package/dist/collection/components/spw-file-upload/spw-file-upload.js +411 -0
- package/dist/collection/components/spw-file-upload/spw-file-upload.js.map +1 -0
- package/dist/collection/components/spw-footer/spw-footer-bottom/spw-footer-bottom.css +2 -0
- package/dist/collection/components/spw-footer/spw-footer-bottom/spw-footer-bottom.js +44 -0
- package/dist/collection/components/spw-footer/spw-footer-bottom/spw-footer-bottom.js.map +1 -0
- package/dist/collection/components/spw-footer/spw-footer-content/spw-footer-content.css +2 -0
- package/dist/collection/components/spw-footer/spw-footer-content/spw-footer-content.js +32 -0
- package/dist/collection/components/spw-footer/spw-footer-content/spw-footer-content.js.map +1 -0
- package/dist/collection/components/spw-footer/spw-footer-content-col/spw-footer-content-col.css +2 -0
- package/dist/collection/components/spw-footer/spw-footer-content-col/spw-footer-content-col.js +43 -0
- package/dist/collection/components/spw-footer/spw-footer-content-col/spw-footer-content-col.js.map +1 -0
- package/dist/collection/components/spw-footer/spw-footer-link/spw-footer-link.css +2 -0
- package/dist/collection/components/spw-footer/spw-footer-link/spw-footer-link.js +62 -0
- package/dist/collection/components/spw-footer/spw-footer-link/spw-footer-link.js.map +1 -0
- package/dist/collection/components/spw-footer/spw-footer-socials/spw-footer-socials.css +2 -0
- package/dist/collection/components/spw-footer/spw-footer-socials/spw-footer-socials.js +19 -0
- package/dist/collection/components/spw-footer/spw-footer-socials/spw-footer-socials.js.map +1 -0
- package/dist/collection/components/spw-footer/spw-footer.css +2 -0
- package/dist/collection/components/spw-footer/spw-footer.js +113 -0
- package/dist/collection/components/spw-footer/spw-footer.js.map +1 -0
- package/dist/collection/components/spw-group/spw-group.css +2 -0
- package/dist/collection/components/spw-group/spw-group.js +181 -0
- package/dist/collection/components/spw-group/spw-group.js.map +1 -0
- package/dist/collection/components/spw-header/spw-header-lang/spw-header-lang.css +2 -0
- package/dist/collection/components/spw-header/spw-header-lang/spw-header-lang.js +46 -0
- package/dist/collection/components/spw-header/spw-header-lang/spw-header-lang.js.map +1 -0
- package/dist/collection/components/spw-header/spw-header-lang-item/spw-header-lang-item.css +2 -0
- package/dist/collection/components/spw-header/spw-header-lang-item/spw-header-lang-item.js +44 -0
- package/dist/collection/components/spw-header/spw-header-lang-item/spw-header-lang-item.js.map +1 -0
- package/dist/collection/components/spw-header/spw-header-navigation/spw-header-navigation.css +2 -0
- package/dist/collection/components/spw-header/spw-header-navigation/spw-header-navigation.js +70 -0
- package/dist/collection/components/spw-header/spw-header-navigation/spw-header-navigation.js.map +1 -0
- package/dist/collection/components/spw-header/spw-header-navigation-dropdown/spw-header-navigation-dropdown.css +2 -0
- package/dist/collection/components/spw-header/spw-header-navigation-dropdown/spw-header-navigation-dropdown.js +19 -0
- package/dist/collection/components/spw-header/spw-header-navigation-dropdown/spw-header-navigation-dropdown.js.map +1 -0
- package/dist/collection/components/spw-header/spw-header-navigation-item/spw-header-navigation-item.css +2 -0
- package/dist/collection/components/spw-header/spw-header-navigation-item/spw-header-navigation-item.js +193 -0
- package/dist/collection/components/spw-header/spw-header-navigation-item/spw-header-navigation-item.js.map +1 -0
- package/dist/collection/components/spw-header/spw-header-persona/spw-header-persona.css +2 -0
- package/dist/collection/components/spw-header/spw-header-persona/spw-header-persona.js +51 -0
- package/dist/collection/components/spw-header/spw-header-persona/spw-header-persona.js.map +1 -0
- package/dist/collection/components/spw-header/spw-header-persona-item/spw-header-persona-item.css +2 -0
- package/dist/collection/components/spw-header/spw-header-persona-item/spw-header-persona-item.js +44 -0
- package/dist/collection/components/spw-header/spw-header-persona-item/spw-header-persona-item.js.map +1 -0
- package/dist/collection/components/spw-header/spw-header.css +2 -0
- package/dist/collection/components/spw-header/spw-header.js +36 -0
- package/dist/collection/components/spw-header/spw-header.js.map +1 -0
- package/dist/collection/components/spw-icon/assets/LICENSE.txt +165 -0
- package/dist/collection/components/spw-icon/assets/all.css +7913 -0
- package/dist/collection/components/spw-icon/assets/all.min.css +9 -0
- package/dist/collection/components/spw-icon/assets/brands.css +1609 -0
- package/dist/collection/components/spw-icon/assets/brands.min.css +6 -0
- package/dist/collection/components/spw-icon/assets/fa-brands-400.ttf +0 -0
- package/dist/collection/components/spw-icon/assets/fa-brands-400.woff2 +0 -0
- package/dist/collection/components/spw-icon/assets/fa-regular-400.ttf +0 -0
- package/dist/collection/components/spw-icon/assets/fa-regular-400.woff2 +0 -0
- package/dist/collection/components/spw-icon/assets/fa-solid-900.ttf +0 -0
- package/dist/collection/components/spw-icon/assets/fa-solid-900.woff2 +0 -0
- package/dist/collection/components/spw-icon/assets/fa-v4compatibility.ttf +0 -0
- package/dist/collection/components/spw-icon/assets/fa-v4compatibility.woff2 +0 -0
- package/dist/collection/components/spw-icon/assets/fontawesome.css +6243 -0
- package/dist/collection/components/spw-icon/assets/fontawesome.min.css +9 -0
- package/dist/collection/components/spw-icon/assets/regular.css +19 -0
- package/dist/collection/components/spw-icon/assets/regular.min.css +6 -0
- package/dist/collection/components/spw-icon/assets/solid.css +19 -0
- package/dist/collection/components/spw-icon/assets/solid.min.css +6 -0
- package/dist/collection/components/spw-icon/assets/svg-with-js.css +461 -0
- package/dist/collection/components/spw-icon/assets/svg-with-js.min.css +6 -0
- package/dist/collection/components/spw-icon/assets/v4-font-face.css +26 -0
- package/dist/collection/components/spw-icon/assets/v4-font-face.min.css +6 -0
- package/dist/collection/components/spw-icon/assets/v4-shims.css +2194 -0
- package/dist/collection/components/spw-icon/assets/v4-shims.min.css +6 -0
- package/dist/collection/components/spw-icon/assets/v5-font-face.css +22 -0
- package/dist/collection/components/spw-icon/assets/v5-font-face.min.css +6 -0
- package/dist/collection/components/spw-icon/spw-icon.css +10 -0
- package/dist/collection/components/spw-icon/spw-icon.js +64 -0
- package/dist/collection/components/spw-icon/spw-icon.js.map +1 -0
- package/dist/collection/components/spw-iodda/spw-iodda.css +2 -0
- package/dist/collection/components/spw-iodda/spw-iodda.js +113 -0
- package/dist/collection/components/spw-iodda/spw-iodda.js.map +1 -0
- package/dist/collection/components/spw-iodda/spw-iodda.service.js +19 -0
- package/dist/collection/components/spw-iodda/spw-iodda.service.js.map +1 -0
- package/dist/collection/components/spw-link/spw-link.css +2 -0
- package/dist/collection/components/spw-link/spw-link.js +220 -0
- package/dist/collection/components/spw-link/spw-link.js.map +1 -0
- package/dist/collection/components/spw-loading/spw-loading.css +2 -0
- package/dist/collection/components/spw-loading/spw-loading.js +44 -0
- package/dist/collection/components/spw-loading/spw-loading.js.map +1 -0
- package/dist/collection/components/spw-message/spw-message.css +2 -0
- package/dist/collection/components/spw-message/spw-message.js +141 -0
- package/dist/collection/components/spw-message/spw-message.js.map +1 -0
- package/dist/collection/components/spw-message/utils.js +27 -0
- package/dist/collection/components/spw-modal/spw-modal.css +2 -0
- package/dist/collection/components/spw-modal/spw-modal.js +361 -0
- package/dist/collection/components/spw-modal/spw-modal.js.map +1 -0
- package/dist/collection/components/spw-mosaic/spw-mosaic-item/spw-mosaic-item.css +2 -0
- package/dist/collection/components/spw-mosaic/spw-mosaic-item/spw-mosaic-item.js +40 -0
- package/dist/collection/components/spw-mosaic/spw-mosaic-item/spw-mosaic-item.js.map +1 -0
- package/dist/collection/components/spw-mosaic/spw-mosaic.css +2 -0
- package/dist/collection/components/spw-mosaic/spw-mosaic.js +301 -0
- package/dist/collection/components/spw-mosaic/spw-mosaic.js.map +1 -0
- package/dist/collection/components/spw-pagination/spw-pagination.css +2 -0
- package/dist/collection/components/spw-pagination/spw-pagination.js +305 -0
- package/dist/collection/components/spw-pagination/spw-pagination.js.map +1 -0
- package/dist/collection/components/spw-radio/spw-radio.css +2 -0
- package/dist/collection/components/spw-radio/spw-radio.js +248 -0
- package/dist/collection/components/spw-radio/spw-radio.js.map +1 -0
- package/dist/collection/components/spw-search-field/spw-search-field.css +2 -0
- package/dist/collection/components/spw-search-field/spw-search-field.js +287 -0
- package/dist/collection/components/spw-search-field/spw-search-field.js.map +1 -0
- package/dist/collection/components/spw-select/spw-select.css +2 -0
- package/dist/collection/components/spw-select/spw-select.js +374 -0
- package/dist/collection/components/spw-select/spw-select.js.map +1 -0
- package/dist/collection/components/spw-separator/spw-separator.css +2 -0
- package/dist/collection/components/spw-separator/spw-separator.js +134 -0
- package/dist/collection/components/spw-separator/spw-separator.js.map +1 -0
- package/dist/collection/components/spw-table/spw-table-body/spw-table-body.css +2 -0
- package/dist/collection/components/spw-table/spw-table-body/spw-table-body.js +19 -0
- package/dist/collection/components/spw-table/spw-table-body/spw-table-body.js.map +1 -0
- package/dist/collection/components/spw-table/spw-table-cell/spw-table-cell.css +2 -0
- package/dist/collection/components/spw-table/spw-table-cell/spw-table-cell.js +159 -0
- package/dist/collection/components/spw-table/spw-table-cell/spw-table-cell.js.map +1 -0
- package/dist/collection/components/spw-table/spw-table-head/spw-table-head.css +2 -0
- package/dist/collection/components/spw-table/spw-table-head/spw-table-head.js +19 -0
- package/dist/collection/components/spw-table/spw-table-head/spw-table-head.js.map +1 -0
- package/dist/collection/components/spw-table/spw-table-header/spw-table-header.css +2 -0
- package/dist/collection/components/spw-table/spw-table-header/spw-table-header.js +158 -0
- package/dist/collection/components/spw-table/spw-table-header/spw-table-header.js.map +1 -0
- package/dist/collection/components/spw-table/spw-table-row/spw-table-row.css +2 -0
- package/dist/collection/components/spw-table/spw-table-row/spw-table-row.js +19 -0
- package/dist/collection/components/spw-table/spw-table-row/spw-table-row.js.map +1 -0
- package/dist/collection/components/spw-table/spw-table.css +2 -0
- package/dist/collection/components/spw-table/spw-table.js +115 -0
- package/dist/collection/components/spw-table/spw-table.js.map +1 -0
- package/dist/collection/components/spw-text-field/spw-text-field.css +2 -0
- package/dist/collection/components/spw-text-field/spw-text-field.js +480 -0
- package/dist/collection/components/spw-text-field/spw-text-field.js.map +1 -0
- package/dist/collection/components/spw-textarea/spw-textarea.css +2 -0
- package/dist/collection/components/spw-textarea/spw-textarea.js +450 -0
- package/dist/collection/components/spw-textarea/spw-textarea.js.map +1 -0
- package/dist/collection/components/spw-theme-provider/spw-theme-provider.js +59 -0
- package/dist/collection/components/spw-theme-provider/spw-theme-provider.js.map +1 -0
- package/dist/collection/components/spw-tooltip/spw-tooltip.css +2 -0
- package/dist/collection/components/spw-tooltip/spw-tooltip.js +100 -0
- package/dist/collection/components/spw-tooltip/spw-tooltip.js.map +1 -0
- package/dist/collection/index.js +2 -0
- package/dist/collection/index.js.map +1 -0
- package/dist/collection/stories/assets/accessibility.svg +5 -0
- package/dist/collection/stories/assets/discord.svg +15 -0
- package/dist/collection/stories/assets/github.svg +3 -0
- package/dist/collection/stories/assets/logo.svg +18 -0
- package/dist/collection/stories/assets/tutorials.svg +12 -0
- package/dist/collection/stories/assets/youtube.svg +4 -0
- package/dist/collection/stories/components/spw-accordion/spw-accordion.stories.js +72 -0
- package/dist/collection/stories/components/spw-accordion/spw-accordion.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-breadcrumb/spw-breadcrumb.stories.js +66 -0
- package/dist/collection/stories/components/spw-breadcrumb/spw-breadcrumb.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-button/spw-button.stories.js +74 -0
- package/dist/collection/stories/components/spw-button/spw-button.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-card/spw-card.stories.js +183 -0
- package/dist/collection/stories/components/spw-card/spw-card.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-checkbox/spw-checkbox.stories.js +61 -0
- package/dist/collection/stories/components/spw-checkbox/spw-checkbox.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-cookies/spw-cookies.stories.js +56 -0
- package/dist/collection/stories/components/spw-cookies/spw-cookies.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-field-message/spw-field-message.stories.js +67 -0
- package/dist/collection/stories/components/spw-field-message/spw-field-message.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-file-upload/spw-file-upload.stories.js +53 -0
- package/dist/collection/stories/components/spw-file-upload/spw-file-upload.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-footer/spw-footer.stories.js +126 -0
- package/dist/collection/stories/components/spw-footer/spw-footer.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-group/spw-group.stories.js +81 -0
- package/dist/collection/stories/components/spw-group/spw-group.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-header/spw-header.stories.js +135 -0
- package/dist/collection/stories/components/spw-header/spw-header.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-icon/spw-icon.stories.js +54 -0
- package/dist/collection/stories/components/spw-icon/spw-icon.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-link/spw-link.stories.js +66 -0
- package/dist/collection/stories/components/spw-link/spw-link.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-loading/spw-loading.stories.js +58 -0
- package/dist/collection/stories/components/spw-loading/spw-loading.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-message/spw-message.stories.js +67 -0
- package/dist/collection/stories/components/spw-message/spw-message.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-modal/spw-modal.stories.js +111 -0
- package/dist/collection/stories/components/spw-modal/spw-modal.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-mosaic/spw-mosaic.stories.js +146 -0
- package/dist/collection/stories/components/spw-mosaic/spw-mosaic.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-pagination/spw-pagination.stories.js +93 -0
- package/dist/collection/stories/components/spw-pagination/spw-pagination.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-radio/spw-radio.stories.js +62 -0
- package/dist/collection/stories/components/spw-radio/spw-radio.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-search-field/spw-search-field.stories.js +60 -0
- package/dist/collection/stories/components/spw-search-field/spw-search-field.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-select/spw-select.stories.js +65 -0
- package/dist/collection/stories/components/spw-select/spw-select.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-separator/spw-separator.stories.js +63 -0
- package/dist/collection/stories/components/spw-separator/spw-separator.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-table/spw-table.stories.js +103 -0
- package/dist/collection/stories/components/spw-table/spw-table.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-text-field/spw-text-field.stories.js +61 -0
- package/dist/collection/stories/components/spw-text-field/spw-text-field.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-textarea/spw-textarea.stories.js +61 -0
- package/dist/collection/stories/components/spw-textarea/spw-textarea.stories.js.map +1 -0
- package/dist/collection/stories/components/spw-tooltip/spw-tooltip.stories.js +58 -0
- package/dist/collection/stories/components/spw-tooltip/spw-tooltip.stories.js.map +1 -0
- package/dist/collection/themes/themes.js +23 -0
- package/dist/collection/themes/themes.js.map +1 -0
- package/dist/collection/utils/animation.js +23 -0
- package/dist/collection/utils/animation.js.map +1 -0
- package/dist/collection/utils/focus-trap.js +113 -0
- package/dist/collection/utils/focus-trap.js.map +1 -0
- package/dist/collection/utils/utils.js +224 -0
- package/dist/collection/utils/utils.js.map +1 -0
- package/dist/components/index.d.ts +33 -0
- package/dist/components/index.js +3 -0
- package/dist/components/index.js.map +1 -0
- package/dist/components/p-0e197bb5.js +231 -0
- package/dist/components/p-0e197bb5.js.map +1 -0
- package/dist/components/p-1808c8c6.js +81 -0
- package/dist/components/p-1808c8c6.js.map +1 -0
- package/dist/components/p-3706b88e.js +1816 -0
- package/dist/components/p-3706b88e.js.map +1 -0
- package/dist/components/p-70d767cd.js +19 -0
- package/dist/components/p-70d767cd.js.map +1 -0
- package/dist/components/p-72ca702e.js +40 -0
- package/dist/components/p-72ca702e.js.map +1 -0
- package/dist/components/p-89cf5afe.js +138 -0
- package/dist/components/p-89cf5afe.js.map +1 -0
- package/dist/components/p-987e354f.js +123 -0
- package/dist/components/p-987e354f.js.map +1 -0
- package/dist/components/p-a9181b0a.js +46 -0
- package/dist/components/p-a9181b0a.js.map +1 -0
- package/dist/components/p-b3b66a09.js +48 -0
- package/dist/components/p-b3b66a09.js.map +1 -0
- package/dist/components/p-cb0eb249.js +36 -0
- package/dist/components/p-cb0eb249.js.map +1 -0
- package/dist/components/p-cb99b731.js +153 -0
- package/dist/components/p-cb99b731.js.map +1 -0
- package/dist/components/p-def4fee9.js +33 -0
- package/dist/components/p-def4fee9.js.map +1 -0
- package/dist/components/p-e37034cf.js +143 -0
- package/dist/components/p-e37034cf.js.map +1 -0
- package/dist/components/p-e70f2b83.js +62 -0
- package/dist/components/p-e70f2b83.js.map +1 -0
- package/dist/components/p-f48f06ae.js +91 -0
- package/dist/components/p-f48f06ae.js.map +1 -0
- package/dist/components/spw-accordion-content.d.ts +11 -0
- package/dist/components/spw-accordion-content.js +8 -0
- package/dist/components/spw-accordion-content.js.map +1 -0
- package/dist/components/spw-accordion-item.d.ts +11 -0
- package/dist/components/spw-accordion-item.js +8 -0
- package/dist/components/spw-accordion-item.js.map +1 -0
- package/dist/components/spw-accordion-title.d.ts +11 -0
- package/dist/components/spw-accordion-title.js +8 -0
- package/dist/components/spw-accordion-title.js.map +1 -0
- package/dist/components/spw-accordion.d.ts +11 -0
- package/dist/components/spw-accordion.js +8 -0
- package/dist/components/spw-accordion.js.map +1 -0
- package/dist/components/spw-breadcrumb-item.d.ts +11 -0
- package/dist/components/spw-breadcrumb-item.js +85 -0
- package/dist/components/spw-breadcrumb-item.js.map +1 -0
- package/dist/components/spw-breadcrumb.d.ts +11 -0
- package/dist/components/spw-breadcrumb.js +75 -0
- package/dist/components/spw-breadcrumb.js.map +1 -0
- package/dist/components/spw-button.d.ts +11 -0
- package/dist/components/spw-button.js +8 -0
- package/dist/components/spw-button.js.map +1 -0
- package/dist/components/spw-card-content.d.ts +11 -0
- package/dist/components/spw-card-content.js +45 -0
- package/dist/components/spw-card-content.js.map +1 -0
- package/dist/components/spw-card-excerpt.d.ts +11 -0
- package/dist/components/spw-card-excerpt.js +47 -0
- package/dist/components/spw-card-excerpt.js.map +1 -0
- package/dist/components/spw-card-image.d.ts +11 -0
- package/dist/components/spw-card-image.js +64 -0
- package/dist/components/spw-card-image.js.map +1 -0
- package/dist/components/spw-card-subtag-item.d.ts +11 -0
- package/dist/components/spw-card-subtag-item.js +50 -0
- package/dist/components/spw-card-subtag-item.js.map +1 -0
- package/dist/components/spw-card-subtags.d.ts +11 -0
- package/dist/components/spw-card-subtags.js +57 -0
- package/dist/components/spw-card-subtags.js.map +1 -0
- package/dist/components/spw-card-title.d.ts +11 -0
- package/dist/components/spw-card-title.js +36 -0
- package/dist/components/spw-card-title.js.map +1 -0
- package/dist/components/spw-card.d.ts +11 -0
- package/dist/components/spw-card.js +136 -0
- package/dist/components/spw-card.js.map +1 -0
- package/dist/components/spw-checkbox.d.ts +11 -0
- package/dist/components/spw-checkbox.js +8 -0
- package/dist/components/spw-checkbox.js.map +1 -0
- package/dist/components/spw-cookies.d.ts +11 -0
- package/dist/components/spw-cookies.js +148 -0
- package/dist/components/spw-cookies.js.map +1 -0
- package/dist/components/spw-custom-select.d.ts +11 -0
- package/dist/components/spw-custom-select.js +407 -0
- package/dist/components/spw-custom-select.js.map +1 -0
- package/dist/components/spw-field-label.d.ts +11 -0
- package/dist/components/spw-field-label.js +8 -0
- package/dist/components/spw-field-label.js.map +1 -0
- package/dist/components/spw-field-message.d.ts +11 -0
- package/dist/components/spw-field-message.js +8 -0
- package/dist/components/spw-field-message.js.map +1 -0
- package/dist/components/spw-file-upload.d.ts +11 -0
- package/dist/components/spw-file-upload.js +238 -0
- package/dist/components/spw-file-upload.js.map +1 -0
- package/dist/components/spw-footer-bottom.d.ts +11 -0
- package/dist/components/spw-footer-bottom.js +39 -0
- package/dist/components/spw-footer-bottom.js.map +1 -0
- package/dist/components/spw-footer-content-col.d.ts +11 -0
- package/dist/components/spw-footer-content-col.js +39 -0
- package/dist/components/spw-footer-content-col.js.map +1 -0
- package/dist/components/spw-footer-content.d.ts +11 -0
- package/dist/components/spw-footer-content.js +49 -0
- package/dist/components/spw-footer-content.js.map +1 -0
- package/dist/components/spw-footer-link.d.ts +11 -0
- package/dist/components/spw-footer-link.js +41 -0
- package/dist/components/spw-footer-link.js.map +1 -0
- package/dist/components/spw-footer-socials.d.ts +11 -0
- package/dist/components/spw-footer-socials.js +36 -0
- package/dist/components/spw-footer-socials.js.map +1 -0
- package/dist/components/spw-footer.d.ts +11 -0
- package/dist/components/spw-footer.js +71 -0
- package/dist/components/spw-footer.js.map +1 -0
- package/dist/components/spw-group.d.ts +11 -0
- package/dist/components/spw-group.js +82 -0
- package/dist/components/spw-group.js.map +1 -0
- package/dist/components/spw-header-lang-item.d.ts +11 -0
- package/dist/components/spw-header-lang-item.js +39 -0
- package/dist/components/spw-header-lang-item.js.map +1 -0
- package/dist/components/spw-header-lang.d.ts +11 -0
- package/dist/components/spw-header-lang.js +70 -0
- package/dist/components/spw-header-lang.js.map +1 -0
- package/dist/components/spw-header-navigation-dropdown.d.ts +11 -0
- package/dist/components/spw-header-navigation-dropdown.js +36 -0
- package/dist/components/spw-header-navigation-dropdown.js.map +1 -0
- package/dist/components/spw-header-navigation-item.d.ts +11 -0
- package/dist/components/spw-header-navigation-item.js +168 -0
- package/dist/components/spw-header-navigation-item.js.map +1 -0
- package/dist/components/spw-header-navigation.d.ts +11 -0
- package/dist/components/spw-header-navigation.js +79 -0
- package/dist/components/spw-header-navigation.js.map +1 -0
- package/dist/components/spw-header-persona-item.d.ts +11 -0
- package/dist/components/spw-header-persona-item.js +39 -0
- package/dist/components/spw-header-persona-item.js.map +1 -0
- package/dist/components/spw-header-persona.d.ts +11 -0
- package/dist/components/spw-header-persona.js +69 -0
- package/dist/components/spw-header-persona.js.map +1 -0
- package/dist/components/spw-header.d.ts +11 -0
- package/dist/components/spw-header.js +60 -0
- package/dist/components/spw-header.js.map +1 -0
- package/dist/components/spw-icon.d.ts +11 -0
- package/dist/components/spw-icon.js +8 -0
- package/dist/components/spw-icon.js.map +1 -0
- package/dist/components/spw-iodda.d.ts +11 -0
- package/dist/components/spw-iodda.js +179 -0
- package/dist/components/spw-iodda.js.map +1 -0
- package/dist/components/spw-link.d.ts +11 -0
- package/dist/components/spw-link.js +8 -0
- package/dist/components/spw-link.js.map +1 -0
- package/dist/components/spw-loading.d.ts +11 -0
- package/dist/components/spw-loading.js +8 -0
- package/dist/components/spw-loading.js.map +1 -0
- package/dist/components/spw-message.d.ts +11 -0
- package/dist/components/spw-message.js +104 -0
- package/dist/components/spw-message.js.map +1 -0
- package/dist/components/spw-modal.d.ts +11 -0
- package/dist/components/spw-modal.js +324 -0
- package/dist/components/spw-modal.js.map +1 -0
- package/dist/components/spw-mosaic-item.d.ts +11 -0
- package/dist/components/spw-mosaic-item.js +52 -0
- package/dist/components/spw-mosaic-item.js.map +1 -0
- package/dist/components/spw-mosaic.d.ts +11 -0
- package/dist/components/spw-mosaic.js +2507 -0
- package/dist/components/spw-mosaic.js.map +1 -0
- package/dist/components/spw-pagination.d.ts +11 -0
- package/dist/components/spw-pagination.js +8 -0
- package/dist/components/spw-pagination.js.map +1 -0
- package/dist/components/spw-radio.d.ts +11 -0
- package/dist/components/spw-radio.js +131 -0
- package/dist/components/spw-radio.js.map +1 -0
- package/dist/components/spw-search-field.d.ts +11 -0
- package/dist/components/spw-search-field.js +203 -0
- package/dist/components/spw-search-field.js.map +1 -0
- package/dist/components/spw-select.d.ts +11 -0
- package/dist/components/spw-select.js +149 -0
- package/dist/components/spw-select.js.map +1 -0
- package/dist/components/spw-separator.d.ts +11 -0
- package/dist/components/spw-separator.js +61 -0
- package/dist/components/spw-separator.js.map +1 -0
- package/dist/components/spw-table-body.d.ts +11 -0
- package/dist/components/spw-table-body.js +36 -0
- package/dist/components/spw-table-body.js.map +1 -0
- package/dist/components/spw-table-cell.d.ts +11 -0
- package/dist/components/spw-table-cell.js +57 -0
- package/dist/components/spw-table-cell.js.map +1 -0
- package/dist/components/spw-table-head.d.ts +11 -0
- package/dist/components/spw-table-head.js +36 -0
- package/dist/components/spw-table-head.js.map +1 -0
- package/dist/components/spw-table-header.d.ts +11 -0
- package/dist/components/spw-table-header.js +56 -0
- package/dist/components/spw-table-header.js.map +1 -0
- package/dist/components/spw-table-row.d.ts +11 -0
- package/dist/components/spw-table-row.js +36 -0
- package/dist/components/spw-table-row.js.map +1 -0
- package/dist/components/spw-table.d.ts +11 -0
- package/dist/components/spw-table.js +61 -0
- package/dist/components/spw-table.js.map +1 -0
- package/dist/components/spw-text-field.d.ts +11 -0
- package/dist/components/spw-text-field.js +8 -0
- package/dist/components/spw-text-field.js.map +1 -0
- package/dist/components/spw-textarea.d.ts +11 -0
- package/dist/components/spw-textarea.js +143 -0
- package/dist/components/spw-textarea.js.map +1 -0
- package/dist/components/spw-theme-provider.d.ts +11 -0
- package/dist/components/spw-theme-provider.js +96 -0
- package/dist/components/spw-theme-provider.js.map +1 -0
- package/dist/components/spw-tooltip.d.ts +11 -0
- package/dist/components/spw-tooltip.js +57 -0
- package/dist/components/spw-tooltip.js.map +1 -0
- package/dist/components_json.d.ts +435 -0
- package/dist/components_json.json +7153 -0
- package/dist/esm/app-globals-0f993ce5.js +5 -0
- package/dist/esm/app-globals-0f993ce5.js.map +1 -0
- package/dist/esm/index-080912e4.js +1926 -0
- package/dist/esm/index-080912e4.js.map +1 -0
- package/dist/esm/index.js +3 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/loader.js +13 -0
- package/dist/esm/loader.js.map +1 -0
- package/dist/esm/spw-accordion_58.entry.js +5894 -0
- package/dist/esm/spw-accordion_58.entry.js.map +1 -0
- package/dist/esm/spw-stencil-library.js +22 -0
- package/dist/esm/spw-stencil-library.js.map +1 -0
- package/dist/index.cjs.js +1 -0
- package/dist/index.js +1 -0
- package/dist/spw-stencil-library/assets/LICENSE.txt +165 -0
- package/dist/spw-stencil-library/assets/all.css +7913 -0
- package/dist/spw-stencil-library/assets/all.min.css +9 -0
- package/dist/spw-stencil-library/assets/brands.css +1609 -0
- package/dist/spw-stencil-library/assets/brands.min.css +6 -0
- package/dist/spw-stencil-library/assets/fa-brands-400.ttf +0 -0
- package/dist/spw-stencil-library/assets/fa-brands-400.woff2 +0 -0
- package/dist/spw-stencil-library/assets/fa-regular-400.ttf +0 -0
- package/dist/spw-stencil-library/assets/fa-regular-400.woff2 +0 -0
- package/dist/spw-stencil-library/assets/fa-solid-900.ttf +0 -0
- package/dist/spw-stencil-library/assets/fa-solid-900.woff2 +0 -0
- package/dist/spw-stencil-library/assets/fa-v4compatibility.ttf +0 -0
- package/dist/spw-stencil-library/assets/fa-v4compatibility.woff2 +0 -0
- package/dist/spw-stencil-library/assets/fontawesome.css +6243 -0
- package/dist/spw-stencil-library/assets/fontawesome.min.css +9 -0
- package/dist/spw-stencil-library/assets/regular.css +19 -0
- package/dist/spw-stencil-library/assets/regular.min.css +6 -0
- package/dist/spw-stencil-library/assets/solid.css +19 -0
- package/dist/spw-stencil-library/assets/solid.min.css +6 -0
- package/dist/spw-stencil-library/assets/svg-with-js.css +461 -0
- package/dist/spw-stencil-library/assets/svg-with-js.min.css +6 -0
- package/dist/spw-stencil-library/assets/v4-font-face.css +26 -0
- package/dist/spw-stencil-library/assets/v4-font-face.min.css +6 -0
- package/dist/spw-stencil-library/assets/v4-shims.css +2194 -0
- package/dist/spw-stencil-library/assets/v4-shims.min.css +6 -0
- package/dist/spw-stencil-library/assets/v5-font-face.css +22 -0
- package/dist/spw-stencil-library/assets/v5-font-face.min.css +6 -0
- package/dist/spw-stencil-library/index.esm.js +2 -0
- package/dist/spw-stencil-library/index.esm.js.map +1 -0
- package/dist/spw-stencil-library/p-205fd6a4.js +3 -0
- package/dist/spw-stencil-library/p-205fd6a4.js.map +1 -0
- package/dist/spw-stencil-library/p-d3d3de91.entry.js +19 -0
- package/dist/spw-stencil-library/p-d3d3de91.entry.js.map +1 -0
- package/dist/spw-stencil-library/p-e1255160.js +2 -0
- package/dist/spw-stencil-library/p-e1255160.js.map +1 -0
- package/dist/spw-stencil-library/spw-stencil-library.css +1 -0
- package/dist/spw-stencil-library/spw-stencil-library.esm.js +2 -0
- package/dist/spw-stencil-library/spw-stencil-library.esm.js.map +1 -0
- package/dist/stats.json +19725 -0
- package/dist/types/components/spw-accordion/spw-accordion-content/spw-accordion-content.d.ts +16 -0
- package/dist/types/components/spw-accordion/spw-accordion-item/spw-accordion-item.d.ts +25 -0
- package/dist/types/components/spw-accordion/spw-accordion-title/spw-accordion-title.d.ts +7 -0
- package/dist/types/components/spw-accordion/spw-accordion.d.ts +3 -0
- package/dist/types/components/spw-breadcrumb/spw-breadcrumb-item/spw-breadcrumb-item.d.ts +11 -0
- package/dist/types/components/spw-breadcrumb/spw-breadcrumb.d.ts +13 -0
- package/dist/types/components/spw-button/spw-button.d.ts +48 -0
- package/dist/types/components/spw-card/spw-card-content/spw-card-content.d.ts +9 -0
- package/dist/types/components/spw-card/spw-card-excerpt/spw-card-excerpt.d.ts +6 -0
- package/dist/types/components/spw-card/spw-card-image/spw-card-image.d.ts +8 -0
- package/dist/types/components/spw-card/spw-card-subtag-item/spw-card-subtag-item.d.ts +7 -0
- package/dist/types/components/spw-card/spw-card-subtags/spw-card-subtags.d.ts +9 -0
- package/dist/types/components/spw-card/spw-card-title/spw-card-title.d.ts +3 -0
- package/dist/types/components/spw-card/spw-card.d.ts +34 -0
- package/dist/types/components/spw-checkbox/spw-checkbox.d.ts +30 -0
- package/dist/types/components/spw-cookies/spw-cookies.d.ts +21 -0
- package/dist/types/components/spw-custom-select/spw-custom-select.d.ts +79 -0
- package/dist/types/components/spw-field-label/spw-field-label.d.ts +11 -0
- package/dist/types/components/spw-field-message/spw-field-message.d.ts +9 -0
- package/dist/types/components/spw-file-upload/spw-file-upload.d.ts +53 -0
- package/dist/types/components/spw-footer/spw-footer-bottom/spw-footer-bottom.d.ts +5 -0
- package/dist/types/components/spw-footer/spw-footer-content/spw-footer-content.d.ts +7 -0
- package/dist/types/components/spw-footer/spw-footer-content-col/spw-footer-content-col.d.ts +5 -0
- package/dist/types/components/spw-footer/spw-footer-link/spw-footer-link.d.ts +7 -0
- package/dist/types/components/spw-footer/spw-footer-socials/spw-footer-socials.d.ts +3 -0
- package/dist/types/components/spw-footer/spw-footer.d.ts +13 -0
- package/dist/types/components/spw-group/spw-group.d.ts +22 -0
- package/dist/types/components/spw-header/spw-header-lang/spw-header-lang.d.ts +8 -0
- package/dist/types/components/spw-header/spw-header-lang-item/spw-header-lang-item.d.ts +4 -0
- package/dist/types/components/spw-header/spw-header-navigation/spw-header-navigation.d.ts +12 -0
- package/dist/types/components/spw-header/spw-header-navigation-dropdown/spw-header-navigation-dropdown.d.ts +3 -0
- package/dist/types/components/spw-header/spw-header-navigation-item/spw-header-navigation-item.d.ts +26 -0
- package/dist/types/components/spw-header/spw-header-persona/spw-header-persona.d.ts +10 -0
- package/dist/types/components/spw-header/spw-header-persona-item/spw-header-persona-item.d.ts +4 -0
- package/dist/types/components/spw-header/spw-header.d.ts +6 -0
- package/dist/types/components/spw-icon/spw-icon.d.ts +7 -0
- package/dist/types/components/spw-iodda/spw-iodda.d.ts +19 -0
- package/dist/types/components/spw-iodda/spw-iodda.service.d.ts +1 -0
- package/dist/types/components/spw-link/spw-link.d.ts +25 -0
- package/dist/types/components/spw-loading/spw-loading.d.ts +5 -0
- package/dist/types/components/spw-message/spw-message.d.ts +18 -0
- package/dist/types/components/spw-modal/spw-modal.d.ts +53 -0
- package/dist/types/components/spw-mosaic/spw-mosaic-item/spw-mosaic-item.d.ts +8 -0
- package/dist/types/components/spw-mosaic/spw-mosaic.d.ts +31 -0
- package/dist/types/components/spw-pagination/spw-pagination.d.ts +30 -0
- package/dist/types/components/spw-radio/spw-radio.d.ts +35 -0
- package/dist/types/components/spw-search-field/spw-search-field.d.ts +39 -0
- package/dist/types/components/spw-select/spw-select.d.ts +48 -0
- package/dist/types/components/spw-separator/spw-separator.d.ts +15 -0
- package/dist/types/components/spw-table/spw-table-body/spw-table-body.d.ts +3 -0
- package/dist/types/components/spw-table/spw-table-cell/spw-table-cell.d.ts +16 -0
- package/dist/types/components/spw-table/spw-table-head/spw-table-head.d.ts +3 -0
- package/dist/types/components/spw-table/spw-table-header/spw-table-header.d.ts +16 -0
- package/dist/types/components/spw-table/spw-table-row/spw-table-row.d.ts +3 -0
- package/dist/types/components/spw-table/spw-table.d.ts +23 -0
- package/dist/types/components/spw-text-field/spw-text-field.d.ts +57 -0
- package/dist/types/components/spw-textarea/spw-textarea.d.ts +53 -0
- package/dist/types/components/spw-theme-provider/spw-theme-provider.d.ts +10 -0
- package/dist/types/components/spw-tooltip/spw-tooltip.d.ts +13 -0
- package/dist/types/components.d.ts +2793 -0
- package/dist/types/index.d.ts +1 -0
- package/dist/types/stencil-public-runtime.d.ts +1678 -0
- package/dist/types/stories/components/spw-accordion/spw-accordion.stories.d.ts +4 -0
- package/dist/types/stories/components/spw-breadcrumb/spw-breadcrumb.stories.d.ts +5 -0
- package/dist/types/stories/components/spw-button/spw-button.stories.d.ts +7 -0
- package/dist/types/stories/components/spw-card/spw-card.stories.d.ts +10 -0
- package/dist/types/stories/components/spw-checkbox/spw-checkbox.stories.d.ts +4 -0
- package/dist/types/stories/components/spw-cookies/spw-cookies.stories.d.ts +4 -0
- package/dist/types/stories/components/spw-field-message/spw-field-message.stories.d.ts +6 -0
- package/dist/types/stories/components/spw-file-upload/spw-file-upload.stories.d.ts +4 -0
- package/dist/types/stories/components/spw-footer/spw-footer.stories.d.ts +5 -0
- package/dist/types/stories/components/spw-group/spw-group.stories.d.ts +6 -0
- package/dist/types/stories/components/spw-header/spw-header.stories.d.ts +4 -0
- package/dist/types/stories/components/spw-icon/spw-icon.stories.d.ts +4 -0
- package/dist/types/stories/components/spw-link/spw-link.stories.d.ts +5 -0
- package/dist/types/stories/components/spw-loading/spw-loading.stories.d.ts +5 -0
- package/dist/types/stories/components/spw-message/spw-message.stories.d.ts +8 -0
- package/dist/types/stories/components/spw-modal/spw-modal.stories.d.ts +8 -0
- package/dist/types/stories/components/spw-mosaic/spw-mosaic.stories.d.ts +4 -0
- package/dist/types/stories/components/spw-pagination/spw-pagination.stories.d.ts +22 -0
- package/dist/types/stories/components/spw-radio/spw-radio.stories.d.ts +4 -0
- package/dist/types/stories/components/spw-search-field/spw-search-field.stories.d.ts +4 -0
- package/dist/types/stories/components/spw-select/spw-select.stories.d.ts +4 -0
- package/dist/types/stories/components/spw-separator/spw-separator.stories.d.ts +5 -0
- package/dist/types/stories/components/spw-table/spw-table.stories.d.ts +4 -0
- package/dist/types/stories/components/spw-text-field/spw-text-field.stories.d.ts +4 -0
- package/dist/types/stories/components/spw-textarea/spw-textarea.stories.d.ts +4 -0
- package/dist/types/stories/components/spw-tooltip/spw-tooltip.stories.d.ts +4 -0
- package/dist/types/themes/themes.d.ts +13 -0
- package/dist/types/utils/animation.d.ts +13 -0
- package/dist/types/utils/focus-trap.d.ts +33 -0
- package/dist/types/utils/utils.d.ts +11 -0
- package/hydrate/index.d.ts +242 -0
- package/hydrate/index.js +24773 -0
- package/hydrate/index.mjs +24765 -0
- package/hydrate/package.json +12 -0
- package/loader/cdn.js +1 -0
- package/loader/index.cjs.js +1 -0
- package/loader/index.d.ts +24 -0
- package/loader/index.es2017.js +1 -0
- package/loader/index.js +2 -0
- package/loader/package.json +11 -0
- package/package.json +88 -0
|
@@ -0,0 +1,224 @@
|
|
|
1
|
+
export function format(first, middle, last) {
|
|
2
|
+
return (first || '') + (middle ? ` ${middle}` : '') + (last ? ` ${last}` : '');
|
|
3
|
+
}
|
|
4
|
+
export function toKebabCase(str) {
|
|
5
|
+
return str.replace(/([a-z0-9])([A-Z])/g, '$1-$2').toLowerCase();
|
|
6
|
+
}
|
|
7
|
+
export function formatDate(date) {
|
|
8
|
+
const parts = date.split('-');
|
|
9
|
+
return `${parts[2]}.${parts[1]}.${parts[0]}`;
|
|
10
|
+
}
|
|
11
|
+
export function stripHtmlContent(content) {
|
|
12
|
+
const div = document.createElement('div');
|
|
13
|
+
div.innerHTML = content;
|
|
14
|
+
return div.textContent || div.innerText || '';
|
|
15
|
+
}
|
|
16
|
+
const description = (prop) => (prop.docs || '').trim();
|
|
17
|
+
const isText = (prop) => prop.type === 'string';
|
|
18
|
+
const isBoolean = (prop) => prop.type === 'boolean';
|
|
19
|
+
const isEnum = (prop) => prop.type.includes('|');
|
|
20
|
+
const isNumber = (prop) => prop.type === 'number';
|
|
21
|
+
const enumOptions = (prop) => prop.type
|
|
22
|
+
.split('|')
|
|
23
|
+
.map(t => t.trim())
|
|
24
|
+
.map(t => (t === '""' ? 'default' : t))
|
|
25
|
+
.map(t => t.replace(/^"(.*)"$/, '$1'));
|
|
26
|
+
const generateProp = (prop) => {
|
|
27
|
+
if (isText(prop)) {
|
|
28
|
+
return {
|
|
29
|
+
[prop.name]: {
|
|
30
|
+
control: 'text',
|
|
31
|
+
description: description(prop),
|
|
32
|
+
defaultValue: prop.default,
|
|
33
|
+
table: {
|
|
34
|
+
category: 'properties',
|
|
35
|
+
defaultValue: { summary: prop.default },
|
|
36
|
+
type: { summary: 'string' },
|
|
37
|
+
},
|
|
38
|
+
},
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
if (isBoolean(prop)) {
|
|
42
|
+
return {
|
|
43
|
+
[prop.name]: {
|
|
44
|
+
control: 'boolean',
|
|
45
|
+
description: description(prop),
|
|
46
|
+
defaultValue: prop.default,
|
|
47
|
+
table: {
|
|
48
|
+
category: 'properties',
|
|
49
|
+
defaultValue: { summary: prop.default },
|
|
50
|
+
type: { summary: 'boolean' },
|
|
51
|
+
},
|
|
52
|
+
},
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
if (isNumber(prop)) {
|
|
56
|
+
return {
|
|
57
|
+
[prop.name]: {
|
|
58
|
+
control: 'number',
|
|
59
|
+
description: description(prop),
|
|
60
|
+
defaultValue: prop.default,
|
|
61
|
+
table: {
|
|
62
|
+
category: 'properties',
|
|
63
|
+
defaultValue: { summary: prop.default },
|
|
64
|
+
type: { summary: 'number' },
|
|
65
|
+
},
|
|
66
|
+
},
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
if (isEnum(prop)) {
|
|
70
|
+
return {
|
|
71
|
+
[prop.name]: {
|
|
72
|
+
control: 'select',
|
|
73
|
+
defaultValue: prop.default,
|
|
74
|
+
options: enumOptions(prop),
|
|
75
|
+
description: description(prop),
|
|
76
|
+
table: {
|
|
77
|
+
category: 'properties',
|
|
78
|
+
defaultValue: { summary: prop.default },
|
|
79
|
+
type: { summary: 'enum' },
|
|
80
|
+
},
|
|
81
|
+
},
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
return {};
|
|
85
|
+
};
|
|
86
|
+
const generateProps = (props) => {
|
|
87
|
+
let args = {};
|
|
88
|
+
props.forEach(prop => (args = Object.assign(Object.assign({}, args), generateProp(prop))));
|
|
89
|
+
return args;
|
|
90
|
+
};
|
|
91
|
+
const generateEvent = (event) => {
|
|
92
|
+
function capitalizeFirstLetter(string) {
|
|
93
|
+
return string.charAt(0).toUpperCase() + string.slice(1);
|
|
94
|
+
}
|
|
95
|
+
return {
|
|
96
|
+
[`on${capitalizeFirstLetter(event.event)}`]: {
|
|
97
|
+
action: event.event,
|
|
98
|
+
description: description(event),
|
|
99
|
+
table: {
|
|
100
|
+
defaultValue: { summary: event.event },
|
|
101
|
+
category: 'events',
|
|
102
|
+
type: { summary: event.detail },
|
|
103
|
+
},
|
|
104
|
+
},
|
|
105
|
+
};
|
|
106
|
+
};
|
|
107
|
+
const generateEvents = (events) => {
|
|
108
|
+
let args = {};
|
|
109
|
+
events.forEach(event => (args = Object.assign(Object.assign({}, args), generateEvent(event))));
|
|
110
|
+
return args;
|
|
111
|
+
};
|
|
112
|
+
const extractComponentInfoByTag = (componentsData, tag) => {
|
|
113
|
+
const component = componentsData.components.find(c => c.tag === tag);
|
|
114
|
+
if (!component) {
|
|
115
|
+
console.error(`Component with tag ${tag} not found`);
|
|
116
|
+
return null;
|
|
117
|
+
}
|
|
118
|
+
const { props, events } = component;
|
|
119
|
+
const propInfo = props.map(prop => ({
|
|
120
|
+
name: prop.name,
|
|
121
|
+
type: prop.type,
|
|
122
|
+
docs: prop.docs,
|
|
123
|
+
default: prop.default || '',
|
|
124
|
+
}));
|
|
125
|
+
const eventInfo = events.map(event => ({
|
|
126
|
+
event: event.event,
|
|
127
|
+
docs: event.docs,
|
|
128
|
+
detail: event.detail,
|
|
129
|
+
}));
|
|
130
|
+
return {
|
|
131
|
+
name: tag,
|
|
132
|
+
props: propInfo,
|
|
133
|
+
events: eventInfo,
|
|
134
|
+
};
|
|
135
|
+
};
|
|
136
|
+
const generateHTMLTable = (componentInfo) => {
|
|
137
|
+
if (!componentInfo) {
|
|
138
|
+
return `<p>Component not found</p>`;
|
|
139
|
+
}
|
|
140
|
+
const { props, events } = componentInfo;
|
|
141
|
+
const propsRows = props
|
|
142
|
+
.map(prop => `
|
|
143
|
+
<tr>
|
|
144
|
+
<td>${prop.name}</td>
|
|
145
|
+
<td>${prop.type}</td>
|
|
146
|
+
<td>${prop.docs}</td>
|
|
147
|
+
<td>${prop.default}</td>
|
|
148
|
+
</tr>
|
|
149
|
+
`)
|
|
150
|
+
.join('');
|
|
151
|
+
const eventsRows = events
|
|
152
|
+
.map(event => `
|
|
153
|
+
<tr>
|
|
154
|
+
<td>${event.event}</td>
|
|
155
|
+
<td>${event.detail}</td>
|
|
156
|
+
<td>${event.docs}</td>
|
|
157
|
+
</tr>
|
|
158
|
+
`)
|
|
159
|
+
.join('');
|
|
160
|
+
return `
|
|
161
|
+
<h3>Propriétés</h3>
|
|
162
|
+
<table class="w-full">
|
|
163
|
+
<thead>
|
|
164
|
+
<tr>
|
|
165
|
+
<th>Propriété</th>
|
|
166
|
+
<th>Type</th>
|
|
167
|
+
<th>Description</th>
|
|
168
|
+
<th>Valeur par défaut</th>
|
|
169
|
+
</tr>
|
|
170
|
+
</thead>
|
|
171
|
+
<tbody>
|
|
172
|
+
${propsRows}
|
|
173
|
+
</tbody>
|
|
174
|
+
</table>
|
|
175
|
+
<h3>Événements</h3>
|
|
176
|
+
<table class="w-full">
|
|
177
|
+
<thead>
|
|
178
|
+
<tr>
|
|
179
|
+
<th>Événement</th>
|
|
180
|
+
<th>Détail</th>
|
|
181
|
+
<th>Description</th>
|
|
182
|
+
</tr>
|
|
183
|
+
</thead>
|
|
184
|
+
<tbody>
|
|
185
|
+
${eventsRows}
|
|
186
|
+
</tbody>
|
|
187
|
+
</table>
|
|
188
|
+
`;
|
|
189
|
+
};
|
|
190
|
+
export const generateComponentTable = (componentsData, tag) => {
|
|
191
|
+
const componentInfo = extractComponentInfoByTag(componentsData, tag);
|
|
192
|
+
return generateHTMLTable(componentInfo);
|
|
193
|
+
};
|
|
194
|
+
export const withComponentControls = (componentsData, { tag }) => {
|
|
195
|
+
const component = componentsData.components.find(c => c.tag === tag);
|
|
196
|
+
if (component) {
|
|
197
|
+
const props = component.props;
|
|
198
|
+
const events = component.events;
|
|
199
|
+
return Object.assign(Object.assign({}, generateProps(props)), generateEvents(events));
|
|
200
|
+
}
|
|
201
|
+
return {};
|
|
202
|
+
};
|
|
203
|
+
export function extractArgTypes(componentsData, subComponentTags) {
|
|
204
|
+
return subComponentTags.reduce((acc, tag) => {
|
|
205
|
+
const subComponentArgTypes = withComponentControls(componentsData, { tag });
|
|
206
|
+
return Object.assign(Object.assign({}, acc), subComponentArgTypes);
|
|
207
|
+
}, {});
|
|
208
|
+
}
|
|
209
|
+
export function formatFileSize(sizeInBytes) {
|
|
210
|
+
const sizeInMB = sizeInBytes / (1024 * 1024);
|
|
211
|
+
let formattedSize = sizeInMB.toFixed(2).replace('.', ',');
|
|
212
|
+
if (sizeInMB > 0 && sizeInMB < 0.01) {
|
|
213
|
+
formattedSize = '0,01';
|
|
214
|
+
}
|
|
215
|
+
else if (sizeInMB === 0) {
|
|
216
|
+
formattedSize = '0,00';
|
|
217
|
+
}
|
|
218
|
+
return `${formattedSize} Mo`;
|
|
219
|
+
}
|
|
220
|
+
export function hasSlotContent(el) {
|
|
221
|
+
const slot = el.querySelector('slot');
|
|
222
|
+
return slot && slot.assignedNodes().length > 0;
|
|
223
|
+
}
|
|
224
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils/utils.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,MAAM,CAAC,KAAa,EAAE,MAAc,EAAE,IAAY;IAChE,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;AACjF,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,GAAW;IACrC,OAAO,GAAG,CAAC,OAAO,CAAC,oBAAoB,EAAE,OAAO,CAAC,CAAC,WAAW,EAAE,CAAC;AAClE,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,IAAY;IACrC,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAC9B,OAAO,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;AAC/C,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,OAAe;IAC9C,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAC1C,GAAG,CAAC,SAAS,GAAG,OAAO,CAAC;IACxB,OAAO,GAAG,CAAC,WAAW,IAAI,GAAG,CAAC,SAAS,IAAI,EAAE,CAAC;AAChD,CAAC;AAqBD,MAAM,WAAW,GAAG,CAAC,IAAoC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;AAEvF,MAAM,MAAM,GAAG,CAAC,IAAmB,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC;AAC/D,MAAM,SAAS,GAAG,CAAC,IAAmB,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,SAAS,CAAC;AACnE,MAAM,MAAM,GAAG,CAAC,IAAmB,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;AAChE,MAAM,QAAQ,GAAG,CAAC,IAAmB,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC;AAEjE,MAAM,WAAW,GAAG,CAAC,IAAmB,EAAE,EAAE,CAC1C,IAAI,CAAC,IAAI;KACN,KAAK,CAAC,GAAG,CAAC;KACV,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;KAClB,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;KACtC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC,CAAC;AAE3C,MAAM,YAAY,GAAG,CAAC,IAAmB,EAAE,EAAE;IAC3C,IAAI,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC;QACjB,OAAO;YACL,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;gBACX,OAAO,EAAE,MAAM;gBACf,WAAW,EAAE,WAAW,CAAC,IAAI,CAAC;gBAC9B,YAAY,EAAE,IAAI,CAAC,OAAO;gBAC1B,KAAK,EAAE;oBACL,QAAQ,EAAE,YAAY;oBACtB,YAAY,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE;oBACvC,IAAI,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE;iBAC5B;aACF;SACF,CAAC;IACJ,CAAC;IAED,IAAI,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC;QACpB,OAAO;YACL,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;gBACX,OAAO,EAAE,SAAS;gBAClB,WAAW,EAAE,WAAW,CAAC,IAAI,CAAC;gBAC9B,YAAY,EAAE,IAAI,CAAC,OAAO;gBAC1B,KAAK,EAAE;oBACL,QAAQ,EAAE,YAAY;oBACtB,YAAY,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE;oBACvC,IAAI,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE;iBAC7B;aACF;SACF,CAAC;IACJ,CAAC;IAED,IAAI,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;QACnB,OAAO;YACL,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;gBACX,OAAO,EAAE,QAAQ;gBACjB,WAAW,EAAE,WAAW,CAAC,IAAI,CAAC;gBAC9B,YAAY,EAAE,IAAI,CAAC,OAAO;gBAC1B,KAAK,EAAE;oBACL,QAAQ,EAAE,YAAY;oBACtB,YAAY,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE;oBACvC,IAAI,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE;iBAC5B;aACF;SACF,CAAC;IACJ,CAAC;IAED,IAAI,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC;QACjB,OAAO;YACL,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;gBACX,OAAO,EAAE,QAAQ;gBACjB,YAAY,EAAE,IAAI,CAAC,OAAO;gBAC1B,OAAO,EAAE,WAAW,CAAC,IAAI,CAAC;gBAC1B,WAAW,EAAE,WAAW,CAAC,IAAI,CAAC;gBAC9B,KAAK,EAAE;oBACL,QAAQ,EAAE,YAAY;oBACtB,YAAY,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE;oBACvC,IAAI,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE;iBAC1B;aACF;SACF,CAAC;IACJ,CAAC;IAED,OAAO,EAAE,CAAC;AACZ,CAAC,CAAC;AAEF,MAAM,aAAa,GAAG,CAAC,KAAsB,EAAE,EAAE;IAC/C,IAAI,IAAI,GAAG,EAAE,CAAC;IACd,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,mCAAQ,IAAI,GAAK,YAAY,CAAC,IAAI,CAAC,CAAE,CAAC,CAAC,CAAC;IACnE,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAEF,MAAM,aAAa,GAAG,CAAC,KAAqB,EAAE,EAAE;IAC9C,SAAS,qBAAqB,CAAC,MAAc;QAC3C,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAC1D,CAAC;IAED,OAAO;QACL,CAAC,KAAK,qBAAqB,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE;YAC3C,MAAM,EAAE,KAAK,CAAC,KAAK;YACnB,WAAW,EAAE,WAAW,CAAC,KAAK,CAAC;YAC/B,KAAK,EAAE;gBACL,YAAY,EAAE,EAAE,OAAO,EAAE,KAAK,CAAC,KAAK,EAAE;gBACtC,QAAQ,EAAE,QAAQ;gBAClB,IAAI,EAAE,EAAE,OAAO,EAAE,KAAK,CAAC,MAAM,EAAE;aAChC;SACF;KACF,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,cAAc,GAAG,CAAC,MAAwB,EAAE,EAAE;IAClD,IAAI,IAAI,GAAG,EAAE,CAAC;IACd,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,IAAI,mCAAQ,IAAI,GAAK,aAAa,CAAC,KAAK,CAAC,CAAE,CAAC,CAAC,CAAC;IACvE,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAEF,MAAM,yBAAyB,GAAG,CAAC,cAAmB,EAAE,GAAW,EAAwB,EAAE;IAC3F,MAAM,SAAS,GAAG,cAAc,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,GAAG,CAAC,CAAC;IAErE,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,OAAO,CAAC,KAAK,CAAC,sBAAsB,GAAG,YAAY,CAAC,CAAC;QACrD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,SAAS,CAAC;IAEpC,MAAM,QAAQ,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAClC,IAAI,EAAE,IAAI,CAAC,IAAI;QACf,IAAI,EAAE,IAAI,CAAC,IAAI;QACf,IAAI,EAAE,IAAI,CAAC,IAAI;QACf,OAAO,EAAE,IAAI,CAAC,OAAO,IAAI,EAAE;KAC5B,CAAC,CAAC,CAAC;IAEJ,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QACrC,KAAK,EAAE,KAAK,CAAC,KAAK;QAClB,IAAI,EAAE,KAAK,CAAC,IAAI;QAChB,MAAM,EAAE,KAAK,CAAC,MAAM;KACrB,CAAC,CAAC,CAAC;IAEJ,OAAO;QACL,IAAI,EAAE,GAAG;QACT,KAAK,EAAE,QAAQ;QACf,MAAM,EAAE,SAAS;KAClB,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,iBAAiB,GAAG,CAAC,aAA4B,EAAU,EAAE;IACjE,IAAI,CAAC,aAAa,EAAE,CAAC;QACnB,OAAO,4BAA4B,CAAC;IACtC,CAAC;IAED,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,aAAa,CAAC;IAExC,MAAM,SAAS,GAAG,KAAK;SACpB,GAAG,CACF,IAAI,CAAC,EAAE,CAAC;;YAEF,IAAI,CAAC,IAAI;YACT,IAAI,CAAC,IAAI;YACT,IAAI,CAAC,IAAI;YACT,IAAI,CAAC,OAAO;;GAErB,CACE;SACA,IAAI,CAAC,EAAE,CAAC,CAAC;IAEZ,MAAM,UAAU,GAAG,MAAM;SACtB,GAAG,CACF,KAAK,CAAC,EAAE,CAAC;;YAEH,KAAK,CAAC,KAAK;YACX,KAAK,CAAC,MAAM;YACZ,KAAK,CAAC,IAAI;;GAEnB,CACE;SACA,IAAI,CAAC,EAAE,CAAC,CAAC;IAEZ,OAAO;;;;;;;;;;;;UAYC,SAAS;;;;;;;;;;;;;UAaT,UAAU;;;GAGjB,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,cAAmB,EAAE,GAAW,EAAU,EAAE;IACjF,MAAM,aAAa,GAAG,yBAAyB,CAAC,cAAc,EAAE,GAAG,CAAC,CAAC;IACrE,OAAO,iBAAiB,CAAC,aAAa,CAAC,CAAC;AAC1C,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,cAAmB,EAAE,EAAE,GAAG,EAAmB,EAAO,EAAE;IAC1F,MAAM,SAAS,GAAG,cAAc,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,GAAG,CAAC,CAAC;IACrE,IAAI,SAAS,EAAE,CAAC;QACd,MAAM,KAAK,GAAG,SAAS,CAAC,KAAK,CAAC;QAC9B,MAAM,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC;QAEhC,uCACK,aAAa,CAAC,KAAwB,CAAC,GACvC,cAAc,CAAC,MAA0B,CAAC,EAC7C;IACJ,CAAC;IAED,OAAO,EAAE,CAAC;AACZ,CAAC,CAAC;AAEF,MAAM,UAAU,eAAe,CAAC,cAAmB,EAAE,gBAA0B;IAC7E,OAAO,gBAAgB,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;QAC1C,MAAM,oBAAoB,GAAG,qBAAqB,CAAC,cAAc,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC;QAC5E,uCAAY,GAAG,GAAK,oBAAoB,EAAG;IAC7C,CAAC,EAAE,EAAE,CAAC,CAAC;AACT,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,WAAW;IACxC,MAAM,QAAQ,GAAG,WAAW,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;IAC7C,IAAI,aAAa,GAAG,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;IAE1D,IAAI,QAAQ,GAAG,CAAC,IAAI,QAAQ,GAAG,IAAI,EAAE,CAAC;QACpC,aAAa,GAAG,MAAM,CAAC;IACzB,CAAC;SAAM,IAAI,QAAQ,KAAK,CAAC,EAAE,CAAC;QAC1B,aAAa,GAAG,MAAM,CAAC;IACzB,CAAC;IAED,OAAO,GAAG,aAAa,KAAK,CAAC;AAC/B,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,EAAe;IAC5C,MAAM,IAAI,GAAG,EAAE,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;IACtC,OAAO,IAAI,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC;AACjD,CAAC","sourcesContent":["export function format(first: string, middle: string, last: string): string {\n return (first || '') + (middle ? ` ${middle}` : '') + (last ? ` ${last}` : '');\n}\n\nexport function toKebabCase(str: string) {\n return str.replace(/([a-z0-9])([A-Z])/g, '$1-$2').toLowerCase();\n}\n\nexport function formatDate(date: string): string {\n const parts = date.split('-');\n return `${parts[2]}.${parts[1]}.${parts[0]}`;\n}\n\nexport function stripHtmlContent(content: string): string {\n const div = document.createElement('div');\n div.innerHTML = content;\n return div.textContent || div.innerText || '';\n}\n\ninterface ComponentProp {\n name: string;\n type: string;\n docs: string;\n default: string;\n}\n\ninterface ComponentEvent {\n event: string;\n docs: string;\n detail: string;\n}\n\ninterface ComponentInfo {\n name: string;\n props: ComponentProp[];\n events: ComponentEvent[];\n}\n\nconst description = (prop: ComponentProp | ComponentEvent) => (prop.docs || '').trim();\n\nconst isText = (prop: ComponentProp) => prop.type === 'string';\nconst isBoolean = (prop: ComponentProp) => prop.type === 'boolean';\nconst isEnum = (prop: ComponentProp) => prop.type.includes('|');\nconst isNumber = (prop: ComponentProp) => prop.type === 'number';\n\nconst enumOptions = (prop: ComponentProp) =>\n prop.type\n .split('|')\n .map(t => t.trim())\n .map(t => (t === '\"\"' ? 'default' : t))\n .map(t => t.replace(/^\"(.*)\"$/, '$1'));\n\nconst generateProp = (prop: ComponentProp) => {\n if (isText(prop)) {\n return {\n [prop.name]: {\n control: 'text',\n description: description(prop),\n defaultValue: prop.default,\n table: {\n category: 'properties',\n defaultValue: { summary: prop.default },\n type: { summary: 'string' },\n },\n },\n };\n }\n\n if (isBoolean(prop)) {\n return {\n [prop.name]: {\n control: 'boolean',\n description: description(prop),\n defaultValue: prop.default,\n table: {\n category: 'properties',\n defaultValue: { summary: prop.default },\n type: { summary: 'boolean' },\n },\n },\n };\n }\n\n if (isNumber(prop)) {\n return {\n [prop.name]: {\n control: 'number',\n description: description(prop),\n defaultValue: prop.default,\n table: {\n category: 'properties',\n defaultValue: { summary: prop.default },\n type: { summary: 'number' },\n },\n },\n };\n }\n\n if (isEnum(prop)) {\n return {\n [prop.name]: {\n control: 'select',\n defaultValue: prop.default,\n options: enumOptions(prop),\n description: description(prop),\n table: {\n category: 'properties',\n defaultValue: { summary: prop.default },\n type: { summary: 'enum' },\n },\n },\n };\n }\n\n return {};\n};\n\nconst generateProps = (props: ComponentProp[]) => {\n let args = {};\n props.forEach(prop => (args = { ...args, ...generateProp(prop) }));\n return args;\n};\n\nconst generateEvent = (event: ComponentEvent) => {\n function capitalizeFirstLetter(string: string) {\n return string.charAt(0).toUpperCase() + string.slice(1);\n }\n\n return {\n [`on${capitalizeFirstLetter(event.event)}`]: {\n action: event.event,\n description: description(event),\n table: {\n defaultValue: { summary: event.event },\n category: 'events',\n type: { summary: event.detail },\n },\n },\n };\n};\n\nconst generateEvents = (events: ComponentEvent[]) => {\n let args = {};\n events.forEach(event => (args = { ...args, ...generateEvent(event) }));\n return args;\n};\n\nconst extractComponentInfoByTag = (componentsData: any, tag: string): ComponentInfo | null => {\n const component = componentsData.components.find(c => c.tag === tag);\n\n if (!component) {\n console.error(`Component with tag ${tag} not found`);\n return null;\n }\n\n const { props, events } = component;\n\n const propInfo = props.map(prop => ({\n name: prop.name,\n type: prop.type,\n docs: prop.docs,\n default: prop.default || '',\n }));\n\n const eventInfo = events.map(event => ({\n event: event.event,\n docs: event.docs,\n detail: event.detail,\n }));\n\n return {\n name: tag,\n props: propInfo,\n events: eventInfo,\n };\n};\n\nconst generateHTMLTable = (componentInfo: ComponentInfo): string => {\n if (!componentInfo) {\n return `<p>Component not found</p>`;\n }\n\n const { props, events } = componentInfo;\n\n const propsRows = props\n .map(\n prop => `\n <tr>\n <td>${prop.name}</td>\n <td>${prop.type}</td>\n <td>${prop.docs}</td>\n <td>${prop.default}</td>\n </tr>\n `,\n )\n .join('');\n\n const eventsRows = events\n .map(\n event => `\n <tr>\n <td>${event.event}</td>\n <td>${event.detail}</td>\n <td>${event.docs}</td>\n </tr>\n `,\n )\n .join('');\n\n return `\n <h3>Propriétés</h3>\n <table class=\"w-full\">\n <thead>\n <tr>\n <th>Propriété</th>\n <th>Type</th>\n <th>Description</th>\n <th>Valeur par défaut</th>\n </tr>\n </thead>\n <tbody>\n ${propsRows}\n </tbody>\n </table>\n <h3>Événements</h3>\n <table class=\"w-full\">\n <thead>\n <tr>\n <th>Événement</th>\n <th>Détail</th>\n <th>Description</th>\n </tr>\n </thead>\n <tbody>\n ${eventsRows}\n </tbody>\n </table>\n `;\n};\n\nexport const generateComponentTable = (componentsData: any, tag: string): string => {\n const componentInfo = extractComponentInfoByTag(componentsData, tag);\n return generateHTMLTable(componentInfo);\n};\n\nexport const withComponentControls = (componentsData: any, { tag }: { tag: string }): any => {\n const component = componentsData.components.find(c => c.tag === tag);\n if (component) {\n const props = component.props;\n const events = component.events;\n\n return {\n ...generateProps(props as ComponentProp[]),\n ...generateEvents(events as ComponentEvent[]),\n };\n }\n\n return {};\n};\n\nexport function extractArgTypes(componentsData: any, subComponentTags: string[]) {\n return subComponentTags.reduce((acc, tag) => {\n const subComponentArgTypes = withComponentControls(componentsData, { tag });\n return { ...acc, ...subComponentArgTypes };\n }, {});\n}\n\nexport function formatFileSize(sizeInBytes) {\n const sizeInMB = sizeInBytes / (1024 * 1024);\n let formattedSize = sizeInMB.toFixed(2).replace('.', ',');\n\n if (sizeInMB > 0 && sizeInMB < 0.01) {\n formattedSize = '0,01';\n } else if (sizeInMB === 0) {\n formattedSize = '0,00';\n }\n\n return `${formattedSize} Mo`;\n}\n\nexport function hasSlotContent(el: HTMLElement): boolean {\n const slot = el.querySelector('slot');\n return slot && slot.assignedNodes().length > 0;\n}\n"]}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Get the base path to where the assets can be found. Use "setAssetPath(path)"
|
|
3
|
+
* if the path needs to be customized.
|
|
4
|
+
*/
|
|
5
|
+
export declare const getAssetPath: (path: string) => string;
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Used to manually set the base path where assets can be found.
|
|
9
|
+
* If the script is used as "module", it's recommended to use "import.meta.url",
|
|
10
|
+
* such as "setAssetPath(import.meta.url)". Other options include
|
|
11
|
+
* "setAssetPath(document.currentScript.src)", or using a bundler's replace plugin to
|
|
12
|
+
* dynamically set the path at build time, such as "setAssetPath(process.env.ASSET_PATH)".
|
|
13
|
+
* But do note that this configuration depends on how your script is bundled, or lack of
|
|
14
|
+
* bundling, and where your assets can be loaded from. Additionally custom bundling
|
|
15
|
+
* will have to ensure the static assets are copied to its build directory.
|
|
16
|
+
*/
|
|
17
|
+
export declare const setAssetPath: (path: string) => void;
|
|
18
|
+
|
|
19
|
+
/**
|
|
20
|
+
* Used to specify a nonce value that corresponds with an application's CSP.
|
|
21
|
+
* When set, the nonce will be added to all dynamically created script and style tags at runtime.
|
|
22
|
+
* Alternatively, the nonce value can be set on a meta tag in the DOM head
|
|
23
|
+
* (<meta name="csp-nonce" content="{ nonce value here }" />) which
|
|
24
|
+
* will result in the same behavior.
|
|
25
|
+
*/
|
|
26
|
+
export declare const setNonce: (nonce: string) => void
|
|
27
|
+
|
|
28
|
+
export interface SetPlatformOptions {
|
|
29
|
+
raf?: (c: FrameRequestCallback) => number;
|
|
30
|
+
ael?: (el: EventTarget, eventName: string, listener: EventListenerOrEventListenerObject, options: boolean | AddEventListenerOptions) => void;
|
|
31
|
+
rel?: (el: EventTarget, eventName: string, listener: EventListenerOrEventListenerObject, options: boolean | AddEventListenerOptions) => void;
|
|
32
|
+
}
|
|
33
|
+
export declare const setPlatformOptions: (opts: SetPlatformOptions) => void;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"file":"index.js","mappings":"","names":[],"sources":[],"sourcesContent":[],"version":3}
|
|
@@ -0,0 +1,231 @@
|
|
|
1
|
+
import { p as proxyCustomElement, H, d as createEvent, h, F as Fragment, c as Host } from './p-3706b88e.js';
|
|
2
|
+
import { d as defineCustomElement$4 } from './p-b3b66a09.js';
|
|
3
|
+
import { d as defineCustomElement$3 } from './p-e70f2b83.js';
|
|
4
|
+
import { d as defineCustomElement$2 } from './p-72ca702e.js';
|
|
5
|
+
import { d as defineCustomElement$1 } from './p-cb99b731.js';
|
|
6
|
+
|
|
7
|
+
const spwPaginationCss = "/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{-webkit-text-size-adjust:100%;line-height:1.3}h1,h2,h3,h4,h5,h6,li,p,ul{margin:0;padding:0}ul{list-style:none}:host{-webkit-text-size-adjust:100%;box-sizing:border-box;display:block;font-size:100%;line-height:1.3}:host *,:host :after,:host :before{box-sizing:inherit;font-family:Nunito Sans}body{margin:0}main{display:block}h1{font-size:2em;margin:.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}[hidden],template{display:none}:root{--spw-ds-container-xl:1220px;--spw-ds-container-lg:1024px;--spw-ds-container-md:768px;--spw-ds-container-sm:640px}.spw-ds-container{width:100%}@media (min-width:460px){.spw-ds-container{max-width:var(--spw-ds-container-sm)}}@media (min-width:768px){.spw-ds-container{max-width:var(--spw-ds-container-md)}}@media (min-width:1024px){.spw-ds-container{max-width:var(--spw-ds-container-lg)}}@media (min-width:1350px){.spw-ds-container{max-width:var(--spw-ds-container-xl)}}.spw-pagination__item button,.spw-pagination__item--dots{border-radius:32px;font-size:14px;font-weight:700;height:32px;line-height:32px;min-width:32px;text-align:center}.spw-pagination__item button:focus-visible,.spw-pagination__item--dots:focus-visible{outline:3px solid var(--spw-ds-focus)}.spw-pagination{align-items:center;display:flex;flex-direction:column}@media (min-width:768px){.spw-pagination{align-items:flex-start}}.spw-pagination ul{align-items:center;display:flex;padding:0}.spw-pagination__item{margin-right:12px}.spw-pagination__item spw-icon{font-size:18px}.spw-pagination__item button{background:none;border:none;color:var(--spw-color-themes-grey-grey-900);cursor:pointer;margin:0;padding:0 6px}.spw-pagination__item:not(.spw-pagination__item--active,.spw-pagination__item--dots,.spw-pagination__item--disabled):hover button{background:var(--spw-color-themes-grey-grey-200)}.spw-pagination__item:not(.spw-pagination__item--active,.spw-pagination__item--dots,.spw-pagination__item--disabled):active button{background:var(--spw-color-themes-grey-grey-300)}.spw-pagination__item--arrow button{align-items:center;display:flex;gap:8px;padding:0 12px;text-decoration:underline}.spw-pagination__item--arrow button:hover{text-decoration:none}.spw-pagination__item--dots{align-items:center;background:none;color:var(--spw-color-themes-grey-grey-400);cursor:default;display:inline-flex;justify-content:center;position:relative;top:3px}.spw-pagination__item--dots spw-icon{font-size:16px}.spw-pagination__item--desktop{display:none}@media (min-width:768px){.spw-pagination__item--desktop{display:inline-block}}.spw-pagination__item--active button{background:var(--spw-ds-primary);color:#fff}.spw-pagination__input spw-text-field{--spw-input-height:32px;--spw-input-padding:0 4px;--spw-input-text-align:center;--spw-input-font-size:14px;width:3ch}.spw-pagination__mobile-arrows{margin-top:12px}@media (min-width:768px){.spw-pagination__mobile-arrows{display:none!important}}.spw-pagination__total-pages{font-size:14px;margin:0 12px 0 6px}.spw-tw-mb-10{margin-bottom:2.5rem}.spw-tw-mb-6{margin-bottom:1.5rem}.spw-tw-ml-2{margin-left:.5rem}.spw-tw-mr-4{margin-right:1rem}.spw-tw-mt-12{margin-top:3rem}.-spw-tw-mt-1{margin-top:-.25rem}.spw-tw-mb-2{margin-bottom:.5rem}";
|
|
8
|
+
const SpwPaginationStyle0 = spwPaginationCss;
|
|
9
|
+
|
|
10
|
+
const SpwPagination = /*@__PURE__*/ proxyCustomElement(class SpwPagination extends H {
|
|
11
|
+
constructor() {
|
|
12
|
+
super();
|
|
13
|
+
this.__registerHost();
|
|
14
|
+
this.__attachShadow();
|
|
15
|
+
this.pageChanged = createEvent(this, "pageChanged", 7);
|
|
16
|
+
this.updateIsMobile = () => {
|
|
17
|
+
this.isMobile = window.innerWidth < 800;
|
|
18
|
+
};
|
|
19
|
+
this.totalItems = undefined;
|
|
20
|
+
this.itemsPerPage = undefined;
|
|
21
|
+
this.isDisabled = false;
|
|
22
|
+
this.variant = 'numbers';
|
|
23
|
+
this.currentPage = 1;
|
|
24
|
+
this.inputPageValue = '';
|
|
25
|
+
this.isMobile = window.innerWidth < 800;
|
|
26
|
+
}
|
|
27
|
+
componentWillLoad() {
|
|
28
|
+
this.calculateTotalPages();
|
|
29
|
+
this.inputPageValue = this.currentPage.toString();
|
|
30
|
+
window.addEventListener('resize', this.updateIsMobile);
|
|
31
|
+
}
|
|
32
|
+
disconnectedCallback() {
|
|
33
|
+
window.removeEventListener('resize', this.updateIsMobile);
|
|
34
|
+
}
|
|
35
|
+
calculateTotalPages() {
|
|
36
|
+
this.totalPages = Math.ceil(this.totalItems / this.itemsPerPage);
|
|
37
|
+
}
|
|
38
|
+
goToPage(page) {
|
|
39
|
+
if (page !== this.currentPage && !this.isDisabled && page >= 1 && page <= this.totalPages) {
|
|
40
|
+
this.currentPage = page;
|
|
41
|
+
this.inputPageValue = this.currentPage.toString();
|
|
42
|
+
this.pageChanged.emit(this.currentPage);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
handleInputChange(event) {
|
|
46
|
+
const inputValue = event.target.value;
|
|
47
|
+
this.inputPageValue = inputValue;
|
|
48
|
+
const page = parseInt(inputValue, 10);
|
|
49
|
+
if (!isNaN(page) && page >= 1 && page <= this.totalPages) {
|
|
50
|
+
clearTimeout(this.debounceTimer);
|
|
51
|
+
this.debounceTimer = setTimeout(() => {
|
|
52
|
+
this.goToPage(page);
|
|
53
|
+
}, 500);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
getPaginationClass() {
|
|
57
|
+
var _a, _b;
|
|
58
|
+
const pages = this.calculatePageRange();
|
|
59
|
+
const ellipsisCount = pages.filter(({ page }) => page === '...').length;
|
|
60
|
+
const hasEllipsisStart = ellipsisCount > 0 && ((_a = pages[1]) === null || _a === void 0 ? void 0 : _a.page) === '...';
|
|
61
|
+
const hasEllipsisEnd = ellipsisCount > 0 && ((_b = pages[pages.length - 2]) === null || _b === void 0 ? void 0 : _b.page) === '...';
|
|
62
|
+
let paginationClass = `spw-pagination spw-pagination--${this.currentPage} spw-pagination--total-${this.totalPages}`;
|
|
63
|
+
if (ellipsisCount === 2) {
|
|
64
|
+
paginationClass += ' spw-pagination--double-ellipsis';
|
|
65
|
+
}
|
|
66
|
+
else if (hasEllipsisStart) {
|
|
67
|
+
paginationClass += ' spw-pagination--ellipsis-start';
|
|
68
|
+
}
|
|
69
|
+
else if (hasEllipsisEnd) {
|
|
70
|
+
paginationClass += ' spw-pagination--ellipsis-end';
|
|
71
|
+
}
|
|
72
|
+
return paginationClass;
|
|
73
|
+
}
|
|
74
|
+
handleKeyDown(event) {
|
|
75
|
+
if (event.key === 'Enter') {
|
|
76
|
+
const page = parseInt(this.inputPageValue, 10);
|
|
77
|
+
if (!isNaN(page)) {
|
|
78
|
+
this.goToPage(page);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
calculateWidth() {
|
|
83
|
+
const length = this.inputPageValue.length;
|
|
84
|
+
if (length <= 1) {
|
|
85
|
+
return '3ch';
|
|
86
|
+
}
|
|
87
|
+
return `${length + 1}ch`;
|
|
88
|
+
}
|
|
89
|
+
calculatePageRange() {
|
|
90
|
+
const pages = [];
|
|
91
|
+
const { currentPage, totalPages, isMobile } = this;
|
|
92
|
+
if (isMobile) {
|
|
93
|
+
// Mode mobile
|
|
94
|
+
if (totalPages <= 5) {
|
|
95
|
+
for (let i = 1; i <= totalPages; i++) {
|
|
96
|
+
pages.push({ page: i, class: 'spw-pagination__item--small-range' });
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
else if (currentPage <= 3) {
|
|
100
|
+
for (let i = 1; i <= 3; i++) {
|
|
101
|
+
pages.push({ page: i, class: 'spw-pagination__item--start-range' });
|
|
102
|
+
}
|
|
103
|
+
pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });
|
|
104
|
+
pages.push({ page: totalPages, class: 'spw-pagination__item--end' });
|
|
105
|
+
}
|
|
106
|
+
else if (currentPage >= totalPages - 2) {
|
|
107
|
+
pages.push({ page: 1, class: 'spw-pagination__item--start' });
|
|
108
|
+
pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });
|
|
109
|
+
for (let i = totalPages - 2; i <= totalPages; i++) {
|
|
110
|
+
pages.push({ page: i, class: 'spw-pagination__item--end-range' });
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
else {
|
|
114
|
+
pages.push({ page: 1, class: 'spw-pagination__item--start' });
|
|
115
|
+
pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });
|
|
116
|
+
for (let i = currentPage - 1; i <= currentPage + 1; i++) {
|
|
117
|
+
pages.push({ page: i, class: 'spw-pagination__item--middle-range' });
|
|
118
|
+
}
|
|
119
|
+
pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });
|
|
120
|
+
pages.push({ page: totalPages, class: 'spw-pagination__item--end' });
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
else {
|
|
124
|
+
// Mode desktop
|
|
125
|
+
if (totalPages <= 7) {
|
|
126
|
+
for (let i = 1; i <= totalPages; i++) {
|
|
127
|
+
pages.push({ page: i, class: 'spw-pagination__item--small-range' });
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
else if (currentPage <= 4) {
|
|
131
|
+
for (let i = 1; i <= 4; i++) {
|
|
132
|
+
pages.push({ page: i, class: 'spw-pagination__item--start-range' });
|
|
133
|
+
}
|
|
134
|
+
pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });
|
|
135
|
+
pages.push({ page: totalPages, class: 'spw-pagination__item--end' });
|
|
136
|
+
}
|
|
137
|
+
else if (currentPage >= totalPages - 3) {
|
|
138
|
+
pages.push({ page: 1, class: 'spw-pagination__item--start' });
|
|
139
|
+
pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });
|
|
140
|
+
for (let i = totalPages - 3; i <= totalPages; i++) {
|
|
141
|
+
pages.push({ page: i, class: 'spw-pagination__item--end-range' });
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
else {
|
|
145
|
+
pages.push({ page: 1, class: 'spw-pagination__item--start' });
|
|
146
|
+
pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });
|
|
147
|
+
for (let i = currentPage - 2; i <= currentPage + 2; i++) {
|
|
148
|
+
pages.push({ page: i, class: 'spw-pagination__item--middle-range' });
|
|
149
|
+
}
|
|
150
|
+
pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });
|
|
151
|
+
pages.push({ page: totalPages, class: 'spw-pagination__item--end' });
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
return pages;
|
|
155
|
+
}
|
|
156
|
+
render() {
|
|
157
|
+
const pages = this.calculatePageRange();
|
|
158
|
+
const showPrevArrow = this.currentPage > 1;
|
|
159
|
+
const showNextArrow = this.currentPage < this.totalPages;
|
|
160
|
+
const prevArrow = showPrevArrow && (h("li", { key: '92ef42761d0175b2c97a9efe65e8645d0f2336a4', class: "spw-pagination__item spw-pagination__item--desktop spw-pagination__item--arrow" }, h("button", { key: '795383fd33cd7d4483f857a130858a8e3140ac32', onClick: () => this.goToPage(this.currentPage - 1) }, h("spw-icon", { key: '083a017a27b2fbc126f602e15a2102d2a5fd24fa', icon: "fa-chevron-left" }), " ", h("span", { key: '5c2d2ac7e3a0eda5dfde49080f3239c97922d663', class: "spw-pagination__item-arrow-text" }, "Pr\u00E9c\u00E9dent"))));
|
|
161
|
+
const nextArrow = showNextArrow && (h("li", { key: '9217f13b26fdd534353493612a74c9cd80c63e02', class: "spw-pagination__item spw-pagination__item--desktop spw-pagination__item--arrow" }, h("button", { key: 'ad665dfb749a5770ffdf6bd53982f8b79b565efb', onClick: () => this.goToPage(this.currentPage + 1) }, h("span", { key: '1e788ff34cdb5ac89df8ee9d69142048dfc423cf', class: "spw-pagination__item-arrow-text" }, "Suivant"), " ", h("spw-icon", { key: 'e1263d3d81c527d4c8f559c7efbe4a882e44f880', icon: "fa-chevron-right" }))));
|
|
162
|
+
const prevArrowMobile = this.currentPage > 1 && (h("li", { key: '155ccc9ef12e82ff0ff4053e6e9121f71d3347e9', class: "spw-pagination__item spw-pagination__item--arrow" }, h("button", { key: '4846fba3c684879086a4445ab59d11b9fedbd729', onClick: () => this.goToPage(this.currentPage - 1) }, h("spw-icon", { key: 'fcc99138e3ba55024e89ac7da3acc4d6e4c0a811', icon: "fa-chevron-left" }), " ", h("span", { key: '86a1e9d336d69919ac1deed354d85138e73c8315' }, "Pr\u00E9c\u00E9dent"))));
|
|
163
|
+
const nextArrowMobile = this.currentPage < this.totalPages && (h("li", { key: '6492294cc5f678aef792ca166c1f276b0e9f97b9', class: "spw-pagination__item spw-pagination__item--arrow" }, h("button", { key: '48db42f6df00985e6e75eeba69afdb4a8de54af5', onClick: () => this.goToPage(this.currentPage + 1), disabled: this.currentPage >= this.totalPages }, h("span", { key: 'c637153995e2e2999c2f4d9c05a5ac5a1eb9daaf' }, "Suivant"), " ", h("spw-icon", { key: '82941730947e3f827215e800efcc3320e4886b2c', icon: "fa-chevron-right" }))));
|
|
164
|
+
const mobileArrows = (h("ul", { key: '49c47245a12a39a869eb8e6446fbbb18b6c81b72', class: "spw-pagination__mobile-arrows" }, prevArrowMobile, nextArrowMobile));
|
|
165
|
+
return (h(Host, { key: 'fd390d68353001dcbc9aadb5f54d367ac512b152' }, h("div", { key: '52264d5fb04ce2b901619c9cd8300fe8e982d460', class: this.getPaginationClass() }, this.variant === 'input' && (h(Fragment, { key: '5c8accb96a11eb63350e56df10c927cdaa8cf0d1' }, h("ul", { key: '9fa4233681297a17bc205d8a0433bd8069c27d5c' }, prevArrow, h("li", { key: '68a58a3f690f81a1e57a04e63db1612ada7b745e', class: "spw-pagination__input" }, h("spw-text-field", { key: '8fe43453a3a780d77e4ce6d16805f8b6ae63901f', value: this.inputPageValue, type: "number", onInput: event => this.handleInputChange(event), onKeyDown: event => this.handleKeyDown(event), disabled: this.isDisabled, style: { width: this.calculateWidth() } })), h("li", { key: '38727323566f8d52440dbc75c87befa17394cdb8', class: "spw-pagination__total-pages" }, "sur ", this.totalPages, " pages"), nextArrow), mobileArrows)), this.variant === 'numbers' && (h(Fragment, { key: '54277117ac1b6a806bc7af5b4abf1b3a964d137f' }, h("ul", { key: 'a0c936f6ac0029c7863f30bdfce1bf46224060dc' }, prevArrow, pages.map(({ page, class: pageClass }) => {
|
|
166
|
+
if (page === '...') {
|
|
167
|
+
return (h("li", { class: `spw-pagination__item spw-pagination__item--dots ${pageClass}` }, h("spw-icon", { icon: "fa-ellipsis" })));
|
|
168
|
+
}
|
|
169
|
+
return (h("li", { class: {
|
|
170
|
+
'spw-pagination__item': true,
|
|
171
|
+
'spw-pagination__item--active': page === this.currentPage,
|
|
172
|
+
[pageClass]: true,
|
|
173
|
+
} }, h("button", { onClick: () => this.goToPage(page), disabled: page === this.currentPage }, page)));
|
|
174
|
+
}), nextArrow), mobileArrows)))));
|
|
175
|
+
}
|
|
176
|
+
static get watchers() { return {
|
|
177
|
+
"totalItems": ["calculateTotalPages"],
|
|
178
|
+
"itemsPerPage": ["calculateTotalPages"],
|
|
179
|
+
"currentPage": ["calculateTotalPages"]
|
|
180
|
+
}; }
|
|
181
|
+
static get style() { return SpwPaginationStyle0; }
|
|
182
|
+
}, [1, "spw-pagination", {
|
|
183
|
+
"totalItems": [2, "total-items"],
|
|
184
|
+
"itemsPerPage": [2, "items-per-page"],
|
|
185
|
+
"isDisabled": [4, "is-disabled"],
|
|
186
|
+
"variant": [1],
|
|
187
|
+
"currentPage": [1026, "current-page"],
|
|
188
|
+
"inputPageValue": [32],
|
|
189
|
+
"isMobile": [32]
|
|
190
|
+
}, undefined, {
|
|
191
|
+
"totalItems": ["calculateTotalPages"],
|
|
192
|
+
"itemsPerPage": ["calculateTotalPages"],
|
|
193
|
+
"currentPage": ["calculateTotalPages"]
|
|
194
|
+
}]);
|
|
195
|
+
function defineCustomElement() {
|
|
196
|
+
if (typeof customElements === "undefined") {
|
|
197
|
+
return;
|
|
198
|
+
}
|
|
199
|
+
const components = ["spw-pagination", "spw-field-label", "spw-field-message", "spw-icon", "spw-text-field"];
|
|
200
|
+
components.forEach(tagName => { switch (tagName) {
|
|
201
|
+
case "spw-pagination":
|
|
202
|
+
if (!customElements.get(tagName)) {
|
|
203
|
+
customElements.define(tagName, SpwPagination);
|
|
204
|
+
}
|
|
205
|
+
break;
|
|
206
|
+
case "spw-field-label":
|
|
207
|
+
if (!customElements.get(tagName)) {
|
|
208
|
+
defineCustomElement$4();
|
|
209
|
+
}
|
|
210
|
+
break;
|
|
211
|
+
case "spw-field-message":
|
|
212
|
+
if (!customElements.get(tagName)) {
|
|
213
|
+
defineCustomElement$3();
|
|
214
|
+
}
|
|
215
|
+
break;
|
|
216
|
+
case "spw-icon":
|
|
217
|
+
if (!customElements.get(tagName)) {
|
|
218
|
+
defineCustomElement$2();
|
|
219
|
+
}
|
|
220
|
+
break;
|
|
221
|
+
case "spw-text-field":
|
|
222
|
+
if (!customElements.get(tagName)) {
|
|
223
|
+
defineCustomElement$1();
|
|
224
|
+
}
|
|
225
|
+
break;
|
|
226
|
+
} });
|
|
227
|
+
}
|
|
228
|
+
|
|
229
|
+
export { SpwPagination as S, defineCustomElement as d };
|
|
230
|
+
|
|
231
|
+
//# sourceMappingURL=p-0e197bb5.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"file":"p-0e197bb5.js","mappings":"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","names":[],"sources":["src/components/spw-pagination/spw-pagination.scss?tag=spw-pagination&encapsulation=shadow","src/components/spw-pagination/spw-pagination.tsx"],"sourcesContent":[":host {\n display: block;\n}\n\n%button {\n text-align: center;\n line-height: 32px;\n font-weight: 700;\n border-radius: 32px;\n font-size: 14px;\n min-width: 32px;\n height: 32px;\n &:focus-visible {\n outline: 3px solid var(--spw-ds-focus);\n }\n}\n\n.spw-pagination {\n display: flex;\n flex-direction: column;\n align-items: center;\n @include breakpoint(md) {\n align-items: flex-start;\n }\n\n ul {\n display: flex;\n align-items: center;\n padding: 0;\n }\n\n &__item {\n margin-right: 12px;\n spw-icon {\n font-size: 18px;\n }\n button {\n padding: 0 6px;\n margin: 0;\n border: none;\n cursor: pointer;\n color: var(--spw-color-themes-grey-grey-900);\n background: none;\n @extend %button;\n }\n\n &:not(.spw-pagination__item--active, .spw-pagination__item--dots, .spw-pagination__item--disabled):hover {\n button {\n background: var(--spw-color-themes-grey-grey-200);\n }\n }\n\n &:not(.spw-pagination__item--active, .spw-pagination__item--dots, .spw-pagination__item--disabled):active {\n button {\n background: var(--spw-color-themes-grey-grey-300);\n }\n }\n\n &--arrow {\n button {\n padding: 0 12px;\n display: flex;\n gap: 8px;\n align-items: center;\n text-decoration: underline;\n &:hover {\n text-decoration: none;\n }\n }\n }\n\n &--dots {\n position: relative;\n top: 3px;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n cursor: default;\n background: none;\n color: var(--spw-color-themes-grey-grey-400);\n @extend %button;\n spw-icon {\n font-size: 16px;\n }\n }\n\n &--desktop {\n display: none;\n @include breakpoint(md) {\n display: inline-block;\n }\n }\n\n &--active {\n button {\n color: white;\n background: var(--spw-ds-primary);\n }\n }\n }\n\n &__input {\n spw-text-field {\n width: 3ch;\n --spw-input-height: 32px;\n --spw-input-padding: 0 4px;\n --spw-input-text-align: center;\n --spw-input-font-size: 14px;\n }\n }\n\n &__mobile-arrows {\n margin-top: 12px;\n @include breakpoint(md) {\n display: none !important;\n }\n }\n\n &__total-pages {\n font-size: 14px;\n margin: 0 12px 0 6px;\n }\n}\n","import { Component, Fragment, Prop, Host, h, Event, EventEmitter, Watch, State } from '@stencil/core';\n\n@Component({\n tag: 'spw-pagination',\n styleUrl: 'spw-pagination.scss',\n shadow: true,\n})\nexport class SpwPagination {\n /** Nombre total d'éléments à paginer */\n @Prop() totalItems: number;\n /** Nombre d'éléments à afficher par page */\n @Prop() itemsPerPage: number;\n /** Indique si la pagination est désactivée */\n @Prop() isDisabled: boolean = false;\n /** Type de variante de la pagination : 'numbers' ou 'input' */\n @Prop() variant: 'numbers' | 'input' = 'numbers';\n /** Page actuellement sélectionnée, mutable */\n @Prop({ mutable: true }) currentPage: number = 1;\n\n /** Événement émis lorsque la page est changée, renvoie le numéro de la nouvelle page */\n @Event() pageChanged: EventEmitter<number>;\n\n private totalPages: number;\n @State() inputPageValue: string = '';\n @State() isMobile: boolean = window.innerWidth < 800;\n private debounceTimer: any;\n\n componentWillLoad() {\n this.calculateTotalPages();\n this.inputPageValue = this.currentPage.toString();\n window.addEventListener('resize', this.updateIsMobile);\n }\n\n disconnectedCallback() {\n window.removeEventListener('resize', this.updateIsMobile);\n }\n\n private updateIsMobile = () => {\n this.isMobile = window.innerWidth < 800;\n };\n\n @Watch('totalItems')\n @Watch('itemsPerPage')\n @Watch('currentPage')\n calculateTotalPages() {\n this.totalPages = Math.ceil(this.totalItems / this.itemsPerPage);\n }\n\n private goToPage(page: number) {\n if (page !== this.currentPage && !this.isDisabled && page >= 1 && page <= this.totalPages) {\n this.currentPage = page;\n this.inputPageValue = this.currentPage.toString();\n this.pageChanged.emit(this.currentPage);\n }\n }\n\n private handleInputChange(event: Event) {\n const inputValue = (event.target as HTMLInputElement).value;\n this.inputPageValue = inputValue;\n const page = parseInt(inputValue, 10);\n\n if (!isNaN(page) && page >= 1 && page <= this.totalPages) {\n clearTimeout(this.debounceTimer);\n this.debounceTimer = setTimeout(() => {\n this.goToPage(page);\n }, 500);\n }\n }\n\n private getPaginationClass() {\n const pages = this.calculatePageRange();\n const ellipsisCount = pages.filter(({ page }) => page === '...').length;\n const hasEllipsisStart = ellipsisCount > 0 && pages[1]?.page === '...';\n const hasEllipsisEnd = ellipsisCount > 0 && pages[pages.length - 2]?.page === '...';\n\n let paginationClass = `spw-pagination spw-pagination--${this.currentPage} spw-pagination--total-${this.totalPages}`;\n\n if (ellipsisCount === 2) {\n paginationClass += ' spw-pagination--double-ellipsis';\n } else if (hasEllipsisStart) {\n paginationClass += ' spw-pagination--ellipsis-start';\n } else if (hasEllipsisEnd) {\n paginationClass += ' spw-pagination--ellipsis-end';\n }\n\n return paginationClass;\n }\n\n private handleKeyDown(event: KeyboardEvent) {\n if (event.key === 'Enter') {\n const page = parseInt(this.inputPageValue, 10);\n if (!isNaN(page)) {\n this.goToPage(page);\n }\n }\n }\n\n private calculateWidth(): string {\n const length = this.inputPageValue.length;\n if (length <= 1) {\n return '3ch';\n }\n return `${length + 1}ch`;\n }\n\n private calculatePageRange() {\n const pages = [];\n const { currentPage, totalPages, isMobile } = this;\n\n if (isMobile) {\n // Mode mobile\n if (totalPages <= 5) {\n for (let i = 1; i <= totalPages; i++) {\n pages.push({ page: i, class: 'spw-pagination__item--small-range' });\n }\n } else if (currentPage <= 3) {\n for (let i = 1; i <= 3; i++) {\n pages.push({ page: i, class: 'spw-pagination__item--start-range' });\n }\n pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });\n pages.push({ page: totalPages, class: 'spw-pagination__item--end' });\n } else if (currentPage >= totalPages - 2) {\n pages.push({ page: 1, class: 'spw-pagination__item--start' });\n pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });\n for (let i = totalPages - 2; i <= totalPages; i++) {\n pages.push({ page: i, class: 'spw-pagination__item--end-range' });\n }\n } else {\n pages.push({ page: 1, class: 'spw-pagination__item--start' });\n pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });\n for (let i = currentPage - 1; i <= currentPage + 1; i++) {\n pages.push({ page: i, class: 'spw-pagination__item--middle-range' });\n }\n pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });\n pages.push({ page: totalPages, class: 'spw-pagination__item--end' });\n }\n } else {\n // Mode desktop\n if (totalPages <= 7) {\n for (let i = 1; i <= totalPages; i++) {\n pages.push({ page: i, class: 'spw-pagination__item--small-range' });\n }\n } else if (currentPage <= 4) {\n for (let i = 1; i <= 4; i++) {\n pages.push({ page: i, class: 'spw-pagination__item--start-range' });\n }\n pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });\n pages.push({ page: totalPages, class: 'spw-pagination__item--end' });\n } else if (currentPage >= totalPages - 3) {\n pages.push({ page: 1, class: 'spw-pagination__item--start' });\n pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });\n for (let i = totalPages - 3; i <= totalPages; i++) {\n pages.push({ page: i, class: 'spw-pagination__item--end-range' });\n }\n } else {\n pages.push({ page: 1, class: 'spw-pagination__item--start' });\n pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });\n for (let i = currentPage - 2; i <= currentPage + 2; i++) {\n pages.push({ page: i, class: 'spw-pagination__item--middle-range' });\n }\n pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });\n pages.push({ page: totalPages, class: 'spw-pagination__item--end' });\n }\n }\n\n return pages;\n }\n\n render() {\n const pages = this.calculatePageRange();\n const showPrevArrow = this.currentPage > 1;\n const showNextArrow = this.currentPage < this.totalPages;\n\n const prevArrow = showPrevArrow && (\n <li class=\"spw-pagination__item spw-pagination__item--desktop spw-pagination__item--arrow\">\n <button onClick={() => this.goToPage(this.currentPage - 1)}>\n <spw-icon icon=\"fa-chevron-left\"></spw-icon> <span class=\"spw-pagination__item-arrow-text\">Précédent</span>\n </button>\n </li>\n );\n\n const nextArrow = showNextArrow && (\n <li class=\"spw-pagination__item spw-pagination__item--desktop spw-pagination__item--arrow\">\n <button onClick={() => this.goToPage(this.currentPage + 1)}>\n <span class=\"spw-pagination__item-arrow-text\">Suivant</span> <spw-icon icon=\"fa-chevron-right\"></spw-icon>\n </button>\n </li>\n );\n\n const prevArrowMobile = this.currentPage > 1 && (\n <li class=\"spw-pagination__item spw-pagination__item--arrow\">\n <button onClick={() => this.goToPage(this.currentPage - 1)}>\n <spw-icon icon=\"fa-chevron-left\"></spw-icon> <span>Précédent</span>\n </button>\n </li>\n );\n\n const nextArrowMobile = this.currentPage < this.totalPages && (\n <li class=\"spw-pagination__item spw-pagination__item--arrow\">\n <button onClick={() => this.goToPage(this.currentPage + 1)} disabled={this.currentPage >= this.totalPages}>\n <span>Suivant</span> <spw-icon icon=\"fa-chevron-right\"></spw-icon>\n </button>\n </li>\n );\n\n const mobileArrows = (\n <ul class=\"spw-pagination__mobile-arrows\">\n {prevArrowMobile}\n {nextArrowMobile}\n </ul>\n );\n\n return (\n <Host>\n <div class={this.getPaginationClass()}>\n {this.variant === 'input' && (\n <Fragment>\n <ul>\n {prevArrow}\n <li class=\"spw-pagination__input\">\n <spw-text-field\n value={this.inputPageValue}\n type=\"number\"\n onInput={event => this.handleInputChange(event)}\n onKeyDown={event => this.handleKeyDown(event)}\n disabled={this.isDisabled}\n style={{ width: this.calculateWidth() }}\n ></spw-text-field>\n </li>\n <li class=\"spw-pagination__total-pages\">sur {this.totalPages} pages</li>\n {nextArrow}\n </ul>\n {mobileArrows}\n </Fragment>\n )}\n {this.variant === 'numbers' && (\n <Fragment>\n <ul>\n {prevArrow}\n\n {pages.map(({ page, class: pageClass }) => {\n if (page === '...') {\n return (\n <li class={`spw-pagination__item spw-pagination__item--dots ${pageClass}`}>\n <spw-icon icon=\"fa-ellipsis\"></spw-icon>\n </li>\n );\n }\n\n return (\n <li\n class={{\n 'spw-pagination__item': true,\n 'spw-pagination__item--active': page === this.currentPage,\n [pageClass]: true,\n }}\n >\n <button onClick={() => this.goToPage(page as number)} disabled={page === this.currentPage}>\n {page}\n </button>\n </li>\n );\n })}\n\n {nextArrow}\n </ul>\n {mobileArrows}\n </Fragment>\n )}\n </div>\n </Host>\n );\n }\n}\n"],"version":3}
|