@mhmo91/schmancy 0.2.115 → 0.2.116
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-BJ8e_TdT.cjs → animated-text-DmtCT-2q.cjs} +2 -2
- package/dist/{animated-text-BJ8e_TdT.cjs.map → animated-text-DmtCT-2q.cjs.map} +1 -1
- package/dist/{animated-text-C-LJVhLw.js → animated-text-DrH4Miy7.js} +3 -3
- package/dist/{animated-text-C-LJVhLw.js.map → animated-text-DrH4Miy7.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-Bf5USqvC.cjs → area.component-Bg1zJKiZ.cjs} +2 -2
- package/dist/{area.component-Bf5USqvC.cjs.map → area.component-Bg1zJKiZ.cjs.map} +1 -1
- package/dist/{area.component-6ebQ-3Kb.js → area.component-CmsssAq_.js} +3 -3
- package/dist/{area.component-6ebQ-3Kb.js.map → area.component-CmsssAq_.js.map} +1 -1
- package/dist/area.js +1 -1
- package/dist/{autocomplete-CM_YM2UF.cjs → autocomplete-BFj0YUYW.cjs} +2 -2
- package/dist/{autocomplete-CM_YM2UF.cjs.map → autocomplete-BFj0YUYW.cjs.map} +1 -1
- package/dist/{autocomplete-NTEOksdT.js → autocomplete-BsrWuTsP.js} +3 -3
- package/dist/{autocomplete-NTEOksdT.js.map → autocomplete-BsrWuTsP.js.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-jcFvgv_5.cjs → checkbox-Cb7nmI6P.cjs} +2 -2
- package/dist/{checkbox-jcFvgv_5.cjs.map → checkbox-Cb7nmI6P.cjs.map} +1 -1
- package/dist/{checkbox-1tBSHNXu.js → checkbox-DUP_qnel.js} +2 -2
- package/dist/{checkbox-1tBSHNXu.js.map → checkbox-DUP_qnel.js.map} +1 -1
- package/dist/checkbox.cjs +1 -1
- package/dist/checkbox.js +1 -1
- package/dist/{chips-CdcS0QXD.js → chips-0hsW-Rxx.js} +3 -3
- package/dist/{chips-CdcS0QXD.js.map → chips-0hsW-Rxx.js.map} +1 -1
- package/dist/{chips-K7p1j3Uk.cjs → chips-CiesiXpI.cjs} +2 -2
- package/dist/{chips-K7p1j3Uk.cjs.map → chips-CiesiXpI.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/content-drawer.cjs +1 -1
- package/dist/content-drawer.js +1 -1
- package/dist/{date-range-BSBJICYH.js → date-range-DF_kjOLs.js} +3 -3
- package/dist/{date-range-BSBJICYH.js.map → date-range-DF_kjOLs.js.map} +1 -1
- package/dist/{date-range-BmVLxD4w.cjs → date-range-DvTXqD8e.cjs} +2 -2
- package/dist/{date-range-BmVLxD4w.cjs.map → date-range-DvTXqD8e.cjs.map} +1 -1
- package/dist/date-range.cjs +1 -1
- package/dist/date-range.js +1 -1
- package/dist/{delay-CgOaVklg.js → delay-Cmf_vIaJ.js} +2 -2
- package/dist/{delay-CgOaVklg.js.map → delay-Cmf_vIaJ.js.map} +1 -1
- package/dist/{delay-BC-GT6yV.cjs → delay-DhV8MSPZ.cjs} +2 -2
- package/dist/{delay-BC-GT6yV.cjs.map → delay-DhV8MSPZ.cjs.map} +1 -1
- package/dist/delay.cjs +1 -1
- package/dist/delay.js +1 -1
- package/dist/{divider-Dw4upy-U.cjs → divider-4ev5A0v0.cjs} +2 -2
- package/dist/{divider-Dw4upy-U.cjs.map → divider-4ev5A0v0.cjs.map} +1 -1
- package/dist/{divider-lRP5ZCxr.js → divider-B7GoicdG.js} +3 -3
- package/dist/{divider-lRP5ZCxr.js.map → divider-B7GoicdG.js.map} +1 -1
- package/dist/divider.cjs +1 -1
- package/dist/divider.js +1 -1
- package/dist/extra.cjs +1 -1
- package/dist/extra.js +1 -1
- package/dist/{flex-X4APHjaR.cjs → flex-DFHDHleC.cjs} +2 -2
- package/dist/{flex-X4APHjaR.cjs.map → flex-DFHDHleC.cjs.map} +1 -1
- package/dist/{flex-BkuM0UK7.js → flex-t4F0-R-c.js} +2 -2
- package/dist/{flex-BkuM0UK7.js.map → flex-t4F0-R-c.js.map} +1 -1
- package/dist/{form-Ct_Qt0rD.cjs → form-D_ShigQq.cjs} +2 -2
- package/dist/{form-Ct_Qt0rD.cjs.map → form-D_ShigQq.cjs.map} +1 -1
- package/dist/{form-Ci8uCvU-.js → form-dVHTERy3.js} +2 -2
- package/dist/{form-Ci8uCvU-.js.map → form-dVHTERy3.js.map} +1 -1
- package/dist/form.cjs +1 -1
- package/dist/form.js +1 -1
- package/dist/{icon-BPsYPc8h.cjs → icon-BNyFKp0p.cjs} +2 -2
- package/dist/{icon-BPsYPc8h.cjs.map → icon-BNyFKp0p.cjs.map} +1 -1
- package/dist/{icon-DOJOFG3x.js → icon-C3PI8GgN.js} +3 -3
- package/dist/{icon-DOJOFG3x.js.map → icon-C3PI8GgN.js.map} +1 -1
- package/dist/{icon-button-cirbgD54.cjs → icon-button-D4D5bXCm.cjs} +2 -2
- package/dist/{icon-button-cirbgD54.cjs.map → icon-button-D4D5bXCm.cjs.map} +1 -1
- package/dist/{icon-button-BPa29txC.js → icon-button-Dr_-8Ey5.js} +3 -3
- package/dist/{icon-button-BPa29txC.js.map → icon-button-Dr_-8Ey5.js.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 +35 -35
- package/dist/{input-B4miYmDK.cjs → input-BHgBONgn.cjs} +2 -2
- package/dist/{input-B4miYmDK.cjs.map → input-BHgBONgn.cjs.map} +1 -1
- package/dist/{input-DTJsOi9t.js → input-BgmQpY14.js} +2 -2
- package/dist/{input-DTJsOi9t.js.map → input-BgmQpY14.js.map} +1 -1
- package/dist/input-Bk7EZhOl.cjs +51 -0
- package/dist/input-Bk7EZhOl.cjs.map +1 -0
- package/dist/{input-CuvPPYVq.js → input-_XU4ILwo.js} +34 -34
- package/dist/input-_XU4ILwo.js.map +1 -0
- package/dist/input.cjs +1 -1
- package/dist/input.js +1 -1
- package/dist/layout.cjs +1 -1
- package/dist/layout.js +1 -1
- package/dist/{list-QiglVzPK.cjs → list-CCrSL1bZ.cjs} +2 -2
- package/dist/{list-QiglVzPK.cjs.map → list-CCrSL1bZ.cjs.map} +1 -1
- package/dist/{list-CWbygRrR.js → list-r6mo_zcT.js} +2 -2
- package/dist/{list-CWbygRrR.js.map → list-r6mo_zcT.js.map} +1 -1
- package/dist/list.cjs +1 -1
- package/dist/list.js +1 -1
- package/dist/{litElement.mixin-D_oDZMIO.cjs → litElement.mixin-CAXeI5RY.cjs} +2 -2
- package/dist/{litElement.mixin-D_oDZMIO.cjs.map → litElement.mixin-CAXeI5RY.cjs.map} +1 -1
- package/dist/{litElement.mixin-MZntPOCu.js → litElement.mixin-DfYInjJd.js} +2 -2
- package/dist/{litElement.mixin-MZntPOCu.js.map → litElement.mixin-DfYInjJd.js.map} +1 -1
- package/dist/{menu-Bn4JuaBS.cjs → menu-B6x8xZng.cjs} +2 -2
- package/dist/{menu-Bn4JuaBS.cjs.map → menu-B6x8xZng.cjs.map} +1 -1
- package/dist/{menu-iSx7aWwL.js → menu-yboJ8_V4.js} +3 -3
- package/dist/{menu-iSx7aWwL.js.map → menu-yboJ8_V4.js.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-DMwxI7ML.js → option-CmZo8fXU.js} +2 -2
- package/dist/{option-DMwxI7ML.js.map → option-CmZo8fXU.js.map} +1 -1
- package/dist/{option-DBfFfXNm.cjs → option-gnBrhD_1.cjs} +2 -2
- package/dist/{option-DBfFfXNm.cjs.map → option-gnBrhD_1.cjs.map} +1 -1
- package/dist/option.cjs +1 -1
- package/dist/option.js +1 -1
- package/dist/{outlet-KhTjvKCU.js → outlet-BgJ_WOwi.js} +2 -2
- package/dist/{outlet-KhTjvKCU.js.map → outlet-BgJ_WOwi.js.map} +1 -1
- package/dist/{outlet-CEaS1zUl.cjs → outlet-CSduKjEi.cjs} +2 -2
- package/dist/{outlet-CEaS1zUl.cjs.map → outlet-CSduKjEi.cjs.map} +1 -1
- package/dist/{payment-card-form-CVZyDkcJ.cjs → payment-card-form-CVW9uWum.cjs} +2 -2
- package/dist/{payment-card-form-CVZyDkcJ.cjs.map → payment-card-form-CVW9uWum.cjs.map} +1 -1
- package/dist/{payment-card-form-DK86Lcng.js → payment-card-form-NUTic2b3.js} +3 -3
- package/dist/{payment-card-form-DK86Lcng.js.map → payment-card-form-NUTic2b3.js.map} +1 -1
- package/dist/{radio-group-DNmZuvSj.js → radio-group-Bl5nhDCh.js} +2 -2
- package/dist/{radio-group-DNmZuvSj.js.map → radio-group-Bl5nhDCh.js.map} +1 -1
- package/dist/{radio-group-CxJXNx54.cjs → radio-group-CTCnzxmZ.cjs} +2 -2
- package/dist/{radio-group-CxJXNx54.cjs.map → radio-group-CTCnzxmZ.cjs.map} +1 -1
- package/dist/radio-group.cjs +1 -1
- package/dist/radio-group.js +1 -1
- package/dist/{select-DRi9CB_N.js → select-C2TJxenH.js} +12 -12
- package/dist/select-C2TJxenH.js.map +1 -0
- package/dist/select-D3yrgnVD.cjs +56 -0
- package/dist/select-D3yrgnVD.cjs.map +1 -0
- package/dist/select.cjs +1 -1
- package/dist/select.js +1 -1
- package/dist/sheet-CwzonocJ.cjs +62 -0
- package/dist/sheet-CwzonocJ.cjs.map +1 -0
- package/dist/sheet-DHyy-OIH.js +244 -0
- package/dist/sheet-DHyy-OIH.js.map +1 -0
- package/dist/sheet.cjs +1 -1
- package/dist/sheet.js +1 -1
- package/dist/{slider-A_LoTZ1P.js → slider-2mhXBUIM.js} +3 -3
- package/dist/{slider-A_LoTZ1P.js.map → slider-2mhXBUIM.js.map} +1 -1
- package/dist/{slider-XRH0sXZN.cjs → slider-DCJHcXt1.cjs} +2 -2
- package/dist/{slider-XRH0sXZN.cjs.map → slider-DCJHcXt1.cjs.map} +1 -1
- package/dist/slider.cjs +1 -1
- package/dist/slider.js +1 -1
- package/dist/{spinner-D0l2eAK5.js → spinner-B9JHqmoP.js} +3 -3
- package/dist/{spinner-D0l2eAK5.js.map → spinner-B9JHqmoP.js.map} +1 -1
- package/dist/{spinner-CSsb6sKK.cjs → spinner-D-vtqMqq.cjs} +2 -2
- package/dist/{spinner-CSsb6sKK.cjs.map → spinner-D-vtqMqq.cjs.map} +1 -1
- package/dist/{surface-DEAdaZUh.cjs → surface-DLHFSFU6.cjs} +2 -2
- package/dist/{surface-DEAdaZUh.cjs.map → surface-DLHFSFU6.cjs.map} +1 -1
- package/dist/{surface-D5FgxeIB.js → surface-O_-YGi6T.js} +2 -2
- package/dist/{surface-D5FgxeIB.js.map → surface-O_-YGi6T.js.map} +1 -1
- package/dist/surface.cjs +1 -1
- package/dist/surface.js +1 -1
- package/dist/{table-DC86Vj6Z.js → table-Bvb_ZG7b.js} +2 -2
- package/dist/{table-DC86Vj6Z.js.map → table-Bvb_ZG7b.js.map} +1 -1
- package/dist/{table-Cygw_pIl.cjs → table-CdkLZM2b.cjs} +2 -2
- package/dist/{table-Cygw_pIl.cjs.map → table-CdkLZM2b.cjs.map} +1 -1
- package/dist/table.cjs +1 -1
- package/dist/table.js +1 -1
- package/dist/{tabs-group-BQomo5q3.cjs → tabs-group-B-KvImY2.cjs} +2 -2
- package/dist/{tabs-group-BQomo5q3.cjs.map → tabs-group-B-KvImY2.cjs.map} +1 -1
- package/dist/{tabs-group-7bz0I9uV.js → tabs-group-CVZ2SEq3.js} +2 -2
- package/dist/{tabs-group-7bz0I9uV.js.map → tabs-group-CVZ2SEq3.js.map} +1 -1
- package/dist/tabs.cjs +1 -1
- package/dist/tabs.js +1 -1
- package/dist/tailwind.mixin-BvhzMkqK.js +43 -0
- package/dist/{tailwind.mixin-B-T2bBPl.js.map → tailwind.mixin-BvhzMkqK.js.map} +1 -1
- package/dist/tailwind.mixin-csgxM8P_.cjs +2 -0
- package/dist/{tailwind.mixin-CduPdozY.cjs.map → tailwind.mixin-csgxM8P_.cjs.map} +1 -1
- package/dist/teleport.cjs +1 -1
- package/dist/{teleport.component-gFIqLOrA.js → teleport.component-BRm0yYbM.js} +37 -37
- package/dist/{teleport.component-gFIqLOrA.js.map → teleport.component-BRm0yYbM.js.map} +1 -1
- package/dist/{teleport.component-BMLwCM8y.cjs → teleport.component-D9xuyN_z.cjs} +2 -2
- package/dist/{teleport.component-BMLwCM8y.cjs.map → teleport.component-D9xuyN_z.cjs.map} +1 -1
- package/dist/teleport.js +1 -1
- package/dist/{textarea-CixoZTFB.cjs → textarea-BaTTXEtZ.cjs} +2 -2
- package/dist/{textarea-CixoZTFB.cjs.map → textarea-BaTTXEtZ.cjs.map} +1 -1
- package/dist/{textarea-1aeql05N.js → textarea-txN6-t64.js} +2 -2
- package/dist/{textarea-1aeql05N.js.map → textarea-txN6-t64.js.map} +1 -1
- package/dist/textarea.cjs +1 -1
- package/dist/textarea.js +1 -1
- package/dist/{theme-button-MRgILdtC.js → theme-button-C2oB9OCM.js} +2 -2
- package/dist/{theme-button-MRgILdtC.js.map → theme-button-C2oB9OCM.js.map} +1 -1
- package/dist/{theme-button-DocSoRxe.cjs → theme-button-qFLBZi0_.cjs} +2 -2
- package/dist/{theme-button-DocSoRxe.cjs.map → theme-button-qFLBZi0_.cjs.map} +1 -1
- package/dist/theme-button.cjs +1 -1
- package/dist/theme-button.js +1 -1
- package/dist/theme.cjs +1 -1
- package/dist/{theme.component-BgOdO6iM.cjs → theme.component-C-055F7V.cjs} +2 -2
- package/dist/{theme.component-BgOdO6iM.cjs.map → theme.component-C-055F7V.cjs.map} +1 -1
- package/dist/{theme.component-BFkhNT0D.js → theme.component-UVrnuMPb.js} +2 -2
- package/dist/{theme.component-BFkhNT0D.js.map → theme.component-UVrnuMPb.js.map} +1 -1
- package/dist/theme.js +1 -1
- package/dist/{timezone-CvOrPfno.cjs → timezone-CvS7opKc.cjs} +2 -2
- package/dist/{timezone-CvOrPfno.cjs.map → timezone-CvS7opKc.cjs.map} +1 -1
- package/dist/{timezone-BW6MC511.js → timezone-DUYp8qD3.js} +3 -3
- package/dist/{timezone-BW6MC511.js.map → timezone-DUYp8qD3.js.map} +1 -1
- package/dist/{tree-PSCsuzDT.js → tree-Cxgw_mi9.js} +2 -2
- package/dist/{tree-PSCsuzDT.js.map → tree-Cxgw_mi9.js.map} +1 -1
- package/dist/{tree-DysB6Y8C.cjs → tree-DYLlgF1F.cjs} +2 -2
- package/dist/{tree-DysB6Y8C.cjs.map → tree-DYLlgF1F.cjs.map} +1 -1
- package/dist/tree.cjs +1 -1
- package/dist/tree.js +1 -1
- package/dist/{typewriter-DmzUuxvZ.js → typewriter-DUdvh6VO.js} +4 -4
- package/dist/{typewriter-DmzUuxvZ.js.map → typewriter-DUdvh6VO.js.map} +1 -1
- package/dist/{typewriter-C8pWgRuU.cjs → typewriter-DoGLma1z.cjs} +2 -2
- package/dist/{typewriter-C8pWgRuU.cjs.map → typewriter-DoGLma1z.cjs.map} +1 -1
- package/dist/typewriter.cjs +1 -1
- package/dist/typewriter.js +1 -1
- package/dist/{typography-D486o2A3.js → typography-BnQJ5TWy.js} +2 -2
- package/dist/{typography-D486o2A3.js.map → typography-BnQJ5TWy.js.map} +1 -1
- package/dist/{typography-BfjWKELJ.cjs → typography-DFREXmBg.cjs} +2 -2
- package/dist/{typography-BfjWKELJ.cjs.map → typography-DFREXmBg.cjs.map} +1 -1
- package/dist/typography.cjs +1 -1
- package/dist/typography.js +1 -1
- package/dist/v2.cjs +1 -1
- package/dist/v2.js +1 -1
- package/package.json +1 -1
- package/types/src/select/select.d.ts +1 -0
- package/types/src/sheet/header.d.ts +0 -1
- package/types/src/sheet/sheet.d.ts +120 -1
- package/dist/input-CuvPPYVq.js.map +0 -1
- package/dist/input-DibJxeWY.cjs +0 -51
- package/dist/input-DibJxeWY.cjs.map +0 -1
- package/dist/select-DRi9CB_N.js.map +0 -1
- package/dist/select-SQOIioEy.cjs +0 -56
- package/dist/select-SQOIioEy.cjs.map +0 -1
- package/dist/sheet-BJGyAQko.js +0 -182
- package/dist/sheet-BJGyAQko.js.map +0 -1
- package/dist/sheet-QIcFyBDD.cjs +0 -43
- package/dist/sheet-QIcFyBDD.cjs.map +0 -1
- package/dist/tailwind.mixin-B-T2bBPl.js +0 -43
- package/dist/tailwind.mixin-CduPdozY.cjs +0 -2
|
@@ -0,0 +1,244 @@
|
|
|
1
|
+
import { Subject as E, switchMap as T, forkJoin as S, fromEvent as p, of as x, takeUntil as f, timer as C, map as y, defaultIfEmpty as k, tap as c, delay as v, filter as A, take as Y, mergeMap as L, merge as z } from "rxjs";
|
|
2
|
+
import "lit/directives/class-map.js";
|
|
3
|
+
import "lit/directives/style-map.js";
|
|
4
|
+
import { T as U } from "./tailwind.mixin-BvhzMkqK.js";
|
|
5
|
+
import { css as P, html as b } from "lit";
|
|
6
|
+
import { customElement as B, property as r, query as $, queryAssignedElements as j } from "lit/decorators.js";
|
|
7
|
+
import { $ as q } from "./litElement.mixin-DfYInjJd.js";
|
|
8
|
+
import { ifDefined as F } from "lit/directives/if-defined.js";
|
|
9
|
+
import { when as D } from "lit/directives/when.js";
|
|
10
|
+
var R = Object.getOwnPropertyDescriptor;
|
|
11
|
+
let O = class extends U(P``) {
|
|
12
|
+
render() {
|
|
13
|
+
return b`
|
|
14
|
+
<sch-flex class="absolute top-0 left-0 md:left-[unset] md:right-0">
|
|
15
|
+
<div class="block md:hidden flex-1 justify-start items-start">
|
|
16
|
+
<slot name="back">
|
|
17
|
+
<schmancy-button
|
|
18
|
+
@click=${() => {
|
|
19
|
+
this.dispatchEvent(new CustomEvent("dismiss", { bubbles: !0, composed: !0 }));
|
|
20
|
+
}}
|
|
21
|
+
>
|
|
22
|
+
<span class="text-[24px]">← </span>
|
|
23
|
+
</schmancy-button>
|
|
24
|
+
</slot>
|
|
25
|
+
</div>
|
|
26
|
+
|
|
27
|
+
<div class="hidden md:block flex-1 justify-end items-end">
|
|
28
|
+
<slot name="actions">
|
|
29
|
+
<schmancy-icon-button
|
|
30
|
+
@click=${() => {
|
|
31
|
+
this.dispatchEvent(new CustomEvent("dismiss", { bubbles: !0, composed: !0 }));
|
|
32
|
+
}}
|
|
33
|
+
>
|
|
34
|
+
close
|
|
35
|
+
</schmancy-icon-button>
|
|
36
|
+
</slot>
|
|
37
|
+
</div>
|
|
38
|
+
</sch-flex>
|
|
39
|
+
`;
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
O = ((t, e, s, i) => {
|
|
43
|
+
for (var h, a = i > 1 ? void 0 : i ? R(e, s) : e, l = t.length - 1; l >= 0; l--) (h = t[l]) && (a = h(a) || a);
|
|
44
|
+
return a;
|
|
45
|
+
})([B("schmancy-sheet-header")], O);
|
|
46
|
+
var d = ((t) => (t.Side = "side", t.Bottom = "bottom", t.BottomCenter = "bottom-center", t.TopRight = "top-right", t.BottomRight = "bottom-right", t))(d || {});
|
|
47
|
+
const g = "are-you-there-sheet", w = "yes-here", Z = new class {
|
|
48
|
+
constructor() {
|
|
49
|
+
this.bottomSheet = new E(), this.$dismiss = new E(), this.bottomSheet.pipe(T((t) => S([p(window, w).pipe(f(C(0)), y((e) => e.detail.sheet), k(void 0)), x(t).pipe(c(() => {
|
|
50
|
+
window.dispatchEvent(new CustomEvent(g, { detail: { uid: t.uid ?? t.component.tagName } }));
|
|
51
|
+
}))])), y(([t, e]) => {
|
|
52
|
+
t || (t = document.createElement("schmancy-sheet"), document.body.appendChild(t)), t.setAttribute("uid", e.uid ?? e.component.tagName);
|
|
53
|
+
const s = e.position || (window.innerWidth >= 768 ? "side" : "bottom");
|
|
54
|
+
return t.setAttribute("position", s), t.setAttribute("allowOverlyDismiss", e.allowOverlyDismiss === !1 ? "false" : "true"), e.title && t.setAttribute("title", e.title), e.persist && t.setAttribute("persist", e.persist ?? !1), e.header && t.setAttribute("header", e.header), document.body.style.overflow = "hidden", { target: e, sheet: t };
|
|
55
|
+
}), v(20), A(({ target: t, sheet: e }) => {
|
|
56
|
+
var s, i;
|
|
57
|
+
return !t.persist || !((i = (s = e == null ? void 0 : e.shadowRoot) == null ? void 0 : s.querySelector("slot")) != null && i.assignedElements().find((h) => h.tagName === t.component.tagName)) || (e == null || e.setAttribute("open", "true"), !1);
|
|
58
|
+
}), c(({ target: t, sheet: e }) => {
|
|
59
|
+
e == null || e.appendChild(t.component);
|
|
60
|
+
}), v(1), c(({ sheet: t }) => {
|
|
61
|
+
t == null || t.setAttribute("open", "true");
|
|
62
|
+
}), c(({ sheet: t }) => {
|
|
63
|
+
p(t, "close").pipe(Y(1)).pipe(v(300)).subscribe((e) => {
|
|
64
|
+
const s = e.target;
|
|
65
|
+
s != null && s.persist || (s == null || s.remove()), document.body.style.overflow = "auto";
|
|
66
|
+
});
|
|
67
|
+
})).subscribe(), this.$dismiss.pipe(L((t) => S([p(window, w).pipe(f(C(100)), y((e) => e.detail.sheet), k(void 0)), x(t).pipe(c(() => {
|
|
68
|
+
window.dispatchEvent(new CustomEvent(g, { detail: { uid: t } }));
|
|
69
|
+
}))])), c(([t]) => {
|
|
70
|
+
t == null || t.closeSheet();
|
|
71
|
+
})).subscribe();
|
|
72
|
+
}
|
|
73
|
+
dismiss(t) {
|
|
74
|
+
this.$dismiss.next(t);
|
|
75
|
+
}
|
|
76
|
+
open(t) {
|
|
77
|
+
this.bottomSheet.next(t);
|
|
78
|
+
}
|
|
79
|
+
}();
|
|
80
|
+
var I = Object.defineProperty, M = Object.getOwnPropertyDescriptor, n = (t, e, s, i) => {
|
|
81
|
+
for (var h, a = i > 1 ? void 0 : i ? M(e, s) : e, l = t.length - 1; l >= 0; l--) (h = t[l]) && (a = (i ? h(e, s, a) : h(a)) || a);
|
|
82
|
+
return i && a && I(e, s, a), a;
|
|
83
|
+
};
|
|
84
|
+
let o = class extends q(':host{--overlay-color: var(--schmancy-sys-color-surface-dim);--transition-duration: .2s;--transition-timing: ease-in-out;--sheet-radius: 0;--max-height: 100vh}.sheet{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;visibility:visible;transition:visibility var(--transition-duration) var(--transition-timing)}.sheet[aria-hidden=true]{visibility:hidden;pointer-events:none}.sheet[aria-hidden=true] .content{transform:translateY(100%)}.sheet[aria-hidden=true] .content[data-position=side]{transform:translate(100%)}.sheet[aria-hidden=true] .overlay{opacity:0}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--overlay-color);opacity:.8;transition:opacity var(--transition-duration) var(--transition-timing)}.content{z-index:1;transition:transform var(--transition-duration) var(--transition-timing);overflow:hidden}.content[data-position=side]{height:100vh;height:100%;min-width:320px;max-width:90vw;width:fit-content;margin-left:auto}.content[data-position=side] #body{max-height:100vh}.content[data-position=bottom]{width:100%;margin-top:auto;border-radius:16px 16px 0 0;max-height:90vh}.content[data-position=bottom] #body{max-height:90vh}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}[data-position=bottom]:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:36px;height:4px;background-color:var(--schmancy-sys-color-surface-onVariant);opacity:.3;border-radius:2px;z-index:10}') {
|
|
85
|
+
constructor() {
|
|
86
|
+
super(...arguments), this.open = !1, this.header = "visible", this.position = d.Side, this.persist = !1, this.allowOverlayDismiss = !0, this.preventBackdropClick = !1, this.title = "", this.animationDuration = 200, this.animationEasing = "ease-in-out", this.focusAttribute = "autofocus", this.lastFocusedElement = null, this.startY = 0, this.currentY = 0, this.resizeObserver = null, this.handleFocusIn = (t) => {
|
|
87
|
+
var e;
|
|
88
|
+
(e = this.sheet) != null && e.contains(t.target) || this.focus();
|
|
89
|
+
}, this.handleScroll = () => {
|
|
90
|
+
}, this.handleTouchStart = (t) => {
|
|
91
|
+
this.position === d.Bottom && (this.startY = t.touches[0].clientY, this.currentY = this.startY);
|
|
92
|
+
}, this.handleTouchMove = (t) => {
|
|
93
|
+
if (this.position === d.Bottom) {
|
|
94
|
+
this.currentY = t.touches[0].clientY;
|
|
95
|
+
const e = this.currentY - this.startY;
|
|
96
|
+
e > 0 && (t.currentTarget.style.transform = `translateY(${e}px)`, t.preventDefault());
|
|
97
|
+
}
|
|
98
|
+
}, this.handleTouchEnd = (t) => {
|
|
99
|
+
if (this.position === d.Bottom) {
|
|
100
|
+
const e = t.currentTarget, s = this.currentY - this.startY;
|
|
101
|
+
e.style.transform = "", s > Math.min(100, 0.3 * e.offsetHeight) && this.closeSheet();
|
|
102
|
+
}
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
onOpenChange(t, e) {
|
|
106
|
+
var s;
|
|
107
|
+
e ? (this.lastFocusedElement = document.activeElement, this.addFocusTrap(), this.focus(), this.fireEvent("open")) : (this.removeFocusTrap(), (s = this.lastFocusedElement) == null || s.focus(), this.lastFocusedElement = null), this.updateCssVariables();
|
|
108
|
+
}
|
|
109
|
+
connectedCallback() {
|
|
110
|
+
super.connectedCallback(), this.setupEventListeners(), this.resizeObserver = new ResizeObserver(() => {
|
|
111
|
+
this.open && this.updateSheetDimensions();
|
|
112
|
+
}), this.resizeObserver.observe(document.body), this.updateCssVariables();
|
|
113
|
+
}
|
|
114
|
+
firstUpdated() {
|
|
115
|
+
var t;
|
|
116
|
+
(t = this.bodyElement) == null || t.addEventListener("scroll", this.handleScroll, { passive: !0 });
|
|
117
|
+
}
|
|
118
|
+
updated(t) {
|
|
119
|
+
(t.has("animationDuration") || t.has("animationEasing")) && this.updateCssVariables();
|
|
120
|
+
}
|
|
121
|
+
disconnectedCallback() {
|
|
122
|
+
var t, e;
|
|
123
|
+
super.disconnectedCallback(), this.disconnecting.next(!0), (t = this.bodyElement) == null || t.removeEventListener("scroll", this.handleScroll), (e = this.resizeObserver) == null || e.disconnect();
|
|
124
|
+
}
|
|
125
|
+
updateCssVariables() {
|
|
126
|
+
this.style.setProperty("--transition-duration", `${this.animationDuration}ms`), this.style.setProperty("--transition-timing", this.animationEasing);
|
|
127
|
+
}
|
|
128
|
+
setupEventListeners() {
|
|
129
|
+
const t = p(window, "popstate").pipe(c((i) => {
|
|
130
|
+
i.preventDefault(), this.closeSheet();
|
|
131
|
+
})), e = p(window, "keyup").pipe(c((i) => {
|
|
132
|
+
i.key !== "Escape" || this.sheetContainsFocus() || this.closeSheet();
|
|
133
|
+
})), s = p(window, g).pipe(c((i) => {
|
|
134
|
+
i.detail.uid === this.uid && this.announcePresence();
|
|
135
|
+
}));
|
|
136
|
+
z(t, e, s).pipe(f(this.disconnecting)).subscribe();
|
|
137
|
+
}
|
|
138
|
+
sheetContainsFocus() {
|
|
139
|
+
var t;
|
|
140
|
+
return ((t = this.sheet) == null ? void 0 : t.contains(document.activeElement)) ?? !1;
|
|
141
|
+
}
|
|
142
|
+
announcePresence() {
|
|
143
|
+
this.dispatchEvent(new CustomEvent(w, { detail: { sheet: this }, bubbles: !0, composed: !0 }));
|
|
144
|
+
}
|
|
145
|
+
addFocusTrap() {
|
|
146
|
+
document.addEventListener("focusin", this.handleFocusIn);
|
|
147
|
+
}
|
|
148
|
+
removeFocusTrap() {
|
|
149
|
+
document.removeEventListener("focusin", this.handleFocusIn);
|
|
150
|
+
}
|
|
151
|
+
setIsSheetShown(t) {
|
|
152
|
+
var e, s;
|
|
153
|
+
(e = this.sheet) == null || e.setAttribute("aria-hidden", String(!t)), (s = this.sheet) == null || s.setAttribute("aria-modal", String(t));
|
|
154
|
+
}
|
|
155
|
+
closeSheet() {
|
|
156
|
+
const t = new CustomEvent("before-close", { bubbles: !0, composed: !0, cancelable: !0 });
|
|
157
|
+
this.dispatchEvent(t) && (this.open = !1, this.fireEvent("close"));
|
|
158
|
+
}
|
|
159
|
+
updateSheetDimensions() {
|
|
160
|
+
var t;
|
|
161
|
+
if (this.position === d.Bottom) {
|
|
162
|
+
const e = (t = this.shadowRoot) == null ? void 0 : t.querySelector(".content");
|
|
163
|
+
e && (e.style.maxHeight = 0.9 * window.innerHeight + "px");
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
getFocusElement() {
|
|
167
|
+
var e;
|
|
168
|
+
if (this.initialFocusSelector) {
|
|
169
|
+
const s = (e = this.shadowRoot) == null ? void 0 : e.querySelector(this.initialFocusSelector);
|
|
170
|
+
if (s) return s;
|
|
171
|
+
}
|
|
172
|
+
const t = `[${this.focusAttribute}]`;
|
|
173
|
+
return this.assignedElements.find((s) => s.matches(t) || s.querySelector(t)) ?? null;
|
|
174
|
+
}
|
|
175
|
+
focus() {
|
|
176
|
+
var t;
|
|
177
|
+
(t = this.getFocusElement()) == null || t.focus();
|
|
178
|
+
}
|
|
179
|
+
fireEvent(t, e = {}) {
|
|
180
|
+
this.dispatchEvent(new CustomEvent(t, { bubbles: !0, composed: !0, detail: e }));
|
|
181
|
+
}
|
|
182
|
+
render() {
|
|
183
|
+
return b`
|
|
184
|
+
<div
|
|
185
|
+
class="sheet"
|
|
186
|
+
role="dialog"
|
|
187
|
+
aria-labelledby=${F(this.title ? "sheet-title" : this.ariaLabel ? "sheet-aria-label" : void 0)}
|
|
188
|
+
aria-describedby=${F(this.ariaDescribedBy)}
|
|
189
|
+
aria-hidden=${!this.open}
|
|
190
|
+
aria-modal=${this.open}
|
|
191
|
+
>
|
|
192
|
+
${D(this.ariaLabel && !this.title, () => b`<span id="sheet-aria-label" class="sr-only">${this.ariaLabel}</span>`)}
|
|
193
|
+
|
|
194
|
+
<div
|
|
195
|
+
class="overlay"
|
|
196
|
+
@click=${(t) => {
|
|
197
|
+
t.stopPropagation(), this.allowOverlayDismiss && !this.preventBackdropClick && this.closeSheet();
|
|
198
|
+
}}
|
|
199
|
+
></div>
|
|
200
|
+
|
|
201
|
+
<schmancy-grid
|
|
202
|
+
@touchstart=${this.handleTouchStart}
|
|
203
|
+
@touchmove=${this.handleTouchMove}
|
|
204
|
+
@touchend=${this.handleTouchEnd}
|
|
205
|
+
rows=${this.header === "hidden" ? "1fr" : "auto 1fr"}
|
|
206
|
+
class="content w-full"
|
|
207
|
+
data-position=${this.position}
|
|
208
|
+
>
|
|
209
|
+
${D(this.header !== "hidden", () => b`<schmancy-sheet-header
|
|
210
|
+
class="sticky top-0 z-50 w-full"
|
|
211
|
+
@dismiss=${(t) => {
|
|
212
|
+
t.stopPropagation(), this.closeSheet();
|
|
213
|
+
}}
|
|
214
|
+
id="sheet-title"
|
|
215
|
+
title=${this.title}
|
|
216
|
+
></schmancy-sheet-header>`)}
|
|
217
|
+
|
|
218
|
+
<schmancy-surface rounded="left" fill="all" id="body" class="overflow-hidden" type="surface">
|
|
219
|
+
<schmancy-scroll>
|
|
220
|
+
<slot></slot>
|
|
221
|
+
</schmancy-scroll>
|
|
222
|
+
</schmancy-surface>
|
|
223
|
+
</schmancy-grid>
|
|
224
|
+
</div>
|
|
225
|
+
`;
|
|
226
|
+
}
|
|
227
|
+
};
|
|
228
|
+
var m, u;
|
|
229
|
+
n([r({ type: String, reflect: !0 })], o.prototype, "uid", 2), n([r({ type: Boolean, reflect: !0 })], o.prototype, "open", 2), n([r({ type: String, reflect: !0 })], o.prototype, "header", 2), n([r({ type: String, reflect: !0 })], o.prototype, "position", 2), n([r({ type: Boolean, reflect: !0 })], o.prototype, "persist", 2), n([r({ type: Boolean, reflect: !0 })], o.prototype, "allowOverlayDismiss", 2), n([r({ type: Boolean })], o.prototype, "preventBackdropClick", 2), n([r({ type: String, reflect: !0 })], o.prototype, "title", 2), n([r({ type: String })], o.prototype, "ariaLabel", 2), n([r({ type: String })], o.prototype, "ariaDescribedBy", 2), n([r({ type: String })], o.prototype, "initialFocusSelector", 2), n([r({ type: Number })], o.prototype, "animationDuration", 2), n([r({ type: String })], o.prototype, "animationEasing", 2), n([r()], o.prototype, "focusAttribute", 2), n([$(".sheet")], o.prototype, "sheet", 2), n([$("#body")], o.prototype, "bodyElement", 2), n([j({ flatten: !0 })], o.prototype, "assignedElements", 2), n([(m = "open", (t, e) => {
|
|
230
|
+
const { willUpdate: s } = t;
|
|
231
|
+
u = Object.assign({ waitUntilFirstUpdate: !1 }, u), t.willUpdate = function(i) {
|
|
232
|
+
if (s.call(this, i), i.has(m)) {
|
|
233
|
+
const h = i.get(m), a = this[m];
|
|
234
|
+
h !== a && (u != null && u.waitUntilFirstUpdate && !this.hasUpdated || this[e].call(this, h, a));
|
|
235
|
+
}
|
|
236
|
+
};
|
|
237
|
+
})], o.prototype, "onOpenChange", 1), o = n([B("schmancy-sheet")], o);
|
|
238
|
+
export {
|
|
239
|
+
d as S,
|
|
240
|
+
g as a,
|
|
241
|
+
w as b,
|
|
242
|
+
Z as s
|
|
243
|
+
};
|
|
244
|
+
//# sourceMappingURL=sheet-DHyy-OIH.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sheet-DHyy-OIH.js","sources":["../src/sheet/header.ts","../src/sheet/sheet.service.ts","../src/sheet/sheet.ts","../src/sheet/hook.ts"],"sourcesContent":["import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\n\n@customElement('schmancy-sheet-header')\nexport default class SchmancySheetHeader extends TailwindElement(css``) {\n\trender() {\n\t\treturn html`\n\t\t\t<sch-flex class=\"absolute top-0 left-0 md:left-[unset] md:right-0\">\n\t\t\t\t<div class=\"block md:hidden flex-1 justify-start items-start\">\n\t\t\t\t\t<slot name=\"back\">\n\t\t\t\t\t\t<schmancy-button\n\t\t\t\t\t\t\t@click=${() => {\n\t\t\t\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\t\t\t\tnew CustomEvent('dismiss', {\n\t\t\t\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\t\t\t\tcomposed: true,\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}}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<span class=\"text-[24px]\">← </span>\n\t\t\t\t\t\t</schmancy-button>\n\t\t\t\t\t</slot>\n\t\t\t\t</div>\n\n\t\t\t\t<div class=\"hidden md:block flex-1 justify-end items-end\">\n\t\t\t\t\t<slot name=\"actions\">\n\t\t\t\t\t\t<schmancy-icon-button\n\t\t\t\t\t\t\t@click=${() => {\n\t\t\t\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\t\t\t\tnew CustomEvent('dismiss', {\n\t\t\t\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\t\t\t\tcomposed: true,\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}}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\tclose\n\t\t\t\t\t\t</schmancy-icon-button>\n\t\t\t\t\t</slot>\n\t\t\t\t</div>\n\t\t\t</sch-flex>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-sheet-header': SchmancySheetHeader\n\t}\n}\n","import {\n\tdefaultIfEmpty,\n\tdelay,\n\tfilter,\n\tforkJoin,\n\tfromEvent,\n\tmap,\n\tmergeMap,\n\tof,\n\tSubject,\n\tswitchMap,\n\ttake,\n\ttakeUntil,\n\ttap,\n\ttimer,\n} from 'rxjs'\nimport SchmancySheet from './sheet'\n\nexport enum SchmancySheetPosition {\n\tSide = 'side',\n\tBottom = 'bottom',\n\t/**\n\t * @deprecated use bottom instead\n\t */\n\tBottomCenter = 'bottom-center',\n\t/**\n\t * @deprecated use side instead\n\t */\n\tTopRight = 'top-right',\n\t/**\n\t * @deprecated use side instead\n\t */\n\tBottomRight = 'bottom-right',\n}\n\ntype BottomSheeetTarget = {\n\tcomponent: HTMLElement\n\tuid?: string\n\tposition?: SchmancySheetPosition\n\tpersist?: boolean\n\tclose?: () => void\n\tallowOverlyDismiss?: boolean\n\ttitle?: string\n\theader?: 'hidden' | 'visible'\n}\n\n// Events for communication between bottom-sheet component and bottom-sheet.service\nexport type SheetWhereAreYouRickyEvent = CustomEvent<{\n\tuid: string\n}>\nexport const SheetWhereAreYouRicky = 'are-you-there-sheet'\n\nexport type SheetHereMortyEvent = CustomEvent<{\n\tsheet: SchmancySheet\n}>\nexport const SheetHereMorty = 'yes-here'\n\n// Function to determine the position based on screen size\nconst getPosition = (): SchmancySheetPosition => {\n\treturn window.innerWidth >= 768 ? SchmancySheetPosition.Side : SchmancySheetPosition.Bottom // Adjust 768 as needed for your breakpoint\n}\n\nclass BottomSheetService {\n\tbottomSheet = new Subject<BottomSheeetTarget>()\n\t$dismiss = new Subject<string>()\n\tconstructor() {\n\t\tthis.bottomSheet\n\t\t\t.pipe(\n\t\t\t\tswitchMap(target =>\n\t\t\t\t\tforkJoin([\n\t\t\t\t\t\tfromEvent<SheetHereMortyEvent>(window, SheetHereMorty).pipe(\n\t\t\t\t\t\t\ttakeUntil(timer(0)),\n\t\t\t\t\t\t\tmap(e => e.detail.sheet),\n\t\t\t\t\t\t\tdefaultIfEmpty(undefined),\n\t\t\t\t\t\t),\n\t\t\t\t\t\tof(target).pipe(\n\t\t\t\t\t\t\ttap(() => {\n\t\t\t\t\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\t\t\t\t\tnew CustomEvent(SheetWhereAreYouRicky, {\n\t\t\t\t\t\t\t\t\t\tdetail: { uid: target.uid ?? target.component.tagName },\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}),\n\t\t\t\t\t\t),\n\t\t\t\t\t]),\n\t\t\t\t),\n\t\t\t\tmap(([sheet, target]) => {\n\t\t\t\t\tconsole.log(sheet, target)\n\t\t\t\t\tif (!sheet) {\n\t\t\t\t\t\t// if sheet is not found, create it\n\t\t\t\t\t\tsheet = document.createElement('schmancy-sheet')\n\t\t\t\t\t\tdocument.body.appendChild(sheet)\n\t\t\t\t\t}\n\t\t\t\t\tsheet.setAttribute('uid', target.uid ?? target.component.tagName)\n\n\t\t\t\t\t// **Use the dynamic position function here**\n\t\t\t\t\tconst position = target.position || getPosition() // Use target.position if it's set, otherwise determine based on screen size\n\t\t\t\t\tsheet.setAttribute('position', position)\n\n\t\t\t\t\tsheet.setAttribute('allowOverlyDismiss', target.allowOverlyDismiss === false ? 'false' : 'true')\n\t\t\t\t\ttarget.title && sheet.setAttribute('title', target.title)\n\t\t\t\t\ttarget.persist && sheet.setAttribute('persist', target.persist ?? false)\n\t\t\t\t\ttarget.header && sheet.setAttribute('header', target.header)\n\t\t\t\t\tdocument.body.style.overflow = 'hidden' // lock the scroll of the host\n\t\t\t\t\treturn { target, sheet }\n\t\t\t\t}),\n\t\t\t\tdelay(20),\n\t\t\t\tfilter(({ target, sheet }) => {\n\t\t\t\t\t// if the sheet has already the component, just show it\n\t\t\t\t\tif (\n\t\t\t\t\t\ttarget.persist &&\n\t\t\t\t\t\tsheet?.shadowRoot\n\t\t\t\t\t\t\t?.querySelector('slot')\n\t\t\t\t\t\t\t?.assignedElements()\n\t\t\t\t\t\t\t.find(e => e.tagName === target.component.tagName)\n\t\t\t\t\t) {\n\t\t\t\t\t\tsheet?.setAttribute('open', 'true')\n\t\t\t\t\t\treturn false\n\t\t\t\t\t} else {\n\t\t\t\t\t\treturn true // if the sheet does not have the component, continue to the next step\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t\ttap(({ target, sheet }) => {\n\t\t\t\t\tsheet?.appendChild(target.component)\n\t\t\t\t}),\n\t\t\t\tdelay(1),\n\t\t\t\ttap(({ sheet }) => {\n\t\t\t\t\tsheet?.setAttribute('open', 'true')\n\t\t\t\t}),\n\t\t\t\ttap(({ sheet }) => {\n\t\t\t\t\tfromEvent<CustomEvent>(sheet, 'close')\n\t\t\t\t\t\t.pipe(take(1))\n\t\t\t\t\t\t.pipe(delay(300))\n\t\t\t\t\t\t.subscribe(e => {\n\t\t\t\t\t\t\tconst target = e.target as SchmancySheet\n\t\t\t\t\t\t\tconsole.log(target)\n\n\t\t\t\t\t\t\tif (!target?.persist) target?.remove()\n\t\t\t\t\t\t\tdocument.body.style.overflow = 'auto' // unlock the scroll of the host\n\t\t\t\t\t\t})\n\t\t\t\t}),\n\t\t\t)\n\t\t\t.subscribe()\n\n\t\tthis.$dismiss\n\t\t\t.pipe(\n\t\t\t\tmergeMap(uid =>\n\t\t\t\t\tforkJoin([\n\t\t\t\t\t\tfromEvent<SheetHereMortyEvent>(window, SheetHereMorty).pipe(\n\t\t\t\t\t\t\ttakeUntil(timer(100)), // Some people say why 10? I say why not?\n\t\t\t\t\t\t\tmap(e => e.detail.sheet),\n\t\t\t\t\t\t\tdefaultIfEmpty(undefined),\n\t\t\t\t\t\t),\n\t\t\t\t\t\tof(uid).pipe(\n\t\t\t\t\t\t\ttap(() => {\n\t\t\t\t\t\t\t\twindow.dispatchEvent(new CustomEvent(SheetWhereAreYouRicky, { detail: { uid } }))\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\ttap(([sheet]) => {\n\t\t\t\t\tsheet?.closeSheet()\n\t\t\t\t}),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tdismiss(uid: string) {\n\t\tthis.$dismiss.next(uid)\n\t}\n\n\topen(target: BottomSheeetTarget) {\n\t\tthis.bottomSheet.next(target)\n\t}\n}\nexport const sheet = new BottomSheetService()\n","import { $LitElement } from '@mixins/index'\nimport { html } from 'lit'\nimport { customElement, property, query, queryAssignedElements } from 'lit/decorators.js'\nimport { ifDefined } from 'lit/directives/if-defined.js'\nimport { when } from 'lit/directives/when.js'\nimport { fromEvent, merge, takeUntil, tap } from 'rxjs'\nimport { on } from './hook'\nimport style from './sheet.scss?inline'\nimport {\n\tSchmancySheetPosition,\n\tSheetHereMorty,\n\tSheetWhereAreYouRicky,\n\tSheetWhereAreYouRickyEvent,\n} from './sheet.service'\n\n/**\n * `<schmancy-sheet>` component\n *\n * A modal sheet component that can be positioned at the bottom or side of the viewport.\n * Supports customizable animations, focus management, and accessibility features.\n *\n * @element schmancy-sheet\n * @fires before-close - Fired before the sheet begins closing (cancelable)\n * @fires close - Fired when the sheet has closed\n * @fires open - Fired when the sheet has opened\n */\n@customElement('schmancy-sheet')\nexport default class SchmancySheet extends $LitElement(style) {\n\t/** Unique identifier for the sheet */\n\t@property({ type: String, reflect: true }) uid!: string\n\n\t/** Controls whether the sheet is open or closed */\n\t@property({ type: Boolean, reflect: true }) open = false\n\n\t/** Controls visibility of the header section */\n\t@property({ type: String, reflect: true }) header: 'hidden' | 'visible' = 'visible'\n\n\t/** Position of the sheet */\n\t@property({ type: String, reflect: true }) position: SchmancySheetPosition = SchmancySheetPosition.Side\n\n\t/** Whether the sheet persists after closing */\n\t@property({ type: Boolean, reflect: true }) persist = false\n\n\t/** Whether clicking the overlay dismisses the sheet */\n\t@property({ type: Boolean, reflect: true }) allowOverlayDismiss = true\n\n\t/** Prevents closing by backdrop click, even if allowOverlayDismiss is true */\n\t@property({ type: Boolean }) preventBackdropClick = false\n\n\t/** Title displayed in the header */\n\t@property({ type: String, reflect: true }) title = ''\n\n\t/** Accessible label for the sheet (for screen readers) */\n\t@property({ type: String }) ariaLabel: string\n\n\t/** ARIA describedby attribute value */\n\t@property({ type: String }) ariaDescribedBy?: string\n\n\t/** Custom selector to specify which element receives focus when opened */\n\t@property({ type: String }) initialFocusSelector?: string\n\n\t/** Animation duration in milliseconds */\n\t@property({ type: Number }) animationDuration = 200\n\n\t/** Animation easing function */\n\t@property({ type: String }) animationEasing = 'ease-in-out'\n\n\t/** Attribute to specify which element should receive focus when the sheet opens */\n\t@property() focusAttribute = 'autofocus'\n\n\t/** Ref to the sheet container */\n\t@query('.sheet') private sheet!: HTMLElement\n\n\t/** Ref to the sheet body */\n\t@query('#body') bodyElement!: HTMLElement\n\n\t/** Collection of assigned elements */\n\t@queryAssignedElements({ flatten: true }) private assignedElements!: HTMLElement[]\n\n\t/** Tracks the element that had focus before the sheet opened */\n\tprivate lastFocusedElement: HTMLElement | null = null\n\n\t/** For touch interactions */\n\tprivate startY = 0\n\tprivate currentY = 0\n\n\t/** ResizeObserver instance */\n\tprivate resizeObserver: ResizeObserver | null = null\n\n\t/**\n\t * Lifecycle callback for when the 'open' property changes\n\t */\n\t@on('open')\n\tonOpenChange(_oldValue: boolean, newValue: boolean) {\n\t\tif (newValue) {\n\t\t\tthis.lastFocusedElement = document.activeElement as HTMLElement\n\t\t\tthis.addFocusTrap()\n\t\t\tthis.focus()\n\t\t\tthis.fireEvent('open')\n\t\t} else {\n\t\t\tthis.removeFocusTrap()\n\t\t\tthis.lastFocusedElement?.focus()\n\t\t\tthis.lastFocusedElement = null\n\t\t}\n\n\t\t// Update CSS variables when opening/closing\n\t\tthis.updateCssVariables()\n\t}\n\n\t/**\n\t * Component connected to DOM\n\t */\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\t\tthis.setupEventListeners()\n\n\t\t// Create resize observer\n\t\tthis.resizeObserver = new ResizeObserver(() => {\n\t\t\tif (this.open) {\n\t\t\t\tthis.updateSheetDimensions()\n\t\t\t}\n\t\t})\n\n\t\tthis.resizeObserver.observe(document.body)\n\n\t\t// Set initial CSS variables\n\t\tthis.updateCssVariables()\n\t}\n\n\t/**\n\t * First update lifecycle callback\n\t */\n\tfirstUpdated() {\n\t\t// Add passive scroll listeners for better performance\n\t\tthis.bodyElement?.addEventListener('scroll', this.handleScroll, { passive: true })\n\t}\n\n\t/**\n\t * Component updated lifecycle callback\n\t */\n\tupdated(changedProps: Map<string, unknown>) {\n\t\tif (changedProps.has('animationDuration') || changedProps.has('animationEasing')) {\n\t\t\tthis.updateCssVariables()\n\t\t}\n\t}\n\n\t/**\n\t * Component disconnected from DOM\n\t */\n\tdisconnectedCallback() {\n\t\tsuper.disconnectedCallback()\n\t\tthis.disconnecting.next(true)\n\t\tthis.bodyElement?.removeEventListener('scroll', this.handleScroll)\n\t\tthis.resizeObserver?.disconnect()\n\t}\n\n\t/**\n\t * Updates CSS custom properties\n\t */\n\tprivate updateCssVariables() {\n\t\tthis.style.setProperty('--transition-duration', `${this.animationDuration}ms`)\n\t\tthis.style.setProperty('--transition-timing', this.animationEasing)\n\t}\n\n\t/**\n\t * Sets up event listeners\n\t */\n\tprivate setupEventListeners() {\n\t\t// Handle browser back button\n\t\tconst popState$ = fromEvent<PopStateEvent>(window, 'popstate').pipe(\n\t\t\ttap(e => {\n\t\t\t\te.preventDefault()\n\t\t\t\tthis.closeSheet()\n\t\t\t}),\n\t\t)\n\n\t\t// Handle ESC key\n\t\tconst keyUp$ = fromEvent<KeyboardEvent>(window, 'keyup').pipe(\n\t\t\ttap(event => {\n\t\t\t\tif (event.key === 'Escape' && !this.sheetContainsFocus()) {\n\t\t\t\t\tthis.closeSheet()\n\t\t\t\t}\n\t\t\t}),\n\t\t)\n\n\t\t// Handle inter-component communication\n\t\tconst rickyComm$ = fromEvent<SheetWhereAreYouRickyEvent>(window, SheetWhereAreYouRicky).pipe(\n\t\t\ttap(e => {\n\t\t\t\tif (e.detail.uid === this.uid) this.announcePresence()\n\t\t\t}),\n\t\t)\n\n\t\tmerge(popState$, keyUp$, rickyComm$).pipe(takeUntil(this.disconnecting)).subscribe()\n\t}\n\n\t/**\n\t * Check if focus is within the sheet\n\t */\n\tprivate sheetContainsFocus(): boolean {\n\t\treturn this.sheet?.contains(document.activeElement) ?? false\n\t}\n\n\t/**\n\t * Announce presence to the sheet service\n\t */\n\tprivate announcePresence() {\n\t\tthis.dispatchEvent(\n\t\t\tnew CustomEvent(SheetHereMorty, {\n\t\t\t\tdetail: { sheet: this },\n\t\t\t\tbubbles: true,\n\t\t\t\tcomposed: true,\n\t\t\t}),\n\t\t)\n\t}\n\n\t/**\n\t * Add focus trap to keep focus within sheet when open\n\t */\n\tprivate addFocusTrap() {\n\t\tdocument.addEventListener('focusin', this.handleFocusIn)\n\t}\n\n\t/**\n\t * Remove focus trap\n\t */\n\tprivate removeFocusTrap() {\n\t\tdocument.removeEventListener('focusin', this.handleFocusIn)\n\t}\n\n\t/**\n\t * Handle focus events to trap focus\n\t */\n\tprivate handleFocusIn = (e: Event) => {\n\t\tif (!this.sheet?.contains(e.target as Node)) {\n\t\t\tthis.focus()\n\t\t}\n\t}\n\n\t/**\n\t * Handle scroll events\n\t */\n\tprivate handleScroll = () => {\n\t\t// Implement scroll handling if needed\n\t}\n\n\t/**\n\t * Updates the aria-hidden and aria-modal attributes\n\t */\n\tsetIsSheetShown(isShown: boolean) {\n\t\tthis.sheet?.setAttribute('aria-hidden', String(!isShown))\n\t\tthis.sheet?.setAttribute('aria-modal', String(isShown))\n\t}\n\n\t/**\n\t * Closes the sheet\n\t */\n\tcloseSheet() {\n\t\t// Fire before-close event, allow prevention\n\t\tconst event = new CustomEvent('before-close', {\n\t\t\tbubbles: true,\n\t\t\tcomposed: true,\n\t\t\tcancelable: true,\n\t\t})\n\n\t\tconst allowed = this.dispatchEvent(event)\n\n\t\tif (!allowed) return // User prevented close\n\n\t\tthis.open = false\n\t\tthis.fireEvent('close')\n\t}\n\n\t/**\n\t * Update dimensions based on viewport\n\t */\n\tprivate updateSheetDimensions() {\n\t\tif (this.position === SchmancySheetPosition.Bottom) {\n\t\t\tconst content = this.shadowRoot?.querySelector('.content') as HTMLElement\n\t\t\tif (content) {\n\t\t\t\tcontent.style.maxHeight = `${window.innerHeight * 0.9}px`\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Find the element that should receive focus\n\t */\n\tprivate getFocusElement(): HTMLElement | null {\n\t\t// If initialFocusSelector is provided, use that first\n\t\tif (this.initialFocusSelector) {\n\t\t\tconst element = this.shadowRoot?.querySelector(this.initialFocusSelector) as HTMLElement\n\t\t\tif (element) return element\n\t\t}\n\n\t\t// Otherwise, try to find element with focusAttribute\n\t\tconst selector = `[${this.focusAttribute}]`\n\t\treturn (this.assignedElements.find(el => el.matches(selector) || el.querySelector(selector)) as HTMLElement) ?? null\n\t}\n\n\t/**\n\t * Set focus within the sheet\n\t */\n\toverride focus() {\n\t\tthis.getFocusElement()?.focus()\n\t}\n\n\t/**\n\t * Fire events with consistent format\n\t */\n\tprivate fireEvent(name: string, detail = {}) {\n\t\tthis.dispatchEvent(\n\t\t\tnew CustomEvent(name, {\n\t\t\t\tbubbles: true,\n\t\t\t\tcomposed: true,\n\t\t\t\tdetail,\n\t\t\t}),\n\t\t)\n\t}\n\n\t/**\n\t * Handle touch start for swipe gesture\n\t */\n\tprivate handleTouchStart = (e: TouchEvent) => {\n\t\tif (this.position === SchmancySheetPosition.Bottom) {\n\t\t\tthis.startY = e.touches[0].clientY\n\t\t\tthis.currentY = this.startY\n\t\t}\n\t}\n\n\t/**\n\t * Handle touch move for swipe gesture\n\t */\n\tprivate handleTouchMove = (e: TouchEvent) => {\n\t\tif (this.position === SchmancySheetPosition.Bottom) {\n\t\t\tthis.currentY = e.touches[0].clientY\n\t\t\tconst deltaY = this.currentY - this.startY\n\n\t\t\t// Only allow downward swipes to close\n\t\t\tif (deltaY > 0) {\n\t\t\t\tconst content = e.currentTarget as HTMLElement\n\t\t\t\tcontent.style.transform = `translateY(${deltaY}px)`\n\t\t\t\te.preventDefault()\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Handle touch end for swipe gesture\n\t */\n\tprivate handleTouchEnd = (e: TouchEvent) => {\n\t\tif (this.position === SchmancySheetPosition.Bottom) {\n\t\t\tconst content = e.currentTarget as HTMLElement\n\t\t\tconst deltaY = this.currentY - this.startY\n\n\t\t\t// Reset transform\n\t\t\tcontent.style.transform = ''\n\n\t\t\t// If dragged down more than 100px or 30% of height, close the sheet\n\t\t\tconst threshold = Math.min(100, content.offsetHeight * 0.3)\n\t\t\tif (deltaY > threshold) {\n\t\t\t\tthis.closeSheet()\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Render the component\n\t */\n\trender() {\n\t\treturn html`\n\t\t\t<div\n\t\t\t\tclass=\"sheet\"\n\t\t\t\trole=\"dialog\"\n\t\t\t\taria-labelledby=${ifDefined(this.title ? 'sheet-title' : this.ariaLabel ? 'sheet-aria-label' : undefined)}\n\t\t\t\taria-describedby=${ifDefined(this.ariaDescribedBy)}\n\t\t\t\taria-hidden=${!this.open}\n\t\t\t\taria-modal=${this.open}\n\t\t\t>\n\t\t\t\t${when(\n\t\t\t\t\tthis.ariaLabel && !this.title,\n\t\t\t\t\t() => html`<span id=\"sheet-aria-label\" class=\"sr-only\">${this.ariaLabel}</span>`,\n\t\t\t\t)}\n\n\t\t\t\t<div\n\t\t\t\t\tclass=\"overlay\"\n\t\t\t\t\t@click=${(e: Event) => {\n\t\t\t\t\t\te.stopPropagation()\n\t\t\t\t\t\tif (this.allowOverlayDismiss && !this.preventBackdropClick) {\n\t\t\t\t\t\t\tthis.closeSheet()\n\t\t\t\t\t\t}\n\t\t\t\t\t}}\n\t\t\t\t></div>\n\n\t\t\t\t<schmancy-grid\n\t\t\t\t\t@touchstart=${this.handleTouchStart}\n\t\t\t\t\t@touchmove=${this.handleTouchMove}\n\t\t\t\t\t@touchend=${this.handleTouchEnd}\n\t\t\t\t\trows=${this.header === 'hidden' ? '1fr' : 'auto 1fr'}\n\t\t\t\t\tclass=\"content w-full\"\n\t\t\t\t\tdata-position=${this.position}\n\t\t\t\t>\n\t\t\t\t\t${when(\n\t\t\t\t\t\tthis.header !== 'hidden',\n\t\t\t\t\t\t() =>\n\t\t\t\t\t\t\thtml`<schmancy-sheet-header\n\t\t\t\t\t\t\t\tclass=\"sticky top-0 z-50 w-full\"\n\t\t\t\t\t\t\t\t@dismiss=${(e: CustomEvent) => {\n\t\t\t\t\t\t\t\t\te.stopPropagation()\n\t\t\t\t\t\t\t\t\tthis.closeSheet()\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\tid=\"sheet-title\"\n\t\t\t\t\t\t\t\ttitle=${this.title}\n\t\t\t\t\t\t\t></schmancy-sheet-header>`,\n\t\t\t\t\t)}\n\n\t\t\t\t\t<schmancy-surface rounded=\"left\" fill=\"all\" id=\"body\" class=\"overflow-hidden\" type=\"surface\">\n\t\t\t\t\t\t<schmancy-scroll>\n\t\t\t\t\t\t\t<slot></slot>\n\t\t\t\t\t\t</schmancy-scroll>\n\t\t\t\t\t</schmancy-surface>\n\t\t\t\t</schmancy-grid>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-sheet': SchmancySheet\n\t}\n}\n","// @watch decorator\n//\n// Runs when an observed property changes, e.g. @property or @state, but before the component updates.\n//\n// To wait for an update to complete after a change occurs, use `await this.updateComplete` in the handler. To start\n// watching after the initial update/render, use `{ waitUntilFirstUpdate: true }` or `this.hasUpdated` in the handler.\n//\n// Usage:\n//\n// @watch('propName')\n// handlePropChange(oldValue, newValue) {\n// ...\n// }\n//\ninterface WatchOptions {\n\twaitUntilFirstUpdate?: boolean\n}\n\nexport function on(propName: string, options?: WatchOptions) {\n\treturn (protoOrDescriptor: any, name: string): any => {\n\t\tconst { willUpdate } = protoOrDescriptor\n\n\t\toptions = Object.assign({ waitUntilFirstUpdate: false }, options) as WatchOptions\n\n\t\tprotoOrDescriptor.willUpdate = function (changedProps: Map<string, any>) {\n\t\t\twillUpdate.call(this, changedProps)\n\n\t\t\tif (changedProps.has(propName)) {\n\t\t\t\tconst oldValue = changedProps.get(propName)\n\t\t\t\tconst newValue = this[propName]\n\n\t\t\t\tif (oldValue !== newValue) {\n\t\t\t\t\tif (!options?.waitUntilFirstUpdate || this.hasUpdated) {\n\t\t\t\t\t\tthis[name].call(this, oldValue, newValue)\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n}\n"],"names":["SchmancySheetHeader","TailwindElement","css","html","this","dispatchEvent","CustomEvent","bubbles","composed","customElement","SchmancySheetPosition","SheetWhereAreYouRicky","SheetHereMorty","sheet","bottomSheet","Subject","$dismiss","pipe","switchMap","forkJoin","fromEvent","window","takeUntil","timer","map","e","detail","defaultIfEmpty","of","target","tap","uid","component","tagName","document","createElement","body","appendChild","setAttribute","position","innerWidth","allowOverlyDismiss","title","persist","header","style","overflow","delay","filter","shadowRoot","querySelector","assignedElements","find","take","subscribe","remove","mergeMap","closeSheet","next","SchmancySheet","$LitElement","super","arguments","open","Side","allowOverlayDismiss","preventBackdropClick","animationDuration","animationEasing","focusAttribute","lastFocusedElement","startY","currentY","resizeObserver","handleFocusIn","contains","focus","handleScroll","handleTouchStart","Bottom","touches","clientY","handleTouchMove","deltaY","currentTarget","transform","preventDefault","handleTouchEnd","content","Math","min","offsetHeight","_oldValue","newValue","activeElement","addFocusTrap","fireEvent","removeFocusTrap","updateCssVariables","connectedCallback","setupEventListeners","ResizeObserver","updateSheetDimensions","observe","bodyElement","addEventListener","passive","changedProps","has","disconnectedCallback","disconnecting","removeEventListener","disconnect","setProperty","popState$","keyUp$","event","key","sheetContainsFocus","rickyComm$","announcePresence","merge","isShown","String","cancelable","maxHeight","innerHeight","initialFocusSelector","element","selector","el","matches","getFocusElement","name","ifDefined","ariaLabel","ariaDescribedBy","when","stopPropagation","propName","options","__decorateClass","property","type","reflect","prototype","Boolean","Number","query","queryAssignedElements","flatten","protoOrDescriptor","willUpdate","Object","assign","waitUntilFirstUpdate","call","oldValue","get","hasUpdated"],"mappings":"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"}
|
package/dist/sheet.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./sheet-
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./sheet-CwzonocJ.cjs");exports.SchmancySheetPosition=e.SchmancySheetPosition,exports.SheetHereMorty=e.SheetHereMorty,exports.SheetWhereAreYouRicky=e.SheetWhereAreYouRicky,exports.sheet=e.sheet;
|
|
2
2
|
//# sourceMappingURL=sheet.cjs.map
|
package/dist/sheet.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { fromEvent as x } from "rxjs";
|
|
2
2
|
import "lit/directives/class-map.js";
|
|
3
3
|
import "lit/directives/style-map.js";
|
|
4
|
-
import { $ as f } from "./litElement.mixin-
|
|
5
|
-
import "./tailwind.mixin-
|
|
4
|
+
import { $ as f } from "./litElement.mixin-DfYInjJd.js";
|
|
5
|
+
import "./tailwind.mixin-BvhzMkqK.js";
|
|
6
6
|
import { css as m, html as c } from "lit";
|
|
7
7
|
import { property as d, customElement as v, state as S, query as y } from "lit/decorators.js";
|
|
8
8
|
import { cache as w } from "lit/directives/cache.js";
|
|
@@ -162,4 +162,4 @@ export {
|
|
|
162
162
|
n as S,
|
|
163
163
|
h as a
|
|
164
164
|
};
|
|
165
|
-
//# sourceMappingURL=slider-
|
|
165
|
+
//# sourceMappingURL=slider-2mhXBUIM.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"slider-A_LoTZ1P.js","sources":["../src/slider/slide.ts","../src/slider/slider.ts"],"sourcesContent":["import { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { cache } from 'lit/directives/cache.js'\n\n/**\n * Supported slide \"types.\"\n * - 'image': Renders an <img>\n * - 'video': Renders a <video>\n * - 'content': Renders a <slot> (the default)\n */\ntype SlideType = 'image' | 'video' | 'content'\n\n/**\n * Allowed values for the 'fit' property,\n * which maps to CSS object-fit.\n */\ntype ObjectFit = 'cover' | 'contain' | 'fill' | 'scale-down' | 'none'\n\n@customElement('schmancy-slide')\nexport class SchmancySlide extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tscroll-snap-align: center; /* If your slider uses scroll-snap */\n\t}\n\n\t.slide {\n\t\tdisplay: block;\n\t\twidth: 100%;\n\t\theight: auto;\n\t\tobject-fit: var(--object-fit, cover);\n\t}\n`) {\n\t/**\n\t * Determines how this slide should be rendered.\n\t * Defaults to 'content' if not provided.\n\t */\n\t@property({ type: String }) type: SlideType = 'content'\n\n\t/**\n\t * Source for images or videos (if `type` is 'image' or 'video').\n\t */\n\t@property({ type: String }) src: string = ''\n\n\t/**\n\t * Alternate text for images.\n\t */\n\t@property({ type: String }) alt: string = ''\n\n\t/**\n\t * Whether to show default video controls (if `type` is 'video').\n\t */\n\t@property({ type: Boolean }) controls = true\n\n\t/**\n\t * Whether the video should autoplay (if `type` is 'video').\n\t */\n\t@property({ type: Boolean }) autoplay = false\n\n\t/**\n\t * Whether the video should loop (if `type` is 'video').\n\t */\n\t@property({ type: Boolean }) loop = false\n\n\t/**\n\t * Whether the video is muted (if `type` is 'video').\n\t */\n\t@property({ type: Boolean }) muted = false\n\n\t/**\n\t * CSS `object-fit` property, applied to images/videos.\n\t */\n\t@property({ type: String }) fit: ObjectFit = 'cover'\n\n\trender() {\n\t\treturn html` <div style=\"--object-fit: ${this.fit}\">${cache(this.renderSlide())}</div> `\n\t}\n\n\tprivate renderSlide() {\n\t\tswitch (this.type) {\n\t\t\tcase 'image':\n\t\t\t\treturn html` <img class=\"slide\" src=\"${this.src}\" alt=\"${this.alt}\" loading=\"lazy\" /> `\n\t\t\tcase 'video':\n\t\t\t\treturn html`\n\t\t\t\t\t<video\n\t\t\t\t\t\tclass=\"slide\"\n\t\t\t\t\t\tsrc=\"${this.src}\"\n\t\t\t\t\t\t?controls=\"${this.controls}\"\n\t\t\t\t\t\t?autoplay=\"${this.autoplay}\"\n\t\t\t\t\t\t?loop=\"${this.loop}\"\n\t\t\t\t\t\t?muted=\"${this.muted}\"\n\t\t\t\t\t>\n\t\t\t\t\t\tYour browser does not support HTML video.\n\t\t\t\t\t</video>\n\t\t\t\t`\n\t\t\tcase 'content':\n\t\t\tdefault:\n\t\t\t\treturn html`<slot></slot>`\n\t\t}\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-slide': SchmancySlide\n\t}\n}\n","import { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query, state } from 'lit/decorators.js'\nimport { fromEvent } from 'rxjs'\nimport { throttleTime } from 'rxjs/operators'\n\n@customElement('schmancy-slider')\nexport class SchmancySlider extends $LitElement(css`\n\t.slider {\n\t\t/* Lay out slides horizontally, one after another */\n\t\tdisplay: flex;\n\t\toverflow-x: auto;\n\n\t\t/* Optional: scroll snapping */\n\t\tscroll-snap-type: x mandatory;\n\n\t\t/* Hide scrollbars */\n\t\t-ms-overflow-style: none; /* IE and Edge */\n\t\tscrollbar-width: none; /* Firefox */\n\t}\n\t.slider::-webkit-scrollbar {\n\t\tdisplay: none; /* Chrome, Safari, Opera */\n\t}\n\n\t/* \n Ensure each slide takes up the full slider width.\n \"schmancy-slide\" is the child custom element.\n */\n\t::slotted(schmancy-slide) {\n\t\tflex: 0 0 100%;\n\t\tbox-sizing: border-box;\n\t}\n`) {\n\t/**\n\t * Currently centered slide index\n\t */\n\t@state() private selectedIndex: number = 0\n\n\t/**\n\t * If true, renders next/prev buttons\n\t */\n\t@property({ type: Boolean }) showArrows: boolean = true\n\n\t@query('#slider') private slider!: HTMLDivElement\n\t@query('slot') private defaultSlot!: HTMLSlotElement\n\n\tprotected firstUpdated() {\n\t\t// Start at leftmost position\n\t\tthis.slider.scrollLeft = 0\n\n\t\t// Throttle scroll events to update selected index\n\t\tfromEvent(this.slider, 'scroll')\n\t\t\t.pipe(throttleTime(100, undefined, { trailing: true }))\n\t\t\t.subscribe(() => {\n\t\t\t\tthis.updateSelectedIndexOnScroll()\n\t\t\t})\n\t}\n\n\tprivate updateSelectedIndexOnScroll() {\n\t\tconst slides = this.defaultSlot?.assignedElements({ flatten: true }) ?? []\n\t\tif (!slides.length) return\n\n\t\tconst oldIndex = this.selectedIndex\n\n\t\t// Center of the slider’s visible area\n\t\tconst sliderCenter = this.slider.scrollLeft + this.slider.clientWidth / 2\n\n\t\tlet closestIndex = 0\n\t\tlet closestDistance = Infinity\n\n\t\tslides.forEach((slide, index) => {\n\t\t\tconst itemStart = (slide as HTMLElement).offsetLeft\n\t\t\tconst itemCenter = itemStart + slide.clientWidth / 2\n\t\t\tconst distance = Math.abs(sliderCenter - itemCenter)\n\n\t\t\tif (distance < closestDistance) {\n\t\t\t\tclosestDistance = distance\n\t\t\t\tclosestIndex = index\n\t\t\t}\n\t\t})\n\n\t\tthis.selectedIndex = closestIndex\n\n\t\t// If the index changed, dispatch event\n\t\tif (this.selectedIndex !== oldIndex) {\n\t\t\tthis.dispatchEvent(\n\t\t\t\tnew CustomEvent('slide-changed', {\n\t\t\t\t\tdetail: { index: this.selectedIndex },\n\t\t\t\t}),\n\t\t\t)\n\t\t}\n\t}\n\n\tprivate goToSlide(newIndex: number) {\n\t\tconst slides = this.defaultSlot?.assignedElements({ flatten: true }) ?? []\n\t\tif (!slides[newIndex]) return\n\n\t\tthis.slider.scrollTo({\n\t\t\tleft: (slides[newIndex] as HTMLElement).offsetLeft,\n\t\t\tbehavior: 'smooth',\n\t\t})\n\t}\n\n\tprivate onPrevClick() {\n\t\tthis.goToSlide(this.selectedIndex - 1)\n\t}\n\n\tprivate onNextClick() {\n\t\tconst slides = this.defaultSlot?.assignedElements({ flatten: true }) ?? []\n\t\tif (this.selectedIndex < slides.length - 1) {\n\t\t\tthis.goToSlide(this.selectedIndex + 1)\n\t\t}\n\t}\n\n\trender() {\n\t\tconst slides = this.defaultSlot?.assignedElements({ flatten: true }) ?? []\n\n\t\treturn html`\n\t\t\t<div class=\"relative inset-0\">\n\t\t\t\t<!-- The scrollable track -->\n\t\t\t\t<div class=\"slider\" id=\"slider\">\n\t\t\t\t\t<slot></slot>\n\t\t\t\t</div>\n\n\t\t\t\t<!-- Next/Prev Buttons (Optional) -->\n\t\t\t\t${this.showArrows\n\t\t\t\t\t? html`\n\t\t\t\t\t\t\t<schmancy-icon-button\n\t\t\t\t\t\t\t\tclass=\"absolute left-2 top-1/2 -translate-y-1/2\"\n\t\t\t\t\t\t\t\t@click=${this.onPrevClick}\n\t\t\t\t\t\t\t\t?disabled=${this.selectedIndex === 0}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\tchevron_left\n\t\t\t\t\t\t\t</schmancy-icon-button>\n\t\t\t\t\t\t\t<schmancy-icon-button\n\t\t\t\t\t\t\t\tclass=\"absolute right-2 top-1/2 -translate-y-1/2\"\n\t\t\t\t\t\t\t\t@click=${this.onNextClick}\n\t\t\t\t\t\t\t\t?disabled=${this.selectedIndex === slides.length - 1}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\tchevron_right\n\t\t\t\t\t\t\t</schmancy-icon-button>\n\t\t\t\t\t\t`\n\t\t\t\t\t: null}\n\n\t\t\t\t<!-- Dots / indicators -->\n\t\t\t\t<div class=\"absolute bottom-4 left-1/2 -translate-x-1/2 flex space-x-2\">\n\t\t\t\t\t${slides.map((_, index) => {\n\t\t\t\t\t\tconst isSelected = index === this.selectedIndex\n\t\t\t\t\t\treturn html`\n\t\t\t\t\t\t\t<schmancy-button .variant=${isSelected ? 'filled tonal' : 'outlined'} class=\"rounded-full \">\n\t\t\t\t\t\t\t</schmancy-button>\n\t\t\t\t\t\t`\n\t\t\t\t\t})}\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-slider': SchmancySlider\n\t}\n}\n"],"names":["SchmancySlide","$LitElement","css","constructor","super","arguments","this","type","src","alt","controls","autoplay","loop","muted","fit","html","cache","renderSlide","__decorateClass","property","String","prototype","Boolean","customElement","SchmancySlider","selectedIndex","showArrows","slider","scrollLeft","fromEvent","pipe","throttleTime","trailing","subscribe","updateSelectedIndexOnScroll","slides","defaultSlot","assignedElements","flatten","length","oldIndex","sliderCenter","clientWidth","closestIndex","closestDistance","Infinity","forEach","slide","index","itemCenter","offsetLeft","distance","Math","abs","dispatchEvent","CustomEvent","detail","newIndex","scrollTo","left","behavior","goToSlide","onNextClick","render","onPrevClick","map","_","isSelected","state","query"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"slider-2mhXBUIM.js","sources":["../src/slider/slide.ts","../src/slider/slider.ts"],"sourcesContent":["import { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { cache } from 'lit/directives/cache.js'\n\n/**\n * Supported slide \"types.\"\n * - 'image': Renders an <img>\n * - 'video': Renders a <video>\n * - 'content': Renders a <slot> (the default)\n */\ntype SlideType = 'image' | 'video' | 'content'\n\n/**\n * Allowed values for the 'fit' property,\n * which maps to CSS object-fit.\n */\ntype ObjectFit = 'cover' | 'contain' | 'fill' | 'scale-down' | 'none'\n\n@customElement('schmancy-slide')\nexport class SchmancySlide extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tscroll-snap-align: center; /* If your slider uses scroll-snap */\n\t}\n\n\t.slide {\n\t\tdisplay: block;\n\t\twidth: 100%;\n\t\theight: auto;\n\t\tobject-fit: var(--object-fit, cover);\n\t}\n`) {\n\t/**\n\t * Determines how this slide should be rendered.\n\t * Defaults to 'content' if not provided.\n\t */\n\t@property({ type: String }) type: SlideType = 'content'\n\n\t/**\n\t * Source for images or videos (if `type` is 'image' or 'video').\n\t */\n\t@property({ type: String }) src: string = ''\n\n\t/**\n\t * Alternate text for images.\n\t */\n\t@property({ type: String }) alt: string = ''\n\n\t/**\n\t * Whether to show default video controls (if `type` is 'video').\n\t */\n\t@property({ type: Boolean }) controls = true\n\n\t/**\n\t * Whether the video should autoplay (if `type` is 'video').\n\t */\n\t@property({ type: Boolean }) autoplay = false\n\n\t/**\n\t * Whether the video should loop (if `type` is 'video').\n\t */\n\t@property({ type: Boolean }) loop = false\n\n\t/**\n\t * Whether the video is muted (if `type` is 'video').\n\t */\n\t@property({ type: Boolean }) muted = false\n\n\t/**\n\t * CSS `object-fit` property, applied to images/videos.\n\t */\n\t@property({ type: String }) fit: ObjectFit = 'cover'\n\n\trender() {\n\t\treturn html` <div style=\"--object-fit: ${this.fit}\">${cache(this.renderSlide())}</div> `\n\t}\n\n\tprivate renderSlide() {\n\t\tswitch (this.type) {\n\t\t\tcase 'image':\n\t\t\t\treturn html` <img class=\"slide\" src=\"${this.src}\" alt=\"${this.alt}\" loading=\"lazy\" /> `\n\t\t\tcase 'video':\n\t\t\t\treturn html`\n\t\t\t\t\t<video\n\t\t\t\t\t\tclass=\"slide\"\n\t\t\t\t\t\tsrc=\"${this.src}\"\n\t\t\t\t\t\t?controls=\"${this.controls}\"\n\t\t\t\t\t\t?autoplay=\"${this.autoplay}\"\n\t\t\t\t\t\t?loop=\"${this.loop}\"\n\t\t\t\t\t\t?muted=\"${this.muted}\"\n\t\t\t\t\t>\n\t\t\t\t\t\tYour browser does not support HTML video.\n\t\t\t\t\t</video>\n\t\t\t\t`\n\t\t\tcase 'content':\n\t\t\tdefault:\n\t\t\t\treturn html`<slot></slot>`\n\t\t}\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-slide': SchmancySlide\n\t}\n}\n","import { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query, state } from 'lit/decorators.js'\nimport { fromEvent } from 'rxjs'\nimport { throttleTime } from 'rxjs/operators'\n\n@customElement('schmancy-slider')\nexport class SchmancySlider extends $LitElement(css`\n\t.slider {\n\t\t/* Lay out slides horizontally, one after another */\n\t\tdisplay: flex;\n\t\toverflow-x: auto;\n\n\t\t/* Optional: scroll snapping */\n\t\tscroll-snap-type: x mandatory;\n\n\t\t/* Hide scrollbars */\n\t\t-ms-overflow-style: none; /* IE and Edge */\n\t\tscrollbar-width: none; /* Firefox */\n\t}\n\t.slider::-webkit-scrollbar {\n\t\tdisplay: none; /* Chrome, Safari, Opera */\n\t}\n\n\t/* \n Ensure each slide takes up the full slider width.\n \"schmancy-slide\" is the child custom element.\n */\n\t::slotted(schmancy-slide) {\n\t\tflex: 0 0 100%;\n\t\tbox-sizing: border-box;\n\t}\n`) {\n\t/**\n\t * Currently centered slide index\n\t */\n\t@state() private selectedIndex: number = 0\n\n\t/**\n\t * If true, renders next/prev buttons\n\t */\n\t@property({ type: Boolean }) showArrows: boolean = true\n\n\t@query('#slider') private slider!: HTMLDivElement\n\t@query('slot') private defaultSlot!: HTMLSlotElement\n\n\tprotected firstUpdated() {\n\t\t// Start at leftmost position\n\t\tthis.slider.scrollLeft = 0\n\n\t\t// Throttle scroll events to update selected index\n\t\tfromEvent(this.slider, 'scroll')\n\t\t\t.pipe(throttleTime(100, undefined, { trailing: true }))\n\t\t\t.subscribe(() => {\n\t\t\t\tthis.updateSelectedIndexOnScroll()\n\t\t\t})\n\t}\n\n\tprivate updateSelectedIndexOnScroll() {\n\t\tconst slides = this.defaultSlot?.assignedElements({ flatten: true }) ?? []\n\t\tif (!slides.length) return\n\n\t\tconst oldIndex = this.selectedIndex\n\n\t\t// Center of the slider’s visible area\n\t\tconst sliderCenter = this.slider.scrollLeft + this.slider.clientWidth / 2\n\n\t\tlet closestIndex = 0\n\t\tlet closestDistance = Infinity\n\n\t\tslides.forEach((slide, index) => {\n\t\t\tconst itemStart = (slide as HTMLElement).offsetLeft\n\t\t\tconst itemCenter = itemStart + slide.clientWidth / 2\n\t\t\tconst distance = Math.abs(sliderCenter - itemCenter)\n\n\t\t\tif (distance < closestDistance) {\n\t\t\t\tclosestDistance = distance\n\t\t\t\tclosestIndex = index\n\t\t\t}\n\t\t})\n\n\t\tthis.selectedIndex = closestIndex\n\n\t\t// If the index changed, dispatch event\n\t\tif (this.selectedIndex !== oldIndex) {\n\t\t\tthis.dispatchEvent(\n\t\t\t\tnew CustomEvent('slide-changed', {\n\t\t\t\t\tdetail: { index: this.selectedIndex },\n\t\t\t\t}),\n\t\t\t)\n\t\t}\n\t}\n\n\tprivate goToSlide(newIndex: number) {\n\t\tconst slides = this.defaultSlot?.assignedElements({ flatten: true }) ?? []\n\t\tif (!slides[newIndex]) return\n\n\t\tthis.slider.scrollTo({\n\t\t\tleft: (slides[newIndex] as HTMLElement).offsetLeft,\n\t\t\tbehavior: 'smooth',\n\t\t})\n\t}\n\n\tprivate onPrevClick() {\n\t\tthis.goToSlide(this.selectedIndex - 1)\n\t}\n\n\tprivate onNextClick() {\n\t\tconst slides = this.defaultSlot?.assignedElements({ flatten: true }) ?? []\n\t\tif (this.selectedIndex < slides.length - 1) {\n\t\t\tthis.goToSlide(this.selectedIndex + 1)\n\t\t}\n\t}\n\n\trender() {\n\t\tconst slides = this.defaultSlot?.assignedElements({ flatten: true }) ?? []\n\n\t\treturn html`\n\t\t\t<div class=\"relative inset-0\">\n\t\t\t\t<!-- The scrollable track -->\n\t\t\t\t<div class=\"slider\" id=\"slider\">\n\t\t\t\t\t<slot></slot>\n\t\t\t\t</div>\n\n\t\t\t\t<!-- Next/Prev Buttons (Optional) -->\n\t\t\t\t${this.showArrows\n\t\t\t\t\t? html`\n\t\t\t\t\t\t\t<schmancy-icon-button\n\t\t\t\t\t\t\t\tclass=\"absolute left-2 top-1/2 -translate-y-1/2\"\n\t\t\t\t\t\t\t\t@click=${this.onPrevClick}\n\t\t\t\t\t\t\t\t?disabled=${this.selectedIndex === 0}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\tchevron_left\n\t\t\t\t\t\t\t</schmancy-icon-button>\n\t\t\t\t\t\t\t<schmancy-icon-button\n\t\t\t\t\t\t\t\tclass=\"absolute right-2 top-1/2 -translate-y-1/2\"\n\t\t\t\t\t\t\t\t@click=${this.onNextClick}\n\t\t\t\t\t\t\t\t?disabled=${this.selectedIndex === slides.length - 1}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\tchevron_right\n\t\t\t\t\t\t\t</schmancy-icon-button>\n\t\t\t\t\t\t`\n\t\t\t\t\t: null}\n\n\t\t\t\t<!-- Dots / indicators -->\n\t\t\t\t<div class=\"absolute bottom-4 left-1/2 -translate-x-1/2 flex space-x-2\">\n\t\t\t\t\t${slides.map((_, index) => {\n\t\t\t\t\t\tconst isSelected = index === this.selectedIndex\n\t\t\t\t\t\treturn html`\n\t\t\t\t\t\t\t<schmancy-button .variant=${isSelected ? 'filled tonal' : 'outlined'} class=\"rounded-full \">\n\t\t\t\t\t\t\t</schmancy-button>\n\t\t\t\t\t\t`\n\t\t\t\t\t})}\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-slider': SchmancySlider\n\t}\n}\n"],"names":["SchmancySlide","$LitElement","css","constructor","super","arguments","this","type","src","alt","controls","autoplay","loop","muted","fit","html","cache","renderSlide","__decorateClass","property","String","prototype","Boolean","customElement","SchmancySlider","selectedIndex","showArrows","slider","scrollLeft","fromEvent","pipe","throttleTime","trailing","subscribe","updateSelectedIndexOnScroll","slides","defaultSlot","assignedElements","flatten","length","oldIndex","sliderCenter","clientWidth","closestIndex","closestDistance","Infinity","forEach","slide","index","itemCenter","offsetLeft","distance","Math","abs","dispatchEvent","CustomEvent","detail","newIndex","scrollTo","left","behavior","goToSlide","onNextClick","render","onPrevClick","map","_","isSelected","state","query"],"mappings":";;;;;;;;;;;;;AAoBa,IAAAA,IAAN,cAA4BC,EAAYC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;EAAxC,cAAAC;AAAAC,UAAAC,GAAAA,SAAAA,GAiBwCC,KAAAC,OAAA,WAKJD,KAAAE,MAAA,IAKAF,KAAAG,MAAA,IAKFH,KAAAI,eAKAJ,KAAAK,WAAA,IAKJL,KAAAM,OAAAA,IAKCN,KAAAO,QAAA,IAKQP,KAAAQ,MAAA;AAAA,EAAA;AAAA,EAE7C,SACQ;AAAA,WAAAC,+BAAkCT,KAAKQ,GAAAA,KAAQE,EAAMV,KAAKW,YAAc,CAAA,CAAA;AAAA,EAAA;AAAA,EAGxE,cAAAA;AACP,YAAQX,KAAKC;MACZ,KAAK;AACJ,eAAOQ,6BAAgCT,KAAKE,GAAaF,UAAAA,KAAKG,GAC/D;AAAA,MAAA,KAAK;AACG,eAAAM;AAAAA;AAAAA;AAAAA,aAGET,KAAKE,GAAAA;AAAAA,mBACCF,KAAKI,QAAAA;AAAAA,mBACLJ,KAAKK,QAAAA;AAAAA,eACTL,KAAKM,IAAAA;AAAAA,gBACJN,KAAKO,KAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,MAMlB;AACQ,eAAAE;AAAAA,IACT;AAAA,EAAA;AAAA;AA7D2BG,EAAA,CAA3BC,EAAS,EAAEZ,MAAMa,OAjBNpB,CAAAA,CAAAA,GAAAA,EAiBgBqB,WAAA,QAAA,IAKAH,EAAA,CAA3BC,EAAS,EAAEZ,MAAMa,OAAAA,CAAAA,CAAAA,GAtBNpB,EAsBgBqB,WAAA,OAAA,CAKAH,GAAAA,EAAA,CAA3BC,EAAS,EAAEZ,MAAMa,OAAAA,CAAAA,CAAAA,GA3BNpB,EA2BgBqB,WAAA,OAAA,CAKCH,GAAAA,EAAA,CAA5BC,EAAS,EAAEZ,MAAMe,QAhCNtB,CAAAA,CAAAA,GAAAA,EAgCiBqB,WAAA,YAAA,CAAA,GAKAH,EAAA,CAA5BC,EAAS,EAAEZ,MAAMe,QArCNtB,CAAAA,CAAAA,GAAAA,EAqCiBqB,WAAA,YAAA,CAAA,GAKAH,EAAA,CAA5BC,EAAS,EAAEZ,MAAMe,QAAAA,CAAAA,CAAAA,GA1CNtB,EA0CiBqB,WAAA,QAAA,CAKAH,GAAAA,EAAA,CAA5BC,EAAS,EAAEZ,MAAMe,QAAAA,CAAAA,CAAAA,GA/CNtB,EA+CiBqB,WAAA,SAAA,CAKDH,GAAAA,EAAA,CAA3BC,EAAS,EAAEZ,MAAMa,YApDNpB,EAoDgBqB,WAAA,OAAA,CAAA,GApDhBrB,IAANkB,EAAA,CADNK,EAAc,gBAAA,CAAA,GACFvB;;;;;ACbA,IAAAwB,IAAN,cAA6BvB,EAAYC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,CAAzC,EAAA;AAAA,EAAA;AAAAE,UAAAC,GAAAA,SAAAA,GA6BGC,KAAQmB,gBAAwB,GAKUnB,KAAAoB,aAAA;AAAA,EAAA;AAAA,EAKzC;AAETpB,SAAKqB,OAAOC,aAAa,GAGzBC,EAAUvB,KAAKqB,QAAQ,QAAA,EACrBG,KAAKC,EAAa,aAAgB,EAAEC,aACpCC,CAAAA,CAAAA,EAAAA,UAAU;AACV3B,WAAK4B,4BAAAA;AAAAA,IAA4B,CACjC;AAAA,EAAA;AAAA,EAGK,8BACD;;AAAA,UAAAC,MAAS7B,IAAAA,KAAK8B,gBAAL9B,gBAAAA,EAAkB+B,iBAAiB,EAAEC,SAAAA,GAAoB,OAAA,CAAA;AACpE,SAACH,EAAOI,OAAQ;AAEpB,UAAMC,IAAWlC,KAAKmB,eAGhBgB,IAAenC,KAAKqB,OAAOC,aAAatB,KAAKqB,OAAOe,cAAc;AAExE,QAAIC,IAAe,GACfC,IAAkBC;AAEfV,IAAAA,EAAAW,QAAQ,CAACC,GAAOC;AACtB,YACMC,IADaF,EAAsBG,aACVH,EAAML,cAAc,GAC7CS,IAAWC,KAAKC,IAAIZ,IAAeQ;AAErCE,MAAAA,IAAWP,MACIA,IAAAO,GACHR,IAAAK;AAAAA,IAAA,CAAA,GAIjB1C,KAAKmB,gBAAgBkB,GAGjBrC,KAAKmB,kBAAkBe,KACrBlC,KAAAgD,cACJ,IAAIC,YAAY,iBAAiB,EAChCC,QAAQ,EAAER,OAAO1C,KAAKmB,cAAAA,EAAAA,CAAAA,CAAAA;AAAAA,EAGzB;AAAA,EAGO,UAAUgC,GACX;;AAAA,UAAAtB,MAAS7B,IAAAA,KAAK8B,gBAAL9B,gBAAAA,EAAkB+B,iBAAiB,EAAEC,SAAAA,UAAoB,CACnEH;AAAAA,IAAAA,EAAOsB,CAEZnD,KAAAA,KAAKqB,OAAO+B,SAAS,EACpBC,MAAOxB,EAAOsB,CAAAA,EAA0BP,YACxCU,UAAU,SAAA,CAAA;AAAA,EACV;AAAA,EAGM;AACFtD,SAAAuD,UAAUvD,KAAKmB,gBAAgB,CAAA;AAAA,EAAC;AAAA,EAG9B,cAAAqC;;AACD,UAAA3B,MAAS7B,IAAAA,KAAK8B,gBAAL9B,gBAAAA,EAAkB+B,iBAAiB,EAAEC,SAAS,GAAA,OAAW;AACpEhC,SAAKmB,gBAAgBU,EAAOI,SAAS,KACnCjC,KAAAuD,UAAUvD,KAAKmB,gBAAgB,CAAA;AAAA,EACrC;AAAA,EAGD,SAAAsC;;AACO,UAAA5B,MAAS7B,IAAAA,KAAK8B,gBAAL9B,gBAAAA,EAAkB+B,iBAAiB,EAAEC,YAAoB,OAAA,CAAA;AAEjE,WAAAvB;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,MAQHT,KAAKoB,aACJX;AAAAA;AAAAA;AAAAA,iBAGUT,KAAK0D,WAAAA;AAAAA,oBACF1D,KAAKmB,kBAAkB,CAAlBA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,iBAMRnB,KAAKwD,WAAAA;AAAAA,oBACFxD,KAAKmB,kBAAkBU,EAAOI,SAAS,CAAA;AAAA;AAAA;AAAA;AAAA,UAKpD,IAAA;AAAA;AAAA;AAAA;AAAA,OAIAJ,EAAO8B,IAAI,CAACC,GAAGlB,MACV;AAAA,YAAAmB,IAAanB,MAAU1C,KAAKmB;AAC3B,aAAAV;AAAAA,mCACsBoD,IAAa,iBAAiB,UAAA;AAAA;AAAA;AAAA,IAAU,CAAA,CAAA;AAAA;AAAA;AAAA;AAAA,EAGpE;AAAA;AApHWjD,EAAA,CAAhBkD,EAAAA,CAAAA,GA7BW5C,EA6BKH,WAAA,iBAAA,CAKYH,GAAAA,EAAA,CAA5BC,EAAS,EAAEZ,MAAMe,QAAAA,CAAAA,CAAAA,GAlCNE,EAkCiBH,WAAA,cAAA,IAEHH,EAAA,CAAzBmD,EAAM,SAAA,CAAA,GApCK7C,EAoCcH,WAAA,UAAA,IACHH,EAAA,CAAtBmD,EAAM,MArCK7C,CAAAA,GAAAA,EAqCWH,WAAA,eAAA,IArCXG,IAANN,EAAA,CADNK,EAAc,iBAAA,CAAA,GACFC;"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
"use strict";const m=require("rxjs");require("lit/directives/class-map.js"),require("lit/directives/style-map.js");const p=require("./litElement.mixin-
|
|
1
|
+
"use strict";const m=require("rxjs");require("lit/directives/class-map.js"),require("lit/directives/style-map.js");const p=require("./litElement.mixin-CAXeI5RY.cjs");require("./tailwind.mixin-csgxM8P_.cjs");const d=require("lit"),o=require("lit/decorators.js"),S=require("lit/directives/cache.js"),f=require("rxjs/operators");var v=Object.defineProperty,b=Object.getOwnPropertyDescriptor,c=(s,e,i,l)=>{for(var r,t=l>1?void 0:l?b(e,i):e,n=s.length-1;n>=0;n--)(r=s[n])&&(t=(l?r(e,i,t):r(t))||t);return l&&t&&v(e,i,t),t};exports.SchmancySlide=class extends p.$LitElement(d.css`
|
|
2
2
|
:host {
|
|
3
3
|
display: block;
|
|
4
4
|
scroll-snap-align: center; /* If your slider uses scroll-snap */
|
|
@@ -80,4 +80,4 @@
|
|
|
80
80
|
</div>
|
|
81
81
|
</div>
|
|
82
82
|
`}},a([o.state()],exports.SchmancySlider.prototype,"selectedIndex",2),a([o.property({type:Boolean})],exports.SchmancySlider.prototype,"showArrows",2),a([o.query("#slider")],exports.SchmancySlider.prototype,"slider",2),a([o.query("slot")],exports.SchmancySlider.prototype,"defaultSlot",2),exports.SchmancySlider=a([o.customElement("schmancy-slider")],exports.SchmancySlider);
|
|
83
|
-
//# sourceMappingURL=slider-
|
|
83
|
+
//# sourceMappingURL=slider-DCJHcXt1.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"slider-XRH0sXZN.cjs","sources":["../src/slider/slide.ts","../src/slider/slider.ts"],"sourcesContent":["import { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { cache } from 'lit/directives/cache.js'\n\n/**\n * Supported slide \"types.\"\n * - 'image': Renders an <img>\n * - 'video': Renders a <video>\n * - 'content': Renders a <slot> (the default)\n */\ntype SlideType = 'image' | 'video' | 'content'\n\n/**\n * Allowed values for the 'fit' property,\n * which maps to CSS object-fit.\n */\ntype ObjectFit = 'cover' | 'contain' | 'fill' | 'scale-down' | 'none'\n\n@customElement('schmancy-slide')\nexport class SchmancySlide extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tscroll-snap-align: center; /* If your slider uses scroll-snap */\n\t}\n\n\t.slide {\n\t\tdisplay: block;\n\t\twidth: 100%;\n\t\theight: auto;\n\t\tobject-fit: var(--object-fit, cover);\n\t}\n`) {\n\t/**\n\t * Determines how this slide should be rendered.\n\t * Defaults to 'content' if not provided.\n\t */\n\t@property({ type: String }) type: SlideType = 'content'\n\n\t/**\n\t * Source for images or videos (if `type` is 'image' or 'video').\n\t */\n\t@property({ type: String }) src: string = ''\n\n\t/**\n\t * Alternate text for images.\n\t */\n\t@property({ type: String }) alt: string = ''\n\n\t/**\n\t * Whether to show default video controls (if `type` is 'video').\n\t */\n\t@property({ type: Boolean }) controls = true\n\n\t/**\n\t * Whether the video should autoplay (if `type` is 'video').\n\t */\n\t@property({ type: Boolean }) autoplay = false\n\n\t/**\n\t * Whether the video should loop (if `type` is 'video').\n\t */\n\t@property({ type: Boolean }) loop = false\n\n\t/**\n\t * Whether the video is muted (if `type` is 'video').\n\t */\n\t@property({ type: Boolean }) muted = false\n\n\t/**\n\t * CSS `object-fit` property, applied to images/videos.\n\t */\n\t@property({ type: String }) fit: ObjectFit = 'cover'\n\n\trender() {\n\t\treturn html` <div style=\"--object-fit: ${this.fit}\">${cache(this.renderSlide())}</div> `\n\t}\n\n\tprivate renderSlide() {\n\t\tswitch (this.type) {\n\t\t\tcase 'image':\n\t\t\t\treturn html` <img class=\"slide\" src=\"${this.src}\" alt=\"${this.alt}\" loading=\"lazy\" /> `\n\t\t\tcase 'video':\n\t\t\t\treturn html`\n\t\t\t\t\t<video\n\t\t\t\t\t\tclass=\"slide\"\n\t\t\t\t\t\tsrc=\"${this.src}\"\n\t\t\t\t\t\t?controls=\"${this.controls}\"\n\t\t\t\t\t\t?autoplay=\"${this.autoplay}\"\n\t\t\t\t\t\t?loop=\"${this.loop}\"\n\t\t\t\t\t\t?muted=\"${this.muted}\"\n\t\t\t\t\t>\n\t\t\t\t\t\tYour browser does not support HTML video.\n\t\t\t\t\t</video>\n\t\t\t\t`\n\t\t\tcase 'content':\n\t\t\tdefault:\n\t\t\t\treturn html`<slot></slot>`\n\t\t}\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-slide': SchmancySlide\n\t}\n}\n","import { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query, state } from 'lit/decorators.js'\nimport { fromEvent } from 'rxjs'\nimport { throttleTime } from 'rxjs/operators'\n\n@customElement('schmancy-slider')\nexport class SchmancySlider extends $LitElement(css`\n\t.slider {\n\t\t/* Lay out slides horizontally, one after another */\n\t\tdisplay: flex;\n\t\toverflow-x: auto;\n\n\t\t/* Optional: scroll snapping */\n\t\tscroll-snap-type: x mandatory;\n\n\t\t/* Hide scrollbars */\n\t\t-ms-overflow-style: none; /* IE and Edge */\n\t\tscrollbar-width: none; /* Firefox */\n\t}\n\t.slider::-webkit-scrollbar {\n\t\tdisplay: none; /* Chrome, Safari, Opera */\n\t}\n\n\t/* \n Ensure each slide takes up the full slider width.\n \"schmancy-slide\" is the child custom element.\n */\n\t::slotted(schmancy-slide) {\n\t\tflex: 0 0 100%;\n\t\tbox-sizing: border-box;\n\t}\n`) {\n\t/**\n\t * Currently centered slide index\n\t */\n\t@state() private selectedIndex: number = 0\n\n\t/**\n\t * If true, renders next/prev buttons\n\t */\n\t@property({ type: Boolean }) showArrows: boolean = true\n\n\t@query('#slider') private slider!: HTMLDivElement\n\t@query('slot') private defaultSlot!: HTMLSlotElement\n\n\tprotected firstUpdated() {\n\t\t// Start at leftmost position\n\t\tthis.slider.scrollLeft = 0\n\n\t\t// Throttle scroll events to update selected index\n\t\tfromEvent(this.slider, 'scroll')\n\t\t\t.pipe(throttleTime(100, undefined, { trailing: true }))\n\t\t\t.subscribe(() => {\n\t\t\t\tthis.updateSelectedIndexOnScroll()\n\t\t\t})\n\t}\n\n\tprivate updateSelectedIndexOnScroll() {\n\t\tconst slides = this.defaultSlot?.assignedElements({ flatten: true }) ?? []\n\t\tif (!slides.length) return\n\n\t\tconst oldIndex = this.selectedIndex\n\n\t\t// Center of the slider’s visible area\n\t\tconst sliderCenter = this.slider.scrollLeft + this.slider.clientWidth / 2\n\n\t\tlet closestIndex = 0\n\t\tlet closestDistance = Infinity\n\n\t\tslides.forEach((slide, index) => {\n\t\t\tconst itemStart = (slide as HTMLElement).offsetLeft\n\t\t\tconst itemCenter = itemStart + slide.clientWidth / 2\n\t\t\tconst distance = Math.abs(sliderCenter - itemCenter)\n\n\t\t\tif (distance < closestDistance) {\n\t\t\t\tclosestDistance = distance\n\t\t\t\tclosestIndex = index\n\t\t\t}\n\t\t})\n\n\t\tthis.selectedIndex = closestIndex\n\n\t\t// If the index changed, dispatch event\n\t\tif (this.selectedIndex !== oldIndex) {\n\t\t\tthis.dispatchEvent(\n\t\t\t\tnew CustomEvent('slide-changed', {\n\t\t\t\t\tdetail: { index: this.selectedIndex },\n\t\t\t\t}),\n\t\t\t)\n\t\t}\n\t}\n\n\tprivate goToSlide(newIndex: number) {\n\t\tconst slides = this.defaultSlot?.assignedElements({ flatten: true }) ?? []\n\t\tif (!slides[newIndex]) return\n\n\t\tthis.slider.scrollTo({\n\t\t\tleft: (slides[newIndex] as HTMLElement).offsetLeft,\n\t\t\tbehavior: 'smooth',\n\t\t})\n\t}\n\n\tprivate onPrevClick() {\n\t\tthis.goToSlide(this.selectedIndex - 1)\n\t}\n\n\tprivate onNextClick() {\n\t\tconst slides = this.defaultSlot?.assignedElements({ flatten: true }) ?? []\n\t\tif (this.selectedIndex < slides.length - 1) {\n\t\t\tthis.goToSlide(this.selectedIndex + 1)\n\t\t}\n\t}\n\n\trender() {\n\t\tconst slides = this.defaultSlot?.assignedElements({ flatten: true }) ?? []\n\n\t\treturn html`\n\t\t\t<div class=\"relative inset-0\">\n\t\t\t\t<!-- The scrollable track -->\n\t\t\t\t<div class=\"slider\" id=\"slider\">\n\t\t\t\t\t<slot></slot>\n\t\t\t\t</div>\n\n\t\t\t\t<!-- Next/Prev Buttons (Optional) -->\n\t\t\t\t${this.showArrows\n\t\t\t\t\t? html`\n\t\t\t\t\t\t\t<schmancy-icon-button\n\t\t\t\t\t\t\t\tclass=\"absolute left-2 top-1/2 -translate-y-1/2\"\n\t\t\t\t\t\t\t\t@click=${this.onPrevClick}\n\t\t\t\t\t\t\t\t?disabled=${this.selectedIndex === 0}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\tchevron_left\n\t\t\t\t\t\t\t</schmancy-icon-button>\n\t\t\t\t\t\t\t<schmancy-icon-button\n\t\t\t\t\t\t\t\tclass=\"absolute right-2 top-1/2 -translate-y-1/2\"\n\t\t\t\t\t\t\t\t@click=${this.onNextClick}\n\t\t\t\t\t\t\t\t?disabled=${this.selectedIndex === slides.length - 1}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\tchevron_right\n\t\t\t\t\t\t\t</schmancy-icon-button>\n\t\t\t\t\t\t`\n\t\t\t\t\t: null}\n\n\t\t\t\t<!-- Dots / indicators -->\n\t\t\t\t<div class=\"absolute bottom-4 left-1/2 -translate-x-1/2 flex space-x-2\">\n\t\t\t\t\t${slides.map((_, index) => {\n\t\t\t\t\t\tconst isSelected = index === this.selectedIndex\n\t\t\t\t\t\treturn html`\n\t\t\t\t\t\t\t<schmancy-button .variant=${isSelected ? 'filled tonal' : 'outlined'} class=\"rounded-full \">\n\t\t\t\t\t\t\t</schmancy-button>\n\t\t\t\t\t\t`\n\t\t\t\t\t})}\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-slider': SchmancySlider\n\t}\n}\n"],"names":["SchmancySlide","$LitElement","css","super","arguments","this","type","src","alt","controls","autoplay","loop","muted","fit","render","html","cache","renderSlide","__decorateClass","property","String","prototype","Boolean","customElement","SchmancySlider","selectedIndex","showArrows","slider","scrollLeft","fromEvent","pipe","throttleTime","trailing","subscribe","updateSelectedIndexOnScroll","slides","defaultSlot","assignedElements","flatten","length","oldIndex","sliderCenter","clientWidth","closestIndex","closestDistance","Infinity","forEach","slide","index","itemCenter","offsetLeft","distance","Math","abs","dispatchEvent","CustomEvent","detail","newIndex","scrollTo","left","behavior","goToSlide","onNextClick","onPrevClick","map","_","isSelected","state","query"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"slider-DCJHcXt1.cjs","sources":["../src/slider/slide.ts","../src/slider/slider.ts"],"sourcesContent":["import { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { cache } from 'lit/directives/cache.js'\n\n/**\n * Supported slide \"types.\"\n * - 'image': Renders an <img>\n * - 'video': Renders a <video>\n * - 'content': Renders a <slot> (the default)\n */\ntype SlideType = 'image' | 'video' | 'content'\n\n/**\n * Allowed values for the 'fit' property,\n * which maps to CSS object-fit.\n */\ntype ObjectFit = 'cover' | 'contain' | 'fill' | 'scale-down' | 'none'\n\n@customElement('schmancy-slide')\nexport class SchmancySlide extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tscroll-snap-align: center; /* If your slider uses scroll-snap */\n\t}\n\n\t.slide {\n\t\tdisplay: block;\n\t\twidth: 100%;\n\t\theight: auto;\n\t\tobject-fit: var(--object-fit, cover);\n\t}\n`) {\n\t/**\n\t * Determines how this slide should be rendered.\n\t * Defaults to 'content' if not provided.\n\t */\n\t@property({ type: String }) type: SlideType = 'content'\n\n\t/**\n\t * Source for images or videos (if `type` is 'image' or 'video').\n\t */\n\t@property({ type: String }) src: string = ''\n\n\t/**\n\t * Alternate text for images.\n\t */\n\t@property({ type: String }) alt: string = ''\n\n\t/**\n\t * Whether to show default video controls (if `type` is 'video').\n\t */\n\t@property({ type: Boolean }) controls = true\n\n\t/**\n\t * Whether the video should autoplay (if `type` is 'video').\n\t */\n\t@property({ type: Boolean }) autoplay = false\n\n\t/**\n\t * Whether the video should loop (if `type` is 'video').\n\t */\n\t@property({ type: Boolean }) loop = false\n\n\t/**\n\t * Whether the video is muted (if `type` is 'video').\n\t */\n\t@property({ type: Boolean }) muted = false\n\n\t/**\n\t * CSS `object-fit` property, applied to images/videos.\n\t */\n\t@property({ type: String }) fit: ObjectFit = 'cover'\n\n\trender() {\n\t\treturn html` <div style=\"--object-fit: ${this.fit}\">${cache(this.renderSlide())}</div> `\n\t}\n\n\tprivate renderSlide() {\n\t\tswitch (this.type) {\n\t\t\tcase 'image':\n\t\t\t\treturn html` <img class=\"slide\" src=\"${this.src}\" alt=\"${this.alt}\" loading=\"lazy\" /> `\n\t\t\tcase 'video':\n\t\t\t\treturn html`\n\t\t\t\t\t<video\n\t\t\t\t\t\tclass=\"slide\"\n\t\t\t\t\t\tsrc=\"${this.src}\"\n\t\t\t\t\t\t?controls=\"${this.controls}\"\n\t\t\t\t\t\t?autoplay=\"${this.autoplay}\"\n\t\t\t\t\t\t?loop=\"${this.loop}\"\n\t\t\t\t\t\t?muted=\"${this.muted}\"\n\t\t\t\t\t>\n\t\t\t\t\t\tYour browser does not support HTML video.\n\t\t\t\t\t</video>\n\t\t\t\t`\n\t\t\tcase 'content':\n\t\t\tdefault:\n\t\t\t\treturn html`<slot></slot>`\n\t\t}\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-slide': SchmancySlide\n\t}\n}\n","import { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query, state } from 'lit/decorators.js'\nimport { fromEvent } from 'rxjs'\nimport { throttleTime } from 'rxjs/operators'\n\n@customElement('schmancy-slider')\nexport class SchmancySlider extends $LitElement(css`\n\t.slider {\n\t\t/* Lay out slides horizontally, one after another */\n\t\tdisplay: flex;\n\t\toverflow-x: auto;\n\n\t\t/* Optional: scroll snapping */\n\t\tscroll-snap-type: x mandatory;\n\n\t\t/* Hide scrollbars */\n\t\t-ms-overflow-style: none; /* IE and Edge */\n\t\tscrollbar-width: none; /* Firefox */\n\t}\n\t.slider::-webkit-scrollbar {\n\t\tdisplay: none; /* Chrome, Safari, Opera */\n\t}\n\n\t/* \n Ensure each slide takes up the full slider width.\n \"schmancy-slide\" is the child custom element.\n */\n\t::slotted(schmancy-slide) {\n\t\tflex: 0 0 100%;\n\t\tbox-sizing: border-box;\n\t}\n`) {\n\t/**\n\t * Currently centered slide index\n\t */\n\t@state() private selectedIndex: number = 0\n\n\t/**\n\t * If true, renders next/prev buttons\n\t */\n\t@property({ type: Boolean }) showArrows: boolean = true\n\n\t@query('#slider') private slider!: HTMLDivElement\n\t@query('slot') private defaultSlot!: HTMLSlotElement\n\n\tprotected firstUpdated() {\n\t\t// Start at leftmost position\n\t\tthis.slider.scrollLeft = 0\n\n\t\t// Throttle scroll events to update selected index\n\t\tfromEvent(this.slider, 'scroll')\n\t\t\t.pipe(throttleTime(100, undefined, { trailing: true }))\n\t\t\t.subscribe(() => {\n\t\t\t\tthis.updateSelectedIndexOnScroll()\n\t\t\t})\n\t}\n\n\tprivate updateSelectedIndexOnScroll() {\n\t\tconst slides = this.defaultSlot?.assignedElements({ flatten: true }) ?? []\n\t\tif (!slides.length) return\n\n\t\tconst oldIndex = this.selectedIndex\n\n\t\t// Center of the slider’s visible area\n\t\tconst sliderCenter = this.slider.scrollLeft + this.slider.clientWidth / 2\n\n\t\tlet closestIndex = 0\n\t\tlet closestDistance = Infinity\n\n\t\tslides.forEach((slide, index) => {\n\t\t\tconst itemStart = (slide as HTMLElement).offsetLeft\n\t\t\tconst itemCenter = itemStart + slide.clientWidth / 2\n\t\t\tconst distance = Math.abs(sliderCenter - itemCenter)\n\n\t\t\tif (distance < closestDistance) {\n\t\t\t\tclosestDistance = distance\n\t\t\t\tclosestIndex = index\n\t\t\t}\n\t\t})\n\n\t\tthis.selectedIndex = closestIndex\n\n\t\t// If the index changed, dispatch event\n\t\tif (this.selectedIndex !== oldIndex) {\n\t\t\tthis.dispatchEvent(\n\t\t\t\tnew CustomEvent('slide-changed', {\n\t\t\t\t\tdetail: { index: this.selectedIndex },\n\t\t\t\t}),\n\t\t\t)\n\t\t}\n\t}\n\n\tprivate goToSlide(newIndex: number) {\n\t\tconst slides = this.defaultSlot?.assignedElements({ flatten: true }) ?? []\n\t\tif (!slides[newIndex]) return\n\n\t\tthis.slider.scrollTo({\n\t\t\tleft: (slides[newIndex] as HTMLElement).offsetLeft,\n\t\t\tbehavior: 'smooth',\n\t\t})\n\t}\n\n\tprivate onPrevClick() {\n\t\tthis.goToSlide(this.selectedIndex - 1)\n\t}\n\n\tprivate onNextClick() {\n\t\tconst slides = this.defaultSlot?.assignedElements({ flatten: true }) ?? []\n\t\tif (this.selectedIndex < slides.length - 1) {\n\t\t\tthis.goToSlide(this.selectedIndex + 1)\n\t\t}\n\t}\n\n\trender() {\n\t\tconst slides = this.defaultSlot?.assignedElements({ flatten: true }) ?? []\n\n\t\treturn html`\n\t\t\t<div class=\"relative inset-0\">\n\t\t\t\t<!-- The scrollable track -->\n\t\t\t\t<div class=\"slider\" id=\"slider\">\n\t\t\t\t\t<slot></slot>\n\t\t\t\t</div>\n\n\t\t\t\t<!-- Next/Prev Buttons (Optional) -->\n\t\t\t\t${this.showArrows\n\t\t\t\t\t? html`\n\t\t\t\t\t\t\t<schmancy-icon-button\n\t\t\t\t\t\t\t\tclass=\"absolute left-2 top-1/2 -translate-y-1/2\"\n\t\t\t\t\t\t\t\t@click=${this.onPrevClick}\n\t\t\t\t\t\t\t\t?disabled=${this.selectedIndex === 0}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\tchevron_left\n\t\t\t\t\t\t\t</schmancy-icon-button>\n\t\t\t\t\t\t\t<schmancy-icon-button\n\t\t\t\t\t\t\t\tclass=\"absolute right-2 top-1/2 -translate-y-1/2\"\n\t\t\t\t\t\t\t\t@click=${this.onNextClick}\n\t\t\t\t\t\t\t\t?disabled=${this.selectedIndex === slides.length - 1}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\tchevron_right\n\t\t\t\t\t\t\t</schmancy-icon-button>\n\t\t\t\t\t\t`\n\t\t\t\t\t: null}\n\n\t\t\t\t<!-- Dots / indicators -->\n\t\t\t\t<div class=\"absolute bottom-4 left-1/2 -translate-x-1/2 flex space-x-2\">\n\t\t\t\t\t${slides.map((_, index) => {\n\t\t\t\t\t\tconst isSelected = index === this.selectedIndex\n\t\t\t\t\t\treturn html`\n\t\t\t\t\t\t\t<schmancy-button .variant=${isSelected ? 'filled tonal' : 'outlined'} class=\"rounded-full \">\n\t\t\t\t\t\t\t</schmancy-button>\n\t\t\t\t\t\t`\n\t\t\t\t\t})}\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-slider': SchmancySlider\n\t}\n}\n"],"names":["SchmancySlide","$LitElement","css","super","arguments","this","type","src","alt","controls","autoplay","loop","muted","fit","render","html","cache","renderSlide","__decorateClass","property","String","prototype","Boolean","customElement","SchmancySlider","selectedIndex","showArrows","slider","scrollLeft","fromEvent","pipe","throttleTime","trailing","subscribe","updateSelectedIndexOnScroll","slides","defaultSlot","assignedElements","flatten","length","oldIndex","sliderCenter","clientWidth","closestIndex","closestDistance","Infinity","forEach","slide","index","itemCenter","offsetLeft","distance","Math","abs","dispatchEvent","CustomEvent","detail","newIndex","scrollTo","left","behavior","goToSlide","onNextClick","onPrevClick","map","_","isSelected","state","query"],"mappings":"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"}
|
package/dist/slider.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./slider-
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./slider-DCJHcXt1.cjs");Object.defineProperty(exports,"SchmancySlide",{enumerable:!0,get:()=>e.SchmancySlide}),Object.defineProperty(exports,"SchmancySlider",{enumerable:!0,get:()=>e.SchmancySlider});
|
|
2
2
|
//# sourceMappingURL=slider.cjs.map
|
package/dist/slider.js
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import "./theme.component-
|
|
1
|
+
import "./theme.component-UVrnuMPb.js";
|
|
2
2
|
import { S as l } from "./theme.interface-C5Kj6WjD.js";
|
|
3
3
|
import { c as u } from "./color-DrgmL7QT.js";
|
|
4
4
|
import "./ripple-3indJ14o.js";
|
|
5
5
|
import "rxjs";
|
|
6
6
|
import "lit/directives/class-map.js";
|
|
7
7
|
import "lit/directives/style-map.js";
|
|
8
|
-
import { T as m } from "./tailwind.mixin-
|
|
8
|
+
import { T as m } from "./tailwind.mixin-BvhzMkqK.js";
|
|
9
9
|
import { css as y, html as h } from "lit";
|
|
10
10
|
import { customElement as f, property as p } from "lit/decorators.js";
|
|
11
11
|
var v = Object.getOwnPropertyDescriptor;
|
|
@@ -75,4 +75,4 @@ let a = class extends m(y`
|
|
|
75
75
|
}
|
|
76
76
|
};
|
|
77
77
|
c([p({ type: String })], a.prototype, "color", 2), c([p({ type: String })], a.prototype, "size", 2), a = c([f("schmancy-spinner")], a);
|
|
78
|
-
//# sourceMappingURL=spinner-
|
|
78
|
+
//# sourceMappingURL=spinner-B9JHqmoP.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"spinner-
|
|
1
|
+
{"version":3,"file":"spinner-B9JHqmoP.js","sources":["../src/busy/busy.ts","../src/busy/spinner.ts"],"sourcesContent":["import { SchmancyTheme } from '@schmancy/theme'\nimport { color } from '@schmancy/directives'\nimport { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\n\n@customElement('schmancy-busy')\nexport default class SchmancyBusy extends TailwindElement(css`\n\t:host {\n\t\tdisplay: inline;\n\t\tposition: absolute;\n\t\tinset: 0;\n\t}\n`) {\n\tprotected render(): unknown {\n\t\treturn html`\n\t\t\t<div class=\"absolute inset-0 flex justify-center items-center animate-pulse z-[9999999]\">\n\t\t\t\t<!-- glass window -->\n\t\t\t\t<div\n\t\t\t\t\t${color({\n\t\t\t\t\t\tbgColor: SchmancyTheme.sys.color.secondary.container,\n\t\t\t\t\t\tcolor: SchmancyTheme.sys.color.tertiary.onContainer,\n\t\t\t\t\t})}\n\t\t\t\t\tclass=\"absolute transform-gpu inset-0 rounded-[inherit] opacity-50 flex align-middle justify-center items-center \"\n\t\t\t\t>\n\t\t\t\t\t<slot> </slot>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-busy': SchmancyBusy\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\n@customElement('schmancy-spinner')\nexport default class SchmnacySpinner extends TailwindElement(css`\n\t.spinner {\n\t\tanimation: spin 1s linear infinite;\n\t\tanimation-direction: reverse;\n\t}\n\n\t@keyframes spin {\n\t\tfrom {\n\t\t\ttransform: rotate(0deg);\n\t\t}\n\t\tto {\n\t\t\ttransform: rotate(360deg);\n\t\t}\n\t}\n`) {\n\t@property({ type: String }) color: string = 'gray'\n\t@property({ type: String }) size: string = '24px'\n\n\tprotected render(): unknown {\n\t\tconst style = {\n\t\t\tfontSize: this.size,\n\t\t\tmaxWidth: this.size,\n\t\t\toverflow: 'hidden',\n\t\t}\n\t\treturn html`\n\t\t\t<div class=\"spinner\" style=${this.styleMap(style)}>\n\t\t\t\t<svg fill=\"none\" viewBox=\"0 0 16 16\" class=\"anim-rotate\" aria-hidden=\"true\" role=\"img\">\n\t\t\t\t\t<path\n\t\t\t\t\t\topacity=\".5\"\n\t\t\t\t\t\td=\"M8 15A7 7 0 108 1a7 7 0 000 14v0z\"\n\t\t\t\t\t\tstroke=\"var(--schmancy-sys-color-secondary-default)\"\n\t\t\t\t\t\tstroke-width=\"2\"\n\t\t\t\t\t></path>\n\t\t\t\t\t<path d=\"M15 8a7 7 0 01-7 7\" stroke=\"var(--schmancy-sys-color-secondary-default)\" stroke-width=\"2\"></path>\n\t\t\t\t\t<path d=\"M8 12a4 4 0 100-8 4 4 0 000 8z\" fill=\"var(--schmancy-sys-color-secondary-default)\"></path>\n\t\t\t\t</svg>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-spinner': SchmnacySpinner\n\t}\n}\n"],"names":["SchmancyBusy","TailwindElement","css","render","html","color","bgColor","SchmancyTheme","sys","secondary","container","tertiary","onContainer","customElement","SchmnacySpinner","constructor","super","arguments","this","size","style","fontSize","maxWidth","overflow","styleMap","__decorateClass","property","type","String","prototype"],"mappings":";;;;;;;;;;;AAOA,IAAqBA,IAArB,cAA0CC,EAAgBC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;EAO/C,SAAAC;AACF,WAAAC;AAAAA;AAAAA;AAAAA;AAAAA,OAIFC,EAAM,EACPC,SAASC,EAAcC,IAAIH,MAAMI,UAAUC,WAC3CL,OAAOE,EAAcC,IAAIH,MAAMM,SAASC,YAAAA,CAAAA,CAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,EACvC;AAfcZ;AAAAA;;;GAArB,CADCa,EAAc,mBACMb;;;;;ACFrB,IAAqBc,IAArB,cAA6Cb,EAAgBC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;EAA7D,cAAAa;AAAAC,UAAAC,GAAAA,SAAAA,GAe6CC,KAAAb,QAAA,QACDa,KAAAC,OAAA;AAAA,EAAA;AAAA,EAEjC,SAAAhB;AACT,UAAMiB,IAAQ,EACbC,UAAUH,KAAKC,MACfG,UAAUJ,KAAKC,MACfI,UAAU,SAEJ;AAAA,WAAAnB;AAAAA,gCACuBc,KAAKM,SAASJ,CAAAA,CAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,EAAM;AAVvBK;AAAAA,EAAA,CAA3BC,EAAS,EAAEC,MAAMC,YAfEd,EAeQe,WAAA,SAAA,CAAA,GACAJ,EAAA,CAA3BC,EAAS,EAAEC,MAAMC,OAhBEd,CAAAA,CAAAA,GAAAA,EAgBQe,WAAA,QAAA,IAhBRf,IAArBW,EAAA,CADCZ,EAAc,kBACMC,CAAAA,GAAAA,CAAAA;"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
"use strict";require("./theme.component-
|
|
1
|
+
"use strict";require("./theme.component-C-055F7V.cjs");const y=require("./theme.interface-Xg5Zi46a.cjs"),m=require("./color-D8r6dpWm.cjs");require("./ripple-B_wT0zgD.cjs"),require("rxjs"),require("lit/directives/class-map.js"),require("lit/directives/style-map.js");const u=require("./tailwind.mixin-csgxM8P_.cjs"),l=require("lit"),c=require("lit/decorators.js");var h=Object.getOwnPropertyDescriptor;let p=class extends u.TailwindElement(l.css`
|
|
2
2
|
:host {
|
|
3
3
|
display: inline;
|
|
4
4
|
position: absolute;
|
|
@@ -42,4 +42,4 @@
|
|
|
42
42
|
</svg>
|
|
43
43
|
</div>
|
|
44
44
|
`}};d([c.property({type:String})],a.prototype,"color",2),d([c.property({type:String})],a.prototype,"size",2),a=d([c.customElement("schmancy-spinner")],a);
|
|
45
|
-
//# sourceMappingURL=spinner-
|
|
45
|
+
//# sourceMappingURL=spinner-D-vtqMqq.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"spinner-
|
|
1
|
+
{"version":3,"file":"spinner-D-vtqMqq.cjs","sources":["../src/busy/busy.ts","../src/busy/spinner.ts"],"sourcesContent":["import { SchmancyTheme } from '@schmancy/theme'\nimport { color } from '@schmancy/directives'\nimport { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\n\n@customElement('schmancy-busy')\nexport default class SchmancyBusy extends TailwindElement(css`\n\t:host {\n\t\tdisplay: inline;\n\t\tposition: absolute;\n\t\tinset: 0;\n\t}\n`) {\n\tprotected render(): unknown {\n\t\treturn html`\n\t\t\t<div class=\"absolute inset-0 flex justify-center items-center animate-pulse z-[9999999]\">\n\t\t\t\t<!-- glass window -->\n\t\t\t\t<div\n\t\t\t\t\t${color({\n\t\t\t\t\t\tbgColor: SchmancyTheme.sys.color.secondary.container,\n\t\t\t\t\t\tcolor: SchmancyTheme.sys.color.tertiary.onContainer,\n\t\t\t\t\t})}\n\t\t\t\t\tclass=\"absolute transform-gpu inset-0 rounded-[inherit] opacity-50 flex align-middle justify-center items-center \"\n\t\t\t\t>\n\t\t\t\t\t<slot> </slot>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-busy': SchmancyBusy\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\n@customElement('schmancy-spinner')\nexport default class SchmnacySpinner extends TailwindElement(css`\n\t.spinner {\n\t\tanimation: spin 1s linear infinite;\n\t\tanimation-direction: reverse;\n\t}\n\n\t@keyframes spin {\n\t\tfrom {\n\t\t\ttransform: rotate(0deg);\n\t\t}\n\t\tto {\n\t\t\ttransform: rotate(360deg);\n\t\t}\n\t}\n`) {\n\t@property({ type: String }) color: string = 'gray'\n\t@property({ type: String }) size: string = '24px'\n\n\tprotected render(): unknown {\n\t\tconst style = {\n\t\t\tfontSize: this.size,\n\t\t\tmaxWidth: this.size,\n\t\t\toverflow: 'hidden',\n\t\t}\n\t\treturn html`\n\t\t\t<div class=\"spinner\" style=${this.styleMap(style)}>\n\t\t\t\t<svg fill=\"none\" viewBox=\"0 0 16 16\" class=\"anim-rotate\" aria-hidden=\"true\" role=\"img\">\n\t\t\t\t\t<path\n\t\t\t\t\t\topacity=\".5\"\n\t\t\t\t\t\td=\"M8 15A7 7 0 108 1a7 7 0 000 14v0z\"\n\t\t\t\t\t\tstroke=\"var(--schmancy-sys-color-secondary-default)\"\n\t\t\t\t\t\tstroke-width=\"2\"\n\t\t\t\t\t></path>\n\t\t\t\t\t<path d=\"M15 8a7 7 0 01-7 7\" stroke=\"var(--schmancy-sys-color-secondary-default)\" stroke-width=\"2\"></path>\n\t\t\t\t\t<path d=\"M8 12a4 4 0 100-8 4 4 0 000 8z\" fill=\"var(--schmancy-sys-color-secondary-default)\"></path>\n\t\t\t\t</svg>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-spinner': SchmnacySpinner\n\t}\n}\n"],"names":["SchmancyBusy","TailwindElement","css","render","html","color","bgColor","SchmancyTheme","sys","secondary","container","tertiary","onContainer","customElement","SchmnacySpinner","constructor","super","arguments","this","size","style","fontSize","maxWidth","overflow","styleMap","__decorateClass","property","type","String","prototype"],"mappings":"iZAOA,IAAqBA,EAArB,cAA0CC,EAAAA,gBAAgBC,EAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,GAO/C,QAAAC,CACF,OAAAC,EAAAA;AAAAA;AAAAA;AAAAA;AAAAA,OAIFC,QAAM,CACPC,QAASC,EAAAA,cAAcC,IAAIH,MAAMI,UAAUC,UAC3CL,MAAOE,EAAAA,cAAcC,IAAIH,MAAMM,SAASC,WAAAA,CAAAA,CAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,GACvC,CAfcZ,EAAAA,wGAArB,CADCa,EAAAA,cAAc,eAAA,CAAA,EACMb,mMCFrB,IAAqBc,EAArB,cAA6Cb,EAAAA,gBAAgBC,EAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,GAA7D,aAAAa,CAAAC,MAAAC,GAAAA,SAAAA,EAe6CC,KAAAb,MAAA,OACDa,KAAAC,KAAA,MAAA,CAEjC,QAAAhB,CACT,MAAMiB,EAAQ,CACbC,SAAUH,KAAKC,KACfG,SAAUJ,KAAKC,KACfI,SAAU,QAAA,EAEJ,OAAAnB,EAAAA;AAAAA,gCACuBc,KAAKM,SAASJ,CAAAA,CAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,GAAM,CAVvBK,EAAAA,EAAA,CAA3BC,WAAS,CAAEC,KAAMC,MAAAA,CAAAA,CAAAA,EAfEd,EAeQe,UAAA,QAAA,CAAA,EACAJ,EAAA,CAA3BC,WAAS,CAAEC,KAAMC,MAhBEd,CAAAA,CAAAA,EAAAA,EAgBQe,UAAA,OAAA,CAhBRf,EAAAA,EAArBW,EAAA,CADCZ,EAAAA,cAAc,kBACMC,CAAAA,EAAAA,CAAAA"}
|