@cupra/ui-kit 2.0.0-canary.140 → 2.0.0-canary.142

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.
Files changed (39) hide show
  1. package/dist/cjs/components/ds-theme-provider/ds-theme-provider.cjs +1 -1
  2. package/dist/cjs/components/ds-theme-switch/ds-theme-switch.cjs +1 -0
  3. package/dist/cjs/components/index.cjs +1 -1
  4. package/dist/cjs/decorators/customUiKitElement.cjs +1 -1
  5. package/dist/cjs/utils/IconsManager.cjs +1 -1
  6. package/dist/cjs/utils/PubSub.cjs +1 -1
  7. package/dist/cjs/utils/StylesRegistry/StylesRegistry.cjs +1 -1
  8. package/dist/cjs/utils/version.cjs +1 -1
  9. package/dist/esm/components/ds-theme-provider/ds-theme-provider.js +1 -1
  10. package/dist/esm/components/ds-theme-switch/ds-theme-switch.js +29 -0
  11. package/dist/esm/components/index.js +1 -0
  12. package/dist/esm/decorators/customUiKitElement.js +1 -1
  13. package/dist/esm/utils/IconsManager.js +1 -1
  14. package/dist/esm/utils/PubSub.js +1 -1
  15. package/dist/esm/utils/StylesRegistry/StylesRegistry.js +1 -1
  16. package/dist/esm/utils/version.js +1 -1
  17. package/dist/types/components/ds-theme-switch/ds-theme-switch.d.ts +12 -0
  18. package/dist/types/components/ds-theme-switch/ds-theme-switch.types.d.ts +2 -0
  19. package/dist/types/components/index.d.ts +1 -0
  20. package/dist-react/cjs/components/ds-theme-provider/ds-theme-provider.cjs +1 -1
  21. package/dist-react/cjs/components/ds-theme-switch/ds-theme-switch.cjs +1 -0
  22. package/dist-react/cjs/components/index.cjs +1 -1
  23. package/dist-react/cjs/decorators/customUiKitElement.cjs +1 -1
  24. package/dist-react/cjs/utils/IconsManager.cjs +1 -1
  25. package/dist-react/cjs/utils/PubSub.cjs +1 -1
  26. package/dist-react/cjs/utils/StylesRegistry/StylesRegistry.cjs +1 -1
  27. package/dist-react/cjs/utils/version.cjs +1 -1
  28. package/dist-react/esm/components/ds-theme-provider/ds-theme-provider.js +1 -1
  29. package/dist-react/esm/components/ds-theme-switch/ds-theme-switch.js +29 -0
  30. package/dist-react/esm/components/index.js +1 -0
  31. package/dist-react/esm/decorators/customUiKitElement.js +1 -1
  32. package/dist-react/esm/utils/IconsManager.js +1 -1
  33. package/dist-react/esm/utils/PubSub.js +1 -1
  34. package/dist-react/esm/utils/StylesRegistry/StylesRegistry.js +1 -1
  35. package/dist-react/esm/utils/version.js +1 -1
  36. package/dist-react/types/components/ds-theme-switch/ds-theme-switch.d.ts +12 -0
  37. package/dist-react/types/components/ds-theme-switch/ds-theme-switch.types.d.ts +2 -0
  38. package/dist-react/types/components/index.d.ts +1 -0
  39. package/package.json +1 -1
