@mhmo91/schmancy 0.2.199 → 0.2.200

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (280) hide show
  1. package/dist/_commonjsHelpers-Dw9sPFZy.js +7 -0
  2. package/dist/_commonjsHelpers-Dw9sPFZy.js.map +1 -0
  3. package/dist/_commonjsHelpers-k2hpEU-q.cjs +2 -0
  4. package/dist/_commonjsHelpers-k2hpEU-q.cjs.map +1 -0
  5. package/dist/{animated-text-Cb07SP6h.js → animated-text-BZWvzqEZ.js} +3 -3
  6. package/dist/{animated-text-Cb07SP6h.js.map → animated-text-BZWvzqEZ.js.map} +1 -1
  7. package/dist/{animated-text-DML1qmmR.cjs → animated-text-BgLktXr-.cjs} +2 -2
  8. package/dist/{animated-text-DML1qmmR.cjs.map → animated-text-BgLktXr-.cjs.map} +1 -1
  9. package/dist/animated-text.cjs +1 -1
  10. package/dist/animated-text.js +1 -1
  11. package/dist/area.cjs +1 -1
  12. package/dist/{area.component-Psgv50Lq.cjs → area.component-CqKoQRDp.cjs} +2 -2
  13. package/dist/{area.component-Psgv50Lq.cjs.map → area.component-CqKoQRDp.cjs.map} +1 -1
  14. package/dist/{area.component-CdFovqHE.js → area.component-zvrF1R-P.js} +3 -3
  15. package/dist/{area.component-CdFovqHE.js.map → area.component-zvrF1R-P.js.map} +1 -1
  16. package/dist/area.js +1 -1
  17. package/dist/{autocomplete-B4F-i4IH.cjs → autocomplete-BCE9oBkO.cjs} +2 -2
  18. package/dist/{autocomplete-B4F-i4IH.cjs.map → autocomplete-BCE9oBkO.cjs.map} +1 -1
  19. package/dist/{autocomplete-87RcHRRv.js → autocomplete-CpYDECg0.js} +3 -3
  20. package/dist/{autocomplete-87RcHRRv.js.map → autocomplete-CpYDECg0.js.map} +1 -1
  21. package/dist/autocomplete.cjs +1 -1
  22. package/dist/autocomplete.js +1 -1
  23. package/dist/{avatar-Dx-kdZaM.js → avatar-B_BubJYb.js} +46 -45
  24. package/dist/{avatar-Dx-kdZaM.js.map → avatar-B_BubJYb.js.map} +1 -1
  25. package/dist/{avatar-DI6tP5aD.cjs → avatar-B_y2vLrR.cjs} +2 -2
  26. package/dist/{avatar-DI6tP5aD.cjs.map → avatar-B_y2vLrR.cjs.map} +1 -1
  27. package/dist/badge.cjs +1 -1
  28. package/dist/badge.js +1 -1
  29. package/dist/busy.cjs +1 -1
  30. package/dist/busy.js +1 -1
  31. package/dist/button.cjs +1 -1
  32. package/dist/button.js +1 -1
  33. package/dist/card.cjs +1 -1
  34. package/dist/card.js +1 -1
  35. package/dist/{checkbox-Cntlr_eV.js → checkbox-CJ6x-G_b.js} +2 -2
  36. package/dist/{checkbox-Cntlr_eV.js.map → checkbox-CJ6x-G_b.js.map} +1 -1
  37. package/dist/{checkbox-C80YxaCN.cjs → checkbox-DATn1US_.cjs} +2 -2
  38. package/dist/{checkbox-C80YxaCN.cjs.map → checkbox-DATn1US_.cjs.map} +1 -1
  39. package/dist/checkbox.cjs +1 -1
  40. package/dist/checkbox.js +1 -1
  41. package/dist/{chips-CI-fsAqX.cjs → chips-BbWIMKDU.cjs} +2 -2
  42. package/dist/{chips-CI-fsAqX.cjs.map → chips-BbWIMKDU.cjs.map} +1 -1
  43. package/dist/{chips-vMtInVGX.js → chips-CcT1N7--.js} +9 -9
  44. package/dist/{chips-vMtInVGX.js.map → chips-CcT1N7--.js.map} +1 -1
  45. package/dist/chips.cjs +1 -1
  46. package/dist/chips.js +1 -1
  47. package/dist/{circular-progress-8LR4RVjD.js → circular-progress-Cs3G6PHo.js} +3 -3
  48. package/dist/{circular-progress-8LR4RVjD.js.map → circular-progress-Cs3G6PHo.js.map} +1 -1
  49. package/dist/{circular-progress-CSWSAcU6.cjs → circular-progress-JGc2_9ef.cjs} +2 -2
  50. package/dist/{circular-progress-CSWSAcU6.cjs.map → circular-progress-JGc2_9ef.cjs.map} +1 -1
  51. package/dist/circular-progress.cjs +1 -1
  52. package/dist/circular-progress.js +1 -1
  53. package/dist/code-highlight.cjs +2 -0
  54. package/dist/code-highlight.cjs.map +1 -0
  55. package/dist/code-highlight.js +7 -0
  56. package/dist/code-highlight.js.map +1 -0
  57. package/dist/code-preview-BZ-uk6y1.js +876 -0
  58. package/dist/code-preview-BZ-uk6y1.js.map +1 -0
  59. package/dist/code-preview-DXf_SN2X.cjs +133 -0
  60. package/dist/code-preview-DXf_SN2X.cjs.map +1 -0
  61. package/dist/components.cjs +1 -1
  62. package/dist/components.js +1 -1
  63. package/dist/content-drawer.cjs +1 -1
  64. package/dist/content-drawer.js +1 -1
  65. package/dist/date-range-D85imfq-.cjs +121 -0
  66. package/dist/{date-range-BkVCslGl.cjs.map → date-range-D85imfq-.cjs.map} +1 -1
  67. package/dist/{date-range-ChsdVWRV.js → date-range-Dt9V5MyB.js} +62 -64
  68. package/dist/{date-range-ChsdVWRV.js.map → date-range-Dt9V5MyB.js.map} +1 -1
  69. package/dist/date-range.cjs +1 -1
  70. package/dist/date-range.js +1 -1
  71. package/dist/{delay-D6UmIwSa.cjs → delay-BH-y0tJg.cjs} +2 -2
  72. package/dist/{delay-D6UmIwSa.cjs.map → delay-BH-y0tJg.cjs.map} +1 -1
  73. package/dist/{delay-DJMIbnvL.js → delay-CE3iPMYG.js} +11 -11
  74. package/dist/{delay-DJMIbnvL.js.map → delay-CE3iPMYG.js.map} +1 -1
  75. package/dist/delay.cjs +1 -1
  76. package/dist/delay.js +1 -1
  77. package/dist/{dialog-content-Cw1Al_Re.cjs → dialog-content-BQN75NSZ.cjs} +2 -2
  78. package/dist/{dialog-content-Cw1Al_Re.cjs.map → dialog-content-BQN75NSZ.cjs.map} +1 -1
  79. package/dist/{dialog-content-CWvxqVsr.js → dialog-content-E5R1XfK5.js} +3 -3
  80. package/dist/{dialog-content-CWvxqVsr.js.map → dialog-content-E5R1XfK5.js.map} +1 -1
  81. package/dist/dialog.cjs +1 -1
  82. package/dist/dialog.js +1 -1
  83. package/dist/{divider-Cp6EXlTN.cjs → divider-BEtL0P-_.cjs} +2 -2
  84. package/dist/{divider-Cp6EXlTN.cjs.map → divider-BEtL0P-_.cjs.map} +1 -1
  85. package/dist/{divider-BGo7hglJ.js → divider-BlSi0WWi.js} +3 -3
  86. package/dist/{divider-BGo7hglJ.js.map → divider-BlSi0WWi.js.map} +1 -1
  87. package/dist/divider.cjs +1 -1
  88. package/dist/divider.js +1 -1
  89. package/dist/{dropdown-content-CTWWDRgy.js → dropdown-content-DkKciM_R.js} +3 -3
  90. package/dist/{dropdown-content-CTWWDRgy.js.map → dropdown-content-DkKciM_R.js.map} +1 -1
  91. package/dist/{dropdown-content-CmCumNjC.cjs → dropdown-content-HRI7Jkak.cjs} +2 -2
  92. package/dist/{dropdown-content-CmCumNjC.cjs.map → dropdown-content-HRI7Jkak.cjs.map} +1 -1
  93. package/dist/dropdown.cjs +1 -1
  94. package/dist/dropdown.js +1 -1
  95. package/dist/extra.cjs +1 -1
  96. package/dist/extra.js +1 -1
  97. package/dist/{flex-Dyfn6mxF.cjs → flex-CwTn3AfA.cjs} +2 -2
  98. package/dist/{flex-Dyfn6mxF.cjs.map → flex-CwTn3AfA.cjs.map} +1 -1
  99. package/dist/{flex-CKtJkkxU.js → flex-DHA02Mfw.js} +2 -2
  100. package/dist/{flex-CKtJkkxU.js.map → flex-DHA02Mfw.js.map} +1 -1
  101. package/dist/{form-BbQRONBu.cjs → form-C9llOgOw.cjs} +2 -2
  102. package/dist/{form-BbQRONBu.cjs.map → form-C9llOgOw.cjs.map} +1 -1
  103. package/dist/{form-BZdw3XUt.js → form-DsprWndI.js} +2 -2
  104. package/dist/{form-BZdw3XUt.js.map → form-DsprWndI.js.map} +1 -1
  105. package/dist/form.cjs +1 -1
  106. package/dist/form.js +1 -1
  107. package/dist/{icon-CNkK3oMH.cjs → icon-B1vaqlkD.cjs} +2 -2
  108. package/dist/icon-B1vaqlkD.cjs.map +1 -0
  109. package/dist/{icon-PZTHZSsC.js → icon-D967cxey.js} +2 -3
  110. package/dist/icon-D967cxey.js.map +1 -0
  111. package/dist/{icon-button-5_uidIo2.js → icon-button-C_OqjQfc.js} +3 -3
  112. package/dist/{icon-button-5_uidIo2.js.map → icon-button-C_OqjQfc.js.map} +1 -1
  113. package/dist/{icon-button-L6UzTqIn.cjs → icon-button-D6RzSEQb.cjs} +2 -2
  114. package/dist/{icon-button-L6UzTqIn.cjs.map → icon-button-D6RzSEQb.cjs.map} +1 -1
  115. package/dist/icons.cjs +1 -1
  116. package/dist/icons.js +1 -1
  117. package/dist/index.cjs +1 -1
  118. package/dist/index.js +156 -152
  119. package/dist/index.js.map +1 -1
  120. package/dist/{input-cvO-mD1t.js → input-4heVsnGw.js} +2 -2
  121. package/dist/{input-cvO-mD1t.js.map → input-4heVsnGw.js.map} +1 -1
  122. package/dist/{input-GETorvfT.cjs → input-DschQCBp.cjs} +2 -2
  123. package/dist/{input-GETorvfT.cjs.map → input-DschQCBp.cjs.map} +1 -1
  124. package/dist/input.cjs +1 -1
  125. package/dist/input.js +1 -1
  126. package/dist/layout.cjs +1 -1
  127. package/dist/layout.js +1 -1
  128. package/dist/{list-BPQwn2ZD.cjs → list-B1bxSmd5.cjs} +2 -2
  129. package/dist/{list-BPQwn2ZD.cjs.map → list-B1bxSmd5.cjs.map} +1 -1
  130. package/dist/{list-CjVW-XS-.js → list-DE1otSG3.js} +2 -2
  131. package/dist/{list-CjVW-XS-.js.map → list-DE1otSG3.js.map} +1 -1
  132. package/dist/list.cjs +1 -1
  133. package/dist/list.js +1 -1
  134. package/dist/{litElement.mixin-BKgKxczr.js → litElement.mixin-1-y-wwQg.js} +2 -2
  135. package/dist/{litElement.mixin-BKgKxczr.js.map → litElement.mixin-1-y-wwQg.js.map} +1 -1
  136. package/dist/{litElement.mixin-0pIFA8ru.cjs → litElement.mixin-CB6DWbFn.cjs} +2 -2
  137. package/dist/{litElement.mixin-0pIFA8ru.cjs.map → litElement.mixin-CB6DWbFn.cjs.map} +1 -1
  138. package/dist/{menu-Bj9xX6Hn.js → menu-B1qPlV2t.js} +3 -3
  139. package/dist/{menu-Bj9xX6Hn.js.map → menu-B1qPlV2t.js.map} +1 -1
  140. package/dist/{menu-BpjaKAXC.cjs → menu-TDH53RmV.cjs} +2 -2
  141. package/dist/{menu-BpjaKAXC.cjs.map → menu-TDH53RmV.cjs.map} +1 -1
  142. package/dist/menu.cjs +1 -1
  143. package/dist/menu.js +1 -1
  144. package/dist/nav-drawer.cjs +1 -1
  145. package/dist/nav-drawer.js +1 -1
  146. package/dist/{notification-service-BFAKagab.cjs → notification-service-BKSRwonz.cjs} +2 -2
  147. package/dist/{notification-service-BFAKagab.cjs.map → notification-service-BKSRwonz.cjs.map} +1 -1
  148. package/dist/{notification-service-ITb5rmvM.js → notification-service-D2pgTqTS.js} +3 -3
  149. package/dist/{notification-service-ITb5rmvM.js.map → notification-service-D2pgTqTS.js.map} +1 -1
  150. package/dist/notification.cjs +1 -1
  151. package/dist/notification.js +1 -1
  152. package/dist/{option-_DZj4_on.js → option-CLY6hO5V.js} +2 -2
  153. package/dist/{option-_DZj4_on.js.map → option-CLY6hO5V.js.map} +1 -1
  154. package/dist/{option-vszqrPbH.cjs → option-Q6l-t3es.cjs} +2 -2
  155. package/dist/{option-vszqrPbH.cjs.map → option-Q6l-t3es.cjs.map} +1 -1
  156. package/dist/option.cjs +1 -1
  157. package/dist/option.js +1 -1
  158. package/dist/{payment-card-form-CxhMa60Q.js → payment-card-form-BpaCnjrt.js} +3 -3
  159. package/dist/{payment-card-form-CxhMa60Q.js.map → payment-card-form-BpaCnjrt.js.map} +1 -1
  160. package/dist/{payment-card-form-DgFUnANa.cjs → payment-card-form-V5eIamA9.cjs} +2 -2
  161. package/dist/{payment-card-form-DgFUnANa.cjs.map → payment-card-form-V5eIamA9.cjs.map} +1 -1
  162. package/dist/{radio-button-svaVfPn8.js → radio-button-CuTpkLr8.js} +2 -2
  163. package/dist/{radio-button-svaVfPn8.js.map → radio-button-CuTpkLr8.js.map} +1 -1
  164. package/dist/{radio-button-ChM1WZDg.cjs → radio-button-Dm2I9Ic4.cjs} +2 -2
  165. package/dist/{radio-button-ChM1WZDg.cjs.map → radio-button-Dm2I9Ic4.cjs.map} +1 -1
  166. package/dist/radio-group.cjs +1 -1
  167. package/dist/radio-group.js +1 -1
  168. package/dist/{schmancy-steps-container-C_-PFkRy.cjs → schmancy-steps-container-DO4tx0KH.cjs} +2 -2
  169. package/dist/{schmancy-steps-container-C_-PFkRy.cjs.map → schmancy-steps-container-DO4tx0KH.cjs.map} +1 -1
  170. package/dist/{schmancy-steps-container-9fHGNLHd.js → schmancy-steps-container-SrnYbTe-.js} +2 -2
  171. package/dist/{schmancy-steps-container-9fHGNLHd.js.map → schmancy-steps-container-SrnYbTe-.js.map} +1 -1
  172. package/dist/{select-DEd1YJF0.cjs → select-BJdRm5US.cjs} +2 -2
  173. package/dist/{select-DEd1YJF0.cjs.map → select-BJdRm5US.cjs.map} +1 -1
  174. package/dist/{select-CWulYSxd.js → select-DfemPf0w.js} +3 -3
  175. package/dist/{select-CWulYSxd.js.map → select-DfemPf0w.js.map} +1 -1
  176. package/dist/select.cjs +1 -1
  177. package/dist/select.js +1 -1
  178. package/dist/{sheet-BhKQmvCN.cjs → sheet-BtaT1eui.cjs} +2 -2
  179. package/dist/{sheet-BhKQmvCN.cjs.map → sheet-BtaT1eui.cjs.map} +1 -1
  180. package/dist/{sheet-C2f1XwT3.js → sheet-Bvj7tapP.js} +3 -3
  181. package/dist/{sheet-C2f1XwT3.js.map → sheet-Bvj7tapP.js.map} +1 -1
  182. package/dist/sheet.cjs +1 -1
  183. package/dist/sheet.js +1 -1
  184. package/dist/{slider-CetPyN3J.cjs → slider-AQvRuZ-m.cjs} +2 -2
  185. package/dist/{slider-CetPyN3J.cjs.map → slider-AQvRuZ-m.cjs.map} +1 -1
  186. package/dist/{slider-CmJGqDDU.js → slider-DAwHA6Az.js} +3 -3
  187. package/dist/{slider-CmJGqDDU.js.map → slider-DAwHA6Az.js.map} +1 -1
  188. package/dist/slider.cjs +1 -1
  189. package/dist/slider.js +1 -1
  190. package/dist/{spinner-CLfAy0cd.cjs → spinner-BLy3-lqb.cjs} +2 -2
  191. package/dist/{spinner-CLfAy0cd.cjs.map → spinner-BLy3-lqb.cjs.map} +1 -1
  192. package/dist/{spinner-CmJk8fIO.js → spinner-DrZuae0L.js} +3 -3
  193. package/dist/{spinner-CmJk8fIO.js.map → spinner-DrZuae0L.js.map} +1 -1
  194. package/dist/steps.cjs +1 -1
  195. package/dist/steps.js +1 -1
  196. package/dist/{surface-ChxX03-I.cjs → surface-BOerTano.cjs} +2 -2
  197. package/dist/{surface-ChxX03-I.cjs.map → surface-BOerTano.cjs.map} +1 -1
  198. package/dist/{surface-BnlEKr-d.js → surface-CAlEVfSs.js} +2 -2
  199. package/dist/{surface-BnlEKr-d.js.map → surface-CAlEVfSs.js.map} +1 -1
  200. package/dist/surface.cjs +1 -1
  201. package/dist/surface.js +1 -1
  202. package/dist/{table-CzD7rJ5o.cjs → table-B3VrNQUV.cjs} +2 -2
  203. package/dist/{table-CzD7rJ5o.cjs.map → table-B3VrNQUV.cjs.map} +1 -1
  204. package/dist/{table-CZJ14ZEI.js → table-hjsAGpRq.js} +2 -2
  205. package/dist/{table-CZJ14ZEI.js.map → table-hjsAGpRq.js.map} +1 -1
  206. package/dist/table.cjs +1 -1
  207. package/dist/table.js +1 -1
  208. package/dist/{tabs-compatibility-DHkghYmL.js → tabs-compatibility-D9ajXdXz.js} +2 -2
  209. package/dist/{tabs-compatibility-DHkghYmL.js.map → tabs-compatibility-D9ajXdXz.js.map} +1 -1
  210. package/dist/{tabs-compatibility-BviE0FdA.cjs → tabs-compatibility-DdXO8DcF.cjs} +2 -2
  211. package/dist/{tabs-compatibility-BviE0FdA.cjs.map → tabs-compatibility-DdXO8DcF.cjs.map} +1 -1
  212. package/dist/tabs.cjs +1 -1
  213. package/dist/tabs.js +1 -1
  214. package/dist/tailwind.mixin-DPUboU_5.js +43 -0
  215. package/dist/{tailwind.mixin-k9HTphsu.js.map → tailwind.mixin-DPUboU_5.js.map} +1 -1
  216. package/dist/tailwind.mixin-mxyACxyp.cjs +2 -0
  217. package/dist/{tailwind.mixin-DFxMrwgk.cjs.map → tailwind.mixin-mxyACxyp.cjs.map} +1 -1
  218. package/dist/teleport.cjs +1 -1
  219. package/dist/teleport.js +1 -1
  220. package/dist/{textarea-qNzKErHX.cjs → textarea-C16vg4ME.cjs} +2 -2
  221. package/dist/{textarea-qNzKErHX.cjs.map → textarea-C16vg4ME.cjs.map} +1 -1
  222. package/dist/{textarea-kTwx4MAh.js → textarea-DqFx1pM1.js} +2 -2
  223. package/dist/{textarea-kTwx4MAh.js.map → textarea-DqFx1pM1.js.map} +1 -1
  224. package/dist/textarea.cjs +1 -1
  225. package/dist/textarea.js +1 -1
  226. package/dist/{theme-button-Dt3WQdd4.cjs → theme-button-CgZ5qc7_.cjs} +2 -2
  227. package/dist/{theme-button-Dt3WQdd4.cjs.map → theme-button-CgZ5qc7_.cjs.map} +1 -1
  228. package/dist/{theme-button-CCwPpArv.js → theme-button-D5fnf2QD.js} +2 -2
  229. package/dist/{theme-button-CCwPpArv.js.map → theme-button-D5fnf2QD.js.map} +1 -1
  230. package/dist/theme-button.cjs +1 -1
  231. package/dist/theme-button.js +1 -1
  232. package/dist/theme.cjs +1 -1
  233. package/dist/{theme.component-Drq675ta.cjs → theme.component-B5uMqEbH.cjs} +2 -2
  234. package/dist/{theme.component-Drq675ta.cjs.map → theme.component-B5uMqEbH.cjs.map} +1 -1
  235. package/dist/{theme.component-CJHr6wNa.js → theme.component-BOnjDUB3.js} +2 -2
  236. package/dist/{theme.component-CJHr6wNa.js.map → theme.component-BOnjDUB3.js.map} +1 -1
  237. package/dist/theme.js +1 -1
  238. package/dist/{timezone-oZ1r5Z54.cjs → timezone-CdAu8QsM.cjs} +2 -2
  239. package/dist/{timezone-oZ1r5Z54.cjs.map → timezone-CdAu8QsM.cjs.map} +1 -1
  240. package/dist/{timezone-B53HOn4a.js → timezone-DwU-YCRw.js} +3 -3
  241. package/dist/{timezone-B53HOn4a.js.map → timezone-DwU-YCRw.js.map} +1 -1
  242. package/dist/{tooltip-Bfcu9uoC.js → tooltip-Bn-UWxd4.js} +2 -2
  243. package/dist/{tooltip-Bfcu9uoC.js.map → tooltip-Bn-UWxd4.js.map} +1 -1
  244. package/dist/{tooltip-DrLzz4rf.cjs → tooltip-CyI3NYzI.cjs} +2 -2
  245. package/dist/{tooltip-DrLzz4rf.cjs.map → tooltip-CyI3NYzI.cjs.map} +1 -1
  246. package/dist/tooltip.cjs +1 -1
  247. package/dist/tooltip.js +1 -1
  248. package/dist/{tree-n0KxiiWX.js → tree-D2g2zq2B.js} +2 -2
  249. package/dist/{tree-n0KxiiWX.js.map → tree-D2g2zq2B.js.map} +1 -1
  250. package/dist/{tree-Buf-0IQD.cjs → tree-DdXcAF6S.cjs} +2 -2
  251. package/dist/{tree-Buf-0IQD.cjs.map → tree-DdXcAF6S.cjs.map} +1 -1
  252. package/dist/tree.cjs +1 -1
  253. package/dist/tree.js +1 -1
  254. package/dist/{typewriter-W7Rj384X.js → typewriter-3w_PiJFo.js} +16 -16
  255. package/dist/{typewriter-W7Rj384X.js.map → typewriter-3w_PiJFo.js.map} +1 -1
  256. package/dist/{typewriter-DSUU_7wv.cjs → typewriter-RVqJuWSv.cjs} +2 -2
  257. package/dist/{typewriter-DSUU_7wv.cjs.map → typewriter-RVqJuWSv.cjs.map} +1 -1
  258. package/dist/typewriter.cjs +1 -1
  259. package/dist/typewriter.js +1 -1
  260. package/dist/typography-BLJPXhuT.cjs +10 -0
  261. package/dist/typography-BLJPXhuT.cjs.map +1 -0
  262. package/dist/typography-izBBu-t8.js +37 -0
  263. package/dist/typography-izBBu-t8.js.map +1 -0
  264. package/dist/typography.cjs +1 -1
  265. package/dist/typography.js +1 -1
  266. package/package.json +2 -1
  267. package/types/src/code-highlight/code-highlight.d.ts +39 -0
  268. package/types/src/code-highlight/code-preview.d.ts +25 -0
  269. package/types/src/code-highlight/index.d.ts +3 -0
  270. package/types/src/icons/icon.d.ts +1 -1
  271. package/types/src/index.d.ts +1 -0
  272. package/dist/date-range-BkVCslGl.cjs +0 -121
  273. package/dist/icon-CNkK3oMH.cjs.map +0 -1
  274. package/dist/icon-PZTHZSsC.js.map +0 -1
  275. package/dist/tailwind.mixin-DFxMrwgk.cjs +0 -2
  276. package/dist/tailwind.mixin-k9HTphsu.js +0 -43
  277. package/dist/typography-DaN7dGA2.cjs +0 -6
  278. package/dist/typography-DaN7dGA2.cjs.map +0 -1
  279. package/dist/typography-XkeTnrP9.js +0 -29
  280. package/dist/typography-XkeTnrP9.js.map +0 -1
