@mhmo91/schmancy 0.0.290 → 0.0.292
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{animated-text-CkVT5xh6.cjs → animated-text-BYy49xv3.cjs} +2 -2
- package/dist/{animated-text-CkVT5xh6.cjs.map → animated-text-BYy49xv3.cjs.map} +1 -1
- package/dist/{animated-text-DnmcLtp6.js → animated-text-BelKfCRb.js} +3 -3
- package/dist/{animated-text-DnmcLtp6.js.map → animated-text-BelKfCRb.js.map} +1 -1
- package/dist/animated-text.cjs +1 -1
- package/dist/animated-text.js +1 -1
- package/dist/area.cjs +1 -1
- package/dist/{area.component-2El6gVUr.cjs → area.component-BAx9ljt5.cjs} +2 -2
- package/dist/{area.component-2El6gVUr.cjs.map → area.component-BAx9ljt5.cjs.map} +1 -1
- package/dist/{area.component-i4jPVHUa.js → area.component-BIircYdd.js} +3 -3
- package/dist/{area.component-i4jPVHUa.js.map → area.component-BIircYdd.js.map} +1 -1
- package/dist/area.js +1 -1
- package/dist/{autocomplete-CJ5BBR5q.js → autocomplete-C-u4ICfa.js} +3 -3
- package/dist/{autocomplete-CJ5BBR5q.js.map → autocomplete-C-u4ICfa.js.map} +1 -1
- package/dist/{autocomplete-Bcb_ZSV9.cjs → autocomplete-ecQ92UGe.cjs} +2 -2
- package/dist/{autocomplete-Bcb_ZSV9.cjs.map → autocomplete-ecQ92UGe.cjs.map} +1 -1
- package/dist/autocomplete.cjs +1 -1
- package/dist/autocomplete.js +1 -1
- package/dist/busy.cjs +1 -1
- package/dist/busy.js +1 -1
- package/dist/button.cjs +1 -1
- package/dist/button.js +1 -1
- package/dist/card.cjs +1 -1
- package/dist/card.js +1 -1
- package/dist/{checkbox-CJjtMba9.js → checkbox-BUrYs8Dg.js} +2 -2
- package/dist/{checkbox-CJjtMba9.js.map → checkbox-BUrYs8Dg.js.map} +1 -1
- package/dist/{checkbox-56Umlzh3.cjs → checkbox-DeVnlyJb.cjs} +2 -2
- package/dist/{checkbox-56Umlzh3.cjs.map → checkbox-DeVnlyJb.cjs.map} +1 -1
- package/dist/checkbox.cjs +1 -1
- package/dist/checkbox.js +1 -1
- package/dist/{chips-B71IFtJB.js → chips-BkjDE2Cx.js} +3 -3
- package/dist/{chips-B71IFtJB.js.map → chips-BkjDE2Cx.js.map} +1 -1
- package/dist/{chips-DO738Kv9.cjs → chips-DjiRqUBT.cjs} +2 -2
- package/dist/{chips-DO738Kv9.cjs.map → chips-DjiRqUBT.cjs.map} +1 -1
- package/dist/chips.cjs +1 -1
- package/dist/chips.js +1 -1
- package/dist/components.cjs +1 -1
- package/dist/components.js +1 -1
- package/dist/consume-DSKPc5vj.js +38 -0
- package/dist/consume-DSKPc5vj.js.map +1 -0
- package/dist/consume-Di0U0iBU.cjs +2 -0
- package/dist/consume-Di0U0iBU.cjs.map +1 -0
- package/dist/content-drawer.cjs +1 -1
- package/dist/content-drawer.js +1 -1
- package/dist/{date-range-Dbj5qwzm.js → date-range-BIdEZhGK.js} +3 -3
- package/dist/{date-range-Dbj5qwzm.js.map → date-range-BIdEZhGK.js.map} +1 -1
- package/dist/{date-range-BFRnIgQ6.cjs → date-range-BirYELq7.cjs} +2 -2
- package/dist/{date-range-BFRnIgQ6.cjs.map → date-range-BirYELq7.cjs.map} +1 -1
- package/dist/date-range.cjs +1 -1
- package/dist/date-range.js +1 -1
- package/dist/delay-CqrzARsM.cjs +10 -0
- package/dist/delay-CqrzARsM.cjs.map +1 -0
- package/dist/delay-DGHDipnV.js +301 -0
- package/dist/delay-DGHDipnV.js.map +1 -0
- package/dist/delay.cjs +2 -0
- package/dist/delay.cjs.map +1 -0
- package/dist/delay.js +6 -0
- package/dist/delay.js.map +1 -0
- package/dist/divider-DcEj-C2P.cjs +83 -0
- package/dist/divider-DcEj-C2P.cjs.map +1 -0
- package/dist/divider-DzwD07xW.js +103 -0
- package/dist/divider-DzwD07xW.js.map +1 -0
- package/dist/divider.cjs +1 -1
- package/dist/divider.js +1 -1
- package/dist/{form-CAYrAoRv.js → form-DG0Kj--R.js} +2 -2
- package/dist/{form-CAYrAoRv.js.map → form-DG0Kj--R.js.map} +1 -1
- package/dist/{form-plr-eJPP.cjs → form-DpOSrAUQ.cjs} +2 -2
- package/dist/{form-plr-eJPP.cjs.map → form-DpOSrAUQ.cjs.map} +1 -1
- package/dist/form.cjs +1 -1
- package/dist/form.js +1 -1
- package/dist/{icon-PqOCyozA.js → icon-B9PnKxEE.js} +3 -3
- package/dist/{icon-PqOCyozA.js.map → icon-B9PnKxEE.js.map} +1 -1
- package/dist/{icon-BzX7n6-d.cjs → icon-alyJW9vl.cjs} +2 -2
- package/dist/{icon-BzX7n6-d.cjs.map → icon-alyJW9vl.cjs.map} +1 -1
- package/dist/{icon-button-Cw5m-xoA.js → icon-button-CJwbffPV.js} +3 -3
- package/dist/{icon-button-Cw5m-xoA.js.map → icon-button-CJwbffPV.js.map} +1 -1
- package/dist/{icon-button-DEmmjVam.cjs → icon-button-D__Gnjzi.cjs} +2 -2
- package/dist/{icon-button-DEmmjVam.cjs.map → icon-button-D__Gnjzi.cjs.map} +1 -1
- package/dist/icons.cjs +1 -1
- package/dist/icons.js +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.js +67 -64
- package/dist/index.js.map +1 -1
- package/dist/{input-CziCM1iP.cjs → input-BgnA2aM_.cjs} +2 -2
- package/dist/{input-CziCM1iP.cjs.map → input-BgnA2aM_.cjs.map} +1 -1
- package/dist/{input-suNgHap8.js → input-C50UsaQY.js} +2 -2
- package/dist/{input-suNgHap8.js.map → input-C50UsaQY.js.map} +1 -1
- package/dist/input.cjs +1 -1
- package/dist/input.js +1 -1
- package/dist/intersection-CJxzz8c-.js +15 -0
- package/dist/intersection-CJxzz8c-.js.map +1 -0
- package/dist/intersection-CVvaDv96.cjs +2 -0
- package/dist/intersection-CVvaDv96.cjs.map +1 -0
- package/dist/layout.cjs +1 -1
- package/dist/layout.js +1 -1
- package/dist/list.cjs +1 -1
- package/dist/list.js +1 -1
- package/dist/{litElement.mixin-B6SmKh9a.cjs → litElement.mixin-dosTHO0i.cjs} +2 -2
- package/dist/{litElement.mixin-B6SmKh9a.cjs.map → litElement.mixin-dosTHO0i.cjs.map} +1 -1
- package/dist/{litElement.mixin-Bl038NZS.js → litElement.mixin-kW4tqV-x.js} +2 -2
- package/dist/{litElement.mixin-Bl038NZS.js.map → litElement.mixin-kW4tqV-x.js.map} +1 -1
- package/dist/{menu-Cysa0uSH.js → menu-BPkKjcYr.js} +3 -3
- package/dist/{menu-Cysa0uSH.js.map → menu-BPkKjcYr.js.map} +1 -1
- package/dist/{menu-BuPKQu4A.cjs → menu-CjJdA5e1.cjs} +2 -2
- package/dist/{menu-BuPKQu4A.cjs.map → menu-CjJdA5e1.cjs.map} +1 -1
- package/dist/menu.cjs +1 -1
- package/dist/menu.js +1 -1
- package/dist/nav-drawer.cjs +1 -1
- package/dist/nav-drawer.js +1 -1
- package/dist/notification.cjs +1 -1
- package/dist/notification.js +1 -1
- package/dist/{option-BPPuRGqZ.js → option-Cf4MQSvl.js} +2 -2
- package/dist/{option-BPPuRGqZ.js.map → option-Cf4MQSvl.js.map} +1 -1
- package/dist/{option-BgkpZebg.cjs → option-DKovQczU.cjs} +2 -2
- package/dist/{option-BgkpZebg.cjs.map → option-DKovQczU.cjs.map} +1 -1
- package/dist/option.cjs +1 -1
- package/dist/option.js +1 -1
- package/dist/{outlet-BwnJ-qSb.cjs → outlet-Dajn35eu.cjs} +2 -2
- package/dist/{outlet-BwnJ-qSb.cjs.map → outlet-Dajn35eu.cjs.map} +1 -1
- package/dist/{outlet-DOGHb9XN.js → outlet-LHeYRUMN.js} +2 -2
- package/dist/{outlet-DOGHb9XN.js.map → outlet-LHeYRUMN.js.map} +1 -1
- package/dist/{payment-card-form-CLPTnEZc.js → payment-card-form-BwoSr0gi.js} +3 -3
- package/dist/{payment-card-form-CLPTnEZc.js.map → payment-card-form-BwoSr0gi.js.map} +1 -1
- package/dist/{payment-card-form-CxPeik8X.cjs → payment-card-form-LKu9PsnX.cjs} +2 -2
- package/dist/{payment-card-form-CxPeik8X.cjs.map → payment-card-form-LKu9PsnX.cjs.map} +1 -1
- package/dist/{radio-group-BQ9pnKtl.js → radio-group-Czi9ftHc.js} +2 -2
- package/dist/{radio-group-BQ9pnKtl.js.map → radio-group-Czi9ftHc.js.map} +1 -1
- package/dist/{radio-group-BoYOkPtY.cjs → radio-group-DyYcHKuk.cjs} +2 -2
- package/dist/{radio-group-BoYOkPtY.cjs.map → radio-group-DyYcHKuk.cjs.map} +1 -1
- package/dist/radio-group.cjs +1 -1
- package/dist/radio-group.js +1 -1
- package/dist/{scroll-BPSgAOxA.cjs → scroll-2nVgiEne.cjs} +2 -2
- package/dist/{scroll-BPSgAOxA.cjs.map → scroll-2nVgiEne.cjs.map} +1 -1
- package/dist/{scroll-CAn_o-0U.js → scroll-Kw278kXe.js} +2 -2
- package/dist/{scroll-CAn_o-0U.js.map → scroll-Kw278kXe.js.map} +1 -1
- package/dist/{select-CoU9pdWP.js → select-Bo8t1cUG.js} +3 -3
- package/dist/{select-CoU9pdWP.js.map → select-Bo8t1cUG.js.map} +1 -1
- package/dist/{select-CGt7bHnh.cjs → select-Brg9GSgM.cjs} +2 -2
- package/dist/{select-CGt7bHnh.cjs.map → select-Brg9GSgM.cjs.map} +1 -1
- package/dist/select.cjs +1 -1
- package/dist/select.js +1 -1
- package/dist/{sheet-DUJN3380.cjs → sheet-Cn9oyd09.cjs} +2 -2
- package/dist/{sheet-DUJN3380.cjs.map → sheet-Cn9oyd09.cjs.map} +1 -1
- package/dist/{sheet-BlzQ1N1K.js → sheet-m3ssA8RK.js} +3 -3
- package/dist/{sheet-BlzQ1N1K.js.map → sheet-m3ssA8RK.js.map} +1 -1
- package/dist/sheet.cjs +1 -1
- package/dist/sheet.js +1 -1
- package/dist/{slider-BknvMw5c.cjs → slider-C3u39UVs.cjs} +2 -2
- package/dist/{slider-BknvMw5c.cjs.map → slider-C3u39UVs.cjs.map} +1 -1
- package/dist/{slider-CII4GjxO.js → slider-DiOhZu0e.js} +3 -3
- package/dist/{slider-CII4GjxO.js.map → slider-DiOhZu0e.js.map} +1 -1
- package/dist/slider.cjs +1 -1
- package/dist/slider.js +1 -1
- package/dist/{spinner-CyrVjD7v.cjs → spinner-CB8tYfyA.cjs} +2 -2
- package/dist/{spinner-CyrVjD7v.cjs.map → spinner-CB8tYfyA.cjs.map} +1 -1
- package/dist/{spinner-MLhIt_0Y.js → spinner-DVKR6oPO.js} +2 -2
- package/dist/{spinner-MLhIt_0Y.js.map → spinner-DVKR6oPO.js.map} +1 -1
- package/dist/{surface-D0z5a4By.cjs → surface-COQfLMIb.cjs} +2 -2
- package/dist/{surface-D0z5a4By.cjs.map → surface-COQfLMIb.cjs.map} +1 -1
- package/dist/{surface-C392eVps.js → surface-_g6PVKz9.js} +2 -2
- package/dist/{surface-C392eVps.js.map → surface-_g6PVKz9.js.map} +1 -1
- package/dist/surface.cjs +1 -1
- package/dist/surface.js +1 -1
- package/dist/{table-Bt69Tb74.js → table-CA_AEMW3.js} +2 -2
- package/dist/{table-Bt69Tb74.js.map → table-CA_AEMW3.js.map} +1 -1
- package/dist/{table-DIgzwejX.cjs → table-XZOjesmO.cjs} +2 -2
- package/dist/{table-DIgzwejX.cjs.map → table-XZOjesmO.cjs.map} +1 -1
- package/dist/table.cjs +1 -1
- package/dist/table.js +1 -1
- package/dist/tabs-group-Bijey97W.js +110 -0
- package/dist/tabs-group-Bijey97W.js.map +1 -0
- package/dist/tabs-group-fV6A7jOd.cjs +41 -0
- package/dist/tabs-group-fV6A7jOd.cjs.map +1 -0
- package/dist/tabs.cjs +1 -1
- package/dist/tabs.js +1 -1
- package/dist/tailwind.mixin-D6m-sJmB.js +43 -0
- package/dist/{tailwind.mixin-CP8BNFiT.js.map → tailwind.mixin-D6m-sJmB.js.map} +1 -1
- package/dist/tailwind.mixin-Dts5Uk3L.cjs +2 -0
- package/dist/{tailwind.mixin-698watWc.cjs.map → tailwind.mixin-Dts5Uk3L.cjs.map} +1 -1
- package/dist/teleport.cjs +1 -1
- package/dist/teleport.js +1 -1
- package/dist/{textarea-DtJZWSOR.js → textarea-BppTG7vC.js} +2 -2
- package/dist/{textarea-DtJZWSOR.js.map → textarea-BppTG7vC.js.map} +1 -1
- package/dist/{textarea-vpqfN_nJ.cjs → textarea-DRm-XQyj.cjs} +2 -2
- package/dist/{textarea-vpqfN_nJ.cjs.map → textarea-DRm-XQyj.cjs.map} +1 -1
- package/dist/textarea.cjs +1 -1
- package/dist/textarea.js +1 -1
- package/dist/{theme-button-BMLzTEhF.js → theme-button-BTQaux2v.js} +37 -35
- package/dist/{theme-button-BMLzTEhF.js.map → theme-button-BTQaux2v.js.map} +1 -1
- package/dist/{theme-button-BAN6lRyQ.cjs → theme-button-lS8U2Zia.cjs} +2 -2
- package/dist/{theme-button-BAN6lRyQ.cjs.map → theme-button-lS8U2Zia.cjs.map} +1 -1
- package/dist/theme-button.cjs +1 -1
- package/dist/theme-button.js +1 -1
- package/dist/{tree-BL9F_EMi.cjs → tree-BxpWT4HG.cjs} +2 -2
- package/dist/{tree-BL9F_EMi.cjs.map → tree-BxpWT4HG.cjs.map} +1 -1
- package/dist/{tree-CLsU6ZKr.js → tree-F8M_QD0f.js} +2 -2
- package/dist/{tree-CLsU6ZKr.js.map → tree-F8M_QD0f.js.map} +1 -1
- package/dist/tree.cjs +1 -1
- package/dist/tree.js +1 -1
- package/dist/typewriter-B5nruGbg.cjs +21 -0
- package/dist/typewriter-B5nruGbg.cjs.map +1 -0
- package/dist/typewriter-m577B5AD.js +436 -0
- package/dist/typewriter-m577B5AD.js.map +1 -0
- package/dist/typewriter.cjs +1 -1
- package/dist/typewriter.js +1 -1
- package/dist/{typography-Bgl5OsmY.js → typography-DFnAG6mR.js} +2 -2
- package/dist/{typography-Bgl5OsmY.js.map → typography-DFnAG6mR.js.map} +1 -1
- package/dist/{typography-CnXlSOz8.cjs → typography-Depf5xNK.cjs} +2 -2
- package/dist/{typography-CnXlSOz8.cjs.map → typography-Depf5xNK.cjs.map} +1 -1
- package/dist/typography.cjs +1 -1
- package/dist/typography.js +1 -1
- package/dist/utils.cjs +2 -0
- package/dist/utils.cjs.map +1 -0
- package/dist/utils.js +5 -0
- package/dist/utils.js.map +1 -0
- package/package.json +1 -1
- package/types/src/delay/delay.d.ts +29 -0
- package/types/src/delay/index.d.ts +1 -0
- package/types/src/divider/divider.d.ts +2 -1
- package/types/src/index.d.ts +1 -0
- package/types/src/typewriter/typewriter.d.ts +5 -5
- package/types/src/utils/hashContent.d.ts +1 -0
- package/types/src/utils/index.d.ts +2 -0
- package/types/src/utils/intersection.d.ts +4 -0
- package/dist/divider-DxinuVg5.js +0 -34
- package/dist/divider-DxinuVg5.js.map +0 -1
- package/dist/divider-xYxX2ecE.cjs +0 -14
- package/dist/divider-xYxX2ecE.cjs.map +0 -1
- package/dist/tabs-group-CNVQ79vr.cjs +0 -41
- package/dist/tabs-group-CNVQ79vr.cjs.map +0 -1
- package/dist/tabs-group-MuRUioRb.js +0 -145
- package/dist/tabs-group-MuRUioRb.js.map +0 -1
- package/dist/tailwind.mixin-698watWc.cjs +0 -2
- package/dist/tailwind.mixin-CP8BNFiT.js +0 -43
- package/dist/typewriter-Co1pVwUH.cjs +0 -19
- package/dist/typewriter-Co1pVwUH.cjs.map +0 -1
- package/dist/typewriter-D-1_zpWl.js +0 -419
- package/dist/typewriter-D-1_zpWl.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"theme-button-BAN6lRyQ.cjs","sources":["../src/card/actions.ts","../src/card/card.ts","../src/card/content.ts","../src/card/media.ts","../src/content-drawer/$sheet.ts","../src/content-drawer/context.ts","../src/content-drawer/drawer.ts","../src/content-drawer/main.ts","../src/content-drawer/sheet.ts","../src/list/list-item.ts","../src/list/context.ts","../src/list/list.ts","../src/nav-drawer/$navbar.ts","../src/nav-drawer/context.ts","../src/nav-drawer/appbar.ts","../src/nav-drawer/content.ts","../src/nav-drawer/drawer.ts","../src/nav-drawer/navbar.ts","../src/teleport/teleport.service.ts","../src/teleport/watcher.ts","../src/teleport/teleport.component.ts","../src/theme-button/theme-button.ts"],"sourcesContent":["import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\n\n/**\n * @element schmancy-card-action\n * @slot - The content of the action\n */\n@customElement('schmancy-card-action')\nexport default class SchmancyCardMedia extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n`) {\n\tprotected render(): unknown {\n\t\treturn html` <section class=\"pb-4 px-4\"><slot> </slot></section> `\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card-action': SchmancyCardMedia\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\n@customElement('schmancy-card')\nexport default class SchmancyCard extends TailwindElement() {\n\t@property() type: 'elevated' | 'filled' | 'outlined' = 'elevated'\n\t@property({ type: Number }) elevation: 0 | 1 | 2 | 3 | 4 | 5 = 0\n\tprotected render(): unknown {\n\t\tconst classes = {\n\t\t\t'rounded-md': true,\n\t\t\t'shadow-1': this.elevation === 1,\n\t\t\t'shadow-2': this.elevation === 2,\n\t\t\t'shadow-3': this.elevation === 3,\n\t\t\t'shadow-4': this.elevation === 4,\n\t\t\t'shadow-5': this.elevation === 5,\n\t\t\t'hover:shadow-1': ['outlined', 'filled'].includes(this.type),\n\t\t\t'bg-surface-low shadow-1 hover:shadow-2': this.type === 'elevated',\n\t\t\t'bg-surface-highest': this.type === 'filled',\n\t\t\t'bg-surface-default border-1 border-outlinetype ': this.type === 'outlined',\n\t\t}\n\t\treturn html`<div class=\"${this.classMap(classes)}\">\n\t\t\t<slot> </slot>\n\t\t</div>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card': SchmancyCard\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { SchmancyTheme } from '@schmancy/theme/theme.interface'\nimport { html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\nimport { color } from '..'\n\n/**\n * @element schmancy-card-content\n * @slot headline\n * @slot subhead\n * @slot default - The content of the card\n */\n@customElement('schmancy-card-content')\nexport default class SchmancyCardContent extends TailwindElement() {\n\tprotected render(): unknown {\n\t\tconst classes = {\n\t\t\t'px-[16px] py-[24px]': true,\n\t\t}\n\t\tconst onSurface = SchmancyTheme.sys.color.surface.on\n\t\tconst onSurfaceVariant = SchmancyTheme.sys.color.surface.onVariant\n\t\treturn html`<schmancy-grid gap=\"md\" class=\"${this.classMap(classes)}\">\n\t\t\t<schmancy-grid gap=\"xs\">\n\t\t\t\t<schmancy-typography\n\t\t\t\t\t${color({\n\t\t\t\t\t\tcolor: onSurface,\n\t\t\t\t\t})}\n\t\t\t\t\ttype=\"body\"\n\t\t\t\t\ttoken=\"lg\"\n\t\t\t\t\t><slot name=\"headline\"> </slot\n\t\t\t\t></schmancy-typography>\n\t\t\t\t<schmancy-typography\n\t\t\t\t\t${color({\n\t\t\t\t\t\tcolor: onSurfaceVariant,\n\t\t\t\t\t})}\n\t\t\t\t\ttype=\"body\"\n\t\t\t\t\t><slot name=\"subhead\"></slot>\n\t\t\t\t</schmancy-typography>\n\t\t\t</schmancy-grid>\n\t\t\t<schmancy-typography\n\t\t\t\ttype=\"body\"\n\t\t\t\t${color({\n\t\t\t\t\tcolor: onSurfaceVariant,\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t<slot></slot>\n\t\t\t</schmancy-typography>\n\t\t</schmancy-grid>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card-content': SchmancyCardContent\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\n/**\n * @element schmancy-card-media\n */\n@customElement('schmancy-card-media')\nexport default class SchmancyCardMedia extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n`) {\n\t@property({ type: String, reflect: true })\n\tsrc: string = ''\n\n\t@property({ type: String })\n\tfit: 'contain' | 'cover' | 'fill' | 'none' | 'scale-down' = 'contain'\n\n\tprotected render(): unknown {\n\t\tconst styles = {\n\t\t\theight: '200px',\n\t\t}\n\t\tconst classes = {\n\t\t\t'object-center': true,\n\t\t\t'object-contain': this.fit === 'contain',\n\t\t\t'object-cover w-full': this.fit === 'cover',\n\t\t\t'object-fill': this.fit === 'fill',\n\t\t\t'object-none': this.fit === 'none',\n\t\t\t'object-scale-down': this.fit === 'scale-down',\n\t\t}\n\t\treturn html`<schmancy-grid align=\"stretch\" justify=\"stretch\" gap=\"md\">\n\t\t\t<img src=\"${this.src}\" style=${this.styleMap(styles)} class=\"${this.classMap(classes)}\" />\n\t\t</schmancy-grid>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card-media': SchmancyCardMedia\n\t}\n}\n","import { SchmancyEvents } from '@schmancy/types/events'\nimport { Subject } from 'rxjs'\n\ntype DrawerAction = 'dismiss' | 'render'\ntype TRef = Element | Window\ntype TRenderRequest = HTMLElement\nexport type TRenderCustomEvent = CustomEvent<{\n\tcomponent: TRenderRequest\n\ttitle?: string\n}>\nclass Drawer {\n\tprivate $drawer = new Subject<{\n\t\tref: TRef\n\t\taction: DrawerAction\n\t\tcomponent?: TRenderRequest\n\t\ttitle?: string\n\t}>()\n\tconstructor() {\n\t\tthis.$drawer.pipe().subscribe(data => {\n\t\t\tif (data.action === 'dismiss') {\n\t\t\t\tdata.ref.dispatchEvent(\n\t\t\t\t\tnew CustomEvent(SchmancyEvents.ContentDrawerToggle, {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tstate: 'close',\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t} else if (data.action === 'render') {\n\t\t\t\tdata.ref.dispatchEvent(\n\t\t\t\t\tnew CustomEvent(SchmancyEvents.ContentDrawerToggle, {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tstate: 'open',\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t\tdata.ref.dispatchEvent(\n\t\t\t\t\tnew CustomEvent('schmancy-content-drawer-render', {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tcomponent: data.component,\n\t\t\t\t\t\t\ttitle: data.title,\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t}\n\t\t})\n\t}\n\n\tdimiss(ref: TRef) {\n\t\tthis.$drawer.next({\n\t\t\taction: 'dismiss',\n\t\t\tref: ref,\n\t\t})\n\t}\n\n\trender(ref: TRef, component: TRenderRequest, title?: string) {\n\t\tref.dispatchEvent(new CustomEvent('custom-event'))\n\t\tthis.$drawer.next({\n\t\t\taction: 'render',\n\t\t\tref: ref,\n\t\t\tcomponent: component,\n\t\t\ttitle,\n\t\t})\n\t}\n}\n\nexport const schmancyContentDrawer = new Drawer()\n","import { createContext } from '@lit/context'\nexport type TSchmancyContentDrawerSheetMode = 'push' | 'overlay'\nexport const SchmancyContentDrawerSheetMode = createContext<TSchmancyContentDrawerSheetMode>('push')\n\nexport type TSchmancyContentDrawerSheetState = 'open' | 'close'\nexport const SchmancyContentDrawerSheetState = createContext<TSchmancyContentDrawerSheetState>('close')\n\nexport const SchmancyContentDrawerID = createContext<string>(Math.floor(Math.random() * Date.now()).toString())\nexport const SchmancyContentDrawerMaxHeight = createContext<string>('100%')\nexport const SchmancyContentDrawerMinWidth = createContext<{\n\tmain: number\n\tsheet: number\n}>({})\n","import { provide } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { css, html, nothing } from 'lit'\nimport { customElement, property, queryAssignedElements, state } from 'lit/decorators.js'\nimport { debounceTime, distinctUntilChanged, fromEvent, map, merge, startWith, takeUntil, tap } from 'rxjs'\nimport { SchmancyEvents, TRenderCustomEvent, area, sheet } from '..'\nimport {\n\tSchmancyContentDrawerID,\n\tSchmancyContentDrawerMaxHeight,\n\tSchmancyContentDrawerMinWidth,\n\tSchmancyContentDrawerSheetMode,\n\tSchmancyContentDrawerSheetState,\n\tTSchmancyContentDrawerSheetMode,\n\tTSchmancyContentDrawerSheetState,\n} from './context'\n\n/**\n * @element schmancy-content-drawer\n * @slot appbar - The appbar slot\n * @slot - The content slot\n */\n@customElement('schmancy-content-drawer')\nexport class SchmancyContentDrawer extends $LitElement(css`\n\t:host {\n\t\tposition: relative;\n\t\tinset: 0;\n\t\tdisplay: block;\n\t\toverflow: hidden;\n\t}\n`) {\n\t/**\n\t * The minimum width of the sheet\n\t * @attr\tminWidth\n\t * @type {number}\n\t * @memberof SchmancyContentDrawer\n\t */\n\n\t@provide({ context: SchmancyContentDrawerMinWidth })\n\tminWidth: typeof SchmancyContentDrawerMinWidth.__context__ = {\n\t\tmain: 360,\n\t\tsheet: 576,\n\t}\n\n\t/**\n\t * The state of the sheet\n\t * @attr open\n\t * @type {TSchmancyContentDrawerSheetState}\n\t */\n\t@provide({ context: SchmancyContentDrawerSheetState })\n\t@property()\n\topen: TSchmancyContentDrawerSheetState\n\n\t/**\n\t * The mode of the sheet\n\t * @type {TSchmancyContentDrawerSheetMode}\n\t * @memberof SchmancyContentDrawer\n\t * @protected\n\t */\n\t@provide({ context: SchmancyContentDrawerSheetMode })\n\t@state()\n\tmode: TSchmancyContentDrawerSheetMode\n\n\t@provide({ context: SchmancyContentDrawerID })\n\tschmancyContentDrawerID = Math.floor(Math.random() * Date.now()).toString()\n\n\t@provide({ context: SchmancyContentDrawerMaxHeight })\n\tmaxHeight = '100%'\n\n\t@queryAssignedElements({ flatten: true })\n\tassignedElements!: HTMLElement[]\n\tfirstUpdated(): void {\n\t\tmerge(fromEvent<CustomEvent>(window, 'resize'), fromEvent<CustomEvent>(window, SchmancyEvents.ContentDrawerResize))\n\t\t\t.pipe(\n\t\t\t\tstartWith(true),\n\t\t\t\ttap(() => console.log(this.minWidth)),\n\t\t\t\tmap(() => (this.clientWidth ? this.clientWidth : window.innerWidth)),\n\t\t\t\tmap(width => width >= this.minWidth.main + this.minWidth.sheet),\n\t\t\t\tdebounceTime(100),\n\t\t\t\ttap(() => {\n\t\t\t\t\tthis.maxHeight = `${window.innerHeight - this.getOffsetTop(this) - 32}px`\n\t\t\t\t\tthis.style.setProperty('max-height', this.maxHeight)\n\t\t\t\t}),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe(lgScreen => {\n\t\t\t\tif (lgScreen) {\n\t\t\t\t\tthis.mode = 'push'\n\t\t\t\t\tthis.open = 'open'\n\t\t\t\t} else {\n\t\t\t\t\tthis.mode = 'overlay'\n\t\t\t\t\tthis.open = 'close'\n\t\t\t\t}\n\t\t\t})\n\n\t\t/*\n\t\t * Listen to the toggle event\n\t\t */\n\t\tfromEvent<CustomEvent>(window, SchmancyEvents.ContentDrawerToggle)\n\t\t\t.pipe(\n\t\t\t\ttap(event => {\n\t\t\t\t\tevent.stopPropagation()\n\t\t\t\t}),\n\t\t\t\tmap(event => event.detail.state),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe(state => {\n\t\t\t\tthis.open = state\n\t\t\t})\n\n\t\tfromEvent<TRenderCustomEvent>(window, 'schmancy-content-drawer-render')\n\t\t\t.pipe(\n\t\t\t\ttap(event => {\n\t\t\t\t\tevent.stopPropagation()\n\t\t\t\t}),\n\t\t\t\tmap(event => event.detail),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe(({ component, title }) => {\n\t\t\t\tif (this.mode === 'push') {\n\t\t\t\t\t// TODO: Fix the router to render if constructor has different arguments\n\t\t\t\t\tarea.push({\n\t\t\t\t\t\tarea: this.schmancyContentDrawerID,\n\t\t\t\t\t\tcomponent: 'empty',\n\t\t\t\t\t\thistoryStrategy: 'silent',\n\t\t\t\t\t})\n\t\t\t\t\tarea.push({\n\t\t\t\t\t\tarea: this.schmancyContentDrawerID,\n\t\t\t\t\t\tcomponent: component,\n\t\t\t\t\t\thistoryStrategy: 'silent',\n\t\t\t\t\t})\n\t\t\t\t} else if ((this.mode = 'overlay')) {\n\t\t\t\t\tsheet.open({ component: component, uid: this.schmancyContentDrawerID, title })\n\t\t\t\t}\n\t\t\t})\n\t}\n\n\tgetOffsetTop(element) {\n\t\tlet offsetTop = 0\n\t\twhile (element) {\n\t\t\toffsetTop += element.offsetTop\n\t\t\telement = element.offsetParent\n\t\t}\n\t\treturn offsetTop\n\t}\n\n\tprotected render() {\n\t\tif (!this.mode || !this.open) return nothing\n\t\treturn html`\n\t\t\t<schmancy-grid\n\t\t\t\tcols=${this.mode === 'overlay' ? '1fr' : 'auto 1fr'}\n\t\t\t\trows=\"1fr\"\n\t\t\t\tflow=\"col\"\n\t\t\t\tjustify=\"stretch\"\n\t\t\t\talign=\"stretch\"\n\t\t\t>\n\t\t\t\t<slot></slot>\n\t\t\t</schmancy-grid>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-content-drawer': SchmancyContentDrawer\n\t}\n}\n","import { consume } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { PropertyValueMap, css, html } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { SchmancyEvents } from '..'\nimport {\n\tSchmancyContentDrawerMaxHeight,\n\tSchmancyContentDrawerMinWidth,\n\tSchmancyContentDrawerSheetMode,\n\tTSchmancyContentDrawerSheetMode,\n} from './context'\nimport { when } from 'lit/directives/when.js'\n\n@customElement('schmancy-content-drawer-main')\nexport class SchmancyContentDrawerMain extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\toverflow: hidden;\n\t}\n`) {\n\t@property({ type: Number })\n\tminWidth\n\n\t@consume({ context: SchmancyContentDrawerMinWidth, subscribe: true })\n\tdrawerMinWidth: typeof SchmancyContentDrawerMinWidth.__context__\n\n\t@consume({ context: SchmancyContentDrawerSheetMode, subscribe: true })\n\t@state()\n\tmode: TSchmancyContentDrawerSheetMode\n\n\t@consume({ context: SchmancyContentDrawerMaxHeight, subscribe: true })\n\t@state()\n\tmaxHeight\n\n\tconnectedCallback(): void {\n\t\tsuper.connectedCallback()\n\t\tif (this.minWidth) this.drawerMinWidth.main = this.minWidth\n\t\telse this.minWidth = this.drawerMinWidth.main\n\t}\n\n\tprotected update(changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>): void {\n\t\tsuper.update(changedProperties)\n\t\tif (changedProperties.has('minWidth') && this.minWidth) {\n\t\t\tthis.drawerMinWidth.main = this.minWidth\n\t\t\tthis.dispatchEvent(new CustomEvent(SchmancyEvents.ContentDrawerResize, { bubbles: true, composed: true }))\n\t\t}\n\t}\n\n\trender() {\n\t\tconst styles = {\n\t\t\tminWidth: `${this.minWidth}px`,\n\t\t\tmaxHeight: this.maxHeight,\n\t\t}\n\t\treturn html`\n\t\t\t<section class=\"relative inset-0 h-full\">\n\t\t\t\t<schmancy-grid\n\t\t\t\t\tclass=\"h-full relative overflow-scroll\"\n\t\t\t\t\tcols=\"${this.mode === 'push' ? 'auto 1fr' : '1fr'}\"\n\t\t\t\t\trows=\"1fr\"\n\t\t\t\t\tflow=\"col\"\n\t\t\t\t\talign=\"stretch\"\n\t\t\t\t\tjustify=\"stretch\"\n\t\t\t\t>\n\t\t\t\t\t<section style=${this.styleMap(styles)}>\n\t\t\t\t\t\t<slot></slot>\n\t\t\t\t\t</section>\n\t\t\t\t</schmancy-grid>\n\t\t\t\t${when(\n\t\t\t\t\tthis.mode === 'push',\n\t\t\t\t\t() => html` <schmancy-divider class=\"absolute right-0 top-0\" orientation=\"vertical\"></schmancy-divider>`,\n\t\t\t\t)}\n\t\t\t</section>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-content-drawer-main': SchmancyContentDrawerMain\n\t}\n}\n","import { consume } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query, queryAssignedElements, state } from 'lit/decorators.js'\nimport { from, merge, Observable, of, takeUntil, tap } from 'rxjs'\nimport { SchmancyEvents, sheet } from '..'\nimport {\n\tSchmancyContentDrawerID,\n\tSchmancyContentDrawerMaxHeight,\n\tSchmancyContentDrawerMinWidth,\n\tSchmancyContentDrawerSheetMode,\n\tSchmancyContentDrawerSheetState,\n\tTSchmancyContentDrawerSheetMode,\n\tTSchmancyContentDrawerSheetState,\n} from './context'\n\n// --- 1) Removed the custom animate import\n// import { animate } from '@packages/anime-beta-master'\n\n@customElement('schmancy-content-drawer-sheet')\nexport class SchmancyContentDrawerSheet extends $LitElement(css`\n\t:host {\n\t\toverflow: scroll;\n\t}\n`) {\n\t@property({ type: Number })\n\tminWidth\n\n\t@consume({ context: SchmancyContentDrawerSheetMode, subscribe: true })\n\t@state()\n\tmode: TSchmancyContentDrawerSheetMode\n\n\t@consume({ context: SchmancyContentDrawerSheetState, subscribe: true })\n\t@state()\n\tstate: TSchmancyContentDrawerSheetState\n\n\t@consume({ context: SchmancyContentDrawerID })\n\tschmancyContentDrawerID\n\n\t@query('#sheet') sheet!: HTMLElement\n\t@queryAssignedElements({ flatten: true, slot: undefined }) defaultSlot!: HTMLElement[]\n\n\t@consume({ context: SchmancyContentDrawerMinWidth, subscribe: true })\n\tdrawerMinWidth: typeof SchmancyContentDrawerMinWidth.__context__\n\n\t@consume({ context: SchmancyContentDrawerMaxHeight, subscribe: true })\n\t@state()\n\tmaxHeight\n\n\tconnectedCallback(): void {\n\t\tsuper.connectedCallback()\n\t\tif (this.minWidth) {\n\t\t\tthis.drawerMinWidth.sheet = this.minWidth\n\t\t} else {\n\t\t\tthis.minWidth = this.drawerMinWidth.sheet\n\t\t}\n\t}\n\n\tupdated(changedProperties: Map<string, any>) {\n\t\tsuper.updated(changedProperties)\n\t\tif (changedProperties.has('minWidth') && this.minWidth) {\n\t\t\t// If the 'minWidth' property changed\n\t\t\tthis.drawerMinWidth.sheet = this.minWidth\n\t\t\tthis.dispatchEvent(new CustomEvent(SchmancyEvents.ContentDrawerResize, { bubbles: true, composed: true }))\n\t\t} else if (changedProperties.has('state') || changedProperties.has('mode')) {\n\t\t\tif (this.mode === 'overlay') {\n\t\t\t\tif (this.state === 'close') {\n\t\t\t\t\tthis.closeAll()\n\t\t\t\t} else if (this.state === 'open') {\n\t\t\t\t\t// Overlay open logic if needed\n\t\t\t\t\t// this.open()\n\t\t\t\t}\n\t\t\t} else if (this.mode === 'push') {\n\t\t\t\tsheet.dismiss(this.schmancyContentDrawerID)\n\t\t\t\tif (this.state === 'close') {\n\t\t\t\t\tthis.closeAll()\n\t\t\t\t} else if (this.state === 'open') {\n\t\t\t\t\tthis.open()\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Open the sheet by sliding it into view.\n\t */\n\topen() {\n\t\t// \"onBegin\" logic from the old `animate(...)`\n\t\tif (this.mode === 'overlay') {\n\t\t\tthis.sheet.style.position = 'fixed'\n\t\t} else {\n\t\t\tthis.sheet.style.position = 'relative'\n\t\t}\n\t\tthis.sheet.style.display = 'block'\n\n\t\t// --- 2) Use native Web Animations API ---\n\t\tthis.sheet.animate(\n\t\t\t[\n\t\t\t\t{ opacity: 0, transform: 'translateX(100%)' },\n\t\t\t\t{ opacity: 1, transform: 'translateX(0%)' },\n\t\t\t],\n\t\t\t{\n\t\t\t\tduration: 500,\n\t\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t\t},\n\t\t)\n\t\t// No return is needed if you don't rely on the result\n\t}\n\n\t/**\n\t * Close everything (modal sheet + the sheet itself).\n\t */\n\tcloseAll() {\n\t\t// Merge them into a single subscription,\n\t\t// so that everything closes in parallel.\n\t\tmerge(from(this.closeModalSheet()), from(this.closeSheet())).pipe(takeUntil(this.disconnecting)).subscribe()\n\t}\n\n\t/**\n\t * Dismiss the \"modal sheet.\"\n\t * This just returns an Observable that completes immediately.\n\t */\n\tcloseModalSheet() {\n\t\treturn of(true).pipe(tap(() => sheet.dismiss(this.schmancyContentDrawerID)))\n\t}\n\n\t/**\n\t * Slide the sheet out of view + hide it.\n\t * Return an Observable so we can merge it with other close operations.\n\t */\n\tcloseSheet() {\n\t\t// --- 2) Use native Web Animations API and wrap in an Observable ---\n\t\treturn new Observable<void>(observer => {\n\t\t\tconst animation = this.sheet.animate(\n\t\t\t\t[\n\t\t\t\t\t{ opacity: 1, transform: 'translateX(0%)' },\n\t\t\t\t\t{ opacity: 1, transform: 'translateX(100%)' },\n\t\t\t\t],\n\t\t\t\t{\n\t\t\t\t\tduration: 500,\n\t\t\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t\t\t},\n\t\t\t)\n\n\t\t\tanimation.onfinish = () => {\n\t\t\t\t// \"onComplete\" logic\n\t\t\t\tthis.sheet.style.display = 'none'\n\t\t\t\tobserver.next()\n\t\t\t\tobserver.complete()\n\t\t\t}\n\t\t})\n\t}\n\n\tprotected render() {\n\t\tconst sheetClasses = {\n\t\t\tblock: this.mode === 'push',\n\t\t\t'absolute z-[50]': this.mode === 'overlay',\n\t\t\t'opacity-1': this.mode === 'overlay' && this.state === 'open',\n\t\t}\n\n\t\tconst styles = {\n\t\t\tminWidth: `${this.minWidth}px`,\n\t\t\tmaxHeight: this.maxHeight,\n\t\t}\n\n\t\treturn html`\n\t\t\t<section id=\"sheet\" class=\"${this.classMap(sheetClasses)}\" style=${this.styleMap(styles)}>\n\t\t\t\t<schmancy-area name=\"${this.schmancyContentDrawerID}\">\n\t\t\t\t\t<slot name=\"placeholder\"></slot>\n\t\t\t\t</schmancy-area>\n\t\t\t</section>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-content-drawer-sheet': SchmancyContentDrawerSheet\n\t}\n}\n","import { consume } from '@lit/context'\nimport { TailwindElement } from '@mixins/index'\nimport { SchmancySurfaceTypeContext } from '@schmancy/surface/context'\nimport { SchmancyTheme } from '@schmancy/theme/theme.interface'\nimport { TSurfaceColor } from '@schmancy/types/surface'\nimport { html } from 'lit'\nimport { customElement, property, queryAssignedElements } from 'lit/decorators.js'\nimport { when } from 'lit/directives/when.js'\nimport { color } from '..'\n\n/**\n * @element schmancy-list-item\n * @slot leading - leading content\n * @slot trailing - trailing content\n * @slot - default content\n */\n@customElement('schmancy-list-item')\nexport class SchmancyListItem extends TailwindElement() {\n\t@consume({ context: SchmancySurfaceTypeContext, subscribe: true })\n\t@property()\n\tvariant: TSurfaceColor\n\n\t@property({ type: Boolean })\n\trounded: boolean\n\n\t@property({ type: Boolean }) readonly: boolean\n\n\t@property({ type: Boolean }) selected: boolean = false\n\n\t@queryAssignedElements({\n\t\tslot: 'leading',\n\t\tflatten: true,\n\t})\n\tprivate leading!: HTMLElement[]\n\n\t@queryAssignedElements({\n\t\tslot: 'trailing',\n\t\tflatten: true,\n\t})\n\tprivate trailing!: HTMLElement[]\n\n\tprotected get imgClasses(): string[] {\n\t\treturn ['h-[24px]', 'w-[24px]', 'object-contain']\n\t}\n\n\tfirstUpdated() {\n\t\tthis.leading?.forEach(img => {\n\t\t\timg.classList.add(...this.imgClasses)\n\t\t})\n\t\tthis.trailing?.forEach(img => {\n\t\t\timg.classList.add(...this.imgClasses)\n\t\t})\n\t}\n\n\trender() {\n\t\tconst classes = {\n\t\t\t'rounded-none': this.rounded === false,\n\t\t\t'rounded-full': this.rounded,\n\t\t\t'w-full min-h-[56px] relative flex items-center gap-[16px] py-[8px] px-[16px] duration-500 transition-colors':\n\t\t\t\ttrue,\n\t\t\t'bg-secondary-container text-secondery-onContainer': this.selected,\n\t\t}\n\n\t\tconst stateLayerClasses = {\n\t\t\t'z-0 duration-500 transition-opacity': true,\n\t\t\t'rounded-none': this.rounded === false,\n\t\t\t'rounded-full': this.rounded,\n\t\t\t'hover:bg-surface-on opacity-[0.08] cursor-pointer absolute inset-0': !this.readonly,\n\t\t}\n\t\treturn html`<li class=${this.classMap(classes)}>\n\t\t\t${when(!this.readonly, () => html` <div class=\"${this.classMap(stateLayerClasses)}\"></div> `)}\n\t\t\t<slot name=\"leading\"> </slot>\n\t\t\t<schmancy-grid class=\"flex-1\" justify=\"stretch\" align=\"center\">\n\t\t\t\t<schmancy-typography type=\"body\" token=\"lg\">\n\t\t\t\t\t<slot></slot>\n\t\t\t\t</schmancy-typography>\n\t\t\t\t<schmancy-typography\n\t\t\t\t\t${color({\n\t\t\t\t\t\tcolor: SchmancyTheme.sys.color.surface.onVariant,\n\t\t\t\t\t})}\n\t\t\t\t\ttype=\"body\"\n\t\t\t\t\ttoken=\"md\"\n\t\t\t\t\talign=\"left\"\n\t\t\t\t>\n\t\t\t\t\t<slot name=\"support\"></slot>\n\t\t\t\t</schmancy-typography>\n\t\t\t\t${when(!this.readonly, () => html` <div class=\"${this.classMap(stateLayerClasses)}\"></div> `)}\n\t\t\t</schmancy-grid>\n\t\t\t<slot name=\"trailing\"></slot>\n\t\t</li>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-list-item': SchmancyListItem\n\t}\n}\n","import { createContext } from '@lit/context'\nimport { TSurfaceColor } from '@schmancy/types/surface'\nexport const SchmancyListTypeContext = createContext<TSurfaceColor>(undefined)\n","import { provide } from '@lit/context'\nimport { TailwindElement } from '@mixins/index'\nimport { TSurfaceColor } from '@schmancy/types/surface'\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { SchmancyListTypeContext } from './context'\n\n/**\n * @slot - The default slot.\n */\n@customElement('schmancy-list')\nexport class List extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tpadding-top: 8px;\n\t\tpadding-bottom: 8px;\n\t}\n`) {\n\t/**\n\t * The type of list.\n\t * @attr type\n\t * @type {SchmancyListType}\n\t * @default 'surface'\n\t */\n\t@provide({ context: SchmancyListTypeContext })\n\t@property()\n\tsurface: TSurfaceColor\n\n\trender() {\n\t\treturn html`\n\t\t\t<schmancy-surface type=${this.surface}>\n\t\t\t\t<ul>\n\t\t\t\t\t<slot></slot>\n\t\t\t\t</ul>\n\t\t\t</schmancy-surface>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-list': List\n\t}\n}\n","import { SchmancyEvents } from '@schmancy/types/events'\nimport { Subject } from 'rxjs'\n\nclass Drawer {\n\tprivate $drawer = new Subject<{\n\t\tself: HTMLElement\n\t\tstate: boolean\n\t}>()\n\tconstructor() {\n\t\tthis.$drawer.subscribe(data => {\n\t\t\tif (data.state) {\n\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\tnew CustomEvent(SchmancyEvents.NavDrawer_toggle, {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tstate: 'open',\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t} else {\n\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\tnew CustomEvent(SchmancyEvents.NavDrawer_toggle, {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tstate: 'close',\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t}\n\t\t})\n\t}\n\topen(self?: HTMLElement) {\n\t\tthis.$drawer.next({\n\t\t\tself,\n\t\t\tstate: true,\n\t\t})\n\t}\n\tclose(self?: HTMLElement) {\n\t\tthis.$drawer.next({\n\t\t\tself,\n\t\t\tstate: false,\n\t\t})\n\t}\n}\n\nexport const schmancyNavDrawer = new Drawer()\n","import { createContext } from '@lit/context'\nexport type TSchmancyDrawerNavbarMode = 'push' | 'overlay' | undefined\nexport const SchmancyDrawerNavbarMode = createContext<TSchmancyDrawerNavbarMode>('push')\n\nexport type TSchmancyDrawerNavbarState = 'open' | 'close' | undefined\nexport const SchmancyDrawerNavbarState = createContext<TSchmancyDrawerNavbarState>('close')\n","import { consume } from '@lit/context'\nimport { TailwindElement } from '@mixins/index'\nimport {\n\tSchmancyDrawerNavbarMode,\n\tSchmancyDrawerNavbarState,\n\tTSchmancyDrawerNavbarMode,\n} from '@schmancy/nav-drawer/context'\nimport { css, html } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { when } from 'lit/directives/when.js'\nimport { SchmancyEvents } from '..'\n\n/**\n * @element schmancy-nav-drawer-appbar\n * @slot toggler - The toggler slot\n * @slot - The default slot\n */\n@customElement('schmancy-nav-drawer-appbar')\nexport class SchmancyDrawerAppbar extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n`) {\n\t@consume({ context: SchmancyDrawerNavbarMode, subscribe: true })\n\t@state()\n\tsidebarMode: TSchmancyDrawerNavbarMode\n\n\t@consume({ context: SchmancyDrawerNavbarState, subscribe: true })\n\t@state()\n\tsidebarOpen\n\n\t@property({ type: Boolean }) toggler = true\n\n\trender() {\n\t\tconst appbarClasses = {\n\t\t\t'block z-50': true,\n\t\t}\n\t\tconst sidebarToggler = {\n\t\t\t'block left-3 z-50': this.sidebarMode === 'overlay',\n\t\t\thidden: this.sidebarMode === 'push',\n\t\t}\n\t\treturn html`\n\t\t\t<schmancy-grid\n\t\t\t\tcols=${this.sidebarMode === 'overlay' && this.toggler ? 'auto 1fr' : '1fr'}\n\t\t\t\tflow=\"col\"\n\t\t\t\tclass=${this.classMap(appbarClasses)}\n\t\t\t\tgap=\"sm\"\n\t\t\t\talign=\"center\"\n\t\t\t>\n\t\t\t\t${when(\n\t\t\t\t\tthis.sidebarMode === 'overlay' && this.toggler,\n\t\t\t\t\t() =>\n\t\t\t\t\t\thtml`<slot name=\"toggler\">\n\t\t\t\t\t\t\t<div class=\"${this.classMap(sidebarToggler)}\">\n\t\t\t\t\t\t\t\t<schmancy-icon-button\n\t\t\t\t\t\t\t\t\t@click=${() => {\n\t\t\t\t\t\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\t\t\t\t\t\tnew CustomEvent(SchmancyEvents.NavDrawer_toggle, {\n\t\t\t\t\t\t\t\t\t\t\t\tdetail: { state: this.sidebarOpen === 'open' ? 'close' : 'open' },\n\t\t\t\t\t\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t${when(\n\t\t\t\t\t\t\t\t\t\tthis.sidebarOpen === 'close',\n\t\t\t\t\t\t\t\t\t\t() => html`menu`,\n\t\t\t\t\t\t\t\t\t\t() => html`menu_open`,\n\t\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t\t</schmancy-icon-button>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t</slot>`,\n\t\t\t\t)}\n\n\t\t\t\t<slot> </slot>\n\t\t\t</schmancy-grid>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-nav-drawer-appbar': SchmancyDrawerAppbar\n\t}\n}\n","import { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\nimport { fromEvent, takeUntil } from 'rxjs'\n\n@customElement('schmancy-nav-drawer-content')\nexport class SchmancyNavigationDrawerContent extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tposition: relative;\n\t\tinset: 0;\n\t\toverflow-y: auto;\n\t}\n`) {\n\tconnectedCallback(): void {\n\t\tsuper.connectedCallback()\n\t\tfromEvent(this, 'scroll')\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe(e => {\n\t\t\t\tthis.parentElement.dispatchEvent(new CustomEvent('scroll', { detail: e, bubbles: true, composed: true }))\n\t\t\t})\n\t}\n\trender() {\n\t\treturn html` <slot></slot> `\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-nav-drawer-content': SchmancyNavigationDrawerContent\n\t}\n}\n","import { provide } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { css, html, nothing } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { debounceTime, distinctUntilChanged, fromEvent, map, startWith, takeUntil, tap } from 'rxjs'\nimport { SchmancyEvents } from '..'\nimport { fullHeight } from './../directives/height'\nimport {\n\tSchmancyDrawerNavbarMode,\n\tSchmancyDrawerNavbarState,\n\tTSchmancyDrawerNavbarMode,\n\tTSchmancyDrawerNavbarState,\n} from './context'\n\n/**\n * @element schmancy-nav-drawer\n * @slot appbar - The appbar slot\n * @slot - The content slot\n */\n@customElement('schmancy-nav-drawer')\nexport class SchmancyNavigationDrawer extends $LitElement(css`\n\t:host {\n\t\tdisplay: flex;\n\t\tflex-grow: 1;\n\t\toverflow: hidden;\n\t}\n`) {\n\t// fullscreen property\n\t@property({ type: Boolean })\n\tfullscreen: boolean = false\n\n\t/**\n\t * The minimum width of the sidebar\n\t * @attr\tbreakpoint\n\t * @type {number}\n\t * @memberof SchmancyNavigationDrawer\n\t */\n\t@property({ type: Number, attribute: 'breakpoint' })\n\tbreakpoint: number = 768\n\n\t/**\n\t * The mode of the sidebar\n\t * @type {TSchmancyDrawerNavbarMode}\n\t * @memberof SchmancyNavigationDrawer\n\t * @protected\n\t */\n\t@provide({ context: SchmancyDrawerNavbarMode })\n\t@state()\n\tmode: TSchmancyDrawerNavbarMode\n\n\t@provide({ context: SchmancyDrawerNavbarState })\n\t@property()\n\topen: TSchmancyDrawerNavbarState\n\n\tconnectedCallback(): void {\n\t\tsuper.connectedCallback()\n\t\tfromEvent<CustomEvent>(window, 'resize')\n\t\t\t.pipe(\n\t\t\t\tmap(event => event.target as Window),\n\t\t\t\tstartWith(window),\n\t\t\t\tmap(window => window.innerWidth),\n\t\t\t\tmap(width => width >= this.breakpoint),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t\tdebounceTime(100),\n\t\t\t)\n\t\t\t.subscribe(lgScreen => {\n\t\t\t\tif (lgScreen) {\n\t\t\t\t\tthis.mode = 'push'\n\t\t\t\t\tthis.open = 'open'\n\t\t\t\t} else {\n\t\t\t\t\tthis.mode = 'overlay'\n\t\t\t\t\tthis.open = 'close'\n\t\t\t\t}\n\t\t\t})\n\n\t\t/*\n\t\t * Listen to the toggle event\n\t\t */\n\t\tfromEvent<CustomEvent>(window, SchmancyEvents.NavDrawer_toggle)\n\t\t\t.pipe(\n\t\t\t\ttap(event => {\n\t\t\t\t\tevent.stopPropagation()\n\t\t\t\t}),\n\t\t\t\tmap(event => event.detail.state),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe(state => {\n\t\t\t\tthis.open = state\n\t\t\t})\n\t}\n\n\tprotected render() {\n\t\tif (!this.mode || !this.open) return nothing\n\t\treturn html`\n\t\t\t<schmancy-grid\n\t\t\t\tcols=${this.fullscreen ? '1fr' : 'auto 1fr'}\n\t\t\t\trows=\"1fr\"\n\t\t\t\tflow=\"col\"\n\t\t\t\tjustify=\"stretch\"\n\t\t\t\talign=\"stretch\"\n\t\t\t\t${fullHeight()}\n\t\t\t>\n\t\t\t\t<slot></slot>\n\t\t\t</schmancy-grid>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-nav-drawer': SchmancyNavigationDrawer\n\t}\n}\n","import { consume } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { html } from 'lit'\nimport { customElement, property, query, state } from 'lit/decorators.js'\nimport { SchmancyEvents, SchmancyTheme, color } from '..'\nimport {\n\tSchmancyDrawerNavbarMode,\n\tSchmancyDrawerNavbarState,\n\tTSchmancyDrawerNavbarMode,\n\tTSchmancyDrawerNavbarState,\n} from './context'\n\n@customElement('schmancy-nav-drawer-navbar')\nexport class SchmancyNavigationDrawerSidebar extends $LitElement() {\n\t// Removed: import { animate } from '@packages/src'\n\n\t@consume({ context: SchmancyDrawerNavbarMode, subscribe: true })\n\t@state()\n\tmode: TSchmancyDrawerNavbarMode\n\n\t@consume({ context: SchmancyDrawerNavbarState, subscribe: true })\n\t@state()\n\tprivate state: TSchmancyDrawerNavbarState\n\n\t@query('#overlay') overlay!: HTMLElement\n\n\t@property({ type: String }) width = '320px'\n\n\tconnectedCallback(): void {\n\t\tsuper.connectedCallback()\n\t\t// Your touch event logic can stay here if needed\n\t}\n\n\tupdated(changedProperties: Map<string, any>) {\n\t\tif (changedProperties.has('state')) {\n\t\t\tif (this.mode === 'overlay') {\n\t\t\t\tif (this.state === 'close') {\n\t\t\t\t\tthis.closeOverlay()\n\t\t\t\t} else if (this.state === 'open') {\n\t\t\t\t\tthis.openOverlay()\n\t\t\t\t}\n\t\t\t} else if (this.mode === 'push') {\n\t\t\t\tthis.closeOverlay()\n\t\t\t}\n\t\t}\n\t}\n\n\topenOverlay() {\n\t\t// Equivalent to onBegin\n\t\tthis.overlay.style.display = 'block'\n\n\t\t// Animate opacity from 0 to 0.4\n\t\tthis.overlay.animate([{ opacity: 0 }, { opacity: 0.4 }], {\n\t\t\tduration: 200,\n\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t\tfill: 'forwards', // <-- This keeps the final keyframe (0.4) after finishing\n\t\t})\n\t\t// If you want an onfinish here, you can add it:\n\t\t// .onfinish = () => console.log('overlay opened!')\n\t}\n\n\tcloseOverlay() {\n\t\t// Animate opacity from 0.4 to 0\n\t\tconst animation = this.overlay.animate([{ opacity: 0.4 }, { opacity: 0 }], {\n\t\t\tduration: 150,\n\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t})\n\n\t\t// Equivalent to onComplete\n\t\tanimation.onfinish = () => {\n\t\t\tthis.overlay.style.display = 'none'\n\t\t}\n\t}\n\n\tprotected render() {\n\t\tconst animate = {\n\t\t\t'transition-all transform-gpu duration-[200ms] ease-[cubicBezier(0.5, 0.01, 0.25, 1)]': true,\n\t\t}\n\n\t\tconst sidebarClasses = {\n\t\t\t'p-[16px] max-w-[360px] w-fit h-full overflow-auto': true,\n\t\t\tblock: this.mode === 'push',\n\t\t\t'fixed inset-0 translate-x-[-100%] z-50': this.mode === 'overlay',\n\t\t\t'translate-x-0': this.mode === 'overlay' && this.state === 'open',\n\t\t\t'translate-x-[-100%]': this.mode === 'overlay' && this.state === 'close',\n\t\t}\n\t\tconst overlayClass = {\n\t\t\t'fixed inset-0 z-[49] hidden': true,\n\t\t}\n\n\t\tconst styleMap = {\n\t\t\twidth: this.width,\n\t\t}\n\n\t\treturn html`\n\t\t\t<nav\n\t\t\t\tstyle=${this.styleMap(styleMap)}\n\t\t\t\tclass=\"${this.classMap({ ...sidebarClasses, ...animate })}\"\n\t\t\t\t${color({\n\t\t\t\t\tbgColor: SchmancyTheme.sys.color.surface.container,\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t<slot></slot>\n\t\t\t</nav>\n\t\t\t<div\n\t\t\t\tid=\"overlay\"\n\t\t\t\t${color({\n\t\t\t\t\tbgColor: SchmancyTheme.sys.color.scrim,\n\t\t\t\t})}\n\t\t\t\t@click=${() => {\n\t\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\t\tnew CustomEvent(SchmancyEvents.NavDrawer_toggle, {\n\t\t\t\t\t\t\tdetail: { state: 'close' },\n\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t}),\n\t\t\t\t\t)\n\t\t\t\t}}\n\t\t\t\tclass=\"${this.classMap({ ...overlayClass })}\"\n\t\t\t></div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-nav-drawer-navbar': SchmancyNavigationDrawerSidebar\n\t}\n}\n","import { bufferTime, concatMap, filter, fromEvent, map, of, Subject, take, tap, timeout, zip } from 'rxjs'\nimport { SchmancyTeleportation } from './teleport.component'\n\nexport type WhereAreYouRickyEvent = CustomEvent<{\n\tid: string\n\tcallerID: number\n}>\n\nexport const WhereAreYouRicky = 'whereAreYouRicky'\n\nexport type HereMortyEvent = CustomEvent<{\n\tcomponent: SchmancyTeleportation\n}>\n\nexport type FLIP_REQUEST = {\n\tfrom: {\n\t\trect: DOMRect\n\t\telement?: HTMLElement\n\t}\n\tto: {\n\t\trect: DOMRect\n\t\telement: HTMLElement\n\t}\n\tstagger?: number\n\thost: HTMLElement\n}\nexport const HereMorty = 'hereMorty'\n\nclass Teleportation {\n\tactiveTeleportations = new Map<string, DOMRect>()\n\tflipRequests = new Subject<FLIP_REQUEST>()\n\n\tconstructor() {\n\t\tthis.flipRequests\n\t\t\t.pipe(\n\t\t\t\tbufferTime(1),\n\t\t\t\tmap(requests =>\n\t\t\t\t\trequests.map(({ from, to, host }, i) => ({\n\t\t\t\t\t\tfrom,\n\t\t\t\t\t\tto,\n\t\t\t\t\t\thost,\n\t\t\t\t\t\ti,\n\t\t\t\t\t})),\n\t\t\t\t),\n\t\t\t\tconcatMap(requests => zip(requests.map(request => of(this.flip(request))))),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tfind = (component: SchmancyTeleportation) => {\n\t\treturn zip([\n\t\t\tfromEvent<HereMortyEvent>(window, HereMorty).pipe(\n\t\t\t\tfilter(\n\t\t\t\t\te =>\n\t\t\t\t\t\t!!e.detail.component.uuid &&\n\t\t\t\t\t\t!!component.id &&\n\t\t\t\t\t\te.detail.component.id === component.id &&\n\t\t\t\t\t\te.detail.component.uuid !== component.uuid,\n\t\t\t\t),\n\t\t\t\tmap(e => e.detail.component),\n\t\t\t\ttake(1),\n\t\t\t),\n\t\t\tof(component).pipe(\n\t\t\t\ttap(() => {\n\t\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\t\tnew CustomEvent<WhereAreYouRickyEvent['detail']>(WhereAreYouRicky, {\n\t\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\t\tid: component.id,\n\t\t\t\t\t\t\t\tcallerID: component.uuid,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t}),\n\t\t\t\t\t)\n\t\t\t\t}),\n\t\t\t),\n\t\t]).pipe(\n\t\t\tmap(([component]) => component),\n\t\t\ttimeout(0),\n\t\t)\n\t}\n\n\tflip = (request: {\n\t\tfrom: {\n\t\t\trect: DOMRect\n\t\t}\n\t\tto: {\n\t\t\telement: HTMLElement\n\t\t\trect: DOMRect\n\t\t}\n\t\thost: HTMLElement\n\t\ti: number\n\t}) => {\n\t\tconst { from, to } = request\n\n\t\t// Prepare the element for animation\n\t\tconst originalZIndex = to.element.style.zIndex\n\t\tto.element.style.transformOrigin = 'top left'\n\t\tto.element.style.setProperty('visibility', 'visible')\n\t\tto.element.style.zIndex = '1000'\n\n\t\t// \"onBegin\" logic goes here (since Web Animations doesn't have onBegin).\n\t\t// If you had more logic, place it here:\n\t\t// e.g., console.log('Starting FLIP animation...');\n\n\t\t// Calculate starting and ending transforms\n\t\tconst startX = from.rect.left - to.rect.left\n\t\tconst startY = from.rect.top - to.rect.top\n\t\tconst startScaleX = from.rect.width / to.rect.width\n\t\tconst startScaleY = from.rect.height / to.rect.height\n\n\t\t// Create keyframes\n\t\tconst keyframes: Keyframe[] = [\n\t\t\t{\n\t\t\t\ttransform: `translate(${startX}px, ${startY}px) scale(${startScaleX}, ${startScaleY})`,\n\t\t\t},\n\t\t\t{\n\t\t\t\ttransform: 'translate(0, 0) scale(1, 1)',\n\t\t\t},\n\t\t]\n\n\t\t// Use native Web Animations API\n\t\tconst animation = to.element.animate(keyframes, {\n\t\t\tduration: 250,\n\t\t\tdelay: 10, // if desired\n\t\t\t// Approximate 'inOutQuad' via a cubic-bezier easing.\n\t\t\t// You can adjust these values to taste, or use a standard one:\n\t\t\teasing: 'cubic-bezier(0.455, 0.03, 0.515, 0.955)',\n\t\t\t// or simply 'ease-in-out'\n\t\t})\n\n\t\t// \"onComplete\" logic goes here\n\t\tanimation.onfinish = () => {\n\t\t\tto.element.style.zIndex = originalZIndex\n\t\t\tto.element.style.transformOrigin = ''\n\t\t\t// If you have additional cleanup, place it here\n\t\t\t// e.g., console.log('FLIP animation completed!');\n\t\t}\n\t}\n}\n\nexport const teleport = new Teleportation()\nexport default teleport\n","import { Observable, interval } from 'rxjs'\nimport { distinctUntilChanged, map, take } from 'rxjs/operators'\n\n// Function to monitor element's bounding client rect\nexport function watchElementRect(element: Element): Observable<DOMRectReadOnly> {\n\treturn interval(50).pipe(\n\t\t// startWith(true),\n\t\tmap(() => element.getBoundingClientRect()),\n\t\tdistinctUntilChanged(\n\t\t\t(prev, curr) =>\n\t\t\t\tprev.width === curr.width &&\n\t\t\t\tprev.height === curr.height &&\n\t\t\t\tprev.top === curr.top &&\n\t\t\t\tprev.right === curr.right &&\n\t\t\t\tprev.bottom === curr.bottom &&\n\t\t\t\tprev.left === curr.left,\n\t\t),\n\t\ttake(1),\n\t)\n}\n","import { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { filter, fromEvent, merge, of, takeUntil, tap, throwIfEmpty } from 'rxjs'\nimport { FINDING_MORTIES, FINDING_MORTIES_EVENT, HERE_RICKY, HERE_RICKY_EVENT } from '..'\nimport {\n\tHereMorty,\n\tHereMortyEvent,\n\tWhereAreYouRicky,\n\tWhereAreYouRickyEvent,\n\tdefault as teleport,\n\tdefault as teleportationService,\n} from './teleport.service'\nimport { watchElementRect } from './watcher'\nimport { $LitElement } from '@mixins/index'\n@customElement('schmancy-teleport')\nexport class SchmancyTeleportation extends $LitElement(css``) {\n\t/**\n\t * @attr {string} uuid - The component tag to teleport\n\t * @readonly\n\t */\n\t@property({ type: Number, reflect: true }) uuid = Math.floor(Math.random() * Date.now())\n\n\t/**\n\t * @attr {string} id - The component tag to teleport\n\t * @required\n\t */\n\t@property({ type: String }) id!: string\n\n\t@property({ type: Number }) delay = 0\n\n\tdebugging = import.meta.env.DEV ? true : false\n\n\tget _slottedChildren() {\n\t\tconst slot = this.shadowRoot.querySelector('slot')\n\t\treturn slot.assignedElements({ flatten: true })\n\t}\n\n\tconnectedCallback(): void {\n\t\tif (this.id === undefined) throw new Error('id is required')\n\t\tsuper.connectedCallback()\n\t\tmerge(\n\t\t\tfromEvent<FINDING_MORTIES_EVENT>(window, FINDING_MORTIES).pipe(\n\t\t\t\ttap({\n\t\t\t\t\tnext: () => {\n\t\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\t\tnew CustomEvent<HERE_RICKY_EVENT['detail']>(HERE_RICKY, {\n\t\t\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\t\t\tcomponent: this,\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t)\n\t\t\t\t\t},\n\t\t\t\t}),\n\t\t\t),\n\t\t\tfromEvent<WhereAreYouRickyEvent>(window, WhereAreYouRicky).pipe(\n\t\t\t\ttap({\n\t\t\t\t\tnext: e => {\n\t\t\t\t\t\tif (e.detail.id === this.id && this.uuid && e.detail.callerID !== this.uuid) {\n\t\t\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\t\t\tnew CustomEvent<HereMortyEvent['detail']>(HereMorty, {\n\t\t\t\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\t\t\t\tcomponent: this,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t}\n\t\t\t\t\t},\n\t\t\t\t}),\n\t\t\t),\n\t\t)\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe()\n\t}\n\n\tasync firstUpdated() {\n\t\tof(teleportationService.activeTeleportations.get(this.id))\n\t\t\t.pipe(\n\t\t\t\tfilter(a => !!a),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t\tthrowIfEmpty(),\n\t\t\t)\n\t\t\t.subscribe({\n\t\t\t\tnext: domRect => {\n\t\t\t\t\tconsole.count('teleport')\n\t\t\t\t\tthis.style.setProperty('visibility', 'hidden')\n\t\t\t\t\t// teleport.flipRequests.next({ from: component, to: this, stagger: 0 })\n\t\t\t\t\twatchElementRect(this)\n\t\t\t\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t\t\t\t.subscribe({\n\t\t\t\t\t\t\tnext: e => {\n\t\t\t\t\t\t\t\t// console.log(e)\n\t\t\t\t\t\t\t\tteleportationService.activeTeleportations.set(this.id, e)\n\t\t\t\t\t\t\t\tteleport.flipRequests.next({\n\t\t\t\t\t\t\t\t\tfrom: {\n\t\t\t\t\t\t\t\t\t\trect: domRect,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\tto: {\n\t\t\t\t\t\t\t\t\t\trect: e,\n\t\t\t\t\t\t\t\t\t\telement: this._slottedChildren[0] as HTMLElement,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\thost: this,\n\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t})\n\t\t\t\t},\n\t\t\t\terror: () => {\n\t\t\t\t\tthis.style.setProperty('visibility', 'visible')\n\t\t\t\t\twatchElementRect(this)\n\t\t\t\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t\t\t\t.subscribe({\n\t\t\t\t\t\t\tnext: e => {\n\t\t\t\t\t\t\t\tconsole.log(e)\n\t\t\t\t\t\t\t\tteleportationService.activeTeleportations.set(this.id, e)\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t})\n\t\t\t\t},\n\t\t\t\tcomplete: () => {},\n\t\t\t})\n\t}\n\n\trender() {\n\t\treturn html`<slot></slot>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-teleport': SchmancyTeleportation\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { html } from 'lit'\nimport { customElement, query } from 'lit/decorators.js'\nimport { $newSchmancyTheme } from '..'\n\n@customElement('schmancy-theme-button')\nexport default class SchmancyThemeButton extends TailwindElement() {\n\t@query('#color') color!: HTMLElement\n\n\tprotected render(): unknown {\n\t\treturn html`\n\t\t\t<schmancy-button\n\t\t\t\t@click=${() => {\n\t\t\t\t\t// Trigger any other effects you have\n\t\t\t\t\t$newSchmancyTheme.next(undefined)\n\n\t\t\t\t\t// Native Web Animations API usage:\n\t\t\t\t\tthis.color.animate([{ transform: 'rotate(0deg)' }, { transform: 'rotate(360deg)' }], {\n\t\t\t\t\t\tduration: 300,\n\t\t\t\t\t\t// fill: 'forwards', // Use if you want it to remain rotated at 360°\n\t\t\t\t\t\t// easing: 'ease-out', // Or another easing function\n\t\t\t\t\t})\n\t\t\t\t}}\n\t\t\t\tvariant=\"text\"\n\t\t\t>\n\t\t\t\t<schmancy-icon id=\"color\">palette</schmancy-icon>\n\t\t\t</schmancy-button>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-theme-button': SchmancyThemeButton\n\t}\n}\n"],"names":["SchmancyCardMedia","TailwindElement","css","html","customElement","SchmancyCard","super","arguments","this","type","elevation","classes","includes","classMap","__decorateClass","property","prototype","Number","SchmancyCardContent","onSurface","SchmancyTheme","sys","color","surface","on","onSurfaceVariant","onVariant","src","fit","styleMap","height","String","reflect","schmancyContentDrawer","$drawer","Subject","pipe","subscribe","data","action","ref","dispatchEvent","CustomEvent","SchmancyEvents","ContentDrawerToggle","detail","state","bubbles","composed","component","title","next","t","SchmancyContentDrawerSheetMode","createContext","SchmancyContentDrawerSheetState","SchmancyContentDrawerID","n","Math","floor","random","Date","now","toString","SchmancyContentDrawerMaxHeight","SchmancyContentDrawerMinWidth","SchmancyContentDrawer","$LitElement","constructor","minWidth","main","sheet","schmancyContentDrawerID","maxHeight","merge","fromEvent","window","ContentDrawerResize","startWith","tap","map","clientWidth","innerWidth","width","debounceTime","innerHeight","getOffsetTop","style","setProperty","distinctUntilChanged","takeUntil","disconnecting","lgScreen","mode","open","event","stopPropagation","area","push","historyStrategy","uid","element","offsetTop","offsetParent","render","nothing","provide","context","queryAssignedElements","flatten","SchmancyContentDrawerMain","connectedCallback","drawerMinWidth","changedProperties","update","has","styles","when","consume","SchmancyContentDrawerSheet","updated","closeAll","dismiss","position","display","animate","opacity","transform","duration","easing","from","closeModalSheet","closeSheet","of","Observable","observer","onfinish","complete","sheetClasses","block","query","slot","SchmancyListItem","selected","leading","forEach","img","classList","add","imgClasses","trailing","rounded","stateLayerClasses","readonly","SchmancySurfaceTypeContext","Boolean","SchmancyListTypeContext","List","schmancyNavDrawer","NavDrawer_toggle","self","SchmancyDrawerNavbarMode","SchmancyDrawerNavbarState","SchmancyDrawerAppbar","toggler","sidebarToggler","sidebarMode","hidden","sidebarOpen","SchmancyNavigationDrawerContent","e","parentElement","SchmancyNavigationDrawer","fullscreen","breakpoint","target","fullHeight","attribute","SchmancyNavigationDrawerSidebar","closeOverlay","openOverlay","overlay","fill","sidebarClasses","bgColor","container","scrim","WhereAreYouRicky","HereMorty","teleport","activeTeleportations","Map","flipRequests","find","zip","filter","uuid","id","take","callerID","timeout","flip","request","to","originalZIndex","zIndex","transformOrigin","keyframes","rect","left","top","delay","bufferTime","requests","host","i","concatMap","watchElementRect","interval","getBoundingClientRect","prev","curr","right","bottom","SchmancyTeleportation","debugging","shadowRoot","querySelector","assignedElements","Error","FINDING_MORTIES","HERE_RICKY","teleportationService","get","a","throwIfEmpty","domRect","set","_slottedChildren","error","SchmancyThemeButton","$newSchmancyTheme"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"theme-button-lS8U2Zia.cjs","sources":["../src/card/actions.ts","../src/card/card.ts","../src/card/content.ts","../src/card/media.ts","../src/content-drawer/$sheet.ts","../src/content-drawer/context.ts","../src/content-drawer/drawer.ts","../src/content-drawer/main.ts","../src/content-drawer/sheet.ts","../src/list/list-item.ts","../src/list/context.ts","../src/list/list.ts","../src/nav-drawer/$navbar.ts","../src/nav-drawer/context.ts","../src/nav-drawer/appbar.ts","../src/nav-drawer/content.ts","../src/nav-drawer/drawer.ts","../src/nav-drawer/navbar.ts","../src/teleport/teleport.service.ts","../src/teleport/watcher.ts","../src/teleport/teleport.component.ts","../src/theme-button/theme-button.ts"],"sourcesContent":["import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\n\n/**\n * @element schmancy-card-action\n * @slot - The content of the action\n */\n@customElement('schmancy-card-action')\nexport default class SchmancyCardMedia extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n`) {\n\tprotected render(): unknown {\n\t\treturn html` <section class=\"pb-4 px-4\"><slot> </slot></section> `\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card-action': SchmancyCardMedia\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\n@customElement('schmancy-card')\nexport default class SchmancyCard extends TailwindElement() {\n\t@property() type: 'elevated' | 'filled' | 'outlined' = 'elevated'\n\t@property({ type: Number }) elevation: 0 | 1 | 2 | 3 | 4 | 5 = 0\n\tprotected render(): unknown {\n\t\tconst classes = {\n\t\t\t'rounded-md': true,\n\t\t\t'shadow-1': this.elevation === 1,\n\t\t\t'shadow-2': this.elevation === 2,\n\t\t\t'shadow-3': this.elevation === 3,\n\t\t\t'shadow-4': this.elevation === 4,\n\t\t\t'shadow-5': this.elevation === 5,\n\t\t\t'hover:shadow-1': ['outlined', 'filled'].includes(this.type),\n\t\t\t'bg-surface-low shadow-1 hover:shadow-2': this.type === 'elevated',\n\t\t\t'bg-surface-highest': this.type === 'filled',\n\t\t\t'bg-surface-default border-1 border-outlinetype ': this.type === 'outlined',\n\t\t}\n\t\treturn html`<div class=\"${this.classMap(classes)}\">\n\t\t\t<slot> </slot>\n\t\t</div>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card': SchmancyCard\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { SchmancyTheme } from '@schmancy/theme/theme.interface'\nimport { html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\nimport { color } from '..'\n\n/**\n * @element schmancy-card-content\n * @slot headline\n * @slot subhead\n * @slot default - The content of the card\n */\n@customElement('schmancy-card-content')\nexport default class SchmancyCardContent extends TailwindElement() {\n\tprotected render(): unknown {\n\t\tconst classes = {\n\t\t\t'px-[16px] py-[24px]': true,\n\t\t}\n\t\tconst onSurface = SchmancyTheme.sys.color.surface.on\n\t\tconst onSurfaceVariant = SchmancyTheme.sys.color.surface.onVariant\n\t\treturn html`<schmancy-grid gap=\"md\" class=\"${this.classMap(classes)}\">\n\t\t\t<schmancy-grid gap=\"xs\">\n\t\t\t\t<schmancy-typography\n\t\t\t\t\t${color({\n\t\t\t\t\t\tcolor: onSurface,\n\t\t\t\t\t})}\n\t\t\t\t\ttype=\"body\"\n\t\t\t\t\ttoken=\"lg\"\n\t\t\t\t\t><slot name=\"headline\"> </slot\n\t\t\t\t></schmancy-typography>\n\t\t\t\t<schmancy-typography\n\t\t\t\t\t${color({\n\t\t\t\t\t\tcolor: onSurfaceVariant,\n\t\t\t\t\t})}\n\t\t\t\t\ttype=\"body\"\n\t\t\t\t\t><slot name=\"subhead\"></slot>\n\t\t\t\t</schmancy-typography>\n\t\t\t</schmancy-grid>\n\t\t\t<schmancy-typography\n\t\t\t\ttype=\"body\"\n\t\t\t\t${color({\n\t\t\t\t\tcolor: onSurfaceVariant,\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t<slot></slot>\n\t\t\t</schmancy-typography>\n\t\t</schmancy-grid>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card-content': SchmancyCardContent\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\n/**\n * @element schmancy-card-media\n */\n@customElement('schmancy-card-media')\nexport default class SchmancyCardMedia extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n`) {\n\t@property({ type: String, reflect: true })\n\tsrc: string = ''\n\n\t@property({ type: String })\n\tfit: 'contain' | 'cover' | 'fill' | 'none' | 'scale-down' = 'contain'\n\n\tprotected render(): unknown {\n\t\tconst styles = {\n\t\t\theight: '200px',\n\t\t}\n\t\tconst classes = {\n\t\t\t'object-center': true,\n\t\t\t'object-contain': this.fit === 'contain',\n\t\t\t'object-cover w-full': this.fit === 'cover',\n\t\t\t'object-fill': this.fit === 'fill',\n\t\t\t'object-none': this.fit === 'none',\n\t\t\t'object-scale-down': this.fit === 'scale-down',\n\t\t}\n\t\treturn html`<schmancy-grid align=\"stretch\" justify=\"stretch\" gap=\"md\">\n\t\t\t<img src=\"${this.src}\" style=${this.styleMap(styles)} class=\"${this.classMap(classes)}\" />\n\t\t</schmancy-grid>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card-media': SchmancyCardMedia\n\t}\n}\n","import { SchmancyEvents } from '@schmancy/types/events'\nimport { Subject } from 'rxjs'\n\ntype DrawerAction = 'dismiss' | 'render'\ntype TRef = Element | Window\ntype TRenderRequest = HTMLElement\nexport type TRenderCustomEvent = CustomEvent<{\n\tcomponent: TRenderRequest\n\ttitle?: string\n}>\nclass Drawer {\n\tprivate $drawer = new Subject<{\n\t\tref: TRef\n\t\taction: DrawerAction\n\t\tcomponent?: TRenderRequest\n\t\ttitle?: string\n\t}>()\n\tconstructor() {\n\t\tthis.$drawer.pipe().subscribe(data => {\n\t\t\tif (data.action === 'dismiss') {\n\t\t\t\tdata.ref.dispatchEvent(\n\t\t\t\t\tnew CustomEvent(SchmancyEvents.ContentDrawerToggle, {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tstate: 'close',\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t} else if (data.action === 'render') {\n\t\t\t\tdata.ref.dispatchEvent(\n\t\t\t\t\tnew CustomEvent(SchmancyEvents.ContentDrawerToggle, {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tstate: 'open',\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t\tdata.ref.dispatchEvent(\n\t\t\t\t\tnew CustomEvent('schmancy-content-drawer-render', {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tcomponent: data.component,\n\t\t\t\t\t\t\ttitle: data.title,\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t}\n\t\t})\n\t}\n\n\tdimiss(ref: TRef) {\n\t\tthis.$drawer.next({\n\t\t\taction: 'dismiss',\n\t\t\tref: ref,\n\t\t})\n\t}\n\n\trender(ref: TRef, component: TRenderRequest, title?: string) {\n\t\tref.dispatchEvent(new CustomEvent('custom-event'))\n\t\tthis.$drawer.next({\n\t\t\taction: 'render',\n\t\t\tref: ref,\n\t\t\tcomponent: component,\n\t\t\ttitle,\n\t\t})\n\t}\n}\n\nexport const schmancyContentDrawer = new Drawer()\n","import { createContext } from '@lit/context'\nexport type TSchmancyContentDrawerSheetMode = 'push' | 'overlay'\nexport const SchmancyContentDrawerSheetMode = createContext<TSchmancyContentDrawerSheetMode>('push')\n\nexport type TSchmancyContentDrawerSheetState = 'open' | 'close'\nexport const SchmancyContentDrawerSheetState = createContext<TSchmancyContentDrawerSheetState>('close')\n\nexport const SchmancyContentDrawerID = createContext<string>(Math.floor(Math.random() * Date.now()).toString())\nexport const SchmancyContentDrawerMaxHeight = createContext<string>('100%')\nexport const SchmancyContentDrawerMinWidth = createContext<{\n\tmain: number\n\tsheet: number\n}>({})\n","import { provide } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { css, html, nothing } from 'lit'\nimport { customElement, property, queryAssignedElements, state } from 'lit/decorators.js'\nimport { debounceTime, distinctUntilChanged, fromEvent, map, merge, startWith, takeUntil, tap } from 'rxjs'\nimport { SchmancyEvents, TRenderCustomEvent, area, sheet } from '..'\nimport {\n\tSchmancyContentDrawerID,\n\tSchmancyContentDrawerMaxHeight,\n\tSchmancyContentDrawerMinWidth,\n\tSchmancyContentDrawerSheetMode,\n\tSchmancyContentDrawerSheetState,\n\tTSchmancyContentDrawerSheetMode,\n\tTSchmancyContentDrawerSheetState,\n} from './context'\n\n/**\n * @element schmancy-content-drawer\n * @slot appbar - The appbar slot\n * @slot - The content slot\n */\n@customElement('schmancy-content-drawer')\nexport class SchmancyContentDrawer extends $LitElement(css`\n\t:host {\n\t\tposition: relative;\n\t\tinset: 0;\n\t\tdisplay: block;\n\t\toverflow: hidden;\n\t}\n`) {\n\t/**\n\t * The minimum width of the sheet\n\t * @attr\tminWidth\n\t * @type {number}\n\t * @memberof SchmancyContentDrawer\n\t */\n\n\t@provide({ context: SchmancyContentDrawerMinWidth })\n\tminWidth: typeof SchmancyContentDrawerMinWidth.__context__ = {\n\t\tmain: 360,\n\t\tsheet: 576,\n\t}\n\n\t/**\n\t * The state of the sheet\n\t * @attr open\n\t * @type {TSchmancyContentDrawerSheetState}\n\t */\n\t@provide({ context: SchmancyContentDrawerSheetState })\n\t@property()\n\topen: TSchmancyContentDrawerSheetState\n\n\t/**\n\t * The mode of the sheet\n\t * @type {TSchmancyContentDrawerSheetMode}\n\t * @memberof SchmancyContentDrawer\n\t * @protected\n\t */\n\t@provide({ context: SchmancyContentDrawerSheetMode })\n\t@state()\n\tmode: TSchmancyContentDrawerSheetMode\n\n\t@provide({ context: SchmancyContentDrawerID })\n\tschmancyContentDrawerID = Math.floor(Math.random() * Date.now()).toString()\n\n\t@provide({ context: SchmancyContentDrawerMaxHeight })\n\tmaxHeight = '100%'\n\n\t@queryAssignedElements({ flatten: true })\n\tassignedElements!: HTMLElement[]\n\tfirstUpdated(): void {\n\t\tmerge(fromEvent<CustomEvent>(window, 'resize'), fromEvent<CustomEvent>(window, SchmancyEvents.ContentDrawerResize))\n\t\t\t.pipe(\n\t\t\t\tstartWith(true),\n\t\t\t\ttap(() => console.log(this.minWidth)),\n\t\t\t\tmap(() => (this.clientWidth ? this.clientWidth : window.innerWidth)),\n\t\t\t\tmap(width => width >= this.minWidth.main + this.minWidth.sheet),\n\t\t\t\tdebounceTime(100),\n\t\t\t\ttap(() => {\n\t\t\t\t\tthis.maxHeight = `${window.innerHeight - this.getOffsetTop(this) - 32}px`\n\t\t\t\t\tthis.style.setProperty('max-height', this.maxHeight)\n\t\t\t\t}),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe(lgScreen => {\n\t\t\t\tif (lgScreen) {\n\t\t\t\t\tthis.mode = 'push'\n\t\t\t\t\tthis.open = 'open'\n\t\t\t\t} else {\n\t\t\t\t\tthis.mode = 'overlay'\n\t\t\t\t\tthis.open = 'close'\n\t\t\t\t}\n\t\t\t})\n\n\t\t/*\n\t\t * Listen to the toggle event\n\t\t */\n\t\tfromEvent<CustomEvent>(window, SchmancyEvents.ContentDrawerToggle)\n\t\t\t.pipe(\n\t\t\t\ttap(event => {\n\t\t\t\t\tevent.stopPropagation()\n\t\t\t\t}),\n\t\t\t\tmap(event => event.detail.state),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe(state => {\n\t\t\t\tthis.open = state\n\t\t\t})\n\n\t\tfromEvent<TRenderCustomEvent>(window, 'schmancy-content-drawer-render')\n\t\t\t.pipe(\n\t\t\t\ttap(event => {\n\t\t\t\t\tevent.stopPropagation()\n\t\t\t\t}),\n\t\t\t\tmap(event => event.detail),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe(({ component, title }) => {\n\t\t\t\tif (this.mode === 'push') {\n\t\t\t\t\t// TODO: Fix the router to render if constructor has different arguments\n\t\t\t\t\tarea.push({\n\t\t\t\t\t\tarea: this.schmancyContentDrawerID,\n\t\t\t\t\t\tcomponent: 'empty',\n\t\t\t\t\t\thistoryStrategy: 'silent',\n\t\t\t\t\t})\n\t\t\t\t\tarea.push({\n\t\t\t\t\t\tarea: this.schmancyContentDrawerID,\n\t\t\t\t\t\tcomponent: component,\n\t\t\t\t\t\thistoryStrategy: 'silent',\n\t\t\t\t\t})\n\t\t\t\t} else if ((this.mode = 'overlay')) {\n\t\t\t\t\tsheet.open({ component: component, uid: this.schmancyContentDrawerID, title })\n\t\t\t\t}\n\t\t\t})\n\t}\n\n\tgetOffsetTop(element) {\n\t\tlet offsetTop = 0\n\t\twhile (element) {\n\t\t\toffsetTop += element.offsetTop\n\t\t\telement = element.offsetParent\n\t\t}\n\t\treturn offsetTop\n\t}\n\n\tprotected render() {\n\t\tif (!this.mode || !this.open) return nothing\n\t\treturn html`\n\t\t\t<schmancy-grid\n\t\t\t\tcols=${this.mode === 'overlay' ? '1fr' : 'auto 1fr'}\n\t\t\t\trows=\"1fr\"\n\t\t\t\tflow=\"col\"\n\t\t\t\tjustify=\"stretch\"\n\t\t\t\talign=\"stretch\"\n\t\t\t>\n\t\t\t\t<slot></slot>\n\t\t\t</schmancy-grid>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-content-drawer': SchmancyContentDrawer\n\t}\n}\n","import { consume } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { PropertyValueMap, css, html } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { SchmancyEvents } from '..'\nimport {\n\tSchmancyContentDrawerMaxHeight,\n\tSchmancyContentDrawerMinWidth,\n\tSchmancyContentDrawerSheetMode,\n\tTSchmancyContentDrawerSheetMode,\n} from './context'\nimport { when } from 'lit/directives/when.js'\n\n@customElement('schmancy-content-drawer-main')\nexport class SchmancyContentDrawerMain extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\toverflow: hidden;\n\t}\n`) {\n\t@property({ type: Number })\n\tminWidth\n\n\t@consume({ context: SchmancyContentDrawerMinWidth, subscribe: true })\n\tdrawerMinWidth: typeof SchmancyContentDrawerMinWidth.__context__\n\n\t@consume({ context: SchmancyContentDrawerSheetMode, subscribe: true })\n\t@state()\n\tmode: TSchmancyContentDrawerSheetMode\n\n\t@consume({ context: SchmancyContentDrawerMaxHeight, subscribe: true })\n\t@state()\n\tmaxHeight\n\n\tconnectedCallback(): void {\n\t\tsuper.connectedCallback()\n\t\tif (this.minWidth) this.drawerMinWidth.main = this.minWidth\n\t\telse this.minWidth = this.drawerMinWidth.main\n\t}\n\n\tprotected update(changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>): void {\n\t\tsuper.update(changedProperties)\n\t\tif (changedProperties.has('minWidth') && this.minWidth) {\n\t\t\tthis.drawerMinWidth.main = this.minWidth\n\t\t\tthis.dispatchEvent(new CustomEvent(SchmancyEvents.ContentDrawerResize, { bubbles: true, composed: true }))\n\t\t}\n\t}\n\n\trender() {\n\t\tconst styles = {\n\t\t\tminWidth: `${this.minWidth}px`,\n\t\t\tmaxHeight: this.maxHeight,\n\t\t}\n\t\treturn html`\n\t\t\t<section class=\"relative inset-0 h-full\">\n\t\t\t\t<schmancy-grid\n\t\t\t\t\tclass=\"h-full relative overflow-scroll\"\n\t\t\t\t\tcols=\"${this.mode === 'push' ? 'auto 1fr' : '1fr'}\"\n\t\t\t\t\trows=\"1fr\"\n\t\t\t\t\tflow=\"col\"\n\t\t\t\t\talign=\"stretch\"\n\t\t\t\t\tjustify=\"stretch\"\n\t\t\t\t>\n\t\t\t\t\t<section style=${this.styleMap(styles)}>\n\t\t\t\t\t\t<slot></slot>\n\t\t\t\t\t</section>\n\t\t\t\t</schmancy-grid>\n\t\t\t\t${when(\n\t\t\t\t\tthis.mode === 'push',\n\t\t\t\t\t() => html` <schmancy-divider class=\"absolute right-0 top-0\" orientation=\"vertical\"></schmancy-divider>`,\n\t\t\t\t)}\n\t\t\t</section>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-content-drawer-main': SchmancyContentDrawerMain\n\t}\n}\n","import { consume } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query, queryAssignedElements, state } from 'lit/decorators.js'\nimport { from, merge, Observable, of, takeUntil, tap } from 'rxjs'\nimport { SchmancyEvents, sheet } from '..'\nimport {\n\tSchmancyContentDrawerID,\n\tSchmancyContentDrawerMaxHeight,\n\tSchmancyContentDrawerMinWidth,\n\tSchmancyContentDrawerSheetMode,\n\tSchmancyContentDrawerSheetState,\n\tTSchmancyContentDrawerSheetMode,\n\tTSchmancyContentDrawerSheetState,\n} from './context'\n\n// --- 1) Removed the custom animate import\n// import { animate } from '@packages/anime-beta-master'\n\n@customElement('schmancy-content-drawer-sheet')\nexport class SchmancyContentDrawerSheet extends $LitElement(css`\n\t:host {\n\t\toverflow: scroll;\n\t}\n`) {\n\t@property({ type: Number })\n\tminWidth\n\n\t@consume({ context: SchmancyContentDrawerSheetMode, subscribe: true })\n\t@state()\n\tmode: TSchmancyContentDrawerSheetMode\n\n\t@consume({ context: SchmancyContentDrawerSheetState, subscribe: true })\n\t@state()\n\tstate: TSchmancyContentDrawerSheetState\n\n\t@consume({ context: SchmancyContentDrawerID })\n\tschmancyContentDrawerID\n\n\t@query('#sheet') sheet!: HTMLElement\n\t@queryAssignedElements({ flatten: true, slot: undefined }) defaultSlot!: HTMLElement[]\n\n\t@consume({ context: SchmancyContentDrawerMinWidth, subscribe: true })\n\tdrawerMinWidth: typeof SchmancyContentDrawerMinWidth.__context__\n\n\t@consume({ context: SchmancyContentDrawerMaxHeight, subscribe: true })\n\t@state()\n\tmaxHeight\n\n\tconnectedCallback(): void {\n\t\tsuper.connectedCallback()\n\t\tif (this.minWidth) {\n\t\t\tthis.drawerMinWidth.sheet = this.minWidth\n\t\t} else {\n\t\t\tthis.minWidth = this.drawerMinWidth.sheet\n\t\t}\n\t}\n\n\tupdated(changedProperties: Map<string, any>) {\n\t\tsuper.updated(changedProperties)\n\t\tif (changedProperties.has('minWidth') && this.minWidth) {\n\t\t\t// If the 'minWidth' property changed\n\t\t\tthis.drawerMinWidth.sheet = this.minWidth\n\t\t\tthis.dispatchEvent(new CustomEvent(SchmancyEvents.ContentDrawerResize, { bubbles: true, composed: true }))\n\t\t} else if (changedProperties.has('state') || changedProperties.has('mode')) {\n\t\t\tif (this.mode === 'overlay') {\n\t\t\t\tif (this.state === 'close') {\n\t\t\t\t\tthis.closeAll()\n\t\t\t\t} else if (this.state === 'open') {\n\t\t\t\t\t// Overlay open logic if needed\n\t\t\t\t\t// this.open()\n\t\t\t\t}\n\t\t\t} else if (this.mode === 'push') {\n\t\t\t\tsheet.dismiss(this.schmancyContentDrawerID)\n\t\t\t\tif (this.state === 'close') {\n\t\t\t\t\tthis.closeAll()\n\t\t\t\t} else if (this.state === 'open') {\n\t\t\t\t\tthis.open()\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Open the sheet by sliding it into view.\n\t */\n\topen() {\n\t\t// \"onBegin\" logic from the old `animate(...)`\n\t\tif (this.mode === 'overlay') {\n\t\t\tthis.sheet.style.position = 'fixed'\n\t\t} else {\n\t\t\tthis.sheet.style.position = 'relative'\n\t\t}\n\t\tthis.sheet.style.display = 'block'\n\n\t\t// --- 2) Use native Web Animations API ---\n\t\tthis.sheet.animate(\n\t\t\t[\n\t\t\t\t{ opacity: 0, transform: 'translateX(100%)' },\n\t\t\t\t{ opacity: 1, transform: 'translateX(0%)' },\n\t\t\t],\n\t\t\t{\n\t\t\t\tduration: 500,\n\t\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t\t},\n\t\t)\n\t\t// No return is needed if you don't rely on the result\n\t}\n\n\t/**\n\t * Close everything (modal sheet + the sheet itself).\n\t */\n\tcloseAll() {\n\t\t// Merge them into a single subscription,\n\t\t// so that everything closes in parallel.\n\t\tmerge(from(this.closeModalSheet()), from(this.closeSheet())).pipe(takeUntil(this.disconnecting)).subscribe()\n\t}\n\n\t/**\n\t * Dismiss the \"modal sheet.\"\n\t * This just returns an Observable that completes immediately.\n\t */\n\tcloseModalSheet() {\n\t\treturn of(true).pipe(tap(() => sheet.dismiss(this.schmancyContentDrawerID)))\n\t}\n\n\t/**\n\t * Slide the sheet out of view + hide it.\n\t * Return an Observable so we can merge it with other close operations.\n\t */\n\tcloseSheet() {\n\t\t// --- 2) Use native Web Animations API and wrap in an Observable ---\n\t\treturn new Observable<void>(observer => {\n\t\t\tconst animation = this.sheet.animate(\n\t\t\t\t[\n\t\t\t\t\t{ opacity: 1, transform: 'translateX(0%)' },\n\t\t\t\t\t{ opacity: 1, transform: 'translateX(100%)' },\n\t\t\t\t],\n\t\t\t\t{\n\t\t\t\t\tduration: 500,\n\t\t\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t\t\t},\n\t\t\t)\n\n\t\t\tanimation.onfinish = () => {\n\t\t\t\t// \"onComplete\" logic\n\t\t\t\tthis.sheet.style.display = 'none'\n\t\t\t\tobserver.next()\n\t\t\t\tobserver.complete()\n\t\t\t}\n\t\t})\n\t}\n\n\tprotected render() {\n\t\tconst sheetClasses = {\n\t\t\tblock: this.mode === 'push',\n\t\t\t'absolute z-[50]': this.mode === 'overlay',\n\t\t\t'opacity-1': this.mode === 'overlay' && this.state === 'open',\n\t\t}\n\n\t\tconst styles = {\n\t\t\tminWidth: `${this.minWidth}px`,\n\t\t\tmaxHeight: this.maxHeight,\n\t\t}\n\n\t\treturn html`\n\t\t\t<section id=\"sheet\" class=\"${this.classMap(sheetClasses)}\" style=${this.styleMap(styles)}>\n\t\t\t\t<schmancy-area name=\"${this.schmancyContentDrawerID}\">\n\t\t\t\t\t<slot name=\"placeholder\"></slot>\n\t\t\t\t</schmancy-area>\n\t\t\t</section>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-content-drawer-sheet': SchmancyContentDrawerSheet\n\t}\n}\n","import { consume } from '@lit/context'\nimport { TailwindElement } from '@mixins/index'\nimport { SchmancySurfaceTypeContext } from '@schmancy/surface/context'\nimport { SchmancyTheme } from '@schmancy/theme/theme.interface'\nimport { TSurfaceColor } from '@schmancy/types/surface'\nimport { html } from 'lit'\nimport { customElement, property, queryAssignedElements } from 'lit/decorators.js'\nimport { when } from 'lit/directives/when.js'\nimport { color } from '..'\n\n/**\n * @element schmancy-list-item\n * @slot leading - leading content\n * @slot trailing - trailing content\n * @slot - default content\n */\n@customElement('schmancy-list-item')\nexport class SchmancyListItem extends TailwindElement() {\n\t@consume({ context: SchmancySurfaceTypeContext, subscribe: true })\n\t@property()\n\tvariant: TSurfaceColor\n\n\t@property({ type: Boolean })\n\trounded: boolean\n\n\t@property({ type: Boolean }) readonly: boolean\n\n\t@property({ type: Boolean }) selected: boolean = false\n\n\t@queryAssignedElements({\n\t\tslot: 'leading',\n\t\tflatten: true,\n\t})\n\tprivate leading!: HTMLElement[]\n\n\t@queryAssignedElements({\n\t\tslot: 'trailing',\n\t\tflatten: true,\n\t})\n\tprivate trailing!: HTMLElement[]\n\n\tprotected get imgClasses(): string[] {\n\t\treturn ['h-[24px]', 'w-[24px]', 'object-contain']\n\t}\n\n\tfirstUpdated() {\n\t\tthis.leading?.forEach(img => {\n\t\t\timg.classList.add(...this.imgClasses)\n\t\t})\n\t\tthis.trailing?.forEach(img => {\n\t\t\timg.classList.add(...this.imgClasses)\n\t\t})\n\t}\n\n\trender() {\n\t\tconst classes = {\n\t\t\t'rounded-none': this.rounded === false,\n\t\t\t'rounded-full': this.rounded,\n\t\t\t'w-full min-h-[56px] relative flex items-center gap-[16px] py-[8px] px-[16px] duration-500 transition-colors':\n\t\t\t\ttrue,\n\t\t\t'bg-secondary-container text-secondery-onContainer': this.selected,\n\t\t}\n\n\t\tconst stateLayerClasses = {\n\t\t\t'z-0 duration-500 transition-opacity': true,\n\t\t\t'rounded-none': this.rounded === false,\n\t\t\t'rounded-full': this.rounded,\n\t\t\t'hover:bg-surface-on opacity-[0.08] cursor-pointer absolute inset-0': !this.readonly,\n\t\t}\n\t\treturn html`<li class=${this.classMap(classes)}>\n\t\t\t${when(!this.readonly, () => html` <div class=\"${this.classMap(stateLayerClasses)}\"></div> `)}\n\t\t\t<slot name=\"leading\"> </slot>\n\t\t\t<schmancy-grid class=\"flex-1\" justify=\"stretch\" align=\"center\">\n\t\t\t\t<schmancy-typography type=\"body\" token=\"lg\">\n\t\t\t\t\t<slot></slot>\n\t\t\t\t</schmancy-typography>\n\t\t\t\t<schmancy-typography\n\t\t\t\t\t${color({\n\t\t\t\t\t\tcolor: SchmancyTheme.sys.color.surface.onVariant,\n\t\t\t\t\t})}\n\t\t\t\t\ttype=\"body\"\n\t\t\t\t\ttoken=\"md\"\n\t\t\t\t\talign=\"left\"\n\t\t\t\t>\n\t\t\t\t\t<slot name=\"support\"></slot>\n\t\t\t\t</schmancy-typography>\n\t\t\t\t${when(!this.readonly, () => html` <div class=\"${this.classMap(stateLayerClasses)}\"></div> `)}\n\t\t\t</schmancy-grid>\n\t\t\t<slot name=\"trailing\"></slot>\n\t\t</li>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-list-item': SchmancyListItem\n\t}\n}\n","import { createContext } from '@lit/context'\nimport { TSurfaceColor } from '@schmancy/types/surface'\nexport const SchmancyListTypeContext = createContext<TSurfaceColor>(undefined)\n","import { provide } from '@lit/context'\nimport { TailwindElement } from '@mixins/index'\nimport { TSurfaceColor } from '@schmancy/types/surface'\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { SchmancyListTypeContext } from './context'\n\n/**\n * @slot - The default slot.\n */\n@customElement('schmancy-list')\nexport class List extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tpadding-top: 8px;\n\t\tpadding-bottom: 8px;\n\t}\n`) {\n\t/**\n\t * The type of list.\n\t * @attr type\n\t * @type {SchmancyListType}\n\t * @default 'surface'\n\t */\n\t@provide({ context: SchmancyListTypeContext })\n\t@property()\n\tsurface: TSurfaceColor\n\n\trender() {\n\t\treturn html`\n\t\t\t<schmancy-surface type=${this.surface}>\n\t\t\t\t<ul>\n\t\t\t\t\t<slot></slot>\n\t\t\t\t</ul>\n\t\t\t</schmancy-surface>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-list': List\n\t}\n}\n","import { SchmancyEvents } from '@schmancy/types/events'\nimport { Subject } from 'rxjs'\n\nclass Drawer {\n\tprivate $drawer = new Subject<{\n\t\tself: HTMLElement\n\t\tstate: boolean\n\t}>()\n\tconstructor() {\n\t\tthis.$drawer.subscribe(data => {\n\t\t\tif (data.state) {\n\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\tnew CustomEvent(SchmancyEvents.NavDrawer_toggle, {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tstate: 'open',\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t} else {\n\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\tnew CustomEvent(SchmancyEvents.NavDrawer_toggle, {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tstate: 'close',\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t}\n\t\t})\n\t}\n\topen(self?: HTMLElement) {\n\t\tthis.$drawer.next({\n\t\t\tself,\n\t\t\tstate: true,\n\t\t})\n\t}\n\tclose(self?: HTMLElement) {\n\t\tthis.$drawer.next({\n\t\t\tself,\n\t\t\tstate: false,\n\t\t})\n\t}\n}\n\nexport const schmancyNavDrawer = new Drawer()\n","import { createContext } from '@lit/context'\nexport type TSchmancyDrawerNavbarMode = 'push' | 'overlay' | undefined\nexport const SchmancyDrawerNavbarMode = createContext<TSchmancyDrawerNavbarMode>('push')\n\nexport type TSchmancyDrawerNavbarState = 'open' | 'close' | undefined\nexport const SchmancyDrawerNavbarState = createContext<TSchmancyDrawerNavbarState>('close')\n","import { consume } from '@lit/context'\nimport { TailwindElement } from '@mixins/index'\nimport {\n\tSchmancyDrawerNavbarMode,\n\tSchmancyDrawerNavbarState,\n\tTSchmancyDrawerNavbarMode,\n} from '@schmancy/nav-drawer/context'\nimport { css, html } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { when } from 'lit/directives/when.js'\nimport { SchmancyEvents } from '..'\n\n/**\n * @element schmancy-nav-drawer-appbar\n * @slot toggler - The toggler slot\n * @slot - The default slot\n */\n@customElement('schmancy-nav-drawer-appbar')\nexport class SchmancyDrawerAppbar extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n`) {\n\t@consume({ context: SchmancyDrawerNavbarMode, subscribe: true })\n\t@state()\n\tsidebarMode: TSchmancyDrawerNavbarMode\n\n\t@consume({ context: SchmancyDrawerNavbarState, subscribe: true })\n\t@state()\n\tsidebarOpen\n\n\t@property({ type: Boolean }) toggler = true\n\n\trender() {\n\t\tconst appbarClasses = {\n\t\t\t'block z-50': true,\n\t\t}\n\t\tconst sidebarToggler = {\n\t\t\t'block left-3 z-50': this.sidebarMode === 'overlay',\n\t\t\thidden: this.sidebarMode === 'push',\n\t\t}\n\t\treturn html`\n\t\t\t<schmancy-grid\n\t\t\t\tcols=${this.sidebarMode === 'overlay' && this.toggler ? 'auto 1fr' : '1fr'}\n\t\t\t\tflow=\"col\"\n\t\t\t\tclass=${this.classMap(appbarClasses)}\n\t\t\t\tgap=\"sm\"\n\t\t\t\talign=\"center\"\n\t\t\t>\n\t\t\t\t${when(\n\t\t\t\t\tthis.sidebarMode === 'overlay' && this.toggler,\n\t\t\t\t\t() =>\n\t\t\t\t\t\thtml`<slot name=\"toggler\">\n\t\t\t\t\t\t\t<div class=\"${this.classMap(sidebarToggler)}\">\n\t\t\t\t\t\t\t\t<schmancy-icon-button\n\t\t\t\t\t\t\t\t\t@click=${() => {\n\t\t\t\t\t\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\t\t\t\t\t\tnew CustomEvent(SchmancyEvents.NavDrawer_toggle, {\n\t\t\t\t\t\t\t\t\t\t\t\tdetail: { state: this.sidebarOpen === 'open' ? 'close' : 'open' },\n\t\t\t\t\t\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t${when(\n\t\t\t\t\t\t\t\t\t\tthis.sidebarOpen === 'close',\n\t\t\t\t\t\t\t\t\t\t() => html`menu`,\n\t\t\t\t\t\t\t\t\t\t() => html`menu_open`,\n\t\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t\t</schmancy-icon-button>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t</slot>`,\n\t\t\t\t)}\n\n\t\t\t\t<slot> </slot>\n\t\t\t</schmancy-grid>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-nav-drawer-appbar': SchmancyDrawerAppbar\n\t}\n}\n","import { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\nimport { fromEvent, takeUntil } from 'rxjs'\n\n@customElement('schmancy-nav-drawer-content')\nexport class SchmancyNavigationDrawerContent extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tposition: relative;\n\t\tinset: 0;\n\t\toverflow-y: auto;\n\t}\n`) {\n\tconnectedCallback(): void {\n\t\tsuper.connectedCallback()\n\t\tfromEvent(this, 'scroll')\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe(e => {\n\t\t\t\tthis.parentElement.dispatchEvent(new CustomEvent('scroll', { detail: e, bubbles: true, composed: true }))\n\t\t\t})\n\t}\n\trender() {\n\t\treturn html` <slot></slot> `\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-nav-drawer-content': SchmancyNavigationDrawerContent\n\t}\n}\n","import { provide } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { css, html, nothing } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { debounceTime, distinctUntilChanged, fromEvent, map, startWith, takeUntil, tap } from 'rxjs'\nimport { SchmancyEvents } from '..'\nimport { fullHeight } from './../directives/height'\nimport {\n\tSchmancyDrawerNavbarMode,\n\tSchmancyDrawerNavbarState,\n\tTSchmancyDrawerNavbarMode,\n\tTSchmancyDrawerNavbarState,\n} from './context'\n\n/**\n * @element schmancy-nav-drawer\n * @slot appbar - The appbar slot\n * @slot - The content slot\n */\n@customElement('schmancy-nav-drawer')\nexport class SchmancyNavigationDrawer extends $LitElement(css`\n\t:host {\n\t\tdisplay: flex;\n\t\tflex-grow: 1;\n\t\toverflow: hidden;\n\t}\n`) {\n\t// fullscreen property\n\t@property({ type: Boolean })\n\tfullscreen: boolean = false\n\n\t/**\n\t * The minimum width of the sidebar\n\t * @attr\tbreakpoint\n\t * @type {number}\n\t * @memberof SchmancyNavigationDrawer\n\t */\n\t@property({ type: Number, attribute: 'breakpoint' })\n\tbreakpoint: number = 768\n\n\t/**\n\t * The mode of the sidebar\n\t * @type {TSchmancyDrawerNavbarMode}\n\t * @memberof SchmancyNavigationDrawer\n\t * @protected\n\t */\n\t@provide({ context: SchmancyDrawerNavbarMode })\n\t@state()\n\tmode: TSchmancyDrawerNavbarMode\n\n\t@provide({ context: SchmancyDrawerNavbarState })\n\t@property()\n\topen: TSchmancyDrawerNavbarState\n\n\tconnectedCallback(): void {\n\t\tsuper.connectedCallback()\n\t\tfromEvent<CustomEvent>(window, 'resize')\n\t\t\t.pipe(\n\t\t\t\tmap(event => event.target as Window),\n\t\t\t\tstartWith(window),\n\t\t\t\tmap(window => window.innerWidth),\n\t\t\t\tmap(width => width >= this.breakpoint),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t\tdebounceTime(100),\n\t\t\t)\n\t\t\t.subscribe(lgScreen => {\n\t\t\t\tif (lgScreen) {\n\t\t\t\t\tthis.mode = 'push'\n\t\t\t\t\tthis.open = 'open'\n\t\t\t\t} else {\n\t\t\t\t\tthis.mode = 'overlay'\n\t\t\t\t\tthis.open = 'close'\n\t\t\t\t}\n\t\t\t})\n\n\t\t/*\n\t\t * Listen to the toggle event\n\t\t */\n\t\tfromEvent<CustomEvent>(window, SchmancyEvents.NavDrawer_toggle)\n\t\t\t.pipe(\n\t\t\t\ttap(event => {\n\t\t\t\t\tevent.stopPropagation()\n\t\t\t\t}),\n\t\t\t\tmap(event => event.detail.state),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe(state => {\n\t\t\t\tthis.open = state\n\t\t\t})\n\t}\n\n\tprotected render() {\n\t\tif (!this.mode || !this.open) return nothing\n\t\treturn html`\n\t\t\t<schmancy-grid\n\t\t\t\tcols=${this.fullscreen ? '1fr' : 'auto 1fr'}\n\t\t\t\trows=\"1fr\"\n\t\t\t\tflow=\"col\"\n\t\t\t\tjustify=\"stretch\"\n\t\t\t\talign=\"stretch\"\n\t\t\t\t${fullHeight()}\n\t\t\t>\n\t\t\t\t<slot></slot>\n\t\t\t</schmancy-grid>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-nav-drawer': SchmancyNavigationDrawer\n\t}\n}\n","import { consume } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { html } from 'lit'\nimport { customElement, property, query, state } from 'lit/decorators.js'\nimport { SchmancyEvents, SchmancyTheme, color } from '..'\nimport {\n\tSchmancyDrawerNavbarMode,\n\tSchmancyDrawerNavbarState,\n\tTSchmancyDrawerNavbarMode,\n\tTSchmancyDrawerNavbarState,\n} from './context'\n\n@customElement('schmancy-nav-drawer-navbar')\nexport class SchmancyNavigationDrawerSidebar extends $LitElement() {\n\t// Removed: import { animate } from '@packages/src'\n\n\t@consume({ context: SchmancyDrawerNavbarMode, subscribe: true })\n\t@state()\n\tmode: TSchmancyDrawerNavbarMode\n\n\t@consume({ context: SchmancyDrawerNavbarState, subscribe: true })\n\t@state()\n\tprivate state: TSchmancyDrawerNavbarState\n\n\t@query('#overlay') overlay!: HTMLElement\n\n\t@property({ type: String }) width = '320px'\n\n\tconnectedCallback(): void {\n\t\tsuper.connectedCallback()\n\t\t// Your touch event logic can stay here if needed\n\t}\n\n\tupdated(changedProperties: Map<string, any>) {\n\t\tif (changedProperties.has('state')) {\n\t\t\tif (this.mode === 'overlay') {\n\t\t\t\tif (this.state === 'close') {\n\t\t\t\t\tthis.closeOverlay()\n\t\t\t\t} else if (this.state === 'open') {\n\t\t\t\t\tthis.openOverlay()\n\t\t\t\t}\n\t\t\t} else if (this.mode === 'push') {\n\t\t\t\tthis.closeOverlay()\n\t\t\t}\n\t\t}\n\t}\n\n\topenOverlay() {\n\t\t// Equivalent to onBegin\n\t\tthis.overlay.style.display = 'block'\n\n\t\t// Animate opacity from 0 to 0.4\n\t\tthis.overlay.animate([{ opacity: 0 }, { opacity: 0.4 }], {\n\t\t\tduration: 200,\n\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t\tfill: 'forwards', // <-- This keeps the final keyframe (0.4) after finishing\n\t\t})\n\t\t// If you want an onfinish here, you can add it:\n\t\t// .onfinish = () => console.log('overlay opened!')\n\t}\n\n\tcloseOverlay() {\n\t\t// Animate opacity from 0.4 to 0\n\t\tconst animation = this.overlay.animate([{ opacity: 0.4 }, { opacity: 0 }], {\n\t\t\tduration: 150,\n\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t})\n\n\t\t// Equivalent to onComplete\n\t\tanimation.onfinish = () => {\n\t\t\tthis.overlay.style.display = 'none'\n\t\t}\n\t}\n\n\tprotected render() {\n\t\tconst animate = {\n\t\t\t'transition-all transform-gpu duration-[200ms] ease-[cubicBezier(0.5, 0.01, 0.25, 1)]': true,\n\t\t}\n\n\t\tconst sidebarClasses = {\n\t\t\t'p-[16px] max-w-[360px] w-fit h-full overflow-auto': true,\n\t\t\tblock: this.mode === 'push',\n\t\t\t'fixed inset-0 translate-x-[-100%] z-50': this.mode === 'overlay',\n\t\t\t'translate-x-0': this.mode === 'overlay' && this.state === 'open',\n\t\t\t'translate-x-[-100%]': this.mode === 'overlay' && this.state === 'close',\n\t\t}\n\t\tconst overlayClass = {\n\t\t\t'fixed inset-0 z-[49] hidden': true,\n\t\t}\n\n\t\tconst styleMap = {\n\t\t\twidth: this.width,\n\t\t}\n\n\t\treturn html`\n\t\t\t<nav\n\t\t\t\tstyle=${this.styleMap(styleMap)}\n\t\t\t\tclass=\"${this.classMap({ ...sidebarClasses, ...animate })}\"\n\t\t\t\t${color({\n\t\t\t\t\tbgColor: SchmancyTheme.sys.color.surface.container,\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t<slot></slot>\n\t\t\t</nav>\n\t\t\t<div\n\t\t\t\tid=\"overlay\"\n\t\t\t\t${color({\n\t\t\t\t\tbgColor: SchmancyTheme.sys.color.scrim,\n\t\t\t\t})}\n\t\t\t\t@click=${() => {\n\t\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\t\tnew CustomEvent(SchmancyEvents.NavDrawer_toggle, {\n\t\t\t\t\t\t\tdetail: { state: 'close' },\n\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t}),\n\t\t\t\t\t)\n\t\t\t\t}}\n\t\t\t\tclass=\"${this.classMap({ ...overlayClass })}\"\n\t\t\t></div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-nav-drawer-navbar': SchmancyNavigationDrawerSidebar\n\t}\n}\n","import { bufferTime, concatMap, filter, fromEvent, map, of, Subject, take, tap, timeout, zip } from 'rxjs'\nimport { SchmancyTeleportation } from './teleport.component'\n\nexport type WhereAreYouRickyEvent = CustomEvent<{\n\tid: string\n\tcallerID: number\n}>\n\nexport const WhereAreYouRicky = 'whereAreYouRicky'\n\nexport type HereMortyEvent = CustomEvent<{\n\tcomponent: SchmancyTeleportation\n}>\n\nexport type FLIP_REQUEST = {\n\tfrom: {\n\t\trect: DOMRect\n\t\telement?: HTMLElement\n\t}\n\tto: {\n\t\trect: DOMRect\n\t\telement: HTMLElement\n\t}\n\tstagger?: number\n\thost: HTMLElement\n}\nexport const HereMorty = 'hereMorty'\n\nclass Teleportation {\n\tactiveTeleportations = new Map<string, DOMRect>()\n\tflipRequests = new Subject<FLIP_REQUEST>()\n\n\tconstructor() {\n\t\tthis.flipRequests\n\t\t\t.pipe(\n\t\t\t\tbufferTime(1),\n\t\t\t\tmap(requests =>\n\t\t\t\t\trequests.map(({ from, to, host }, i) => ({\n\t\t\t\t\t\tfrom,\n\t\t\t\t\t\tto,\n\t\t\t\t\t\thost,\n\t\t\t\t\t\ti,\n\t\t\t\t\t})),\n\t\t\t\t),\n\t\t\t\tconcatMap(requests => zip(requests.map(request => of(this.flip(request))))),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tfind = (component: SchmancyTeleportation) => {\n\t\treturn zip([\n\t\t\tfromEvent<HereMortyEvent>(window, HereMorty).pipe(\n\t\t\t\tfilter(\n\t\t\t\t\te =>\n\t\t\t\t\t\t!!e.detail.component.uuid &&\n\t\t\t\t\t\t!!component.id &&\n\t\t\t\t\t\te.detail.component.id === component.id &&\n\t\t\t\t\t\te.detail.component.uuid !== component.uuid,\n\t\t\t\t),\n\t\t\t\tmap(e => e.detail.component),\n\t\t\t\ttake(1),\n\t\t\t),\n\t\t\tof(component).pipe(\n\t\t\t\ttap(() => {\n\t\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\t\tnew CustomEvent<WhereAreYouRickyEvent['detail']>(WhereAreYouRicky, {\n\t\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\t\tid: component.id,\n\t\t\t\t\t\t\t\tcallerID: component.uuid,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t}),\n\t\t\t\t\t)\n\t\t\t\t}),\n\t\t\t),\n\t\t]).pipe(\n\t\t\tmap(([component]) => component),\n\t\t\ttimeout(0),\n\t\t)\n\t}\n\n\tflip = (request: {\n\t\tfrom: {\n\t\t\trect: DOMRect\n\t\t}\n\t\tto: {\n\t\t\telement: HTMLElement\n\t\t\trect: DOMRect\n\t\t}\n\t\thost: HTMLElement\n\t\ti: number\n\t}) => {\n\t\tconst { from, to } = request\n\n\t\t// Prepare the element for animation\n\t\tconst originalZIndex = to.element.style.zIndex\n\t\tto.element.style.transformOrigin = 'top left'\n\t\tto.element.style.setProperty('visibility', 'visible')\n\t\tto.element.style.zIndex = '1000'\n\n\t\t// \"onBegin\" logic goes here (since Web Animations doesn't have onBegin).\n\t\t// If you had more logic, place it here:\n\t\t// e.g., console.log('Starting FLIP animation...');\n\n\t\t// Calculate starting and ending transforms\n\t\tconst startX = from.rect.left - to.rect.left\n\t\tconst startY = from.rect.top - to.rect.top\n\t\tconst startScaleX = from.rect.width / to.rect.width\n\t\tconst startScaleY = from.rect.height / to.rect.height\n\n\t\t// Create keyframes\n\t\tconst keyframes: Keyframe[] = [\n\t\t\t{\n\t\t\t\ttransform: `translate(${startX}px, ${startY}px) scale(${startScaleX}, ${startScaleY})`,\n\t\t\t},\n\t\t\t{\n\t\t\t\ttransform: 'translate(0, 0) scale(1, 1)',\n\t\t\t},\n\t\t]\n\n\t\t// Use native Web Animations API\n\t\tconst animation = to.element.animate(keyframes, {\n\t\t\tduration: 250,\n\t\t\tdelay: 10, // if desired\n\t\t\t// Approximate 'inOutQuad' via a cubic-bezier easing.\n\t\t\t// You can adjust these values to taste, or use a standard one:\n\t\t\teasing: 'cubic-bezier(0.455, 0.03, 0.515, 0.955)',\n\t\t\t// or simply 'ease-in-out'\n\t\t})\n\n\t\t// \"onComplete\" logic goes here\n\t\tanimation.onfinish = () => {\n\t\t\tto.element.style.zIndex = originalZIndex\n\t\t\tto.element.style.transformOrigin = ''\n\t\t\t// If you have additional cleanup, place it here\n\t\t\t// e.g., console.log('FLIP animation completed!');\n\t\t}\n\t}\n}\n\nexport const teleport = new Teleportation()\nexport default teleport\n","import { Observable, interval } from 'rxjs'\nimport { distinctUntilChanged, map, take } from 'rxjs/operators'\n\n// Function to monitor element's bounding client rect\nexport function watchElementRect(element: Element): Observable<DOMRectReadOnly> {\n\treturn interval(50).pipe(\n\t\t// startWith(true),\n\t\tmap(() => element.getBoundingClientRect()),\n\t\tdistinctUntilChanged(\n\t\t\t(prev, curr) =>\n\t\t\t\tprev.width === curr.width &&\n\t\t\t\tprev.height === curr.height &&\n\t\t\t\tprev.top === curr.top &&\n\t\t\t\tprev.right === curr.right &&\n\t\t\t\tprev.bottom === curr.bottom &&\n\t\t\t\tprev.left === curr.left,\n\t\t),\n\t\ttake(1),\n\t)\n}\n","import { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { filter, fromEvent, merge, of, takeUntil, tap, throwIfEmpty } from 'rxjs'\nimport { FINDING_MORTIES, FINDING_MORTIES_EVENT, HERE_RICKY, HERE_RICKY_EVENT } from '..'\nimport {\n\tHereMorty,\n\tHereMortyEvent,\n\tWhereAreYouRicky,\n\tWhereAreYouRickyEvent,\n\tdefault as teleport,\n\tdefault as teleportationService,\n} from './teleport.service'\nimport { watchElementRect } from './watcher'\nimport { $LitElement } from '@mixins/index'\n@customElement('schmancy-teleport')\nexport class SchmancyTeleportation extends $LitElement(css``) {\n\t/**\n\t * @attr {string} uuid - The component tag to teleport\n\t * @readonly\n\t */\n\t@property({ type: Number, reflect: true }) uuid = Math.floor(Math.random() * Date.now())\n\n\t/**\n\t * @attr {string} id - The component tag to teleport\n\t * @required\n\t */\n\t@property({ type: String }) id!: string\n\n\t@property({ type: Number }) delay = 0\n\n\tdebugging = import.meta.env.DEV ? true : false\n\n\tget _slottedChildren() {\n\t\tconst slot = this.shadowRoot.querySelector('slot')\n\t\treturn slot.assignedElements({ flatten: true })\n\t}\n\n\tconnectedCallback(): void {\n\t\tif (this.id === undefined) throw new Error('id is required')\n\t\tsuper.connectedCallback()\n\t\tmerge(\n\t\t\tfromEvent<FINDING_MORTIES_EVENT>(window, FINDING_MORTIES).pipe(\n\t\t\t\ttap({\n\t\t\t\t\tnext: () => {\n\t\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\t\tnew CustomEvent<HERE_RICKY_EVENT['detail']>(HERE_RICKY, {\n\t\t\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\t\t\tcomponent: this,\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t)\n\t\t\t\t\t},\n\t\t\t\t}),\n\t\t\t),\n\t\t\tfromEvent<WhereAreYouRickyEvent>(window, WhereAreYouRicky).pipe(\n\t\t\t\ttap({\n\t\t\t\t\tnext: e => {\n\t\t\t\t\t\tif (e.detail.id === this.id && this.uuid && e.detail.callerID !== this.uuid) {\n\t\t\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\t\t\tnew CustomEvent<HereMortyEvent['detail']>(HereMorty, {\n\t\t\t\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\t\t\t\tcomponent: this,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t}\n\t\t\t\t\t},\n\t\t\t\t}),\n\t\t\t),\n\t\t)\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe()\n\t}\n\n\tasync firstUpdated() {\n\t\tof(teleportationService.activeTeleportations.get(this.id))\n\t\t\t.pipe(\n\t\t\t\tfilter(a => !!a),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t\tthrowIfEmpty(),\n\t\t\t)\n\t\t\t.subscribe({\n\t\t\t\tnext: domRect => {\n\t\t\t\t\tconsole.count('teleport')\n\t\t\t\t\tthis.style.setProperty('visibility', 'hidden')\n\t\t\t\t\t// teleport.flipRequests.next({ from: component, to: this, stagger: 0 })\n\t\t\t\t\twatchElementRect(this)\n\t\t\t\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t\t\t\t.subscribe({\n\t\t\t\t\t\t\tnext: e => {\n\t\t\t\t\t\t\t\t// console.log(e)\n\t\t\t\t\t\t\t\tteleportationService.activeTeleportations.set(this.id, e)\n\t\t\t\t\t\t\t\tteleport.flipRequests.next({\n\t\t\t\t\t\t\t\t\tfrom: {\n\t\t\t\t\t\t\t\t\t\trect: domRect,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\tto: {\n\t\t\t\t\t\t\t\t\t\trect: e,\n\t\t\t\t\t\t\t\t\t\telement: this._slottedChildren[0] as HTMLElement,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\thost: this,\n\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t})\n\t\t\t\t},\n\t\t\t\terror: () => {\n\t\t\t\t\tthis.style.setProperty('visibility', 'visible')\n\t\t\t\t\twatchElementRect(this)\n\t\t\t\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t\t\t\t.subscribe({\n\t\t\t\t\t\t\tnext: e => {\n\t\t\t\t\t\t\t\tconsole.log(e)\n\t\t\t\t\t\t\t\tteleportationService.activeTeleportations.set(this.id, e)\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t})\n\t\t\t\t},\n\t\t\t\tcomplete: () => {},\n\t\t\t})\n\t}\n\n\trender() {\n\t\treturn html`<slot></slot>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-teleport': SchmancyTeleportation\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { html } from 'lit'\nimport { customElement, query } from 'lit/decorators.js'\nimport { $newSchmancyTheme } from '..'\n\n@customElement('schmancy-theme-button')\nexport default class SchmancyThemeButton extends TailwindElement() {\n\t@query('#color') color!: HTMLElement\n\n\tprotected render(): unknown {\n\t\treturn html`\n\t\t\t<schmancy-button\n\t\t\t\t@click=${() => {\n\t\t\t\t\t// Trigger any other effects you have\n\t\t\t\t\t$newSchmancyTheme.next(undefined)\n\n\t\t\t\t\t// Native Web Animations API usage:\n\t\t\t\t\tthis.color.animate([{ transform: 'rotate(0deg)' }, { transform: 'rotate(360deg)' }], {\n\t\t\t\t\t\tduration: 300,\n\t\t\t\t\t\t// fill: 'forwards', // Use if you want it to remain rotated at 360°\n\t\t\t\t\t\t// easing: 'ease-out', // Or another easing function\n\t\t\t\t\t})\n\t\t\t\t}}\n\t\t\t\tvariant=\"text\"\n\t\t\t>\n\t\t\t\t<schmancy-icon id=\"color\">palette</schmancy-icon>\n\t\t\t</schmancy-button>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-theme-button': SchmancyThemeButton\n\t}\n}\n"],"names":["SchmancyCardMedia","TailwindElement","css","html","customElement","SchmancyCard","super","arguments","this","type","elevation","classes","includes","classMap","__decorateClass","property","prototype","Number","SchmancyCardContent","onSurface","SchmancyTheme","sys","color","surface","on","onSurfaceVariant","onVariant","src","fit","styleMap","height","String","reflect","schmancyContentDrawer","$drawer","Subject","pipe","subscribe","data","action","ref","dispatchEvent","CustomEvent","SchmancyEvents","ContentDrawerToggle","detail","state","bubbles","composed","component","title","next","t","SchmancyContentDrawerSheetMode","createContext","SchmancyContentDrawerSheetState","SchmancyContentDrawerID","n","Math","floor","random","Date","now","toString","SchmancyContentDrawerMaxHeight","SchmancyContentDrawerMinWidth","SchmancyContentDrawer","$LitElement","constructor","minWidth","main","sheet","schmancyContentDrawerID","maxHeight","merge","fromEvent","window","ContentDrawerResize","startWith","tap","map","clientWidth","innerWidth","width","debounceTime","innerHeight","getOffsetTop","style","setProperty","distinctUntilChanged","takeUntil","disconnecting","lgScreen","mode","open","event","stopPropagation","area","push","historyStrategy","uid","element","offsetTop","offsetParent","render","nothing","provide","context","queryAssignedElements","flatten","SchmancyContentDrawerMain","connectedCallback","drawerMinWidth","changedProperties","update","has","styles","when","consume","SchmancyContentDrawerSheet","updated","closeAll","dismiss","position","display","animate","opacity","transform","duration","easing","from","closeModalSheet","closeSheet","of","Observable","observer","onfinish","complete","sheetClasses","block","query","slot","SchmancyListItem","selected","leading","forEach","img","classList","add","imgClasses","trailing","rounded","stateLayerClasses","readonly","SchmancySurfaceTypeContext","Boolean","SchmancyListTypeContext","List","schmancyNavDrawer","NavDrawer_toggle","self","SchmancyDrawerNavbarMode","SchmancyDrawerNavbarState","SchmancyDrawerAppbar","toggler","sidebarToggler","sidebarMode","hidden","sidebarOpen","SchmancyNavigationDrawerContent","e","parentElement","SchmancyNavigationDrawer","fullscreen","breakpoint","target","fullHeight","attribute","SchmancyNavigationDrawerSidebar","closeOverlay","openOverlay","overlay","fill","sidebarClasses","bgColor","container","scrim","WhereAreYouRicky","HereMorty","teleport","activeTeleportations","Map","flipRequests","find","zip","filter","uuid","id","take","callerID","timeout","flip","request","to","originalZIndex","zIndex","transformOrigin","keyframes","rect","left","top","delay","bufferTime","requests","host","i","concatMap","watchElementRect","interval","getBoundingClientRect","prev","curr","right","bottom","SchmancyTeleportation","debugging","shadowRoot","querySelector","assignedElements","Error","FINDING_MORTIES","HERE_RICKY","teleportationService","get","a","throwIfEmpty","domRect","set","_slottedChildren","error","SchmancyThemeButton","$newSchmancyTheme"],"mappings":"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"}
|
package/dist/theme-button.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";require("./theme-button-
|
|
1
|
+
"use strict";require("./theme-button-lS8U2Zia.cjs");
|
|
2
2
|
//# sourceMappingURL=theme-button.cjs.map
|
package/dist/theme-button.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import "./theme-button-
|
|
1
|
+
import "./theme-button-BTQaux2v.js";
|
|
2
2
|
//# sourceMappingURL=theme-button.js.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
"use strict";const t=require("rxjs");require("lit/directives/class-map.js"),require("lit/directives/style-map.js");const d=require("./tailwind.mixin-
|
|
1
|
+
"use strict";const t=require("rxjs");require("lit/directives/class-map.js"),require("lit/directives/style-map.js");const d=require("./tailwind.mixin-Dts5Uk3L.cjs"),p=require("lit"),c=require("lit/decorators.js");var u=Object.defineProperty,g=Object.getOwnPropertyDescriptor,l=(n,r,o,i)=>{for(var s,e=i>1?void 0:i?g(r,o):r,a=n.length-1;a>=0;a--)(s=n[a])&&(e=(i?s(r,o,e):s(e))||e);return i&&e&&u(r,o,e),e};exports.SchmancyTree=class extends d.TailwindElement(p.css`
|
|
2
2
|
:host {
|
|
3
3
|
display: block;
|
|
4
4
|
position: relative;
|
|
@@ -24,4 +24,4 @@
|
|
|
24
24
|
<!-- The default slot: tree children -->
|
|
25
25
|
<slot></slot>
|
|
26
26
|
`}},l([c.property({type:Boolean})],exports.SchmancyTree.prototype,"open",2),l([c.query("#toggler")],exports.SchmancyTree.prototype,"toggler",2),l([c.query('slot:not([name="root"])')],exports.SchmancyTree.prototype,"defaultSlot",2),l([c.query("#chevron")],exports.SchmancyTree.prototype,"chevron",2),exports.SchmancyTree=l([c.customElement("schmancy-tree")],exports.SchmancyTree);
|
|
27
|
-
//# sourceMappingURL=tree-
|
|
27
|
+
//# sourceMappingURL=tree-BxpWT4HG.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tree-
|
|
1
|
+
{"version":3,"file":"tree-BxpWT4HG.cjs","sources":["../src/tree/tree.ts"],"sourcesContent":["import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\nimport { fromEvent, merge, switchMap, takeUntil, tap, zip } from 'rxjs'\n\n/**\n * @element schmancy-tree\n * @slot root - The root element of the tree\n * @slot - The children of the tree\n */\n@customElement('schmancy-tree')\nexport class SchmancyTree extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tposition: relative;\n\t\tbackground-color: initial;\n\t}\n\t::slotted([slot='root']) {\n\t\twidth: 100%;\n\t\ttext-align: left;\n\t}\n\t::slotted([slot='root'] + *) {\n\t\tmargin-top: 0.5rem;\n\t}\n`) {\n\t/**\n\t * Whether the tree’s children are visible\n\t */\n\t@property({ type: Boolean }) open = false\n\n\t@query('#toggler') toggler!: HTMLSlotElement\n\t@query('slot:not([name=\"root\"])') defaultSlot!: HTMLSlotElement\n\n\t// Since it's actually a <schmancy-button>, use HTMLElement or a custom type\n\t@query('#chevron') chevron!: HTMLElement\n\n\tfirstUpdated() {\n\t\t// Hide or show the slot initially based on `open`\n\t\tif (!this.open) {\n\t\t\tthis.defaultSlot.hidden = true\n\t\t}\n\n\t\t// Root toggler\n\t\tconst toggleClick$ = fromEvent<MouseEvent>(this.toggler, 'click').pipe(\n\t\t\ttakeUntil(this.disconnecting),\n\t\t\ttap(e => {\n\t\t\t\te.preventDefault()\n\t\t\t\te.stopPropagation()\n\t\t\t\tthis.dispatchEvent(new CustomEvent('toggle', { bubbles: true, composed: true }))\n\t\t\t}),\n\t\t)\n\n\t\t// Chevron (the schmancy-button) click\n\t\tconst chevronClick$ = fromEvent<MouseEvent>(this.chevron, 'click')\n\n\t\tmerge(toggleClick$, chevronClick$)\n\t\t\t.pipe(\n\t\t\t\tswitchMap(() => {\n\t\t\t\t\t// 1. Animate the chevron rotation\n\t\t\t\t\t// If `open` is true, rotate from 180 -> 0; if false, from 0 -> 180\n\t\t\t\t\tconst fromDeg = this.open ? 180 : 0\n\t\t\t\t\tconst toDeg = this.open ? 0 : 180\n\t\t\t\t\tconst chevronAnimation = this.chevron.animate(\n\t\t\t\t\t\t[{ transform: `rotate(${fromDeg}deg)` }, { transform: `rotate(${toDeg}deg)` }],\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tduration: 150,\n\t\t\t\t\t\t\teasing: 'ease-in',\n\t\t\t\t\t\t\tfill: 'forwards',\n\t\t\t\t\t\t},\n\t\t\t\t\t)\n\n\t\t\t\t\t// 2. Animate the slot’s height + opacity\n\t\t\t\t\tif (!this.open) {\n\t\t\t\t\t\t// We are about to open, so remove `hidden` to measure scrollHeight\n\t\t\t\t\t\tthis.defaultSlot.hidden = false\n\t\t\t\t\t}\n\n\t\t\t\t\tconst fromOpacity = this.open ? 1 : 0\n\t\t\t\t\tconst toOpacity = this.open ? 0 : 1\n\n\t\t\t\t\tconst slotAnimation = this.defaultSlot.animate([{ opacity: fromOpacity }, { opacity: toOpacity }], {\n\t\t\t\t\t\tduration: 150,\n\t\t\t\t\t\teasing: 'ease-out',\n\t\t\t\t\t\tfill: 'forwards',\n\t\t\t\t\t})\n\n\t\t\t\t\t// Hide the slot if we just closed it\n\t\t\t\t\tslotAnimation.onfinish = () => {\n\t\t\t\t\t\tif (this.open) {\n\t\t\t\t\t\t\tthis.defaultSlot.hidden = true\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tthis.defaultSlot.style.height = 'auto'\n\t\t\t\t\t\t\tthis.defaultSlot.style.opacity = '1'\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Return an Observable that completes when both animations finish\n\t\t\t\t\treturn zip(fromEvent(chevronAnimation, 'finish'), fromEvent(slotAnimation, 'finish')).pipe(\n\t\t\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t\t\t)\n\t\t\t\t}),\n\t\t\t\ttap(() => {\n\t\t\t\t\t// Flip the open state\n\t\t\t\t\tthis.open = !this.open\n\t\t\t\t}),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<div class=\"flex content-center items-center justify-between\">\n\t\t\t\t<!-- Root toggler content -->\n\t\t\t\t<slot id=\"toggler\" name=\"root\"></slot>\n\n\t\t\t\t<!-- The chevron or arrow symbol -->\n\t\t\t\t<!-- Stop propagation on the schmancy-button itself just to avoid double triggers -->\n\t\t\t\t<schmancy-button slot=\"trailing\" id=\"chevron\" @click=${(e: Event) => e.stopPropagation()}> ⌅ </schmancy-button>\n\t\t\t</div>\n\n\t\t\t<!-- The default slot: tree children -->\n\t\t\t<slot></slot>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-tree': SchmancyTree\n\t}\n}\n"],"names":["SchmancyTree","TailwindElement","css","super","arguments","this","open","firstUpdated","defaultSlot","hidden","toggleClick$","fromEvent","toggler","pipe","takeUntil","disconnecting","tap","e","preventDefault","stopPropagation","dispatchEvent","CustomEvent","bubbles","composed","chevronClick$","chevron","merge","switchMap","fromDeg","toDeg","chevronAnimation","animate","transform","duration","easing","fill","fromOpacity","toOpacity","slotAnimation","opacity","onfinish","style","height","zip","subscribe","html","__decorateClass","property","type","Boolean","prototype","query","customElement"],"mappings":"oZAWaA,QAAAA,aAAN,cAA2BC,EAAAA,gBAAgBC,EAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,CAA3C,CAAA,CAAA,cAAAC,MAAAC,GAAAA,SAAAA,EAiB8BC,KAAAC,KAAA,EAAA,CAQpC,cAAAC,CAEMF,KAAKC,OACTD,KAAKG,YAAYC,OAAS,IAI3B,MAAMC,EAAeC,EAAAA,UAAsBN,KAAKO,QAAS,OAASC,EAAAA,KACjEC,EAAAA,UAAUT,KAAKU,eACfC,MAASC,IACRA,EAAEC,eAAAA,EACFD,EAAEE,gBACGd,EAAAA,KAAAe,cAAc,IAAIC,YAAY,SAAU,CAAEC,QAAAA,GAAeC,SAAU,EAAA,CAAA,CAAA,CAAO,CAK3EC,CAAAA,EAAAA,EAAgBb,EAAAA,UAAsBN,KAAKoB,QAAS,OAEpDC,EAAAA,QAAAhB,EAAcc,CAAAA,EAClBX,KACAc,EAAAA,UAAU,KAGH,MAAAC,EAAUvB,KAAKC,KAAO,IAAM,EAC5BuB,EAAQxB,KAAKC,KAAO,EAAI,IACxBwB,EAAmBzB,KAAKoB,QAAQM,QACrC,CAAC,CAAEC,UAAW,UAAUJ,SAAiB,CAAEI,UAAW,UAAUH,CAChE,MAAA,CAAA,EAAA,CACCI,SAAU,IACVC,OAAQ,UACRC,KAAM,UAAA,CAAA,EAKH9B,KAAKC,OAETD,KAAKG,YAAYC,OAAAA,IAGZ,MAAA2B,EAAc/B,KAAKC,KAAO,EAAI,EAC9B+B,EAAYhC,KAAKC,KAAO,EAAI,EAE5BgC,EAAgBjC,KAAKG,YAAYuB,QAAQ,CAAC,CAAEQ,QAASH,CAAAA,EAAe,CAAEG,QAASF,CAAAA,CAAAA,EAAc,CAClGJ,SAAU,IACVC,OAAQ,WACRC,KAAM,aAcA,OAVPG,EAAcE,SAAW,IACpBnC,CAAAA,KAAKC,KACRD,KAAKG,YAAYC,WAEZJ,KAAAG,YAAYiC,MAAMC,OAAS,OAC3BrC,KAAAG,YAAYiC,MAAMF,QAAU,IAAA,EAK5BI,EAAAA,IAAIhC,YAAUmB,EAAkB,QAAWnB,EAAAA,EAAAA,UAAU2B,EAAe,QAAA,CAAA,EAAWzB,KACrFC,EAAAA,UAAUT,KAAKU,aAAAA,CAAAA,CAChB,GAEDC,EAAAA,IAAI,KAEEX,KAAAC,KAAAA,CAAQD,KAAKC,IAAA,CAAA,EAEnBQ,EAAAA,UAAUT,KAAKU,gBAEf6B,UAAU,CAAA,CAGb,QACQ,CAAA,OAAAC,EAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,2DAOmD5B,GAAaA,EAAEE,gBAAAA,CAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,GAAiB,CA1F9D2B,EAAAA,EAAA,CAA5BC,WAAS,CAAEC,KAAMC,OAAAA,CAAAA,CAAAA,EAjBNjD,qBAiBiBkD,UAAA,OAAA,GAEVJ,EAAA,CAAlBK,EAAAA,MAAM,UAAA,CAAA,EAnBKnD,qBAmBOkD,UAAA,UAAA,CAAA,EACeJ,EAAA,CAAjCK,EAAAA,MAAM,yBAAA,CAAA,EApBKnD,qBAoBsBkD,UAAA,cAAA,CAGfJ,EAAAA,EAAA,CAAlBK,EAAAA,MAAM,UAAA,CAAA,EAvBKnD,qBAuBOkD,UAAA,UAAA,CAAA,EAvBPlD,QAANA,aAAA8C,EAAA,CADNM,EAAAA,cAAc,eAAA,CAAA,EACFpD"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { fromEvent as p, takeUntil as c, tap as g, merge as m, switchMap as f, zip as u } from "rxjs";
|
|
2
2
|
import "lit/directives/class-map.js";
|
|
3
3
|
import "lit/directives/style-map.js";
|
|
4
|
-
import { T as y } from "./tailwind.mixin-
|
|
4
|
+
import { T as y } from "./tailwind.mixin-D6m-sJmB.js";
|
|
5
5
|
import { css as v, html as b } from "lit";
|
|
6
6
|
import { property as S, query as h, customElement as w } from "lit/decorators.js";
|
|
7
7
|
var k = Object.defineProperty, j = Object.getOwnPropertyDescriptor, l = (e, s, o, i) => {
|
|
@@ -61,4 +61,4 @@ l([S({ type: Boolean })], n.prototype, "open", 2), l([h("#toggler")], n.prototyp
|
|
|
61
61
|
export {
|
|
62
62
|
n as S
|
|
63
63
|
};
|
|
64
|
-
//# sourceMappingURL=tree-
|
|
64
|
+
//# sourceMappingURL=tree-F8M_QD0f.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tree-
|
|
1
|
+
{"version":3,"file":"tree-F8M_QD0f.js","sources":["../src/tree/tree.ts"],"sourcesContent":["import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\nimport { fromEvent, merge, switchMap, takeUntil, tap, zip } from 'rxjs'\n\n/**\n * @element schmancy-tree\n * @slot root - The root element of the tree\n * @slot - The children of the tree\n */\n@customElement('schmancy-tree')\nexport class SchmancyTree extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tposition: relative;\n\t\tbackground-color: initial;\n\t}\n\t::slotted([slot='root']) {\n\t\twidth: 100%;\n\t\ttext-align: left;\n\t}\n\t::slotted([slot='root'] + *) {\n\t\tmargin-top: 0.5rem;\n\t}\n`) {\n\t/**\n\t * Whether the tree’s children are visible\n\t */\n\t@property({ type: Boolean }) open = false\n\n\t@query('#toggler') toggler!: HTMLSlotElement\n\t@query('slot:not([name=\"root\"])') defaultSlot!: HTMLSlotElement\n\n\t// Since it's actually a <schmancy-button>, use HTMLElement or a custom type\n\t@query('#chevron') chevron!: HTMLElement\n\n\tfirstUpdated() {\n\t\t// Hide or show the slot initially based on `open`\n\t\tif (!this.open) {\n\t\t\tthis.defaultSlot.hidden = true\n\t\t}\n\n\t\t// Root toggler\n\t\tconst toggleClick$ = fromEvent<MouseEvent>(this.toggler, 'click').pipe(\n\t\t\ttakeUntil(this.disconnecting),\n\t\t\ttap(e => {\n\t\t\t\te.preventDefault()\n\t\t\t\te.stopPropagation()\n\t\t\t\tthis.dispatchEvent(new CustomEvent('toggle', { bubbles: true, composed: true }))\n\t\t\t}),\n\t\t)\n\n\t\t// Chevron (the schmancy-button) click\n\t\tconst chevronClick$ = fromEvent<MouseEvent>(this.chevron, 'click')\n\n\t\tmerge(toggleClick$, chevronClick$)\n\t\t\t.pipe(\n\t\t\t\tswitchMap(() => {\n\t\t\t\t\t// 1. Animate the chevron rotation\n\t\t\t\t\t// If `open` is true, rotate from 180 -> 0; if false, from 0 -> 180\n\t\t\t\t\tconst fromDeg = this.open ? 180 : 0\n\t\t\t\t\tconst toDeg = this.open ? 0 : 180\n\t\t\t\t\tconst chevronAnimation = this.chevron.animate(\n\t\t\t\t\t\t[{ transform: `rotate(${fromDeg}deg)` }, { transform: `rotate(${toDeg}deg)` }],\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tduration: 150,\n\t\t\t\t\t\t\teasing: 'ease-in',\n\t\t\t\t\t\t\tfill: 'forwards',\n\t\t\t\t\t\t},\n\t\t\t\t\t)\n\n\t\t\t\t\t// 2. Animate the slot’s height + opacity\n\t\t\t\t\tif (!this.open) {\n\t\t\t\t\t\t// We are about to open, so remove `hidden` to measure scrollHeight\n\t\t\t\t\t\tthis.defaultSlot.hidden = false\n\t\t\t\t\t}\n\n\t\t\t\t\tconst fromOpacity = this.open ? 1 : 0\n\t\t\t\t\tconst toOpacity = this.open ? 0 : 1\n\n\t\t\t\t\tconst slotAnimation = this.defaultSlot.animate([{ opacity: fromOpacity }, { opacity: toOpacity }], {\n\t\t\t\t\t\tduration: 150,\n\t\t\t\t\t\teasing: 'ease-out',\n\t\t\t\t\t\tfill: 'forwards',\n\t\t\t\t\t})\n\n\t\t\t\t\t// Hide the slot if we just closed it\n\t\t\t\t\tslotAnimation.onfinish = () => {\n\t\t\t\t\t\tif (this.open) {\n\t\t\t\t\t\t\tthis.defaultSlot.hidden = true\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tthis.defaultSlot.style.height = 'auto'\n\t\t\t\t\t\t\tthis.defaultSlot.style.opacity = '1'\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Return an Observable that completes when both animations finish\n\t\t\t\t\treturn zip(fromEvent(chevronAnimation, 'finish'), fromEvent(slotAnimation, 'finish')).pipe(\n\t\t\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t\t\t)\n\t\t\t\t}),\n\t\t\t\ttap(() => {\n\t\t\t\t\t// Flip the open state\n\t\t\t\t\tthis.open = !this.open\n\t\t\t\t}),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<div class=\"flex content-center items-center justify-between\">\n\t\t\t\t<!-- Root toggler content -->\n\t\t\t\t<slot id=\"toggler\" name=\"root\"></slot>\n\n\t\t\t\t<!-- The chevron or arrow symbol -->\n\t\t\t\t<!-- Stop propagation on the schmancy-button itself just to avoid double triggers -->\n\t\t\t\t<schmancy-button slot=\"trailing\" id=\"chevron\" @click=${(e: Event) => e.stopPropagation()}> ⌅ </schmancy-button>\n\t\t\t</div>\n\n\t\t\t<!-- The default slot: tree children -->\n\t\t\t<slot></slot>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-tree': SchmancyTree\n\t}\n}\n"],"names":["SchmancyTree","TailwindElement","css","super","arguments","this","open","defaultSlot","hidden","toggleClick$","fromEvent","toggler","pipe","takeUntil","disconnecting","tap","e","preventDefault","stopPropagation","dispatchEvent","CustomEvent","bubbles","composed","chevronClick$","chevron","merge","switchMap","fromDeg","toDeg","chevronAnimation","animate","transform","duration","easing","fill","fromOpacity","toOpacity","slotAnimation","opacity","onfinish","style","height","zip","subscribe","render","html","__decorateClass","property","type","Boolean","prototype","query","customElement"],"mappings":";;;;;;;;;;AAWa,IAAAA,IAAN,cAA2BC,EAAgBC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,CAA3C,EAAA;AAAA,EAAA;AAAAC,UAAAC,GAAAA,SAAAA,GAiB8BC,KAAAC,OAAAA;AAAAA,EAAA;AAAA,EAQpC,eAEMD;AAAAA,SAAKC,SACTD,KAAKE,YAAYC;AAIlB,UAAMC,IAAeC,EAAsBL,KAAKM,SAAS,OAAA,EAASC,KACjEC,EAAUR,KAAKS,aACfC,GAAAA,EAASC,CAAAA;AACRA,MAAAA,EAAEC,eAAAA,GACFD,EAAEE,gBAAAA,GACGb,KAAAc,cAAc,IAAIC,YAAY,UAAU,EAAEC,aAAeC,UAAAA,GAAiB,CAAA,CAAA;AAAA,IAAA,CAAA,CAAA,GAK3EC,IAAgBb,EAAsBL,KAAKmB,SAAS,OAAA;AAEpDC,IAAAA,EAAAhB,GAAcc,CAAAA,EAClBX,KACAc,EAAU;AAGH,YAAAC,IAAUtB,KAAKC,OAAO,MAAM,GAC5BsB,IAAQvB,KAAKC,OAAO,IAAI,KACxBuB,IAAmBxB,KAAKmB,QAAQM,QACrC,CAAC,EAAEC,WAAW,UAAUJ,CAAiB,OAAA,GAAA,EAAEI,WAAW,UAAUH,CAAAA,OAAAA,CAAAA,GAChE,EACCI,UAAU,KACVC,QAAQ,WACRC,MAAM,WAKH7B,CAAAA;AAAAA,WAAKC,SAETD,KAAKE,YAAYC,SAAS;AAGrB,YAAA2B,IAAc9B,KAAKC,OAAO,IAAI,GAC9B8B,IAAY/B,KAAKC,OAAO,IAAI,GAE5B+B,IAAgBhC,KAAKE,YAAYuB,QAAQ,CAAC,EAAEQ,SAASH,EAAAA,GAAe,EAAEG,SAASF,EAAAA,CAAAA,GAAc,EAClGJ,UAAU,KACVC,QAAQ,YACRC,MAAM,WAcA,CAAA;AAAA,aAVPG,EAAcE,WAAW,MAAA;AACpBlC,aAAKC,OACRD,KAAKE,YAAYC,SAAAA,MAEZH,KAAAE,YAAYiC,MAAMC,SAAS,QAC3BpC,KAAAE,YAAYiC,MAAMF,UAAU;AAAA,MAAA,GAK5BI,EAAIhC,EAAUmB,GAAkB,QAAA,GAAWnB,EAAU2B,GAAe,QAAA,CAAA,EAAWzB,KACrFC,EAAUR,KAAKS,aAChB,CAAA;AAAA,IAAA,CAAA,GAEDC,EAAI,MAEEV;AAAAA,WAAAC,QAAQD,KAAKC;AAAAA,IAAA,CAEnBO,GAAAA,EAAUR,KAAKS,aAEf6B,CAAAA,EAAAA,UAAAA;AAAAA,EAAU;AAAA,EAGb,SAAAC;AACQ,WAAAC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,2DAOmD7B,CAAAA,MAAaA,EAAEE,gBAAAA,CAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,EAAiB;AAAA;AA1F9D4B,EAAA,CAA5BC,EAAS,EAAEC,MAAMC,aAjBNjD,EAiBiBkD,WAAA,QAAA,CAAA,GAEVJ,EAAA,CAAlBK,EAAM,cAnBKnD,EAmBOkD,WAAA,WAAA,CACeJ,GAAAA,EAAA,CAAjCK,EAAM,6BApBKnD,EAoBsBkD,WAAA,eAAA,CAGfJ,GAAAA,EAAA,CAAlBK,EAAM,UAAA,CAAA,GAvBKnD,EAuBOkD,WAAA,WAAA,CAvBPlD,GAAAA,IAAN8C,EAAA,CADNM,EAAc,mBACFpD;"}
|
package/dist/tree.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./tree-
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./tree-BxpWT4HG.cjs");Object.defineProperty(exports,"SchmancyTree",{enumerable:!0,get:()=>e.SchmancyTree});
|
|
2
2
|
//# sourceMappingURL=tree.cjs.map
|
package/dist/tree.js
CHANGED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";var qe=Object.defineProperty;var se=s=>{throw TypeError(s)};var Ne=(s,e,t)=>e in s?qe(s,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):s[e]=t;var m=(s,e,t)=>Ne(s,typeof e!="symbol"?e+"":e,t),ie=(s,e,t)=>e.has(s)||se("Cannot "+t);var d=(s,e,t)=>(ie(s,e,"read from private field"),t?t.call(s):e.get(s)),j=(s,e,t)=>e.has(s)?se("Cannot add the same private member more than once"):e instanceof WeakSet?e.add(s):e.set(s,t);var a=(s,e,t)=>(ie(s,e,"access private method"),t);const Le=require("./consume-Di0U0iBU.cjs");require("rxjs"),require("lit/directives/class-map.js"),require("lit/directives/style-map.js");const xe=require("./litElement.mixin-dosTHO0i.cjs");require("./tailwind.mixin-Dts5Uk3L.cjs");const re=require("./delay-CqrzARsM.cjs"),De=require("./intersection-CVvaDv96.cjs"),ne=require("lit"),f=require("lit/decorators.js"),ye=s=>Array.isArray(s),oe=s=>ye(s)?s:[s],me="data-typeit-id",E="ti-cursor",Me={started:!1,completed:!1,frozen:!1,destroyed:!1},C={breakLines:!0,cursor:{autoPause:!0,autoPauseDelay:500,animation:{frames:[0,0,1].map(s=>({opacity:s})),options:{iterations:1/0,easing:"steps(2, start)",fill:"forwards"}}},cursorChar:"|",cursorSpeed:1e3,deleteSpeed:null,html:!0,lifeLike:!0,loop:!1,loopDelay:750,nextStringDelay:750,speed:100,startDelay:250,startDelete:!1,strings:[],waitUntilVisible:!1,beforeString:()=>{},afterString:()=>{},beforeStep:()=>{},afterStep:()=>{},afterComplete:()=>{}},ke=`[${me}]:before {content: '.'; display: inline-block; width: 0; visibility: hidden;}`,$=s=>document.createElement(s),G=s=>document.createTextNode(s),ae=(s,e="")=>{let t=$("style");t.id=e,t.appendChild(G(s)),document.head.appendChild(t)},le=s=>(ye(s)||(s=[s/2,s/2]),s),ue=(s,e)=>Math.abs(Math.random()*(s+e-(s-e))+(s-e));let he=s=>s/2;const fe=s=>Array.from(s);let Y=s=>([...s.childNodes].forEach(e=>{if(e.nodeValue)return[...e.nodeValue].forEach(t=>{e.parentNode.insertBefore(G(t),e)}),void e.remove();Y(e)}),s);const ge=s=>{let e=document.implementation.createHTMLDocument();return e.body.innerHTML=s,Y(e.body)};function be(s,e=!1,t=!1){let r,n=s.querySelector(`.${E}`),o=document.createTreeWalker(s,NodeFilter.SHOW_ALL,{acceptNode:u=>{var h,p;if(n&&t){if((h=u.classList)!=null&&h.contains(E))return NodeFilter.FILTER_ACCEPT;if(n.contains(u))return NodeFilter.FILTER_REJECT}return(p=u.classList)!=null&&p.contains(E)?NodeFilter.FILTER_REJECT:NodeFilter.FILTER_ACCEPT}}),l=[];for(;r=o.nextNode();)r.originalParent||(r.originalParent=r.parentNode),l.push(r);return e?l.reverse():l}function Ae(s,e=!0){return e?be(ge(s)):fe(s).map(G)}const _e=({index:s,newIndex:e,queueItems:t,cleanUp:r})=>{for(let n=s+1;n<e+1;n++)r(t[n][0])},we=s=>Number.isInteger(s),ce=({queueItems:s,selector:e,cursorPosition:t,to:r})=>{if(we(e))return-1*e;let n=new RegExp("END","i").test(r),o=e?[...s].reverse().findIndex(({char:l})=>{let u=l.parentElement,h=u.matches(e);return!(!n||!h)||h&&u.firstChild.isSameNode(l)}):-1;return o<0&&(o=n?0:s.length-1),o-t+(n?0:1)},A=(s,e)=>new Array(e).fill(s);let F=s=>new Promise(e=>{requestAnimationFrame(async()=>{e(await s())})}),pe=s=>s==null?void 0:s.getAnimations().find(e=>e.id===s.dataset.tiAnimationId),Te=({cursor:s,frames:e,options:t})=>{let r=s.animate(e,t);return r.pause(),r.id=s.dataset.tiAnimationId,F(()=>{F(()=>{r.play()})}),r},de=s=>{var e;return(e=s.func)==null?void 0:e.call(null)},$e=async({index:s,queueItems:e,wait:t,cursor:r,cursorOptions:n})=>{let o=e[s][1],l=[],u=s,h=o,p=()=>h&&!h.delay,c=o.shouldPauseCursor()&&n.autoPause;for(;p();)l.push(h),p()&&u++,h=e[u]?e[u][1]:null;if(l.length)return await F(async()=>{for(let P of l)await de(P)}),u-1;let y,b=pe(r);return b&&(y={...b.effect.getComputedTiming(),delay:c?n.autoPauseDelay:0}),await t(async()=>{b&&c&&b.cancel(),await F(()=>{de(o)})},o.delay),await(({cursor:P,options:Z,cursorOptions:ee})=>{if(!P||!ee)return;let B,k=pe(P);k&&(Z.delay=k.effect.getComputedTiming().delay,B=k.currentTime,k.cancel());let te=Te({cursor:P,frames:ee.animation.frames,options:Z});return B&&(te.currentTime=B),te})({cursor:r,options:y,cursorOptions:n}),s};const _=s=>"value"in s;let v=s=>typeof s=="function"?s():s,K=(s,e=document,t=!1)=>e["querySelector"+(t?"All":"")](s);const S=(s,e)=>Object.assign({},s,e);let Oe={"font-family":"","font-weight":"","font-size":"","font-style":"","line-height":"",color:"",transform:"translateX(-.125em)"};var i,Ie,q,Q,Ee,U,V,X,O,w,Ce,N,L,ve,R,Pe,Se,J,H,x,z,I,D,M,W,T;class He{constructor(e,t={}){j(this,i);m(this,"element");m(this,"timeouts");m(this,"cursorPosition");m(this,"predictedCursorPosition");m(this,"statuses",{started:!1,completed:!1,frozen:!1,destroyed:!1,firing:!1});m(this,"opts");m(this,"id");m(this,"queue");m(this,"cursor");m(this,"flushCallback",null);m(this,"unfreeze",()=>{});m(this,"is",function(e){return this.statuses[e]});j(this,R,e=>{this.opts.cursor=(t=>{var r,n;if(typeof t=="object"){let o={},{frames:l,options:u}=C.cursor.animation;return o.animation=t.animation||{},o.animation.frames=((r=t.animation)==null?void 0:r.frames)||l,o.animation.options=S(u,((n=t.animation)==null?void 0:n.options)||{}),o.autoPause=t.autoPause??C.cursor.autoPause,o.autoPauseDelay=t.autoPauseDelay||C.cursor.autoPauseDelay,o}return t===!0?C.cursor:t})(e.cursor??C.cursor),this.opts.strings=a(this,i,Pe).call(this,oe(this.opts.strings)),this.opts=S(this.opts,{html:!d(this,i,M)&&this.opts.html,nextStringDelay:le(this.opts.nextStringDelay),loopDelay:le(this.opts.loopDelay)})});var r;this.opts=S(C,t),this.element=typeof(r=e)=="string"?K(r):r,this.timeouts=[],this.cursorPosition=0,this.unfreeze=()=>{},this.predictedCursorPosition=null,this.statuses=S({},Me),this.id=Math.random().toString().substring(2,9),this.queue=function(n){let o=function(c){return oe(c).forEach(y=>{var b;return p.set(Symbol((b=y.char)==null?void 0:b.innerText),l({...y}))}),this},l=c=>(c.shouldPauseCursor=function(){return!!(this.typeable||this.cursorable||this.deletable)},c),u=()=>p,h=()=>Array.from(p.values()),p=new Map;return o(n),{add:o,set:function(c,y){let b=[...p.keys()];p.set(b[c],l(y))},wipe:function(){p=new Map,o(n)},done:(c,y=!1)=>y?p.delete(c):p.get(c).done=!0,reset:function(){p.forEach(c=>delete c.done)},destroy:c=>p.delete(c),getItems:(c=!1)=>c?h():h().filter(y=>!y.done),getQueue:u,getTypeable:()=>h().filter(c=>c.typeable),getPendingQueueItems:()=>{const c=[];for(let[,y]of u())y.done||c.push(y);return c}}}([{delay:this.opts.startDelay}]),d(this,R).call(this,t),this.cursor=a(this,i,Se).call(this),this.element.dataset.typeitId=this.id,ae(ke),this.opts.strings.length&&a(this,i,ve).call(this)}go(){return this.statuses.started?this:(a(this,i,X).call(this),this.opts.waitUntilVisible?(e=this.element,t=a(this,i,q).bind(this),new IntersectionObserver((r,n)=>{r.forEach(o=>{o.isIntersecting&&(t(),n.unobserve(e))})},{threshold:1}).observe(e),this):(a(this,i,q).call(this),this));var e,t}destroy(e=!0){this.timeouts=(this.timeouts.forEach(clearTimeout),[]),v(e)&&this.cursor&&a(this,i,z).call(this,this.cursor),this.statuses.destroyed=!0}reset(e){!this.is("destroyed")&&this.destroy(),e?(this.queue.wipe(),e(this)):this.queue.reset(),this.cursorPosition=0;for(let t in this.statuses)this.statuses[t]=!1;return this.element[a(this,i,O).call(this)?"value":"innerHTML"]="",this}type(e,t={}){e=v(e);let{instant:r}=t,n=a(this,i,N).call(this,t),o=Ae(e,this.opts.html).map(u=>{return{func:()=>a(this,i,H).call(this,u),char:u,delay:r||(h=u,/<(.+)>(.*?)<\/(.+)>/.test(h.outerHTML))?0:a(this,i,I).call(this),typeable:u.nodeType===Node.TEXT_NODE};var h}),l=[n[0],{func:async()=>await this.opts.beforeString(e,this)},...o,{func:async()=>await this.opts.afterString(e,this)},n[1]];return a(this,i,w).call(this,l,t)}break(e={}){return a(this,i,w).call(this,{func:()=>a(this,i,H).call(this,$("BR")),typeable:!0},e)}move(e,t={}){e=v(e);let r=a(this,i,N).call(this,t),{instant:n,to:o}=t,l=ce({queueItems:this.queue.getTypeable(),selector:e===null?"":e,to:o,cursorPosition:d(this,i,D)}),u=l<0?-1:1;return this.predictedCursorPosition=d(this,i,D)+l,a(this,i,w).call(this,[r[0],...A({func:()=>a(this,i,Q).call(this,u),delay:n?0:a(this,i,I).call(this),cursorable:!0},Math.abs(l)),r[1]],t)}exec(e,t={}){let r=a(this,i,N).call(this,t);return a(this,i,w).call(this,[r[0],{func:()=>e(this)},r[1]],t)}options(e,t={}){return e=v(e),a(this,i,L).call(this,e),a(this,i,w).call(this,{},t)}pause(e,t={}){return a(this,i,w).call(this,{delay:v(e)},t)}delete(e=null,t={}){e=v(e);let r=a(this,i,N).call(this,t),n=e,{instant:o,to:l}=t,u=this.queue.getTypeable(),h=n===null?u.length:we(n)?n:ce({queueItems:u,selector:n,cursorPosition:d(this,i,D),to:l});return a(this,i,w).call(this,[r[0],...A({func:a(this,i,x).bind(this),delay:o?0:a(this,i,I).call(this,1),deletable:!0},h),r[1]],t)}freeze(){this.statuses.frozen=!0}flush(e=null){return this.flushCallback=e||this.flushCallback,this.statuses.firing||(a(this,i,X).call(this),a(this,i,q).call(this,!1).then(()=>{if(this.queue.getPendingQueueItems().length>0)return this.flush();this.flushCallback(),this.flushCallback=null})),this}getQueue(){return this.queue}getOptions(){return this.opts}updateOptions(e){return a(this,i,L).call(this,e)}getElement(){return this.element}empty(e={}){return a(this,i,w).call(this,{func:a(this,i,Ie).bind(this)},e)}}i=new WeakSet,Ie=async function(){a(this,i,O).call(this)?this.element.value="":d(this,i,T).forEach(a(this,i,z).bind(this))},q=async function(e=!0){this.statuses.started=!0,this.statuses.firing=!0;let t=r=>{this.queue.done(r,!e)};try{let r=[...this.queue.getQueue()];for(let o=0;o<r.length;o++){let[l,u]=r[o];if(!u.done){if(!u.deletable||u.deletable&&d(this,i,T).length){let h=await a(this,i,U).call(this,o,r);_e({index:o,newIndex:h,queueItems:r,cleanUp:t}),o=h}t(l)}}if(!e)return this.statuses.firing=!1,this;if(this.statuses.completed=!0,this.statuses.firing=!1,await this.opts.afterComplete(this),!this.opts.loop)throw"";let n=this.opts.loopDelay;a(this,i,V).call(this,async()=>{await a(this,i,Ee).call(this,n[0]),a(this,i,q).call(this)},n[1])}catch{}return this.statuses.firing=!1,this},Q=async function(e){var t,r,n;this.cursorPosition=(t=e,r=this.cursorPosition,n=d(this,i,T),Math.min(Math.max(r+t,0),n.length)),((o,l,u)=>{let h=l[u-1],p=K(`.${E}`,o);(o=(h==null?void 0:h.parentNode)||o).insertBefore(p,h||null)})(this.element,d(this,i,T),this.cursorPosition)},Ee=async function(e){let t=d(this,i,D);t&&await a(this,i,Q).call(this,{value:t});let r=d(this,i,T).map(n=>[Symbol(),{func:a(this,i,x).bind(this),delay:a(this,i,I).call(this,1),deletable:!0,shouldPauseCursor:()=>!0}]);for(let n=0;n<r.length;n++)await a(this,i,U).call(this,n,r);this.queue.reset(),this.queue.set(0,{delay:e})},U=function(e,t){return $e({index:e,queueItems:t,wait:a(this,i,V).bind(this),cursor:this.cursor,cursorOptions:this.opts.cursor})},V=async function(e,t,r=!1){this.statuses.frozen&&await new Promise(n=>{this.unfreeze=()=>{this.statuses.frozen=!1,n()}}),r||await this.opts.beforeStep(this),await((n,o,l)=>new Promise(u=>{l.push(setTimeout(async()=>{await n(),u()},o||0))}))(e,t,this.timeouts),r||await this.opts.afterStep(this)},X=async function(){if(!a(this,i,O).call(this)&&this.cursor&&this.element.appendChild(this.cursor),d(this,i,W)){((n,o)=>{let l=`[${me}='${n}'] .${E}`,u=getComputedStyle(o),h=Object.entries(Oe).reduce((p,[c,y])=>`${p} ${c}: var(--ti-cursor-${c}, ${y||u[c]});`,"");ae(`${l} { display: inline-block; width: 0; ${h} }`,n)})(this.id,this.element),this.cursor.dataset.tiAnimationId=this.id;let{animation:e}=this.opts.cursor,{frames:t,options:r}=e;Te({frames:t,cursor:this.cursor,options:{duration:this.opts.cursorSpeed,...r}})}},O=function(){return _(this.element)},w=function(e,t){return this.queue.add(e),a(this,i,Ce).call(this,t),this},Ce=function(e={}){let t=e.delay;t&&this.queue.add({delay:t})},N=function(e={}){return[{func:()=>a(this,i,L).call(this,e)},{func:()=>a(this,i,L).call(this,this.opts)}]},L=async function(e){this.opts=S(this.opts,e)},ve=function(){let e=this.opts.strings.filter(t=>!!t);e.forEach((t,r)=>{if(this.type(t),r+1===e.length)return;let n=this.opts.breakLines?[{func:()=>a(this,i,H).call(this,$("BR")),typeable:!0}]:A({func:a(this,i,x).bind(this),delay:a(this,i,I).call(this,1)},this.queue.getTypeable().length);a(this,i,J).call(this,n)})},R=new WeakMap,Pe=function(e){let t=this.element.innerHTML;return t?(this.element.innerHTML="",this.opts.startDelete?(this.element.innerHTML=t,Y(this.element),a(this,i,J).call(this,A({func:a(this,i,x).bind(this),delay:a(this,i,I).call(this,1),deletable:!0},d(this,i,T).length)),e):(r=t,r.replace(/<!--(.+?)-->/g,"").trim().split(/<br(?:\s*?)(?:\/)?>/)).concat(e)):e;var r},Se=function(){if(d(this,i,M))return null;let e=$("span");return e.className=E,d(this,i,W)?(e.innerHTML=ge(this.opts.cursorChar).innerHTML,e):(e.style.visibility="hidden",e)},J=function(e){let t=this.opts.nextStringDelay;this.queue.add([{delay:t[0]},...e,{delay:t[1]}])},H=function(e){((t,r)=>{if(_(t))return void(t.value=`${t.value}${r.textContent}`);r.innerHTML="";let n=(o=r.originalParent,/body/i.test(o==null?void 0:o.tagName)?t:r.originalParent||t);var o;let l=K("."+E,n)||null;l&&l.parentElement!==n&&(n=l.parentElement),n.insertBefore(r,l)})(this.element,e)},x=function(){d(this,i,T).length&&(d(this,i,M)?this.element.value=this.element.value.slice(0,-1):a(this,i,z).call(this,d(this,i,T)[this.cursorPosition]))},z=function(e){((t,r)=>{if(!t)return;let n=t.parentNode;(n.childNodes.length>1||n.isSameNode(r)?t:n).remove()})(e,this.element)},I=function(e=0){return function(t){let{speed:r,deleteSpeed:n,lifeLike:o}=t;return n=n!==null?n:r/3,o?[ue(r,he(r)),ue(n,he(n))]:[r,n]}(this.opts)[e]},D=function(){return this.predictedCursorPosition??this.cursorPosition},M=function(){return _(this.element)},W=function(){return!!this.opts.cursor&&!d(this,i,M)},T=function(){return e=this.element,_(e)?fe(e.value):be(e,!0).filter(t=>!(t.childNodes.length>0));var e};var ze=Object.defineProperty,Fe=Object.getOwnPropertyDescriptor,g=(s,e,t,r)=>{for(var n,o=r>1?void 0:r?Fe(e,t):e,l=s.length-1;l>=0;l--)(n=s[l])&&(o=(r?n(e,t,o):n(o))||o);return r&&o&&ze(e,t,o),o};exports.TypewriterElement=class extends xe.$LitElement(ne.css`
|
|
2
|
+
:host {
|
|
3
|
+
display: inherit;
|
|
4
|
+
}
|
|
5
|
+
|
|
6
|
+
#typewriter {
|
|
7
|
+
--ti-cursor-display: initial;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
#typewriter .ti-cursor {
|
|
11
|
+
display: var(--ti-cursor-display);
|
|
12
|
+
}
|
|
13
|
+
`){constructor(){super(...arguments),this.speed=50,this.delay=0,this.autoStart=!0,this.cursorChar="",this.deleteSpeed=25,this.once=!0,this.typeItInstance=null,this.sessionKey=""}disconnectedCallback(){super.disconnectedCallback(),this._destroyTypeIt()}_startTyping(){var e,t,r;if(this._destroyTypeIt(),this.sessionKey=this.generateSessionKey(),this.once&&sessionStorage.getItem(this.sessionKey)==="true")return void((t=(e=this.shadowRoot)==null?void 0:e.querySelector("slot"))==null?void 0:t.removeAttribute("hidden"));if(!this.typewriterContainer)return;const s={speed:this.speed,startDelay:this.delay,cursor:!!this.cursorChar,cursorChar:this.cursorChar,deleteSpeed:this.deleteSpeed,afterComplete:()=>{if(this.once)try{sessionStorage.setItem(this.sessionKey,"true")}catch{}this.dispatchEvent(new CustomEvent("typeit-complete",{bubbles:!0,composed:!0})),this.typewriterContainer.style.setProperty("--ti-cursor-display","none")}};this.typeItInstance=new He(this.typewriterContainer,s),this._getSlottedNodes.forEach(n=>{var o;n.nodeType===Node.TEXT_NODE?(o=this.typeItInstance)==null||o.type(n.textContent||""):n instanceof HTMLElement&&this._processCustomElement(n)}),De.intersection$((r=this.shadowRoot)==null?void 0:r.host).subscribe(()=>{var n;(n=this.typeItInstance)==null||n.go()})}generateSessionKey(){const s=this._getSlottedElements.map(e=>e.outerHTML).join("");return this.once?re.hashContent(s):""}_destroyTypeIt(){if(this.typeItInstance){try{this.typeItInstance.destroy()}catch{}this.typeItInstance=null}}_processCustomElement(s){var r,n,o;const e=s.getAttribute("action"),t=s.getAttribute("value");switch(e){case"pause":(r=this.typeItInstance)==null||r.pause(parseInt(t||"0",10));break;case"delete":(n=this.typeItInstance)==null||n.delete(parseInt(t||"0",10));break;default:s.tagName==="P"&&this.typeItInstance.break(),(o=this.typeItInstance)==null||o.type(s.textContent||"")}}render(){return ne.html`<div id="typewriter" aria-live="polite"></div>
|
|
14
|
+
|
|
15
|
+
<div class="typewriter">
|
|
16
|
+
<slot
|
|
17
|
+
hidden
|
|
18
|
+
@slotchange=${()=>{this._startTyping()}}
|
|
19
|
+
></slot>
|
|
20
|
+
</div> `}},g([f.property({type:Number})],exports.TypewriterElement.prototype,"speed",2),g([Le.c({context:re.delayContext,subscribe:!0}),f.property({type:Number})],exports.TypewriterElement.prototype,"delay",2),g([f.property({type:Boolean})],exports.TypewriterElement.prototype,"autoStart",2),g([f.property({type:String})],exports.TypewriterElement.prototype,"cursorChar",2),g([f.property({type:Number})],exports.TypewriterElement.prototype,"deleteSpeed",2),g([f.property({type:Boolean})],exports.TypewriterElement.prototype,"once",2),g([f.query("#typewriter")],exports.TypewriterElement.prototype,"typewriterContainer",2),g([f.queryAssignedNodes({flatten:!0})],exports.TypewriterElement.prototype,"_getSlottedNodes",2),g([f.queryAssignedElements({flatten:!0})],exports.TypewriterElement.prototype,"_getSlottedElements",2),exports.TypewriterElement=g([f.customElement("schmancy-typewriter")],exports.TypewriterElement);
|
|
21
|
+
//# sourceMappingURL=typewriter-B5nruGbg.cjs.map
|