@@ -1,4 +1,4 @@
1
1
  const e=require(`../../node_modules/.pnpm/@lit_context@1.1.6/node_modules/@lit/context/lib/decorators/provide.cjs`),t=require(`./themeContext.cjs`),n=require(`../../core/theme.constants.cjs`),r=require(`../../utils/PubSub.cjs`),i=require(`../../node_modules/.pnpm/lit-html@3.3.1/node_modules/lit-html/lit-html.cjs`),a=require(`../../node_modules/.pnpm/lit-element@4.2.1/node_modules/lit-element/lit-element.cjs`);require(`../../node_modules/.pnpm/lit@3.3.1/node_modules/lit/index.cjs`);const o=require(`../../node_modules/.pnpm/@lit_reactive-element@2.1.1/node_modules/@lit/reactive-element/decorators/property.cjs`),s=require(`../../node_modules/.pnpm/@lit_reactive-element@2.1.1/node_modules/@lit/reactive-element/decorators/state.cjs`);require(`../../node_modules/.pnpm/lit@3.3.1/node_modules/lit/decorators.cjs`);const c=require(`../../_virtual/_@oxc-project_runtime@0.122.0/helpers/decorate.cjs`),l=require(`../../decorators/customUiKitElement.cjs`),u=require(`../../utils/booleanConverter.cjs`),d=require(`../../styles/source/shared/fonts-config.cjs`);var f=class extends a.i{constructor(...e){super(...e),this.loadFonts=!0,this.loadStyles=!0,this.cssLoaded=!1,this.loadedFonts=new Set}updated(e){super.updated(e),e.has(`theme`)&&(r.pubSub.publish(`theme`,this.theme),sessionStorage?.setItem(n.THEME_STORAGE_KEY,this.theme),typeof FontFace<`u`&&document?.fonts&&this.loadThemeFonts(),this.loadThemeStyles().then(()=>{this.cssLoaded=!0,this.dispatchEvent(new CustomEvent(`ui-kit:ready`,{bubbles:!0,composed:!0}))}))}loadThemeFonts(){d.fontsConfig[this.theme]?.fonts.forEach(e=>{this.loadThemeFont(e)})}async loadThemeFont({weight:e,name:t,file:n}){if(!this.loadFonts)return Promise.resolve();let r=`${t}-${e}`;if(this.loadedFonts.has(r))return;let i=new FontFace(t,`url('https://ds-assets.cupra.com/fonts/${this.theme}/${n}.woff2') format('woff2'),
2
2
  url('https://ds-assets.cupra.com/fonts/${this.theme}/${n}.woff') format('woff'),
3
3
  url('https://ds-assets.cupra.com/fonts/${this.theme}/${n}.ttf') format('truetype'),
4
- url('https://ds-assets.cupra.com/fonts/${this.theme}/${n}.otf') format('opentype')`,{style:`normal`,weight:e,display:`swap`});try{await i.load(),document.fonts.add(i),this.loadedFonts.add(r)}catch(n){console.error(`Error loading "${t}" font with "${e}" weight:`,n)}}loadThemeStyles(){return this.loadStyles?new Promise((e,t)=>{let n=`/2.0.0-canary.140`,r=`https://ds-assets.cupra.com${n}/styles/${this.theme}/theme.css`;if(document.head.querySelector(`link[href="${r}"]`))e();else{let i=`ui-kit-theme-${n}`,a=document.getElementById(i),o=document.createElement(`link`);o.id=i,o.rel=`stylesheet`,o.href=r,o.onload=()=>e(),o.onerror=()=>t(Error(`Failed to load theme CSS: ${r}`)),document.head.appendChild(o),a?.remove()}}):Promise.resolve()}render(){return this.cssLoaded?i.x`<slot></slot>`:i.E}};c.__decorate([o.n({type:Boolean,converter:u.booleanConverter,attribute:`load-fonts`})],f.prototype,`loadFonts`,void 0),c.__decorate([o.n({type:Boolean,converter:u.booleanConverter,attribute:`load-styles`})],f.prototype,`loadStyles`,void 0),c.__decorate([e.e({context:t.themeContext}),o.n({type:String})],f.prototype,`theme`,void 0),c.__decorate([s.r()],f.prototype,`cssLoaded`,void 0),c.__decorate([s.r()],f.prototype,`loadedFonts`,void 0),f=c.__decorate([l.customUiKitElement(`ds-theme-provider`)],f);
4
+ url('https://ds-assets.cupra.com/fonts/${this.theme}/${n}.otf') format('opentype')`,{style:`normal`,weight:e,display:`swap`});try{await i.load(),document.fonts.add(i),this.loadedFonts.add(r)}catch(n){console.error(`Error loading "${t}" font with "${e}" weight:`,n)}}loadThemeStyles(){return this.loadStyles?new Promise((e,t)=>{let n=`/2.0.0-canary.142`,r=`https://ds-assets.cupra.com${n}/styles/${this.theme}/theme.css`;if(document.head.querySelector(`link[href="${r}"]`))e();else{let i=`ui-kit-theme-${n}`,a=document.getElementById(i),o=document.createElement(`link`);o.id=i,o.rel=`stylesheet`,o.href=r,o.onload=()=>e(),o.onerror=()=>t(Error(`Failed to load theme CSS: ${r}`)),document.head.appendChild(o),a?.remove()}}):Promise.resolve()}render(){return this.cssLoaded?i.x`<slot></slot>`:i.E}};c.__decorate([o.n({type:Boolean,converter:u.booleanConverter,attribute:`load-fonts`})],f.prototype,`loadFonts`,void 0),c.__decorate([o.n({type:Boolean,converter:u.booleanConverter,attribute:`load-styles`})],f.prototype,`loadStyles`,void 0),c.__decorate([e.e({context:t.themeContext}),o.n({type:String})],f.prototype,`theme`,void 0),c.__decorate([s.r()],f.prototype,`cssLoaded`,void 0),c.__decorate([s.r()],f.prototype,`loadedFonts`,void 0),f=c.__decorate([l.customUiKitElement(`ds-theme-provider`)],f);
@@ -0,0 +1 @@
1
+ const e=require(`../../node_modules/.pnpm/@lit_context@1.1.6/node_modules/@lit/context/lib/decorators/consume.cjs`),t=require(`../ds-theme-provider/themeContext.cjs`),n=require(`../../node_modules/.pnpm/lit-html@3.3.1/node_modules/lit-html/lit-html.cjs`),r=require(`../../node_modules/.pnpm/lit-element@4.2.1/node_modules/lit-element/lit-element.cjs`);require(`../../node_modules/.pnpm/lit@3.3.1/node_modules/lit/index.cjs`);const i=require(`../../node_modules/.pnpm/@lit_reactive-element@2.1.1/node_modules/@lit/reactive-element/decorators/property.cjs`);require(`../../node_modules/.pnpm/lit@3.3.1/node_modules/lit/decorators.cjs`);const a=require(`../../_virtual/_@oxc-project_runtime@0.122.0/helpers/decorate.cjs`),o=require(`../../decorators/customUiKitElement.cjs`);var s=class extends r.i{getMatchingTemplate(){return this.activeTheme?this.querySelector(`template[slot="${this.activeTheme}"]`):null}getDefaultTemplate(){return this.querySelector(`template[slot="default"]`)}render(){let e=this.getMatchingTemplate();if(e)return n.x`${e.content.cloneNode(!0)}`;let t=this.getDefaultTemplate();return t?n.x`${t.content.cloneNode(!0)}`:n.E}};a.__decorate([i.n({attribute:!1}),e.c({context:t.themeContext,subscribe:!0})],s.prototype,`activeTheme`,void 0),s=a.__decorate([o.customUiKitElement(`ds-theme-switch`,{skipTagAsComponentName:!0})],s);
@@ -1 +1 @@
1
- require(`./ds-icon/ds-icon.cjs`),require(`./ds-accordion/ds-accordion.cjs`),require(`./ds-avatar/ds-avatar.cjs`),require(`./ds-badge/ds-badge.cjs`),require(`./ds-basic-card/ds-basic-card.cjs`),require(`./ds-basic-card-image/ds-basic-card-image.cjs`),require(`./ds-divider/ds-divider.cjs`),require(`./ds-basic-card-header/ds-basic-card-header.cjs`),require(`./ds-basic-card-section/ds-basic-card-section.cjs`),require(`./ds-tooltip/ds-tooltip.cjs`),require(`./ds-breadcrumbs-item/ds-breadcrumbs-item.cjs`),require(`./ds-breadcrumbs/ds-breadcrumbs.cjs`),require(`./ds-bullets/ds-bullets.cjs`),require(`./ds-button/ds-button.cjs`),require(`./ds-calendar-day/ds-calendar-day.cjs`),require(`./ds-icon-button/ds-icon-button.cjs`),require(`./ds-calendar/ds-calendar.cjs`),require(`./ds-carousel-indicator/ds-carousel-indicator.cjs`),require(`./ds-checkbox-group/ds-checkbox-group.cjs`),require(`./ds-checkbox/ds-checkbox.cjs`),require(`./ds-chip/ds-chip.cjs`),require(`./ds-chips/ds-chips.cjs`),require(`./ds-currency/ds-currency.cjs`),require(`./ds-date-picker/ds-date-picker.cjs`),require(`./ds-dialog/ds-dialog.cjs`),require(`./ds-dialog-body/ds-dialog-body.cjs`),require(`./ds-dialog-footer/ds-dialog-footer.cjs`),require(`./ds-dialog-fullscreen/ds-dialog-fullscreen.cjs`),require(`./ds-dialog-header/ds-dialog-header.cjs`),require(`./ds-drawer/ds-drawer.cjs`),require(`./ds-favourite-action/ds-favourite-action.cjs`),require(`./ds-hyperlink/ds-hyperlink.cjs`),require(`./ds-input/ds-input.cjs`),require(`./ds-interactive-card/ds-interactive-card.cjs`),require(`./ds-link-button/ds-link-button.cjs`),require(`./ds-loader-bar/ds-loader-bar.cjs`),require(`./ds-loader-dots/ds-loader-dots.cjs`),require(`./ds-loader-logo/ds-loader-logo.cjs`),require(`./ds-loader-spinner/ds-loader-spinner.cjs`),require(`./ds-logo/ds-logo.cjs`),require(`./ds-main-title/ds-main-title.cjs`),require(`./ds-map-pin/ds-map-pin.cjs`),require(`./ds-modal/ds-modal.cjs`),require(`./ds-text-input/ds-text-input.cjs`),require(`./ds-password-input/ds-password-input.cjs`),require(`./ds-picker-item/ds-picker-item.cjs`),require(`./ds-portal/ds-portal.cjs`),require(`./ds-progress-bar/ds-progress-bar.cjs`),require(`./ds-radio/ds-radio.cjs`),require(`./ds-radio-button-group/ds-radio-button-group.cjs`),require(`./ds-radio-button/ds-radio-button.cjs`),require(`./ds-radio-group/ds-radio-group.cjs`),require(`./ds-rating/ds-rating.cjs`),require(`./ds-search/ds-search.cjs`),require(`./ds-search-input/ds-search-input.cjs`),require(`./ds-secondary-navigation/ds-secondary-navigation.cjs`),require(`./ds-segmented-control/ds-segmented-control.cjs`),require(`./ds-select/ds-select.cjs`),require(`./ds-selection/ds-selection.cjs`),require(`./ds-skeleton/ds-skeleton.cjs`),require(`./ds-sidebar-navigation/ds-sidebar-navigation.cjs`),require(`./ds-slider/ds-slider.cjs`),require(`./ds-static-box/ds-static-box.cjs`),require(`./ds-stepper/ds-stepper.cjs`),require(`./ds-tabs/ds-tabs.cjs`),require(`./ds-tag/ds-tag.cjs`),require(`./ds-text/ds-text.cjs`),require(`./ds-textarea/ds-textarea.cjs`),require(`./ds-theme-provider/ds-theme-provider.cjs`),require(`./ds-toast-message/ds-toast-message.cjs`),require(`./ds-toast/ds-toast.cjs`),require(`./ds-inline-alert/ds-inline-alert.cjs`),require(`./ds-toggle-button/ds-toggle-button.cjs`),require(`./ds-toggle-switch/ds-toggle-switch.cjs`),require(`./ds-value-unit/ds-value-unit.cjs`),require(`./ds-media-control/ds-media-control.cjs`),require(`./ds-list-item/ds-list-item.cjs`),require(`./ds-list/ds-list.cjs`),require(`./ds-icon-button-group/ds-icon-button-group.cjs`),require(`./ds-navigation-controls/ds-navigation-controls.cjs`),require(`./ds-table/ds-table.cjs`),require(`./ds-table-row/ds-table-row.cjs`),require(`./ds-table-cell/ds-table-cell.cjs`);
1
+ require(`./ds-icon/ds-icon.cjs`),require(`./ds-accordion/ds-accordion.cjs`),require(`./ds-avatar/ds-avatar.cjs`),require(`./ds-badge/ds-badge.cjs`),require(`./ds-basic-card/ds-basic-card.cjs`),require(`./ds-basic-card-image/ds-basic-card-image.cjs`),require(`./ds-divider/ds-divider.cjs`),require(`./ds-basic-card-header/ds-basic-card-header.cjs`),require(`./ds-basic-card-section/ds-basic-card-section.cjs`),require(`./ds-tooltip/ds-tooltip.cjs`),require(`./ds-breadcrumbs-item/ds-breadcrumbs-item.cjs`),require(`./ds-breadcrumbs/ds-breadcrumbs.cjs`),require(`./ds-bullets/ds-bullets.cjs`),require(`./ds-button/ds-button.cjs`),require(`./ds-calendar-day/ds-calendar-day.cjs`),require(`./ds-icon-button/ds-icon-button.cjs`),require(`./ds-calendar/ds-calendar.cjs`),require(`./ds-carousel-indicator/ds-carousel-indicator.cjs`),require(`./ds-checkbox-group/ds-checkbox-group.cjs`),require(`./ds-checkbox/ds-checkbox.cjs`),require(`./ds-chip/ds-chip.cjs`),require(`./ds-chips/ds-chips.cjs`),require(`./ds-currency/ds-currency.cjs`),require(`./ds-date-picker/ds-date-picker.cjs`),require(`./ds-dialog/ds-dialog.cjs`),require(`./ds-dialog-body/ds-dialog-body.cjs`),require(`./ds-dialog-footer/ds-dialog-footer.cjs`),require(`./ds-dialog-fullscreen/ds-dialog-fullscreen.cjs`),require(`./ds-dialog-header/ds-dialog-header.cjs`),require(`./ds-drawer/ds-drawer.cjs`),require(`./ds-favourite-action/ds-favourite-action.cjs`),require(`./ds-hyperlink/ds-hyperlink.cjs`),require(`./ds-input/ds-input.cjs`),require(`./ds-interactive-card/ds-interactive-card.cjs`),require(`./ds-link-button/ds-link-button.cjs`),require(`./ds-loader-bar/ds-loader-bar.cjs`),require(`./ds-loader-dots/ds-loader-dots.cjs`),require(`./ds-loader-logo/ds-loader-logo.cjs`),require(`./ds-loader-spinner/ds-loader-spinner.cjs`),require(`./ds-logo/ds-logo.cjs`),require(`./ds-main-title/ds-main-title.cjs`),require(`./ds-map-pin/ds-map-pin.cjs`),require(`./ds-modal/ds-modal.cjs`),require(`./ds-text-input/ds-text-input.cjs`),require(`./ds-password-input/ds-password-input.cjs`),require(`./ds-picker-item/ds-picker-item.cjs`),require(`./ds-portal/ds-portal.cjs`),require(`./ds-progress-bar/ds-progress-bar.cjs`),require(`./ds-radio/ds-radio.cjs`),require(`./ds-radio-button-group/ds-radio-button-group.cjs`),require(`./ds-radio-button/ds-radio-button.cjs`),require(`./ds-radio-group/ds-radio-group.cjs`),require(`./ds-rating/ds-rating.cjs`),require(`./ds-search/ds-search.cjs`),require(`./ds-search-input/ds-search-input.cjs`),require(`./ds-secondary-navigation/ds-secondary-navigation.cjs`),require(`./ds-segmented-control/ds-segmented-control.cjs`),require(`./ds-select/ds-select.cjs`),require(`./ds-selection/ds-selection.cjs`),require(`./ds-skeleton/ds-skeleton.cjs`),require(`./ds-sidebar-navigation/ds-sidebar-navigation.cjs`),require(`./ds-slider/ds-slider.cjs`),require(`./ds-static-box/ds-static-box.cjs`),require(`./ds-stepper/ds-stepper.cjs`),require(`./ds-tabs/ds-tabs.cjs`),require(`./ds-tag/ds-tag.cjs`),require(`./ds-text/ds-text.cjs`),require(`./ds-textarea/ds-textarea.cjs`),require(`./ds-theme-provider/ds-theme-provider.cjs`),require(`./ds-theme-switch/ds-theme-switch.cjs`),require(`./ds-toast-message/ds-toast-message.cjs`),require(`./ds-toast/ds-toast.cjs`),require(`./ds-inline-alert/ds-inline-alert.cjs`),require(`./ds-toggle-button/ds-toggle-button.cjs`),require(`./ds-toggle-switch/ds-toggle-switch.cjs`),require(`./ds-value-unit/ds-value-unit.cjs`),require(`./ds-media-control/ds-media-control.cjs`),require(`./ds-list-item/ds-list-item.cjs`),require(`./ds-list/ds-list.cjs`),require(`./ds-icon-button-group/ds-icon-button-group.cjs`),require(`./ds-navigation-controls/ds-navigation-controls.cjs`),require(`./ds-table/ds-table.cjs`),require(`./ds-table-row/ds-table-row.cjs`),require(`./ds-table-cell/ds-table-cell.cjs`);
@@ -1 +1 @@
1
- require(`../utils/version.cjs`);function e(e,t){return function(n){if(!n?.prototype)throw TypeError(`@customUiKitElement requires a class that extends HTMLElement.`);let r=e;if(globalThis?.customElements?.get(r))return;let i=t?.skipTagAsComponentName?[]:[e];Array.isArray(t?.extendComponentNames)&&(i=[...t.extendComponentNames,...i]),globalThis?.customElements?.define?.(r,class extends n{static{this.componentName=i}connectedCallback(){n.prototype.connectedCallback?.call(this),this.setAttribute(`data-ui-kit-version`,`2.0.0-canary.140`)}})}}exports.customUiKitElement=e;
1
+ require(`../utils/version.cjs`);function e(e,t){return function(n){if(!n?.prototype)throw TypeError(`@customUiKitElement requires a class that extends HTMLElement.`);let r=e;if(globalThis?.customElements?.get(r))return;let i=t?.skipTagAsComponentName?[]:[e];Array.isArray(t?.extendComponentNames)&&(i=[...t.extendComponentNames,...i]),globalThis?.customElements?.define?.(r,class extends n{static{this.componentName=i}connectedCallback(){n.prototype.connectedCallback?.call(this),this.setAttribute(`data-ui-kit-version`,`2.0.0-canary.142`)}})}}exports.customUiKitElement=e;
@@ -1 +1 @@
1
- const e=require(`../core/theme.constants.cjs`),t=require(`./PubSub.cjs`);var n=class{constructor(){this.icons={},this.handleChangeTheme=e=>{if(this.theme===e)return;this.theme=e;let t=Object.keys(this.icons);this.icons={},t.forEach(e=>this.fetchIcon(e))},this.fetchIcon=async(t,n={})=>{let r=typeof sessionStorage<`u`?sessionStorage?.getItem(e.THEME_STORAGE_KEY):null;!this.theme&&r&&(this.theme=r);let i=this.icons[t];if(i)return await i;let a=this.loadIcon(t,n).catch(e=>{throw delete this.icons[t],e});return this.icons[t]=a,a},this.loadIcon=(e,{cache:t=`force-cache`,...n})=>!this.theme||typeof fetch>`u`?Promise.resolve(`<svg class="ds-icon"></svg>`):fetch(`https://ds-assets.cupra.com/icons/${this.theme}/${e}.svg`,{cache:t,...n}).then(e=>e.text()).catch(t=>{if(t?.name===`AbortError`)throw t;return console.error(`Failed to fetch icon "${e}":`,t),``}),t.pubSub.subscribe(`theme`,this.handleChangeTheme)}},r=Symbol.for(`@cupra/ui-kit/icons-manager/2.0.0-canary.140`),i=globalThis,a=i[r];a||(a=new n,Object.defineProperty(i,r,{value:a,writable:!1,configurable:!1,enumerable:!1}));var o=a;exports.iconsManager=o;
1
+ const e=require(`../core/theme.constants.cjs`),t=require(`./PubSub.cjs`);var n=class{constructor(){this.icons={},this.handleChangeTheme=e=>{if(this.theme===e)return;this.theme=e;let t=Object.keys(this.icons);this.icons={},t.forEach(e=>this.fetchIcon(e))},this.fetchIcon=async(t,n={})=>{let r=typeof sessionStorage<`u`?sessionStorage?.getItem(e.THEME_STORAGE_KEY):null;!this.theme&&r&&(this.theme=r);let i=this.icons[t];if(i)return await i;let a=this.loadIcon(t,n).catch(e=>{throw delete this.icons[t],e});return this.icons[t]=a,a},this.loadIcon=(e,{cache:t=`force-cache`,...n})=>!this.theme||typeof fetch>`u`?Promise.resolve(`<svg class="ds-icon"></svg>`):fetch(`https://ds-assets.cupra.com/icons/${this.theme}/${e}.svg`,{cache:t,...n}).then(e=>e.text()).catch(t=>{if(t?.name===`AbortError`)throw t;return console.error(`Failed to fetch icon "${e}":`,t),``}),t.pubSub.subscribe(`theme`,this.handleChangeTheme)}},r=Symbol.for(`@cupra/ui-kit/icons-manager/2.0.0-canary.142`),i=globalThis,a=i[r];a||(a=new n,Object.defineProperty(i,r,{value:a,writable:!1,configurable:!1,enumerable:!1}));var o=a;exports.iconsManager=o;
@@ -1 +1 @@
1
- var e=class{constructor(){this.subscribers={},this.lastPublishedData={}}subscribe(e,t){return this.subscribers[e]||(this.subscribers[e]=[]),this.subscribers[e].push(t),this.lastPublishedData[e]}unsubscribe(e,t){this.subscribers[e]&&(this.subscribers[e]=this.subscribers[e].filter(e=>e!==t))}publish(e,t){this.lastPublishedData[e]=t,this.subscribers[e]&&this.subscribers[e].forEach(n=>{try{n(t)}catch(t){console.error(`Error in subscriber for event "${e}":`,t)}})}},t=Symbol.for(`@cupra/ui-kit/pubsub/2.0.0-canary.140`),n=globalThis,r=n[t];r||(r=new e,Object.defineProperty(n,t,{value:r,writable:!1,configurable:!1,enumerable:!1}));var i=r;exports.pubSub=i;
1
+ var e=class{constructor(){this.subscribers={},this.lastPublishedData={}}subscribe(e,t){return this.subscribers[e]||(this.subscribers[e]=[]),this.subscribers[e].push(t),this.lastPublishedData[e]}unsubscribe(e,t){this.subscribers[e]&&(this.subscribers[e]=this.subscribers[e].filter(e=>e!==t))}publish(e,t){this.lastPublishedData[e]=t,this.subscribers[e]&&this.subscribers[e].forEach(n=>{try{n(t)}catch(t){console.error(`Error in subscriber for event "${e}":`,t)}})}},t=Symbol.for(`@cupra/ui-kit/pubsub/2.0.0-canary.142`),n=globalThis,r=n[t];r||(r=new e,Object.defineProperty(n,t,{value:r,writable:!1,configurable:!1,enumerable:!1}));var i=r;exports.pubSub=i;
@@ -1 +1 @@
1
- var e=require(`../concurrencyLimit.cjs`).concurrencyLimit(20),t=class t{constructor(){this.stylePromises=new Map,this.getStyles=async({componentName:t,theme:n})=>{if(!n||!t)return;let r=`https://ds-assets.cupra.com/2.0.0-canary.140/styles/${n}/components/${t}.css`,i=this.getCachedStyleSheetPromise({url:r});if(i)return i;let a=e(()=>this.fetchStyle({url:r})).then(e=>(e||this.stylePromises.delete(r),e));return this.stylePromises.set(r,a),this.stylePromises.get(r)}}async fetchStyle({url:e}){try{if(typeof fetch>`u`)return;let t=await fetch(e,{cache:`force-cache`});if(t.ok)return t.text()}catch(t){console.error(`Failed to fetch Style Sheet "${e}":`,t)}}getCachedStyleSheetPromise({url:e}){return this.stylePromises.get(e)}static getInstance(){return t.instance||=new t,t.instance}}.getInstance();exports.stylesRegistry=t;
1
+ var e=require(`../concurrencyLimit.cjs`).concurrencyLimit(20),t=class t{constructor(){this.stylePromises=new Map,this.getStyles=async({componentName:t,theme:n})=>{if(!n||!t)return;let r=`https://ds-assets.cupra.com/2.0.0-canary.142/styles/${n}/components/${t}.css`,i=this.getCachedStyleSheetPromise({url:r});if(i)return i;let a=e(()=>this.fetchStyle({url:r})).then(e=>(e||this.stylePromises.delete(r),e));return this.stylePromises.set(r,a),this.stylePromises.get(r)}}async fetchStyle({url:e}){try{if(typeof fetch>`u`)return;let t=await fetch(e,{cache:`force-cache`});if(t.ok)return t.text()}catch(t){console.error(`Failed to fetch Style Sheet "${e}":`,t)}}getCachedStyleSheetPromise({url:e}){return this.stylePromises.get(e)}static getInstance(){return t.instance||=new t,t.instance}}.getInstance();exports.stylesRegistry=t;
@@ -1 +1 @@
1
- var e=`2.0.0-canary.140`,t=`--v${e.replaceAll(`.`,`-`)}`;exports.VERSION=e,exports.VERSION_TAG_SUFFIX=t;
1
+ var e=`2.0.0-canary.142`,t=`--v${e.replaceAll(`.`,`-`)}`;exports.VERSION=e,exports.VERSION_TAG_SUFFIX=t;
@@ -50,7 +50,7 @@ var p = class extends o {
50
50
  }