@@ -1,6 +1,6 @@
1
1
  import { autoUpdate as j, offset as O, flip as $, shift as P, arrow as M, computePosition as z } from "@floating-ui/dom";
2
2
  import { directive as D, Directive as R, PartType as U } from "lit/directive.js";
3
- import { T as q } from "./tailwind.mixin-k9HTphsu.js";
3
+ import { T as q } from "./tailwind.mixin-DPUboU_5.js";
4
4
  import { css as B, html as F } from "lit";
5
5
  import { property as y, state as G, customElement as H } from "lit/decorators.js";
6
6
  import { fromEvent as h, takeUntil as v, merge as S } from "rxjs";
@@ -118,4 +118,4 @@ export {
118
118
  p as S,
119
119
  tt as t
120
120
  };
121
- //# sourceMappingURL=tooltip-Bfcu9uoC.js.map
121
+ //# sourceMappingURL=tooltip-Bn-UWxd4.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"tooltip-Bfcu9uoC.js","sources":["../src/tooltip/tooltip.directive.ts","../src/tooltip/tooltip.ts"],"sourcesContent":["import { arrow, autoUpdate, computePosition, flip, offset, Placement, shift, Strategy } from '@floating-ui/dom'\nimport { Directive, directive, ElementPart, ElementPartInfo, PartType } from 'lit/directive.js'\n\n// Store tooltip data for elements\nconst tooltipMap = new WeakMap<\n\tElement,\n\t{\n\t\ttooltipElement: HTMLElement\n\t\tarrowElement?: HTMLElement\n\t\tcleanup?: () => void\n\t\tshowTimeout?: number\n\t}\n>()\n\nclass TooltipDirective extends Directive {\n\tconstructor(partInfo: ElementPartInfo) {\n\t\tsuper(partInfo)\n\t\tif (partInfo.type !== PartType.ELEMENT) {\n\t\t\tthrow new Error('The tooltip directive can only be used on elements')\n\t\t}\n\t}\n\n\trender(\n\t\ttext: string,\n\t\toptions: {\n\t\t\tposition?: 'top' | 'right' | 'bottom' | 'left'\n\t\t\tdelay?: number\n\t\t\tshowArrow?: boolean\n\t\t} = {},\n\t) {\n\t\treturn { text, options }\n\t}\n\n\tupdate(part: ElementPart, [text, options = {}]: [string, any]) {\n\t\tconst element = part.element as HTMLElement\n\t\tconst position = options?.position || 'top'\n\t\tconst delay = options?.delay || 300\n\t\tconst showArrow = options?.showArrow !== false // Default to true\n\n\t\t// Get or create tooltip data\n\t\tlet tooltipData = tooltipMap.get(element)\n\n\t\tif (!tooltipData) {\n\t\t\t// Create tooltip element\n\t\t\tconst tooltipElement = document.createElement('div')\n\t\t\ttooltipElement.className = 'schmancy-tooltip'\n\n\t\t\t// Apply styles\n\t\t\tObject.assign(tooltipElement.style, {\n\t\t\t\tposition: 'absolute',\n\t\t\t\tzIndex: '10000',\n\t\t\t\tbackgroundColor: 'var(--schmancy-sys-color-surface-highest, #333)',\n\t\t\t\tcolor: 'var(--schmancy-sys-color-surface-on, white)',\n\t\t\t\tpadding: '8px 12px',\n\t\t\t\tborderRadius: '4px',\n\t\t\t\tfontSize: '14px',\n\t\t\t\tfontWeight: 'normal',\n\t\t\t\tmaxWidth: '300px',\n\t\t\t\tpointerEvents: 'none',\n\t\t\t\topacity: '0',\n\t\t\t\ttransition: 'opacity 150ms ease',\n\t\t\t\tboxShadow: 'var(--schmancy-sys-elevation-2)',\n\t\t\t\ttextAlign: 'center',\n\t\t\t\t// Important: start with visibility hidden to avoid flash\n\t\t\t\tvisibility: 'hidden',\n\t\t\t})\n\n\t\t\t// Create arrow element if needed\n\t\t\tlet arrowElement: HTMLElement | undefined\n\t\t\tif (showArrow) {\n\t\t\t\tarrowElement = document.createElement('div')\n\t\t\t\tarrowElement.className = 'schmancy-tooltip-arrow'\n\t\t\t\tObject.assign(arrowElement.style, {\n\t\t\t\t\tposition: 'absolute',\n\t\t\t\t\twidth: '8px',\n\t\t\t\t\theight: '8px',\n\t\t\t\t\tbackground: 'inherit',\n\t\t\t\t\tvisibility: 'hidden',\n\t\t\t\t\t// We'll rotate this to create an arrow\n\t\t\t\t\ttransform: 'rotate(45deg)',\n\t\t\t\t})\n\t\t\t\ttooltipElement.appendChild(arrowElement)\n\t\t\t}\n\n\t\t\t// Set ARIA attributes\n\t\t\ttooltipElement.setAttribute('role', 'tooltip')\n\n\t\t\t// Generate unique ID\n\t\t\tconst tooltipId = `tooltip-${Math.random().toString(36).slice(2, 9)}`\n\t\t\ttooltipElement.id = tooltipId\n\t\t\telement.setAttribute('aria-describedby', tooltipId)\n\n\t\t\t// Add to document\n\t\t\tdocument.body.appendChild(tooltipElement)\n\n\t\t\t// Create tooltip data\n\t\t\ttooltipData = {\n\t\t\t\ttooltipElement,\n\t\t\t\tarrowElement,\n\t\t\t}\n\n\t\t\ttooltipMap.set(element, tooltipData)\n\n\t\t\t// Define show handler\n\t\t\tconst showTooltip = () => {\n\t\t\t\tif (tooltipData?.showTimeout) {\n\t\t\t\t\tclearTimeout(tooltipData.showTimeout)\n\t\t\t\t}\n\n\t\t\t\ttooltipData.showTimeout = window.setTimeout(() => {\n\t\t\t\t\t// Set content\n\t\t\t\t\ttooltipData.tooltipElement.textContent = text\n\n\t\t\t\t\t// Add arrow back if it was removed\n\t\t\t\t\tif (showArrow && tooltipData.arrowElement && !tooltipData.tooltipElement.contains(tooltipData.arrowElement)) {\n\t\t\t\t\t\ttooltipData.tooltipElement.appendChild(tooltipData.arrowElement)\n\t\t\t\t\t}\n\n\t\t\t\t\t// Make sure element is visible first\n\t\t\t\t\ttooltipData.tooltipElement.style.visibility = 'visible'\n\n\t\t\t\t\t// Clean up existing positioning\n\t\t\t\t\tif (tooltipData.cleanup) {\n\t\t\t\t\t\ttooltipData.cleanup()\n\t\t\t\t\t}\n\n\t\t\t\t\t// Set up positioning\n\t\t\t\t\ttooltipData.cleanup = autoUpdate(element, tooltipData.tooltipElement, () =>\n\t\t\t\t\t\tupdatePosition(element, tooltipData, position, showArrow),\n\t\t\t\t\t)\n\n\t\t\t\t\t// Make opacity 1 after positioning is set up\n\t\t\t\t\trequestAnimationFrame(() => {\n\t\t\t\t\t\ttooltipData.tooltipElement.style.opacity = '1'\n\t\t\t\t\t})\n\t\t\t\t}, delay)\n\t\t\t}\n\n\t\t\t// Define hide handler\n\t\t\tconst hideTooltip = () => {\n\t\t\t\tif (tooltipData?.showTimeout) {\n\t\t\t\t\tclearTimeout(tooltipData.showTimeout)\n\t\t\t\t}\n\n\t\t\t\ttooltipData.tooltipElement.style.opacity = '0'\n\n\t\t\t\t// Set visibility to hidden after fade out\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\ttooltipData.tooltipElement.style.visibility = 'hidden'\n\t\t\t\t}, 150) // Match transition time\n\n\t\t\t\t// Clean up positioning\n\t\t\t\tif (tooltipData?.cleanup) {\n\t\t\t\t\ttooltipData.cleanup()\n\t\t\t\t\ttooltipData.cleanup = undefined\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Add event listeners\n\t\t\telement.addEventListener('mouseenter', showTooltip)\n\t\t\telement.addEventListener('focus', showTooltip)\n\t\t\telement.addEventListener('mouseleave', hideTooltip)\n\t\t\telement.addEventListener('blur', hideTooltip)\n\n\t\t\t// Add keyboard handler\n\t\t\tdocument.addEventListener('keydown', (e: KeyboardEvent) => {\n\t\t\t\tif (e.key === 'Escape' && tooltipData?.tooltipElement.style.opacity === '1') {\n\t\t\t\t\thideTooltip()\n\t\t\t\t}\n\t\t\t})\n\t\t} else {\n\t\t\t// Update content for existing tooltip\n\t\t\ttooltipData.tooltipElement.textContent = text\n\n\t\t\t// Update arrow visibility if needed\n\t\t\tif (tooltipData.arrowElement) {\n\t\t\t\ttooltipData.arrowElement.style.visibility = showArrow ? 'visible' : 'hidden'\n\t\t\t}\n\t\t}\n\n\t\treturn { text, options }\n\t}\n\n\tdisconnected(part: ElementPart) {\n\t\tconst element = part.element\n\t\tconst tooltipData = tooltipMap.get(element)\n\n\t\tif (tooltipData) {\n\t\t\t// Clean up\n\t\t\tif (tooltipData.showTimeout) {\n\t\t\t\tclearTimeout(tooltipData.showTimeout)\n\t\t\t}\n\n\t\t\tif (tooltipData.cleanup) {\n\t\t\t\ttooltipData.cleanup()\n\t\t\t}\n\n\t\t\t// Remove tooltip element\n\t\t\tif (document.body.contains(tooltipData.tooltipElement)) {\n\t\t\t\tdocument.body.removeChild(tooltipData.tooltipElement)\n\t\t\t}\n\n\t\t\t// Remove ARIA attributes\n\t\t\tif (element.hasAttribute('aria-describedby')) {\n\t\t\t\telement.removeAttribute('aria-describedby')\n\t\t\t}\n\n\t\t\t// Remove from WeakMap\n\t\t\ttooltipMap.delete(element)\n\t\t}\n\t}\n}\n\n// Separate positioning function for clarity and reuse\nasync function updatePosition(element: HTMLElement, tooltipData: any, position: string, showArrow: boolean) {\n\t// Use floating-ui to compute position\n\tconst middleware = [\n\t\toffset(8), // Distance from the element\n\t\tflip({\n\t\t\tfallbackPlacements: ['top', 'right', 'bottom', 'left'].filter(p => p !== position) as Placement[],\n\t\t\tpadding: 5, // How far from the edges before flipping\n\t\t}),\n\t\tshift({ padding: 5 }), // Keep it within viewport bounds\n\t]\n\n\t// Add arrow middleware if needed\n\tif (showArrow && tooltipData.arrowElement) {\n\t\tmiddleware.push(arrow({ element: tooltipData.arrowElement }))\n\t}\n\n\tconst { x, y, placement, middlewareData } = await computePosition(element, tooltipData.tooltipElement, {\n\t\tplacement: position as Placement,\n\t\tmiddleware,\n\t\tstrategy: 'fixed' as Strategy, // Fixed positioning works better across contexts\n\t})\n\n\t// Apply position\n\tObject.assign(tooltipData.tooltipElement.style, {\n\t\tleft: `${x}px`,\n\t\ttop: `${y}px`,\n\t\tposition: 'fixed',\n\t})\n\n\t// Position the arrow if it exists\n\tif (showArrow && tooltipData.arrowElement && middlewareData.arrow) {\n\t\tconst { x: arrowX, y: arrowY } = middlewareData.arrow\n\n\t\t// Determine which side the arrow should be on based on placement\n\t\tconst staticSide =\n\t\t\t{\n\t\t\t\ttop: 'bottom',\n\t\t\t\tright: 'left',\n\t\t\t\tbottom: 'top',\n\t\t\t\tleft: 'right',\n\t\t\t}[placement.split('-')[0]] || 'bottom'\n\n\t\t// Position the arrow\n\t\tObject.assign(tooltipData.arrowElement.style, {\n\t\t\tleft: arrowX != null ? `${arrowX}px` : '',\n\t\t\ttop: arrowY != null ? `${arrowY}px` : '',\n\t\t\t[staticSide]: '-4px', // Position the arrow on the correct side\n\t\t\tvisibility: 'visible',\n\t\t})\n\t}\n}\n\nexport const tooltip = directive(TooltipDirective)\n","import { TailwindElement } from '@mixins/tailwind.mixin'\nimport { html, css } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { fromEvent, merge, takeUntil } from 'rxjs'\nimport { computePosition, flip, shift, offset, autoUpdate, Placement } from '@floating-ui/dom'\n\n/**\n * A tooltip component that displays a text tooltip when hovering over content.\n * Addresses shadow DOM limitations by teleporting the tooltip to document.body.\n *\n * @element schmancy-tooltip\n */\n@customElement('schmancy-tooltip')\nexport class SchmancyTooltip extends TailwindElement(css`\n\t:host {\n\t\tdisplay: inline-block;\n\t\tposition: relative;\n\t}\n`) {\n\t@property({ type: String })\n\ttext = ''\n\n\t@property({ type: String })\n\tposition: 'top' | 'right' | 'bottom' | 'left' = 'top'\n\n\t@property({ type: Number })\n\tdelay = 50\n\n\t@property({ type: Boolean })\n\tdisabled = false\n\n\t@state() private visible = false\n\n\tprivate triggerElement: HTMLElement | null = null\n\tprivate tooltipElement: HTMLElement | null = null\n\tprivate cleanup: (() => void) | undefined\n\tprivate showTimeoutId: number | undefined\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\n\t\t// Create tooltip element once\n\t\tif (!this.tooltipElement) {\n\t\t\tthis.createTooltipElement()\n\t\t}\n\t}\n\n\tfirstUpdated() {\n\t\t// Wait for slotted elements to be available\n\t\tthis.updateComplete.then(() => {\n\t\t\t// Get the first slotted element as trigger\n\t\t\tconst slot = this.shadowRoot?.querySelector('slot') as HTMLSlotElement\n\t\t\tconst slottedElements = slot?.assignedElements() || []\n\n\t\t\tif (slottedElements.length > 0) {\n\t\t\t\tthis.triggerElement = slottedElements[0] as HTMLElement\n\t\t\t\tthis.setupEvents()\n\t\t\t}\n\t\t})\n\t}\n\n\tprivate createTooltipElement() {\n\t\t// Create the tooltip element in document.body\n\t\tthis.tooltipElement = document.createElement('div')\n\t\tthis.tooltipElement.className = 'schmancy-tooltip'\n\n\t\t// Apply styles\n\t\tObject.assign(this.tooltipElement.style, {\n\t\t\tposition: 'absolute',\n\t\t\tzIndex: '10000',\n\t\t\tbackgroundColor: 'var(--schmancy-sys-color-surface-highest, #333)',\n\t\t\tcolor: 'var(--schmancy-sys-color-surface-on, white)',\n\t\t\tpadding: '8px 12px',\n\t\t\tborderRadius: '4px',\n\t\t\tfontSize: '14px',\n\t\t\tfontWeight: 'normal',\n\t\t\tmaxWidth: '300px',\n\t\t\tpointerEvents: 'none',\n\t\t\topacity: '0',\n\t\t\ttransition: 'opacity 150ms ease',\n\t\t\tboxShadow: 'var(--schmancy-sys-elevation-2)',\n\t\t\ttextAlign: 'center',\n\t\t})\n\n\t\t// Set ARIA attributes\n\t\tthis.tooltipElement.setAttribute('role', 'tooltip')\n\n\t\t// Add to document\n\t\tdocument.body.appendChild(this.tooltipElement)\n\t}\n\n\tprivate setupEvents() {\n\t\tif (!this.triggerElement || this.disabled) return\n\n\t\t// Generate unique ID for ARIA\n\t\tconst tooltipId = `tooltip-${Math.random().toString(36).slice(2, 9)}`\n\t\tif (this.tooltipElement) {\n\t\t\tthis.tooltipElement.id = tooltipId\n\t\t\tthis.triggerElement.setAttribute('aria-describedby', tooltipId)\n\t\t}\n\n\t\t// Setup event streams using RxJS\n\t\tconst mouseEnter$ = fromEvent(this.triggerElement, 'mouseenter')\n\t\tconst focus$ = fromEvent(this.triggerElement, 'focus')\n\t\tconst mouseLeave$ = fromEvent(this.triggerElement, 'mouseleave')\n\t\tconst blur$ = fromEvent(this.triggerElement, 'blur')\n\n\t\t// Global escape key handler\n\t\tfromEvent<KeyboardEvent>(document, 'keydown')\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe(event => {\n\t\t\t\tif (event.key === 'Escape' && this.visible) {\n\t\t\t\t\tthis.hideTooltip()\n\t\t\t\t}\n\t\t\t})\n\n\t\t// Handle showing\n\t\tmerge(mouseEnter$, focus$)\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe(() => {\n\t\t\t\tthis.showTooltip()\n\t\t\t})\n\n\t\t// Handle hiding\n\t\tmerge(mouseLeave$, blur$)\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe(() => {\n\t\t\t\tthis.hideTooltip()\n\t\t\t})\n\t}\n\n\tdisconnectedCallback() {\n\t\t// Clean up\n\t\tif (this.tooltipElement && document.body.contains(this.tooltipElement)) {\n\t\t\tdocument.body.removeChild(this.tooltipElement)\n\t\t}\n\t\tthis.cleanup?.()\n\t\tclearTimeout(this.showTimeoutId)\n\t\tsuper.disconnectedCallback()\n\t}\n\n\tprivate showTooltip() {\n\t\tif (this.disabled || !this.tooltipElement || !this.triggerElement) return\n\n\t\t// Clear any existing timeout\n\t\tclearTimeout(this.showTimeoutId)\n\n\t\t// Set timeout for showing\n\t\tthis.showTimeoutId = window.setTimeout(() => {\n\t\t\t// Update content\n\t\t\tif (this.tooltipElement) {\n\t\t\t\tthis.tooltipElement.textContent = this.text\n\n\t\t\t\t// Make visible\n\t\t\t\tthis.visible = true\n\t\t\t\tthis.tooltipElement.style.opacity = '1'\n\n\t\t\t\t// Initialize positioning\n\t\t\t\tthis.initializePositioning()\n\t\t\t}\n\t\t}, this.delay)\n\t}\n\n\tprivate hideTooltip() {\n\t\t// Clear showing timeout\n\t\tclearTimeout(this.showTimeoutId)\n\n\t\t// Hide tooltip\n\t\tif (this.tooltipElement) {\n\t\t\tthis.visible = false\n\t\t\tthis.tooltipElement.style.opacity = '0'\n\t\t}\n\n\t\t// Clean up positioning\n\t\tif (this.cleanup) {\n\t\t\tthis.cleanup()\n\t\t\tthis.cleanup = undefined\n\t\t}\n\t}\n\n\tprivate initializePositioning() {\n\t\tif (!this.triggerElement || !this.tooltipElement) return\n\n\t\t// Clean up existing positioning\n\t\tif (this.cleanup) {\n\t\t\tthis.cleanup()\n\t\t}\n\n\t\t// Set up auto-updating position\n\t\tthis.cleanup = autoUpdate(this.triggerElement, this.tooltipElement, () => {\n\t\t\t// Compute position\n\t\t\tcomputePosition(this.triggerElement!, this.tooltipElement!, {\n\t\t\t\tplacement: this.position as Placement,\n\t\t\t\tmiddleware: [offset(8), flip({ padding: 5 }), shift({ padding: 5 })],\n\t\t\t}).then(({ x, y }) => {\n\t\t\t\t// Apply position\n\t\t\t\tif (this.tooltipElement) {\n\t\t\t\t\tObject.assign(this.tooltipElement.style, {\n\t\t\t\t\t\tleft: `${x}px`,\n\t\t\t\t\t\ttop: `${y}px`,\n\t\t\t\t\t})\n\t\t\t\t}\n\t\t\t})\n\t\t})\n\t}\n\n\trender() {\n\t\treturn html`<slot></slot>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-tooltip': SchmancyTooltip\n\t}\n}\n"],"names":["tooltipMap","WeakMap","tooltip","directive","Directive","partInfo","super","type","PartType","ELEMENT","Error","text","options","part","element","position","delay","showArrow","tooltipData","get","tooltipElement","textContent","arrowElement","style","visibility","document","createElement","className","Object","assign","zIndex","backgroundColor","color","padding","borderRadius","fontSize","fontWeight","maxWidth","pointerEvents","opacity","transition","boxShadow","textAlign","width","height","background","transform","appendChild","setAttribute","tooltipId","Math","random","toString","slice","id","body","set","showTooltip","showTimeout","clearTimeout","window","setTimeout","contains","cleanup","autoUpdate","async","middleware","offset","flip","fallbackPlacements","filter","p","shift","push","arrow","x","y","placement","middlewareData","computePosition","strategy","left","top","arrowX","arrowY","staticSide","right","bottom","split","requestAnimationFrame","hideTooltip","addEventListener","e","key","c","removeChild","hasAttribute","removeAttribute","delete","SchmancyTooltip","TailwindElement","css","constructor","arguments","this","disabled","visible","triggerElement","connectedCallback","createTooltipElement","firstUpdated","updateComplete","then","slot","shadowRoot","querySelector","slottedElements","assignedElements","length","setupEvents","mouseEnter$","fromEvent","focus$","mouseLeave$","blur$","pipe","takeUntil","disconnecting","subscribe","event","merge","disconnectedCallback","showTimeoutId","initializePositioning","render","html","__decorateClass","property","String","prototype","Number","Boolean","state","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"tooltip-Bn-UWxd4.js","sources":["../src/tooltip/tooltip.directive.ts","../src/tooltip/tooltip.ts"],"sourcesContent":["import { arrow, autoUpdate, computePosition, flip, offset, Placement, shift, Strategy } from '@floating-ui/dom'\nimport { Directive, directive, ElementPart, ElementPartInfo, PartType } from 'lit/directive.js'\n\n// Store tooltip data for elements\nconst tooltipMap = new WeakMap<\n\tElement,\n\t{\n\t\ttooltipElement: HTMLElement\n\t\tarrowElement?: HTMLElement\n\t\tcleanup?: () => void\n\t\tshowTimeout?: number\n\t}\n>()\n\nclass TooltipDirective extends Directive {\n\tconstructor(partInfo: ElementPartInfo) {\n\t\tsuper(partInfo)\n\t\tif (partInfo.type !== PartType.ELEMENT) {\n\t\t\tthrow new Error('The tooltip directive can only be used on elements')\n\t\t}\n\t}\n\n\trender(\n\t\ttext: string,\n\t\toptions: {\n\t\t\tposition?: 'top' | 'right' | 'bottom' | 'left'\n\t\t\tdelay?: number\n\t\t\tshowArrow?: boolean\n\t\t} = {},\n\t) {\n\t\treturn { text, options }\n\t}\n\n\tupdate(part: ElementPart, [text, options = {}]: [string, any]) {\n\t\tconst element = part.element as HTMLElement\n\t\tconst position = options?.position || 'top'\n\t\tconst delay = options?.delay || 300\n\t\tconst showArrow = options?.showArrow !== false // Default to true\n\n\t\t// Get or create tooltip data\n\t\tlet tooltipData = tooltipMap.get(element)\n\n\t\tif (!tooltipData) {\n\t\t\t// Create tooltip element\n\t\t\tconst tooltipElement = document.createElement('div')\n\t\t\ttooltipElement.className = 'schmancy-tooltip'\n\n\t\t\t// Apply styles\n\t\t\tObject.assign(tooltipElement.style, {\n\t\t\t\tposition: 'absolute',\n\t\t\t\tzIndex: '10000',\n\t\t\t\tbackgroundColor: 'var(--schmancy-sys-color-surface-highest, #333)',\n\t\t\t\tcolor: 'var(--schmancy-sys-color-surface-on, white)',\n\t\t\t\tpadding: '8px 12px',\n\t\t\t\tborderRadius: '4px',\n\t\t\t\tfontSize: '14px',\n\t\t\t\tfontWeight: 'normal',\n\t\t\t\tmaxWidth: '300px',\n\t\t\t\tpointerEvents: 'none',\n\t\t\t\topacity: '0',\n\t\t\t\ttransition: 'opacity 150ms ease',\n\t\t\t\tboxShadow: 'var(--schmancy-sys-elevation-2)',\n\t\t\t\ttextAlign: 'center',\n\t\t\t\t// Important: start with visibility hidden to avoid flash\n\t\t\t\tvisibility: 'hidden',\n\t\t\t})\n\n\t\t\t// Create arrow element if needed\n\t\t\tlet arrowElement: HTMLElement | undefined\n\t\t\tif (showArrow) {\n\t\t\t\tarrowElement = document.createElement('div')\n\t\t\t\tarrowElement.className = 'schmancy-tooltip-arrow'\n\t\t\t\tObject.assign(arrowElement.style, {\n\t\t\t\t\tposition: 'absolute',\n\t\t\t\t\twidth: '8px',\n\t\t\t\t\theight: '8px',\n\t\t\t\t\tbackground: 'inherit',\n\t\t\t\t\tvisibility: 'hidden',\n\t\t\t\t\t// We'll rotate this to create an arrow\n\t\t\t\t\ttransform: 'rotate(45deg)',\n\t\t\t\t})\n\t\t\t\ttooltipElement.appendChild(arrowElement)\n\t\t\t}\n\n\t\t\t// Set ARIA attributes\n\t\t\ttooltipElement.setAttribute('role', 'tooltip')\n\n\t\t\t// Generate unique ID\n\t\t\tconst tooltipId = `tooltip-${Math.random().toString(36).slice(2, 9)}`\n\t\t\ttooltipElement.id = tooltipId\n\t\t\telement.setAttribute('aria-describedby', tooltipId)\n\n\t\t\t// Add to document\n\t\t\tdocument.body.appendChild(tooltipElement)\n\n\t\t\t// Create tooltip data\n\t\t\ttooltipData = {\n\t\t\t\ttooltipElement,\n\t\t\t\tarrowElement,\n\t\t\t}\n\n\t\t\ttooltipMap.set(element, tooltipData)\n\n\t\t\t// Define show handler\n\t\t\tconst showTooltip = () => {\n\t\t\t\tif (tooltipData?.showTimeout) {\n\t\t\t\t\tclearTimeout(tooltipData.showTimeout)\n\t\t\t\t}\n\n\t\t\t\ttooltipData.showTimeout = window.setTimeout(() => {\n\t\t\t\t\t// Set content\n\t\t\t\t\ttooltipData.tooltipElement.textContent = text\n\n\t\t\t\t\t// Add arrow back if it was removed\n\t\t\t\t\tif (showArrow && tooltipData.arrowElement && !tooltipData.tooltipElement.contains(tooltipData.arrowElement)) {\n\t\t\t\t\t\ttooltipData.tooltipElement.appendChild(tooltipData.arrowElement)\n\t\t\t\t\t}\n\n\t\t\t\t\t// Make sure element is visible first\n\t\t\t\t\ttooltipData.tooltipElement.style.visibility = 'visible'\n\n\t\t\t\t\t// Clean up existing positioning\n\t\t\t\t\tif (tooltipData.cleanup) {\n\t\t\t\t\t\ttooltipData.cleanup()\n\t\t\t\t\t}\n\n\t\t\t\t\t// Set up positioning\n\t\t\t\t\ttooltipData.cleanup = autoUpdate(element, tooltipData.tooltipElement, () =>\n\t\t\t\t\t\tupdatePosition(element, tooltipData, position, showArrow),\n\t\t\t\t\t)\n\n\t\t\t\t\t// Make opacity 1 after positioning is set up\n\t\t\t\t\trequestAnimationFrame(() => {\n\t\t\t\t\t\ttooltipData.tooltipElement.style.opacity = '1'\n\t\t\t\t\t})\n\t\t\t\t}, delay)\n\t\t\t}\n\n\t\t\t// Define hide handler\n\t\t\tconst hideTooltip = () => {\n\t\t\t\tif (tooltipData?.showTimeout) {\n\t\t\t\t\tclearTimeout(tooltipData.showTimeout)\n\t\t\t\t}\n\n\t\t\t\ttooltipData.tooltipElement.style.opacity = '0'\n\n\t\t\t\t// Set visibility to hidden after fade out\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\ttooltipData.tooltipElement.style.visibility = 'hidden'\n\t\t\t\t}, 150) // Match transition time\n\n\t\t\t\t// Clean up positioning\n\t\t\t\tif (tooltipData?.cleanup) {\n\t\t\t\t\ttooltipData.cleanup()\n\t\t\t\t\ttooltipData.cleanup = undefined\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Add event listeners\n\t\t\telement.addEventListener('mouseenter', showTooltip)\n\t\t\telement.addEventListener('focus', showTooltip)\n\t\t\telement.addEventListener('mouseleave', hideTooltip)\n\t\t\telement.addEventListener('blur', hideTooltip)\n\n\t\t\t// Add keyboard handler\n\t\t\tdocument.addEventListener('keydown', (e: KeyboardEvent) => {\n\t\t\t\tif (e.key === 'Escape' && tooltipData?.tooltipElement.style.opacity === '1') {\n\t\t\t\t\thideTooltip()\n\t\t\t\t}\n\t\t\t})\n\t\t} else {\n\t\t\t// Update content for existing tooltip\n\t\t\ttooltipData.tooltipElement.textContent = text\n\n\t\t\t// Update arrow visibility if needed\n\t\t\tif (tooltipData.arrowElement) {\n\t\t\t\ttooltipData.arrowElement.style.visibility = showArrow ? 'visible' : 'hidden'\n\t\t\t}\n\t\t}\n\n\t\treturn { text, options }\n\t}\n\n\tdisconnected(part: ElementPart) {\n\t\tconst element = part.element\n\t\tconst tooltipData = tooltipMap.get(element)\n\n\t\tif (tooltipData) {\n\t\t\t// Clean up\n\t\t\tif (tooltipData.showTimeout) {\n\t\t\t\tclearTimeout(tooltipData.showTimeout)\n\t\t\t}\n\n\t\t\tif (tooltipData.cleanup) {\n\t\t\t\ttooltipData.cleanup()\n\t\t\t}\n\n\t\t\t// Remove tooltip element\n\t\t\tif (document.body.contains(tooltipData.tooltipElement)) {\n\t\t\t\tdocument.body.removeChild(tooltipData.tooltipElement)\n\t\t\t}\n\n\t\t\t// Remove ARIA attributes\n\t\t\tif (element.hasAttribute('aria-describedby')) {\n\t\t\t\telement.removeAttribute('aria-describedby')\n\t\t\t}\n\n\t\t\t// Remove from WeakMap\n\t\t\ttooltipMap.delete(element)\n\t\t}\n\t}\n}\n\n// Separate positioning function for clarity and reuse\nasync function updatePosition(element: HTMLElement, tooltipData: any, position: string, showArrow: boolean) {\n\t// Use floating-ui to compute position\n\tconst middleware = [\n\t\toffset(8), // Distance from the element\n\t\tflip({\n\t\t\tfallbackPlacements: ['top', 'right', 'bottom', 'left'].filter(p => p !== position) as Placement[],\n\t\t\tpadding: 5, // How far from the edges before flipping\n\t\t}),\n\t\tshift({ padding: 5 }), // Keep it within viewport bounds\n\t]\n\n\t// Add arrow middleware if needed\n\tif (showArrow && tooltipData.arrowElement) {\n\t\tmiddleware.push(arrow({ element: tooltipData.arrowElement }))\n\t}\n\n\tconst { x, y, placement, middlewareData } = await computePosition(element, tooltipData.tooltipElement, {\n\t\tplacement: position as Placement,\n\t\tmiddleware,\n\t\tstrategy: 'fixed' as Strategy, // Fixed positioning works better across contexts\n\t})\n\n\t// Apply position\n\tObject.assign(tooltipData.tooltipElement.style, {\n\t\tleft: `${x}px`,\n\t\ttop: `${y}px`,\n\t\tposition: 'fixed',\n\t})\n\n\t// Position the arrow if it exists\n\tif (showArrow && tooltipData.arrowElement && middlewareData.arrow) {\n\t\tconst { x: arrowX, y: arrowY } = middlewareData.arrow\n\n\t\t// Determine which side the arrow should be on based on placement\n\t\tconst staticSide =\n\t\t\t{\n\t\t\t\ttop: 'bottom',\n\t\t\t\tright: 'left',\n\t\t\t\tbottom: 'top',\n\t\t\t\tleft: 'right',\n\t\t\t}[placement.split('-')[0]] || 'bottom'\n\n\t\t// Position the arrow\n\t\tObject.assign(tooltipData.arrowElement.style, {\n\t\t\tleft: arrowX != null ? `${arrowX}px` : '',\n\t\t\ttop: arrowY != null ? `${arrowY}px` : '',\n\t\t\t[staticSide]: '-4px', // Position the arrow on the correct side\n\t\t\tvisibility: 'visible',\n\t\t})\n\t}\n}\n\nexport const tooltip = directive(TooltipDirective)\n","import { TailwindElement } from '@mixins/tailwind.mixin'\nimport { html, css } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { fromEvent, merge, takeUntil } from 'rxjs'\nimport { computePosition, flip, shift, offset, autoUpdate, Placement } from '@floating-ui/dom'\n\n/**\n * A tooltip component that displays a text tooltip when hovering over content.\n * Addresses shadow DOM limitations by teleporting the tooltip to document.body.\n *\n * @element schmancy-tooltip\n */\n@customElement('schmancy-tooltip')\nexport class SchmancyTooltip extends TailwindElement(css`\n\t:host {\n\t\tdisplay: inline-block;\n\t\tposition: relative;\n\t}\n`) {\n\t@property({ type: String })\n\ttext = ''\n\n\t@property({ type: String })\n\tposition: 'top' | 'right' | 'bottom' | 'left' = 'top'\n\n\t@property({ type: Number })\n\tdelay = 50\n\n\t@property({ type: Boolean })\n\tdisabled = false\n\n\t@state() private visible = false\n\n\tprivate triggerElement: HTMLElement | null = null\n\tprivate tooltipElement: HTMLElement | null = null\n\tprivate cleanup: (() => void) | undefined\n\tprivate showTimeoutId: number | undefined\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\n\t\t// Create tooltip element once\n\t\tif (!this.tooltipElement) {\n\t\t\tthis.createTooltipElement()\n\t\t}\n\t}\n\n\tfirstUpdated() {\n\t\t// Wait for slotted elements to be available\n\t\tthis.updateComplete.then(() => {\n\t\t\t// Get the first slotted element as trigger\n\t\t\tconst slot = this.shadowRoot?.querySelector('slot') as HTMLSlotElement\n\t\t\tconst slottedElements = slot?.assignedElements() || []\n\n\t\t\tif (slottedElements.length > 0) {\n\t\t\t\tthis.triggerElement = slottedElements[0] as HTMLElement\n\t\t\t\tthis.setupEvents()\n\t\t\t}\n\t\t})\n\t}\n\n\tprivate createTooltipElement() {\n\t\t// Create the tooltip element in document.body\n\t\tthis.tooltipElement = document.createElement('div')\n\t\tthis.tooltipElement.className = 'schmancy-tooltip'\n\n\t\t// Apply styles\n\t\tObject.assign(this.tooltipElement.style, {\n\t\t\tposition: 'absolute',\n\t\t\tzIndex: '10000',\n\t\t\tbackgroundColor: 'var(--schmancy-sys-color-surface-highest, #333)',\n\t\t\tcolor: 'var(--schmancy-sys-color-surface-on, white)',\n\t\t\tpadding: '8px 12px',\n\t\t\tborderRadius: '4px',\n\t\t\tfontSize: '14px',\n\t\t\tfontWeight: 'normal',\n\t\t\tmaxWidth: '300px',\n\t\t\tpointerEvents: 'none',\n\t\t\topacity: '0',\n\t\t\ttransition: 'opacity 150ms ease',\n\t\t\tboxShadow: 'var(--schmancy-sys-elevation-2)',\n\t\t\ttextAlign: 'center',\n\t\t})\n\n\t\t// Set ARIA attributes\n\t\tthis.tooltipElement.setAttribute('role', 'tooltip')\n\n\t\t// Add to document\n\t\tdocument.body.appendChild(this.tooltipElement)\n\t}\n\n\tprivate setupEvents() {\n\t\tif (!this.triggerElement || this.disabled) return\n\n\t\t// Generate unique ID for ARIA\n\t\tconst tooltipId = `tooltip-${Math.random().toString(36).slice(2, 9)}`\n\t\tif (this.tooltipElement) {\n\t\t\tthis.tooltipElement.id = tooltipId\n\t\t\tthis.triggerElement.setAttribute('aria-describedby', tooltipId)\n\t\t}\n\n\t\t// Setup event streams using RxJS\n\t\tconst mouseEnter$ = fromEvent(this.triggerElement, 'mouseenter')\n\t\tconst focus$ = fromEvent(this.triggerElement, 'focus')\n\t\tconst mouseLeave$ = fromEvent(this.triggerElement, 'mouseleave')\n\t\tconst blur$ = fromEvent(this.triggerElement, 'blur')\n\n\t\t// Global escape key handler\n\t\tfromEvent<KeyboardEvent>(document, 'keydown')\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe(event => {\n\t\t\t\tif (event.key === 'Escape' && this.visible) {\n\t\t\t\t\tthis.hideTooltip()\n\t\t\t\t}\n\t\t\t})\n\n\t\t// Handle showing\n\t\tmerge(mouseEnter$, focus$)\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe(() => {\n\t\t\t\tthis.showTooltip()\n\t\t\t})\n\n\t\t// Handle hiding\n\t\tmerge(mouseLeave$, blur$)\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe(() => {\n\t\t\t\tthis.hideTooltip()\n\t\t\t})\n\t}\n\n\tdisconnectedCallback() {\n\t\t// Clean up\n\t\tif (this.tooltipElement && document.body.contains(this.tooltipElement)) {\n\t\t\tdocument.body.removeChild(this.tooltipElement)\n\t\t}\n\t\tthis.cleanup?.()\n\t\tclearTimeout(this.showTimeoutId)\n\t\tsuper.disconnectedCallback()\n\t}\n\n\tprivate showTooltip() {\n\t\tif (this.disabled || !this.tooltipElement || !this.triggerElement) return\n\n\t\t// Clear any existing timeout\n\t\tclearTimeout(this.showTimeoutId)\n\n\t\t// Set timeout for showing\n\t\tthis.showTimeoutId = window.setTimeout(() => {\n\t\t\t// Update content\n\t\t\tif (this.tooltipElement) {\n\t\t\t\tthis.tooltipElement.textContent = this.text\n\n\t\t\t\t// Make visible\n\t\t\t\tthis.visible = true\n\t\t\t\tthis.tooltipElement.style.opacity = '1'\n\n\t\t\t\t// Initialize positioning\n\t\t\t\tthis.initializePositioning()\n\t\t\t}\n\t\t}, this.delay)\n\t}\n\n\tprivate hideTooltip() {\n\t\t// Clear showing timeout\n\t\tclearTimeout(this.showTimeoutId)\n\n\t\t// Hide tooltip\n\t\tif (this.tooltipElement) {\n\t\t\tthis.visible = false\n\t\t\tthis.tooltipElement.style.opacity = '0'\n\t\t}\n\n\t\t// Clean up positioning\n\t\tif (this.cleanup) {\n\t\t\tthis.cleanup()\n\t\t\tthis.cleanup = undefined\n\t\t}\n\t}\n\n\tprivate initializePositioning() {\n\t\tif (!this.triggerElement || !this.tooltipElement) return\n\n\t\t// Clean up existing positioning\n\t\tif (this.cleanup) {\n\t\t\tthis.cleanup()\n\t\t}\n\n\t\t// Set up auto-updating position\n\t\tthis.cleanup = autoUpdate(this.triggerElement, this.tooltipElement, () => {\n\t\t\t// Compute position\n\t\t\tcomputePosition(this.triggerElement!, this.tooltipElement!, {\n\t\t\t\tplacement: this.position as Placement,\n\t\t\t\tmiddleware: [offset(8), flip({ padding: 5 }), shift({ padding: 5 })],\n\t\t\t}).then(({ x, y }) => {\n\t\t\t\t// Apply position\n\t\t\t\tif (this.tooltipElement) {\n\t\t\t\t\tObject.assign(this.tooltipElement.style, {\n\t\t\t\t\t\tleft: `${x}px`,\n\t\t\t\t\t\ttop: `${y}px`,\n\t\t\t\t\t})\n\t\t\t\t}\n\t\t\t})\n\t\t})\n\t}\n\n\trender() {\n\t\treturn html`<slot></slot>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-tooltip': SchmancyTooltip\n\t}\n}\n"],"names":["tooltipMap","WeakMap","tooltip","directive","Directive","partInfo","super","type","PartType","ELEMENT","Error","text","options","part","element","position","delay","showArrow","tooltipData","get","tooltipElement","textContent","arrowElement","style","visibility","document","createElement","className","Object","assign","zIndex","backgroundColor","color","padding","borderRadius","fontSize","fontWeight","maxWidth","pointerEvents","opacity","transition","boxShadow","textAlign","width","height","background","transform","appendChild","setAttribute","tooltipId","Math","random","toString","slice","id","body","set","showTooltip","showTimeout","clearTimeout","window","setTimeout","contains","cleanup","autoUpdate","async","middleware","offset","flip","fallbackPlacements","filter","p","shift","push","arrow","x","y","placement","middlewareData","computePosition","strategy","left","top","arrowX","arrowY","staticSide","right","bottom","split","requestAnimationFrame","hideTooltip","addEventListener","e","key","c","removeChild","hasAttribute","removeAttribute","delete","SchmancyTooltip","TailwindElement","css","constructor","arguments","this","disabled","visible","triggerElement","connectedCallback","createTooltipElement","firstUpdated","updateComplete","then","slot","shadowRoot","querySelector","slottedElements","assignedElements","length","setupEvents","mouseEnter$","fromEvent","focus$","mouseLeave$","blur$","pipe","takeUntil","disconnecting","subscribe","event","merge","disconnectedCallback","showTimeoutId","initializePositioning","render","html","__decorateClass","property","String","prototype","Number","Boolean","state","customElement"],"mappings":"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"}
@@ -1,7 +1,7 @@
1
- "use strict";const r=require("@floating-ui/dom"),w=require("lit/directive.js"),z=require("./tailwind.mixin-DFxMrwgk.cjs"),O=require("lit"),m=require("lit/decorators.js"),a=require("rxjs"),b=new WeakMap;class I extends w.Directive{constructor(i){if(super(i),i.type!==w.PartType.ELEMENT)throw new Error("The tooltip directive can only be used on elements")}render(i,o={}){return{text:i,options:o}}update(i,[o,e={}]){const l=i.element,s=(e==null?void 0:e.position)||"top",h=(e==null?void 0:e.delay)||300,y=(e==null?void 0:e.showArrow)!==!1;let t=b.get(l);if(t)t.tooltipElement.textContent=o,t.arrowElement&&(t.arrowElement.style.visibility=y?"visible":"hidden");else{const p=document.createElement("div");let u;p.className="schmancy-tooltip",Object.assign(p.style,{position:"absolute",zIndex:"10000",backgroundColor:"var(--schmancy-sys-color-surface-highest, #333)",color:"var(--schmancy-sys-color-surface-on, white)",padding:"8px 12px",borderRadius:"4px",fontSize:"14px",fontWeight:"normal",maxWidth:"300px",pointerEvents:"none",opacity:"0",transition:"opacity 150ms ease",boxShadow:"var(--schmancy-sys-elevation-2)",textAlign:"center",visibility:"hidden"}),y&&(u=document.createElement("div"),u.className="schmancy-tooltip-arrow",Object.assign(u.style,{position:"absolute",width:"8px",height:"8px",background:"inherit",visibility:"hidden",transform:"rotate(45deg)"}),p.appendChild(u)),p.setAttribute("role","tooltip");const f=`tooltip-${Math.random().toString(36).slice(2,9)}`;p.id=f,l.setAttribute("aria-describedby",f),document.body.appendChild(p),t={tooltipElement:p,arrowElement:u},b.set(l,t);const x=()=>{t!=null&&t.showTimeout&&clearTimeout(t.showTimeout),t.showTimeout=window.setTimeout(()=>{t.tooltipElement.textContent=o,y&&t.arrowElement&&!t.tooltipElement.contains(t.arrowElement)&&t.tooltipElement.appendChild(t.arrowElement),t.tooltipElement.style.visibility="visible",t.cleanup&&t.cleanup(),t.cleanup=r.autoUpdate(l,t.tooltipElement,()=>async function(v,c,T,k){const S=[r.offset(8),r.flip({fallbackPlacements:["top","right","bottom","left"].filter(E=>E!==T),padding:5}),r.shift({padding:5})];k&&c.arrowElement&&S.push(r.arrow({element:c.arrowElement}));const{x:j,y:q,placement:P,middlewareData:C}=await r.computePosition(v,c.tooltipElement,{placement:T,middleware:S,strategy:"fixed"});if(Object.assign(c.tooltipElement.style,{left:`${j}px`,top:`${q}px`,position:"fixed"}),k&&c.arrowElement&&C.arrow){const{x:E,y:A}=C.arrow,$={top:"bottom",right:"left",bottom:"top",left:"right"}[P.split("-")[0]]||"bottom";Object.assign(c.arrowElement.style,{left:E!=null?`${E}px`:"",top:A!=null?`${A}px`:"",[$]:"-4px",visibility:"visible"})}}(l,t,s,y)),requestAnimationFrame(()=>{t.tooltipElement.style.opacity="1"})},h)},g=()=>{t!=null&&t.showTimeout&&clearTimeout(t.showTimeout),t.tooltipElement.style.opacity="0",setTimeout(()=>{t.tooltipElement.style.visibility="hidden"},150),t!=null&&t.cleanup&&(t.cleanup(),t.cleanup=void 0)};l.addEventListener("mouseenter",x),l.addEventListener("focus",x),l.addEventListener("mouseleave",g),l.addEventListener("blur",g),document.addEventListener("keydown",v=>{v.key==="Escape"&&(t==null?void 0:t.tooltipElement.style.opacity)==="1"&&g()})}return{text:o,options:e}}disconnected(i){const o=i.element,e=b.get(o);e&&(e.showTimeout&&clearTimeout(e.showTimeout),e.cleanup&&e.cleanup(),document.body.contains(e.tooltipElement)&&document.body.removeChild(e.tooltipElement),o.hasAttribute("aria-describedby")&&o.removeAttribute("aria-describedby"),b.delete(o))}}const L=w.directive(I);var U=Object.defineProperty,N=Object.getOwnPropertyDescriptor,d=(n,i,o,e)=>{for(var l,s=e>1?void 0:e?N(i,o):i,h=n.length-1;h>=0;h--)(l=n[h])&&(s=(e?l(i,o,s):l(s))||s);return e&&s&&U(i,o,s),s};exports.SchmancyTooltip=class extends z.TailwindElement(O.css`
1
+ "use strict";const r=require("@floating-ui/dom"),w=require("lit/directive.js"),z=require("./tailwind.mixin-mxyACxyp.cjs"),O=require("lit"),m=require("lit/decorators.js"),a=require("rxjs"),b=new WeakMap;class I extends w.Directive{constructor(i){if(super(i),i.type!==w.PartType.ELEMENT)throw new Error("The tooltip directive can only be used on elements")}render(i,o={}){return{text:i,options:o}}update(i,[o,e={}]){const l=i.element,s=(e==null?void 0:e.position)||"top",h=(e==null?void 0:e.delay)||300,y=(e==null?void 0:e.showArrow)!==!1;let t=b.get(l);if(t)t.tooltipElement.textContent=o,t.arrowElement&&(t.arrowElement.style.visibility=y?"visible":"hidden");else{const p=document.createElement("div");let u;p.className="schmancy-tooltip",Object.assign(p.style,{position:"absolute",zIndex:"10000",backgroundColor:"var(--schmancy-sys-color-surface-highest, #333)",color:"var(--schmancy-sys-color-surface-on, white)",padding:"8px 12px",borderRadius:"4px",fontSize:"14px",fontWeight:"normal",maxWidth:"300px",pointerEvents:"none",opacity:"0",transition:"opacity 150ms ease",boxShadow:"var(--schmancy-sys-elevation-2)",textAlign:"center",visibility:"hidden"}),y&&(u=document.createElement("div"),u.className="schmancy-tooltip-arrow",Object.assign(u.style,{position:"absolute",width:"8px",height:"8px",background:"inherit",visibility:"hidden",transform:"rotate(45deg)"}),p.appendChild(u)),p.setAttribute("role","tooltip");const f=`tooltip-${Math.random().toString(36).slice(2,9)}`;p.id=f,l.setAttribute("aria-describedby",f),document.body.appendChild(p),t={tooltipElement:p,arrowElement:u},b.set(l,t);const x=()=>{t!=null&&t.showTimeout&&clearTimeout(t.showTimeout),t.showTimeout=window.setTimeout(()=>{t.tooltipElement.textContent=o,y&&t.arrowElement&&!t.tooltipElement.contains(t.arrowElement)&&t.tooltipElement.appendChild(t.arrowElement),t.tooltipElement.style.visibility="visible",t.cleanup&&t.cleanup(),t.cleanup=r.autoUpdate(l,t.tooltipElement,()=>async function(v,c,T,k){const S=[r.offset(8),r.flip({fallbackPlacements:["top","right","bottom","left"].filter(E=>E!==T),padding:5}),r.shift({padding:5})];k&&c.arrowElement&&S.push(r.arrow({element:c.arrowElement}));const{x:j,y:q,placement:P,middlewareData:C}=await r.computePosition(v,c.tooltipElement,{placement:T,middleware:S,strategy:"fixed"});if(Object.assign(c.tooltipElement.style,{left:`${j}px`,top:`${q}px`,position:"fixed"}),k&&c.arrowElement&&C.arrow){const{x:E,y:A}=C.arrow,$={top:"bottom",right:"left",bottom:"top",left:"right"}[P.split("-")[0]]||"bottom";Object.assign(c.arrowElement.style,{left:E!=null?`${E}px`:"",top:A!=null?`${A}px`:"",[$]:"-4px",visibility:"visible"})}}(l,t,s,y)),requestAnimationFrame(()=>{t.tooltipElement.style.opacity="1"})},h)},g=()=>{t!=null&&t.showTimeout&&clearTimeout(t.showTimeout),t.tooltipElement.style.opacity="0",setTimeout(()=>{t.tooltipElement.style.visibility="hidden"},150),t!=null&&t.cleanup&&(t.cleanup(),t.cleanup=void 0)};l.addEventListener("mouseenter",x),l.addEventListener("focus",x),l.addEventListener("mouseleave",g),l.addEventListener("blur",g),document.addEventListener("keydown",v=>{v.key==="Escape"&&(t==null?void 0:t.tooltipElement.style.opacity)==="1"&&g()})}return{text:o,options:e}}disconnected(i){const o=i.element,e=b.get(o);e&&(e.showTimeout&&clearTimeout(e.showTimeout),e.cleanup&&e.cleanup(),document.body.contains(e.tooltipElement)&&document.body.removeChild(e.tooltipElement),o.hasAttribute("aria-describedby")&&o.removeAttribute("aria-describedby"),b.delete(o))}}const L=w.directive(I);var U=Object.defineProperty,N=Object.getOwnPropertyDescriptor,d=(n,i,o,e)=>{for(var l,s=e>1?void 0:e?N(i,o):i,h=n.length-1;h>=0;h--)(l=n[h])&&(s=(e?l(i,o,s):l(s))||s);return e&&s&&U(i,o,s),s};exports.SchmancyTooltip=class extends z.TailwindElement(O.css`
2
2
  :host {
3
3
  display: inline-block;
4
4
  position: relative;
5
5
  }
6
6
  `){constructor(){super(...arguments),this.text="",this.position="top",this.delay=50,this.disabled=!1,this.visible=!1,this.triggerElement=null,this.tooltipElement=null}connectedCallback(){super.connectedCallback(),this.tooltipElement||this.createTooltipElement()}firstUpdated(){this.updateComplete.then(()=>{var o;const n=(o=this.shadowRoot)==null?void 0:o.querySelector("slot"),i=(n==null?void 0:n.assignedElements())||[];i.length>0&&(this.triggerElement=i[0],this.setupEvents())})}createTooltipElement(){this.tooltipElement=document.createElement("div"),this.tooltipElement.className="schmancy-tooltip",Object.assign(this.tooltipElement.style,{position:"absolute",zIndex:"10000",backgroundColor:"var(--schmancy-sys-color-surface-highest, #333)",color:"var(--schmancy-sys-color-surface-on, white)",padding:"8px 12px",borderRadius:"4px",fontSize:"14px",fontWeight:"normal",maxWidth:"300px",pointerEvents:"none",opacity:"0",transition:"opacity 150ms ease",boxShadow:"var(--schmancy-sys-elevation-2)",textAlign:"center"}),this.tooltipElement.setAttribute("role","tooltip"),document.body.appendChild(this.tooltipElement)}setupEvents(){if(!this.triggerElement||this.disabled)return;const n=`tooltip-${Math.random().toString(36).slice(2,9)}`;this.tooltipElement&&(this.tooltipElement.id=n,this.triggerElement.setAttribute("aria-describedby",n));const i=a.fromEvent(this.triggerElement,"mouseenter"),o=a.fromEvent(this.triggerElement,"focus"),e=a.fromEvent(this.triggerElement,"mouseleave"),l=a.fromEvent(this.triggerElement,"blur");a.fromEvent(document,"keydown").pipe(a.takeUntil(this.disconnecting)).subscribe(s=>{s.key==="Escape"&&this.visible&&this.hideTooltip()}),a.merge(i,o).pipe(a.takeUntil(this.disconnecting)).subscribe(()=>{this.showTooltip()}),a.merge(e,l).pipe(a.takeUntil(this.disconnecting)).subscribe(()=>{this.hideTooltip()})}disconnectedCallback(){var n;this.tooltipElement&&document.body.contains(this.tooltipElement)&&document.body.removeChild(this.tooltipElement),(n=this.cleanup)==null||n.call(this),clearTimeout(this.showTimeoutId),super.disconnectedCallback()}showTooltip(){!this.disabled&&this.tooltipElement&&this.triggerElement&&(clearTimeout(this.showTimeoutId),this.showTimeoutId=window.setTimeout(()=>{this.tooltipElement&&(this.tooltipElement.textContent=this.text,this.visible=!0,this.tooltipElement.style.opacity="1",this.initializePositioning())},this.delay))}hideTooltip(){clearTimeout(this.showTimeoutId),this.tooltipElement&&(this.visible=!1,this.tooltipElement.style.opacity="0"),this.cleanup&&(this.cleanup(),this.cleanup=void 0)}initializePositioning(){this.triggerElement&&this.tooltipElement&&(this.cleanup&&this.cleanup(),this.cleanup=r.autoUpdate(this.triggerElement,this.tooltipElement,()=>{r.computePosition(this.triggerElement,this.tooltipElement,{placement:this.position,middleware:[r.offset(8),r.flip({padding:5}),r.shift({padding:5})]}).then(({x:n,y:i})=>{this.tooltipElement&&Object.assign(this.tooltipElement.style,{left:`${n}px`,top:`${i}px`})})}))}render(){return O.html`<slot></slot>`}},d([m.property({type:String})],exports.SchmancyTooltip.prototype,"text",2),d([m.property({type:String})],exports.SchmancyTooltip.prototype,"position",2),d([m.property({type:Number})],exports.SchmancyTooltip.prototype,"delay",2),d([m.property({type:Boolean})],exports.SchmancyTooltip.prototype,"disabled",2),d([m.state()],exports.SchmancyTooltip.prototype,"visible",2),exports.SchmancyTooltip=d([m.customElement("schmancy-tooltip")],exports.SchmancyTooltip),exports.tooltip=L;
7
- //# sourceMappingURL=tooltip-DrLzz4rf.cjs.map
7
+ //# sourceMappingURL=tooltip-CyI3NYzI.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"tooltip-DrLzz4rf.cjs","sources":["../src/tooltip/tooltip.directive.ts","../src/tooltip/tooltip.ts"],"sourcesContent":["import { arrow, autoUpdate, computePosition, flip, offset, Placement, shift, Strategy } from '@floating-ui/dom'\nimport { Directive, directive, ElementPart, ElementPartInfo, PartType } from 'lit/directive.js'\n\n// Store tooltip data for elements\nconst tooltipMap = new WeakMap<\n\tElement,\n\t{\n\t\ttooltipElement: HTMLElement\n\t\tarrowElement?: HTMLElement\n\t\tcleanup?: () => void\n\t\tshowTimeout?: number\n\t}\n>()\n\nclass TooltipDirective extends Directive {\n\tconstructor(partInfo: ElementPartInfo) {\n\t\tsuper(partInfo)\n\t\tif (partInfo.type !== PartType.ELEMENT) {\n\t\t\tthrow new Error('The tooltip directive can only be used on elements')\n\t\t}\n\t}\n\n\trender(\n\t\ttext: string,\n\t\toptions: {\n\t\t\tposition?: 'top' | 'right' | 'bottom' | 'left'\n\t\t\tdelay?: number\n\t\t\tshowArrow?: boolean\n\t\t} = {},\n\t) {\n\t\treturn { text, options }\n\t}\n\n\tupdate(part: ElementPart, [text, options = {}]: [string, any]) {\n\t\tconst element = part.element as HTMLElement\n\t\tconst position = options?.position || 'top'\n\t\tconst delay = options?.delay || 300\n\t\tconst showArrow = options?.showArrow !== false // Default to true\n\n\t\t// Get or create tooltip data\n\t\tlet tooltipData = tooltipMap.get(element)\n\n\t\tif (!tooltipData) {\n\t\t\t// Create tooltip element\n\t\t\tconst tooltipElement = document.createElement('div')\n\t\t\ttooltipElement.className = 'schmancy-tooltip'\n\n\t\t\t// Apply styles\n\t\t\tObject.assign(tooltipElement.style, {\n\t\t\t\tposition: 'absolute',\n\t\t\t\tzIndex: '10000',\n\t\t\t\tbackgroundColor: 'var(--schmancy-sys-color-surface-highest, #333)',\n\t\t\t\tcolor: 'var(--schmancy-sys-color-surface-on, white)',\n\t\t\t\tpadding: '8px 12px',\n\t\t\t\tborderRadius: '4px',\n\t\t\t\tfontSize: '14px',\n\t\t\t\tfontWeight: 'normal',\n\t\t\t\tmaxWidth: '300px',\n\t\t\t\tpointerEvents: 'none',\n\t\t\t\topacity: '0',\n\t\t\t\ttransition: 'opacity 150ms ease',\n\t\t\t\tboxShadow: 'var(--schmancy-sys-elevation-2)',\n\t\t\t\ttextAlign: 'center',\n\t\t\t\t// Important: start with visibility hidden to avoid flash\n\t\t\t\tvisibility: 'hidden',\n\t\t\t})\n\n\t\t\t// Create arrow element if needed\n\t\t\tlet arrowElement: HTMLElement | undefined\n\t\t\tif (showArrow) {\n\t\t\t\tarrowElement = document.createElement('div')\n\t\t\t\tarrowElement.className = 'schmancy-tooltip-arrow'\n\t\t\t\tObject.assign(arrowElement.style, {\n\t\t\t\t\tposition: 'absolute',\n\t\t\t\t\twidth: '8px',\n\t\t\t\t\theight: '8px',\n\t\t\t\t\tbackground: 'inherit',\n\t\t\t\t\tvisibility: 'hidden',\n\t\t\t\t\t// We'll rotate this to create an arrow\n\t\t\t\t\ttransform: 'rotate(45deg)',\n\t\t\t\t})\n\t\t\t\ttooltipElement.appendChild(arrowElement)\n\t\t\t}\n\n\t\t\t// Set ARIA attributes\n\t\t\ttooltipElement.setAttribute('role', 'tooltip')\n\n\t\t\t// Generate unique ID\n\t\t\tconst tooltipId = `tooltip-${Math.random().toString(36).slice(2, 9)}`\n\t\t\ttooltipElement.id = tooltipId\n\t\t\telement.setAttribute('aria-describedby', tooltipId)\n\n\t\t\t// Add to document\n\t\t\tdocument.body.appendChild(tooltipElement)\n\n\t\t\t// Create tooltip data\n\t\t\ttooltipData = {\n\t\t\t\ttooltipElement,\n\t\t\t\tarrowElement,\n\t\t\t}\n\n\t\t\ttooltipMap.set(element, tooltipData)\n\n\t\t\t// Define show handler\n\t\t\tconst showTooltip = () => {\n\t\t\t\tif (tooltipData?.showTimeout) {\n\t\t\t\t\tclearTimeout(tooltipData.showTimeout)\n\t\t\t\t}\n\n\t\t\t\ttooltipData.showTimeout = window.setTimeout(() => {\n\t\t\t\t\t// Set content\n\t\t\t\t\ttooltipData.tooltipElement.textContent = text\n\n\t\t\t\t\t// Add arrow back if it was removed\n\t\t\t\t\tif (showArrow && tooltipData.arrowElement && !tooltipData.tooltipElement.contains(tooltipData.arrowElement)) {\n\t\t\t\t\t\ttooltipData.tooltipElement.appendChild(tooltipData.arrowElement)\n\t\t\t\t\t}\n\n\t\t\t\t\t// Make sure element is visible first\n\t\t\t\t\ttooltipData.tooltipElement.style.visibility = 'visible'\n\n\t\t\t\t\t// Clean up existing positioning\n\t\t\t\t\tif (tooltipData.cleanup) {\n\t\t\t\t\t\ttooltipData.cleanup()\n\t\t\t\t\t}\n\n\t\t\t\t\t// Set up positioning\n\t\t\t\t\ttooltipData.cleanup = autoUpdate(element, tooltipData.tooltipElement, () =>\n\t\t\t\t\t\tupdatePosition(element, tooltipData, position, showArrow),\n\t\t\t\t\t)\n\n\t\t\t\t\t// Make opacity 1 after positioning is set up\n\t\t\t\t\trequestAnimationFrame(() => {\n\t\t\t\t\t\ttooltipData.tooltipElement.style.opacity = '1'\n\t\t\t\t\t})\n\t\t\t\t}, delay)\n\t\t\t}\n\n\t\t\t// Define hide handler\n\t\t\tconst hideTooltip = () => {\n\t\t\t\tif (tooltipData?.showTimeout) {\n\t\t\t\t\tclearTimeout(tooltipData.showTimeout)\n\t\t\t\t}\n\n\t\t\t\ttooltipData.tooltipElement.style.opacity = '0'\n\n\t\t\t\t// Set visibility to hidden after fade out\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\ttooltipData.tooltipElement.style.visibility = 'hidden'\n\t\t\t\t}, 150) // Match transition time\n\n\t\t\t\t// Clean up positioning\n\t\t\t\tif (tooltipData?.cleanup) {\n\t\t\t\t\ttooltipData.cleanup()\n\t\t\t\t\ttooltipData.cleanup = undefined\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Add event listeners\n\t\t\telement.addEventListener('mouseenter', showTooltip)\n\t\t\telement.addEventListener('focus', showTooltip)\n\t\t\telement.addEventListener('mouseleave', hideTooltip)\n\t\t\telement.addEventListener('blur', hideTooltip)\n\n\t\t\t// Add keyboard handler\n\t\t\tdocument.addEventListener('keydown', (e: KeyboardEvent) => {\n\t\t\t\tif (e.key === 'Escape' && tooltipData?.tooltipElement.style.opacity === '1') {\n\t\t\t\t\thideTooltip()\n\t\t\t\t}\n\t\t\t})\n\t\t} else {\n\t\t\t// Update content for existing tooltip\n\t\t\ttooltipData.tooltipElement.textContent = text\n\n\t\t\t// Update arrow visibility if needed\n\t\t\tif (tooltipData.arrowElement) {\n\t\t\t\ttooltipData.arrowElement.style.visibility = showArrow ? 'visible' : 'hidden'\n\t\t\t}\n\t\t}\n\n\t\treturn { text, options }\n\t}\n\n\tdisconnected(part: ElementPart) {\n\t\tconst element = part.element\n\t\tconst tooltipData = tooltipMap.get(element)\n\n\t\tif (tooltipData) {\n\t\t\t// Clean up\n\t\t\tif (tooltipData.showTimeout) {\n\t\t\t\tclearTimeout(tooltipData.showTimeout)\n\t\t\t}\n\n\t\t\tif (tooltipData.cleanup) {\n\t\t\t\ttooltipData.cleanup()\n\t\t\t}\n\n\t\t\t// Remove tooltip element\n\t\t\tif (document.body.contains(tooltipData.tooltipElement)) {\n\t\t\t\tdocument.body.removeChild(tooltipData.tooltipElement)\n\t\t\t}\n\n\t\t\t// Remove ARIA attributes\n\t\t\tif (element.hasAttribute('aria-describedby')) {\n\t\t\t\telement.removeAttribute('aria-describedby')\n\t\t\t}\n\n\t\t\t// Remove from WeakMap\n\t\t\ttooltipMap.delete(element)\n\t\t}\n\t}\n}\n\n// Separate positioning function for clarity and reuse\nasync function updatePosition(element: HTMLElement, tooltipData: any, position: string, showArrow: boolean) {\n\t// Use floating-ui to compute position\n\tconst middleware = [\n\t\toffset(8), // Distance from the element\n\t\tflip({\n\t\t\tfallbackPlacements: ['top', 'right', 'bottom', 'left'].filter(p => p !== position) as Placement[],\n\t\t\tpadding: 5, // How far from the edges before flipping\n\t\t}),\n\t\tshift({ padding: 5 }), // Keep it within viewport bounds\n\t]\n\n\t// Add arrow middleware if needed\n\tif (showArrow && tooltipData.arrowElement) {\n\t\tmiddleware.push(arrow({ element: tooltipData.arrowElement }))\n\t}\n\n\tconst { x, y, placement, middlewareData } = await computePosition(element, tooltipData.tooltipElement, {\n\t\tplacement: position as Placement,\n\t\tmiddleware,\n\t\tstrategy: 'fixed' as Strategy, // Fixed positioning works better across contexts\n\t})\n\n\t// Apply position\n\tObject.assign(tooltipData.tooltipElement.style, {\n\t\tleft: `${x}px`,\n\t\ttop: `${y}px`,\n\t\tposition: 'fixed',\n\t})\n\n\t// Position the arrow if it exists\n\tif (showArrow && tooltipData.arrowElement && middlewareData.arrow) {\n\t\tconst { x: arrowX, y: arrowY } = middlewareData.arrow\n\n\t\t// Determine which side the arrow should be on based on placement\n\t\tconst staticSide =\n\t\t\t{\n\t\t\t\ttop: 'bottom',\n\t\t\t\tright: 'left',\n\t\t\t\tbottom: 'top',\n\t\t\t\tleft: 'right',\n\t\t\t}[placement.split('-')[0]] || 'bottom'\n\n\t\t// Position the arrow\n\t\tObject.assign(tooltipData.arrowElement.style, {\n\t\t\tleft: arrowX != null ? `${arrowX}px` : '',\n\t\t\ttop: arrowY != null ? `${arrowY}px` : '',\n\t\t\t[staticSide]: '-4px', // Position the arrow on the correct side\n\t\t\tvisibility: 'visible',\n\t\t})\n\t}\n}\n\nexport const tooltip = directive(TooltipDirective)\n","import { TailwindElement } from '@mixins/tailwind.mixin'\nimport { html, css } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { fromEvent, merge, takeUntil } from 'rxjs'\nimport { computePosition, flip, shift, offset, autoUpdate, Placement } from '@floating-ui/dom'\n\n/**\n * A tooltip component that displays a text tooltip when hovering over content.\n * Addresses shadow DOM limitations by teleporting the tooltip to document.body.\n *\n * @element schmancy-tooltip\n */\n@customElement('schmancy-tooltip')\nexport class SchmancyTooltip extends TailwindElement(css`\n\t:host {\n\t\tdisplay: inline-block;\n\t\tposition: relative;\n\t}\n`) {\n\t@property({ type: String })\n\ttext = ''\n\n\t@property({ type: String })\n\tposition: 'top' | 'right' | 'bottom' | 'left' = 'top'\n\n\t@property({ type: Number })\n\tdelay = 50\n\n\t@property({ type: Boolean })\n\tdisabled = false\n\n\t@state() private visible = false\n\n\tprivate triggerElement: HTMLElement | null = null\n\tprivate tooltipElement: HTMLElement | null = null\n\tprivate cleanup: (() => void) | undefined\n\tprivate showTimeoutId: number | undefined\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\n\t\t// Create tooltip element once\n\t\tif (!this.tooltipElement) {\n\t\t\tthis.createTooltipElement()\n\t\t}\n\t}\n\n\tfirstUpdated() {\n\t\t// Wait for slotted elements to be available\n\t\tthis.updateComplete.then(() => {\n\t\t\t// Get the first slotted element as trigger\n\t\t\tconst slot = this.shadowRoot?.querySelector('slot') as HTMLSlotElement\n\t\t\tconst slottedElements = slot?.assignedElements() || []\n\n\t\t\tif (slottedElements.length > 0) {\n\t\t\t\tthis.triggerElement = slottedElements[0] as HTMLElement\n\t\t\t\tthis.setupEvents()\n\t\t\t}\n\t\t})\n\t}\n\n\tprivate createTooltipElement() {\n\t\t// Create the tooltip element in document.body\n\t\tthis.tooltipElement = document.createElement('div')\n\t\tthis.tooltipElement.className = 'schmancy-tooltip'\n\n\t\t// Apply styles\n\t\tObject.assign(this.tooltipElement.style, {\n\t\t\tposition: 'absolute',\n\t\t\tzIndex: '10000',\n\t\t\tbackgroundColor: 'var(--schmancy-sys-color-surface-highest, #333)',\n\t\t\tcolor: 'var(--schmancy-sys-color-surface-on, white)',\n\t\t\tpadding: '8px 12px',\n\t\t\tborderRadius: '4px',\n\t\t\tfontSize: '14px',\n\t\t\tfontWeight: 'normal',\n\t\t\tmaxWidth: '300px',\n\t\t\tpointerEvents: 'none',\n\t\t\topacity: '0',\n\t\t\ttransition: 'opacity 150ms ease',\n\t\t\tboxShadow: 'var(--schmancy-sys-elevation-2)',\n\t\t\ttextAlign: 'center',\n\t\t})\n\n\t\t// Set ARIA attributes\n\t\tthis.tooltipElement.setAttribute('role', 'tooltip')\n\n\t\t// Add to document\n\t\tdocument.body.appendChild(this.tooltipElement)\n\t}\n\n\tprivate setupEvents() {\n\t\tif (!this.triggerElement || this.disabled) return\n\n\t\t// Generate unique ID for ARIA\n\t\tconst tooltipId = `tooltip-${Math.random().toString(36).slice(2, 9)}`\n\t\tif (this.tooltipElement) {\n\t\t\tthis.tooltipElement.id = tooltipId\n\t\t\tthis.triggerElement.setAttribute('aria-describedby', tooltipId)\n\t\t}\n\n\t\t// Setup event streams using RxJS\n\t\tconst mouseEnter$ = fromEvent(this.triggerElement, 'mouseenter')\n\t\tconst focus$ = fromEvent(this.triggerElement, 'focus')\n\t\tconst mouseLeave$ = fromEvent(this.triggerElement, 'mouseleave')\n\t\tconst blur$ = fromEvent(this.triggerElement, 'blur')\n\n\t\t// Global escape key handler\n\t\tfromEvent<KeyboardEvent>(document, 'keydown')\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe(event => {\n\t\t\t\tif (event.key === 'Escape' && this.visible) {\n\t\t\t\t\tthis.hideTooltip()\n\t\t\t\t}\n\t\t\t})\n\n\t\t// Handle showing\n\t\tmerge(mouseEnter$, focus$)\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe(() => {\n\t\t\t\tthis.showTooltip()\n\t\t\t})\n\n\t\t// Handle hiding\n\t\tmerge(mouseLeave$, blur$)\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe(() => {\n\t\t\t\tthis.hideTooltip()\n\t\t\t})\n\t}\n\n\tdisconnectedCallback() {\n\t\t// Clean up\n\t\tif (this.tooltipElement && document.body.contains(this.tooltipElement)) {\n\t\t\tdocument.body.removeChild(this.tooltipElement)\n\t\t}\n\t\tthis.cleanup?.()\n\t\tclearTimeout(this.showTimeoutId)\n\t\tsuper.disconnectedCallback()\n\t}\n\n\tprivate showTooltip() {\n\t\tif (this.disabled || !this.tooltipElement || !this.triggerElement) return\n\n\t\t// Clear any existing timeout\n\t\tclearTimeout(this.showTimeoutId)\n\n\t\t// Set timeout for showing\n\t\tthis.showTimeoutId = window.setTimeout(() => {\n\t\t\t// Update content\n\t\t\tif (this.tooltipElement) {\n\t\t\t\tthis.tooltipElement.textContent = this.text\n\n\t\t\t\t// Make visible\n\t\t\t\tthis.visible = true\n\t\t\t\tthis.tooltipElement.style.opacity = '1'\n\n\t\t\t\t// Initialize positioning\n\t\t\t\tthis.initializePositioning()\n\t\t\t}\n\t\t}, this.delay)\n\t}\n\n\tprivate hideTooltip() {\n\t\t// Clear showing timeout\n\t\tclearTimeout(this.showTimeoutId)\n\n\t\t// Hide tooltip\n\t\tif (this.tooltipElement) {\n\t\t\tthis.visible = false\n\t\t\tthis.tooltipElement.style.opacity = '0'\n\t\t}\n\n\t\t// Clean up positioning\n\t\tif (this.cleanup) {\n\t\t\tthis.cleanup()\n\t\t\tthis.cleanup = undefined\n\t\t}\n\t}\n\n\tprivate initializePositioning() {\n\t\tif (!this.triggerElement || !this.tooltipElement) return\n\n\t\t// Clean up existing positioning\n\t\tif (this.cleanup) {\n\t\t\tthis.cleanup()\n\t\t}\n\n\t\t// Set up auto-updating position\n\t\tthis.cleanup = autoUpdate(this.triggerElement, this.tooltipElement, () => {\n\t\t\t// Compute position\n\t\t\tcomputePosition(this.triggerElement!, this.tooltipElement!, {\n\t\t\t\tplacement: this.position as Placement,\n\t\t\t\tmiddleware: [offset(8), flip({ padding: 5 }), shift({ padding: 5 })],\n\t\t\t}).then(({ x, y }) => {\n\t\t\t\t// Apply position\n\t\t\t\tif (this.tooltipElement) {\n\t\t\t\t\tObject.assign(this.tooltipElement.style, {\n\t\t\t\t\t\tleft: `${x}px`,\n\t\t\t\t\t\ttop: `${y}px`,\n\t\t\t\t\t})\n\t\t\t\t}\n\t\t\t})\n\t\t})\n\t}\n\n\trender() {\n\t\treturn html`<slot></slot>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-tooltip': SchmancyTooltip\n\t}\n}\n"],"names":["tooltipMap","WeakMap","TooltipDirective","Directive","partInfo","super","type","PartType","ELEMENT","Error","text","options","i","part","element","position","delay","showArrow","tooltipData","get","tooltipElement","textContent","arrowElement","style","visibility","document","createElement","className","Object","assign","zIndex","backgroundColor","color","padding","borderRadius","fontSize","fontWeight","maxWidth","pointerEvents","opacity","transition","boxShadow","textAlign","width","height","background","transform","appendChild","setAttribute","tooltipId","Math","random","toString","slice","id","body","set","showTooltip","showTimeout","clearTimeout","window","setTimeout","contains","cleanup","autoUpdate","async","middleware","offset","flip","fallbackPlacements","filter","p","shift","push","arrow","x","y","placement","middlewareData","computePosition","strategy","left","top","arrowX","arrowY","staticSide","right","bottom","split","requestAnimationFrame","hideTooltip","addEventListener","e","key","removeChild","hasAttribute","removeAttribute","delete","tooltip","directive","SchmancyTooltip","TailwindElement","css","constructor","arguments","this","disabled","visible","triggerElement","connectedCallback","createTooltipElement","updateComplete","then","slot","shadowRoot","querySelector","slottedElements","assignedElements","length","setupEvents","mouseEnter$","fromEvent","focus$","mouseLeave$","blur$","pipe","takeUntil","disconnecting","subscribe","event","merge","showTimeoutId","disconnectedCallback","initializePositioning","render","html","__decorateClass","property","String","prototype","Number","Boolean","state","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"tooltip-CyI3NYzI.cjs","sources":["../src/tooltip/tooltip.directive.ts","../src/tooltip/tooltip.ts"],"sourcesContent":["import { arrow, autoUpdate, computePosition, flip, offset, Placement, shift, Strategy } from '@floating-ui/dom'\nimport { Directive, directive, ElementPart, ElementPartInfo, PartType } from 'lit/directive.js'\n\n// Store tooltip data for elements\nconst tooltipMap = new WeakMap<\n\tElement,\n\t{\n\t\ttooltipElement: HTMLElement\n\t\tarrowElement?: HTMLElement\n\t\tcleanup?: () => void\n\t\tshowTimeout?: number\n\t}\n>()\n\nclass TooltipDirective extends Directive {\n\tconstructor(partInfo: ElementPartInfo) {\n\t\tsuper(partInfo)\n\t\tif (partInfo.type !== PartType.ELEMENT) {\n\t\t\tthrow new Error('The tooltip directive can only be used on elements')\n\t\t}\n\t}\n\n\trender(\n\t\ttext: string,\n\t\toptions: {\n\t\t\tposition?: 'top' | 'right' | 'bottom' | 'left'\n\t\t\tdelay?: number\n\t\t\tshowArrow?: boolean\n\t\t} = {},\n\t) {\n\t\treturn { text, options }\n\t}\n\n\tupdate(part: ElementPart, [text, options = {}]: [string, any]) {\n\t\tconst element = part.element as HTMLElement\n\t\tconst position = options?.position || 'top'\n\t\tconst delay = options?.delay || 300\n\t\tconst showArrow = options?.showArrow !== false // Default to true\n\n\t\t// Get or create tooltip data\n\t\tlet tooltipData = tooltipMap.get(element)\n\n\t\tif (!tooltipData) {\n\t\t\t// Create tooltip element\n\t\t\tconst tooltipElement = document.createElement('div')\n\t\t\ttooltipElement.className = 'schmancy-tooltip'\n\n\t\t\t// Apply styles\n\t\t\tObject.assign(tooltipElement.style, {\n\t\t\t\tposition: 'absolute',\n\t\t\t\tzIndex: '10000',\n\t\t\t\tbackgroundColor: 'var(--schmancy-sys-color-surface-highest, #333)',\n\t\t\t\tcolor: 'var(--schmancy-sys-color-surface-on, white)',\n\t\t\t\tpadding: '8px 12px',\n\t\t\t\tborderRadius: '4px',\n\t\t\t\tfontSize: '14px',\n\t\t\t\tfontWeight: 'normal',\n\t\t\t\tmaxWidth: '300px',\n\t\t\t\tpointerEvents: 'none',\n\t\t\t\topacity: '0',\n\t\t\t\ttransition: 'opacity 150ms ease',\n\t\t\t\tboxShadow: 'var(--schmancy-sys-elevation-2)',\n\t\t\t\ttextAlign: 'center',\n\t\t\t\t// Important: start with visibility hidden to avoid flash\n\t\t\t\tvisibility: 'hidden',\n\t\t\t})\n\n\t\t\t// Create arrow element if needed\n\t\t\tlet arrowElement: HTMLElement | undefined\n\t\t\tif (showArrow) {\n\t\t\t\tarrowElement = document.createElement('div')\n\t\t\t\tarrowElement.className = 'schmancy-tooltip-arrow'\n\t\t\t\tObject.assign(arrowElement.style, {\n\t\t\t\t\tposition: 'absolute',\n\t\t\t\t\twidth: '8px',\n\t\t\t\t\theight: '8px',\n\t\t\t\t\tbackground: 'inherit',\n\t\t\t\t\tvisibility: 'hidden',\n\t\t\t\t\t// We'll rotate this to create an arrow\n\t\t\t\t\ttransform: 'rotate(45deg)',\n\t\t\t\t})\n\t\t\t\ttooltipElement.appendChild(arrowElement)\n\t\t\t}\n\n\t\t\t// Set ARIA attributes\n\t\t\ttooltipElement.setAttribute('role', 'tooltip')\n\n\t\t\t// Generate unique ID\n\t\t\tconst tooltipId = `tooltip-${Math.random().toString(36).slice(2, 9)}`\n\t\t\ttooltipElement.id = tooltipId\n\t\t\telement.setAttribute('aria-describedby', tooltipId)\n\n\t\t\t// Add to document\n\t\t\tdocument.body.appendChild(tooltipElement)\n\n\t\t\t// Create tooltip data\n\t\t\ttooltipData = {\n\t\t\t\ttooltipElement,\n\t\t\t\tarrowElement,\n\t\t\t}\n\n\t\t\ttooltipMap.set(element, tooltipData)\n\n\t\t\t// Define show handler\n\t\t\tconst showTooltip = () => {\n\t\t\t\tif (tooltipData?.showTimeout) {\n\t\t\t\t\tclearTimeout(tooltipData.showTimeout)\n\t\t\t\t}\n\n\t\t\t\ttooltipData.showTimeout = window.setTimeout(() => {\n\t\t\t\t\t// Set content\n\t\t\t\t\ttooltipData.tooltipElement.textContent = text\n\n\t\t\t\t\t// Add arrow back if it was removed\n\t\t\t\t\tif (showArrow && tooltipData.arrowElement && !tooltipData.tooltipElement.contains(tooltipData.arrowElement)) {\n\t\t\t\t\t\ttooltipData.tooltipElement.appendChild(tooltipData.arrowElement)\n\t\t\t\t\t}\n\n\t\t\t\t\t// Make sure element is visible first\n\t\t\t\t\ttooltipData.tooltipElement.style.visibility = 'visible'\n\n\t\t\t\t\t// Clean up existing positioning\n\t\t\t\t\tif (tooltipData.cleanup) {\n\t\t\t\t\t\ttooltipData.cleanup()\n\t\t\t\t\t}\n\n\t\t\t\t\t// Set up positioning\n\t\t\t\t\ttooltipData.cleanup = autoUpdate(element, tooltipData.tooltipElement, () =>\n\t\t\t\t\t\tupdatePosition(element, tooltipData, position, showArrow),\n\t\t\t\t\t)\n\n\t\t\t\t\t// Make opacity 1 after positioning is set up\n\t\t\t\t\trequestAnimationFrame(() => {\n\t\t\t\t\t\ttooltipData.tooltipElement.style.opacity = '1'\n\t\t\t\t\t})\n\t\t\t\t}, delay)\n\t\t\t}\n\n\t\t\t// Define hide handler\n\t\t\tconst hideTooltip = () => {\n\t\t\t\tif (tooltipData?.showTimeout) {\n\t\t\t\t\tclearTimeout(tooltipData.showTimeout)\n\t\t\t\t}\n\n\t\t\t\ttooltipData.tooltipElement.style.opacity = '0'\n\n\t\t\t\t// Set visibility to hidden after fade out\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\ttooltipData.tooltipElement.style.visibility = 'hidden'\n\t\t\t\t}, 150) // Match transition time\n\n\t\t\t\t// Clean up positioning\n\t\t\t\tif (tooltipData?.cleanup) {\n\t\t\t\t\ttooltipData.cleanup()\n\t\t\t\t\ttooltipData.cleanup = undefined\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Add event listeners\n\t\t\telement.addEventListener('mouseenter', showTooltip)\n\t\t\telement.addEventListener('focus', showTooltip)\n\t\t\telement.addEventListener('mouseleave', hideTooltip)\n\t\t\telement.addEventListener('blur', hideTooltip)\n\n\t\t\t// Add keyboard handler\n\t\t\tdocument.addEventListener('keydown', (e: KeyboardEvent) => {\n\t\t\t\tif (e.key === 'Escape' && tooltipData?.tooltipElement.style.opacity === '1') {\n\t\t\t\t\thideTooltip()\n\t\t\t\t}\n\t\t\t})\n\t\t} else {\n\t\t\t// Update content for existing tooltip\n\t\t\ttooltipData.tooltipElement.textContent = text\n\n\t\t\t// Update arrow visibility if needed\n\t\t\tif (tooltipData.arrowElement) {\n\t\t\t\ttooltipData.arrowElement.style.visibility = showArrow ? 'visible' : 'hidden'\n\t\t\t}\n\t\t}\n\n\t\treturn { text, options }\n\t}\n\n\tdisconnected(part: ElementPart) {\n\t\tconst element = part.element\n\t\tconst tooltipData = tooltipMap.get(element)\n\n\t\tif (tooltipData) {\n\t\t\t// Clean up\n\t\t\tif (tooltipData.showTimeout) {\n\t\t\t\tclearTimeout(tooltipData.showTimeout)\n\t\t\t}\n\n\t\t\tif (tooltipData.cleanup) {\n\t\t\t\ttooltipData.cleanup()\n\t\t\t}\n\n\t\t\t// Remove tooltip element\n\t\t\tif (document.body.contains(tooltipData.tooltipElement)) {\n\t\t\t\tdocument.body.removeChild(tooltipData.tooltipElement)\n\t\t\t}\n\n\t\t\t// Remove ARIA attributes\n\t\t\tif (element.hasAttribute('aria-describedby')) {\n\t\t\t\telement.removeAttribute('aria-describedby')\n\t\t\t}\n\n\t\t\t// Remove from WeakMap\n\t\t\ttooltipMap.delete(element)\n\t\t}\n\t}\n}\n\n// Separate positioning function for clarity and reuse\nasync function updatePosition(element: HTMLElement, tooltipData: any, position: string, showArrow: boolean) {\n\t// Use floating-ui to compute position\n\tconst middleware = [\n\t\toffset(8), // Distance from the element\n\t\tflip({\n\t\t\tfallbackPlacements: ['top', 'right', 'bottom', 'left'].filter(p => p !== position) as Placement[],\n\t\t\tpadding: 5, // How far from the edges before flipping\n\t\t}),\n\t\tshift({ padding: 5 }), // Keep it within viewport bounds\n\t]\n\n\t// Add arrow middleware if needed\n\tif (showArrow && tooltipData.arrowElement) {\n\t\tmiddleware.push(arrow({ element: tooltipData.arrowElement }))\n\t}\n\n\tconst { x, y, placement, middlewareData } = await computePosition(element, tooltipData.tooltipElement, {\n\t\tplacement: position as Placement,\n\t\tmiddleware,\n\t\tstrategy: 'fixed' as Strategy, // Fixed positioning works better across contexts\n\t})\n\n\t// Apply position\n\tObject.assign(tooltipData.tooltipElement.style, {\n\t\tleft: `${x}px`,\n\t\ttop: `${y}px`,\n\t\tposition: 'fixed',\n\t})\n\n\t// Position the arrow if it exists\n\tif (showArrow && tooltipData.arrowElement && middlewareData.arrow) {\n\t\tconst { x: arrowX, y: arrowY } = middlewareData.arrow\n\n\t\t// Determine which side the arrow should be on based on placement\n\t\tconst staticSide =\n\t\t\t{\n\t\t\t\ttop: 'bottom',\n\t\t\t\tright: 'left',\n\t\t\t\tbottom: 'top',\n\t\t\t\tleft: 'right',\n\t\t\t}[placement.split('-')[0]] || 'bottom'\n\n\t\t// Position the arrow\n\t\tObject.assign(tooltipData.arrowElement.style, {\n\t\t\tleft: arrowX != null ? `${arrowX}px` : '',\n\t\t\ttop: arrowY != null ? `${arrowY}px` : '',\n\t\t\t[staticSide]: '-4px', // Position the arrow on the correct side\n\t\t\tvisibility: 'visible',\n\t\t})\n\t}\n}\n\nexport const tooltip = directive(TooltipDirective)\n","import { TailwindElement } from '@mixins/tailwind.mixin'\nimport { html, css } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { fromEvent, merge, takeUntil } from 'rxjs'\nimport { computePosition, flip, shift, offset, autoUpdate, Placement } from '@floating-ui/dom'\n\n/**\n * A tooltip component that displays a text tooltip when hovering over content.\n * Addresses shadow DOM limitations by teleporting the tooltip to document.body.\n *\n * @element schmancy-tooltip\n */\n@customElement('schmancy-tooltip')\nexport class SchmancyTooltip extends TailwindElement(css`\n\t:host {\n\t\tdisplay: inline-block;\n\t\tposition: relative;\n\t}\n`) {\n\t@property({ type: String })\n\ttext = ''\n\n\t@property({ type: String })\n\tposition: 'top' | 'right' | 'bottom' | 'left' = 'top'\n\n\t@property({ type: Number })\n\tdelay = 50\n\n\t@property({ type: Boolean })\n\tdisabled = false\n\n\t@state() private visible = false\n\n\tprivate triggerElement: HTMLElement | null = null\n\tprivate tooltipElement: HTMLElement | null = null\n\tprivate cleanup: (() => void) | undefined\n\tprivate showTimeoutId: number | undefined\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\n\t\t// Create tooltip element once\n\t\tif (!this.tooltipElement) {\n\t\t\tthis.createTooltipElement()\n\t\t}\n\t}\n\n\tfirstUpdated() {\n\t\t// Wait for slotted elements to be available\n\t\tthis.updateComplete.then(() => {\n\t\t\t// Get the first slotted element as trigger\n\t\t\tconst slot = this.shadowRoot?.querySelector('slot') as HTMLSlotElement\n\t\t\tconst slottedElements = slot?.assignedElements() || []\n\n\t\t\tif (slottedElements.length > 0) {\n\t\t\t\tthis.triggerElement = slottedElements[0] as HTMLElement\n\t\t\t\tthis.setupEvents()\n\t\t\t}\n\t\t})\n\t}\n\n\tprivate createTooltipElement() {\n\t\t// Create the tooltip element in document.body\n\t\tthis.tooltipElement = document.createElement('div')\n\t\tthis.tooltipElement.className = 'schmancy-tooltip'\n\n\t\t// Apply styles\n\t\tObject.assign(this.tooltipElement.style, {\n\t\t\tposition: 'absolute',\n\t\t\tzIndex: '10000',\n\t\t\tbackgroundColor: 'var(--schmancy-sys-color-surface-highest, #333)',\n\t\t\tcolor: 'var(--schmancy-sys-color-surface-on, white)',\n\t\t\tpadding: '8px 12px',\n\t\t\tborderRadius: '4px',\n\t\t\tfontSize: '14px',\n\t\t\tfontWeight: 'normal',\n\t\t\tmaxWidth: '300px',\n\t\t\tpointerEvents: 'none',\n\t\t\topacity: '0',\n\t\t\ttransition: 'opacity 150ms ease',\n\t\t\tboxShadow: 'var(--schmancy-sys-elevation-2)',\n\t\t\ttextAlign: 'center',\n\t\t})\n\n\t\t// Set ARIA attributes\n\t\tthis.tooltipElement.setAttribute('role', 'tooltip')\n\n\t\t// Add to document\n\t\tdocument.body.appendChild(this.tooltipElement)\n\t}\n\n\tprivate setupEvents() {\n\t\tif (!this.triggerElement || this.disabled) return\n\n\t\t// Generate unique ID for ARIA\n\t\tconst tooltipId = `tooltip-${Math.random().toString(36).slice(2, 9)}`\n\t\tif (this.tooltipElement) {\n\t\t\tthis.tooltipElement.id = tooltipId\n\t\t\tthis.triggerElement.setAttribute('aria-describedby', tooltipId)\n\t\t}\n\n\t\t// Setup event streams using RxJS\n\t\tconst mouseEnter$ = fromEvent(this.triggerElement, 'mouseenter')\n\t\tconst focus$ = fromEvent(this.triggerElement, 'focus')\n\t\tconst mouseLeave$ = fromEvent(this.triggerElement, 'mouseleave')\n\t\tconst blur$ = fromEvent(this.triggerElement, 'blur')\n\n\t\t// Global escape key handler\n\t\tfromEvent<KeyboardEvent>(document, 'keydown')\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe(event => {\n\t\t\t\tif (event.key === 'Escape' && this.visible) {\n\t\t\t\t\tthis.hideTooltip()\n\t\t\t\t}\n\t\t\t})\n\n\t\t// Handle showing\n\t\tmerge(mouseEnter$, focus$)\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe(() => {\n\t\t\t\tthis.showTooltip()\n\t\t\t})\n\n\t\t// Handle hiding\n\t\tmerge(mouseLeave$, blur$)\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe(() => {\n\t\t\t\tthis.hideTooltip()\n\t\t\t})\n\t}\n\n\tdisconnectedCallback() {\n\t\t// Clean up\n\t\tif (this.tooltipElement && document.body.contains(this.tooltipElement)) {\n\t\t\tdocument.body.removeChild(this.tooltipElement)\n\t\t}\n\t\tthis.cleanup?.()\n\t\tclearTimeout(this.showTimeoutId)\n\t\tsuper.disconnectedCallback()\n\t}\n\n\tprivate showTooltip() {\n\t\tif (this.disabled || !this.tooltipElement || !this.triggerElement) return\n\n\t\t// Clear any existing timeout\n\t\tclearTimeout(this.showTimeoutId)\n\n\t\t// Set timeout for showing\n\t\tthis.showTimeoutId = window.setTimeout(() => {\n\t\t\t// Update content\n\t\t\tif (this.tooltipElement) {\n\t\t\t\tthis.tooltipElement.textContent = this.text\n\n\t\t\t\t// Make visible\n\t\t\t\tthis.visible = true\n\t\t\t\tthis.tooltipElement.style.opacity = '1'\n\n\t\t\t\t// Initialize positioning\n\t\t\t\tthis.initializePositioning()\n\t\t\t}\n\t\t}, this.delay)\n\t}\n\n\tprivate hideTooltip() {\n\t\t// Clear showing timeout\n\t\tclearTimeout(this.showTimeoutId)\n\n\t\t// Hide tooltip\n\t\tif (this.tooltipElement) {\n\t\t\tthis.visible = false\n\t\t\tthis.tooltipElement.style.opacity = '0'\n\t\t}\n\n\t\t// Clean up positioning\n\t\tif (this.cleanup) {\n\t\t\tthis.cleanup()\n\t\t\tthis.cleanup = undefined\n\t\t}\n\t}\n\n\tprivate initializePositioning() {\n\t\tif (!this.triggerElement || !this.tooltipElement) return\n\n\t\t// Clean up existing positioning\n\t\tif (this.cleanup) {\n\t\t\tthis.cleanup()\n\t\t}\n\n\t\t// Set up auto-updating position\n\t\tthis.cleanup = autoUpdate(this.triggerElement, this.tooltipElement, () => {\n\t\t\t// Compute position\n\t\t\tcomputePosition(this.triggerElement!, this.tooltipElement!, {\n\t\t\t\tplacement: this.position as Placement,\n\t\t\t\tmiddleware: [offset(8), flip({ padding: 5 }), shift({ padding: 5 })],\n\t\t\t}).then(({ x, y }) => {\n\t\t\t\t// Apply position\n\t\t\t\tif (this.tooltipElement) {\n\t\t\t\t\tObject.assign(this.tooltipElement.style, {\n\t\t\t\t\t\tleft: `${x}px`,\n\t\t\t\t\t\ttop: `${y}px`,\n\t\t\t\t\t})\n\t\t\t\t}\n\t\t\t})\n\t\t})\n\t}\n\n\trender() {\n\t\treturn html`<slot></slot>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-tooltip': SchmancyTooltip\n\t}\n}\n"],"names":["tooltipMap","WeakMap","TooltipDirective","Directive","partInfo","super","type","PartType","ELEMENT","Error","text","options","i","part","element","position","delay","showArrow","tooltipData","get","tooltipElement","textContent","arrowElement","style","visibility","document","createElement","className","Object","assign","zIndex","backgroundColor","color","padding","borderRadius","fontSize","fontWeight","maxWidth","pointerEvents","opacity","transition","boxShadow","textAlign","width","height","background","transform","appendChild","setAttribute","tooltipId","Math","random","toString","slice","id","body","set","showTooltip","showTimeout","clearTimeout","window","setTimeout","contains","cleanup","autoUpdate","async","middleware","offset","flip","fallbackPlacements","filter","p","shift","push","arrow","x","y","placement","middlewareData","computePosition","strategy","left","top","arrowX","arrowY","staticSide","right","bottom","split","requestAnimationFrame","hideTooltip","addEventListener","e","key","removeChild","hasAttribute","removeAttribute","delete","tooltip","directive","SchmancyTooltip","TailwindElement","css","constructor","arguments","this","disabled","visible","triggerElement","connectedCallback","createTooltipElement","updateComplete","then","slot","shadowRoot","querySelector","slottedElements","assignedElements","length","setupEvents","mouseEnter$","fromEvent","focus$","mouseLeave$","blur$","pipe","takeUntil","disconnecting","subscribe","event","merge","showTimeoutId","disconnectedCallback","initializePositioning","render","html","__decorateClass","property","String","prototype","Number","Boolean","state","customElement"],"mappings":"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"}
package/dist/tooltip.cjs CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./tooltip-DrLzz4rf.cjs");Object.defineProperty(exports,"SchmancyTooltip",{enumerable:!0,get:()=>e.SchmancyTooltip}),exports.tooltip=e.tooltip;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./tooltip-CyI3NYzI.cjs");Object.defineProperty(exports,"SchmancyTooltip",{enumerable:!0,get:()=>e.SchmancyTooltip}),exports.tooltip=e.tooltip;
2
2
  //# sourceMappingURL=tooltip.cjs.map
package/dist/tooltip.js CHANGED
@@ -1,4 +1,4 @@
1
- import { S as a, t as p } from "./tooltip-Bfcu9uoC.js";
1
+ import { S as a, t as p } from "./tooltip-Bn-UWxd4.js";
2
2
  export {
3
3
  a as SchmancyTooltip,
4
4
  p as tooltip
@@ -1,7 +1,7 @@
1
1
  import { fromEvent as p, takeUntil as c, tap as g, merge as m, switchMap as f, zip as u } from "rxjs";
2
2
  import "lit/directives/class-map.js";
3
3
  import "lit/directives/style-map.js";
4
- import { T as y } from "./tailwind.mixin-k9HTphsu.js";
4
+ import { T as y } from "./tailwind.mixin-DPUboU_5.js";
5
5
  import { css as v, html as b } from "lit";
6
6
  import { property as S, query as h, customElement as w } from "lit/decorators.js";
7
7
  var k = Object.defineProperty, j = Object.getOwnPropertyDescriptor, l = (e, s, o, i) => {
@@ -61,4 +61,4 @@ l([S({ type: Boolean })], n.prototype, "open", 2), l([h("#toggler")], n.prototyp
61
61
  export {
62
62
  n as S
63
63
  };
64
- //# sourceMappingURL=tree-n0KxiiWX.js.map
64
+ //# sourceMappingURL=tree-D2g2zq2B.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"tree-n0KxiiWX.js","sources":["../src/tree/tree.ts"],"sourcesContent":["import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\nimport { fromEvent, merge, switchMap, takeUntil, tap, zip } from 'rxjs'\n\n/**\n * @element schmancy-tree\n * @slot root - The root element of the tree\n * @slot - The children of the tree\n */\n@customElement('schmancy-tree')\nexport class SchmancyTree extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tposition: relative;\n\t\tbackground-color: initial;\n\t}\n\t::slotted([slot='root']) {\n\t\twidth: 100%;\n\t\ttext-align: left;\n\t}\n\t::slotted([slot='root'] + *) {\n\t\tmargin-top: 0.5rem;\n\t}\n`) {\n\t/**\n\t * Whether the tree’s children are visible\n\t */\n\t@property({ type: Boolean }) open = false\n\n\t@query('#toggler') toggler!: HTMLSlotElement\n\t@query('slot:not([name=\"root\"])') defaultSlot!: HTMLSlotElement\n\n\t// Since it's actually a <schmancy-button>, use HTMLElement or a custom type\n\t@query('#chevron') chevron!: HTMLElement\n\n\tfirstUpdated() {\n\t\t// Hide or show the slot initially based on `open`\n\t\tif (!this.open) {\n\t\t\tthis.defaultSlot.hidden = true\n\t\t}\n\n\t\t// Root toggler\n\t\tconst toggleClick$ = fromEvent<MouseEvent>(this.toggler, 'click').pipe(\n\t\t\ttakeUntil(this.disconnecting),\n\t\t\ttap(e => {\n\t\t\t\te.preventDefault()\n\t\t\t\te.stopPropagation()\n\t\t\t\tthis.dispatchEvent(new CustomEvent('toggle', { bubbles: true, composed: true }))\n\t\t\t}),\n\t\t)\n\n\t\t// Chevron (the schmancy-button) click\n\t\tconst chevronClick$ = fromEvent<MouseEvent>(this.chevron, 'click')\n\n\t\tmerge(toggleClick$, chevronClick$)\n\t\t\t.pipe(\n\t\t\t\tswitchMap(() => {\n\t\t\t\t\t// 1. Animate the chevron rotation\n\t\t\t\t\t// If `open` is true, rotate from 180 -> 0; if false, from 0 -> 180\n\t\t\t\t\tconst fromDeg = this.open ? 180 : 0\n\t\t\t\t\tconst toDeg = this.open ? 0 : 180\n\t\t\t\t\tconst chevronAnimation = this.chevron.animate(\n\t\t\t\t\t\t[{ transform: `rotate(${fromDeg}deg)` }, { transform: `rotate(${toDeg}deg)` }],\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tduration: 150,\n\t\t\t\t\t\t\teasing: 'ease-in',\n\t\t\t\t\t\t\tfill: 'forwards',\n\t\t\t\t\t\t},\n\t\t\t\t\t)\n\n\t\t\t\t\t// 2. Animate the slot’s height + opacity\n\t\t\t\t\tif (!this.open) {\n\t\t\t\t\t\t// We are about to open, so remove `hidden` to measure scrollHeight\n\t\t\t\t\t\tthis.defaultSlot.hidden = false\n\t\t\t\t\t}\n\n\t\t\t\t\tconst fromOpacity = this.open ? 1 : 0\n\t\t\t\t\tconst toOpacity = this.open ? 0 : 1\n\n\t\t\t\t\tconst slotAnimation = this.defaultSlot.animate([{ opacity: fromOpacity }, { opacity: toOpacity }], {\n\t\t\t\t\t\tduration: 150,\n\t\t\t\t\t\teasing: 'ease-out',\n\t\t\t\t\t\tfill: 'forwards',\n\t\t\t\t\t})\n\n\t\t\t\t\t// Hide the slot if we just closed it\n\t\t\t\t\tslotAnimation.onfinish = () => {\n\t\t\t\t\t\tif (this.open) {\n\t\t\t\t\t\t\tthis.defaultSlot.hidden = true\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tthis.defaultSlot.style.height = 'auto'\n\t\t\t\t\t\t\tthis.defaultSlot.style.opacity = '1'\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Return an Observable that completes when both animations finish\n\t\t\t\t\treturn zip(fromEvent(chevronAnimation, 'finish'), fromEvent(slotAnimation, 'finish')).pipe(\n\t\t\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t\t\t)\n\t\t\t\t}),\n\t\t\t\ttap(() => {\n\t\t\t\t\t// Flip the open state\n\t\t\t\t\tthis.open = !this.open\n\t\t\t\t}),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<div class=\"flex content-center items-center justify-between\">\n\t\t\t\t<!-- Root toggler content -->\n\t\t\t\t<slot id=\"toggler\" name=\"root\"></slot>\n\n\t\t\t\t<!-- The chevron or arrow symbol -->\n\t\t\t\t<!-- Stop propagation on the schmancy-button itself just to avoid double triggers -->\n\t\t\t\t<schmancy-button slot=\"trailing\" id=\"chevron\" @click=${(e: Event) => e.stopPropagation()}> ⌅ </schmancy-button>\n\t\t\t</div>\n\n\t\t\t<!-- The default slot: tree children -->\n\t\t\t<slot></slot>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-tree': SchmancyTree\n\t}\n}\n"],"names":["SchmancyTree","TailwindElement","css","super","arguments","this","open","defaultSlot","hidden","toggleClick$","fromEvent","toggler","pipe","takeUntil","disconnecting","tap","e","preventDefault","stopPropagation","dispatchEvent","CustomEvent","bubbles","composed","chevronClick$","chevron","merge","switchMap","fromDeg","toDeg","chevronAnimation","animate","transform","duration","easing","fill","fromOpacity","toOpacity","slotAnimation","opacity","onfinish","style","height","zip","subscribe","render","html","__decorateClass","property","type","Boolean","prototype","query","customElement"],"mappings":";;;;;;;;;;AAWa,IAAAA,IAAN,cAA2BC,EAAgBC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,CAA3C,EAAA;AAAA,EAAA;AAAAC,UAAAC,GAAAA,SAAAA,GAiB8BC,KAAAC,OAAAA;AAAAA,EAAA;AAAA,EAQpC,eAEMD;AAAAA,SAAKC,SACTD,KAAKE,YAAYC;AAIlB,UAAMC,IAAeC,EAAsBL,KAAKM,SAAS,OAAA,EAASC,KACjEC,EAAUR,KAAKS,aACfC,GAAAA,EAASC,CAAAA;AACRA,MAAAA,EAAEC,eAAAA,GACFD,EAAEE,gBAAAA,GACGb,KAAAc,cAAc,IAAIC,YAAY,UAAU,EAAEC,aAAeC,UAAAA,GAAiB,CAAA,CAAA;AAAA,IAAA,CAAA,CAAA,GAK3EC,IAAgBb,EAAsBL,KAAKmB,SAAS,OAAA;AAEpDC,IAAAA,EAAAhB,GAAcc,CAAAA,EAClBX,KACAc,EAAU;AAGH,YAAAC,IAAUtB,KAAKC,OAAO,MAAM,GAC5BsB,IAAQvB,KAAKC,OAAO,IAAI,KACxBuB,IAAmBxB,KAAKmB,QAAQM,QACrC,CAAC,EAAEC,WAAW,UAAUJ,CAAiB,OAAA,GAAA,EAAEI,WAAW,UAAUH,CAAAA,OAAAA,CAAAA,GAChE,EACCI,UAAU,KACVC,QAAQ,WACRC,MAAM,WAKH7B,CAAAA;AAAAA,WAAKC,SAETD,KAAKE,YAAYC,SAAS;AAGrB,YAAA2B,IAAc9B,KAAKC,OAAO,IAAI,GAC9B8B,IAAY/B,KAAKC,OAAO,IAAI,GAE5B+B,IAAgBhC,KAAKE,YAAYuB,QAAQ,CAAC,EAAEQ,SAASH,EAAAA,GAAe,EAAEG,SAASF,EAAAA,CAAAA,GAAc,EAClGJ,UAAU,KACVC,QAAQ,YACRC,MAAM,WAcA,CAAA;AAAA,aAVPG,EAAcE,WAAW,MAAA;AACpBlC,aAAKC,OACRD,KAAKE,YAAYC,SAAAA,MAEZH,KAAAE,YAAYiC,MAAMC,SAAS,QAC3BpC,KAAAE,YAAYiC,MAAMF,UAAU;AAAA,MAAA,GAK5BI,EAAIhC,EAAUmB,GAAkB,QAAA,GAAWnB,EAAU2B,GAAe,QAAA,CAAA,EAAWzB,KACrFC,EAAUR,KAAKS,aAChB,CAAA;AAAA,IAAA,CAAA,GAEDC,EAAI,MAEEV;AAAAA,WAAAC,QAAQD,KAAKC;AAAAA,IAAA,CAEnBO,GAAAA,EAAUR,KAAKS,aAEf6B,CAAAA,EAAAA,UAAAA;AAAAA,EAAU;AAAA,EAGb,SAAAC;AACQ,WAAAC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,2DAOmD7B,CAAAA,MAAaA,EAAEE,gBAAAA,CAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,EAAiB;AAAA;AA1F9D4B,EAAA,CAA5BC,EAAS,EAAEC,MAAMC,aAjBNjD,EAiBiBkD,WAAA,QAAA,CAAA,GAEVJ,EAAA,CAAlBK,EAAM,cAnBKnD,EAmBOkD,WAAA,WAAA,CACeJ,GAAAA,EAAA,CAAjCK,EAAM,6BApBKnD,EAoBsBkD,WAAA,eAAA,CAGfJ,GAAAA,EAAA,CAAlBK,EAAM,UAAA,CAAA,GAvBKnD,EAuBOkD,WAAA,WAAA,CAvBPlD,GAAAA,IAAN8C,EAAA,CADNM,EAAc,mBACFpD;"}
1
+ {"version":3,"file":"tree-D2g2zq2B.js","sources":["../src/tree/tree.ts"],"sourcesContent":["import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\nimport { fromEvent, merge, switchMap, takeUntil, tap, zip } from 'rxjs'\n\n/**\n * @element schmancy-tree\n * @slot root - The root element of the tree\n * @slot - The children of the tree\n */\n@customElement('schmancy-tree')\nexport class SchmancyTree extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tposition: relative;\n\t\tbackground-color: initial;\n\t}\n\t::slotted([slot='root']) {\n\t\twidth: 100%;\n\t\ttext-align: left;\n\t}\n\t::slotted([slot='root'] + *) {\n\t\tmargin-top: 0.5rem;\n\t}\n`) {\n\t/**\n\t * Whether the tree’s children are visible\n\t */\n\t@property({ type: Boolean }) open = false\n\n\t@query('#toggler') toggler!: HTMLSlotElement\n\t@query('slot:not([name=\"root\"])') defaultSlot!: HTMLSlotElement\n\n\t// Since it's actually a <schmancy-button>, use HTMLElement or a custom type\n\t@query('#chevron') chevron!: HTMLElement\n\n\tfirstUpdated() {\n\t\t// Hide or show the slot initially based on `open`\n\t\tif (!this.open) {\n\t\t\tthis.defaultSlot.hidden = true\n\t\t}\n\n\t\t// Root toggler\n\t\tconst toggleClick$ = fromEvent<MouseEvent>(this.toggler, 'click').pipe(\n\t\t\ttakeUntil(this.disconnecting),\n\t\t\ttap(e => {\n\t\t\t\te.preventDefault()\n\t\t\t\te.stopPropagation()\n\t\t\t\tthis.dispatchEvent(new CustomEvent('toggle', { bubbles: true, composed: true }))\n\t\t\t}),\n\t\t)\n\n\t\t// Chevron (the schmancy-button) click\n\t\tconst chevronClick$ = fromEvent<MouseEvent>(this.chevron, 'click')\n\n\t\tmerge(toggleClick$, chevronClick$)\n\t\t\t.pipe(\n\t\t\t\tswitchMap(() => {\n\t\t\t\t\t// 1. Animate the chevron rotation\n\t\t\t\t\t// If `open` is true, rotate from 180 -> 0; if false, from 0 -> 180\n\t\t\t\t\tconst fromDeg = this.open ? 180 : 0\n\t\t\t\t\tconst toDeg = this.open ? 0 : 180\n\t\t\t\t\tconst chevronAnimation = this.chevron.animate(\n\t\t\t\t\t\t[{ transform: `rotate(${fromDeg}deg)` }, { transform: `rotate(${toDeg}deg)` }],\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tduration: 150,\n\t\t\t\t\t\t\teasing: 'ease-in',\n\t\t\t\t\t\t\tfill: 'forwards',\n\t\t\t\t\t\t},\n\t\t\t\t\t)\n\n\t\t\t\t\t// 2. Animate the slot’s height + opacity\n\t\t\t\t\tif (!this.open) {\n\t\t\t\t\t\t// We are about to open, so remove `hidden` to measure scrollHeight\n\t\t\t\t\t\tthis.defaultSlot.hidden = false\n\t\t\t\t\t}\n\n\t\t\t\t\tconst fromOpacity = this.open ? 1 : 0\n\t\t\t\t\tconst toOpacity = this.open ? 0 : 1\n\n\t\t\t\t\tconst slotAnimation = this.defaultSlot.animate([{ opacity: fromOpacity }, { opacity: toOpacity }], {\n\t\t\t\t\t\tduration: 150,\n\t\t\t\t\t\teasing: 'ease-out',\n\t\t\t\t\t\tfill: 'forwards',\n\t\t\t\t\t})\n\n\t\t\t\t\t// Hide the slot if we just closed it\n\t\t\t\t\tslotAnimation.onfinish = () => {\n\t\t\t\t\t\tif (this.open) {\n\t\t\t\t\t\t\tthis.defaultSlot.hidden = true\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tthis.defaultSlot.style.height = 'auto'\n\t\t\t\t\t\t\tthis.defaultSlot.style.opacity = '1'\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Return an Observable that completes when both animations finish\n\t\t\t\t\treturn zip(fromEvent(chevronAnimation, 'finish'), fromEvent(slotAnimation, 'finish')).pipe(\n\t\t\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t\t\t)\n\t\t\t\t}),\n\t\t\t\ttap(() => {\n\t\t\t\t\t// Flip the open state\n\t\t\t\t\tthis.open = !this.open\n\t\t\t\t}),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<div class=\"flex content-center items-center justify-between\">\n\t\t\t\t<!-- Root toggler content -->\n\t\t\t\t<slot id=\"toggler\" name=\"root\"></slot>\n\n\t\t\t\t<!-- The chevron or arrow symbol -->\n\t\t\t\t<!-- Stop propagation on the schmancy-button itself just to avoid double triggers -->\n\t\t\t\t<schmancy-button slot=\"trailing\" id=\"chevron\" @click=${(e: Event) => e.stopPropagation()}> ⌅ </schmancy-button>\n\t\t\t</div>\n\n\t\t\t<!-- The default slot: tree children -->\n\t\t\t<slot></slot>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-tree': SchmancyTree\n\t}\n}\n"],"names":["SchmancyTree","TailwindElement","css","super","arguments","this","open","defaultSlot","hidden","toggleClick$","fromEvent","toggler","pipe","takeUntil","disconnecting","tap","e","preventDefault","stopPropagation","dispatchEvent","CustomEvent","bubbles","composed","chevronClick$","chevron","merge","switchMap","fromDeg","toDeg","chevronAnimation","animate","transform","duration","easing","fill","fromOpacity","toOpacity","slotAnimation","opacity","onfinish","style","height","zip","subscribe","render","html","__decorateClass","property","type","Boolean","prototype","query","customElement"],"mappings":";;;;;;;;;;AAWa,IAAAA,IAAN,cAA2BC,EAAgBC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,CAA3C,EAAA;AAAA,EAAA;AAAAC,UAAAC,GAAAA,SAAAA,GAiB8BC,KAAAC,OAAAA;AAAAA,EAAA;AAAA,EAQpC,eAEMD;AAAAA,SAAKC,SACTD,KAAKE,YAAYC;AAIlB,UAAMC,IAAeC,EAAsBL,KAAKM,SAAS,OAAA,EAASC,KACjEC,EAAUR,KAAKS,aACfC,GAAAA,EAASC,CAAAA;AACRA,MAAAA,EAAEC,eAAAA,GACFD,EAAEE,gBAAAA,GACGb,KAAAc,cAAc,IAAIC,YAAY,UAAU,EAAEC,aAAeC,UAAAA,GAAiB,CAAA,CAAA;AAAA,IAAA,CAAA,CAAA,GAK3EC,IAAgBb,EAAsBL,KAAKmB,SAAS,OAAA;AAEpDC,IAAAA,EAAAhB,GAAcc,CAAAA,EAClBX,KACAc,EAAU;AAGH,YAAAC,IAAUtB,KAAKC,OAAO,MAAM,GAC5BsB,IAAQvB,KAAKC,OAAO,IAAI,KACxBuB,IAAmBxB,KAAKmB,QAAQM,QACrC,CAAC,EAAEC,WAAW,UAAUJ,CAAiB,OAAA,GAAA,EAAEI,WAAW,UAAUH,CAAAA,OAAAA,CAAAA,GAChE,EACCI,UAAU,KACVC,QAAQ,WACRC,MAAM,WAKH7B,CAAAA;AAAAA,WAAKC,SAETD,KAAKE,YAAYC,SAAS;AAGrB,YAAA2B,IAAc9B,KAAKC,OAAO,IAAI,GAC9B8B,IAAY/B,KAAKC,OAAO,IAAI,GAE5B+B,IAAgBhC,KAAKE,YAAYuB,QAAQ,CAAC,EAAEQ,SAASH,EAAAA,GAAe,EAAEG,SAASF,EAAAA,CAAAA,GAAc,EAClGJ,UAAU,KACVC,QAAQ,YACRC,MAAM,WAcA,CAAA;AAAA,aAVPG,EAAcE,WAAW,MAAA;AACpBlC,aAAKC,OACRD,KAAKE,YAAYC,SAAAA,MAEZH,KAAAE,YAAYiC,MAAMC,SAAS,QAC3BpC,KAAAE,YAAYiC,MAAMF,UAAU;AAAA,MAAA,GAK5BI,EAAIhC,EAAUmB,GAAkB,QAAA,GAAWnB,EAAU2B,GAAe,QAAA,CAAA,EAAWzB,KACrFC,EAAUR,KAAKS,aAChB,CAAA;AAAA,IAAA,CAAA,GAEDC,EAAI,MAEEV;AAAAA,WAAAC,QAAQD,KAAKC;AAAAA,IAAA,CAEnBO,GAAAA,EAAUR,KAAKS,aAEf6B,CAAAA,EAAAA,UAAAA;AAAAA,EAAU;AAAA,EAGb,SAAAC;AACQ,WAAAC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,2DAOmD7B,CAAAA,MAAaA,EAAEE,gBAAAA,CAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,EAAiB;AAAA;AA1F9D4B,EAAA,CAA5BC,EAAS,EAAEC,MAAMC,aAjBNjD,EAiBiBkD,WAAA,QAAA,CAAA,GAEVJ,EAAA,CAAlBK,EAAM,cAnBKnD,EAmBOkD,WAAA,WAAA,CACeJ,GAAAA,EAAA,CAAjCK,EAAM,6BApBKnD,EAoBsBkD,WAAA,eAAA,CAGfJ,GAAAA,EAAA,CAAlBK,EAAM,UAAA,CAAA,GAvBKnD,EAuBOkD,WAAA,WAAA,CAvBPlD,GAAAA,IAAN8C,EAAA,CADNM,EAAc,mBACFpD;"}
@@ -1,4 +1,4 @@
1
- "use strict";const t=require("rxjs");require("lit/directives/class-map.js"),require("lit/directives/style-map.js");const d=require("./tailwind.mixin-DFxMrwgk.cjs"),p=require("lit"),c=require("lit/decorators.js");var u=Object.defineProperty,g=Object.getOwnPropertyDescriptor,l=(n,r,o,i)=>{for(var s,e=i>1?void 0:i?g(r,o):r,a=n.length-1;a>=0;a--)(s=n[a])&&(e=(i?s(r,o,e):s(e))||e);return i&&e&&u(r,o,e),e};exports.SchmancyTree=class extends d.TailwindElement(p.css`
1
+ "use strict";const t=require("rxjs");require("lit/directives/class-map.js"),require("lit/directives/style-map.js");const d=require("./tailwind.mixin-mxyACxyp.cjs"),p=require("lit"),c=require("lit/decorators.js");var u=Object.defineProperty,g=Object.getOwnPropertyDescriptor,l=(n,r,o,i)=>{for(var s,e=i>1?void 0:i?g(r,o):r,a=n.length-1;a>=0;a--)(s=n[a])&&(e=(i?s(r,o,e):s(e))||e);return i&&e&&u(r,o,e),e};exports.SchmancyTree=class extends d.TailwindElement(p.css`
2
2
  :host {
3
3
  display: block;
4
4
  position: relative;
@@ -24,4 +24,4 @@
24
24
  <!-- The default slot: tree children -->
25
25
  <slot></slot>
26
26
  `}},l([c.property({type:Boolean})],exports.SchmancyTree.prototype,"open",2),l([c.query("#toggler")],exports.SchmancyTree.prototype,"toggler",2),l([c.query('slot:not([name="root"])')],exports.SchmancyTree.prototype,"defaultSlot",2),l([c.query("#chevron")],exports.SchmancyTree.prototype,"chevron",2),exports.SchmancyTree=l([c.customElement("schmancy-tree")],exports.SchmancyTree);
27
- //# sourceMappingURL=tree-Buf-0IQD.cjs.map
27
+ //# sourceMappingURL=tree-DdXcAF6S.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"tree-Buf-0IQD.cjs","sources":["../src/tree/tree.ts"],"sourcesContent":["import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\nimport { fromEvent, merge, switchMap, takeUntil, tap, zip } from 'rxjs'\n\n/**\n * @element schmancy-tree\n * @slot root - The root element of the tree\n * @slot - The children of the tree\n */\n@customElement('schmancy-tree')\nexport class SchmancyTree extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tposition: relative;\n\t\tbackground-color: initial;\n\t}\n\t::slotted([slot='root']) {\n\t\twidth: 100%;\n\t\ttext-align: left;\n\t}\n\t::slotted([slot='root'] + *) {\n\t\tmargin-top: 0.5rem;\n\t}\n`) {\n\t/**\n\t * Whether the tree’s children are visible\n\t */\n\t@property({ type: Boolean }) open = false\n\n\t@query('#toggler') toggler!: HTMLSlotElement\n\t@query('slot:not([name=\"root\"])') defaultSlot!: HTMLSlotElement\n\n\t// Since it's actually a <schmancy-button>, use HTMLElement or a custom type\n\t@query('#chevron') chevron!: HTMLElement\n\n\tfirstUpdated() {\n\t\t// Hide or show the slot initially based on `open`\n\t\tif (!this.open) {\n\t\t\tthis.defaultSlot.hidden = true\n\t\t}\n\n\t\t// Root toggler\n\t\tconst toggleClick$ = fromEvent<MouseEvent>(this.toggler, 'click').pipe(\n\t\t\ttakeUntil(this.disconnecting),\n\t\t\ttap(e => {\n\t\t\t\te.preventDefault()\n\t\t\t\te.stopPropagation()\n\t\t\t\tthis.dispatchEvent(new CustomEvent('toggle', { bubbles: true, composed: true }))\n\t\t\t}),\n\t\t)\n\n\t\t// Chevron (the schmancy-button) click\n\t\tconst chevronClick$ = fromEvent<MouseEvent>(this.chevron, 'click')\n\n\t\tmerge(toggleClick$, chevronClick$)\n\t\t\t.pipe(\n\t\t\t\tswitchMap(() => {\n\t\t\t\t\t// 1. Animate the chevron rotation\n\t\t\t\t\t// If `open` is true, rotate from 180 -> 0; if false, from 0 -> 180\n\t\t\t\t\tconst fromDeg = this.open ? 180 : 0\n\t\t\t\t\tconst toDeg = this.open ? 0 : 180\n\t\t\t\t\tconst chevronAnimation = this.chevron.animate(\n\t\t\t\t\t\t[{ transform: `rotate(${fromDeg}deg)` }, { transform: `rotate(${toDeg}deg)` }],\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tduration: 150,\n\t\t\t\t\t\t\teasing: 'ease-in',\n\t\t\t\t\t\t\tfill: 'forwards',\n\t\t\t\t\t\t},\n\t\t\t\t\t)\n\n\t\t\t\t\t// 2. Animate the slot’s height + opacity\n\t\t\t\t\tif (!this.open) {\n\t\t\t\t\t\t// We are about to open, so remove `hidden` to measure scrollHeight\n\t\t\t\t\t\tthis.defaultSlot.hidden = false\n\t\t\t\t\t}\n\n\t\t\t\t\tconst fromOpacity = this.open ? 1 : 0\n\t\t\t\t\tconst toOpacity = this.open ? 0 : 1\n\n\t\t\t\t\tconst slotAnimation = this.defaultSlot.animate([{ opacity: fromOpacity }, { opacity: toOpacity }], {\n\t\t\t\t\t\tduration: 150,\n\t\t\t\t\t\teasing: 'ease-out',\n\t\t\t\t\t\tfill: 'forwards',\n\t\t\t\t\t})\n\n\t\t\t\t\t// Hide the slot if we just closed it\n\t\t\t\t\tslotAnimation.onfinish = () => {\n\t\t\t\t\t\tif (this.open) {\n\t\t\t\t\t\t\tthis.defaultSlot.hidden = true\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tthis.defaultSlot.style.height = 'auto'\n\t\t\t\t\t\t\tthis.defaultSlot.style.opacity = '1'\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Return an Observable that completes when both animations finish\n\t\t\t\t\treturn zip(fromEvent(chevronAnimation, 'finish'), fromEvent(slotAnimation, 'finish')).pipe(\n\t\t\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t\t\t)\n\t\t\t\t}),\n\t\t\t\ttap(() => {\n\t\t\t\t\t// Flip the open state\n\t\t\t\t\tthis.open = !this.open\n\t\t\t\t}),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<div class=\"flex content-center items-center justify-between\">\n\t\t\t\t<!-- Root toggler content -->\n\t\t\t\t<slot id=\"toggler\" name=\"root\"></slot>\n\n\t\t\t\t<!-- The chevron or arrow symbol -->\n\t\t\t\t<!-- Stop propagation on the schmancy-button itself just to avoid double triggers -->\n\t\t\t\t<schmancy-button slot=\"trailing\" id=\"chevron\" @click=${(e: Event) => e.stopPropagation()}> ⌅ </schmancy-button>\n\t\t\t</div>\n\n\t\t\t<!-- The default slot: tree children -->\n\t\t\t<slot></slot>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-tree': SchmancyTree\n\t}\n}\n"],"names":["SchmancyTree","TailwindElement","css","super","arguments","this","open","firstUpdated","defaultSlot","hidden","toggleClick$","fromEvent","toggler","pipe","takeUntil","disconnecting","tap","e","preventDefault","stopPropagation","dispatchEvent","CustomEvent","bubbles","composed","chevronClick$","chevron","merge","switchMap","fromDeg","toDeg","chevronAnimation","animate","transform","duration","easing","fill","fromOpacity","toOpacity","slotAnimation","opacity","onfinish","style","height","zip","subscribe","html","__decorateClass","property","type","Boolean","prototype","query","customElement"],"mappings":"oZAWaA,QAAAA,aAAN,cAA2BC,EAAAA,gBAAgBC,EAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,CAA3C,CAAA,CAAA,cAAAC,MAAAC,GAAAA,SAAAA,EAiB8BC,KAAAC,KAAA,EAAA,CAQpC,cAAAC,CAEMF,KAAKC,OACTD,KAAKG,YAAYC,OAAS,IAI3B,MAAMC,EAAeC,EAAAA,UAAsBN,KAAKO,QAAS,OAASC,EAAAA,KACjEC,EAAAA,UAAUT,KAAKU,eACfC,MAASC,IACRA,EAAEC,eAAAA,EACFD,EAAEE,gBACGd,EAAAA,KAAAe,cAAc,IAAIC,YAAY,SAAU,CAAEC,QAAAA,GAAeC,SAAU,EAAA,CAAA,CAAA,CAAO,CAK3EC,CAAAA,EAAAA,EAAgBb,EAAAA,UAAsBN,KAAKoB,QAAS,OAEpDC,EAAAA,QAAAhB,EAAcc,CAAAA,EAClBX,KACAc,EAAAA,UAAU,KAGH,MAAAC,EAAUvB,KAAKC,KAAO,IAAM,EAC5BuB,EAAQxB,KAAKC,KAAO,EAAI,IACxBwB,EAAmBzB,KAAKoB,QAAQM,QACrC,CAAC,CAAEC,UAAW,UAAUJ,SAAiB,CAAEI,UAAW,UAAUH,CAChE,MAAA,CAAA,EAAA,CACCI,SAAU,IACVC,OAAQ,UACRC,KAAM,UAAA,CAAA,EAKH9B,KAAKC,OAETD,KAAKG,YAAYC,OAAAA,IAGZ,MAAA2B,EAAc/B,KAAKC,KAAO,EAAI,EAC9B+B,EAAYhC,KAAKC,KAAO,EAAI,EAE5BgC,EAAgBjC,KAAKG,YAAYuB,QAAQ,CAAC,CAAEQ,QAASH,CAAAA,EAAe,CAAEG,QAASF,CAAAA,CAAAA,EAAc,CAClGJ,SAAU,IACVC,OAAQ,WACRC,KAAM,aAcA,OAVPG,EAAcE,SAAW,IACpBnC,CAAAA,KAAKC,KACRD,KAAKG,YAAYC,WAEZJ,KAAAG,YAAYiC,MAAMC,OAAS,OAC3BrC,KAAAG,YAAYiC,MAAMF,QAAU,IAAA,EAK5BI,EAAAA,IAAIhC,YAAUmB,EAAkB,QAAWnB,EAAAA,EAAAA,UAAU2B,EAAe,QAAA,CAAA,EAAWzB,KACrFC,EAAAA,UAAUT,KAAKU,aAAAA,CAAAA,CAChB,GAEDC,EAAAA,IAAI,KAEEX,KAAAC,KAAAA,CAAQD,KAAKC,IAAA,CAAA,EAEnBQ,EAAAA,UAAUT,KAAKU,gBAEf6B,UAAU,CAAA,CAGb,QACQ,CAAA,OAAAC,EAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,2DAOmD5B,GAAaA,EAAEE,gBAAAA,CAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,GAAiB,CA1F9D2B,EAAAA,EAAA,CAA5BC,WAAS,CAAEC,KAAMC,OAAAA,CAAAA,CAAAA,EAjBNjD,qBAiBiBkD,UAAA,OAAA,GAEVJ,EAAA,CAAlBK,EAAAA,MAAM,UAAA,CAAA,EAnBKnD,qBAmBOkD,UAAA,UAAA,CAAA,EACeJ,EAAA,CAAjCK,EAAAA,MAAM,yBAAA,CAAA,EApBKnD,qBAoBsBkD,UAAA,cAAA,CAGfJ,EAAAA,EAAA,CAAlBK,EAAAA,MAAM,UAAA,CAAA,EAvBKnD,qBAuBOkD,UAAA,UAAA,CAAA,EAvBPlD,QAANA,aAAA8C,EAAA,CADNM,EAAAA,cAAc,eAAA,CAAA,EACFpD"}
1
+ {"version":3,"file":"tree-DdXcAF6S.cjs","sources":["../src/tree/tree.ts"],"sourcesContent":["import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\nimport { fromEvent, merge, switchMap, takeUntil, tap, zip } from 'rxjs'\n\n/**\n * @element schmancy-tree\n * @slot root - The root element of the tree\n * @slot - The children of the tree\n */\n@customElement('schmancy-tree')\nexport class SchmancyTree extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tposition: relative;\n\t\tbackground-color: initial;\n\t}\n\t::slotted([slot='root']) {\n\t\twidth: 100%;\n\t\ttext-align: left;\n\t}\n\t::slotted([slot='root'] + *) {\n\t\tmargin-top: 0.5rem;\n\t}\n`) {\n\t/**\n\t * Whether the tree’s children are visible\n\t */\n\t@property({ type: Boolean }) open = false\n\n\t@query('#toggler') toggler!: HTMLSlotElement\n\t@query('slot:not([name=\"root\"])') defaultSlot!: HTMLSlotElement\n\n\t// Since it's actually a <schmancy-button>, use HTMLElement or a custom type\n\t@query('#chevron') chevron!: HTMLElement\n\n\tfirstUpdated() {\n\t\t// Hide or show the slot initially based on `open`\n\t\tif (!this.open) {\n\t\t\tthis.defaultSlot.hidden = true\n\t\t}\n\n\t\t// Root toggler\n\t\tconst toggleClick$ = fromEvent<MouseEvent>(this.toggler, 'click').pipe(\n\t\t\ttakeUntil(this.disconnecting),\n\t\t\ttap(e => {\n\t\t\t\te.preventDefault()\n\t\t\t\te.stopPropagation()\n\t\t\t\tthis.dispatchEvent(new CustomEvent('toggle', { bubbles: true, composed: true }))\n\t\t\t}),\n\t\t)\n\n\t\t// Chevron (the schmancy-button) click\n\t\tconst chevronClick$ = fromEvent<MouseEvent>(this.chevron, 'click')\n\n\t\tmerge(toggleClick$, chevronClick$)\n\t\t\t.pipe(\n\t\t\t\tswitchMap(() => {\n\t\t\t\t\t// 1. Animate the chevron rotation\n\t\t\t\t\t// If `open` is true, rotate from 180 -> 0; if false, from 0 -> 180\n\t\t\t\t\tconst fromDeg = this.open ? 180 : 0\n\t\t\t\t\tconst toDeg = this.open ? 0 : 180\n\t\t\t\t\tconst chevronAnimation = this.chevron.animate(\n\t\t\t\t\t\t[{ transform: `rotate(${fromDeg}deg)` }, { transform: `rotate(${toDeg}deg)` }],\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tduration: 150,\n\t\t\t\t\t\t\teasing: 'ease-in',\n\t\t\t\t\t\t\tfill: 'forwards',\n\t\t\t\t\t\t},\n\t\t\t\t\t)\n\n\t\t\t\t\t// 2. Animate the slot’s height + opacity\n\t\t\t\t\tif (!this.open) {\n\t\t\t\t\t\t// We are about to open, so remove `hidden` to measure scrollHeight\n\t\t\t\t\t\tthis.defaultSlot.hidden = false\n\t\t\t\t\t}\n\n\t\t\t\t\tconst fromOpacity = this.open ? 1 : 0\n\t\t\t\t\tconst toOpacity = this.open ? 0 : 1\n\n\t\t\t\t\tconst slotAnimation = this.defaultSlot.animate([{ opacity: fromOpacity }, { opacity: toOpacity }], {\n\t\t\t\t\t\tduration: 150,\n\t\t\t\t\t\teasing: 'ease-out',\n\t\t\t\t\t\tfill: 'forwards',\n\t\t\t\t\t})\n\n\t\t\t\t\t// Hide the slot if we just closed it\n\t\t\t\t\tslotAnimation.onfinish = () => {\n\t\t\t\t\t\tif (this.open) {\n\t\t\t\t\t\t\tthis.defaultSlot.hidden = true\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tthis.defaultSlot.style.height = 'auto'\n\t\t\t\t\t\t\tthis.defaultSlot.style.opacity = '1'\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Return an Observable that completes when both animations finish\n\t\t\t\t\treturn zip(fromEvent(chevronAnimation, 'finish'), fromEvent(slotAnimation, 'finish')).pipe(\n\t\t\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t\t\t)\n\t\t\t\t}),\n\t\t\t\ttap(() => {\n\t\t\t\t\t// Flip the open state\n\t\t\t\t\tthis.open = !this.open\n\t\t\t\t}),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<div class=\"flex content-center items-center justify-between\">\n\t\t\t\t<!-- Root toggler content -->\n\t\t\t\t<slot id=\"toggler\" name=\"root\"></slot>\n\n\t\t\t\t<!-- The chevron or arrow symbol -->\n\t\t\t\t<!-- Stop propagation on the schmancy-button itself just to avoid double triggers -->\n\t\t\t\t<schmancy-button slot=\"trailing\" id=\"chevron\" @click=${(e: Event) => e.stopPropagation()}> ⌅ </schmancy-button>\n\t\t\t</div>\n\n\t\t\t<!-- The default slot: tree children -->\n\t\t\t<slot></slot>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-tree': SchmancyTree\n\t}\n}\n"],"names":["SchmancyTree","TailwindElement","css","super","arguments","this","open","firstUpdated","defaultSlot","hidden","toggleClick$","fromEvent","toggler","pipe","takeUntil","disconnecting","tap","e","preventDefault","stopPropagation","dispatchEvent","CustomEvent","bubbles","composed","chevronClick$","chevron","merge","switchMap","fromDeg","toDeg","chevronAnimation","animate","transform","duration","easing","fill","fromOpacity","toOpacity","slotAnimation","opacity","onfinish","style","height","zip","subscribe","html","__decorateClass","property","type","Boolean","prototype","query","customElement"],"mappings":"oZAWaA,QAAAA,aAAN,cAA2BC,EAAAA,gBAAgBC,EAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,CAA3C,CAAA,CAAA,cAAAC,MAAAC,GAAAA,SAAAA,EAiB8BC,KAAAC,KAAA,EAAA,CAQpC,cAAAC,CAEMF,KAAKC,OACTD,KAAKG,YAAYC,OAAS,IAI3B,MAAMC,EAAeC,EAAAA,UAAsBN,KAAKO,QAAS,OAASC,EAAAA,KACjEC,EAAAA,UAAUT,KAAKU,eACfC,MAASC,IACRA,EAAEC,eAAAA,EACFD,EAAEE,gBACGd,EAAAA,KAAAe,cAAc,IAAIC,YAAY,SAAU,CAAEC,QAAAA,GAAeC,SAAU,EAAA,CAAA,CAAA,CAAO,CAK3EC,CAAAA,EAAAA,EAAgBb,EAAAA,UAAsBN,KAAKoB,QAAS,OAEpDC,EAAAA,QAAAhB,EAAcc,CAAAA,EAClBX,KACAc,EAAAA,UAAU,KAGH,MAAAC,EAAUvB,KAAKC,KAAO,IAAM,EAC5BuB,EAAQxB,KAAKC,KAAO,EAAI,IACxBwB,EAAmBzB,KAAKoB,QAAQM,QACrC,CAAC,CAAEC,UAAW,UAAUJ,SAAiB,CAAEI,UAAW,UAAUH,CAChE,MAAA,CAAA,EAAA,CACCI,SAAU,IACVC,OAAQ,UACRC,KAAM,UAAA,CAAA,EAKH9B,KAAKC,OAETD,KAAKG,YAAYC,OAAAA,IAGZ,MAAA2B,EAAc/B,KAAKC,KAAO,EAAI,EAC9B+B,EAAYhC,KAAKC,KAAO,EAAI,EAE5BgC,EAAgBjC,KAAKG,YAAYuB,QAAQ,CAAC,CAAEQ,QAASH,CAAAA,EAAe,CAAEG,QAASF,CAAAA,CAAAA,EAAc,CAClGJ,SAAU,IACVC,OAAQ,WACRC,KAAM,aAcA,OAVPG,EAAcE,SAAW,IACpBnC,CAAAA,KAAKC,KACRD,KAAKG,YAAYC,WAEZJ,KAAAG,YAAYiC,MAAMC,OAAS,OAC3BrC,KAAAG,YAAYiC,MAAMF,QAAU,IAAA,EAK5BI,EAAAA,IAAIhC,YAAUmB,EAAkB,QAAWnB,EAAAA,EAAAA,UAAU2B,EAAe,QAAA,CAAA,EAAWzB,KACrFC,EAAAA,UAAUT,KAAKU,aAAAA,CAAAA,CAChB,GAEDC,EAAAA,IAAI,KAEEX,KAAAC,KAAAA,CAAQD,KAAKC,IAAA,CAAA,EAEnBQ,EAAAA,UAAUT,KAAKU,gBAEf6B,UAAU,CAAA,CAGb,QACQ,CAAA,OAAAC,EAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,2DAOmD5B,GAAaA,EAAEE,gBAAAA,CAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,GAAiB,CA1F9D2B,EAAAA,EAAA,CAA5BC,WAAS,CAAEC,KAAMC,OAAAA,CAAAA,CAAAA,EAjBNjD,qBAiBiBkD,UAAA,OAAA,GAEVJ,EAAA,CAAlBK,EAAAA,MAAM,UAAA,CAAA,EAnBKnD,qBAmBOkD,UAAA,UAAA,CAAA,EACeJ,EAAA,CAAjCK,EAAAA,MAAM,yBAAA,CAAA,EApBKnD,qBAoBsBkD,UAAA,cAAA,CAGfJ,EAAAA,EAAA,CAAlBK,EAAAA,MAAM,UAAA,CAAA,EAvBKnD,qBAuBOkD,UAAA,UAAA,CAAA,EAvBPlD,QAANA,aAAA8C,EAAA,CADNM,EAAAA,cAAc,eAAA,CAAA,EACFpD"}
package/dist/tree.cjs CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./tree-Buf-0IQD.cjs");Object.defineProperty(exports,"SchmancyTree",{enumerable:!0,get:()=>e.SchmancyTree});
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./tree-DdXcAF6S.cjs");Object.defineProperty(exports,"SchmancyTree",{enumerable:!0,get:()=>e.SchmancyTree});
2
2
  //# sourceMappingURL=tree.cjs.map
package/dist/tree.js CHANGED
@@ -1,4 +1,4 @@
1
- import { S as a } from "./tree-n0KxiiWX.js";
1
+ import { S as a } from "./tree-D2g2zq2B.js";
2
2
  export {
3
3
  a as SchmancyTree
4
4
  };
@@ -10,9 +10,9 @@ import { c as qt } from "./consume-B05Dd6qy.js";
10
10
  import "rxjs";
11
11
  import "lit/directives/class-map.js";
12
12
  import "lit/directives/style-map.js";
13
- import { $ as Lt } from "./litElement.mixin-BKgKxczr.js";
14
- import "./tailwind.mixin-k9HTphsu.js";
15
- import { h as xt, d as Dt } from "./delay-DJMIbnvL.js";
13
+ import { $ as xt } from "./litElement.mixin-1-y-wwQg.js";
14
+ import "./tailwind.mixin-DPUboU_5.js";
15
+ import { h as Lt, d as Dt } from "./delay-CE3iPMYG.js";
16
16
  import { i as Mt } from "./intersection-CJxzz8c-.js";
17
17
  import { css as kt, html as At } from "lit";
18
18
  import { property as T, query as _t, queryAssignedNodes as $t, queryAssignedElements as Ot, customElement as Ht } from "lit/decorators.js";
@@ -99,7 +99,7 @@ const $ = (s) => "value" in s;
99
99
  let S = (s) => typeof s == "function" ? s() : s, Q = (s, t = document, e = !1) => t["querySelector" + (e ? "All" : "")](s);
100
100
  const N = (s, t) => Object.assign({}, s, t);
101
101
  let Kt = { "font-family": "", "font-weight": "", "font-size": "", "font-style": "", "line-height": "", color: "", transform: "translateX(-.125em)" };
102
- var i, It, q, U, Ct, V, W, X, H, w, vt, L, x, Tt, B, Pt, St, J, R, D, z, C, M, k, G, I;
102
+ var i, It, q, U, Ct, V, W, X, H, w, vt, x, L, Tt, B, Pt, St, J, R, D, z, C, M, k, G, I;
103
103
  class Qt {
104
104
  constructor(t, e = {}) {
105
105
  K(this, i);
@@ -171,7 +171,7 @@ class Qt {
171
171
  }
172
172
  type(t, e = {}) {
173
173
  t = S(t);
174
- let { instant: r } = e, n = a(this, i, L).call(this, e), o = Ft(t, this.opts.html).map((l) => {
174
+ let { instant: r } = e, n = a(this, i, x).call(this, e), o = Ft(t, this.opts.html).map((l) => {
175
175
  return { func: () => a(this, i, R).call(this, l), char: l, delay: r || (u = l, /<(.+)>(.*?)<\/(.+)>/.test(u.outerHTML)) ? 0 : a(this, i, C).call(this), typeable: l.nodeType === Node.TEXT_NODE };
176
176
  var u;
177
177
  }), h = [n[0], { func: async () => await this.opts.beforeString(t, this) }, ...o, { func: async () => await this.opts.afterString(t, this) }, n[1]];
@@ -182,22 +182,22 @@ class Qt {
182
182
  }
183
183
  move(t, e = {}) {
184
184
  t = S(t);
185
- let r = a(this, i, L).call(this, e), { instant: n, to: o } = e, h = ut({ queueItems: this.queue.getTypeable(), selector: t === null ? "" : t, to: o, cursorPosition: p(this, i, M) }), l = h < 0 ? -1 : 1;
185
+ let r = a(this, i, x).call(this, e), { instant: n, to: o } = e, h = ut({ queueItems: this.queue.getTypeable(), selector: t === null ? "" : t, to: o, cursorPosition: p(this, i, M) }), l = h < 0 ? -1 : 1;
186
186
  return this.predictedCursorPosition = p(this, i, M) + h, a(this, i, w).call(this, [r[0], ..._({ func: () => a(this, i, U).call(this, l), delay: n ? 0 : a(this, i, C).call(this), cursorable: !0 }, Math.abs(h)), r[1]], e);
187
187
  }
188
188
  exec(t, e = {}) {
189
- let r = a(this, i, L).call(this, e);
189
+ let r = a(this, i, x).call(this, e);
190
190
  return a(this, i, w).call(this, [r[0], { func: () => t(this) }, r[1]], e);
191
191
  }
192
192
  options(t, e = {}) {
193
- return t = S(t), a(this, i, x).call(this, t), a(this, i, w).call(this, {}, e);
193
+ return t = S(t), a(this, i, L).call(this, t), a(this, i, w).call(this, {}, e);
194
194
  }
195
195
  pause(t, e = {}) {
196
196
  return a(this, i, w).call(this, { delay: S(t) }, e);
197
197
  }
198
198
  delete(t = null, e = {}) {
199
199
  t = S(t);
200
- let r = a(this, i, L).call(this, e), n = t, { instant: o, to: h } = e, l = this.queue.getTypeable(), u = n === null ? l.length : bt(n) ? n : ut({ queueItems: l, selector: n, cursorPosition: p(this, i, M), to: h });
200
+ let r = a(this, i, x).call(this, e), n = t, { instant: o, to: h } = e, l = this.queue.getTypeable(), u = n === null ? l.length : bt(n) ? n : ut({ queueItems: l, selector: n, cursorPosition: p(this, i, M), to: h });
201
201
  return a(this, i, w).call(this, [r[0], ..._({ func: a(this, i, D).bind(this), delay: o ? 0 : a(this, i, C).call(this, 1), deletable: !0 }, u), r[1]], e);
202
202
  }
203
203
  freeze() {
@@ -216,7 +216,7 @@ class Qt {
216
216
  return this.opts;
217
217
  }
218
218
  updateOptions(t) {
219
- return a(this, i, x).call(this, t);
219
+ return a(this, i, L).call(this, t);
220
220
  }
221
221
  getElement() {
222
222
  return this.element;
@@ -293,9 +293,9 @@ i = new WeakSet(), It = async function() {
293
293
  }, vt = function(t = {}) {
294
294
  let e = t.delay;
295
295
  e && this.queue.add({ delay: e });
296
- }, L = function(t = {}) {
297
- return [{ func: () => a(this, i, x).call(this, t) }, { func: () => a(this, i, x).call(this, this.opts) }];
298
- }, x = async function(t) {
296
+ }, x = function(t = {}) {
297
+ return [{ func: () => a(this, i, L).call(this, t) }, { func: () => a(this, i, L).call(this, this.opts) }];
298
+ }, L = async function(t) {
299
299
  this.opts = N(this.opts, t);
300
300
  }, Tt = function() {
301
301
  let t = this.opts.strings.filter((e) => !!e);
@@ -351,7 +351,7 @@ var Ut = Object.defineProperty, Vt = Object.getOwnPropertyDescriptor, g = (s, t,
351
351
  for (var n, o = r > 1 ? void 0 : r ? Vt(t, e) : t, h = s.length - 1; h >= 0; h--) (n = s[h]) && (o = (r ? n(t, e, o) : n(o)) || o);
352
352
  return r && o && Ut(t, e, o), o;
353
353
  };
354
- let f = class extends Lt(kt`
354
+ let f = class extends xt(kt`
355
355
  :host {
356
356
  display: inherit;
357
357
  }
@@ -391,7 +391,7 @@ let f = class extends Lt(kt`
391
391
  }
392
392
  generateSessionKey() {
393
393
  const s = this._getSlottedElements.map((t) => t.outerHTML).join("");
394
- return this.once ? xt(s) : "";
394
+ return this.once ? Lt(s) : "";
395
395
  }
396
396
  _destroyTypeIt() {
397
397
  if (this.typeItInstance) {
@@ -433,4 +433,4 @@ g([T({ type: Number })], f.prototype, "speed", 2), g([qt({ context: Dt, subscrib
433
433
  export {
434
434
  f as T
435
435
  };
436
- //# sourceMappingURL=typewriter-W7Rj384X.js.map
436
+ //# sourceMappingURL=typewriter-3w_PiJFo.js.map