@mhmo91/schmancy 0.9.9 → 0.9.11
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/custom-elements.json +4 -4
- package/dist/{area-D9b9dHQr.cjs → area-BafkBc1f.cjs} +1 -1
- package/dist/{area-D9b9dHQr.cjs.map → area-BafkBc1f.cjs.map} +1 -1
- package/dist/{area-BARjKpE9.js → area-D03HRn1L.js} +1 -1
- package/dist/{area-BARjKpE9.js.map → area-D03HRn1L.js.map} +1 -1
- package/dist/area.cjs +1 -1
- package/dist/area.js +1 -1
- package/dist/{autocomplete-AI2CCJmK.cjs → autocomplete-BeLg4A3T.cjs} +1 -1
- package/dist/{autocomplete-AI2CCJmK.cjs.map → autocomplete-BeLg4A3T.cjs.map} +1 -1
- package/dist/{autocomplete-DOimwVMP.js → autocomplete-BotVnTfP.js} +2 -2
- package/dist/{autocomplete-DOimwVMP.js.map → autocomplete-BotVnTfP.js.map} +1 -1
- package/dist/autocomplete.cjs +1 -1
- package/dist/autocomplete.js +1 -1
- package/dist/badge.cjs +1 -1
- package/dist/badge.js +1 -1
- package/dist/{boat-Bk4u-LzT.cjs → boat-4hSLFsGy.cjs} +1 -1
- package/dist/{boat-Bk4u-LzT.cjs.map → boat-4hSLFsGy.cjs.map} +1 -1
- package/dist/{boat-DrghVeWK.js → boat-C1wGdoaF.js} +1 -1
- package/dist/{boat-DrghVeWK.js.map → boat-C1wGdoaF.js.map} +1 -1
- package/dist/boat.cjs +1 -1
- package/dist/boat.js +1 -1
- package/dist/breadcrumb.cjs +1 -1
- package/dist/breadcrumb.js +1 -1
- package/dist/{busy-c_q_F8O0.cjs → busy-C0qP0TiL.cjs} +1 -1
- package/dist/{busy-c_q_F8O0.cjs.map → busy-C0qP0TiL.cjs.map} +1 -1
- package/dist/{busy-BmFfwyz_.js → busy-D74-XaFn.js} +1 -1
- package/dist/{busy-BmFfwyz_.js.map → busy-D74-XaFn.js.map} +1 -1
- package/dist/busy.cjs +1 -1
- package/dist/busy.js +1 -1
- package/dist/button.cjs +29 -29
- package/dist/button.cjs.map +1 -1
- package/dist/button.js +52 -50
- package/dist/button.js.map +1 -1
- package/dist/{card-C_E944_Z.cjs → card-Bht1QcYl.cjs} +1 -1
- package/dist/{card-C_E944_Z.cjs.map → card-Bht1QcYl.cjs.map} +1 -1
- package/dist/{card-BADJHUMA.js → card-DiNYPJ9b.js} +1 -1
- package/dist/{card-BADJHUMA.js.map → card-DiNYPJ9b.js.map} +1 -1
- package/dist/card.cjs +1 -1
- package/dist/card.js +1 -1
- package/dist/charts.cjs +1 -1
- package/dist/charts.js +1 -1
- package/dist/{checkbox-ZqDoCagB.cjs → checkbox-CRzu7URt.cjs} +1 -1
- package/dist/{checkbox-ZqDoCagB.cjs.map → checkbox-CRzu7URt.cjs.map} +1 -1
- package/dist/{checkbox-D7rvCrGk.js → checkbox-dRBf89qt.js} +2 -2
- package/dist/{checkbox-D7rvCrGk.js.map → checkbox-dRBf89qt.js.map} +1 -1
- package/dist/checkbox.cjs +1 -1
- package/dist/checkbox.js +1 -1
- package/dist/{chips-vdzIsesI.js → chips-Bma_B3J-.js} +3 -3
- package/dist/{chips-vdzIsesI.js.map → chips-Bma_B3J-.js.map} +1 -1
- package/dist/{chips-Cux635Qs.cjs → chips-CXknD-vY.cjs} +1 -1
- package/dist/{chips-Cux635Qs.cjs.map → chips-CXknD-vY.cjs.map} +1 -1
- package/dist/chips.cjs +1 -1
- package/dist/chips.js +2 -2
- package/dist/{code-highlight-C9lKek2p.cjs → code-highlight-BROOsNA_.cjs} +1 -1
- package/dist/{code-highlight-C9lKek2p.cjs.map → code-highlight-BROOsNA_.cjs.map} +1 -1
- package/dist/{code-highlight-D6yruol6.js → code-highlight-DjiyaDcX.js} +1 -1
- package/dist/{code-highlight-D6yruol6.js.map → code-highlight-DjiyaDcX.js.map} +1 -1
- package/dist/code-highlight.cjs +1 -1
- package/dist/code-highlight.js +1 -1
- package/dist/{components-DSvPKR9Q.js → components-DKgu88mm.js} +1 -1
- package/dist/{components-DSvPKR9Q.js.map → components-DKgu88mm.js.map} +1 -1
- package/dist/{components-ByRyEzz5.cjs → components-ubXwQbGs.cjs} +1 -1
- package/dist/{components-ByRyEzz5.cjs.map → components-ubXwQbGs.cjs.map} +1 -1
- package/dist/components.cjs +1 -1
- package/dist/components.js +1 -1
- package/dist/connectivity.cjs +1 -1
- package/dist/connectivity.js +1 -1
- package/dist/content-drawer.cjs +1 -1
- package/dist/content-drawer.js +1 -1
- package/dist/context-B81Q3U_1.cjs +1 -0
- package/dist/context-B81Q3U_1.cjs.map +1 -0
- package/dist/context-Dnj4ofbV.js +3 -0
- package/dist/context-Dnj4ofbV.js.map +1 -0
- package/dist/{date-range-tEX2Jx2j.js → date-range-CwqFuGGK.js} +3 -3
- package/dist/{date-range-tEX2Jx2j.js.map → date-range-CwqFuGGK.js.map} +1 -1
- package/dist/{date-range-inline-B87TDYI6.js.map → date-range-inline-B_g1YXu3.js.map} +1 -1
- package/dist/{date-range-inline-De-M0VmL.cjs.map → date-range-inline-LLC3Y0mi.cjs.map} +1 -1
- package/dist/date-range-inline.cjs +1 -1
- package/dist/date-range-inline.js +1 -1
- package/dist/{date-range-DJsavigf.cjs → date-range-n_xPONd5.cjs} +1 -1
- package/dist/{date-range-DJsavigf.cjs.map → date-range-n_xPONd5.cjs.map} +1 -1
- package/dist/date-range.cjs +1 -1
- package/dist/date-range.js +1 -1
- package/dist/{delay-BvVdfhAR.cjs → delay-BFpu_Yz9.cjs} +1 -1
- package/dist/{delay-BvVdfhAR.cjs.map → delay-BFpu_Yz9.cjs.map} +1 -1
- package/dist/{delay-CZw37zps.js → delay-Bkd3SOTy.js} +4 -4
- package/dist/{delay-CZw37zps.js.map → delay-Bkd3SOTy.js.map} +1 -1
- package/dist/delay.cjs +1 -1
- package/dist/delay.js +1 -1
- package/dist/{details-Bhz8_whd.cjs → details-Bal2g3J4.cjs} +1 -1
- package/dist/{details-Bhz8_whd.cjs.map → details-Bal2g3J4.cjs.map} +1 -1
- package/dist/{details-D7VTnLOh.js → details-DZq61CD5.js} +1 -1
- package/dist/{details-D7VTnLOh.js.map → details-DZq61CD5.js.map} +1 -1
- package/dist/details.cjs +1 -1
- package/dist/details.js +1 -1
- package/dist/{dialog-service-ClFrOWf4.js → dialog-service-CCFGpU7a.js} +1 -1
- package/dist/{dialog-service-ClFrOWf4.js.map → dialog-service-CCFGpU7a.js.map} +1 -1
- package/dist/{dialog-service-DcuAavp2.cjs → dialog-service-DXLGSshF.cjs} +1 -1
- package/dist/{dialog-service-DcuAavp2.cjs.map → dialog-service-DXLGSshF.cjs.map} +1 -1
- package/dist/dialog.cjs +1 -1
- package/dist/dialog.js +2 -2
- package/dist/{divider-zS232JDr.js → divider-ChK7lCQF.js} +1 -1
- package/dist/{divider-zS232JDr.js.map → divider-ChK7lCQF.js.map} +1 -1
- package/dist/{divider-S0bHwCCS.cjs → divider-RjZbewe8.cjs} +1 -1
- package/dist/{divider-S0bHwCCS.cjs.map → divider-RjZbewe8.cjs.map} +1 -1
- package/dist/divider.cjs +1 -1
- package/dist/divider.js +1 -1
- package/dist/dropdown.cjs +1 -1
- package/dist/dropdown.js +2 -2
- package/dist/{expand-BXt9SqAF.js → expand-CUrWPZu-.js} +2 -2
- package/dist/{expand-BXt9SqAF.js.map → expand-CUrWPZu-.js.map} +1 -1
- package/dist/{expand-Dr7TFXpl.cjs → expand-DwZKr9hD.cjs} +1 -1
- package/dist/{expand-Dr7TFXpl.cjs.map → expand-DwZKr9hD.cjs.map} +1 -1
- package/dist/expand.cjs +1 -1
- package/dist/expand.js +1 -1
- package/dist/{extra-BmZTXAp0.cjs → extra-BE9p8l3U.cjs} +1 -1
- package/dist/{extra-BmZTXAp0.cjs.map → extra-BE9p8l3U.cjs.map} +1 -1
- package/dist/{extra-COYhsOyZ.js → extra-C7xp1GQG.js} +1 -1
- package/dist/{extra-COYhsOyZ.js.map → extra-C7xp1GQG.js.map} +1 -1
- package/dist/extra.cjs +1 -1
- package/dist/extra.js +1 -1
- package/dist/{float-CSRW-Rrd.cjs → float-DoHSvH7R.cjs} +1 -1
- package/dist/{float-CSRW-Rrd.cjs.map → float-DoHSvH7R.cjs.map} +1 -1
- package/dist/{float-DCXafWh6.js → float-kRCgEf_1.js} +1 -1
- package/dist/{float-DCXafWh6.js.map → float-kRCgEf_1.js.map} +1 -1
- package/dist/float.cjs +1 -1
- package/dist/float.js +1 -1
- package/dist/{flow-CqgDEIqK.js.map → flow-BPDtbhLe.js.map} +1 -1
- package/dist/{flow-DSu4PLt1.cjs.map → flow-Dn9AZktE.cjs.map} +1 -1
- package/dist/{form-D2cJ58TB.js.map → form-C1qS9uvS.js.map} +1 -1
- package/dist/{form-CAY9GSCd.cjs.map → form-CzD0JLxM.cjs.map} +1 -1
- package/dist/form.cjs +1 -1
- package/dist/form.js +1 -1
- package/dist/{hashContent-nD2uWwi2.js.map → hashContent-BUqULUiZ.js.map} +1 -1
- package/dist/{hashContent-kKvXKFa9.cjs.map → hashContent-CI39BY-_.cjs.map} +1 -1
- package/dist/{icons-DPUeLS_Y.cjs → icons-Bz84Dr-q.cjs} +4 -4
- package/dist/icons-Bz84Dr-q.cjs.map +1 -0
- package/dist/{icons-BbaI9Zf-.js → icons-D93IZn6-.js} +29 -25
- package/dist/icons-D93IZn6-.js.map +1 -0
- package/dist/icons.cjs +1 -1
- package/dist/icons.js +1 -1
- package/dist/{iframe-Ct50FYXq.cjs → iframe-Cmanzy9x.cjs} +1 -1
- package/dist/{iframe-Ct50FYXq.cjs.map → iframe-Cmanzy9x.cjs.map} +1 -1
- package/dist/{iframe-CEDOvkql.js → iframe-DyOg96rn.js} +1 -1
- package/dist/{iframe-CEDOvkql.js.map → iframe-DyOg96rn.js.map} +1 -1
- package/dist/iframe.cjs +1 -1
- package/dist/iframe.js +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.js +40 -40
- package/dist/{input-DMjpf6V8.cjs.map → input-DIuyi3Gm.cjs.map} +1 -1
- package/dist/{input-Ri72dn5t.js.map → input-HzweUBSn.js.map} +1 -1
- package/dist/{input-chip-CI4__N8w.js → input-chip-B4uw64rQ.js} +1 -1
- package/dist/{input-chip-CI4__N8w.js.map → input-chip-B4uw64rQ.js.map} +1 -1
- package/dist/{input-chip-BhjGVpc3.cjs → input-chip-DY9IEbQj.cjs} +1 -1
- package/dist/{input-chip-BhjGVpc3.cjs.map → input-chip-DY9IEbQj.cjs.map} +1 -1
- package/dist/input.cjs +1 -1
- package/dist/input.js +1 -1
- package/dist/{intersection-LfEsy29T.js.map → intersection-C0JuW_7U.js.map} +1 -1
- package/dist/{intersection-D1v1UCVv.cjs.map → intersection-MvbRovUz.cjs.map} +1 -1
- package/dist/json.cjs +1 -1
- package/dist/json.js +2 -2
- package/dist/kbd.cjs +1 -1
- package/dist/kbd.js +1 -1
- package/dist/{layout-uAQpJN31.js → layout-D7OCZ8rE.js} +2 -2
- package/dist/{layout-uAQpJN31.js.map → layout-D7OCZ8rE.js.map} +1 -1
- package/dist/{layout-D7xOqMkJ.cjs → layout-DIuACbuC.cjs} +1 -1
- package/dist/{layout-D7xOqMkJ.cjs.map → layout-DIuACbuC.cjs.map} +1 -1
- package/dist/layout.cjs +1 -1
- package/dist/layout.js +2 -2
- package/dist/{lightbox-cXRnvHMN.cjs → lightbox-DFbqNGoX.cjs} +1 -1
- package/dist/{lightbox-cXRnvHMN.cjs.map → lightbox-DFbqNGoX.cjs.map} +1 -1
- package/dist/{lightbox-C0OEHns9.js → lightbox-DL-v1tk9.js} +3 -3
- package/dist/{lightbox-C0OEHns9.js.map → lightbox-DL-v1tk9.js.map} +1 -1
- package/dist/lightbox.cjs +1 -1
- package/dist/lightbox.js +1 -1
- package/dist/{list-CmJ5h35b.cjs → list-D99W7WvC.cjs} +1 -1
- package/dist/{list-CmJ5h35b.cjs.map → list-D99W7WvC.cjs.map} +1 -1
- package/dist/{list-d1mHar5p.js → list-DZTLJ-2e.js} +2 -2
- package/dist/{list-d1mHar5p.js.map → list-DZTLJ-2e.js.map} +1 -1
- package/dist/list.cjs +1 -1
- package/dist/list.js +1 -1
- package/dist/{litElement.mixin-CncaUoxz.js → litElement.mixin-D6ZHgGZv.js} +1 -1
- package/dist/{litElement.mixin-CncaUoxz.js.map → litElement.mixin-D6ZHgGZv.js.map} +1 -1
- package/dist/{litElement.mixin-Bj2q1yPw.cjs → litElement.mixin-De5SG5z7.cjs} +1 -1
- package/dist/{litElement.mixin-Bj2q1yPw.cjs.map → litElement.mixin-De5SG5z7.cjs.map} +1 -1
- package/dist/{mailbox-C4-E93be.js → mailbox-BBV6hDAa.js} +5 -5
- package/dist/{mailbox-C4-E93be.js.map → mailbox-BBV6hDAa.js.map} +1 -1
- package/dist/{mailbox-BmChskZc.cjs → mailbox-CW7zc0v-.cjs} +1 -1
- package/dist/{mailbox-BmChskZc.cjs.map → mailbox-CW7zc0v-.cjs.map} +1 -1
- package/dist/mailbox.cjs +1 -1
- package/dist/mailbox.js +1 -1
- package/dist/{map-DYEvlNl0.cjs → map-CSQMA89X.cjs} +1 -1
- package/dist/{map-DYEvlNl0.cjs.map → map-CSQMA89X.cjs.map} +1 -1
- package/dist/{map-DHyYLhvy.js → map-PvojF8B3.js} +1 -1
- package/dist/{map-DHyYLhvy.js.map → map-PvojF8B3.js.map} +1 -1
- package/dist/map.cjs +1 -1
- package/dist/map.js +1 -1
- package/dist/{menu-BlPTI6H9.cjs → menu-3XXOfmrj.cjs} +1 -1
- package/dist/{menu-BlPTI6H9.cjs.map → menu-3XXOfmrj.cjs.map} +1 -1
- package/dist/{menu-DFDBADp4.js → menu-B_o1fOPW.js} +2 -2
- package/dist/{menu-DFDBADp4.js.map → menu-B_o1fOPW.js.map} +1 -1
- package/dist/menu.cjs +1 -1
- package/dist/menu.js +1 -1
- package/dist/mixins.cjs +1 -1
- package/dist/mixins.js +2 -2
- package/dist/nav-drawer.cjs +1 -1
- package/dist/nav-drawer.js +1 -1
- package/dist/navigation-bar.cjs +1 -1
- package/dist/navigation-bar.js +1 -1
- package/dist/navigation-rail.cjs +1 -1
- package/dist/navigation-rail.js +1 -1
- package/dist/{notification-DGpv8g2H.js → notification-BMtrJG-Y.js} +2 -2
- package/dist/{notification-DGpv8g2H.js.map → notification-BMtrJG-Y.js.map} +1 -1
- package/dist/{notification-DKVWYhqs.cjs → notification-NnsatHAh.cjs} +1 -1
- package/dist/{notification-DKVWYhqs.cjs.map → notification-NnsatHAh.cjs.map} +1 -1
- package/dist/notification.cjs +1 -1
- package/dist/notification.js +1 -1
- package/dist/{option-BD2eh458.js → option-CNzW-sdU.js} +1 -1
- package/dist/{option-BD2eh458.js.map → option-CNzW-sdU.js.map} +1 -1
- package/dist/{option-LtSDy2xf.cjs → option-DxIFpYpC.cjs} +1 -1
- package/dist/{option-LtSDy2xf.cjs.map → option-DxIFpYpC.cjs.map} +1 -1
- package/dist/option.cjs +1 -1
- package/dist/option.js +1 -1
- package/dist/{overlay-stack-Ca4EK2Mu.js.map → overlay-stack-BJt_r6aZ.js.map} +1 -1
- package/dist/{overlay-stack-CEYGD9T1.cjs.map → overlay-stack-J_eJCUTX.cjs.map} +1 -1
- package/dist/page.cjs +1 -1
- package/dist/page.js +2 -2
- package/dist/{progress-B5ChDPbB.cjs → progress-Cw6Qn3Kb.cjs} +1 -1
- package/dist/{progress-B5ChDPbB.cjs.map → progress-Cw6Qn3Kb.cjs.map} +1 -1
- package/dist/{progress-CE1Pk2hi.js → progress-DHmYCHmy.js} +1 -1
- package/dist/{progress-CE1Pk2hi.js.map → progress-DHmYCHmy.js.map} +1 -1
- package/dist/progress.cjs +1 -1
- package/dist/progress.js +1 -1
- package/dist/{provide-jn1Fj1vv.js → provide-C4L6R1lo.js} +1 -1
- package/dist/{provide-jn1Fj1vv.js.map → provide-C4L6R1lo.js.map} +1 -1
- package/dist/{provide-BZ9lq_Be.cjs → provide-Dsoh3FdP.cjs} +1 -1
- package/dist/{provide-BZ9lq_Be.cjs.map → provide-Dsoh3FdP.cjs.map} +1 -1
- package/dist/qr-scanner.cjs +1 -1
- package/dist/qr-scanner.js +1 -1
- package/dist/{radio-group-CyRHgIF3.js → radio-group-DneItRXU.js} +1 -1
- package/dist/{radio-group-CyRHgIF3.js.map → radio-group-DneItRXU.js.map} +1 -1
- package/dist/{radio-group-Cd9pZ2MR.cjs → radio-group-xgKQTd6h.cjs} +1 -1
- package/dist/{radio-group-Cd9pZ2MR.cjs.map → radio-group-xgKQTd6h.cjs.map} +1 -1
- package/dist/radio-group.cjs +1 -1
- package/dist/radio-group.js +1 -1
- package/dist/range.cjs +1 -1
- package/dist/range.js +1 -1
- package/dist/{rxjs-utils-Bldch1RO.js.map → rxjs-utils-CN9fv8Xq.js.map} +1 -1
- package/dist/{rxjs-utils-hAgKC7vk.cjs.map → rxjs-utils-Vn6DCKgL.cjs.map} +1 -1
- package/dist/rxjs-utils.cjs +1 -1
- package/dist/rxjs-utils.js +1 -1
- package/dist/{scroll-DoliwpRu.js → scroll-D7QJYev7.js} +1 -1
- package/dist/{scroll-DoliwpRu.js.map → scroll-D7QJYev7.js.map} +1 -1
- package/dist/{scroll-C_iNOi7E.cjs → scroll-DZAB4JFv.cjs} +1 -1
- package/dist/{scroll-C_iNOi7E.cjs.map → scroll-DZAB4JFv.cjs.map} +1 -1
- package/dist/{select-_vHPXi30.js → select-B2T3RZng.js} +2 -2
- package/dist/{select-_vHPXi30.js.map → select-B2T3RZng.js.map} +1 -1
- package/dist/{select-CWWuZ2iJ.cjs → select-D2eLEDUT.cjs} +1 -1
- package/dist/{select-CWWuZ2iJ.cjs.map → select-D2eLEDUT.cjs.map} +1 -1
- package/dist/select.cjs +1 -1
- package/dist/select.js +1 -1
- package/dist/{sheet-i1KtxGIj.js → sheet-BiGXZPdu.js} +3 -3
- package/dist/{sheet-i1KtxGIj.js.map → sheet-BiGXZPdu.js.map} +1 -1
- package/dist/{sheet-r0oEYIdi.cjs → sheet-NaecDxuR.cjs} +1 -1
- package/dist/{sheet-r0oEYIdi.cjs.map → sheet-NaecDxuR.cjs.map} +1 -1
- package/dist/sheet.cjs +1 -1
- package/dist/sheet.js +2 -2
- package/dist/{sheet.service-Cr13Oo6G.cjs → sheet.service-CQq5hUNb.cjs} +1 -1
- package/dist/{sheet.service-Cr13Oo6G.cjs.map → sheet.service-CQq5hUNb.cjs.map} +1 -1
- package/dist/{sheet.service-DUO5_kmI.js → sheet.service-gek7Spb6.js} +2 -2
- package/dist/{sheet.service-DUO5_kmI.js.map → sheet.service-gek7Spb6.js.map} +1 -1
- package/dist/skeleton.cjs +1 -1
- package/dist/skeleton.js +1 -1
- package/dist/skills/INDEX.md +1 -1
- package/dist/skills/SKILL.md +2 -2
- package/dist/skills/schmancy/INDEX.md +1 -1
- package/dist/skills/schmancy/SKILL.md +2 -2
- package/dist/skills/schmancy/surface.md +14 -0
- package/dist/skills/schmancy/theme.md +83 -5
- package/dist/skills/surface.md +14 -0
- package/dist/skills/theme.md +83 -5
- package/dist/slider.cjs +1 -1
- package/dist/slider.js +1 -1
- package/dist/{splash-screen-CquyPP1C.cjs → splash-screen-CxPHf-SC.cjs} +1 -1
- package/dist/{splash-screen-CquyPP1C.cjs.map → splash-screen-CxPHf-SC.cjs.map} +1 -1
- package/dist/{splash-screen-CvucPkpD.js → splash-screen-Dc6LDIbK.js} +1 -1
- package/dist/{splash-screen-CvucPkpD.js.map → splash-screen-Dc6LDIbK.js.map} +1 -1
- package/dist/splash-screen.cjs +1 -1
- package/dist/splash-screen.js +1 -1
- package/dist/{src-Bemk2C2P.cjs → src-BP8bYUHc.cjs} +1 -1
- package/dist/{src-Bemk2C2P.cjs.map → src-BP8bYUHc.cjs.map} +1 -1
- package/dist/{src-f5a3W9Mj.js → src-BYrvfmFF.js} +46 -46
- package/dist/{src-f5a3W9Mj.js.map → src-BYrvfmFF.js.map} +1 -1
- package/dist/steps.cjs +1 -1
- package/dist/steps.js +3 -3
- package/dist/{surface-CkEYJCae.js → surface-B2cmGNZ2.js} +2 -2
- package/dist/{surface-CkEYJCae.js.map → surface-B2cmGNZ2.js.map} +1 -1
- package/dist/{surface-CDufon40.cjs → surface-C9plkl5F.cjs} +1 -1
- package/dist/{surface-CDufon40.cjs.map → surface-C9plkl5F.cjs.map} +1 -1
- package/dist/surface.cjs +1 -1
- package/dist/surface.js +1 -1
- package/dist/switch.cjs +1 -1
- package/dist/switch.js +1 -1
- package/dist/{table-DWc1mkpj.cjs → table-6xNLZh3K.cjs} +2 -2
- package/dist/{table-DWc1mkpj.cjs.map → table-6xNLZh3K.cjs.map} +1 -1
- package/dist/{table-P6VGG7NK.js → table-BCJgjSvq.js} +3 -3
- package/dist/{table-P6VGG7NK.js.map → table-BCJgjSvq.js.map} +1 -1
- package/dist/table.cjs +1 -1
- package/dist/table.js +1 -1
- package/dist/{tabs-CjGjGrqY.js → tabs-BDqvhB54.js} +2 -2
- package/dist/{tabs-CjGjGrqY.js.map → tabs-BDqvhB54.js.map} +1 -1
- package/dist/{tabs-DGJEKuhC.cjs → tabs-pvevSaFB.cjs} +1 -1
- package/dist/{tabs-DGJEKuhC.cjs.map → tabs-pvevSaFB.cjs.map} +1 -1
- package/dist/tabs.cjs +1 -1
- package/dist/tabs.js +1 -1
- package/dist/tailwind.mixin-Bug3G6K6.cjs +2 -0
- package/dist/tailwind.mixin-Bug3G6K6.cjs.map +1 -0
- package/dist/tailwind.mixin-ywtUNG2c.js +219 -0
- package/dist/tailwind.mixin-ywtUNG2c.js.map +1 -0
- package/dist/teleport.cjs +1 -1
- package/dist/teleport.js +1 -1
- package/dist/{textarea-DZT_Ofp5.js → textarea-BvZn41aa.js} +1 -1
- package/dist/{textarea-DZT_Ofp5.js.map → textarea-BvZn41aa.js.map} +1 -1
- package/dist/{textarea-jmTOXrzl.cjs → textarea-D2v000gK.cjs} +1 -1
- package/dist/{textarea-jmTOXrzl.cjs.map → textarea-D2v000gK.cjs.map} +1 -1
- package/dist/textarea.cjs +1 -1
- package/dist/textarea.js +1 -1
- package/dist/{theme-CCKqaksQ.cjs → theme-Dw9Ag_VS.cjs} +1 -1
- package/dist/{theme-CCKqaksQ.cjs.map → theme-Dw9Ag_VS.cjs.map} +1 -1
- package/dist/{theme-CEc32pAv.js → theme-JvXazXJr.js} +4 -4
- package/dist/{theme-CEc32pAv.js.map → theme-JvXazXJr.js.map} +1 -1
- package/dist/{theme-button-dOiAvdKU.js → theme-button-Bh8wKXtV.js} +1 -1
- package/dist/{theme-button-dOiAvdKU.js.map → theme-button-Bh8wKXtV.js.map} +1 -1
- package/dist/{theme-button-BsJcv-Zv.cjs → theme-button-qHd4AFsE.cjs} +1 -1
- package/dist/{theme-button-BsJcv-Zv.cjs.map → theme-button-qHd4AFsE.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.interface-CM26m9te.cjs.map → theme.interface-CCE3L1ql.cjs.map} +1 -1
- package/dist/{theme.interface-FAUIgbIq.js.map → theme.interface-Cyqv5XWY.js.map} +1 -1
- package/dist/theme.js +3 -3
- package/dist/tree.cjs +1 -1
- package/dist/tree.js +1 -1
- package/dist/{tslib.es6-Bd-92OW3.cjs.map → tslib.es6-PMITL0Z3.cjs.map} +1 -1
- package/dist/{tslib.es6-CI1onEZb.js.map → tslib.es6-vJQZBGJO.js.map} +1 -1
- package/dist/{typewriter-ByIL2Mh-.cjs → typewriter-C5uDB2Lu.cjs} +1 -1
- package/dist/{typewriter-ByIL2Mh-.cjs.map → typewriter-C5uDB2Lu.cjs.map} +1 -1
- package/dist/{typewriter-vOQ3bDLb.js → typewriter-PpYJFsVi.js} +5 -5
- package/dist/{typewriter-vOQ3bDLb.js.map → typewriter-PpYJFsVi.js.map} +1 -1
- package/dist/typewriter.cjs +1 -1
- package/dist/typewriter.js +1 -1
- package/dist/typography.cjs +1 -1
- package/dist/typography.js +1 -1
- package/dist/{utils-D2kE-6zc.cjs → utils-C8PD8So2.cjs} +1 -1
- package/dist/{utils-D2kE-6zc.cjs.map → utils-C8PD8So2.cjs.map} +1 -1
- package/dist/{utils-Cq0m3LYo.js → utils-DVuCPDfw.js} +2 -2
- package/dist/{utils-Cq0m3LYo.js.map → utils-DVuCPDfw.js.map} +1 -1
- package/dist/utils.cjs +1 -1
- package/dist/utils.js +3 -3
- package/dist/visually-hidden.cjs +1 -1
- package/dist/visually-hidden.js +1 -1
- package/dist/{window-WnAihpsA.js → window-ChDgkb97.js} +2 -2
- package/dist/{window-WnAihpsA.js.map → window-ChDgkb97.js.map} +1 -1
- package/dist/{window-BS7ZQjgH.cjs → window-Czfu-i4Y.cjs} +1 -1
- package/dist/{window-BS7ZQjgH.cjs.map → window-Czfu-i4Y.cjs.map} +1 -1
- package/dist/window.cjs +1 -1
- package/dist/window.js +1 -1
- package/package.json +1 -1
- package/skills/schmancy/INDEX.md +1 -1
- package/skills/schmancy/SKILL.md +2 -2
- package/skills/schmancy/surface.md +14 -0
- package/skills/schmancy/theme.md +83 -5
- package/src/button/button.ts +6 -1
- package/src/button/context.ts +9 -0
- package/src/icons/icon.ts +19 -3
- package/types/src/button/button.d.ts +4 -1
- package/types/src/button/context.d.ts +8 -0
- package/types/src/icons/icon.d.ts +9 -0
- package/dist/icons-BbaI9Zf-.js.map +0 -1
- package/dist/icons-DPUeLS_Y.cjs.map +0 -1
- package/dist/tailwind.mixin-Cpa-VnnX.cjs +0 -2
- package/dist/tailwind.mixin-Cpa-VnnX.cjs.map +0 -1
- package/dist/tailwind.mixin-DufHBjmb.js +0 -219
- package/dist/tailwind.mixin-DufHBjmb.js.map +0 -1
- /package/dist/{date-range-inline-B87TDYI6.js → date-range-inline-B_g1YXu3.js} +0 -0
- /package/dist/{date-range-inline-De-M0VmL.cjs → date-range-inline-LLC3Y0mi.cjs} +0 -0
- /package/dist/{flow-CqgDEIqK.js → flow-BPDtbhLe.js} +0 -0
- /package/dist/{flow-DSu4PLt1.cjs → flow-Dn9AZktE.cjs} +0 -0
- /package/dist/{form-D2cJ58TB.js → form-C1qS9uvS.js} +0 -0
- /package/dist/{form-CAY9GSCd.cjs → form-CzD0JLxM.cjs} +0 -0
- /package/dist/{hashContent-nD2uWwi2.js → hashContent-BUqULUiZ.js} +0 -0
- /package/dist/{hashContent-kKvXKFa9.cjs → hashContent-CI39BY-_.cjs} +0 -0
- /package/dist/{input-DMjpf6V8.cjs → input-DIuyi3Gm.cjs} +0 -0
- /package/dist/{input-Ri72dn5t.js → input-HzweUBSn.js} +0 -0
- /package/dist/{intersection-LfEsy29T.js → intersection-C0JuW_7U.js} +0 -0
- /package/dist/{intersection-D1v1UCVv.cjs → intersection-MvbRovUz.cjs} +0 -0
- /package/dist/{overlay-stack-Ca4EK2Mu.js → overlay-stack-BJt_r6aZ.js} +0 -0
- /package/dist/{overlay-stack-CEYGD9T1.cjs → overlay-stack-J_eJCUTX.cjs} +0 -0
- /package/dist/{rxjs-utils-Bldch1RO.js → rxjs-utils-CN9fv8Xq.js} +0 -0
- /package/dist/{rxjs-utils-hAgKC7vk.cjs → rxjs-utils-Vn6DCKgL.cjs} +0 -0
- /package/dist/{theme.interface-CM26m9te.cjs → theme.interface-CCE3L1ql.cjs} +0 -0
- /package/dist/{theme.interface-FAUIgbIq.js → theme.interface-Cyqv5XWY.js} +0 -0
- /package/dist/{tslib.es6-Bd-92OW3.cjs → tslib.es6-PMITL0Z3.cjs} +0 -0
- /package/dist/{tslib.es6-CI1onEZb.js → tslib.es6-vJQZBGJO.js} +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dialog-service-ClFrOWf4.js","names":[],"sources":["../src/dialog/dialog-events.ts","../src/dialog/dialog-service.ts"],"sourcesContent":["// Dialog discovery event constants\r\nexport const DialogWhereAreYouRicky = 'are-you-there-dialog'\r\nexport const DialogHereMorty = 'yes-dialog-here'\r\n\r\n// Event interfaces\r\nexport interface DialogWhereAreYouRickyEvent extends CustomEvent {\r\n detail: {\r\n uid: string\r\n }\r\n}\r\n\r\nexport interface DialogHereMortyEvent extends CustomEvent {\r\n detail: {\r\n dialog: any // Will be schmancy-dialog instance\r\n theme?: any // Will be schmancy-theme instance\r\n }\r\n}","import { render, TemplateResult } from 'lit'\nimport {\n\tdefaultIfEmpty,\n\tforkJoin,\n\tfromEvent,\n\tmap,\n\tof,\n\tSubject,\n\tSubscription,\n\tswitchMap,\n\ttakeUntil,\n\ttap,\n\ttimer,\n} from 'rxjs'\nimport { ThemeHereIAm, ThemeHereIAmEvent, ThemeWhereAreYou } from '../theme/theme.events'\nimport { overlayStack } from '../utils/overlay-stack'\nimport { SchmancyDialog } from './dialog.component'\nimport { DialogHereMorty, DialogHereMortyEvent, DialogWhereAreYouRicky } from './dialog-events'\n\n/**\n * Dialog service options interface\n */\nexport interface DialogOptions {\n\ttitle?: string\n\tsubtitle?: string\n\tmessage?: string\n\tconfirmText?: string\n\tcancelText?: string\n\tvariant?: 'default' | 'danger'\n\tposition?: { x: number; y: number } | MouseEvent | TouchEvent\n\tcontent?: TemplateResult | HTMLElement | (() => HTMLElement | TemplateResult)\n\tonConfirm?: () => void\n\tonCancel?: () => void\n\thideActions?: boolean\n\ttargetContainer?: HTMLElement\n}\n\n/**\n * Prompt dialog options\n */\nexport interface PromptOptions {\n\ttitle?: string\n\tmessage?: string\n\tlabel?: string\n\tplaceholder?: string\n\tdefaultValue?: string\n\tinputType?: 'text' | 'email' | 'password' | 'number' | 'tel' | 'url'\n\tconfirmText?: string\n\tcancelText?: string\n\tposition?: { x: number; y: number } | MouseEvent | TouchEvent\n}\n\ninterface DialogTarget {\n\toptions: DialogOptions\n\ttype: 'confirm' | 'component'\n\tcontent?: TemplateResult | HTMLElement | (() => HTMLElement | TemplateResult)\n\tresolve?: (value: boolean) => void\n\treject?: (reason?: unknown) => void\n}\n\n/**\n * Dialog service for centralized dialog management.\n * Uses a single unified SchmancyDialog component for all dialog types.\n */\nexport class DialogService {\n\tprivate static instance: DialogService\n\n\tprivate static DEFAULT_OPTIONS: Partial<DialogOptions> = {\n\t\ttitle: undefined,\n\t\tsubtitle: undefined,\n\t\tconfirmText: undefined,\n\t\tcancelText: undefined,\n\t\tvariant: 'default',\n\t}\n\n\t// Single array to track all dialogs\n\tprivate activeDialogs: SchmancyDialog[] = []\n\n\tprivate dialogSubject = new Subject<DialogTarget>()\n\tprivate dismissSubject = new Subject<string>()\n\n\t// Lazy click position tracking - only initialized when first dialog opens\n\tprivate lastClickPosition: { x: number; y: number } | null = null\n\tprivate clickTrackingInitialized = false\n\n\tprivate constructor() {\n\t\tthis.setupDialogOpeningLogic()\n\t\tthis.setupDialogDismissLogic()\n\t\tthis.setupClickPositionTracking()\n\t}\n\n\tprivate setupClickPositionTracking() {\n\t\tif (this.clickTrackingInitialized || typeof document === 'undefined') return\n\t\tthis.clickTrackingInitialized = true\n\n\t\tfromEvent<PointerEvent>(document, 'pointerdown', { capture: true, passive: true })\n\t\t\t.pipe(\n\t\t\t\ttap(event => {\n\t\t\t\t\tthis.lastClickPosition = { x: event.clientX, y: event.clientY }\n\t\t\t\t}),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tpublic static getInstance(): DialogService {\n\t\tif (!DialogService.instance) {\n\t\t\tDialogService.instance = new DialogService()\n\t\t}\n\t\treturn DialogService.instance\n\t}\n\n\tprivate setupDialogOpeningLogic() {\n\t\tthis.dialogSubject\n\t\t\t.pipe(\n\t\t\t\tswitchMap(target =>\n\t\t\t\t\tforkJoin([\n\t\t\t\t\t\tfromEvent<ThemeHereIAmEvent>(window, ThemeHereIAm).pipe(\n\t\t\t\t\t\t\ttakeUntil(timer(50)),\n\t\t\t\t\t\t\tmap(e => e.detail.theme),\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\tconst uid = `dialog-${Date.now()}-${Math.random().toString(36).substring(2, 9)}`\n\t\t\t\t\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\t\t\t\t\tnew CustomEvent(ThemeWhereAreYou, {\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\t;(target as { uid?: string }).uid = 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\tmap(([theme, target]) => {\n\t\t\t\t\tconst targetContainer =\n\t\t\t\t\t\ttheme ||\n\t\t\t\t\t\ttarget.options.targetContainer ||\n\t\t\t\t\t\t(document.querySelector('schmancy-theme') as HTMLElement) ||\n\t\t\t\t\t\tdocument.body\n\n\t\t\t\t\tconst uid = (target as { uid?: string }).uid!\n\t\t\t\t\tconst dialog = document.createElement('schmancy-dialog') as SchmancyDialog\n\t\t\t\t\tdialog.setAttribute('uid', uid)\n\t\t\t\t\tdialog.style.setProperty('--schmancy-overlay-z', String(overlayStack.getNextZIndex()))\n\t\t\t\t\ttargetContainer.appendChild(dialog)\n\n\t\t\t\t\treturn { dialog, target }\n\t\t\t\t}),\n\t\t\t\ttap(({ dialog, target }) => {\n\t\t\t\t\tconst options = target.options\n\n\t\t\t\t\tif (target.type === 'confirm') {\n\t\t\t\t\t\t// Configure for confirm mode\n\t\t\t\t\t\tdialog.title = options.title\n\t\t\t\t\t\tdialog.subtitle = options.subtitle\n\t\t\t\t\t\tdialog.message = options.message\n\t\t\t\t\t\tdialog.confirmText = options.confirmText ?? 'Confirm'\n\t\t\t\t\t\tdialog.cancelText = options.cancelText ?? 'Cancel'\n\t\t\t\t\t\tdialog.variant = options.variant ?? 'default'\n\n\t\t\t\t\t\t// Handle custom content slot\n\t\t\t\t\t\tif (options.content) {\n\t\t\t\t\t\t\tconst contentContainer = document.createElement('div')\n\t\t\t\t\t\t\tcontentContainer.slot = 'content'\n\n\t\t\t\t\t\t\tif (typeof options.content === 'function') {\n\t\t\t\t\t\t\t\tconst result = options.content()\n\t\t\t\t\t\t\t\tif (result instanceof HTMLElement) {\n\t\t\t\t\t\t\t\t\tcontentContainer.appendChild(result)\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\trender(result, contentContainer)\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} else if (options.content instanceof HTMLElement) {\n\t\t\t\t\t\t\t\tcontentContainer.appendChild(options.content)\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\trender(options.content, contentContainer)\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tdialog.appendChild(contentContainer)\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// Configure for content mode\n\t\t\t\t\t\tdialog.hideActions = true\n\n\t\t\t\t\t\tif (target.content) {\n\t\t\t\t\t\t\tconst contentContainer = document.createElement('div')\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tcontentContainer.style.display = 'contents'\n\t\t\t\t\t\t\tcontentContainer.classList.add('schmancy-dialog-content-container')\n\n\t\t\t\t\t\t\tif (typeof target.content === 'function') {\n\t\t\t\t\t\t\t\tconst result = target.content()\n\t\t\t\t\t\t\t\tif (result instanceof HTMLElement) {\n\t\t\t\t\t\t\t\t\tcontentContainer.appendChild(result)\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\trender(result, contentContainer)\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} else if (target.content instanceof HTMLElement) {\n\t\t\t\t\t\t\t\tcontentContainer.appendChild(target.content)\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\trender(target.content, contentContainer)\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tdialog.appendChild(contentContainer)\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.activeDialogs.push(dialog)\n\t\t\t\t}),\n\t\t\t\ttap(({ dialog, target }) => {\n\t\t\t\t\tconst position = target.options.position || this.getDefaultPosition()\n\n\t\t\t\t\tdialog\n\t\t\t\t\t\t.show(position)\n\t\t\t\t\t\t.then((result: boolean) => {\n\t\t\t\t\t\t\ttarget.resolve?.(result)\n\n\t\t\t\t\t\t\t// Cleanup\n\t\t\t\t\t\t\tconst index = this.activeDialogs.indexOf(dialog)\n\t\t\t\t\t\t\tif (index !== -1) {\n\t\t\t\t\t\t\t\tthis.activeDialogs.splice(index, 1)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\toverlayStack.release()\n\n\t\t\t\t\t\t\t// Clean up content\n\t\t\t\t\t\t\tconst contentEl = dialog.querySelector('[slot=\"content\"]')\n\t\t\t\t\t\t\tif (contentEl) dialog.removeChild(contentEl)\n\n\t\t\t\t\t\t\tconst contentContainer = dialog.querySelector('.schmancy-dialog-content-container')\n\t\t\t\t\t\t\tif (contentContainer?.parentNode) {\n\t\t\t\t\t\t\t\tcontentContainer.parentNode.removeChild(contentContainer)\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t// Clean up event subscriptions\n\t\t\t\t\t\t\tconst eventSubscriptions = (dialog as unknown as { _eventSubscriptions?: Subscription[] })\n\t\t\t\t\t\t\t\t._eventSubscriptions\n\t\t\t\t\t\t\teventSubscriptions?.forEach(sub => sub.unsubscribe())\n\n\t\t\t\t\t\t\t// Remove from DOM\n\t\t\t\t\t\t\tdialog.parentElement?.removeChild(dialog)\n\t\t\t\t\t\t})\n\t\t\t\t\t\t.catch((error: unknown) => {\n\t\t\t\t\t\t\ttarget.reject?.(error)\n\t\t\t\t\t\t})\n\n\t\t\t\t\t// Set up event listeners\n\t\t\t\t\tconst eventSubscriptions: Subscription[] = []\n\n\t\t\t\t\tif (target.options.onConfirm) {\n\t\t\t\t\t\tconst confirmSub = fromEvent(dialog, 'confirm').subscribe(() => {\n\t\t\t\t\t\t\ttarget.options.onConfirm!()\n\t\t\t\t\t\t\tconfirmSub.unsubscribe()\n\t\t\t\t\t\t})\n\t\t\t\t\t\teventSubscriptions.push(confirmSub)\n\t\t\t\t\t}\n\n\t\t\t\t\tif (target.options.onCancel) {\n\t\t\t\t\t\tconst cancelSub = fromEvent(dialog, 'cancel').subscribe(() => {\n\t\t\t\t\t\t\ttarget.options.onCancel!()\n\t\t\t\t\t\t\tcancelSub.unsubscribe()\n\t\t\t\t\t\t})\n\t\t\t\t\t\teventSubscriptions.push(cancelSub)\n\t\t\t\t\t}\n\n\t\t\t\t\t;(dialog as unknown as { _eventSubscriptions: Subscription[] })._eventSubscriptions = eventSubscriptions\n\t\t\t\t}),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tprivate setupDialogDismissLogic() {\n\t\tthis.dismissSubject\n\t\t\t.pipe(\n\t\t\t\tswitchMap(uid =>\n\t\t\t\t\tforkJoin([\n\t\t\t\t\t\tfromEvent<DialogHereMortyEvent>(window, DialogHereMorty).pipe(\n\t\t\t\t\t\t\ttakeUntil(timer(100)),\n\t\t\t\t\t\t\tmap(e => e.detail),\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(\n\t\t\t\t\t\t\t\t\tnew CustomEvent(DialogWhereAreYouRicky, {\n\t\t\t\t\t\t\t\t\t\tdetail: { uid },\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]),\n\t\t\t\t),\n\t\t\t\ttap(([response]) => {\n\t\t\t\t\tif (response?.dialog) {\n\t\t\t\t\t\tresponse.dialog.hide(false)\n\n\t\t\t\t\t\tconst eventSubscriptions = (response.dialog as unknown as { _eventSubscriptions?: Subscription[] })\n\t\t\t\t\t\t\t._eventSubscriptions\n\t\t\t\t\t\teventSubscriptions?.forEach(sub => sub.unsubscribe())\n\n\t\t\t\t\t\tconst index = this.activeDialogs.indexOf(response.dialog as SchmancyDialog)\n\t\t\t\t\t\tif (index !== -1) {\n\t\t\t\t\t\t\tthis.activeDialogs.splice(index, 1)\n\t\t\t\t\t\t}\n\t\t\t\t\t\toverlayStack.release()\n\n\t\t\t\t\t\tresponse.dialog.parentElement?.removeChild(response.dialog)\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tpublic confirm(options: DialogOptions): Promise<boolean> {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tconst completeOptions = {\n\t\t\t\t...DialogService.DEFAULT_OPTIONS,\n\t\t\t\t...options,\n\t\t\t}\n\n\t\t\tif (!completeOptions.position) {\n\t\t\t\tcompleteOptions.position = this.getDefaultPosition()\n\t\t\t}\n\n\t\t\tthis.dialogSubject.next({\n\t\t\t\toptions: completeOptions,\n\t\t\t\ttype: 'confirm',\n\t\t\t\tcontent: completeOptions.content,\n\t\t\t\tresolve,\n\t\t\t\treject,\n\t\t\t})\n\t\t})\n\t}\n\n\tpublic component(\n\t\tcontent: TemplateResult | HTMLElement | (() => HTMLElement | TemplateResult),\n\t\toptions: Omit<DialogOptions, 'content' | 'message'> = {},\n\t): Promise<boolean> {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tif (!options.position) {\n\t\t\t\toptions.position = this.getDefaultPosition()\n\t\t\t}\n\n\t\t\tthis.dialogSubject.next({\n\t\t\t\toptions: options as DialogOptions,\n\t\t\t\ttype: 'component',\n\t\t\t\tcontent,\n\t\t\t\tresolve,\n\t\t\t\treject,\n\t\t\t})\n\t\t})\n\t}\n\n\tpublic dismiss(): boolean {\n\t\tif (this.activeDialogs.length > 0) {\n\t\t\tconst dialog = this.activeDialogs[this.activeDialogs.length - 1]\n\t\t\tconst uid = dialog.getAttribute('uid')\n\n\t\t\tif (uid) {\n\t\t\t\tthis.dismissSubject.next(uid)\n\t\t\t\treturn true\n\t\t\t}\n\t\t}\n\t\treturn false\n\t}\n\n\tpublic close(): boolean {\n\t\treturn this.dismiss()\n\t}\n\n\tpublic ask(message: string, event?: MouseEvent | TouchEvent): Promise<boolean> {\n\t\treturn this.confirm({\n\t\t\tmessage,\n\t\t\tconfirmText: 'Confirm',\n\t\t\tcancelText: 'Cancel',\n\t\t\tposition: event,\n\t\t})\n\t}\n\n\tpublic danger(options: Omit<DialogOptions, 'variant'>): Promise<boolean> {\n\t\treturn this.confirm({\n\t\t\t...options,\n\t\t\tvariant: 'danger',\n\t\t})\n\t}\n\n\t/**\n\t * Shows a prompt dialog with an input field.\n\t * Returns the input value if confirmed, null if cancelled.\n\t */\n\tpublic prompt(options: PromptOptions): Promise<string | null> {\n\t\treturn new Promise(resolve => {\n\t\t\tlet inputValue = options.defaultValue || ''\n\n\t\t\t// Create container for input\n\t\t\tconst container = document.createElement('div')\n\t\t\tcontainer.style.width = '100%'\n\t\t\tcontainer.style.minWidth = '280px'\n\n\t\t\tconst input = document.createElement('schmancy-input') as HTMLElement\n\t\t\tinput.setAttribute('type', options.inputType || 'text')\n\t\t\tif (options.label) input.setAttribute('label', options.label)\n\t\t\tif (options.placeholder) input.setAttribute('placeholder', options.placeholder)\n\t\t\tif (options.defaultValue) input.setAttribute('value', options.defaultValue)\n\n\t\t\tinput.addEventListener('input', (e: Event) => {\n\t\t\t\tinputValue = (e.target as HTMLInputElement).value\n\t\t\t})\n\n\t\t\tcontainer.appendChild(input)\n\n\t\t\tthis.confirm({\n\t\t\t\ttitle: options.title,\n\t\t\t\tmessage: options.message,\n\t\t\t\tconfirmText: options.confirmText ?? 'OK',\n\t\t\t\tcancelText: options.cancelText ?? 'Cancel',\n\t\t\t\tposition: options.position,\n\t\t\t\tcontent: container,\n\t\t\t}).then(confirmed => {\n\t\t\t\tresolve(confirmed ? inputValue : null)\n\t\t\t})\n\t\t})\n\t}\n\n\tprivate getDefaultPosition(): { x: number; y: number } {\n\t\t// Use last click position if available, otherwise center of screen\n\t\tif (this.lastClickPosition) {\n\t\t\treturn { ...this.lastClickPosition }\n\t\t}\n\t\treturn {\n\t\t\tx: window.innerWidth / 2,\n\t\t\ty: window.innerHeight / 2,\n\t\t}\n\t}\n}\n\n/**\n * Eagerly instantiate so click tracking starts immediately on import,\n * not on first dialog open (which would miss the triggering click).\n */\nconst service = DialogService.getInstance()\n\n/**\n * Global dialog utility\n */\nexport const $dialog = {\n\tconfirm: (options: DialogOptions): Promise<boolean> => {\n\t\treturn service.confirm(options)\n\t},\n\n\task: (message: string, event?: MouseEvent | TouchEvent): Promise<boolean> => {\n\t\treturn service.ask(message, event)\n\t},\n\n\tdanger: (options: Omit<DialogOptions, 'variant'>): Promise<boolean> => {\n\t\treturn service.danger(options)\n\t},\n\n\tprompt: (options: PromptOptions): Promise<string | null> => {\n\t\treturn service.prompt(options)\n\t},\n\n\tcomponent: (\n\t\tcontent: TemplateResult | HTMLElement | (() => HTMLElement | TemplateResult),\n\t\toptions?: Omit<DialogOptions, 'content' | 'message'>,\n\t): Promise<boolean> => {\n\t\treturn service.component(content, options)\n\t},\n\n\tdismiss: (): boolean => {\n\t\treturn service.dismiss()\n\t},\n\n\tclose: (): boolean => {\n\t\treturn service.close()\n\t},\n}\n\nexport default DialogService\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"dialog-service-CCFGpU7a.js","names":[],"sources":["../src/dialog/dialog-events.ts","../src/dialog/dialog-service.ts"],"sourcesContent":["// Dialog discovery event constants\r\nexport const DialogWhereAreYouRicky = 'are-you-there-dialog'\r\nexport const DialogHereMorty = 'yes-dialog-here'\r\n\r\n// Event interfaces\r\nexport interface DialogWhereAreYouRickyEvent extends CustomEvent {\r\n detail: {\r\n uid: string\r\n }\r\n}\r\n\r\nexport interface DialogHereMortyEvent extends CustomEvent {\r\n detail: {\r\n dialog: any // Will be schmancy-dialog instance\r\n theme?: any // Will be schmancy-theme instance\r\n }\r\n}","import { render, TemplateResult } from 'lit'\nimport {\n\tdefaultIfEmpty,\n\tforkJoin,\n\tfromEvent,\n\tmap,\n\tof,\n\tSubject,\n\tSubscription,\n\tswitchMap,\n\ttakeUntil,\n\ttap,\n\ttimer,\n} from 'rxjs'\nimport { ThemeHereIAm, ThemeHereIAmEvent, ThemeWhereAreYou } from '../theme/theme.events'\nimport { overlayStack } from '../utils/overlay-stack'\nimport { SchmancyDialog } from './dialog.component'\nimport { DialogHereMorty, DialogHereMortyEvent, DialogWhereAreYouRicky } from './dialog-events'\n\n/**\n * Dialog service options interface\n */\nexport interface DialogOptions {\n\ttitle?: string\n\tsubtitle?: string\n\tmessage?: string\n\tconfirmText?: string\n\tcancelText?: string\n\tvariant?: 'default' | 'danger'\n\tposition?: { x: number; y: number } | MouseEvent | TouchEvent\n\tcontent?: TemplateResult | HTMLElement | (() => HTMLElement | TemplateResult)\n\tonConfirm?: () => void\n\tonCancel?: () => void\n\thideActions?: boolean\n\ttargetContainer?: HTMLElement\n}\n\n/**\n * Prompt dialog options\n */\nexport interface PromptOptions {\n\ttitle?: string\n\tmessage?: string\n\tlabel?: string\n\tplaceholder?: string\n\tdefaultValue?: string\n\tinputType?: 'text' | 'email' | 'password' | 'number' | 'tel' | 'url'\n\tconfirmText?: string\n\tcancelText?: string\n\tposition?: { x: number; y: number } | MouseEvent | TouchEvent\n}\n\ninterface DialogTarget {\n\toptions: DialogOptions\n\ttype: 'confirm' | 'component'\n\tcontent?: TemplateResult | HTMLElement | (() => HTMLElement | TemplateResult)\n\tresolve?: (value: boolean) => void\n\treject?: (reason?: unknown) => void\n}\n\n/**\n * Dialog service for centralized dialog management.\n * Uses a single unified SchmancyDialog component for all dialog types.\n */\nexport class DialogService {\n\tprivate static instance: DialogService\n\n\tprivate static DEFAULT_OPTIONS: Partial<DialogOptions> = {\n\t\ttitle: undefined,\n\t\tsubtitle: undefined,\n\t\tconfirmText: undefined,\n\t\tcancelText: undefined,\n\t\tvariant: 'default',\n\t}\n\n\t// Single array to track all dialogs\n\tprivate activeDialogs: SchmancyDialog[] = []\n\n\tprivate dialogSubject = new Subject<DialogTarget>()\n\tprivate dismissSubject = new Subject<string>()\n\n\t// Lazy click position tracking - only initialized when first dialog opens\n\tprivate lastClickPosition: { x: number; y: number } | null = null\n\tprivate clickTrackingInitialized = false\n\n\tprivate constructor() {\n\t\tthis.setupDialogOpeningLogic()\n\t\tthis.setupDialogDismissLogic()\n\t\tthis.setupClickPositionTracking()\n\t}\n\n\tprivate setupClickPositionTracking() {\n\t\tif (this.clickTrackingInitialized || typeof document === 'undefined') return\n\t\tthis.clickTrackingInitialized = true\n\n\t\tfromEvent<PointerEvent>(document, 'pointerdown', { capture: true, passive: true })\n\t\t\t.pipe(\n\t\t\t\ttap(event => {\n\t\t\t\t\tthis.lastClickPosition = { x: event.clientX, y: event.clientY }\n\t\t\t\t}),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tpublic static getInstance(): DialogService {\n\t\tif (!DialogService.instance) {\n\t\t\tDialogService.instance = new DialogService()\n\t\t}\n\t\treturn DialogService.instance\n\t}\n\n\tprivate setupDialogOpeningLogic() {\n\t\tthis.dialogSubject\n\t\t\t.pipe(\n\t\t\t\tswitchMap(target =>\n\t\t\t\t\tforkJoin([\n\t\t\t\t\t\tfromEvent<ThemeHereIAmEvent>(window, ThemeHereIAm).pipe(\n\t\t\t\t\t\t\ttakeUntil(timer(50)),\n\t\t\t\t\t\t\tmap(e => e.detail.theme),\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\tconst uid = `dialog-${Date.now()}-${Math.random().toString(36).substring(2, 9)}`\n\t\t\t\t\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\t\t\t\t\tnew CustomEvent(ThemeWhereAreYou, {\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\t;(target as { uid?: string }).uid = 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\tmap(([theme, target]) => {\n\t\t\t\t\tconst targetContainer =\n\t\t\t\t\t\ttheme ||\n\t\t\t\t\t\ttarget.options.targetContainer ||\n\t\t\t\t\t\t(document.querySelector('schmancy-theme') as HTMLElement) ||\n\t\t\t\t\t\tdocument.body\n\n\t\t\t\t\tconst uid = (target as { uid?: string }).uid!\n\t\t\t\t\tconst dialog = document.createElement('schmancy-dialog') as SchmancyDialog\n\t\t\t\t\tdialog.setAttribute('uid', uid)\n\t\t\t\t\tdialog.style.setProperty('--schmancy-overlay-z', String(overlayStack.getNextZIndex()))\n\t\t\t\t\ttargetContainer.appendChild(dialog)\n\n\t\t\t\t\treturn { dialog, target }\n\t\t\t\t}),\n\t\t\t\ttap(({ dialog, target }) => {\n\t\t\t\t\tconst options = target.options\n\n\t\t\t\t\tif (target.type === 'confirm') {\n\t\t\t\t\t\t// Configure for confirm mode\n\t\t\t\t\t\tdialog.title = options.title\n\t\t\t\t\t\tdialog.subtitle = options.subtitle\n\t\t\t\t\t\tdialog.message = options.message\n\t\t\t\t\t\tdialog.confirmText = options.confirmText ?? 'Confirm'\n\t\t\t\t\t\tdialog.cancelText = options.cancelText ?? 'Cancel'\n\t\t\t\t\t\tdialog.variant = options.variant ?? 'default'\n\n\t\t\t\t\t\t// Handle custom content slot\n\t\t\t\t\t\tif (options.content) {\n\t\t\t\t\t\t\tconst contentContainer = document.createElement('div')\n\t\t\t\t\t\t\tcontentContainer.slot = 'content'\n\n\t\t\t\t\t\t\tif (typeof options.content === 'function') {\n\t\t\t\t\t\t\t\tconst result = options.content()\n\t\t\t\t\t\t\t\tif (result instanceof HTMLElement) {\n\t\t\t\t\t\t\t\t\tcontentContainer.appendChild(result)\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\trender(result, contentContainer)\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} else if (options.content instanceof HTMLElement) {\n\t\t\t\t\t\t\t\tcontentContainer.appendChild(options.content)\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\trender(options.content, contentContainer)\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tdialog.appendChild(contentContainer)\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// Configure for content mode\n\t\t\t\t\t\tdialog.hideActions = true\n\n\t\t\t\t\t\tif (target.content) {\n\t\t\t\t\t\t\tconst contentContainer = document.createElement('div')\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tcontentContainer.style.display = 'contents'\n\t\t\t\t\t\t\tcontentContainer.classList.add('schmancy-dialog-content-container')\n\n\t\t\t\t\t\t\tif (typeof target.content === 'function') {\n\t\t\t\t\t\t\t\tconst result = target.content()\n\t\t\t\t\t\t\t\tif (result instanceof HTMLElement) {\n\t\t\t\t\t\t\t\t\tcontentContainer.appendChild(result)\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\trender(result, contentContainer)\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} else if (target.content instanceof HTMLElement) {\n\t\t\t\t\t\t\t\tcontentContainer.appendChild(target.content)\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\trender(target.content, contentContainer)\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tdialog.appendChild(contentContainer)\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.activeDialogs.push(dialog)\n\t\t\t\t}),\n\t\t\t\ttap(({ dialog, target }) => {\n\t\t\t\t\tconst position = target.options.position || this.getDefaultPosition()\n\n\t\t\t\t\tdialog\n\t\t\t\t\t\t.show(position)\n\t\t\t\t\t\t.then((result: boolean) => {\n\t\t\t\t\t\t\ttarget.resolve?.(result)\n\n\t\t\t\t\t\t\t// Cleanup\n\t\t\t\t\t\t\tconst index = this.activeDialogs.indexOf(dialog)\n\t\t\t\t\t\t\tif (index !== -1) {\n\t\t\t\t\t\t\t\tthis.activeDialogs.splice(index, 1)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\toverlayStack.release()\n\n\t\t\t\t\t\t\t// Clean up content\n\t\t\t\t\t\t\tconst contentEl = dialog.querySelector('[slot=\"content\"]')\n\t\t\t\t\t\t\tif (contentEl) dialog.removeChild(contentEl)\n\n\t\t\t\t\t\t\tconst contentContainer = dialog.querySelector('.schmancy-dialog-content-container')\n\t\t\t\t\t\t\tif (contentContainer?.parentNode) {\n\t\t\t\t\t\t\t\tcontentContainer.parentNode.removeChild(contentContainer)\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t// Clean up event subscriptions\n\t\t\t\t\t\t\tconst eventSubscriptions = (dialog as unknown as { _eventSubscriptions?: Subscription[] })\n\t\t\t\t\t\t\t\t._eventSubscriptions\n\t\t\t\t\t\t\teventSubscriptions?.forEach(sub => sub.unsubscribe())\n\n\t\t\t\t\t\t\t// Remove from DOM\n\t\t\t\t\t\t\tdialog.parentElement?.removeChild(dialog)\n\t\t\t\t\t\t})\n\t\t\t\t\t\t.catch((error: unknown) => {\n\t\t\t\t\t\t\ttarget.reject?.(error)\n\t\t\t\t\t\t})\n\n\t\t\t\t\t// Set up event listeners\n\t\t\t\t\tconst eventSubscriptions: Subscription[] = []\n\n\t\t\t\t\tif (target.options.onConfirm) {\n\t\t\t\t\t\tconst confirmSub = fromEvent(dialog, 'confirm').subscribe(() => {\n\t\t\t\t\t\t\ttarget.options.onConfirm!()\n\t\t\t\t\t\t\tconfirmSub.unsubscribe()\n\t\t\t\t\t\t})\n\t\t\t\t\t\teventSubscriptions.push(confirmSub)\n\t\t\t\t\t}\n\n\t\t\t\t\tif (target.options.onCancel) {\n\t\t\t\t\t\tconst cancelSub = fromEvent(dialog, 'cancel').subscribe(() => {\n\t\t\t\t\t\t\ttarget.options.onCancel!()\n\t\t\t\t\t\t\tcancelSub.unsubscribe()\n\t\t\t\t\t\t})\n\t\t\t\t\t\teventSubscriptions.push(cancelSub)\n\t\t\t\t\t}\n\n\t\t\t\t\t;(dialog as unknown as { _eventSubscriptions: Subscription[] })._eventSubscriptions = eventSubscriptions\n\t\t\t\t}),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tprivate setupDialogDismissLogic() {\n\t\tthis.dismissSubject\n\t\t\t.pipe(\n\t\t\t\tswitchMap(uid =>\n\t\t\t\t\tforkJoin([\n\t\t\t\t\t\tfromEvent<DialogHereMortyEvent>(window, DialogHereMorty).pipe(\n\t\t\t\t\t\t\ttakeUntil(timer(100)),\n\t\t\t\t\t\t\tmap(e => e.detail),\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(\n\t\t\t\t\t\t\t\t\tnew CustomEvent(DialogWhereAreYouRicky, {\n\t\t\t\t\t\t\t\t\t\tdetail: { uid },\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]),\n\t\t\t\t),\n\t\t\t\ttap(([response]) => {\n\t\t\t\t\tif (response?.dialog) {\n\t\t\t\t\t\tresponse.dialog.hide(false)\n\n\t\t\t\t\t\tconst eventSubscriptions = (response.dialog as unknown as { _eventSubscriptions?: Subscription[] })\n\t\t\t\t\t\t\t._eventSubscriptions\n\t\t\t\t\t\teventSubscriptions?.forEach(sub => sub.unsubscribe())\n\n\t\t\t\t\t\tconst index = this.activeDialogs.indexOf(response.dialog as SchmancyDialog)\n\t\t\t\t\t\tif (index !== -1) {\n\t\t\t\t\t\t\tthis.activeDialogs.splice(index, 1)\n\t\t\t\t\t\t}\n\t\t\t\t\t\toverlayStack.release()\n\n\t\t\t\t\t\tresponse.dialog.parentElement?.removeChild(response.dialog)\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tpublic confirm(options: DialogOptions): Promise<boolean> {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tconst completeOptions = {\n\t\t\t\t...DialogService.DEFAULT_OPTIONS,\n\t\t\t\t...options,\n\t\t\t}\n\n\t\t\tif (!completeOptions.position) {\n\t\t\t\tcompleteOptions.position = this.getDefaultPosition()\n\t\t\t}\n\n\t\t\tthis.dialogSubject.next({\n\t\t\t\toptions: completeOptions,\n\t\t\t\ttype: 'confirm',\n\t\t\t\tcontent: completeOptions.content,\n\t\t\t\tresolve,\n\t\t\t\treject,\n\t\t\t})\n\t\t})\n\t}\n\n\tpublic component(\n\t\tcontent: TemplateResult | HTMLElement | (() => HTMLElement | TemplateResult),\n\t\toptions: Omit<DialogOptions, 'content' | 'message'> = {},\n\t): Promise<boolean> {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tif (!options.position) {\n\t\t\t\toptions.position = this.getDefaultPosition()\n\t\t\t}\n\n\t\t\tthis.dialogSubject.next({\n\t\t\t\toptions: options as DialogOptions,\n\t\t\t\ttype: 'component',\n\t\t\t\tcontent,\n\t\t\t\tresolve,\n\t\t\t\treject,\n\t\t\t})\n\t\t})\n\t}\n\n\tpublic dismiss(): boolean {\n\t\tif (this.activeDialogs.length > 0) {\n\t\t\tconst dialog = this.activeDialogs[this.activeDialogs.length - 1]\n\t\t\tconst uid = dialog.getAttribute('uid')\n\n\t\t\tif (uid) {\n\t\t\t\tthis.dismissSubject.next(uid)\n\t\t\t\treturn true\n\t\t\t}\n\t\t}\n\t\treturn false\n\t}\n\n\tpublic close(): boolean {\n\t\treturn this.dismiss()\n\t}\n\n\tpublic ask(message: string, event?: MouseEvent | TouchEvent): Promise<boolean> {\n\t\treturn this.confirm({\n\t\t\tmessage,\n\t\t\tconfirmText: 'Confirm',\n\t\t\tcancelText: 'Cancel',\n\t\t\tposition: event,\n\t\t})\n\t}\n\n\tpublic danger(options: Omit<DialogOptions, 'variant'>): Promise<boolean> {\n\t\treturn this.confirm({\n\t\t\t...options,\n\t\t\tvariant: 'danger',\n\t\t})\n\t}\n\n\t/**\n\t * Shows a prompt dialog with an input field.\n\t * Returns the input value if confirmed, null if cancelled.\n\t */\n\tpublic prompt(options: PromptOptions): Promise<string | null> {\n\t\treturn new Promise(resolve => {\n\t\t\tlet inputValue = options.defaultValue || ''\n\n\t\t\t// Create container for input\n\t\t\tconst container = document.createElement('div')\n\t\t\tcontainer.style.width = '100%'\n\t\t\tcontainer.style.minWidth = '280px'\n\n\t\t\tconst input = document.createElement('schmancy-input') as HTMLElement\n\t\t\tinput.setAttribute('type', options.inputType || 'text')\n\t\t\tif (options.label) input.setAttribute('label', options.label)\n\t\t\tif (options.placeholder) input.setAttribute('placeholder', options.placeholder)\n\t\t\tif (options.defaultValue) input.setAttribute('value', options.defaultValue)\n\n\t\t\tinput.addEventListener('input', (e: Event) => {\n\t\t\t\tinputValue = (e.target as HTMLInputElement).value\n\t\t\t})\n\n\t\t\tcontainer.appendChild(input)\n\n\t\t\tthis.confirm({\n\t\t\t\ttitle: options.title,\n\t\t\t\tmessage: options.message,\n\t\t\t\tconfirmText: options.confirmText ?? 'OK',\n\t\t\t\tcancelText: options.cancelText ?? 'Cancel',\n\t\t\t\tposition: options.position,\n\t\t\t\tcontent: container,\n\t\t\t}).then(confirmed => {\n\t\t\t\tresolve(confirmed ? inputValue : null)\n\t\t\t})\n\t\t})\n\t}\n\n\tprivate getDefaultPosition(): { x: number; y: number } {\n\t\t// Use last click position if available, otherwise center of screen\n\t\tif (this.lastClickPosition) {\n\t\t\treturn { ...this.lastClickPosition }\n\t\t}\n\t\treturn {\n\t\t\tx: window.innerWidth / 2,\n\t\t\ty: window.innerHeight / 2,\n\t\t}\n\t}\n}\n\n/**\n * Eagerly instantiate so click tracking starts immediately on import,\n * not on first dialog open (which would miss the triggering click).\n */\nconst service = DialogService.getInstance()\n\n/**\n * Global dialog utility\n */\nexport const $dialog = {\n\tconfirm: (options: DialogOptions): Promise<boolean> => {\n\t\treturn service.confirm(options)\n\t},\n\n\task: (message: string, event?: MouseEvent | TouchEvent): Promise<boolean> => {\n\t\treturn service.ask(message, event)\n\t},\n\n\tdanger: (options: Omit<DialogOptions, 'variant'>): Promise<boolean> => {\n\t\treturn service.danger(options)\n\t},\n\n\tprompt: (options: PromptOptions): Promise<string | null> => {\n\t\treturn service.prompt(options)\n\t},\n\n\tcomponent: (\n\t\tcontent: TemplateResult | HTMLElement | (() => HTMLElement | TemplateResult),\n\t\toptions?: Omit<DialogOptions, 'content' | 'message'>,\n\t): Promise<boolean> => {\n\t\treturn service.component(content, options)\n\t},\n\n\tdismiss: (): boolean => {\n\t\treturn service.dismiss()\n\t},\n\n\tclose: (): boolean => {\n\t\treturn service.close()\n\t},\n}\n\nexport default DialogService\n"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
require(`./chunk-BCfY8kxB.cjs`);const e=require(`./theme.events-EznKK2Y0.cjs`),t=require(`./overlay-stack-
|
|
1
|
+
require(`./chunk-BCfY8kxB.cjs`);const e=require(`./theme.events-EznKK2Y0.cjs`),t=require(`./overlay-stack-J_eJCUTX.cjs`);let n=require(`rxjs`),r=require(`lit`);var i=`are-you-there-dialog`,a=`yes-dialog-here`,o=class o{static{this.DEFAULT_OPTIONS={title:void 0,subtitle:void 0,confirmText:void 0,cancelText:void 0,variant:`default`}}constructor(){this.activeDialogs=[],this.dialogSubject=new n.Subject,this.dismissSubject=new n.Subject,this.lastClickPosition=null,this.clickTrackingInitialized=!1,this.setupDialogOpeningLogic(),this.setupDialogDismissLogic(),this.setupClickPositionTracking()}setupClickPositionTracking(){this.clickTrackingInitialized||typeof document>`u`||(this.clickTrackingInitialized=!0,(0,n.fromEvent)(document,`pointerdown`,{capture:!0,passive:!0}).pipe((0,n.tap)(e=>{this.lastClickPosition={x:e.clientX,y:e.clientY}})).subscribe())}static getInstance(){return o.instance||=new o,o.instance}setupDialogOpeningLogic(){this.dialogSubject.pipe((0,n.switchMap)(t=>(0,n.forkJoin)([(0,n.fromEvent)(window,e.t).pipe((0,n.takeUntil)((0,n.timer)(50)),(0,n.map)(e=>e.detail.theme),(0,n.defaultIfEmpty)(void 0)),(0,n.of)(t).pipe((0,n.tap)(()=>{let n=`dialog-${Date.now()}-${Math.random().toString(36).substring(2,9)}`;window.dispatchEvent(new CustomEvent(e.n,{bubbles:!0,composed:!0})),t.uid=n}))])),(0,n.map)(([e,n])=>{let r=e||n.options.targetContainer||document.querySelector(`schmancy-theme`)||document.body,i=n.uid,a=document.createElement(`schmancy-dialog`);return a.setAttribute(`uid`,i),a.style.setProperty(`--schmancy-overlay-z`,String(t.t.getNextZIndex())),r.appendChild(a),{dialog:a,target:n}}),(0,n.tap)(({dialog:e,target:t})=>{let n=t.options;if(t.type===`confirm`){if(e.title=n.title,e.subtitle=n.subtitle,e.message=n.message,e.confirmText=n.confirmText??`Confirm`,e.cancelText=n.cancelText??`Cancel`,e.variant=n.variant??`default`,n.content){let t=document.createElement(`div`);if(t.slot=`content`,typeof n.content==`function`){let e=n.content();e instanceof HTMLElement?t.appendChild(e):(0,r.render)(e,t)}else n.content instanceof HTMLElement?t.appendChild(n.content):(0,r.render)(n.content,t);e.appendChild(t)}}else if(e.hideActions=!0,t.content){let n=document.createElement(`div`);if(n.style.display=`contents`,n.classList.add(`schmancy-dialog-content-container`),typeof t.content==`function`){let e=t.content();e instanceof HTMLElement?n.appendChild(e):(0,r.render)(e,n)}else t.content instanceof HTMLElement?n.appendChild(t.content):(0,r.render)(t.content,n);e.appendChild(n)}this.activeDialogs.push(e)}),(0,n.tap)(({dialog:e,target:r})=>{let i=r.options.position||this.getDefaultPosition();e.show(i).then(n=>{r.resolve?.(n);let i=this.activeDialogs.indexOf(e);i!==-1&&this.activeDialogs.splice(i,1),t.t.release();let a=e.querySelector(`[slot="content"]`);a&&e.removeChild(a);let o=e.querySelector(`.schmancy-dialog-content-container`);o?.parentNode&&o.parentNode.removeChild(o),e._eventSubscriptions?.forEach(e=>e.unsubscribe()),e.parentElement?.removeChild(e)}).catch(e=>{r.reject?.(e)});let a=[];if(r.options.onConfirm){let t=(0,n.fromEvent)(e,`confirm`).subscribe(()=>{r.options.onConfirm(),t.unsubscribe()});a.push(t)}if(r.options.onCancel){let t=(0,n.fromEvent)(e,`cancel`).subscribe(()=>{r.options.onCancel(),t.unsubscribe()});a.push(t)}e._eventSubscriptions=a})).subscribe()}setupDialogDismissLogic(){this.dismissSubject.pipe((0,n.switchMap)(e=>(0,n.forkJoin)([(0,n.fromEvent)(window,a).pipe((0,n.takeUntil)((0,n.timer)(100)),(0,n.map)(e=>e.detail),(0,n.defaultIfEmpty)(void 0)),(0,n.of)(e).pipe((0,n.tap)(()=>{window.dispatchEvent(new CustomEvent(i,{detail:{uid:e},bubbles:!0,composed:!0}))}))])),(0,n.tap)(([e])=>{if(e?.dialog){e.dialog.hide(!1),e.dialog._eventSubscriptions?.forEach(e=>e.unsubscribe());let n=this.activeDialogs.indexOf(e.dialog);n!==-1&&this.activeDialogs.splice(n,1),t.t.release(),e.dialog.parentElement?.removeChild(e.dialog)}})).subscribe()}confirm(e){return new Promise((t,n)=>{let r={...o.DEFAULT_OPTIONS,...e};r.position||=this.getDefaultPosition(),this.dialogSubject.next({options:r,type:`confirm`,content:r.content,resolve:t,reject:n})})}component(e,t={}){return new Promise((n,r)=>{t.position||=this.getDefaultPosition(),this.dialogSubject.next({options:t,type:`component`,content:e,resolve:n,reject:r})})}dismiss(){if(this.activeDialogs.length>0){let e=this.activeDialogs[this.activeDialogs.length-1].getAttribute(`uid`);if(e)return this.dismissSubject.next(e),!0}return!1}close(){return this.dismiss()}ask(e,t){return this.confirm({message:e,confirmText:`Confirm`,cancelText:`Cancel`,position:t})}danger(e){return this.confirm({...e,variant:`danger`})}prompt(e){return new Promise(t=>{let n=e.defaultValue||``,r=document.createElement(`div`);r.style.width=`100%`,r.style.minWidth=`280px`;let i=document.createElement(`schmancy-input`);i.setAttribute(`type`,e.inputType||`text`),e.label&&i.setAttribute(`label`,e.label),e.placeholder&&i.setAttribute(`placeholder`,e.placeholder),e.defaultValue&&i.setAttribute(`value`,e.defaultValue),i.addEventListener(`input`,e=>{n=e.target.value}),r.appendChild(i),this.confirm({title:e.title,message:e.message,confirmText:e.confirmText??`OK`,cancelText:e.cancelText??`Cancel`,position:e.position,content:r}).then(e=>{t(e?n:null)})})}getDefaultPosition(){return this.lastClickPosition?{...this.lastClickPosition}:{x:window.innerWidth/2,y:window.innerHeight/2}}},s=o.getInstance(),c={confirm:e=>s.confirm(e),ask:(e,t)=>s.ask(e,t),danger:e=>s.danger(e),prompt:e=>s.prompt(e),component:(e,t)=>s.component(e,t),dismiss:()=>s.dismiss(),close:()=>s.close()};Object.defineProperty(exports,`i`,{enumerable:!0,get:function(){return i}}),Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return o}}),Object.defineProperty(exports,`r`,{enumerable:!0,get:function(){return a}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return c}});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dialog-service-DcuAavp2.cjs","names":[],"sources":["../src/dialog/dialog-events.ts","../src/dialog/dialog-service.ts"],"sourcesContent":["// Dialog discovery event constants\r\nexport const DialogWhereAreYouRicky = 'are-you-there-dialog'\r\nexport const DialogHereMorty = 'yes-dialog-here'\r\n\r\n// Event interfaces\r\nexport interface DialogWhereAreYouRickyEvent extends CustomEvent {\r\n detail: {\r\n uid: string\r\n }\r\n}\r\n\r\nexport interface DialogHereMortyEvent extends CustomEvent {\r\n detail: {\r\n dialog: any // Will be schmancy-dialog instance\r\n theme?: any // Will be schmancy-theme instance\r\n }\r\n}","import { render, TemplateResult } from 'lit'\nimport {\n\tdefaultIfEmpty,\n\tforkJoin,\n\tfromEvent,\n\tmap,\n\tof,\n\tSubject,\n\tSubscription,\n\tswitchMap,\n\ttakeUntil,\n\ttap,\n\ttimer,\n} from 'rxjs'\nimport { ThemeHereIAm, ThemeHereIAmEvent, ThemeWhereAreYou } from '../theme/theme.events'\nimport { overlayStack } from '../utils/overlay-stack'\nimport { SchmancyDialog } from './dialog.component'\nimport { DialogHereMorty, DialogHereMortyEvent, DialogWhereAreYouRicky } from './dialog-events'\n\n/**\n * Dialog service options interface\n */\nexport interface DialogOptions {\n\ttitle?: string\n\tsubtitle?: string\n\tmessage?: string\n\tconfirmText?: string\n\tcancelText?: string\n\tvariant?: 'default' | 'danger'\n\tposition?: { x: number; y: number } | MouseEvent | TouchEvent\n\tcontent?: TemplateResult | HTMLElement | (() => HTMLElement | TemplateResult)\n\tonConfirm?: () => void\n\tonCancel?: () => void\n\thideActions?: boolean\n\ttargetContainer?: HTMLElement\n}\n\n/**\n * Prompt dialog options\n */\nexport interface PromptOptions {\n\ttitle?: string\n\tmessage?: string\n\tlabel?: string\n\tplaceholder?: string\n\tdefaultValue?: string\n\tinputType?: 'text' | 'email' | 'password' | 'number' | 'tel' | 'url'\n\tconfirmText?: string\n\tcancelText?: string\n\tposition?: { x: number; y: number } | MouseEvent | TouchEvent\n}\n\ninterface DialogTarget {\n\toptions: DialogOptions\n\ttype: 'confirm' | 'component'\n\tcontent?: TemplateResult | HTMLElement | (() => HTMLElement | TemplateResult)\n\tresolve?: (value: boolean) => void\n\treject?: (reason?: unknown) => void\n}\n\n/**\n * Dialog service for centralized dialog management.\n * Uses a single unified SchmancyDialog component for all dialog types.\n */\nexport class DialogService {\n\tprivate static instance: DialogService\n\n\tprivate static DEFAULT_OPTIONS: Partial<DialogOptions> = {\n\t\ttitle: undefined,\n\t\tsubtitle: undefined,\n\t\tconfirmText: undefined,\n\t\tcancelText: undefined,\n\t\tvariant: 'default',\n\t}\n\n\t// Single array to track all dialogs\n\tprivate activeDialogs: SchmancyDialog[] = []\n\n\tprivate dialogSubject = new Subject<DialogTarget>()\n\tprivate dismissSubject = new Subject<string>()\n\n\t// Lazy click position tracking - only initialized when first dialog opens\n\tprivate lastClickPosition: { x: number; y: number } | null = null\n\tprivate clickTrackingInitialized = false\n\n\tprivate constructor() {\n\t\tthis.setupDialogOpeningLogic()\n\t\tthis.setupDialogDismissLogic()\n\t\tthis.setupClickPositionTracking()\n\t}\n\n\tprivate setupClickPositionTracking() {\n\t\tif (this.clickTrackingInitialized || typeof document === 'undefined') return\n\t\tthis.clickTrackingInitialized = true\n\n\t\tfromEvent<PointerEvent>(document, 'pointerdown', { capture: true, passive: true })\n\t\t\t.pipe(\n\t\t\t\ttap(event => {\n\t\t\t\t\tthis.lastClickPosition = { x: event.clientX, y: event.clientY }\n\t\t\t\t}),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tpublic static getInstance(): DialogService {\n\t\tif (!DialogService.instance) {\n\t\t\tDialogService.instance = new DialogService()\n\t\t}\n\t\treturn DialogService.instance\n\t}\n\n\tprivate setupDialogOpeningLogic() {\n\t\tthis.dialogSubject\n\t\t\t.pipe(\n\t\t\t\tswitchMap(target =>\n\t\t\t\t\tforkJoin([\n\t\t\t\t\t\tfromEvent<ThemeHereIAmEvent>(window, ThemeHereIAm).pipe(\n\t\t\t\t\t\t\ttakeUntil(timer(50)),\n\t\t\t\t\t\t\tmap(e => e.detail.theme),\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\tconst uid = `dialog-${Date.now()}-${Math.random().toString(36).substring(2, 9)}`\n\t\t\t\t\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\t\t\t\t\tnew CustomEvent(ThemeWhereAreYou, {\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\t;(target as { uid?: string }).uid = 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\tmap(([theme, target]) => {\n\t\t\t\t\tconst targetContainer =\n\t\t\t\t\t\ttheme ||\n\t\t\t\t\t\ttarget.options.targetContainer ||\n\t\t\t\t\t\t(document.querySelector('schmancy-theme') as HTMLElement) ||\n\t\t\t\t\t\tdocument.body\n\n\t\t\t\t\tconst uid = (target as { uid?: string }).uid!\n\t\t\t\t\tconst dialog = document.createElement('schmancy-dialog') as SchmancyDialog\n\t\t\t\t\tdialog.setAttribute('uid', uid)\n\t\t\t\t\tdialog.style.setProperty('--schmancy-overlay-z', String(overlayStack.getNextZIndex()))\n\t\t\t\t\ttargetContainer.appendChild(dialog)\n\n\t\t\t\t\treturn { dialog, target }\n\t\t\t\t}),\n\t\t\t\ttap(({ dialog, target }) => {\n\t\t\t\t\tconst options = target.options\n\n\t\t\t\t\tif (target.type === 'confirm') {\n\t\t\t\t\t\t// Configure for confirm mode\n\t\t\t\t\t\tdialog.title = options.title\n\t\t\t\t\t\tdialog.subtitle = options.subtitle\n\t\t\t\t\t\tdialog.message = options.message\n\t\t\t\t\t\tdialog.confirmText = options.confirmText ?? 'Confirm'\n\t\t\t\t\t\tdialog.cancelText = options.cancelText ?? 'Cancel'\n\t\t\t\t\t\tdialog.variant = options.variant ?? 'default'\n\n\t\t\t\t\t\t// Handle custom content slot\n\t\t\t\t\t\tif (options.content) {\n\t\t\t\t\t\t\tconst contentContainer = document.createElement('div')\n\t\t\t\t\t\t\tcontentContainer.slot = 'content'\n\n\t\t\t\t\t\t\tif (typeof options.content === 'function') {\n\t\t\t\t\t\t\t\tconst result = options.content()\n\t\t\t\t\t\t\t\tif (result instanceof HTMLElement) {\n\t\t\t\t\t\t\t\t\tcontentContainer.appendChild(result)\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\trender(result, contentContainer)\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} else if (options.content instanceof HTMLElement) {\n\t\t\t\t\t\t\t\tcontentContainer.appendChild(options.content)\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\trender(options.content, contentContainer)\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tdialog.appendChild(contentContainer)\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// Configure for content mode\n\t\t\t\t\t\tdialog.hideActions = true\n\n\t\t\t\t\t\tif (target.content) {\n\t\t\t\t\t\t\tconst contentContainer = document.createElement('div')\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tcontentContainer.style.display = 'contents'\n\t\t\t\t\t\t\tcontentContainer.classList.add('schmancy-dialog-content-container')\n\n\t\t\t\t\t\t\tif (typeof target.content === 'function') {\n\t\t\t\t\t\t\t\tconst result = target.content()\n\t\t\t\t\t\t\t\tif (result instanceof HTMLElement) {\n\t\t\t\t\t\t\t\t\tcontentContainer.appendChild(result)\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\trender(result, contentContainer)\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} else if (target.content instanceof HTMLElement) {\n\t\t\t\t\t\t\t\tcontentContainer.appendChild(target.content)\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\trender(target.content, contentContainer)\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tdialog.appendChild(contentContainer)\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.activeDialogs.push(dialog)\n\t\t\t\t}),\n\t\t\t\ttap(({ dialog, target }) => {\n\t\t\t\t\tconst position = target.options.position || this.getDefaultPosition()\n\n\t\t\t\t\tdialog\n\t\t\t\t\t\t.show(position)\n\t\t\t\t\t\t.then((result: boolean) => {\n\t\t\t\t\t\t\ttarget.resolve?.(result)\n\n\t\t\t\t\t\t\t// Cleanup\n\t\t\t\t\t\t\tconst index = this.activeDialogs.indexOf(dialog)\n\t\t\t\t\t\t\tif (index !== -1) {\n\t\t\t\t\t\t\t\tthis.activeDialogs.splice(index, 1)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\toverlayStack.release()\n\n\t\t\t\t\t\t\t// Clean up content\n\t\t\t\t\t\t\tconst contentEl = dialog.querySelector('[slot=\"content\"]')\n\t\t\t\t\t\t\tif (contentEl) dialog.removeChild(contentEl)\n\n\t\t\t\t\t\t\tconst contentContainer = dialog.querySelector('.schmancy-dialog-content-container')\n\t\t\t\t\t\t\tif (contentContainer?.parentNode) {\n\t\t\t\t\t\t\t\tcontentContainer.parentNode.removeChild(contentContainer)\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t// Clean up event subscriptions\n\t\t\t\t\t\t\tconst eventSubscriptions = (dialog as unknown as { _eventSubscriptions?: Subscription[] })\n\t\t\t\t\t\t\t\t._eventSubscriptions\n\t\t\t\t\t\t\teventSubscriptions?.forEach(sub => sub.unsubscribe())\n\n\t\t\t\t\t\t\t// Remove from DOM\n\t\t\t\t\t\t\tdialog.parentElement?.removeChild(dialog)\n\t\t\t\t\t\t})\n\t\t\t\t\t\t.catch((error: unknown) => {\n\t\t\t\t\t\t\ttarget.reject?.(error)\n\t\t\t\t\t\t})\n\n\t\t\t\t\t// Set up event listeners\n\t\t\t\t\tconst eventSubscriptions: Subscription[] = []\n\n\t\t\t\t\tif (target.options.onConfirm) {\n\t\t\t\t\t\tconst confirmSub = fromEvent(dialog, 'confirm').subscribe(() => {\n\t\t\t\t\t\t\ttarget.options.onConfirm!()\n\t\t\t\t\t\t\tconfirmSub.unsubscribe()\n\t\t\t\t\t\t})\n\t\t\t\t\t\teventSubscriptions.push(confirmSub)\n\t\t\t\t\t}\n\n\t\t\t\t\tif (target.options.onCancel) {\n\t\t\t\t\t\tconst cancelSub = fromEvent(dialog, 'cancel').subscribe(() => {\n\t\t\t\t\t\t\ttarget.options.onCancel!()\n\t\t\t\t\t\t\tcancelSub.unsubscribe()\n\t\t\t\t\t\t})\n\t\t\t\t\t\teventSubscriptions.push(cancelSub)\n\t\t\t\t\t}\n\n\t\t\t\t\t;(dialog as unknown as { _eventSubscriptions: Subscription[] })._eventSubscriptions = eventSubscriptions\n\t\t\t\t}),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tprivate setupDialogDismissLogic() {\n\t\tthis.dismissSubject\n\t\t\t.pipe(\n\t\t\t\tswitchMap(uid =>\n\t\t\t\t\tforkJoin([\n\t\t\t\t\t\tfromEvent<DialogHereMortyEvent>(window, DialogHereMorty).pipe(\n\t\t\t\t\t\t\ttakeUntil(timer(100)),\n\t\t\t\t\t\t\tmap(e => e.detail),\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(\n\t\t\t\t\t\t\t\t\tnew CustomEvent(DialogWhereAreYouRicky, {\n\t\t\t\t\t\t\t\t\t\tdetail: { uid },\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]),\n\t\t\t\t),\n\t\t\t\ttap(([response]) => {\n\t\t\t\t\tif (response?.dialog) {\n\t\t\t\t\t\tresponse.dialog.hide(false)\n\n\t\t\t\t\t\tconst eventSubscriptions = (response.dialog as unknown as { _eventSubscriptions?: Subscription[] })\n\t\t\t\t\t\t\t._eventSubscriptions\n\t\t\t\t\t\teventSubscriptions?.forEach(sub => sub.unsubscribe())\n\n\t\t\t\t\t\tconst index = this.activeDialogs.indexOf(response.dialog as SchmancyDialog)\n\t\t\t\t\t\tif (index !== -1) {\n\t\t\t\t\t\t\tthis.activeDialogs.splice(index, 1)\n\t\t\t\t\t\t}\n\t\t\t\t\t\toverlayStack.release()\n\n\t\t\t\t\t\tresponse.dialog.parentElement?.removeChild(response.dialog)\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tpublic confirm(options: DialogOptions): Promise<boolean> {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tconst completeOptions = {\n\t\t\t\t...DialogService.DEFAULT_OPTIONS,\n\t\t\t\t...options,\n\t\t\t}\n\n\t\t\tif (!completeOptions.position) {\n\t\t\t\tcompleteOptions.position = this.getDefaultPosition()\n\t\t\t}\n\n\t\t\tthis.dialogSubject.next({\n\t\t\t\toptions: completeOptions,\n\t\t\t\ttype: 'confirm',\n\t\t\t\tcontent: completeOptions.content,\n\t\t\t\tresolve,\n\t\t\t\treject,\n\t\t\t})\n\t\t})\n\t}\n\n\tpublic component(\n\t\tcontent: TemplateResult | HTMLElement | (() => HTMLElement | TemplateResult),\n\t\toptions: Omit<DialogOptions, 'content' | 'message'> = {},\n\t): Promise<boolean> {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tif (!options.position) {\n\t\t\t\toptions.position = this.getDefaultPosition()\n\t\t\t}\n\n\t\t\tthis.dialogSubject.next({\n\t\t\t\toptions: options as DialogOptions,\n\t\t\t\ttype: 'component',\n\t\t\t\tcontent,\n\t\t\t\tresolve,\n\t\t\t\treject,\n\t\t\t})\n\t\t})\n\t}\n\n\tpublic dismiss(): boolean {\n\t\tif (this.activeDialogs.length > 0) {\n\t\t\tconst dialog = this.activeDialogs[this.activeDialogs.length - 1]\n\t\t\tconst uid = dialog.getAttribute('uid')\n\n\t\t\tif (uid) {\n\t\t\t\tthis.dismissSubject.next(uid)\n\t\t\t\treturn true\n\t\t\t}\n\t\t}\n\t\treturn false\n\t}\n\n\tpublic close(): boolean {\n\t\treturn this.dismiss()\n\t}\n\n\tpublic ask(message: string, event?: MouseEvent | TouchEvent): Promise<boolean> {\n\t\treturn this.confirm({\n\t\t\tmessage,\n\t\t\tconfirmText: 'Confirm',\n\t\t\tcancelText: 'Cancel',\n\t\t\tposition: event,\n\t\t})\n\t}\n\n\tpublic danger(options: Omit<DialogOptions, 'variant'>): Promise<boolean> {\n\t\treturn this.confirm({\n\t\t\t...options,\n\t\t\tvariant: 'danger',\n\t\t})\n\t}\n\n\t/**\n\t * Shows a prompt dialog with an input field.\n\t * Returns the input value if confirmed, null if cancelled.\n\t */\n\tpublic prompt(options: PromptOptions): Promise<string | null> {\n\t\treturn new Promise(resolve => {\n\t\t\tlet inputValue = options.defaultValue || ''\n\n\t\t\t// Create container for input\n\t\t\tconst container = document.createElement('div')\n\t\t\tcontainer.style.width = '100%'\n\t\t\tcontainer.style.minWidth = '280px'\n\n\t\t\tconst input = document.createElement('schmancy-input') as HTMLElement\n\t\t\tinput.setAttribute('type', options.inputType || 'text')\n\t\t\tif (options.label) input.setAttribute('label', options.label)\n\t\t\tif (options.placeholder) input.setAttribute('placeholder', options.placeholder)\n\t\t\tif (options.defaultValue) input.setAttribute('value', options.defaultValue)\n\n\t\t\tinput.addEventListener('input', (e: Event) => {\n\t\t\t\tinputValue = (e.target as HTMLInputElement).value\n\t\t\t})\n\n\t\t\tcontainer.appendChild(input)\n\n\t\t\tthis.confirm({\n\t\t\t\ttitle: options.title,\n\t\t\t\tmessage: options.message,\n\t\t\t\tconfirmText: options.confirmText ?? 'OK',\n\t\t\t\tcancelText: options.cancelText ?? 'Cancel',\n\t\t\t\tposition: options.position,\n\t\t\t\tcontent: container,\n\t\t\t}).then(confirmed => {\n\t\t\t\tresolve(confirmed ? inputValue : null)\n\t\t\t})\n\t\t})\n\t}\n\n\tprivate getDefaultPosition(): { x: number; y: number } {\n\t\t// Use last click position if available, otherwise center of screen\n\t\tif (this.lastClickPosition) {\n\t\t\treturn { ...this.lastClickPosition }\n\t\t}\n\t\treturn {\n\t\t\tx: window.innerWidth / 2,\n\t\t\ty: window.innerHeight / 2,\n\t\t}\n\t}\n}\n\n/**\n * Eagerly instantiate so click tracking starts immediately on import,\n * not on first dialog open (which would miss the triggering click).\n */\nconst service = DialogService.getInstance()\n\n/**\n * Global dialog utility\n */\nexport const $dialog = {\n\tconfirm: (options: DialogOptions): Promise<boolean> => {\n\t\treturn service.confirm(options)\n\t},\n\n\task: (message: string, event?: MouseEvent | TouchEvent): Promise<boolean> => {\n\t\treturn service.ask(message, event)\n\t},\n\n\tdanger: (options: Omit<DialogOptions, 'variant'>): Promise<boolean> => {\n\t\treturn service.danger(options)\n\t},\n\n\tprompt: (options: PromptOptions): Promise<string | null> => {\n\t\treturn service.prompt(options)\n\t},\n\n\tcomponent: (\n\t\tcontent: TemplateResult | HTMLElement | (() => HTMLElement | TemplateResult),\n\t\toptions?: Omit<DialogOptions, 'content' | 'message'>,\n\t): Promise<boolean> => {\n\t\treturn service.component(content, options)\n\t},\n\n\tdismiss: (): boolean => {\n\t\treturn service.dismiss()\n\t},\n\n\tclose: (): boolean => {\n\t\treturn service.close()\n\t},\n}\n\nexport default DialogService\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"dialog-service-DXLGSshF.cjs","names":[],"sources":["../src/dialog/dialog-events.ts","../src/dialog/dialog-service.ts"],"sourcesContent":["// Dialog discovery event constants\r\nexport const DialogWhereAreYouRicky = 'are-you-there-dialog'\r\nexport const DialogHereMorty = 'yes-dialog-here'\r\n\r\n// Event interfaces\r\nexport interface DialogWhereAreYouRickyEvent extends CustomEvent {\r\n detail: {\r\n uid: string\r\n }\r\n}\r\n\r\nexport interface DialogHereMortyEvent extends CustomEvent {\r\n detail: {\r\n dialog: any // Will be schmancy-dialog instance\r\n theme?: any // Will be schmancy-theme instance\r\n }\r\n}","import { render, TemplateResult } from 'lit'\nimport {\n\tdefaultIfEmpty,\n\tforkJoin,\n\tfromEvent,\n\tmap,\n\tof,\n\tSubject,\n\tSubscription,\n\tswitchMap,\n\ttakeUntil,\n\ttap,\n\ttimer,\n} from 'rxjs'\nimport { ThemeHereIAm, ThemeHereIAmEvent, ThemeWhereAreYou } from '../theme/theme.events'\nimport { overlayStack } from '../utils/overlay-stack'\nimport { SchmancyDialog } from './dialog.component'\nimport { DialogHereMorty, DialogHereMortyEvent, DialogWhereAreYouRicky } from './dialog-events'\n\n/**\n * Dialog service options interface\n */\nexport interface DialogOptions {\n\ttitle?: string\n\tsubtitle?: string\n\tmessage?: string\n\tconfirmText?: string\n\tcancelText?: string\n\tvariant?: 'default' | 'danger'\n\tposition?: { x: number; y: number } | MouseEvent | TouchEvent\n\tcontent?: TemplateResult | HTMLElement | (() => HTMLElement | TemplateResult)\n\tonConfirm?: () => void\n\tonCancel?: () => void\n\thideActions?: boolean\n\ttargetContainer?: HTMLElement\n}\n\n/**\n * Prompt dialog options\n */\nexport interface PromptOptions {\n\ttitle?: string\n\tmessage?: string\n\tlabel?: string\n\tplaceholder?: string\n\tdefaultValue?: string\n\tinputType?: 'text' | 'email' | 'password' | 'number' | 'tel' | 'url'\n\tconfirmText?: string\n\tcancelText?: string\n\tposition?: { x: number; y: number } | MouseEvent | TouchEvent\n}\n\ninterface DialogTarget {\n\toptions: DialogOptions\n\ttype: 'confirm' | 'component'\n\tcontent?: TemplateResult | HTMLElement | (() => HTMLElement | TemplateResult)\n\tresolve?: (value: boolean) => void\n\treject?: (reason?: unknown) => void\n}\n\n/**\n * Dialog service for centralized dialog management.\n * Uses a single unified SchmancyDialog component for all dialog types.\n */\nexport class DialogService {\n\tprivate static instance: DialogService\n\n\tprivate static DEFAULT_OPTIONS: Partial<DialogOptions> = {\n\t\ttitle: undefined,\n\t\tsubtitle: undefined,\n\t\tconfirmText: undefined,\n\t\tcancelText: undefined,\n\t\tvariant: 'default',\n\t}\n\n\t// Single array to track all dialogs\n\tprivate activeDialogs: SchmancyDialog[] = []\n\n\tprivate dialogSubject = new Subject<DialogTarget>()\n\tprivate dismissSubject = new Subject<string>()\n\n\t// Lazy click position tracking - only initialized when first dialog opens\n\tprivate lastClickPosition: { x: number; y: number } | null = null\n\tprivate clickTrackingInitialized = false\n\n\tprivate constructor() {\n\t\tthis.setupDialogOpeningLogic()\n\t\tthis.setupDialogDismissLogic()\n\t\tthis.setupClickPositionTracking()\n\t}\n\n\tprivate setupClickPositionTracking() {\n\t\tif (this.clickTrackingInitialized || typeof document === 'undefined') return\n\t\tthis.clickTrackingInitialized = true\n\n\t\tfromEvent<PointerEvent>(document, 'pointerdown', { capture: true, passive: true })\n\t\t\t.pipe(\n\t\t\t\ttap(event => {\n\t\t\t\t\tthis.lastClickPosition = { x: event.clientX, y: event.clientY }\n\t\t\t\t}),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tpublic static getInstance(): DialogService {\n\t\tif (!DialogService.instance) {\n\t\t\tDialogService.instance = new DialogService()\n\t\t}\n\t\treturn DialogService.instance\n\t}\n\n\tprivate setupDialogOpeningLogic() {\n\t\tthis.dialogSubject\n\t\t\t.pipe(\n\t\t\t\tswitchMap(target =>\n\t\t\t\t\tforkJoin([\n\t\t\t\t\t\tfromEvent<ThemeHereIAmEvent>(window, ThemeHereIAm).pipe(\n\t\t\t\t\t\t\ttakeUntil(timer(50)),\n\t\t\t\t\t\t\tmap(e => e.detail.theme),\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\tconst uid = `dialog-${Date.now()}-${Math.random().toString(36).substring(2, 9)}`\n\t\t\t\t\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\t\t\t\t\tnew CustomEvent(ThemeWhereAreYou, {\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\t;(target as { uid?: string }).uid = 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\tmap(([theme, target]) => {\n\t\t\t\t\tconst targetContainer =\n\t\t\t\t\t\ttheme ||\n\t\t\t\t\t\ttarget.options.targetContainer ||\n\t\t\t\t\t\t(document.querySelector('schmancy-theme') as HTMLElement) ||\n\t\t\t\t\t\tdocument.body\n\n\t\t\t\t\tconst uid = (target as { uid?: string }).uid!\n\t\t\t\t\tconst dialog = document.createElement('schmancy-dialog') as SchmancyDialog\n\t\t\t\t\tdialog.setAttribute('uid', uid)\n\t\t\t\t\tdialog.style.setProperty('--schmancy-overlay-z', String(overlayStack.getNextZIndex()))\n\t\t\t\t\ttargetContainer.appendChild(dialog)\n\n\t\t\t\t\treturn { dialog, target }\n\t\t\t\t}),\n\t\t\t\ttap(({ dialog, target }) => {\n\t\t\t\t\tconst options = target.options\n\n\t\t\t\t\tif (target.type === 'confirm') {\n\t\t\t\t\t\t// Configure for confirm mode\n\t\t\t\t\t\tdialog.title = options.title\n\t\t\t\t\t\tdialog.subtitle = options.subtitle\n\t\t\t\t\t\tdialog.message = options.message\n\t\t\t\t\t\tdialog.confirmText = options.confirmText ?? 'Confirm'\n\t\t\t\t\t\tdialog.cancelText = options.cancelText ?? 'Cancel'\n\t\t\t\t\t\tdialog.variant = options.variant ?? 'default'\n\n\t\t\t\t\t\t// Handle custom content slot\n\t\t\t\t\t\tif (options.content) {\n\t\t\t\t\t\t\tconst contentContainer = document.createElement('div')\n\t\t\t\t\t\t\tcontentContainer.slot = 'content'\n\n\t\t\t\t\t\t\tif (typeof options.content === 'function') {\n\t\t\t\t\t\t\t\tconst result = options.content()\n\t\t\t\t\t\t\t\tif (result instanceof HTMLElement) {\n\t\t\t\t\t\t\t\t\tcontentContainer.appendChild(result)\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\trender(result, contentContainer)\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} else if (options.content instanceof HTMLElement) {\n\t\t\t\t\t\t\t\tcontentContainer.appendChild(options.content)\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\trender(options.content, contentContainer)\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tdialog.appendChild(contentContainer)\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// Configure for content mode\n\t\t\t\t\t\tdialog.hideActions = true\n\n\t\t\t\t\t\tif (target.content) {\n\t\t\t\t\t\t\tconst contentContainer = document.createElement('div')\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tcontentContainer.style.display = 'contents'\n\t\t\t\t\t\t\tcontentContainer.classList.add('schmancy-dialog-content-container')\n\n\t\t\t\t\t\t\tif (typeof target.content === 'function') {\n\t\t\t\t\t\t\t\tconst result = target.content()\n\t\t\t\t\t\t\t\tif (result instanceof HTMLElement) {\n\t\t\t\t\t\t\t\t\tcontentContainer.appendChild(result)\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\trender(result, contentContainer)\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} else if (target.content instanceof HTMLElement) {\n\t\t\t\t\t\t\t\tcontentContainer.appendChild(target.content)\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\trender(target.content, contentContainer)\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tdialog.appendChild(contentContainer)\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.activeDialogs.push(dialog)\n\t\t\t\t}),\n\t\t\t\ttap(({ dialog, target }) => {\n\t\t\t\t\tconst position = target.options.position || this.getDefaultPosition()\n\n\t\t\t\t\tdialog\n\t\t\t\t\t\t.show(position)\n\t\t\t\t\t\t.then((result: boolean) => {\n\t\t\t\t\t\t\ttarget.resolve?.(result)\n\n\t\t\t\t\t\t\t// Cleanup\n\t\t\t\t\t\t\tconst index = this.activeDialogs.indexOf(dialog)\n\t\t\t\t\t\t\tif (index !== -1) {\n\t\t\t\t\t\t\t\tthis.activeDialogs.splice(index, 1)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\toverlayStack.release()\n\n\t\t\t\t\t\t\t// Clean up content\n\t\t\t\t\t\t\tconst contentEl = dialog.querySelector('[slot=\"content\"]')\n\t\t\t\t\t\t\tif (contentEl) dialog.removeChild(contentEl)\n\n\t\t\t\t\t\t\tconst contentContainer = dialog.querySelector('.schmancy-dialog-content-container')\n\t\t\t\t\t\t\tif (contentContainer?.parentNode) {\n\t\t\t\t\t\t\t\tcontentContainer.parentNode.removeChild(contentContainer)\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t// Clean up event subscriptions\n\t\t\t\t\t\t\tconst eventSubscriptions = (dialog as unknown as { _eventSubscriptions?: Subscription[] })\n\t\t\t\t\t\t\t\t._eventSubscriptions\n\t\t\t\t\t\t\teventSubscriptions?.forEach(sub => sub.unsubscribe())\n\n\t\t\t\t\t\t\t// Remove from DOM\n\t\t\t\t\t\t\tdialog.parentElement?.removeChild(dialog)\n\t\t\t\t\t\t})\n\t\t\t\t\t\t.catch((error: unknown) => {\n\t\t\t\t\t\t\ttarget.reject?.(error)\n\t\t\t\t\t\t})\n\n\t\t\t\t\t// Set up event listeners\n\t\t\t\t\tconst eventSubscriptions: Subscription[] = []\n\n\t\t\t\t\tif (target.options.onConfirm) {\n\t\t\t\t\t\tconst confirmSub = fromEvent(dialog, 'confirm').subscribe(() => {\n\t\t\t\t\t\t\ttarget.options.onConfirm!()\n\t\t\t\t\t\t\tconfirmSub.unsubscribe()\n\t\t\t\t\t\t})\n\t\t\t\t\t\teventSubscriptions.push(confirmSub)\n\t\t\t\t\t}\n\n\t\t\t\t\tif (target.options.onCancel) {\n\t\t\t\t\t\tconst cancelSub = fromEvent(dialog, 'cancel').subscribe(() => {\n\t\t\t\t\t\t\ttarget.options.onCancel!()\n\t\t\t\t\t\t\tcancelSub.unsubscribe()\n\t\t\t\t\t\t})\n\t\t\t\t\t\teventSubscriptions.push(cancelSub)\n\t\t\t\t\t}\n\n\t\t\t\t\t;(dialog as unknown as { _eventSubscriptions: Subscription[] })._eventSubscriptions = eventSubscriptions\n\t\t\t\t}),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tprivate setupDialogDismissLogic() {\n\t\tthis.dismissSubject\n\t\t\t.pipe(\n\t\t\t\tswitchMap(uid =>\n\t\t\t\t\tforkJoin([\n\t\t\t\t\t\tfromEvent<DialogHereMortyEvent>(window, DialogHereMorty).pipe(\n\t\t\t\t\t\t\ttakeUntil(timer(100)),\n\t\t\t\t\t\t\tmap(e => e.detail),\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(\n\t\t\t\t\t\t\t\t\tnew CustomEvent(DialogWhereAreYouRicky, {\n\t\t\t\t\t\t\t\t\t\tdetail: { uid },\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]),\n\t\t\t\t),\n\t\t\t\ttap(([response]) => {\n\t\t\t\t\tif (response?.dialog) {\n\t\t\t\t\t\tresponse.dialog.hide(false)\n\n\t\t\t\t\t\tconst eventSubscriptions = (response.dialog as unknown as { _eventSubscriptions?: Subscription[] })\n\t\t\t\t\t\t\t._eventSubscriptions\n\t\t\t\t\t\teventSubscriptions?.forEach(sub => sub.unsubscribe())\n\n\t\t\t\t\t\tconst index = this.activeDialogs.indexOf(response.dialog as SchmancyDialog)\n\t\t\t\t\t\tif (index !== -1) {\n\t\t\t\t\t\t\tthis.activeDialogs.splice(index, 1)\n\t\t\t\t\t\t}\n\t\t\t\t\t\toverlayStack.release()\n\n\t\t\t\t\t\tresponse.dialog.parentElement?.removeChild(response.dialog)\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tpublic confirm(options: DialogOptions): Promise<boolean> {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tconst completeOptions = {\n\t\t\t\t...DialogService.DEFAULT_OPTIONS,\n\t\t\t\t...options,\n\t\t\t}\n\n\t\t\tif (!completeOptions.position) {\n\t\t\t\tcompleteOptions.position = this.getDefaultPosition()\n\t\t\t}\n\n\t\t\tthis.dialogSubject.next({\n\t\t\t\toptions: completeOptions,\n\t\t\t\ttype: 'confirm',\n\t\t\t\tcontent: completeOptions.content,\n\t\t\t\tresolve,\n\t\t\t\treject,\n\t\t\t})\n\t\t})\n\t}\n\n\tpublic component(\n\t\tcontent: TemplateResult | HTMLElement | (() => HTMLElement | TemplateResult),\n\t\toptions: Omit<DialogOptions, 'content' | 'message'> = {},\n\t): Promise<boolean> {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tif (!options.position) {\n\t\t\t\toptions.position = this.getDefaultPosition()\n\t\t\t}\n\n\t\t\tthis.dialogSubject.next({\n\t\t\t\toptions: options as DialogOptions,\n\t\t\t\ttype: 'component',\n\t\t\t\tcontent,\n\t\t\t\tresolve,\n\t\t\t\treject,\n\t\t\t})\n\t\t})\n\t}\n\n\tpublic dismiss(): boolean {\n\t\tif (this.activeDialogs.length > 0) {\n\t\t\tconst dialog = this.activeDialogs[this.activeDialogs.length - 1]\n\t\t\tconst uid = dialog.getAttribute('uid')\n\n\t\t\tif (uid) {\n\t\t\t\tthis.dismissSubject.next(uid)\n\t\t\t\treturn true\n\t\t\t}\n\t\t}\n\t\treturn false\n\t}\n\n\tpublic close(): boolean {\n\t\treturn this.dismiss()\n\t}\n\n\tpublic ask(message: string, event?: MouseEvent | TouchEvent): Promise<boolean> {\n\t\treturn this.confirm({\n\t\t\tmessage,\n\t\t\tconfirmText: 'Confirm',\n\t\t\tcancelText: 'Cancel',\n\t\t\tposition: event,\n\t\t})\n\t}\n\n\tpublic danger(options: Omit<DialogOptions, 'variant'>): Promise<boolean> {\n\t\treturn this.confirm({\n\t\t\t...options,\n\t\t\tvariant: 'danger',\n\t\t})\n\t}\n\n\t/**\n\t * Shows a prompt dialog with an input field.\n\t * Returns the input value if confirmed, null if cancelled.\n\t */\n\tpublic prompt(options: PromptOptions): Promise<string | null> {\n\t\treturn new Promise(resolve => {\n\t\t\tlet inputValue = options.defaultValue || ''\n\n\t\t\t// Create container for input\n\t\t\tconst container = document.createElement('div')\n\t\t\tcontainer.style.width = '100%'\n\t\t\tcontainer.style.minWidth = '280px'\n\n\t\t\tconst input = document.createElement('schmancy-input') as HTMLElement\n\t\t\tinput.setAttribute('type', options.inputType || 'text')\n\t\t\tif (options.label) input.setAttribute('label', options.label)\n\t\t\tif (options.placeholder) input.setAttribute('placeholder', options.placeholder)\n\t\t\tif (options.defaultValue) input.setAttribute('value', options.defaultValue)\n\n\t\t\tinput.addEventListener('input', (e: Event) => {\n\t\t\t\tinputValue = (e.target as HTMLInputElement).value\n\t\t\t})\n\n\t\t\tcontainer.appendChild(input)\n\n\t\t\tthis.confirm({\n\t\t\t\ttitle: options.title,\n\t\t\t\tmessage: options.message,\n\t\t\t\tconfirmText: options.confirmText ?? 'OK',\n\t\t\t\tcancelText: options.cancelText ?? 'Cancel',\n\t\t\t\tposition: options.position,\n\t\t\t\tcontent: container,\n\t\t\t}).then(confirmed => {\n\t\t\t\tresolve(confirmed ? inputValue : null)\n\t\t\t})\n\t\t})\n\t}\n\n\tprivate getDefaultPosition(): { x: number; y: number } {\n\t\t// Use last click position if available, otherwise center of screen\n\t\tif (this.lastClickPosition) {\n\t\t\treturn { ...this.lastClickPosition }\n\t\t}\n\t\treturn {\n\t\t\tx: window.innerWidth / 2,\n\t\t\ty: window.innerHeight / 2,\n\t\t}\n\t}\n}\n\n/**\n * Eagerly instantiate so click tracking starts immediately on import,\n * not on first dialog open (which would miss the triggering click).\n */\nconst service = DialogService.getInstance()\n\n/**\n * Global dialog utility\n */\nexport const $dialog = {\n\tconfirm: (options: DialogOptions): Promise<boolean> => {\n\t\treturn service.confirm(options)\n\t},\n\n\task: (message: string, event?: MouseEvent | TouchEvent): Promise<boolean> => {\n\t\treturn service.ask(message, event)\n\t},\n\n\tdanger: (options: Omit<DialogOptions, 'variant'>): Promise<boolean> => {\n\t\treturn service.danger(options)\n\t},\n\n\tprompt: (options: PromptOptions): Promise<string | null> => {\n\t\treturn service.prompt(options)\n\t},\n\n\tcomponent: (\n\t\tcontent: TemplateResult | HTMLElement | (() => HTMLElement | TemplateResult),\n\t\toptions?: Omit<DialogOptions, 'content' | 'message'>,\n\t): Promise<boolean> => {\n\t\treturn service.component(content, options)\n\t},\n\n\tdismiss: (): boolean => {\n\t\treturn service.dismiss()\n\t},\n\n\tclose: (): boolean => {\n\t\treturn service.close()\n\t},\n}\n\nexport default DialogService\n"],"mappings":"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"}
|
package/dist/dialog.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`}),require(`./chunk-BCfY8kxB.cjs`);const e=require(`./decorate-F9CuyeHg.cjs`),t=require(`./litElement.mixin-
|
|
1
|
+
Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`}),require(`./chunk-BCfY8kxB.cjs`);const e=require(`./decorate-F9CuyeHg.cjs`),t=require(`./litElement.mixin-De5SG5z7.cjs`);require(`./mixins.cjs`);const n=require(`./animation-Bcwh107v.cjs`),r=require(`./reduced-motion-DR32yKEO.cjs`),i=require(`./cursor-glow-82y5h3E4.cjs`),a=require(`./dialog-service-DXLGSshF.cjs`);let o=require(`rxjs`),s=require(`rxjs/operators`),c=require(`lit/decorators.js`),l=require(`lit`),u=require(`lit/directives/ref.js`),d=require(`lit/directives/when.js`),f=require(`@floating-ui/dom`);var p=e=>class extends e{constructor(...e){super(...e),this.position={x:0,y:0},this.isMobile=!1,this.dragOffset=0,this.stopSwipe$=new o.Subject,this.lastFocusedElement=null,this.inertSiblings=[],this.animating=!1,this.dialogInternals=(()=>{try{return this.attachInternals()}catch{return}})()}isAnimating(){return this.animating}getDialogElement(){return null}getBackdropElement(){return null}getDragHandleElement(){return null}connectedCallback(){super.connectedCallback(),this.setupResizeListener()}setupResizeListener(){(0,o.fromEvent)(window,`resize`).pipe((0,o.map)(()=>window.innerWidth<640),(0,o.distinctUntilChanged)(),(0,o.filter)(()=>this.hasAttribute(`active`)),(0,o.tap)(e=>{if(this.isMobile!==e){this.isMobile=e,this.requestUpdate();let t=this.getDialogElement();t&&(e?(this.applyBottomSheetStyles(t),this.setupSwipeGesture(t)):(this.stopSwipe$.next(),this.setupPositioning()))}}),(0,o.takeUntil)(this.disconnecting)).subscribe()}setupSwipeGesture(e){this.stopSwipe$.next();let t=0,n=!1,r=0,i=this.getDragHandleElement();(0,o.merge)((0,o.fromEvent)(i||e,`touchstart`,{passive:!0}).pipe((0,o.tap)(a=>{let o=a.touches[0],s=e.getBoundingClientRect();o.clientY-s.top>80&&!i||(n=!0,t=o.clientY,r=0,this.dragOffset=0,e.style.transition=`none`,e.style.willChange=`transform`)})),(0,o.fromEvent)(e,`touchmove`,{passive:!1}).pipe((0,o.filter)(()=>n),(0,o.tap)(n=>{let i=n.touches[0].clientY-t;r=i<0?.2*i:i,this.dragOffset=Math.max(0,i),e.style.transform=`translateY(${r}px)`,n.preventDefault()})),(0,o.merge)((0,o.fromEvent)(e,`touchend`,{passive:!0}),(0,o.fromEvent)(e,`touchcancel`,{passive:!0})).pipe((0,o.filter)(()=>n),(0,o.tap)(()=>{n=!1,e.style.transition=`transform 0.3s cubic-bezier(0.16, 1, 0.3, 1)`,e.style.willChange=``;let t=e.getBoundingClientRect().height,r=Math.min(100,.25*t);this.dragOffset>r?(e.style.transform=`translateY(100%)`,this.hide(!1)):(e.style.transform=`translateY(0)`,this.dragOffset=0)}))).pipe((0,o.takeUntil)((0,o.merge)(this.stopSwipe$,this.disconnecting))).subscribe()}applyBottomSheetStyles(e){this.cleanupAutoUpdate&&=(this.cleanupAutoUpdate(),void 0),Object.assign(e.style,{position:``,left:``,top:``,transform:``,maxWidth:``})}async show(e){let t,n;if(this.cleanupAutoUpdate&&=(this.cleanupAutoUpdate(),void 0),this.isMobile=window.innerWidth<640,e)if(`clientX`in e)t=e.clientX,n=e.clientY;else if(`touches`in e&&e.touches.length)t=e.touches[0].clientX,n=e.touches[0].clientY;else{let r=e;t=r.x,n=r.y}else t=window.innerWidth/2,n=window.innerHeight/2;this.position={x:t,y:n},this.virtualReference={getBoundingClientRect:()=>new DOMRect(t,n,0,0)},this.requestUpdate(),await this.updateComplete,this.setAttribute(`active`,``),this.dialogInternals?.states.add(`open`),await this.updateComplete,this.lastFocusedElement=document.activeElement;let r=this.parentElement;if(r){this.inertSiblings=[];for(let e=0;e<r.children.length;e++){let t=r.children[e];t!==this&&`inert`in t&&(t.inert=!0,this.inertSiblings.push(t))}}(0,o.fromEvent)(document,`keydown`).pipe((0,o.filter)(e=>e.key===`Escape`),(0,o.tap)(e=>{e.preventDefault(),this.hide(!1)}),(0,o.takeUntil)((0,o.merge)(this.stopSwipe$,this.disconnecting))).subscribe();let i=this.getDialogElement(),a=window.innerWidth<1024?.6:.8;return!this.isMobile&&i&&(i.scrollHeight>window.innerHeight*a||i.scrollWidth>window.innerWidth*a)&&(this.isMobile=!0,this.requestUpdate(),await this.updateComplete),this.isMobile?i&&(this.applyBottomSheetStyles(i),this.setupSwipeGesture(i)):this.setupPositioning(),this.animating=!0,await this.animateIn(),this.animating=!1,new Promise(e=>{this.resolvePromise=e})}async animateIn(){let e=this.getDialogElement(),t=this.getBackdropElement();if(r.t.value)return t&&(t.style.opacity=`1`),void(e&&(e.style.opacity=`1`));if(t?.animate([{opacity:0},{opacity:1}],{duration:200,easing:n.s,fill:`forwards`}),e){let t=this.isMobile?[{opacity:0,transform:`translateY(100%)`},{opacity:1,transform:`translateY(0)`}]:[{opacity:0,transform:`scale(0.92) translateY(16px)`},{opacity:1,transform:`scale(1) translateY(0)`}];await e.animate(t,{duration:n.i,easing:n.n,fill:`forwards`}).finished}}async animateOut(){let e=this.getDialogElement(),t=this.getBackdropElement();if(r.t.value)return t&&(t.style.opacity=`0`),void(e&&(e.style.opacity=`0`));let i=[];if(t&&i.push(t.animate([{opacity:1},{opacity:0}],{duration:150,easing:n.s,fill:`forwards`}).finished),e){let t=this.isMobile?[{opacity:1,transform:`translateY(0)`},{opacity:0,transform:`translateY(100%)`}]:[{opacity:1,transform:`scale(1) translateY(0)`},{opacity:0,transform:`scale(0.95) translateY(8px)`}];i.push(e.animate(t,{duration:150,easing:n.o,fill:`forwards`}).finished)}await Promise.all(i)}async hide(e=!1){this.stopSwipe$.next(),this.animating=!0,await this.animateOut(),this.animating=!1,this.removeAttribute(`active`),this.dialogInternals?.states.delete(`open`);for(let e of this.inertSiblings)e.inert=!1;if(this.inertSiblings=[],this.lastFocusedElement){let e=this.lastFocusedElement;typeof e.focus==`function`&&e.focus(),this.lastFocusedElement=null}this.cleanupAutoUpdate&&=(this.cleanupAutoUpdate(),void 0),this.resolvePromise&&=(this.resolvePromise(e),void 0)}isCentered(){let e=.05*window.innerWidth,t=.05*window.innerHeight;return Math.abs(this.position.x-window.innerWidth/2)<e&&Math.abs(this.position.y-window.innerHeight/2)<t}setupPositioning(){let e=this.getDialogElement();e&&(this.isCentered()||this.virtualReference&&(this.cleanupAutoUpdate=(0,f.autoUpdate)(this.virtualReference,e,()=>this.updatePosition(e),{ancestorScroll:!0,ancestorResize:!0,elementResize:!0}),this.updatePosition(e)))}async updatePosition(e){if(!this.virtualReference)return;let{x:t,y:n}=await(0,f.computePosition)(this.virtualReference,e,{strategy:`fixed`,middleware:[(0,f.offset)(8),(0,f.autoPlacement)({padding:16,allowedPlacements:[`top-start`,`top-end`,`bottom-start`,`bottom-end`,`left-start`,`left-end`,`right-start`,`right-end`]}),(0,f.shift)({padding:16}),(0,f.size)({padding:16,apply({availableWidth:e,elements:t}){t.floating.style.maxWidth=`${e}px`}})]});Object.assign(e.style,{position:`fixed`,left:`${Math.round(t)}px`,top:`${Math.round(n)}px`,transform:`none`})}disconnectedCallback(){this.stopSwipe$.next(),this.cleanupAutoUpdate&&=(this.cleanupAutoUpdate(),void 0),super.disconnectedCallback()}},m=class extends p(t.t(l.css`
|
|
2
2
|
:host {
|
|
3
3
|
position: fixed;
|
|
4
4
|
z-index: var(--schmancy-overlay-z, 10000);
|
package/dist/dialog.js
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { t as e } from "./decorate-D_utPUsC.js";
|
|
2
|
-
import { t } from "./litElement.mixin-
|
|
2
|
+
import { t } from "./litElement.mixin-D6ZHgGZv.js";
|
|
3
3
|
import "./mixins.js";
|
|
4
4
|
import { i as n, n as r, o as i, s as a } from "./animation-CXKSuUoE.js";
|
|
5
5
|
import { t as o } from "./reduced-motion-B83yZbcO.js";
|
|
6
6
|
import { t as s } from "./cursor-glow-C2YRrB8Z.js";
|
|
7
|
-
import { i as c, n as l, r as u, t as d } from "./dialog-service-
|
|
7
|
+
import { i as c, n as l, r as u, t as d } from "./dialog-service-CCFGpU7a.js";
|
|
8
8
|
import { Subject as f, distinctUntilChanged as p, filter as m, fromEvent as h, map as g, merge as _, takeUntil as v, tap as y } from "rxjs";
|
|
9
9
|
import { takeUntil as b } from "rxjs/operators";
|
|
10
10
|
import { customElement as x, property as S, queryAssignedElements as C } from "lit/decorators.js";
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { t as e } from "./decorate-D_utPUsC.js";
|
|
2
|
-
import { t } from "./litElement.mixin-
|
|
2
|
+
import { t } from "./litElement.mixin-D6ZHgGZv.js";
|
|
3
3
|
import "./mixins.js";
|
|
4
4
|
import { customElement as n, property as r } from "lit/decorators.js";
|
|
5
5
|
import { css as i, html as a } from "lit";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"divider-
|
|
1
|
+
{"version":3,"file":"divider-ChK7lCQF.js","names":[],"sources":["../src/divider/divider.ts"],"sourcesContent":["// divider.ts\nimport { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\n@customElement('schmancy-divider')\nexport default class SchmancyDivider extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n\n\t@keyframes grow-horizontal {\n\t\tfrom {\n\t\t\ttransform: scaleX(0);\n\t\t}\n\t\tto {\n\t\t\ttransform: scaleX(1);\n\t\t}\n\t}\n\n\t@keyframes grow-vertical {\n\t\tfrom {\n\t\t\ttransform: scaleY(0);\n\t\t}\n\t\tto {\n\t\t\ttransform: scaleY(1);\n\t\t}\n\t}\n\n\t/* Horizontal divider grow animations */\n\t.grow-start:not(.h-full) {\n\t\tanimation: grow-horizontal 400ms ease-out;\n\t\ttransform-origin: left;\n\t}\n\n\t.grow-end:not(.h-full) {\n\t\tanimation: grow-horizontal 400ms ease-out;\n\t\ttransform-origin: right;\n\t}\n\n\t.grow-both:not(.h-full) {\n\t\tanimation: grow-horizontal 400ms ease-out;\n\t\ttransform-origin: center;\n\t}\n\n\t/* Vertical divider grow animations */\n\t.grow-start.h-full {\n\t\tanimation: grow-vertical 400ms ease-out;\n\t\ttransform-origin: top;\n\t}\n\n\t.grow-end.h-full {\n\t\tanimation: grow-vertical 400ms ease-out;\n\t\ttransform-origin: bottom;\n\t}\n\n\t.grow-both.h-full {\n\t\tanimation: grow-vertical 400ms ease-out;\n\t\ttransform-origin: center;\n\t}\n`) {\n\t@property({ type: String }) outline: 'default' | 'variant' = 'variant'\n\t@property({ type: Boolean }) vertical = false\n\t@property({ type: String }) grow: 'start' | 'end' | 'both' = 'start'\n\n\t/**\n\t * @deprecated Use `vertical` property instead. Will be removed in next major version.\n\t */\n\t@property({ reflect: true, type: String })\n\tset orientation(value: 'horizontal' | 'vertical') {\n\t\tthis.vertical = value === 'vertical'\n\t}\n\tget orientation(): 'horizontal' | 'vertical' {\n\t\treturn this.vertical ? 'vertical' : 'horizontal'\n\t}\n\n\tprotected render() {\n\t\treturn html`<div\n\t\t\tclass=${this.classMap({\n\t\t\t\t// Dimensions\n\t\t\t\t'w-full h-px': !this.vertical,\n\t\t\t\t'h-full w-px': this.vertical,\n\t\t\t\t// Border color\n\t\t\t\t'border-outlineVariant': this.outline === 'variant',\n\t\t\t\t'border-outline': this.outline === 'default',\n\t\t\t\t// Border style\n\t\t\t\t'border-t': !this.vertical,\n\t\t\t\t'border-l': this.vertical,\n\t\t\t\t// Grow behavior\n\t\t\t\t[`grow-${this.grow}`]: true,\n\t\t\t})}\n\t\t></div>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-divider': SchmancyDivider\n\t}\n}\n"],"mappings":";;;;;AAMe,IAAA,IAAA,cAA8B,EAAY,CAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAuDE,WAAA,KAAA,WAAA,CACrB,GAAA,KAAA,OACqB;;CAK7D,IAAA,YACgB,GAAA;AACf,OAAK,WAAW,MAAU;;CAE3B,IAAA,cAAI;AACH,SAAO,KAAK,WAAW,aAAa;;CAGrC,SAAA;AACC,SAAO,CAAI;WACF,KAAK,SAAS;GAErB,eAAA,CAAgB,KAAK;GACrB,eAAe,KAAK;GAEpB,yBAAyB,KAAK,YAAY;GAC1C,kBAAkB,KAAK,YAAY;GAEnC,YAAA,CAAa,KAAK;GAClB,YAAY,KAAK;IAEhB,QAAQ,KAAK,SAAA,CAAS;GAAA,CAAA,CAAA;;;;GA5BzB,EAAS,EAAE,MAAM,QAAA,CAAA,CAAA,EAAS,EAAA,WAAA,WAAA,KAAA,EAAA,EAAA,EAAA,CAC1B,EAAS,EAAE,MAAM,SAAA,CAAA,CAAA,EAAU,EAAA,WAAA,YAAA,KAAA,EAAA,EAAA,EAAA,CAC3B,EAAS,EAAE,MAAM,QAAA,CAAA,CAAA,EAAS,EAAA,WAAA,QAAA,KAAA,EAAA,EAAA,EAAA,CAK1B,EAAS;CAAE,SAAA,CAAS;CAAM,MAAM;CAAA,CAAA,CAAA,EAAS,EAAA,WAAA,eAAA,KAAA,EAAA,IAAA,EAAA,CA/D1C,EAAc,mBAAA,CAAA,EAAmB,EAAA"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
require(`./chunk-BCfY8kxB.cjs`);const e=require(`./decorate-F9CuyeHg.cjs`),t=require(`./litElement.mixin-
|
|
1
|
+
require(`./chunk-BCfY8kxB.cjs`);const e=require(`./decorate-F9CuyeHg.cjs`),t=require(`./litElement.mixin-De5SG5z7.cjs`);require(`./mixins.cjs`);let n=require(`lit/decorators.js`),r=require(`lit`);var i=class extends t.t(r.css`
|
|
2
2
|
:host {
|
|
3
3
|
display: block;
|
|
4
4
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"divider-
|
|
1
|
+
{"version":3,"file":"divider-RjZbewe8.cjs","names":[],"sources":["../src/divider/divider.ts"],"sourcesContent":["// divider.ts\nimport { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\n@customElement('schmancy-divider')\nexport default class SchmancyDivider extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n\n\t@keyframes grow-horizontal {\n\t\tfrom {\n\t\t\ttransform: scaleX(0);\n\t\t}\n\t\tto {\n\t\t\ttransform: scaleX(1);\n\t\t}\n\t}\n\n\t@keyframes grow-vertical {\n\t\tfrom {\n\t\t\ttransform: scaleY(0);\n\t\t}\n\t\tto {\n\t\t\ttransform: scaleY(1);\n\t\t}\n\t}\n\n\t/* Horizontal divider grow animations */\n\t.grow-start:not(.h-full) {\n\t\tanimation: grow-horizontal 400ms ease-out;\n\t\ttransform-origin: left;\n\t}\n\n\t.grow-end:not(.h-full) {\n\t\tanimation: grow-horizontal 400ms ease-out;\n\t\ttransform-origin: right;\n\t}\n\n\t.grow-both:not(.h-full) {\n\t\tanimation: grow-horizontal 400ms ease-out;\n\t\ttransform-origin: center;\n\t}\n\n\t/* Vertical divider grow animations */\n\t.grow-start.h-full {\n\t\tanimation: grow-vertical 400ms ease-out;\n\t\ttransform-origin: top;\n\t}\n\n\t.grow-end.h-full {\n\t\tanimation: grow-vertical 400ms ease-out;\n\t\ttransform-origin: bottom;\n\t}\n\n\t.grow-both.h-full {\n\t\tanimation: grow-vertical 400ms ease-out;\n\t\ttransform-origin: center;\n\t}\n`) {\n\t@property({ type: String }) outline: 'default' | 'variant' = 'variant'\n\t@property({ type: Boolean }) vertical = false\n\t@property({ type: String }) grow: 'start' | 'end' | 'both' = 'start'\n\n\t/**\n\t * @deprecated Use `vertical` property instead. Will be removed in next major version.\n\t */\n\t@property({ reflect: true, type: String })\n\tset orientation(value: 'horizontal' | 'vertical') {\n\t\tthis.vertical = value === 'vertical'\n\t}\n\tget orientation(): 'horizontal' | 'vertical' {\n\t\treturn this.vertical ? 'vertical' : 'horizontal'\n\t}\n\n\tprotected render() {\n\t\treturn html`<div\n\t\t\tclass=${this.classMap({\n\t\t\t\t// Dimensions\n\t\t\t\t'w-full h-px': !this.vertical,\n\t\t\t\t'h-full w-px': this.vertical,\n\t\t\t\t// Border color\n\t\t\t\t'border-outlineVariant': this.outline === 'variant',\n\t\t\t\t'border-outline': this.outline === 'default',\n\t\t\t\t// Border style\n\t\t\t\t'border-t': !this.vertical,\n\t\t\t\t'border-l': this.vertical,\n\t\t\t\t// Grow behavior\n\t\t\t\t[`grow-${this.grow}`]: true,\n\t\t\t})}\n\t\t></div>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-divider': SchmancyDivider\n\t}\n}\n"],"mappings":"oMAMe,IAAA,EAAA,cAA8B,EAAA,EAAY,EAAA,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8CAuDE,UAAA,KAAA,SAAA,CACrB,EAAA,KAAA,KACqB,QAK7D,IAAA,YACgB,EAAA,CACf,KAAK,SAAW,IAAU,WAE3B,IAAA,aAAI,CACH,OAAO,KAAK,SAAW,WAAa,aAGrC,QAAA,CACC,MAAO,GAAA,IAAI;WACF,KAAK,SAAS,CAErB,cAAA,CAAgB,KAAK,SACrB,cAAe,KAAK,SAEpB,wBAAyB,KAAK,UAAY,UAC1C,iBAAkB,KAAK,UAAY,UAEnC,WAAA,CAAa,KAAK,SAClB,WAAY,KAAK,UAEhB,QAAQ,KAAK,QAAA,CAAS,EAAA,CAAA,CAAA;iCA5BhB,CAAE,KAAM,OAAA,CAAA,CAAA,CAAS,EAAA,UAAA,UAAA,IAAA,GAAA,CAAA,EAAA,EAAA,EAAA,EAAA,EAAA,UACjB,CAAE,KAAM,QAAA,CAAA,CAAA,CAAU,EAAA,UAAA,WAAA,IAAA,GAAA,CAAA,EAAA,EAAA,EAAA,EAAA,EAAA,UAClB,CAAE,KAAM,OAAA,CAAA,CAAA,CAAS,EAAA,UAAA,OAAA,IAAA,GAAA,CAAA,EAAA,EAAA,EAAA,EAAA,EAAA,UAKjB,CAAE,QAAA,CAAS,EAAM,KAAM,OAAA,CAAA,CAAA,CAAS,EAAA,UAAA,cAAA,KAAA,CAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,eA/D5B,mBAAA,CAAA,CAAmB,EAAA"}
|
package/dist/divider.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
require(`./divider-
|
|
1
|
+
require(`./divider-RjZbewe8.cjs`);
|
package/dist/divider.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import "./divider-
|
|
1
|
+
import "./divider-ChK7lCQF.js";
|
package/dist/dropdown.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`}),require(`./chunk-BCfY8kxB.cjs`);const e=require(`./tailwind.mixin-
|
|
1
|
+
Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`}),require(`./chunk-BCfY8kxB.cjs`);const e=require(`./tailwind.mixin-Bug3G6K6.cjs`),t=require(`./decorate-F9CuyeHg.cjs`),n=require(`./litElement.mixin-De5SG5z7.cjs`);require(`./mixins.cjs`);let r=require(`rxjs`),i=require(`lit/decorators.js`),a=require(`lit`),o=require(`@floating-ui/dom`);var s=class extends n.t(){constructor(...e){super(...e),this.open=!1,this.placement=`bottom-start`,this.distance=8,this.portal=null,this.portalSubscriptions=[]}connectedCallback(){super.connectedCallback(),this.setupPortal(),(0,r.fromEvent)(document,`click`).pipe((0,r.filter)(e=>this.open&&!this.isEventFromSelf(e)),(0,r.takeUntil)(this.disconnecting)).subscribe(()=>{this.open=!1}),(0,r.fromEvent)(document,`keydown`).pipe((0,r.filter)(e=>this.open&&e.key===`Escape`),(0,r.takeUntil)(this.disconnecting)).subscribe(()=>{this.open=!1})}setupPortal(){let e=document.getElementById(`schmancy-portal-container`);e||(e=document.createElement(`div`),e.id=`schmancy-portal-container`,e.style.position=`fixed`,e.style.zIndex=`10000`,e.style.top=`0`,e.style.left=`0`,e.style.pointerEvents=`none`,document.body.appendChild(e));let t=document.createElement(`div`);t.className=`schmancy-dropdown-portal`,t.style.position=`absolute`,t.style.pointerEvents=`auto`,t.style.display=`none`,e.appendChild(t),this.portal=t}isEventFromSelf(e){return e.composedPath().some(e=>e===this)}disconnectedCallback(){this.cleanupPositioner?.(),this.portalSubscriptions.forEach(e=>e.unsubscribe()),this.portalSubscriptions=[],this.portal&&=(this.portal.remove(),null),super.disconnectedCallback()}toggle(){this.open=!this.open}updated(e){super.updated(e),e.has(`open`)&&(this.open?this.setupPositioner():(this.cleanupPositioner?.(),this.portal&&(this.portal.style.display=`none`,this.portal.innerHTML=``,this.portalSubscriptions.forEach(e=>e.unsubscribe()),this.portalSubscriptions=[])))}setupPositioner(){this.triggerContainer&&this.portal&&(this.portal.style.display=`block`,this.teleportContentToPortal(),this.cleanupPositioner=(0,o.autoUpdate)(this.triggerContainer,this.portal,()=>{(0,o.computePosition)(this.triggerContainer,this.portal,{placement:this.placement,middleware:[(0,o.offset)(this.distance),(0,o.flip)({fallbackPlacements:[`top-start`,`bottom-start`]}),(0,o.shift)({padding:0})]}).then(({x:e,y:t})=>{Object.assign(this.portal.style,{left:`${e}px`,top:t-8+`px`})})}))}teleportContentToPortal(){this.portal&&(this.portalSubscriptions.forEach(e=>e.unsubscribe()),this.portalSubscriptions=[],this.portal.innerHTML=``,this.contentElements.forEach(e=>{let t=e.cloneNode(!0);if(e.tagName.toLowerCase()===`schmancy-dropdown-content`){let e=(0,r.fromEvent)(t,`slotchange`).subscribe(()=>{let e=t.shadowRoot?.querySelector(`[part="content"]`);e&&e.classList.add(`schmancy-dropdown-content`)});this.portalSubscriptions.push(e)}this.portal?.appendChild(t)}))}handleTriggerClick(e){e.stopPropagation(),this.toggle()}render(){return a.html`
|
|
2
2
|
<div class="trigger-container" @click=${this.handleTriggerClick}>
|
|
3
3
|
<slot name="trigger"></slot>
|
|
4
4
|
</div>
|
package/dist/dropdown.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { t as e } from "./tailwind.mixin-
|
|
1
|
+
import { t as e } from "./tailwind.mixin-ywtUNG2c.js";
|
|
2
2
|
import { t } from "./decorate-D_utPUsC.js";
|
|
3
|
-
import { t as n } from "./litElement.mixin-
|
|
3
|
+
import { t as n } from "./litElement.mixin-D6ZHgGZv.js";
|
|
4
4
|
import "./mixins.js";
|
|
5
5
|
import { filter as r, fromEvent as i, takeUntil as a } from "rxjs";
|
|
6
6
|
import { customElement as o, property as s, query as c, queryAssignedElements as l, state as u } from "lit/decorators.js";
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { t as e } from "./tailwind.mixin-
|
|
1
|
+
import { t as e } from "./tailwind.mixin-ywtUNG2c.js";
|
|
2
2
|
import { t } from "./decorate-D_utPUsC.js";
|
|
3
3
|
import { t as n } from "./surface.mixin-DqMwoddO.js";
|
|
4
4
|
import "./mixins.js";
|
|
5
5
|
import { d as r, f as i } from "./animation-CXKSuUoE.js";
|
|
6
6
|
import { t as a } from "./reduced-motion-B83yZbcO.js";
|
|
7
|
-
import "./surface-
|
|
7
|
+
import "./surface-B2cmGNZ2.js";
|
|
8
8
|
import { filter as o, fromEvent as s, lastValueFrom as c } from "rxjs";
|
|
9
9
|
import { takeUntil as l, tap as u } from "rxjs/operators";
|
|
10
10
|
import { styleMap as d } from "lit/directives/style-map.js";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"expand-BXt9SqAF.js","names":[],"sources":["../src/expand/expand-root.component.ts","../src/expand/expand.component.ts"],"sourcesContent":["import { css, html, nothing } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { createRef, ref } from 'lit/directives/ref.js'\nimport { TailwindElement, SurfaceMixin } from '@mixins/index'\nimport type { TSurfaceColor } from '@schmancy/types'\nimport { SPRING_SMOOTH } from '../utils/animation.js'\nimport { reducedMotion$ } from '../directives/reduced-motion'\nimport '../surface/surface.js'\n\n@customElement('schmancy-expand-root')\nexport class SchmancyExpandRoot extends SurfaceMixin(TailwindElement(css`\n\t:host {\n\t\tdisplay: contents;\n\t}\n\n\t.portal-panel {\n\t\tposition: fixed;\n\t\ttransform-origin: top left;\n\t\twill-change: clip-path, opacity;\n\t\tborder-radius: 1rem;\n\t\tbox-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.5);\n\t\tz-index: 9999;\n\t}\n\n\t.minimize-btn {\n\t\tposition: absolute;\n\t\ttop: 0.5rem;\n\t\tright: 0.5rem;\n\t\tz-index: 1;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tjustify-content: center;\n\t\twidth: 2rem;\n\t\theight: 2rem;\n\t\tborder-radius: 9999px;\n\t\tborder: none;\n\t\tbackground: transparent;\n\t\tcursor: pointer;\n\t\topacity: 0.5;\n\t\ttransition: opacity 150ms, background 150ms;\n\t\tcolor: inherit;\n\t}\n\n\t.minimize-btn:hover {\n\t\topacity: 1;\n\t\tbackground: rgb(0 0 0 / 0.08);\n\t}\n`)) {\n\t@property({ reflect: true }) override type: TSurfaceColor = 'solid'\n\t@state() isOpen = false\n\tprivate summaryRect: DOMRect | null = null\n\n\tprivate _panelRef = createRef<HTMLElement>()\n\tprivate _backdropRef = createRef<HTMLDivElement>()\n\tprivate _btnRef = createRef<HTMLButtonElement>()\n\tprivate _owner: (Element & { close?: () => void }) | null = null\n\tprivate _hideIndicator = false\n\tprivate _backdrop = true\n\n\t/** Called by schmancy-expand before nodes are moved */\n\tprepare(rect: DOMRect, owner: Element, hideIndicator = false, backdrop = true) {\n\t\tthis.summaryRect = rect\n\t\tthis._owner = owner as Element & { close?: () => void }\n\t\tthis._hideIndicator = hideIndicator\n\t\tthis._backdrop = backdrop\n\t}\n\n\t/** Called by schmancy-expand after nodes are moved in */\n\tasync triggerOpen() {\n\t\tthis.isOpen = true\n\t\tawait this.updateComplete\n\n\t\tconst panel = this._panelRef.value\n\t\tif (!panel) return\n\n\t\tconst src = this.summaryRect!\n\n\t\t// 1. Anchor at summary's top-left, measure natural content size\n\t\t// Use nearly full viewport height for measurement so content near the bottom\n\t\t// of the screen isn't artificially capped — the positioning step will move the panel up.\n\t\tObject.assign(panel.style, {\n\t\t\tvisibility: 'hidden',\n\t\t\ttop: `${src.top}px`,\n\t\t\tleft: `${src.left}px`,\n\t\t\tminWidth: `${src.width}px`,\n\t\t\twidth: 'max-content',\n\t\t\tmaxWidth: `${window.innerWidth - src.left}px`,\n\t\t\theight: 'auto',\n\t\t\tmaxHeight: `${window.innerHeight - 32}px`,\n\t\t\toverflowY: 'auto',\n\t\t})\n\n\t\tconst measured = panel.getBoundingClientRect()\n\t\tconst finalW = measured.width\n\t\tconst finalH = measured.height\n\n\t\t// 2. Adjust position so panel stays within viewport\n\t\tlet finalTop = src.top\n\t\tlet finalLeft = src.left\n\t\tif (finalTop + finalH > window.innerHeight) {\n\t\t\tfinalTop = Math.max(0, src.bottom - finalH)\n\t\t}\n\t\tif (finalLeft + finalW > window.innerWidth) {\n\t\t\tfinalLeft = Math.max(0, window.innerWidth - finalW)\n\t\t}\n\n\t\t// 3. Compute clip-path insets — summary rect expressed relative to panel final position\n\t\t// These insets shrink the visible area down to exactly the summary box\n\t\tconst insetTop = Math.max(0, src.top - finalTop)\n\t\tconst insetLeft = Math.max(0, src.left - finalLeft)\n\t\tconst insetRight = Math.max(0, finalLeft + finalW - (src.left + src.width))\n\t\tconst insetBottom = Math.max(0, finalTop + finalH - (src.top + src.height))\n\n\t\t// 4. Place panel at final size + position, masked to summary bounds (no flash)\n\t\tObject.assign(panel.style, {\n\t\t\tvisibility: '',\n\t\t\ttop: `${finalTop}px`,\n\t\t\tleft: `${finalLeft}px`,\n\t\t\tminWidth: `${src.width}px`,\n\t\t\twidth: `${finalW}px`,\n\t\t\theight: `${finalH}px`,\n\t\t\tmaxWidth: '',\n\t\t\tmaxHeight: '',\n\t\t\tclipPath: `inset(${insetTop}px ${insetRight}px ${insetBottom}px ${insetLeft}px round 0.5rem)`,\n\t\t})\n\n\t\t// 5. Animate the mask open — content revealed, not stretched\n\t\tthis._animateOpen(insetTop, insetRight, insetBottom, insetLeft, finalTop)\n\t}\n\n\t/** Animate close, return Promise resolving when done */\n\tasync triggerClose(targetRect: DOMRect): Promise<void> {\n\t\tawait this._animateClose(targetRect)\n\t\tthis.isOpen = false\n\t\tthis.summaryRect = null\n\t}\n\n\tprivate _animateOpen(insetTop: number, insetRight: number, insetBottom: number, insetLeft: number, finalTop: number) {\n\t\tconst panel = this._panelRef.value\n\t\tif (!panel) return\n\n\t\tif (reducedMotion$.value) {\n\t\t\tpanel.style.clipPath = ''\n\t\t\treturn\n\t\t}\n\n\t\tconst backdrop = this._backdropRef.value\n\t\tif (backdrop) {\n\t\t\tbackdrop.animate([{ opacity: 0 }, { opacity: 1 }], {\n\t\t\t\tduration: SPRING_SMOOTH.duration,\n\t\t\t\teasing: SPRING_SMOOTH.easingFallback,\n\t\t\t\tfill: 'forwards',\n\t\t\t})\n\t\t}\n\n\t\tconst keyframes: Keyframe[] = [\n\t\t\t{\n\t\t\t\tclipPath: `inset(${insetTop}px ${insetRight}px ${insetBottom}px ${insetLeft}px round 0.5rem)`,\n\t\t\t\topacity: 0.9,\n\t\t\t},\n\t\t\t{\n\t\t\t\tclipPath: 'inset(0px 0px 0px 0px round 1rem)',\n\t\t\t\topacity: 1,\n\t\t\t},\n\t\t]\n\n\t\tconst anim = panel.animate(keyframes, {\n\t\t\tduration: SPRING_SMOOTH.duration,\n\t\t\teasing: SPRING_SMOOTH.easingFallback,\n\t\t\tfill: 'forwards',\n\t\t})\n\n\t\t// Clear clip-path and fixed dimensions after animation so content can grow naturally,\n\t\t// but cap at viewport height so overflow-y: auto can scroll\n\t\tanim.finished.then(() => {\n\t\t\tif (panel.isConnected) {\n\t\t\t\tpanel.style.clipPath = ''\n\t\t\t\tpanel.style.height = 'auto'\n\t\t\t\tpanel.style.maxHeight = `${window.innerHeight - finalTop - 16}px`\n\t\t\t}\n\t\t})\n\n\t\tconst btn = this._btnRef.value\n\t\tif (btn) {\n\t\t\tbtn.animate([{ transform: 'rotate(0deg)' }, { transform: 'rotate(180deg)' }], {\n\t\t\t\tduration: SPRING_SMOOTH.duration,\n\t\t\t\teasing: SPRING_SMOOTH.easingFallback,\n\t\t\t\tfill: 'forwards',\n\t\t\t})\n\t\t}\n\t}\n\n\tprivate _animateClose(targetRect: DOMRect): Promise<void> {\n\t\tconst panel = this._panelRef.value\n\t\tif (!panel) return Promise.resolve()\n\t\tif (reducedMotion$.value) return Promise.resolve()\n\n\t\t// Compute insets to mask panel back down to the summary box\n\t\tconst panelRect = panel.getBoundingClientRect()\n\t\tconst insetTop = Math.max(0, targetRect.top - panelRect.top)\n\t\tconst insetLeft = Math.max(0, targetRect.left - panelRect.left)\n\t\tconst insetRight = Math.max(0, panelRect.right - targetRect.right)\n\t\tconst insetBottom = Math.max(0, panelRect.bottom - targetRect.bottom)\n\n\t\tconst closeDuration = Math.round(SPRING_SMOOTH.duration * 0.4)\n\t\tconst closeEasing = 'cubic-bezier(0.4, 0, 1, 1)'\n\n\t\tconst closeKeyframes: Keyframe[] = [\n\t\t\t{ clipPath: 'inset(0px 0px 0px 0px round 1rem)', opacity: 1 },\n\t\t\t{\n\t\t\t\tclipPath: `inset(${insetTop}px ${insetRight}px ${insetBottom}px ${insetLeft}px round 0.5rem)`,\n\t\t\t\topacity: 0.6,\n\t\t\t},\n\t\t]\n\n\t\tconst anim = panel.animate(closeKeyframes, { duration: closeDuration, easing: closeEasing, fill: 'forwards' })\n\n\t\tconst backdrop = this._backdropRef.value\n\t\tif (backdrop) {\n\t\t\tbackdrop.animate([{ opacity: 1 }, { opacity: 0 }], {\n\t\t\t\tduration: closeDuration,\n\t\t\t\teasing: closeEasing,\n\t\t\t\tfill: 'forwards',\n\t\t\t})\n\t\t}\n\n\t\tconst btn = this._btnRef.value\n\t\tif (btn) {\n\t\t\tbtn.animate([{ transform: 'rotate(180deg)' }, { transform: 'rotate(0deg)' }], {\n\t\t\t\tduration: closeDuration,\n\t\t\t\teasing: closeEasing,\n\t\t\t\tfill: 'forwards',\n\t\t\t})\n\t\t}\n\n\t\treturn anim.finished as unknown as Promise<void>\n\t}\n\n\trender() {\n\t\tif (!this.isOpen) return nothing\n\n\t\treturn html`\n\t\t\t${this._backdrop ? html`\n\t\t\t\t<div\n\t\t\t\t\t${ref(this._backdropRef)}\n\t\t\t\t\tclass=\"fixed inset-0 z-9998 backdrop-blur-sm backdrop-saturate-150 backdrop-brightness-105 bg-black/[0.07] will-change-[opacity]\"\n\t\t\t\t\t@click=${() => this._owner?.close?.()}\n\t\t\t\t></div>\n\t\t\t` : nothing}\n\t\t\t<schmancy-surface\n\t\t\t\t${ref(this._panelRef)}\n\t\t\t\tclass=\"portal-panel\"\n\t\t\t\ttype=${this.type}\n\t\t\t\tstyle=\"overflow-y: auto;\"\n\t\t\t>\n\t\t\t\t${!this._hideIndicator ? html`\n\t\t\t\t\t<button\n\t\t\t\t\t\t${ref(this._btnRef)}\n\t\t\t\t\t\tclass=\"minimize-btn\"\n\t\t\t\t\t\taria-label=\"Minimize\"\n\t\t\t\t\t\t@click=${() => this._owner?.close?.()}\n\t\t\t\t\t>\n\t\t\t\t\t\t<svg width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"none\" aria-hidden=\"true\">\n\t\t\t\t\t\t\t<path d=\"M19 9L12 16L5 9\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n\t\t\t\t\t\t</svg>\n\t\t\t\t\t</button>\n\t\t\t\t` : nothing}\n\t\t\t\t<slot></slot>\n\t\t\t</schmancy-surface>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-expand-root': SchmancyExpandRoot\n\t}\n}\n","import { css, html, nothing } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { createRef, ref } from 'lit/directives/ref.js'\nimport { styleMap } from 'lit/directives/style-map.js'\nimport { filter, fromEvent, lastValueFrom } from 'rxjs'\nimport { tap, takeUntil } from 'rxjs/operators'\nimport { TailwindElement } from '@mixins/index'\nimport { SPRING_SNAPPY } from '../utils/animation.js'\nimport { reducedMotion$ } from '../directives/reduced-motion'\nimport { SchmancyExpandRoot } from './expand-root.component.js'\n\n/** Dispatch this event on window to close whichever schmancy-expand is currently open */\nexport const SCHMANCY_EXPAND_REQUEST_CLOSE = 'schmancy-expand-request-close'\n\n@customElement('schmancy-expand')\nexport default class SchmancyExpand extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n\n\tsummary::-webkit-details-marker {\n\t\tdisplay: none;\n\t}\n\n\tsummary {\n\t\tlist-style: none;\n\t\tcolor: inherit;\n\t}\n\n\t.inline-grid {\n\t\tdisplay: grid;\n\t\tgrid-template-rows: 0fr;\n\t\toverflow: hidden;\n\t\ttransition: grid-template-rows 300ms cubic-bezier(0.22, 1.25, 0.36, 1),\n\t\t opacity 300ms cubic-bezier(0.22, 1.25, 0.36, 1);\n\t\topacity: 0;\n\t}\n\n\t.inline-grid[data-open] {\n\t\tgrid-template-rows: 1fr;\n\t\topacity: 1;\n\t}\n\n\t.inline-grid > .inner {\n\t\tmin-height: 0;\n\t\toverflow: hidden;\n\t}\n`) {\n\t@property() summary = ''\n\n\t@property({ type: Boolean, reflect: true }) open = false\n\n\t@property({ attribute: 'summary-padding' }) summaryPadding = ''\n\n\t@property({ attribute: 'content-padding' }) contentPadding = ''\n\n\t@property({ type: Boolean, attribute: 'hide-indicator' }) hideIndicator = false\n\n\t@property({ type: Number, attribute: 'indicator-rotate' }) indicatorRotate = 90\n\n\t@property({ type: Boolean }) backdrop = true\n\n\t@property({ type: Boolean }) inline = false\n\n\tprivate _summaryRef = createRef<HTMLElement>()\n\tprivate _contentSlotRef = createRef<HTMLSlotElement>()\n\tprivate _root: SchmancyExpandRoot | null = null\n\tprivate _movedNodes: Element[] = []\n\tprivate _currentIndicatorAnim: Animation | undefined\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\n\t\t// Close on Escape key\n\t\tfromEvent<KeyboardEvent>(window, 'keydown')\n\t\t\t.pipe(\n\t\t\t\tfilter(e => e.key === 'Escape'),\n\t\t\t\tfilter(() => this.open),\n\t\t\t\ttap(() => void this._handleClose()),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe()\n\n\t\t// Close on click outside the portal panel\n\t\tfromEvent<PointerEvent>(document, 'pointerdown')\n\t\t\t.pipe(\n\t\t\t\tfilter(() => this.open),\n\t\t\t\tfilter(e => !!this._root && !e.composedPath().includes(this._root)),\n\t\t\t\ttap(() => void this._handleClose()),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tdisconnectedCallback() {\n\t\tsuper.disconnectedCallback()\n\t\tif (this._movedNodes.length > 0) {\n\t\t\tthis._movedNodes.forEach(n => this.appendChild(n))\n\t\t\tthis._movedNodes = []\n\t\t}\n\t\tif (this._root && this._root.children.length === 0) {\n\t\t\tthis._root.remove()\n\t\t\tthis._root = null\n\t\t}\n\t}\n\n\tprivate async _getOrCreateRoot(): Promise<SchmancyExpandRoot> {\n\t\tconst theme = await lastValueFrom(this.discover<HTMLElement>('schmancy-theme'))\n\t\tconst container: HTMLElement = theme ?? document.querySelector('schmancy-theme') ?? document.body\n\t\tlet root = container.querySelector('schmancy-expand-root') as SchmancyExpandRoot | null\n\t\tif (!root) {\n\t\t\troot = new SchmancyExpandRoot()\n\t\t\tcontainer.appendChild(root)\n\t\t}\n\t\treturn root\n\t}\n\n\t/** Close the expand portal, animating back to the summary position. */\n\tpublic close(): void {\n\t\tvoid this._handleClose()\n\t}\n\n\t/** Programmatically open the expand portal. */\n\tpublic expand(): void {\n\t\tif (this.open) return\n\t\tvoid this._expand()\n\t}\n\n\tprotected override updated(changed: Map<PropertyKey, unknown>) {\n\t\tsuper.updated(changed)\n\t\tif (changed.has('open') && this.open && !this.inline && !this._root) {\n\t\t\tvoid this._expand()\n\t\t}\n\t}\n\n\tprivate _toggle() {\n\t\tif (this.inline) {\n\t\t\tthis.open = !this.open\n\t\t\tthis._animateIndicator(this.open)\n\t\t} else if (!this.open) {\n\t\t\tvoid this._expand()\n\t\t}\n\t}\n\n\tprivate _handleSummaryClick(e: MouseEvent) {\n\t\te.preventDefault()\n\t\tthis._toggle()\n\t}\n\n\tprivate async _expand() {\n\t\tif (this.inline) {\n\t\t\tthis.open = true\n\t\t\tthis._animateIndicator(true)\n\t\t\treturn\n\t\t}\n\n\t\tconst root = await this._getOrCreateRoot()\n\t\tthis._root = root\n\t\tconst summary = this._summaryRef.value\n\t\tconst contentSlot = this._contentSlotRef.value\n\t\tif (!summary || !contentSlot) return\n\n\t\tconst summaryRect = summary.getBoundingClientRect()\n\t\tconst nodes = contentSlot.assignedElements({ flatten: true })\n\t\tif (nodes.length === 0) return\n\n\t\troot.prepare(summaryRect, this, this.hideIndicator, this.backdrop)\n\n\t\tthis._movedNodes = [...nodes]\n\t\tthis._movedNodes.forEach(n => root.appendChild(n))\n\n\t\troot.triggerOpen()\n\n\t\tthis._animateIndicator(true)\n\t\tthis.open = true\n\t}\n\n\tasync _handleClose() {\n\t\tif (this.inline) {\n\t\t\tthis._animateIndicator(false)\n\t\t\tthis.open = false\n\t\t\treturn\n\t\t}\n\n\t\tconst root = this._root\n\t\tconst summary = this._summaryRef.value\n\t\tif (!root || !summary) return\n\n\t\tconst summaryRect = summary.getBoundingClientRect()\n\t\tthis._animateIndicator(false)\n\n\t\tawait root.triggerClose(summaryRect)\n\n\t\tthis._movedNodes.forEach(n => this.appendChild(n))\n\t\tthis._movedNodes = []\n\t\tthis.open = false\n\t}\n\n\tprivate _animateIndicator(isOpen: boolean) {\n\t\tif (reducedMotion$.value) return\n\n\t\tconst indicator = this.shadowRoot?.querySelector('.indicator') as HTMLElement | null\n\t\tif (!indicator) return\n\n\t\tthis._currentIndicatorAnim?.cancel()\n\t\tthis._currentIndicatorAnim = indicator.animate(\n\t\t\t[\n\t\t\t\t{ transform: `rotate(${isOpen ? '0deg' : `${this.indicatorRotate}deg`})` },\n\t\t\t\t{ transform: `rotate(${isOpen ? `${this.indicatorRotate}deg` : '0deg'})` },\n\t\t\t],\n\t\t\t{\n\t\t\t\tduration: SPRING_SNAPPY.duration,\n\t\t\t\teasing: SPRING_SNAPPY.easingFallback,\n\t\t\t\tfill: 'forwards',\n\t\t\t},\n\t\t)\n\t}\n\n\trender() {\n\t\tconst summaryClasses = this.classMap({\n\t\t\t[this.summaryPadding]: true,\n\t\t\t'select-none relative flex items-center gap-2 rounded-xl transition-all duration-150': true,\n\t\t\t'hover:brightness-[0.92] active:brightness-[0.85] cursor-pointer group': true,\n\t\t\t'flex-row-reverse': true,\n\t\t})\n\n\t\treturn html`\n\t\t\t<div class=\"w-full rounded-xl\">\n\t\t\t\t<div\n\t\t\t\t\t${ref(this._summaryRef)}\n\t\t\t\t\tclass=${summaryClasses}\n\t\t\t\t\ttabindex=\"0\"\n\t\t\t\t\trole=\"button\"\n\t\t\t\t\t@click=${this._handleSummaryClick}\n\t\t\t\t\t@keydown=${(e: KeyboardEvent) => {\n\t\t\t\t\t\tif (e.key === 'Enter' || e.key === ' ') {\n\t\t\t\t\t\t\te.preventDefault()\n\t\t\t\t\t\t\tthis._toggle()\n\t\t\t\t\t\t}\n\t\t\t\t\t}}\n\t\t\t\t>\n\t\t\t\t\t${!this.hideIndicator\n\t\t\t\t\t\t? html`\n\t\t\t\t\t\t\t\t<span class=\"indicator flex items-center justify-center w-5 h-5 rounded-full shrink-0 opacity-70 group-hover:opacity-100 will-change-transform\">\n\t\t\t\t\t\t\t\t\t<svg width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\" aria-hidden=\"true\">\n\t\t\t\t\t\t\t\t\t\t<path\n\t\t\t\t\t\t\t\t\t\t\td=\"M9 6L15 12L9 18\"\n\t\t\t\t\t\t\t\t\t\t\tstroke=\"currentColor\"\n\t\t\t\t\t\t\t\t\t\t\tstroke-width=\"2\"\n\t\t\t\t\t\t\t\t\t\t\tstroke-linecap=\"round\"\n\t\t\t\t\t\t\t\t\t\t\tstroke-linejoin=\"round\"\n\t\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t\t</svg>\n\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t`\n\t\t\t\t\t\t: nothing}\n\n\t\t\t\t\t<span class=\"flex-1 font-medium text-base min-w-0\">\n\t\t\t\t\t\t<slot name=\"summary\">${this.summary}</slot>\n\t\t\t\t\t</span>\n\n\t\t\t\t\t<slot name=\"actions\"></slot>\n\t\t\t\t</div>\n\n\t\t\t\t${this.inline\n\t\t\t\t\t? html`\n\t\t\t\t\t\t<div class=\"inline-grid\" ?data-open=${this.open}>\n\t\t\t\t\t\t\t<div class=\"inner\">\n\t\t\t\t\t\t\t\t<slot ${ref(this._contentSlotRef)}></slot>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t`\n\t\t\t\t\t: html`\n\t\t\t\t\t\t<div style=${styleMap(this.open ? {} : { display: 'none' })}>\n\t\t\t\t\t\t\t<slot ${ref(this._contentSlotRef)}></slot>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t`}\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-expand': SchmancyExpand\n\t}\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"expand-CUrWPZu-.js","names":[],"sources":["../src/expand/expand-root.component.ts","../src/expand/expand.component.ts"],"sourcesContent":["import { css, html, nothing } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { createRef, ref } from 'lit/directives/ref.js'\nimport { TailwindElement, SurfaceMixin } from '@mixins/index'\nimport type { TSurfaceColor } from '@schmancy/types'\nimport { SPRING_SMOOTH } from '../utils/animation.js'\nimport { reducedMotion$ } from '../directives/reduced-motion'\nimport '../surface/surface.js'\n\n@customElement('schmancy-expand-root')\nexport class SchmancyExpandRoot extends SurfaceMixin(TailwindElement(css`\n\t:host {\n\t\tdisplay: contents;\n\t}\n\n\t.portal-panel {\n\t\tposition: fixed;\n\t\ttransform-origin: top left;\n\t\twill-change: clip-path, opacity;\n\t\tborder-radius: 1rem;\n\t\tbox-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.5);\n\t\tz-index: 9999;\n\t}\n\n\t.minimize-btn {\n\t\tposition: absolute;\n\t\ttop: 0.5rem;\n\t\tright: 0.5rem;\n\t\tz-index: 1;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tjustify-content: center;\n\t\twidth: 2rem;\n\t\theight: 2rem;\n\t\tborder-radius: 9999px;\n\t\tborder: none;\n\t\tbackground: transparent;\n\t\tcursor: pointer;\n\t\topacity: 0.5;\n\t\ttransition: opacity 150ms, background 150ms;\n\t\tcolor: inherit;\n\t}\n\n\t.minimize-btn:hover {\n\t\topacity: 1;\n\t\tbackground: rgb(0 0 0 / 0.08);\n\t}\n`)) {\n\t@property({ reflect: true }) override type: TSurfaceColor = 'solid'\n\t@state() isOpen = false\n\tprivate summaryRect: DOMRect | null = null\n\n\tprivate _panelRef = createRef<HTMLElement>()\n\tprivate _backdropRef = createRef<HTMLDivElement>()\n\tprivate _btnRef = createRef<HTMLButtonElement>()\n\tprivate _owner: (Element & { close?: () => void }) | null = null\n\tprivate _hideIndicator = false\n\tprivate _backdrop = true\n\n\t/** Called by schmancy-expand before nodes are moved */\n\tprepare(rect: DOMRect, owner: Element, hideIndicator = false, backdrop = true) {\n\t\tthis.summaryRect = rect\n\t\tthis._owner = owner as Element & { close?: () => void }\n\t\tthis._hideIndicator = hideIndicator\n\t\tthis._backdrop = backdrop\n\t}\n\n\t/** Called by schmancy-expand after nodes are moved in */\n\tasync triggerOpen() {\n\t\tthis.isOpen = true\n\t\tawait this.updateComplete\n\n\t\tconst panel = this._panelRef.value\n\t\tif (!panel) return\n\n\t\tconst src = this.summaryRect!\n\n\t\t// 1. Anchor at summary's top-left, measure natural content size\n\t\t// Use nearly full viewport height for measurement so content near the bottom\n\t\t// of the screen isn't artificially capped — the positioning step will move the panel up.\n\t\tObject.assign(panel.style, {\n\t\t\tvisibility: 'hidden',\n\t\t\ttop: `${src.top}px`,\n\t\t\tleft: `${src.left}px`,\n\t\t\tminWidth: `${src.width}px`,\n\t\t\twidth: 'max-content',\n\t\t\tmaxWidth: `${window.innerWidth - src.left}px`,\n\t\t\theight: 'auto',\n\t\t\tmaxHeight: `${window.innerHeight - 32}px`,\n\t\t\toverflowY: 'auto',\n\t\t})\n\n\t\tconst measured = panel.getBoundingClientRect()\n\t\tconst finalW = measured.width\n\t\tconst finalH = measured.height\n\n\t\t// 2. Adjust position so panel stays within viewport\n\t\tlet finalTop = src.top\n\t\tlet finalLeft = src.left\n\t\tif (finalTop + finalH > window.innerHeight) {\n\t\t\tfinalTop = Math.max(0, src.bottom - finalH)\n\t\t}\n\t\tif (finalLeft + finalW > window.innerWidth) {\n\t\t\tfinalLeft = Math.max(0, window.innerWidth - finalW)\n\t\t}\n\n\t\t// 3. Compute clip-path insets — summary rect expressed relative to panel final position\n\t\t// These insets shrink the visible area down to exactly the summary box\n\t\tconst insetTop = Math.max(0, src.top - finalTop)\n\t\tconst insetLeft = Math.max(0, src.left - finalLeft)\n\t\tconst insetRight = Math.max(0, finalLeft + finalW - (src.left + src.width))\n\t\tconst insetBottom = Math.max(0, finalTop + finalH - (src.top + src.height))\n\n\t\t// 4. Place panel at final size + position, masked to summary bounds (no flash)\n\t\tObject.assign(panel.style, {\n\t\t\tvisibility: '',\n\t\t\ttop: `${finalTop}px`,\n\t\t\tleft: `${finalLeft}px`,\n\t\t\tminWidth: `${src.width}px`,\n\t\t\twidth: `${finalW}px`,\n\t\t\theight: `${finalH}px`,\n\t\t\tmaxWidth: '',\n\t\t\tmaxHeight: '',\n\t\t\tclipPath: `inset(${insetTop}px ${insetRight}px ${insetBottom}px ${insetLeft}px round 0.5rem)`,\n\t\t})\n\n\t\t// 5. Animate the mask open — content revealed, not stretched\n\t\tthis._animateOpen(insetTop, insetRight, insetBottom, insetLeft, finalTop)\n\t}\n\n\t/** Animate close, return Promise resolving when done */\n\tasync triggerClose(targetRect: DOMRect): Promise<void> {\n\t\tawait this._animateClose(targetRect)\n\t\tthis.isOpen = false\n\t\tthis.summaryRect = null\n\t}\n\n\tprivate _animateOpen(insetTop: number, insetRight: number, insetBottom: number, insetLeft: number, finalTop: number) {\n\t\tconst panel = this._panelRef.value\n\t\tif (!panel) return\n\n\t\tif (reducedMotion$.value) {\n\t\t\tpanel.style.clipPath = ''\n\t\t\treturn\n\t\t}\n\n\t\tconst backdrop = this._backdropRef.value\n\t\tif (backdrop) {\n\t\t\tbackdrop.animate([{ opacity: 0 }, { opacity: 1 }], {\n\t\t\t\tduration: SPRING_SMOOTH.duration,\n\t\t\t\teasing: SPRING_SMOOTH.easingFallback,\n\t\t\t\tfill: 'forwards',\n\t\t\t})\n\t\t}\n\n\t\tconst keyframes: Keyframe[] = [\n\t\t\t{\n\t\t\t\tclipPath: `inset(${insetTop}px ${insetRight}px ${insetBottom}px ${insetLeft}px round 0.5rem)`,\n\t\t\t\topacity: 0.9,\n\t\t\t},\n\t\t\t{\n\t\t\t\tclipPath: 'inset(0px 0px 0px 0px round 1rem)',\n\t\t\t\topacity: 1,\n\t\t\t},\n\t\t]\n\n\t\tconst anim = panel.animate(keyframes, {\n\t\t\tduration: SPRING_SMOOTH.duration,\n\t\t\teasing: SPRING_SMOOTH.easingFallback,\n\t\t\tfill: 'forwards',\n\t\t})\n\n\t\t// Clear clip-path and fixed dimensions after animation so content can grow naturally,\n\t\t// but cap at viewport height so overflow-y: auto can scroll\n\t\tanim.finished.then(() => {\n\t\t\tif (panel.isConnected) {\n\t\t\t\tpanel.style.clipPath = ''\n\t\t\t\tpanel.style.height = 'auto'\n\t\t\t\tpanel.style.maxHeight = `${window.innerHeight - finalTop - 16}px`\n\t\t\t}\n\t\t})\n\n\t\tconst btn = this._btnRef.value\n\t\tif (btn) {\n\t\t\tbtn.animate([{ transform: 'rotate(0deg)' }, { transform: 'rotate(180deg)' }], {\n\t\t\t\tduration: SPRING_SMOOTH.duration,\n\t\t\t\teasing: SPRING_SMOOTH.easingFallback,\n\t\t\t\tfill: 'forwards',\n\t\t\t})\n\t\t}\n\t}\n\n\tprivate _animateClose(targetRect: DOMRect): Promise<void> {\n\t\tconst panel = this._panelRef.value\n\t\tif (!panel) return Promise.resolve()\n\t\tif (reducedMotion$.value) return Promise.resolve()\n\n\t\t// Compute insets to mask panel back down to the summary box\n\t\tconst panelRect = panel.getBoundingClientRect()\n\t\tconst insetTop = Math.max(0, targetRect.top - panelRect.top)\n\t\tconst insetLeft = Math.max(0, targetRect.left - panelRect.left)\n\t\tconst insetRight = Math.max(0, panelRect.right - targetRect.right)\n\t\tconst insetBottom = Math.max(0, panelRect.bottom - targetRect.bottom)\n\n\t\tconst closeDuration = Math.round(SPRING_SMOOTH.duration * 0.4)\n\t\tconst closeEasing = 'cubic-bezier(0.4, 0, 1, 1)'\n\n\t\tconst closeKeyframes: Keyframe[] = [\n\t\t\t{ clipPath: 'inset(0px 0px 0px 0px round 1rem)', opacity: 1 },\n\t\t\t{\n\t\t\t\tclipPath: `inset(${insetTop}px ${insetRight}px ${insetBottom}px ${insetLeft}px round 0.5rem)`,\n\t\t\t\topacity: 0.6,\n\t\t\t},\n\t\t]\n\n\t\tconst anim = panel.animate(closeKeyframes, { duration: closeDuration, easing: closeEasing, fill: 'forwards' })\n\n\t\tconst backdrop = this._backdropRef.value\n\t\tif (backdrop) {\n\t\t\tbackdrop.animate([{ opacity: 1 }, { opacity: 0 }], {\n\t\t\t\tduration: closeDuration,\n\t\t\t\teasing: closeEasing,\n\t\t\t\tfill: 'forwards',\n\t\t\t})\n\t\t}\n\n\t\tconst btn = this._btnRef.value\n\t\tif (btn) {\n\t\t\tbtn.animate([{ transform: 'rotate(180deg)' }, { transform: 'rotate(0deg)' }], {\n\t\t\t\tduration: closeDuration,\n\t\t\t\teasing: closeEasing,\n\t\t\t\tfill: 'forwards',\n\t\t\t})\n\t\t}\n\n\t\treturn anim.finished as unknown as Promise<void>\n\t}\n\n\trender() {\n\t\tif (!this.isOpen) return nothing\n\n\t\treturn html`\n\t\t\t${this._backdrop ? html`\n\t\t\t\t<div\n\t\t\t\t\t${ref(this._backdropRef)}\n\t\t\t\t\tclass=\"fixed inset-0 z-9998 backdrop-blur-sm backdrop-saturate-150 backdrop-brightness-105 bg-black/[0.07] will-change-[opacity]\"\n\t\t\t\t\t@click=${() => this._owner?.close?.()}\n\t\t\t\t></div>\n\t\t\t` : nothing}\n\t\t\t<schmancy-surface\n\t\t\t\t${ref(this._panelRef)}\n\t\t\t\tclass=\"portal-panel\"\n\t\t\t\ttype=${this.type}\n\t\t\t\tstyle=\"overflow-y: auto;\"\n\t\t\t>\n\t\t\t\t${!this._hideIndicator ? html`\n\t\t\t\t\t<button\n\t\t\t\t\t\t${ref(this._btnRef)}\n\t\t\t\t\t\tclass=\"minimize-btn\"\n\t\t\t\t\t\taria-label=\"Minimize\"\n\t\t\t\t\t\t@click=${() => this._owner?.close?.()}\n\t\t\t\t\t>\n\t\t\t\t\t\t<svg width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"none\" aria-hidden=\"true\">\n\t\t\t\t\t\t\t<path d=\"M19 9L12 16L5 9\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n\t\t\t\t\t\t</svg>\n\t\t\t\t\t</button>\n\t\t\t\t` : nothing}\n\t\t\t\t<slot></slot>\n\t\t\t</schmancy-surface>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-expand-root': SchmancyExpandRoot\n\t}\n}\n","import { css, html, nothing } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { createRef, ref } from 'lit/directives/ref.js'\nimport { styleMap } from 'lit/directives/style-map.js'\nimport { filter, fromEvent, lastValueFrom } from 'rxjs'\nimport { tap, takeUntil } from 'rxjs/operators'\nimport { TailwindElement } from '@mixins/index'\nimport { SPRING_SNAPPY } from '../utils/animation.js'\nimport { reducedMotion$ } from '../directives/reduced-motion'\nimport { SchmancyExpandRoot } from './expand-root.component.js'\n\n/** Dispatch this event on window to close whichever schmancy-expand is currently open */\nexport const SCHMANCY_EXPAND_REQUEST_CLOSE = 'schmancy-expand-request-close'\n\n@customElement('schmancy-expand')\nexport default class SchmancyExpand extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n\n\tsummary::-webkit-details-marker {\n\t\tdisplay: none;\n\t}\n\n\tsummary {\n\t\tlist-style: none;\n\t\tcolor: inherit;\n\t}\n\n\t.inline-grid {\n\t\tdisplay: grid;\n\t\tgrid-template-rows: 0fr;\n\t\toverflow: hidden;\n\t\ttransition: grid-template-rows 300ms cubic-bezier(0.22, 1.25, 0.36, 1),\n\t\t opacity 300ms cubic-bezier(0.22, 1.25, 0.36, 1);\n\t\topacity: 0;\n\t}\n\n\t.inline-grid[data-open] {\n\t\tgrid-template-rows: 1fr;\n\t\topacity: 1;\n\t}\n\n\t.inline-grid > .inner {\n\t\tmin-height: 0;\n\t\toverflow: hidden;\n\t}\n`) {\n\t@property() summary = ''\n\n\t@property({ type: Boolean, reflect: true }) open = false\n\n\t@property({ attribute: 'summary-padding' }) summaryPadding = ''\n\n\t@property({ attribute: 'content-padding' }) contentPadding = ''\n\n\t@property({ type: Boolean, attribute: 'hide-indicator' }) hideIndicator = false\n\n\t@property({ type: Number, attribute: 'indicator-rotate' }) indicatorRotate = 90\n\n\t@property({ type: Boolean }) backdrop = true\n\n\t@property({ type: Boolean }) inline = false\n\n\tprivate _summaryRef = createRef<HTMLElement>()\n\tprivate _contentSlotRef = createRef<HTMLSlotElement>()\n\tprivate _root: SchmancyExpandRoot | null = null\n\tprivate _movedNodes: Element[] = []\n\tprivate _currentIndicatorAnim: Animation | undefined\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\n\t\t// Close on Escape key\n\t\tfromEvent<KeyboardEvent>(window, 'keydown')\n\t\t\t.pipe(\n\t\t\t\tfilter(e => e.key === 'Escape'),\n\t\t\t\tfilter(() => this.open),\n\t\t\t\ttap(() => void this._handleClose()),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe()\n\n\t\t// Close on click outside the portal panel\n\t\tfromEvent<PointerEvent>(document, 'pointerdown')\n\t\t\t.pipe(\n\t\t\t\tfilter(() => this.open),\n\t\t\t\tfilter(e => !!this._root && !e.composedPath().includes(this._root)),\n\t\t\t\ttap(() => void this._handleClose()),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tdisconnectedCallback() {\n\t\tsuper.disconnectedCallback()\n\t\tif (this._movedNodes.length > 0) {\n\t\t\tthis._movedNodes.forEach(n => this.appendChild(n))\n\t\t\tthis._movedNodes = []\n\t\t}\n\t\tif (this._root && this._root.children.length === 0) {\n\t\t\tthis._root.remove()\n\t\t\tthis._root = null\n\t\t}\n\t}\n\n\tprivate async _getOrCreateRoot(): Promise<SchmancyExpandRoot> {\n\t\tconst theme = await lastValueFrom(this.discover<HTMLElement>('schmancy-theme'))\n\t\tconst container: HTMLElement = theme ?? document.querySelector('schmancy-theme') ?? document.body\n\t\tlet root = container.querySelector('schmancy-expand-root') as SchmancyExpandRoot | null\n\t\tif (!root) {\n\t\t\troot = new SchmancyExpandRoot()\n\t\t\tcontainer.appendChild(root)\n\t\t}\n\t\treturn root\n\t}\n\n\t/** Close the expand portal, animating back to the summary position. */\n\tpublic close(): void {\n\t\tvoid this._handleClose()\n\t}\n\n\t/** Programmatically open the expand portal. */\n\tpublic expand(): void {\n\t\tif (this.open) return\n\t\tvoid this._expand()\n\t}\n\n\tprotected override updated(changed: Map<PropertyKey, unknown>) {\n\t\tsuper.updated(changed)\n\t\tif (changed.has('open') && this.open && !this.inline && !this._root) {\n\t\t\tvoid this._expand()\n\t\t}\n\t}\n\n\tprivate _toggle() {\n\t\tif (this.inline) {\n\t\t\tthis.open = !this.open\n\t\t\tthis._animateIndicator(this.open)\n\t\t} else if (!this.open) {\n\t\t\tvoid this._expand()\n\t\t}\n\t}\n\n\tprivate _handleSummaryClick(e: MouseEvent) {\n\t\te.preventDefault()\n\t\tthis._toggle()\n\t}\n\n\tprivate async _expand() {\n\t\tif (this.inline) {\n\t\t\tthis.open = true\n\t\t\tthis._animateIndicator(true)\n\t\t\treturn\n\t\t}\n\n\t\tconst root = await this._getOrCreateRoot()\n\t\tthis._root = root\n\t\tconst summary = this._summaryRef.value\n\t\tconst contentSlot = this._contentSlotRef.value\n\t\tif (!summary || !contentSlot) return\n\n\t\tconst summaryRect = summary.getBoundingClientRect()\n\t\tconst nodes = contentSlot.assignedElements({ flatten: true })\n\t\tif (nodes.length === 0) return\n\n\t\troot.prepare(summaryRect, this, this.hideIndicator, this.backdrop)\n\n\t\tthis._movedNodes = [...nodes]\n\t\tthis._movedNodes.forEach(n => root.appendChild(n))\n\n\t\troot.triggerOpen()\n\n\t\tthis._animateIndicator(true)\n\t\tthis.open = true\n\t}\n\n\tasync _handleClose() {\n\t\tif (this.inline) {\n\t\t\tthis._animateIndicator(false)\n\t\t\tthis.open = false\n\t\t\treturn\n\t\t}\n\n\t\tconst root = this._root\n\t\tconst summary = this._summaryRef.value\n\t\tif (!root || !summary) return\n\n\t\tconst summaryRect = summary.getBoundingClientRect()\n\t\tthis._animateIndicator(false)\n\n\t\tawait root.triggerClose(summaryRect)\n\n\t\tthis._movedNodes.forEach(n => this.appendChild(n))\n\t\tthis._movedNodes = []\n\t\tthis.open = false\n\t}\n\n\tprivate _animateIndicator(isOpen: boolean) {\n\t\tif (reducedMotion$.value) return\n\n\t\tconst indicator = this.shadowRoot?.querySelector('.indicator') as HTMLElement | null\n\t\tif (!indicator) return\n\n\t\tthis._currentIndicatorAnim?.cancel()\n\t\tthis._currentIndicatorAnim = indicator.animate(\n\t\t\t[\n\t\t\t\t{ transform: `rotate(${isOpen ? '0deg' : `${this.indicatorRotate}deg`})` },\n\t\t\t\t{ transform: `rotate(${isOpen ? `${this.indicatorRotate}deg` : '0deg'})` },\n\t\t\t],\n\t\t\t{\n\t\t\t\tduration: SPRING_SNAPPY.duration,\n\t\t\t\teasing: SPRING_SNAPPY.easingFallback,\n\t\t\t\tfill: 'forwards',\n\t\t\t},\n\t\t)\n\t}\n\n\trender() {\n\t\tconst summaryClasses = this.classMap({\n\t\t\t[this.summaryPadding]: true,\n\t\t\t'select-none relative flex items-center gap-2 rounded-xl transition-all duration-150': true,\n\t\t\t'hover:brightness-[0.92] active:brightness-[0.85] cursor-pointer group': true,\n\t\t\t'flex-row-reverse': true,\n\t\t})\n\n\t\treturn html`\n\t\t\t<div class=\"w-full rounded-xl\">\n\t\t\t\t<div\n\t\t\t\t\t${ref(this._summaryRef)}\n\t\t\t\t\tclass=${summaryClasses}\n\t\t\t\t\ttabindex=\"0\"\n\t\t\t\t\trole=\"button\"\n\t\t\t\t\t@click=${this._handleSummaryClick}\n\t\t\t\t\t@keydown=${(e: KeyboardEvent) => {\n\t\t\t\t\t\tif (e.key === 'Enter' || e.key === ' ') {\n\t\t\t\t\t\t\te.preventDefault()\n\t\t\t\t\t\t\tthis._toggle()\n\t\t\t\t\t\t}\n\t\t\t\t\t}}\n\t\t\t\t>\n\t\t\t\t\t${!this.hideIndicator\n\t\t\t\t\t\t? html`\n\t\t\t\t\t\t\t\t<span class=\"indicator flex items-center justify-center w-5 h-5 rounded-full shrink-0 opacity-70 group-hover:opacity-100 will-change-transform\">\n\t\t\t\t\t\t\t\t\t<svg width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\" aria-hidden=\"true\">\n\t\t\t\t\t\t\t\t\t\t<path\n\t\t\t\t\t\t\t\t\t\t\td=\"M9 6L15 12L9 18\"\n\t\t\t\t\t\t\t\t\t\t\tstroke=\"currentColor\"\n\t\t\t\t\t\t\t\t\t\t\tstroke-width=\"2\"\n\t\t\t\t\t\t\t\t\t\t\tstroke-linecap=\"round\"\n\t\t\t\t\t\t\t\t\t\t\tstroke-linejoin=\"round\"\n\t\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t\t</svg>\n\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t`\n\t\t\t\t\t\t: nothing}\n\n\t\t\t\t\t<span class=\"flex-1 font-medium text-base min-w-0\">\n\t\t\t\t\t\t<slot name=\"summary\">${this.summary}</slot>\n\t\t\t\t\t</span>\n\n\t\t\t\t\t<slot name=\"actions\"></slot>\n\t\t\t\t</div>\n\n\t\t\t\t${this.inline\n\t\t\t\t\t? html`\n\t\t\t\t\t\t<div class=\"inline-grid\" ?data-open=${this.open}>\n\t\t\t\t\t\t\t<div class=\"inner\">\n\t\t\t\t\t\t\t\t<slot ${ref(this._contentSlotRef)}></slot>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t`\n\t\t\t\t\t: html`\n\t\t\t\t\t\t<div style=${styleMap(this.open ? {} : { display: 'none' })}>\n\t\t\t\t\t\t\t<slot ${ref(this._contentSlotRef)}></slot>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t`}\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-expand': SchmancyExpand\n\t}\n}\n"],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
require(`./chunk-BCfY8kxB.cjs`);const e=require(`./tailwind.mixin-
|
|
1
|
+
require(`./chunk-BCfY8kxB.cjs`);const e=require(`./tailwind.mixin-Bug3G6K6.cjs`),t=require(`./decorate-F9CuyeHg.cjs`),n=require(`./surface.mixin-CSKqQH-0.cjs`);require(`./mixins.cjs`);const r=require(`./animation-Bcwh107v.cjs`),i=require(`./reduced-motion-DR32yKEO.cjs`);require(`./surface-C9plkl5F.cjs`);let a=require(`rxjs`),o=require(`rxjs/operators`),s=require(`lit/directives/style-map.js`),c=require(`lit/decorators.js`),l=require(`lit`),u=require(`lit/directives/ref.js`);var d=class extends n.t(e.t(l.css`
|
|
2
2
|
:host {
|
|
3
3
|
display: contents;
|
|
4
4
|
}
|