51
51
  loadThemeStyles() {
52
52
  return this.loadStyles ? new Promise((e, t) => {
53
- let n = "/2.0.0-canary.140", r = `https://ds-assets.cupra.com${n}/styles/${this.theme}/theme.css`;
53
+ let n = "/2.0.0-canary.142", r = `https://ds-assets.cupra.com${n}/styles/${this.theme}/theme.css`;
54
54
  if (document.head.querySelector(`link[href="${r}"]`)) e();
55
55
  else {
56
56
  let i = `ui-kit-theme-${n}`, a = document.getElementById(i), o = document.createElement("link");
@@ -0,0 +1,29 @@
1
+ import { c as e } from "../../node_modules/.pnpm/@lit_context@1.1.6/node_modules/@lit/context/lib/decorators/consume.js";
2
+ import { themeContext as t } from "../ds-theme-provider/themeContext.js";
3
+ import { E as n, x as r } from "../../node_modules/.pnpm/lit-html@3.3.1/node_modules/lit-html/lit-html.js";
4
+ import { i } from "../../node_modules/.pnpm/lit-element@4.2.1/node_modules/lit-element/lit-element.js";
5
+ import "../../node_modules/.pnpm/lit@3.3.1/node_modules/lit/index.js";
6
+ import { n as a } from "../../node_modules/.pnpm/@lit_reactive-element@2.1.1/node_modules/@lit/reactive-element/decorators/property.js";
7
+ import "../../node_modules/.pnpm/lit@3.3.1/node_modules/lit/decorators.js";
8
+ import { __decorate as o } from "../../_virtual/_@oxc-project_runtime@0.122.0/helpers/decorate.js";
9
+ import { customUiKitElement as s } from "../../decorators/customUiKitElement.js";
10
+ //#region src/components/ds-theme-switch/ds-theme-switch.ts
11
+ var c = class extends i {
12
+ getMatchingTemplate() {
13
+ return this.activeTheme ? this.querySelector(`template[slot="${this.activeTheme}"]`) : null;
14
+ }
15
+ getDefaultTemplate() {
16
+ return this.querySelector("template[slot=\"default\"]");
17
+ }
18
+ render() {
19
+ let e = this.getMatchingTemplate();
20
+ if (e) return r`${e.content.cloneNode(!0)}`;
21
+ let t = this.getDefaultTemplate();
22
+ return t ? r`${t.content.cloneNode(!0)}` : n;
23
+ }
24
+ };
25
+ o([a({ attribute: !1 }), e({
26
+ context: t,
27
+ subscribe: !0
28
+ })], c.prototype, "activeTheme", void 0), c = o([s("ds-theme-switch", { skipTagAsComponentName: !0 })], c);
29
+ //#endregion
@@ -67,6 +67,7 @@ import "./ds-tag/ds-tag.js";
67
67
  import "./ds-text/ds-text.js";
68
68
  import "./ds-textarea/ds-textarea.js";
69
69
  import "./ds-theme-provider/ds-theme-provider.js";
70
+ import "./ds-theme-switch/ds-theme-switch.js";
70
71
  import "./ds-toast-message/ds-toast-message.js";
71
72
  import "./ds-toast/ds-toast.js";
72
73
  import "./ds-inline-alert/ds-inline-alert.js";
@@ -11,7 +11,7 @@ function e(e, t) {
11
11
  this.componentName = i;
12
12
  }
13
13
  connectedCallback() {
14
- n.prototype.connectedCallback?.call(this), this.setAttribute("data-ui-kit-version", "2.0.0-canary.140");
14
+ n.prototype.connectedCallback?.call(this), this.setAttribute("data-ui-kit-version", "2.0.0-canary.142");
15
15
  }
16
16
  });
17
17
  };
@@ -25,7 +25,7 @@ var n = class {
25
25
  return console.error(`Failed to fetch icon "${e}":`, t), "";
26
26
  }), t.subscribe("theme", this.handleChangeTheme);
27
27
  }
28
- }, r = Symbol.for("@cupra/ui-kit/icons-manager/2.0.0-canary.140"), i = globalThis, a = i[r];
28
+ }, r = Symbol.for("@cupra/ui-kit/icons-manager/2.0.0-canary.142"), i = globalThis, a = i[r];
29
29
  a || (a = new n(), Object.defineProperty(i, r, {
30
30
  value: a,
31
31
  writable: !1,
@@ -18,7 +18,7 @@ var e = class {
18
18
  }
19
19
  });
20
20
  }
21
- }, t = Symbol.for("@cupra/ui-kit/pubsub/2.0.0-canary.140"), n = globalThis, r = n[t];
21
+ }, t = Symbol.for("@cupra/ui-kit/pubsub/2.0.0-canary.142"), n = globalThis, r = n[t];
22
22
  r || (r = new e(), Object.defineProperty(n, t, {
23
23
  value: r,
24
24
  writable: !1,
@@ -4,7 +4,7 @@ var t = e(20), n = class e {
4
4
  constructor() {
5
5
  this.stylePromises = /* @__PURE__ */ new Map(), this.getStyles = async ({ componentName: e, theme: n }) => {
6
6
  if (!n || !e) return;
7
- let r = `https://ds-assets.cupra.com/2.0.0-canary.140/styles/${n}/components/${e}.css`, i = this.getCachedStyleSheetPromise({ url: r });
7
+ let r = `https://ds-assets.cupra.com/2.0.0-canary.142/styles/${n}/components/${e}.css`, i = this.getCachedStyleSheetPromise({ url: r });
8
8
  if (i) return i;
9
9
  let a = t(() => this.fetchStyle({ url: r })).then((e) => (e || this.stylePromises.delete(r), e));
10
10
  return this.stylePromises.set(r, a), this.stylePromises.get(r);
@@ -1,4 +1,4 @@
1
1
  //#region src/utils/version.ts
2
- var e = "2.0.0-canary.140", t = `--v${e.replaceAll(".", "-")}`;
2
+ var e = "2.0.0-canary.142", t = `--v${e.replaceAll(".", "-")}`;
3
3
  //#endregion
4
4
  export { e as VERSION, t as VERSION_TAG_SUFFIX };
@@ -0,0 +1,12 @@
1
+ import { LitElement, nothing } from 'lit';
2
+ export declare class DsThemeSwitch extends LitElement {
3
+ private activeTheme?;
4
+ private getMatchingTemplate;
5
+ private getDefaultTemplate;
6
+ render(): import("lit").TemplateResult<1> | typeof nothing;
7
+ }
8
+ declare global {
9
+ interface HTMLElementTagNameMap {
10
+ 'ds-theme-switch': DsThemeSwitch;
11
+ }
12
+ }
@@ -0,0 +1,2 @@
1
+ import type { CommonAttrs } from '../../types/types';
2
+ export type DsThemeSwitchAttrs = CommonAttrs;
@@ -66,6 +66,7 @@ import './ds-text/ds-text.ts';
66
66
  import './ds-text-input/ds-text-input.ts';
67
67
  import './ds-textarea/ds-textarea.ts';
68
68
  import './ds-theme-provider/ds-theme-provider.ts';
69
+ import './ds-theme-switch/ds-theme-switch.ts';
69
70
  import './ds-toast/ds-toast.ts';
70
71
  import './ds-toast-message/ds-toast-message.ts';
71
72
  import './ds-inline-alert/ds-inline-alert.ts';
@@ -1,4 +1,4 @@
1
1
  const e=require(`../../node_modules/.pnpm/@lit_context@1.1.6/node_modules/@lit/context/lib/decorators/provide.cjs`),t=require(`./themeContext.cjs`),n=require(`../../core/theme.constants.cjs`),r=require(`../../utils/PubSub.cjs`),i=require(`../../node_modules/.pnpm/lit-html@3.3.1/node_modules/lit-html/lit-html.cjs`),a=require(`../../node_modules/.pnpm/lit-element@4.2.1/node_modules/lit-element/lit-element.cjs`);require(`../../node_modules/.pnpm/lit@3.3.1/node_modules/lit/index.cjs`);const o=require(`../../node_modules/.pnpm/@lit_reactive-element@2.1.1/node_modules/@lit/reactive-element/decorators/property.cjs`),s=require(`../../node_modules/.pnpm/@lit_reactive-element@2.1.1/node_modules/@lit/reactive-element/decorators/state.cjs`);require(`../../node_modules/.pnpm/lit@3.3.1/node_modules/lit/decorators.cjs`);const c=require(`../../_virtual/_@oxc-project_runtime@0.122.0/helpers/decorate.cjs`),l=require(`../../decorators/customUiKitElement.cjs`),u=require(`../../utils/booleanConverter.cjs`),d=require(`../../styles/source/shared/fonts-config.cjs`);var f=class extends a.i{constructor(...e){super(...e),this.loadFonts=!0,this.loadStyles=!0,this.cssLoaded=!1,this.loadedFonts=new Set}updated(e){super.updated(e),e.has(`theme`)&&(r.pubSub.publish(`theme`,this.theme),sessionStorage?.setItem(n.THEME_STORAGE_KEY,this.theme),typeof FontFace<`u`&&document?.fonts&&this.loadThemeFonts(),this.loadThemeStyles().then(()=>{this.cssLoaded=!0,this.dispatchEvent(new CustomEvent(`ui-kit:ready`,{bubbles:!0,composed:!0}))}))}loadThemeFonts(){d.fontsConfig[this.theme]?.fonts.forEach(e=>{this.loadThemeFont(e)})}async loadThemeFont({weight:e,name:t,file:n}){if(!this.loadFonts)return Promise.resolve();let r=`${t}-${e}`;if(this.loadedFonts.has(r))return;let i=new FontFace(t,`url('https://ds-assets.cupra.com/fonts/${this.theme}/${n}.woff2') format('woff2'),
2
2
  url('https://ds-assets.cupra.com/fonts/${this.theme}/${n}.woff') format('woff'),
3
3
  url('https://ds-assets.cupra.com/fonts/${this.theme}/${n}.ttf') format('truetype'),
4
- url('https://ds-assets.cupra.com/fonts/${this.theme}/${n}.otf') format('opentype')`,{style:`normal`,weight:e,display:`swap`});try{await i.load(),document.fonts.add(i),this.loadedFonts.add(r)}catch(n){console.error(`Error loading "${t}" font with "${e}" weight:`,n)}}loadThemeStyles(){return this.loadStyles?new Promise((e,t)=>{let n=`/2.0.0-canary.140`,r=`https://ds-assets.cupra.com${n}/styles/${this.theme}/theme.css`;if(document.head.querySelector(`link[href="${r}"]`))e();else{let i=`ui-kit-theme-${n}`,a=document.getElementById(i),o=document.createElement(`link`);o.id=i,o.rel=`stylesheet`,o.href=r,o.onload=()=>e(),o.onerror=()=>t(Error(`Failed to load theme CSS: ${r}`)),document.head.appendChild(o),a?.remove()}}):Promise.resolve()}render(){return this.cssLoaded?i.x`<slot></slot>`:i.E}};c.__decorate([o.n({type:Boolean,converter:u.booleanConverter,attribute:`load-fonts`})],f.prototype,`loadFonts`,void 0),c.__decorate([o.n({type:Boolean,converter:u.booleanConverter,attribute:`load-styles`})],f.prototype,`loadStyles`,void 0),c.__decorate([e.e({context:t.themeContext}),o.n({type:String})],f.prototype,`theme`,void 0),c.__decorate([s.r()],f.prototype,`cssLoaded`,void 0),c.__decorate([s.r()],f.prototype,`loadedFonts`,void 0),f=c.__decorate([l.customUiKitElement(`ds-theme-provider`)],f);
4
+ url('https://ds-assets.cupra.com/fonts/${this.theme}/${n}.otf') format('opentype')`,{style:`normal`,weight:e,display:`swap`});try{await i.load(),document.fonts.add(i),this.loadedFonts.add(r)}catch(n){console.error(`Error loading "${t}" font with "${e}" weight:`,n)}}loadThemeStyles(){return this.loadStyles?new Promise((e,t)=>{let n=`/2.0.0-canary.142`,r=`https://ds-assets.cupra.com${n}/styles/${this.theme}/theme.css`;if(document.head.querySelector(`link[href="${r}"]`))e();else{let i=`ui-kit-theme-${n}`,a=document.getElementById(i),o=document.createElement(`link`);o.id=i,o.rel=`stylesheet`,o.href=r,o.onload=()=>e(),o.onerror=()=>t(Error(`Failed to load theme CSS: ${r}`)),document.head.appendChild(o),a?.remove()}}):Promise.resolve()}render(){return this.cssLoaded?i.x`<slot></slot>`:i.E}};c.__decorate([o.n({type:Boolean,converter:u.booleanConverter,attribute:`load-fonts`})],f.prototype,`loadFonts`,void 0),c.__decorate([o.n({type:Boolean,converter:u.booleanConverter,attribute:`load-styles`})],f.prototype,`loadStyles`,void 0),c.__decorate([e.e({context:t.themeContext}),o.n({type:String})],f.prototype,`theme`,void 0),c.__decorate([s.r()],f.prototype,`cssLoaded`,void 0),c.__decorate([s.r()],f.prototype,`loadedFonts`,void 0),f=c.__decorate([l.customUiKitElement(`ds-theme-provider`)],f);
@@ -0,0 +1 @@
1
+ const e=require(`../../node_modules/.pnpm/@lit_context@1.1.6/node_modules/@lit/context/lib/decorators/consume.cjs`),t=require(`../ds-theme-provider/themeContext.cjs`),n=require(`../../node_modules/.pnpm/lit-html@3.3.1/node_modules/lit-html/lit-html.cjs`),r=require(`../../node_modules/.pnpm/lit-element@4.2.1/node_modules/lit-element/lit-element.cjs`);require(`../../node_modules/.pnpm/lit@3.3.1/node_modules/lit/index.cjs`);const i=require(`../../node_modules/.pnpm/@lit_reactive-element@2.1.1/node_modules/@lit/reactive-element/decorators/property.cjs`);require(`../../node_modules/.pnpm/lit@3.3.1/node_modules/lit/decorators.cjs`);const a=require(`../../_virtual/_@oxc-project_runtime@0.122.0/helpers/decorate.cjs`),o=require(`../../decorators/customUiKitElement.cjs`);var s=class extends r.i{getMatchingTemplate(){return this.activeTheme?this.querySelector(`template[slot="${this.activeTheme}"]`):null}getDefaultTemplate(){return this.querySelector(`template[slot="default"]`)}render(){let e=this.getMatchingTemplate();if(e)return n.x`${e.content.cloneNode(!0)}`;let t=this.getDefaultTemplate();return t?n.x`${t.content.cloneNode(!0)}`:n.E}};a.__decorate([i.n({attribute:!1}),e.c({context:t.themeContext,subscribe:!0})],s.prototype,`activeTheme`,void 0),s=a.__decorate([o.customUiKitElement(`ds-theme-switch`,{skipTagAsComponentName:!0})],s);
@@ -1 +1 @@
1
- require(`./ds-icon/ds-icon.cjs`),require(`./ds-accordion/ds-accordion.cjs`),require(`./ds-avatar/ds-avatar.cjs`),require(`./ds-badge/ds-badge.cjs`),require(`./ds-basic-card/ds-basic-card.cjs`),require(`./ds-basic-card-image/ds-basic-card-image.cjs`),require(`./ds-divider/ds-divider.cjs`),require(`./ds-basic-card-header/ds-basic-card-header.cjs`),require(`./ds-basic-card-section/ds-basic-card-section.cjs`),require(`./ds-tooltip/ds-tooltip.cjs`),require(`./ds-breadcrumbs-item/ds-breadcrumbs-item.cjs`),require(`./ds-breadcrumbs/ds-breadcrumbs.cjs`),require(`./ds-bullets/ds-bullets.cjs`),require(`./ds-button/ds-button.cjs`),require(`./ds-calendar-day/ds-calendar-day.cjs`),require(`./ds-icon-button/ds-icon-button.cjs`),require(`./ds-calendar/ds-calendar.cjs`),require(`./ds-carousel-indicator/ds-carousel-indicator.cjs`),require(`./ds-checkbox-group/ds-checkbox-group.cjs`),require(`./ds-checkbox/ds-checkbox.cjs`),require(`./ds-chip/ds-chip.cjs`),require(`./ds-chips/ds-chips.cjs`),require(`./ds-currency/ds-currency.cjs`),require(`./ds-date-picker/ds-date-picker.cjs`),require(`./ds-dialog/ds-dialog.cjs`),require(`./ds-dialog-body/ds-dialog-body.cjs`),require(`./ds-dialog-footer/ds-dialog-footer.cjs`),require(`./ds-dialog-fullscreen/ds-dialog-fullscreen.cjs`),require(`./ds-dialog-header/ds-dialog-header.cjs`),require(`./ds-drawer/ds-drawer.cjs`),require(`./ds-favourite-action/ds-favourite-action.cjs`),require(`./ds-hyperlink/ds-hyperlink.cjs`),require(`./ds-input/ds-input.cjs`),require(`./ds-interactive-card/ds-interactive-card.cjs`),require(`./ds-link-button/ds-link-button.cjs`),require(`./ds-loader-bar/ds-loader-bar.cjs`),require(`./ds-loader-dots/ds-loader-dots.cjs`),require(`./ds-loader-logo/ds-loader-logo.cjs`),require(`./ds-loader-spinner/ds-loader-spinner.cjs`),require(`./ds-logo/ds-logo.cjs`),require(`./ds-main-title/ds-main-title.cjs`),require(`./ds-map-pin/ds-map-pin.cjs`),require(`./ds-modal/ds-modal.cjs`),require(`./ds-text-input/ds-text-input.cjs`),require(`./ds-password-input/ds-password-input.cjs`),require(`./ds-picker-item/ds-picker-item.cjs`),require(`./ds-portal/ds-portal.cjs`),require(`./ds-progress-bar/ds-progress-bar.cjs`),require(`./ds-radio/ds-radio.cjs`),require(`./ds-radio-button-group/ds-radio-button-group.cjs`),require(`./ds-radio-button/ds-radio-button.cjs`),require(`./ds-radio-group/ds-radio-group.cjs`),require(`./ds-rating/ds-rating.cjs`),require(`./ds-search/ds-search.cjs`),require(`./ds-search-input/ds-search-input.cjs`),require(`./ds-secondary-navigation/ds-secondary-navigation.cjs`),require(`./ds-segmented-control/ds-segmented-control.cjs`),require(`./ds-select/ds-select.cjs`),require(`./ds-selection/ds-selection.cjs`),require(`./ds-skeleton/ds-skeleton.cjs`),require(`./ds-sidebar-navigation/ds-sidebar-navigation.cjs`),require(`./ds-slider/ds-slider.cjs`),require(`./ds-static-box/ds-static-box.cjs`),require(`./ds-stepper/ds-stepper.cjs`),require(`./ds-tabs/ds-tabs.cjs`),require(`./ds-tag/ds-tag.cjs`),require(`./ds-text/ds-text.cjs`),require(`./ds-textarea/ds-textarea.cjs`),require(`./ds-theme-provider/ds-theme-provider.cjs`),require(`./ds-toast-message/ds-toast-message.cjs`),require(`./ds-toast/ds-toast.cjs`),require(`./ds-inline-alert/ds-inline-alert.cjs`),require(`./ds-toggle-button/ds-toggle-button.cjs`),require(`./ds-toggle-switch/ds-toggle-switch.cjs`),require(`./ds-value-unit/ds-value-unit.cjs`),require(`./ds-media-control/ds-media-control.cjs`),require(`./ds-list-item/ds-list-item.cjs`),require(`./ds-list/ds-list.cjs`),require(`./ds-icon-button-group/ds-icon-button-group.cjs`),require(`./ds-navigation-controls/ds-navigation-controls.cjs`),require(`./ds-table/ds-table.cjs`),require(`./ds-table-row/ds-table-row.cjs`),require(`./ds-table-cell/ds-table-cell.cjs`);
1
+ require(`./ds-icon/ds-icon.cjs`),require(`./ds-accordion/ds-accordion.cjs`),require(`./ds-avatar/ds-avatar.cjs`),require(`./ds-badge/ds-badge.cjs`),require(`./ds-basic-card/ds-basic-card.cjs`),require(`./ds-basic-card-image/ds-basic-card-image.cjs`),require(`./ds-divider/ds-divider.cjs`),require(`./ds-basic-card-header/ds-basic-card-header.cjs`),require(`./ds-basic-card-section/ds-basic-card-section.cjs`),require(`./ds-tooltip/ds-tooltip.cjs`),require(`./ds-breadcrumbs-item/ds-breadcrumbs-item.cjs`),require(`./ds-breadcrumbs/ds-breadcrumbs.cjs`),require(`./ds-bullets/ds-bullets.cjs`),require(`./ds-button/ds-button.cjs`),require(`./ds-calendar-day/ds-calendar-day.cjs`),require(`./ds-icon-button/ds-icon-button.cjs`),require(`./ds-calendar/ds-calendar.cjs`),require(`./ds-carousel-indicator/ds-carousel-indicator.cjs`),require(`./ds-checkbox-group/ds-checkbox-group.cjs`),require(`./ds-checkbox/ds-checkbox.cjs`),require(`./ds-chip/ds-chip.cjs`),require(`./ds-chips/ds-chips.cjs`),require(`./ds-currency/ds-currency.cjs`),require(`./ds-date-picker/ds-date-picker.cjs`),require(`./ds-dialog/ds-dialog.cjs`),require(`./ds-dialog-body/ds-dialog-body.cjs`),require(`./ds-dialog-footer/ds-dialog-footer.cjs`),require(`./ds-dialog-fullscreen/ds-dialog-fullscreen.cjs`),require(`./ds-dialog-header/ds-dialog-header.cjs`),require(`./ds-drawer/ds-drawer.cjs`),require(`./ds-favourite-action/ds-favourite-action.cjs`),require(`./ds-hyperlink/ds-hyperlink.cjs`),require(`./ds-input/ds-input.cjs`),require(`./ds-interactive-card/ds-interactive-card.cjs`),require(`./ds-link-button/ds-link-button.cjs`),require(`./ds-loader-bar/ds-loader-bar.cjs`),require(`./ds-loader-dots/ds-loader-dots.cjs`),require(`./ds-loader-logo/ds-loader-logo.cjs`),require(`./ds-loader-spinner/ds-loader-spinner.cjs`),require(`./ds-logo/ds-logo.cjs`),require(`./ds-main-title/ds-main-title.cjs`),require(`./ds-map-pin/ds-map-pin.cjs`),require(`./ds-modal/ds-modal.cjs`),require(`./ds-text-input/ds-text-input.cjs`),require(`./ds-password-input/ds-password-input.cjs`),require(`./ds-picker-item/ds-picker-item.cjs`),require(`./ds-portal/ds-portal.cjs`),require(`./ds-progress-bar/ds-progress-bar.cjs`),require(`./ds-radio/ds-radio.cjs`),require(`./ds-radio-button-group/ds-radio-button-group.cjs`),require(`./ds-radio-button/ds-radio-button.cjs`),require(`./ds-radio-group/ds-radio-group.cjs`),require(`./ds-rating/ds-rating.cjs`),require(`./ds-search/ds-search.cjs`),require(`./ds-search-input/ds-search-input.cjs`),require(`./ds-secondary-navigation/ds-secondary-navigation.cjs`),require(`./ds-segmented-control/ds-segmented-control.cjs`),require(`./ds-select/ds-select.cjs`),require(`./ds-selection/ds-selection.cjs`),require(`./ds-skeleton/ds-skeleton.cjs`),require(`./ds-sidebar-navigation/ds-sidebar-navigation.cjs`),require(`./ds-slider/ds-slider.cjs`),require(`./ds-static-box/ds-static-box.cjs`),require(`./ds-stepper/ds-stepper.cjs`),require(`./ds-tabs/ds-tabs.cjs`),require(`./ds-tag/ds-tag.cjs`),require(`./ds-text/ds-text.cjs`),require(`./ds-textarea/ds-textarea.cjs`),require(`./ds-theme-provider/ds-theme-provider.cjs`),require(`./ds-theme-switch/ds-theme-switch.cjs`),require(`./ds-toast-message/ds-toast-message.cjs`),require(`./ds-toast/ds-toast.cjs`),require(`./ds-inline-alert/ds-inline-alert.cjs`),require(`./ds-toggle-button/ds-toggle-button.cjs`),require(`./ds-toggle-switch/ds-toggle-switch.cjs`),require(`./ds-value-unit/ds-value-unit.cjs`),require(`./ds-media-control/ds-media-control.cjs`),require(`./ds-list-item/ds-list-item.cjs`),require(`./ds-list/ds-list.cjs`),require(`./ds-icon-button-group/ds-icon-button-group.cjs`),require(`./ds-navigation-controls/ds-navigation-controls.cjs`),require(`./ds-table/ds-table.cjs`),require(`./ds-table-row/ds-table-row.cjs`),require(`./ds-table-cell/ds-table-cell.cjs`);
@@ -1 +1 @@
1
- const e=require(`../utils/version.cjs`);function t(t,n){return function(r){if(!r?.prototype)throw TypeError(`@customUiKitElement requires a class that extends HTMLElement.`);let i=`${t}${e.VERSION_TAG_SUFFIX}`;if(globalThis?.customElements?.get(i))return;let a=n?.skipTagAsComponentName?[]:[t];Array.isArray(n?.extendComponentNames)&&(a=[...n.extendComponentNames,...a]),globalThis?.customElements?.define?.(i,class extends r{static{this.componentName=a}connectedCallback(){r.prototype.connectedCallback?.call(this),this.setAttribute(`data-ui-kit-version`,`2.0.0-canary.140`)}})}}exports.customUiKitElement=t;
1
+ const e=require(`../utils/version.cjs`);function t(t,n){return function(r){if(!r?.prototype)throw TypeError(`@customUiKitElement requires a class that extends HTMLElement.`);let i=`${t}${e.VERSION_TAG_SUFFIX}`;if(globalThis?.customElements?.get(i))return;let a=n?.skipTagAsComponentName?[]:[t];Array.isArray(n?.extendComponentNames)&&(a=[...n.extendComponentNames,...a]),globalThis?.customElements?.define?.(i,class extends r{static{this.componentName=a}connectedCallback(){r.prototype.connectedCallback?.call(this),this.setAttribute(`data-ui-kit-version`,`2.0.0-canary.142`)}})}}exports.customUiKitElement=t;
@@ -1 +1 @@
1
- const e=require(`../core/theme.constants.cjs`),t=require(`./PubSub.cjs`);var n=class{constructor(){this.icons={},this.handleChangeTheme=e=>{if(this.theme===e)return;this.theme=e;let t=Object.keys(this.icons);this.icons={},t.forEach(e=>this.fetchIcon(e))},this.fetchIcon=async(t,n={})=>{let r=typeof sessionStorage<`u`?sessionStorage?.getItem(e.THEME_STORAGE_KEY):null;!this.theme&&r&&(this.theme=r);let i=this.icons[t];if(i)return await i;let a=this.loadIcon(t,n).catch(e=>{throw delete this.icons[t],e});return this.icons[t]=a,a},this.loadIcon=(e,{cache:t=`force-cache`,...n})=>!this.theme||typeof fetch>`u`?Promise.resolve(`<svg class="ds-icon"></svg>`):fetch(`https://ds-assets.cupra.com/icons/${this.theme}/${e}.svg`,{cache:t,...n}).then(e=>e.text()).catch(t=>{if(t?.name===`AbortError`)throw t;return console.error(`Failed to fetch icon "${e}":`,t),``}),t.pubSub.subscribe(`theme`,this.handleChangeTheme)}},r=Symbol.for(`@cupra/ui-kit/icons-manager/2.0.0-canary.140`),i=globalThis,a=i[r];a||(a=new n,Object.defineProperty(i,r,{value:a,writable:!1,configurable:!1,enumerable:!1}));var o=a;exports.iconsManager=o;
1
+ const e=require(`../core/theme.constants.cjs`),t=require(`./PubSub.cjs`);var n=class{constructor(){this.icons={},this.handleChangeTheme=e=>{if(this.theme===e)return;this.theme=e;let t=Object.keys(this.icons);this.icons={},t.forEach(e=>this.fetchIcon(e))},this.fetchIcon=async(t,n={})=>{let r=typeof sessionStorage<`u`?sessionStorage?.getItem(e.THEME_STORAGE_KEY):null;!this.theme&&r&&(this.theme=r);let i=this.icons[t];if(i)return await i;let a=this.loadIcon(t,n).catch(e=>{throw delete this.icons[t],e});return this.icons[t]=a,a},this.loadIcon=(e,{cache:t=`force-cache`,...n})=>!this.theme||typeof fetch>`u`?Promise.resolve(`<svg class="ds-icon"></svg>`):fetch(`https://ds-assets.cupra.com/icons/${this.theme}/${e}.svg`,{cache:t,...n}).then(e=>e.text()).catch(t=>{if(t?.name===`AbortError`)throw t;return console.error(`Failed to fetch icon "${e}":`,t),``}),t.pubSub.subscribe(`theme`,this.handleChangeTheme)}},r=Symbol.for(`@cupra/ui-kit/icons-manager/2.0.0-canary.142`),i=globalThis,a=i[r];a||(a=new n,Object.defineProperty(i,r,{value:a,writable:!1,configurable:!1,enumerable:!1}));var o=a;exports.iconsManager=o;
@@ -1 +1 @@
1
- var e=class{constructor(){this.subscribers={},this.lastPublishedData={}}subscribe(e,t){return this.subscribers[e]||(this.subscribers[e]=[]),this.subscribers[e].push(t),this.lastPublishedData[e]}unsubscribe(e,t){this.subscribers[e]&&(this.subscribers[e]=this.subscribers[e].filter(e=>e!==t))}publish(e,t){this.lastPublishedData[e]=t,this.subscribers[e]&&this.subscribers[e].forEach(n=>{try{n(t)}catch(t){console.error(`Error in subscriber for event "${e}":`,t)}})}},t=Symbol.for(`@cupra/ui-kit/pubsub/2.0.0-canary.140`),n=globalThis,r=n[t];r||(r=new e,Object.defineProperty(n,t,{value:r,writable:!1,configurable:!1,enumerable:!1}));var i=r;exports.pubSub=i;
1
+ var e=class{constructor(){this.subscribers={},this.lastPublishedData={}}subscribe(e,t){return this.subscribers[e]||(this.subscribers[e]=[]),this.subscribers[e].push(t),this.lastPublishedData[e]}unsubscribe(e,t){this.subscribers[e]&&(this.subscribers[e]=this.subscribers[e].filter(e=>e!==t))}publish(e,t){this.lastPublishedData[e]=t,this.subscribers[e]&&this.subscribers[e].forEach(n=>{try{n(t)}catch(t){console.error(`Error in subscriber for event "${e}":`,t)}})}},t=Symbol.for(`@cupra/ui-kit/pubsub/2.0.0-canary.142`),n=globalThis,r=n[t];r||(r=new e,Object.defineProperty(n,t,{value:r,writable:!1,configurable:!1,enumerable:!1}));var i=r;exports.pubSub=i;
@@ -1 +1 @@
1
- var e=require(`../concurrencyLimit.cjs`).concurrencyLimit(20),t=class t{constructor(){this.stylePromises=new Map,this.getStyles=async({componentName:t,theme:n})=>{if(!n||!t)return;let r=`https://ds-assets.cupra.com/2.0.0-canary.140/styles/${n}/components/${t}.css`,i=this.getCachedStyleSheetPromise({url:r});if(i)return i;let a=e(()=>this.fetchStyle({url:r})).then(e=>(e||this.stylePromises.delete(r),e));return this.stylePromises.set(r,a),this.stylePromises.get(r)}}async fetchStyle({url:e}){try{if(typeof fetch>`u`)return;let t=await fetch(e,{cache:`force-cache`});if(t.ok)return t.text()}catch(t){console.error(`Failed to fetch Style Sheet "${e}":`,t)}}getCachedStyleSheetPromise({url:e}){return this.stylePromises.get(e)}static getInstance(){return t.instance||=new t,t.instance}}.getInstance();exports.stylesRegistry=t;
1
+ var e=require(`../concurrencyLimit.cjs`).concurrencyLimit(20),t=class t{constructor(){this.stylePromises=new Map,this.getStyles=async({componentName:t,theme:n})=>{if(!n||!t)return;let r=`https://ds-assets.cupra.com/2.0.0-canary.142/styles/${n}/components/${t}.css`,i=this.getCachedStyleSheetPromise({url:r});if(i)return i;let a=e(()=>this.fetchStyle({url:r})).then(e=>(e||this.stylePromises.delete(r),e));return this.stylePromises.set(r,a),this.stylePromises.get(r)}}async fetchStyle({url:e}){try{if(typeof fetch>`u`)return;let t=await fetch(e,{cache:`force-cache`});if(t.ok)return t.text()}catch(t){console.error(`Failed to fetch Style Sheet "${e}":`,t)}}getCachedStyleSheetPromise({url:e}){return this.stylePromises.get(e)}static getInstance(){return t.instance||=new t,t.instance}}.getInstance();exports.stylesRegistry=t;
@@ -1 +1 @@
1
- var e=`2.0.0-canary.140`,t=`--v${e.replaceAll(`.`,`-`)}`;exports.VERSION=e,exports.VERSION_TAG_SUFFIX=t;
1
+ var e=`2.0.0-canary.142`,t=`--v${e.replaceAll(`.`,`-`)}`;exports.VERSION=e,exports.VERSION_TAG_SUFFIX=t;
@@ -50,7 +50,7 @@ var p = class extends o {
50
50
  }
51
51
  loadThemeStyles() {
52
52
  return this.loadStyles ? new Promise((e, t) => {
53
- let n = "/2.0.0-canary.140", r = `https://ds-assets.cupra.com${n}/styles/${this.theme}/theme.css`;
53
+ let n = "/2.0.0-canary.142", r = `https://ds-assets.cupra.com${n}/styles/${this.theme}/theme.css`;
54
54
  if (document.head.querySelector(`link[href="${r}"]`)) e();
55
55
  else {
56
56
  let i = `ui-kit-theme-${n}`, a = document.getElementById(i), o = document.createElement("link");
@@ -0,0 +1,29 @@
1
+ import { c as e } from "../../node_modules/.pnpm/@lit_context@1.1.6/node_modules/@lit/context/lib/decorators/consume.js";
2
+ import { themeContext as t } from "../ds-theme-provider/themeContext.js";
3
+ import { E as n, x as r } from "../../node_modules/.pnpm/lit-html@3.3.1/node_modules/lit-html/lit-html.js";
4
+ import { i } from "../../node_modules/.pnpm/lit-element@4.2.1/node_modules/lit-element/lit-element.js";
5
+ import "../../node_modules/.pnpm/lit@3.3.1/node_modules/lit/index.js";
6
+ import { n as a } from "../../node_modules/.pnpm/@lit_reactive-element@2.1.1/node_modules/@lit/reactive-element/decorators/property.js";
7
+ import "../../node_modules/.pnpm/lit@3.3.1/node_modules/lit/decorators.js";
8
+ import { __decorate as o } from "../../_virtual/_@oxc-project_runtime@0.122.0/helpers/decorate.js";
9
+ import { customUiKitElement as s } from "../../decorators/customUiKitElement.js";
10
+ //#region src/components/ds-theme-switch/ds-theme-switch.ts
11
+ var c = class extends i {
12
+ getMatchingTemplate() {
13
+ return this.activeTheme ? this.querySelector(`template[slot="${this.activeTheme}"]`) : null;
14
+ }
15
+ getDefaultTemplate() {
16
+ return this.querySelector("template[slot=\"default\"]");
17
+ }
18
+ render() {
19
+ let e = this.getMatchingTemplate();
20
+ if (e) return r`${e.content.cloneNode(!0)}`;
21
+ let t = this.getDefaultTemplate();
22
+ return t ? r`${t.content.cloneNode(!0)}` : n;
23
+ }
24
+ };
25
+ o([a({ attribute: !1 }), e({
26
+ context: t,
27
+ subscribe: !0
28
+ })], c.prototype, "activeTheme", void 0), c = o([s("ds-theme-switch", { skipTagAsComponentName: !0 })], c);
29
+ //#endregion
@@ -67,6 +67,7 @@ import "./ds-tag/ds-tag.js";
67
67
  import "./ds-text/ds-text.js";
68
68
  import "./ds-textarea/ds-textarea.js";
69
69
  import "./ds-theme-provider/ds-theme-provider.js";
70
+ import "./ds-theme-switch/ds-theme-switch.js";
70
71
  import "./ds-toast-message/ds-toast-message.js";
71
72
  import "./ds-toast/ds-toast.js";
72
73
  import "./ds-inline-alert/ds-inline-alert.js";
@@ -11,7 +11,7 @@ function t(t, n) {
11
11
  this.componentName = a;
12
12
  }
13
13
  connectedCallback() {
14
- r.prototype.connectedCallback?.call(this), this.setAttribute("data-ui-kit-version", "2.0.0-canary.140");
14
+ r.prototype.connectedCallback?.call(this), this.setAttribute("data-ui-kit-version", "2.0.0-canary.142");
15
15
  }
16
16
  });
17
17
  };
@@ -25,7 +25,7 @@ var n = class {
25
25
  return console.error(`Failed to fetch icon "${e}":`, t), "";
26
26
  }), t.subscribe("theme", this.handleChangeTheme);
27
27
  }
28
- }, r = Symbol.for("@cupra/ui-kit/icons-manager/2.0.0-canary.140"), i = globalThis, a = i[r];
28
+ }, r = Symbol.for("@cupra/ui-kit/icons-manager/2.0.0-canary.142"), i = globalThis, a = i[r];
29
29
  a || (a = new n(), Object.defineProperty(i, r, {
30
30
  value: a,
31
31
  writable: !1,
@@ -18,7 +18,7 @@ var e = class {
18
18
  }
19
19
  });
20
20
  }
21
- }, t = Symbol.for("@cupra/ui-kit/pubsub/2.0.0-canary.140"), n = globalThis, r = n[t];
21
+ }, t = Symbol.for("@cupra/ui-kit/pubsub/2.0.0-canary.142"), n = globalThis, r = n[t];
22
22
  r || (r = new e(), Object.defineProperty(n, t, {
23
23
  value: r,
24
24
  writable: !1,
@@ -4,7 +4,7 @@ var t = e(20), n = class e {
4
4
  constructor() {
5
5
  this.stylePromises = /* @__PURE__ */ new Map(), this.getStyles = async ({ componentName: e, theme: n }) => {
6
6
  if (!n || !e) return;
7
- let r = `https://ds-assets.cupra.com/2.0.0-canary.140/styles/${n}/components/${e}.css`, i = this.getCachedStyleSheetPromise({ url: r });
7
+ let r = `https://ds-assets.cupra.com/2.0.0-canary.142/styles/${n}/components/${e}.css`, i = this.getCachedStyleSheetPromise({ url: r });
8
8
  if (i) return i;
9
9
  let a = t(() => this.fetchStyle({ url: r })).then((e) => (e || this.stylePromises.delete(r), e));
10
10
  return this.stylePromises.set(r, a), this.stylePromises.get(r);
@@ -1,4 +1,4 @@
1
1
  //#region src/utils/version.ts
2
- var e = "2.0.0-canary.140", t = `--v${e.replaceAll(".", "-")}`;
2
+ var e = "2.0.0-canary.142", t = `--v${e.replaceAll(".", "-")}`;
3
3
  //#endregion
4
4
  export { e as VERSION, t as VERSION_TAG_SUFFIX };
@@ -0,0 +1,12 @@
1
+ import { LitElement, nothing } from 'lit';
2
+ export declare class DsThemeSwitch extends LitElement {
3
+ private activeTheme?;
4
+ private getMatchingTemplate;
5
+ private getDefaultTemplate;
6
+ render(): import("lit").TemplateResult<1> | typeof nothing;
7
+ }
8
+ declare global {
9
+ interface HTMLElementTagNameMap {
10
+ 'ds-theme-switch': DsThemeSwitch;
11
+ }
12
+ }
@@ -0,0 +1,2 @@
1
+ import type { CommonAttrs } from '../../types/types';
2
+ export type DsThemeSwitchAttrs = CommonAttrs;
@@ -66,6 +66,7 @@ import './ds-text/ds-text.ts';
66
66
  import './ds-text-input/ds-text-input.ts';
67
67
  import './ds-textarea/ds-textarea.ts';
68
68
  import './ds-theme-provider/ds-theme-provider.ts';
69
+ import './ds-theme-switch/ds-theme-switch.ts';
69
70
  import './ds-toast/ds-toast.ts';
70
71
  import './ds-toast-message/ds-toast-message.ts';
71
72
  import './ds-inline-alert/ds-inline-alert.ts';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cupra/ui-kit",
3
- "version": "2.0.0-canary.140",
3
+ "version": "2.0.0-canary.142",
4
4
  "description": "Web components library",
5
5
  "author": "SEAT S.A.",
6
6
  "license": "SEAT S.A. Library EULA 1.0",