@mhmo91/schmancy 0.5.25 → 0.5.27

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 (362) hide show
  1. package/ai/checkbox.md +93 -52
  2. package/dist/ai/checkbox.md +93 -52
  3. package/dist/{animated-text-Q61RCdXT.js → animated-text-Bn8-ILmB.js} +3 -3
  4. package/dist/{animated-text-Q61RCdXT.js.map → animated-text-Bn8-ILmB.js.map} +1 -1
  5. package/dist/{animated-text-CiHeHOww.cjs → animated-text-vdNivzdc.cjs} +2 -2
  6. package/dist/{animated-text-CiHeHOww.cjs.map → animated-text-vdNivzdc.cjs.map} +1 -1
  7. package/dist/animated-text.cjs +1 -1
  8. package/dist/animated-text.js +1 -1
  9. package/dist/area.cjs +1 -1
  10. package/dist/{area.component-C_cHSKz0.cjs → area.component-DwPL6bdo.cjs} +2 -2
  11. package/dist/{area.component-C_cHSKz0.cjs.map → area.component-DwPL6bdo.cjs.map} +1 -1
  12. package/dist/{area.component-DYMGLvuA.js → area.component-pd24G8zW.js} +3 -3
  13. package/dist/{area.component-DYMGLvuA.js.map → area.component-pd24G8zW.js.map} +1 -1
  14. package/dist/area.js +1 -1
  15. package/dist/{autocomplete-DuQWyQeT.js → autocomplete-BlhAOtex.js} +4 -4
  16. package/dist/{autocomplete-DuQWyQeT.js.map → autocomplete-BlhAOtex.js.map} +1 -1
  17. package/dist/{autocomplete-ZT3BOEA5.cjs → autocomplete-GW91jVqw.cjs} +2 -2
  18. package/dist/{autocomplete-ZT3BOEA5.cjs.map → autocomplete-GW91jVqw.cjs.map} +1 -1
  19. package/dist/autocomplete.cjs +1 -1
  20. package/dist/autocomplete.js +1 -1
  21. package/dist/{avatar-BcnWoLvo.js → avatar-4sGidVGe.js} +51 -51
  22. package/dist/{avatar-BcnWoLvo.js.map → avatar-4sGidVGe.js.map} +1 -1
  23. package/dist/{avatar-8CSFLRvq.cjs → avatar-q32dkyky.cjs} +2 -2
  24. package/dist/{avatar-8CSFLRvq.cjs.map → avatar-q32dkyky.cjs.map} +1 -1
  25. package/dist/badge.cjs +1 -1
  26. package/dist/badge.js +1 -1
  27. package/dist/boat-DNmaFlxD.cjs +83 -0
  28. package/dist/boat-DNmaFlxD.cjs.map +1 -0
  29. package/dist/boat-dSTPix8t.js +240 -0
  30. package/dist/boat-dSTPix8t.js.map +1 -0
  31. package/dist/boat.cjs +1 -1
  32. package/dist/boat.js +1 -1
  33. package/dist/busy.cjs +1 -1
  34. package/dist/busy.js +1 -1
  35. package/dist/button.cjs +1 -1
  36. package/dist/button.js +1 -1
  37. package/dist/card.cjs +1 -1
  38. package/dist/card.js +1 -1
  39. package/dist/{checkbox-D0LwTB_L.cjs → checkbox-BJ5aqrKY.cjs} +2 -2
  40. package/dist/{checkbox-D0LwTB_L.cjs.map → checkbox-BJ5aqrKY.cjs.map} +1 -1
  41. package/dist/{checkbox-WxVuYamU.js → checkbox-CU2tyEL0.js} +2 -2
  42. package/dist/{checkbox-WxVuYamU.js.map → checkbox-CU2tyEL0.js.map} +1 -1
  43. package/dist/checkbox.cjs +1 -1
  44. package/dist/checkbox.js +1 -1
  45. package/dist/chips.cjs +1 -1
  46. package/dist/chips.js +2 -2
  47. package/dist/code-highlight.cjs +1 -1
  48. package/dist/code-highlight.js +1 -1
  49. package/dist/{code-preview-7uzeIcQP.js → code-preview-KDpn0Q3T.js} +2 -2
  50. package/dist/{code-preview-7uzeIcQP.js.map → code-preview-KDpn0Q3T.js.map} +1 -1
  51. package/dist/{code-preview-BcwituOr.cjs → code-preview-fda91FDi.cjs} +2 -2
  52. package/dist/{code-preview-BcwituOr.cjs.map → code-preview-fda91FDi.cjs.map} +1 -1
  53. package/dist/components.cjs +1 -1
  54. package/dist/components.js +1 -1
  55. package/dist/content-drawer.cjs +1 -1
  56. package/dist/content-drawer.js +1 -1
  57. package/dist/{date-range-eygGuBZz.cjs → date-range-0nOdLk-l.cjs} +2 -2
  58. package/dist/{date-range-eygGuBZz.cjs.map → date-range-0nOdLk-l.cjs.map} +1 -1
  59. package/dist/{date-range-inline-97fWguq7.cjs → date-range-inline-UoP6EDug.cjs} +2 -2
  60. package/dist/{date-range-inline-97fWguq7.cjs.map → date-range-inline-UoP6EDug.cjs.map} +1 -1
  61. package/dist/{date-range-inline-B2QQNDMg.js → date-range-inline-b0yYxPn_.js} +3 -3
  62. package/dist/{date-range-inline-B2QQNDMg.js.map → date-range-inline-b0yYxPn_.js.map} +1 -1
  63. package/dist/date-range-inline.cjs +1 -1
  64. package/dist/date-range-inline.js +1 -1
  65. package/dist/{date-range-s3Us154k.js → date-range-yd-FnXRe.js} +3 -3
  66. package/dist/{date-range-s3Us154k.js.map → date-range-yd-FnXRe.js.map} +1 -1
  67. package/dist/date-range.cjs +1 -1
  68. package/dist/date-range.js +1 -1
  69. package/dist/{delay-CQEb521T.js → delay-CE9VOJBG.js} +2 -2
  70. package/dist/{delay-CQEb521T.js.map → delay-CE9VOJBG.js.map} +1 -1
  71. package/dist/{delay-B0GqQ3C1.cjs → delay-CaOsI0yP.cjs} +2 -2
  72. package/dist/{delay-B0GqQ3C1.cjs.map → delay-CaOsI0yP.cjs.map} +1 -1
  73. package/dist/delay.cjs +1 -1
  74. package/dist/delay.js +1 -1
  75. package/dist/details-B_kKG0Du.cjs +143 -0
  76. package/dist/details-B_kKG0Du.cjs.map +1 -0
  77. package/dist/details-m-njXkGl.js +210 -0
  78. package/dist/details-m-njXkGl.js.map +1 -0
  79. package/dist/details.cjs +1 -1
  80. package/dist/details.js +1 -1
  81. package/dist/{dialog-content-DMImBN73.cjs → dialog-content-B5MUa6uq.cjs} +2 -2
  82. package/dist/{dialog-content-DMImBN73.cjs.map → dialog-content-B5MUa6uq.cjs.map} +1 -1
  83. package/dist/{dialog-content-CcNZ5YU6.js → dialog-content-BireCTdH.js} +3 -3
  84. package/dist/{dialog-content-CcNZ5YU6.js.map → dialog-content-BireCTdH.js.map} +1 -1
  85. package/dist/dialog.cjs +1 -1
  86. package/dist/dialog.js +1 -1
  87. package/dist/{divider-DvznHh3I.js → divider-CMaqpnia.js} +3 -3
  88. package/dist/{divider-DvznHh3I.js.map → divider-CMaqpnia.js.map} +1 -1
  89. package/dist/{divider-DNxHAfMo.cjs → divider-DekMH80a.cjs} +2 -2
  90. package/dist/{divider-DNxHAfMo.cjs.map → divider-DekMH80a.cjs.map} +1 -1
  91. package/dist/divider.cjs +1 -1
  92. package/dist/divider.js +1 -1
  93. package/dist/{dropdown-content-CtMauszk.js → dropdown-content-CViuccZ6.js} +3 -3
  94. package/dist/{dropdown-content-CtMauszk.js.map → dropdown-content-CViuccZ6.js.map} +1 -1
  95. package/dist/{dropdown-content-CH5MB5mz.cjs → dropdown-content-eXth59vX.cjs} +2 -2
  96. package/dist/{dropdown-content-CH5MB5mz.cjs.map → dropdown-content-eXth59vX.cjs.map} +1 -1
  97. package/dist/dropdown.cjs +1 -1
  98. package/dist/dropdown.js +1 -1
  99. package/dist/{email-recipients-BxiV610x.js → email-recipients-BSopuO1J.js} +5 -5
  100. package/dist/{email-recipients-BxiV610x.js.map → email-recipients-BSopuO1J.js.map} +1 -1
  101. package/dist/{email-recipients-pW93YxrA.cjs → email-recipients-DNcWf4_1.cjs} +2 -2
  102. package/dist/{email-recipients-pW93YxrA.cjs.map → email-recipients-DNcWf4_1.cjs.map} +1 -1
  103. package/dist/extra.cjs +1 -1
  104. package/dist/extra.js +1 -1
  105. package/dist/{flex-H2ZPqfIW.cjs → flex-CE0IKjR4.cjs} +2 -2
  106. package/dist/{flex-H2ZPqfIW.cjs.map → flex-CE0IKjR4.cjs.map} +1 -1
  107. package/dist/{flex-ykbucnko.js → flex-Czj-zqJQ.js} +2 -2
  108. package/dist/{flex-ykbucnko.js.map → flex-Czj-zqJQ.js.map} +1 -1
  109. package/dist/{form-CGGeAQbK.js → form-CAvvBQiv.js} +2 -2
  110. package/dist/{form-CGGeAQbK.js.map → form-CAvvBQiv.js.map} +1 -1
  111. package/dist/{form-C7FRhHOX.cjs → form-OUNdJnUW.cjs} +2 -2
  112. package/dist/{form-C7FRhHOX.cjs.map → form-OUNdJnUW.cjs.map} +1 -1
  113. package/dist/form.cjs +1 -1
  114. package/dist/form.js +1 -1
  115. package/dist/{formField.mixin-MbkisYHL.cjs → formField.mixin-Bu0ygAbE.cjs} +2 -2
  116. package/dist/{formField.mixin-MbkisYHL.cjs.map → formField.mixin-Bu0ygAbE.cjs.map} +1 -1
  117. package/dist/{formField.mixin-D-3pktvx.js → formField.mixin-DlYLC82X.js} +2 -2
  118. package/dist/{formField.mixin-D-3pktvx.js.map → formField.mixin-DlYLC82X.js.map} +1 -1
  119. package/dist/{icon-CnVNGmjD.cjs → icon-BwhQbcAk.cjs} +2 -2
  120. package/dist/{icon-CnVNGmjD.cjs.map → icon-BwhQbcAk.cjs.map} +1 -1
  121. package/dist/{icon-BiHCgOyT.js → icon-D0EaNtwd.js} +2 -2
  122. package/dist/{icon-BiHCgOyT.js.map → icon-D0EaNtwd.js.map} +1 -1
  123. package/dist/{icon-button-CB52pDFa.cjs → icon-button-BrRSVzzx.cjs} +2 -2
  124. package/dist/{icon-button-CB52pDFa.cjs.map → icon-button-BrRSVzzx.cjs.map} +1 -1
  125. package/dist/{icon-button--hjJtAL_.js → icon-button-CGMdsmXS.js} +3 -3
  126. package/dist/{icon-button--hjJtAL_.js.map → icon-button-CGMdsmXS.js.map} +1 -1
  127. package/dist/icons.cjs +1 -1
  128. package/dist/icons.js +1 -1
  129. package/dist/index.cjs +1 -1
  130. package/dist/index.js +166 -163
  131. package/dist/{input-Mrc7DrIK.js → input-DZYN1TnY.js} +3 -3
  132. package/dist/{input-Mrc7DrIK.js.map → input-DZYN1TnY.js.map} +1 -1
  133. package/dist/{input-chip-BRdk5zlg.js → input-chip-CNLkwei6.js} +2 -2
  134. package/dist/{input-chip-BRdk5zlg.js.map → input-chip-CNLkwei6.js.map} +1 -1
  135. package/dist/{input-chip-DnM_iJbj.cjs → input-chip-Cf25jEob.cjs} +2 -2
  136. package/dist/{input-chip-DnM_iJbj.cjs.map → input-chip-Cf25jEob.cjs.map} +1 -1
  137. package/dist/{input-BXcrOvCH.cjs → input-lzxE1e5L.cjs} +2 -2
  138. package/dist/{input-BXcrOvCH.cjs.map → input-lzxE1e5L.cjs.map} +1 -1
  139. package/dist/input.cjs +1 -1
  140. package/dist/input.js +1 -1
  141. package/dist/layout.cjs +1 -1
  142. package/dist/layout.js +1 -1
  143. package/dist/{list-CXBxuSyn.js → list-Cqo45m_h.js} +2 -2
  144. package/dist/{list-CXBxuSyn.js.map → list-Cqo45m_h.js.map} +1 -1
  145. package/dist/{list-CYvT9cR6.cjs → list-rGx4YHgo.cjs} +2 -2
  146. package/dist/{list-CYvT9cR6.cjs.map → list-rGx4YHgo.cjs.map} +1 -1
  147. package/dist/list.cjs +1 -1
  148. package/dist/list.js +1 -1
  149. package/dist/{litElement.mixin-DvxIa-6i.js → litElement.mixin-B0Rsd4Km.js} +2 -2
  150. package/dist/{litElement.mixin-DvxIa-6i.js.map → litElement.mixin-B0Rsd4Km.js.map} +1 -1
  151. package/dist/{litElement.mixin-BlkckXzw.cjs → litElement.mixin-DUiUa087.cjs} +2 -2
  152. package/dist/{litElement.mixin-BlkckXzw.cjs.map → litElement.mixin-DUiUa087.cjs.map} +1 -1
  153. package/dist/mailbox.cjs +1 -1
  154. package/dist/mailbox.js +1 -1
  155. package/dist/{map-CnBZmqCI.cjs → map-8DhybTup.cjs} +2 -2
  156. package/dist/{map-CnBZmqCI.cjs.map → map-8DhybTup.cjs.map} +1 -1
  157. package/dist/{map-DwJzufvh.js → map-DWf43TA1.js} +2 -2
  158. package/dist/{map-DwJzufvh.js.map → map-DWf43TA1.js.map} +1 -1
  159. package/dist/map.cjs +1 -1
  160. package/dist/map.js +1 -1
  161. package/dist/media-BVKgZzK_.js +243 -0
  162. package/dist/media-BVKgZzK_.js.map +1 -0
  163. package/dist/media-BZwiyJto.cjs +152 -0
  164. package/dist/media-BZwiyJto.cjs.map +1 -0
  165. package/dist/{menu-dj8ocrls.js → menu-CGaCEOer.js} +3 -3
  166. package/dist/{menu-dj8ocrls.js.map → menu-CGaCEOer.js.map} +1 -1
  167. package/dist/{menu-1D8Grlkb.cjs → menu-D8qP_e7D.cjs} +2 -2
  168. package/dist/{menu-1D8Grlkb.cjs.map → menu-D8qP_e7D.cjs.map} +1 -1
  169. package/dist/menu.cjs +1 -1
  170. package/dist/menu.js +1 -1
  171. package/dist/mixins/tailwind.css +0 -247
  172. package/dist/nav-drawer.cjs +1 -1
  173. package/dist/nav-drawer.js +1 -1
  174. package/dist/navigation-bar.cjs +1 -1
  175. package/dist/navigation-bar.js +1 -1
  176. package/dist/{navigation-rail-CO20kIzL.cjs → navigation-rail-BzMOzaFm.cjs} +77 -39
  177. package/dist/navigation-rail-BzMOzaFm.cjs.map +1 -0
  178. package/dist/{navigation-rail-DDSUxYea.js → navigation-rail-CjBw96pi.js} +88 -50
  179. package/dist/navigation-rail-CjBw96pi.js.map +1 -0
  180. package/dist/navigation-rail.cjs +1 -1
  181. package/dist/navigation-rail.js +1 -1
  182. package/dist/{notification-service-DcZEP2es.cjs → notification-service-DCmDSvc-.cjs} +2 -2
  183. package/dist/{notification-service-DcZEP2es.cjs.map → notification-service-DCmDSvc-.cjs.map} +1 -1
  184. package/dist/{notification-service-pckh5tN0.js → notification-service-Dv4oQi_Z.js} +5 -5
  185. package/dist/{notification-service-pckh5tN0.js.map → notification-service-Dv4oQi_Z.js.map} +1 -1
  186. package/dist/notification.cjs +1 -1
  187. package/dist/notification.js +2 -2
  188. package/dist/{notify-CkVQ8Yk1.js → notify-COuaNTJP.js} +2 -2
  189. package/dist/{notify-CkVQ8Yk1.js.map → notify-COuaNTJP.js.map} +1 -1
  190. package/dist/{notify-G37oQhaA.cjs → notify-XY2e8y_a.cjs} +2 -2
  191. package/dist/{notify-G37oQhaA.cjs.map → notify-XY2e8y_a.cjs.map} +1 -1
  192. package/dist/{option-aPValeTc.js → option-CSSmqUBi.js} +2 -2
  193. package/dist/{option-aPValeTc.js.map → option-CSSmqUBi.js.map} +1 -1
  194. package/dist/{option-Cjwmga85.cjs → option-q-dig7LF.cjs} +2 -2
  195. package/dist/{option-Cjwmga85.cjs.map → option-q-dig7LF.cjs.map} +1 -1
  196. package/dist/option.cjs +1 -1
  197. package/dist/option.js +1 -1
  198. package/dist/{payment-card-form-CbGx00Fm.cjs → payment-card-form-C8bWa_hh.cjs} +2 -2
  199. package/dist/{payment-card-form-CbGx00Fm.cjs.map → payment-card-form-C8bWa_hh.cjs.map} +1 -1
  200. package/dist/{payment-card-form-B0kQ8Wr5.js → payment-card-form-CWboYwqO.js} +3 -3
  201. package/dist/{payment-card-form-B0kQ8Wr5.js.map → payment-card-form-CWboYwqO.js.map} +1 -1
  202. package/dist/{progress-CmI5A7Z_.cjs → progress-CP2lpJsl.cjs} +2 -2
  203. package/dist/{progress-CmI5A7Z_.cjs.map → progress-CP2lpJsl.cjs.map} +1 -1
  204. package/dist/{progress-DuqVkW8o.js → progress-Cci0dXzp.js} +2 -2
  205. package/dist/{progress-DuqVkW8o.js.map → progress-Cci0dXzp.js.map} +1 -1
  206. package/dist/progress.cjs +1 -1
  207. package/dist/progress.js +1 -1
  208. package/dist/{radio-button-Chlsm46k.cjs → radio-button-CU-lMs92.cjs} +2 -2
  209. package/dist/{radio-button-Chlsm46k.cjs.map → radio-button-CU-lMs92.cjs.map} +1 -1
  210. package/dist/{radio-button-sQa0jt-L.js → radio-button-DFbfVgox.js} +3 -3
  211. package/dist/{radio-button-sQa0jt-L.js.map → radio-button-DFbfVgox.js.map} +1 -1
  212. package/dist/radio-group.cjs +1 -1
  213. package/dist/radio-group.js +1 -1
  214. package/dist/{schmancy-steps-container-r34O78hN.cjs → schmancy-steps-container-CQY1zmws.cjs} +2 -2
  215. package/dist/{schmancy-steps-container-r34O78hN.cjs.map → schmancy-steps-container-CQY1zmws.cjs.map} +1 -1
  216. package/dist/{schmancy-steps-container-BsVtwIIR.js → schmancy-steps-container-vW7r1ZTL.js} +2 -2
  217. package/dist/{schmancy-steps-container-BsVtwIIR.js.map → schmancy-steps-container-vW7r1ZTL.js.map} +1 -1
  218. package/dist/{select-lhS0e1Jw.cjs → select-Be8HIqWu.cjs} +2 -2
  219. package/dist/{select-lhS0e1Jw.cjs.map → select-Be8HIqWu.cjs.map} +1 -1
  220. package/dist/{select-DQNDWSWh.js → select-BkGodZaS.js} +4 -4
  221. package/dist/{select-DQNDWSWh.js.map → select-BkGodZaS.js.map} +1 -1
  222. package/dist/select.cjs +1 -1
  223. package/dist/select.js +1 -1
  224. package/dist/{sheet-DImUVTqD.js → sheet-DECb9whB.js} +3 -3
  225. package/dist/{sheet-DImUVTqD.js.map → sheet-DECb9whB.js.map} +1 -1
  226. package/dist/{sheet-CVQ6px7m.cjs → sheet-dK5UPVjp.cjs} +2 -2
  227. package/dist/{sheet-CVQ6px7m.cjs.map → sheet-dK5UPVjp.cjs.map} +1 -1
  228. package/dist/sheet.cjs +1 -1
  229. package/dist/sheet.js +1 -1
  230. package/dist/{slider-CZMt67fl.js → slider-BhFc1oRj.js} +3 -3
  231. package/dist/{slider-CZMt67fl.js.map → slider-BhFc1oRj.js.map} +1 -1
  232. package/dist/{slider-MzOpDc_J.cjs → slider-CP3JRaWR.cjs} +2 -2
  233. package/dist/{slider-MzOpDc_J.cjs.map → slider-CP3JRaWR.cjs.map} +1 -1
  234. package/dist/slider.cjs +1 -1
  235. package/dist/slider.js +1 -1
  236. package/dist/{spinner-BuujVERe.cjs → spinner-BD8cXVK_.cjs} +2 -2
  237. package/dist/{spinner-BuujVERe.cjs.map → spinner-BD8cXVK_.cjs.map} +1 -1
  238. package/dist/{spinner-CUHM2lNo.js → spinner-DGyRYqUZ.js} +2 -2
  239. package/dist/{spinner-CUHM2lNo.js.map → spinner-DGyRYqUZ.js.map} +1 -1
  240. package/dist/steps.cjs +1 -1
  241. package/dist/steps.js +1 -1
  242. package/dist/{suggestion-chip-CzMoacAF.cjs → suggestion-chip-C1n2VYBG.cjs} +31 -20
  243. package/dist/suggestion-chip-C1n2VYBG.cjs.map +1 -0
  244. package/dist/{suggestion-chip-8mpcT2Lk.js → suggestion-chip-Cl0cPTKV.js} +89 -70
  245. package/dist/suggestion-chip-Cl0cPTKV.js.map +1 -0
  246. package/dist/surface-C3V23wh9.js +140 -0
  247. package/dist/surface-C3V23wh9.js.map +1 -0
  248. package/dist/surface-ClIDhSRv.cjs +119 -0
  249. package/dist/surface-ClIDhSRv.cjs.map +1 -0
  250. package/dist/surface.cjs +1 -1
  251. package/dist/surface.js +1 -1
  252. package/dist/{table-Dt0gOEZZ.cjs → table-1New2HBS.cjs} +2 -2
  253. package/dist/{table-Dt0gOEZZ.cjs.map → table-1New2HBS.cjs.map} +1 -1
  254. package/dist/{table-DkaAXbrh.js → table-CLA3cxIk.js} +2 -2
  255. package/dist/{table-DkaAXbrh.js.map → table-CLA3cxIk.js.map} +1 -1
  256. package/dist/table.cjs +1 -1
  257. package/dist/table.js +1 -1
  258. package/dist/{tabs-compatibility-5WVuGrk5.cjs → tabs-compatibility-DDtYFCUj.cjs} +2 -2
  259. package/dist/{tabs-compatibility-5WVuGrk5.cjs.map → tabs-compatibility-DDtYFCUj.cjs.map} +1 -1
  260. package/dist/{tabs-compatibility-DGvPxrEr.js → tabs-compatibility-RMzYuSJ1.js} +2 -2
  261. package/dist/{tabs-compatibility-DGvPxrEr.js.map → tabs-compatibility-RMzYuSJ1.js.map} +1 -1
  262. package/dist/tabs.cjs +1 -1
  263. package/dist/tabs.js +1 -1
  264. package/dist/tailwind.mixin-CFrLBtkD.cjs +2 -0
  265. package/dist/{tailwind.mixin-BiRVB4Hl.cjs.map → tailwind.mixin-CFrLBtkD.cjs.map} +1 -1
  266. package/dist/tailwind.mixin-CZKT1dUr.js +43 -0
  267. package/dist/{tailwind.mixin-BbF53_0W.js.map → tailwind.mixin-CZKT1dUr.js.map} +1 -1
  268. package/dist/teleport.cjs +1 -1
  269. package/dist/teleport.js +1 -1
  270. package/dist/{textarea-mc3Gk2Ch.js → textarea-B4DXG5Sg.js} +3 -3
  271. package/dist/{textarea-mc3Gk2Ch.js.map → textarea-B4DXG5Sg.js.map} +1 -1
  272. package/dist/{textarea-CJECXt0r.cjs → textarea-ChDsPBZz.cjs} +2 -2
  273. package/dist/{textarea-CJECXt0r.cjs.map → textarea-ChDsPBZz.cjs.map} +1 -1
  274. package/dist/textarea.cjs +1 -1
  275. package/dist/textarea.js +1 -1
  276. package/dist/{theme-button-cDGf9KiE.js → theme-button-DGjG_shg.js} +2 -2
  277. package/dist/{theme-button-cDGf9KiE.js.map → theme-button-DGjG_shg.js.map} +1 -1
  278. package/dist/{theme-button-1nU7sd5N.cjs → theme-button-qzDX0i9Q.cjs} +2 -2
  279. package/dist/{theme-button-1nU7sd5N.cjs.map → theme-button-qzDX0i9Q.cjs.map} +1 -1
  280. package/dist/theme-button.cjs +1 -1
  281. package/dist/theme-button.js +1 -1
  282. package/dist/theme.cjs +1 -1
  283. package/dist/theme.component-Blc_4wu9.cjs +3 -0
  284. package/dist/{theme.component-BpyyRbkh.cjs.map → theme.component-Blc_4wu9.cjs.map} +1 -1
  285. package/dist/theme.component-C3r_-QqQ.js +818 -0
  286. package/dist/{theme.component-HF6Qt0YA.js.map → theme.component-C3r_-QqQ.js.map} +1 -1
  287. package/dist/theme.interface-BLfE5J_1.js +5 -0
  288. package/dist/theme.interface-BLfE5J_1.js.map +1 -0
  289. package/dist/theme.interface-BMeNadVb.cjs +2 -0
  290. package/dist/theme.interface-BMeNadVb.cjs.map +1 -0
  291. package/dist/theme.js +13 -10
  292. package/dist/{timezone-8UCGVbbl.js → timezone-BkE20wzQ.js} +3 -3
  293. package/dist/{timezone-8UCGVbbl.js.map → timezone-BkE20wzQ.js.map} +1 -1
  294. package/dist/{timezone-DC3VVwlT.cjs → timezone-wWfEuXrb.cjs} +2 -2
  295. package/dist/{timezone-DC3VVwlT.cjs.map → timezone-wWfEuXrb.cjs.map} +1 -1
  296. package/dist/{tooltip-DNl5aBNp.cjs → tooltip-DLadXXnP.cjs} +2 -2
  297. package/dist/{tooltip-DNl5aBNp.cjs.map → tooltip-DLadXXnP.cjs.map} +1 -1
  298. package/dist/{tooltip-C5r_jUM1.js → tooltip-UtpbXzQX.js} +2 -2
  299. package/dist/{tooltip-C5r_jUM1.js.map → tooltip-UtpbXzQX.js.map} +1 -1
  300. package/dist/tooltip.cjs +1 -1
  301. package/dist/tooltip.js +1 -1
  302. package/dist/{tree-yiGCSyyN.cjs → tree-Brtho3Eu.cjs} +2 -2
  303. package/dist/{tree-yiGCSyyN.cjs.map → tree-Brtho3Eu.cjs.map} +1 -1
  304. package/dist/{tree-CeNor9l6.js → tree-VkXtw2P8.js} +2 -2
  305. package/dist/{tree-CeNor9l6.js.map → tree-VkXtw2P8.js.map} +1 -1
  306. package/dist/tree.cjs +1 -1
  307. package/dist/tree.js +1 -1
  308. package/dist/{typewriter-CWFH8-z-.cjs → typewriter-CEgaw_pR.cjs} +2 -2
  309. package/dist/{typewriter-CWFH8-z-.cjs.map → typewriter-CEgaw_pR.cjs.map} +1 -1
  310. package/dist/{typewriter-BbQsON2M.js → typewriter-CsReDsYS.js} +4 -4
  311. package/dist/{typewriter-BbQsON2M.js.map → typewriter-CsReDsYS.js.map} +1 -1
  312. package/dist/typewriter.cjs +1 -1
  313. package/dist/typewriter.js +1 -1
  314. package/dist/{typography-PFj-xY2T.js → typography-D_bM5DW7.js} +2 -2
  315. package/dist/{typography-PFj-xY2T.js.map → typography-D_bM5DW7.js.map} +1 -1
  316. package/dist/{typography-ByLTIj6U.cjs → typography-NurK7F-8.cjs} +2 -2
  317. package/dist/{typography-ByLTIj6U.cjs.map → typography-NurK7F-8.cjs.map} +1 -1
  318. package/dist/typography.cjs +1 -1
  319. package/dist/typography.js +1 -1
  320. package/package.json +1 -1
  321. package/types/src/boat/boat.d.ts +9 -0
  322. package/types/src/card/card.d.ts +5 -1
  323. package/types/src/chips/chips.d.ts +1 -6
  324. package/types/src/details/details.d.ts +4 -4
  325. package/types/src/theme/context.d.ts +222 -2
  326. package/types/src/theme/index.d.ts +10 -3
  327. package/types/src/theme/theme.elevation.d.ts +131 -0
  328. package/types/src/theme/theme.format.d.ts +32 -5
  329. package/types/src/theme/theme.interface.d.ts +231 -5
  330. package/types/src/theme/theme.motion.d.ts +198 -0
  331. package/types/src/theme/theme.service.d.ts +222 -2
  332. package/types/src/theme/theme.shape.d.ts +144 -0
  333. package/types/src/theme/theme.state.d.ts +546 -0
  334. package/types/src/theme/theme.typography.d.ts +74 -0
  335. package/dist/boat-BTSQNgJQ.js +0 -174
  336. package/dist/boat-BTSQNgJQ.js.map +0 -1
  337. package/dist/boat-BtViHW8M.cjs +0 -66
  338. package/dist/boat-BtViHW8M.cjs.map +0 -1
  339. package/dist/details-BSmS_ILq.cjs +0 -161
  340. package/dist/details-BSmS_ILq.cjs.map +0 -1
  341. package/dist/details-kr1zYIlK.js +0 -228
  342. package/dist/details-kr1zYIlK.js.map +0 -1
  343. package/dist/media-CdM6XhRo.cjs +0 -177
  344. package/dist/media-CdM6XhRo.cjs.map +0 -1
  345. package/dist/media-DOKkl0Ic.js +0 -261
  346. package/dist/media-DOKkl0Ic.js.map +0 -1
  347. package/dist/navigation-rail-CO20kIzL.cjs.map +0 -1
  348. package/dist/navigation-rail-DDSUxYea.js.map +0 -1
  349. package/dist/suggestion-chip-8mpcT2Lk.js.map +0 -1
  350. package/dist/suggestion-chip-CzMoacAF.cjs.map +0 -1
  351. package/dist/surface-C3B9Sbtw.cjs +0 -90
  352. package/dist/surface-C3B9Sbtw.cjs.map +0 -1
  353. package/dist/surface-DdR9DjO8.js +0 -111
  354. package/dist/surface-DdR9DjO8.js.map +0 -1
  355. package/dist/tailwind.mixin-BbF53_0W.js +0 -43
  356. package/dist/tailwind.mixin-BiRVB4Hl.cjs +0 -2
  357. package/dist/theme.component-BpyyRbkh.cjs +0 -3
  358. package/dist/theme.component-HF6Qt0YA.js +0 -814
  359. package/dist/theme.interface-C5Kj6WjD.js +0 -5
  360. package/dist/theme.interface-C5Kj6WjD.js.map +0 -1
  361. package/dist/theme.interface-Xg5Zi46a.cjs +0 -2
  362. package/dist/theme.interface-Xg5Zi46a.cjs.map +0 -1
@@ -1,228 +0,0 @@
1
- import { BehaviorSubject as h, takeUntil as u } from "rxjs";
2
- import "lit/directives/class-map.js";
3
- import "lit/directives/style-map.js";
4
- import { property as l, state as c, customElement as m } from "lit/decorators.js";
5
- import { T as y } from "./tailwind.mixin-BbF53_0W.js";
6
- import { css as v, html as d, LitElement as f } from "lit";
7
- import { when as g } from "lit/directives/when.js";
8
- import { tap as x } from "rxjs/operators";
9
- var b = Object.defineProperty, w = Object.getOwnPropertyDescriptor, r = (e, t, n, i) => {
10
- for (var s, o = i > 1 ? void 0 : i ? w(t, n) : t, p = e.length - 1; p >= 0; p--) (s = e[p]) && (o = (i ? s(t, n, o) : s(o)) || o);
11
- return i && o && b(t, n, o), o;
12
- };
13
- let a = class extends y(v`
14
- :host {
15
- display: block;
16
- position: relative;
17
- }
18
-
19
- /* Hide browser default marker */
20
- summary::-webkit-details-marker {
21
- display: none;
22
- }
23
-
24
- summary {
25
- list-style: none;
26
- }
27
-
28
- /* Container border-radius following M3 spec */
29
- details {
30
- border-radius: 12px; /* M3 medium component radius */
31
- transition: all 200ms cubic-bezier(0.2, 0, 0, 1); /* M3 standard easing */
32
- }
33
-
34
- /* Variant-specific styles */
35
- :host([variant='outlined']) details {
36
- border: 1px solid var(--schmancy-sys-color-outline-variant);
37
- background-color: var(--schmancy-sys-color-surface-default);
38
- }
39
-
40
- :host([variant='filled']) details {
41
- background-color: var(--schmancy-sys-color-surface-container);
42
- }
43
-
44
- :host([variant='elevated']) details {
45
- background-color: var(--schmancy-sys-color-surface-low);
46
- box-shadow: var(--schmancy-sys-elevation-1);
47
- }
48
-
49
- :host([variant='elevated']) details[open] {
50
- box-shadow: var(--schmancy-sys-elevation-2);
51
- background-color: var(--schmancy-sys-color-surface-container);
52
- }
53
-
54
- /* Content animation */
55
- @keyframes slideDown {
56
- from {
57
- opacity: 0;
58
- transform: translateY(-8px);
59
- }
60
- to {
61
- opacity: 1;
62
- transform: translateY(0);
63
- }
64
- }
65
-
66
- .content-wrapper[data-open='true'] {
67
- animation: slideDown 250ms cubic-bezier(0.2, 0, 0, 1);
68
- }
69
-
70
- /* Ripple effect */
71
- @keyframes ripple {
72
- to {
73
- transform: scale(4);
74
- opacity: 0;
75
- }
76
- }
77
-
78
- /* Focus ring following M3 spec */
79
- summary:focus-visible {
80
- outline: 2px solid var(--schmancy-sys-color-primary-default);
81
- outline-offset: 2px;
82
- border-radius: 12px;
83
- }
84
-
85
- /* Icon rotation transition */
86
- .icon-wrapper {
87
- transition: transform 200ms cubic-bezier(0.2, 0, 0, 1);
88
- }
89
-
90
- .icon-wrapper[data-open='true'] {
91
- transform: rotate(90deg);
92
- }
93
- `) {
94
- constructor() {
95
- super(...arguments), this.summary = "", this.variant = "default", this.ripples = [], this.pressed = !1, this._isOpen = !1, this.nextRippleId = 0, this._open$ = new h(!1);
96
- }
97
- get open() {
98
- return this._open$.value;
99
- }
100
- set open(e) {
101
- this._open$.value !== e && this._open$.next(e);
102
- }
103
- connectedCallback() {
104
- super.connectedCallback(), this._open$.pipe(x((e) => {
105
- this._isOpen = e, this.requestUpdate();
106
- }), u(this.disconnecting)).subscribe();
107
- }
108
- render() {
109
- const e = this.classMap({ "cursor-pointer": !0, "select-none": !0, relative: !0, flex: !0, "items-center": !0, "gap-3": !0, "min-h-[48px]": !0, "sm:min-h-[56px]": !0, "px-4": !0, "sm:px-6": !0, "py-3": !0, "sm:py-4": !0, "rounded-xl": !0, "transition-colors": !0, "duration-200": !0, "text-surface-on": !0, group: !0 }), t = this.classMap({ absolute: !0, "inset-0": !0, "rounded-xl": !0, "pointer-events-none": !0, "transition-opacity": !0, "duration-200": !0, "bg-surface-on": !0, [this.pressed ? "opacity-[0.12]" : this.variant === "default" ? "opacity-0 hover:opacity-[0.08]" : "opacity-0 hover:opacity-[0.04]"]: !0 }), n = this.classMap({ "px-4": !0, "sm:px-6": !0, "pb-3": !0, "sm:pb-4": !0, "text-surface-onVariant": !0, "text-sm": !0, "sm:text-base": !0 }), i = this.classMap({ flex: !0, "items-center": !0, "justify-center": !0, "w-6": !0, "h-6": !0, "rounded-full": !0, "flex-shrink-0": !0, "text-surface-onVariant": !0, "group-hover:text-surface-on": !0, "transition-all": !0, "duration-200": !0 });
110
- return d`
111
- <details
112
- ?open=${this._isOpen}
113
- @toggle=${this._handleToggle}
114
- class="w-full overflow-hidden"
115
- >
116
- <summary
117
- class=${e}
118
- @click=${this._handleClick}
119
- @mousedown=${this._handleMouseDown}
120
- @mouseup=${this._handleMouseUp}
121
- @mouseleave=${this._handleMouseLeave}
122
- @keydown=${this._handleKeyDown}
123
- @keyup=${this._handleKeyUp}
124
- tabindex="0"
125
- >
126
- <!-- State layer for hover/focus/pressed states -->
127
- <div class=${t}></div>
128
-
129
- <!-- Ripple container -->
130
- <div class="absolute inset-0 rounded-xl overflow-hidden pointer-events-none">
131
- ${this.ripples.map((s) => d`
132
- <span
133
- class="absolute rounded-full scale-0 animate-[ripple_600ms_linear] bg-surface-on opacity-[0.12] pointer-events-none"
134
- style="
135
- left: ${s.x}px;
136
- top: ${s.y}px;
137
- width: 20px;
138
- height: 20px;
139
- margin-left: -10px;
140
- margin-top: -10px;
141
- "
142
- ></span>
143
- `)}
144
- </div>
145
-
146
- <!-- Summary content -->
147
- <span class="relative flex-1 font-medium text-base sm:text-lg z-10">
148
- <slot name="summary">${this.summary}</slot>
149
- </span>
150
-
151
- <!-- Expand/collapse icon -->
152
- <span
153
- class=${i}
154
- data-open=${this._isOpen}
155
- style="transform: rotate(${this._isOpen ? "90deg" : "0deg"})"
156
- >
157
- <svg
158
- width="24"
159
- height="24"
160
- viewBox="0 0 24 24"
161
- fill="none"
162
- xmlns="http://www.w3.org/2000/svg"
163
- class="w-5 h-5 sm:w-6 sm:h-6"
164
- >
165
- <path
166
- d="M9 6L15 12L9 18"
167
- stroke="currentColor"
168
- stroke-width="2"
169
- stroke-linecap="round"
170
- stroke-linejoin="round"
171
- />
172
- </svg>
173
- </span>
174
- </summary>
175
-
176
- <!-- Content area -->
177
- <div
178
- class=${n}
179
- data-open=${this._isOpen}
180
- style="${this._isOpen ? "" : "display: none;"}"
181
- >
182
- ${g(this._isOpen, () => d`
183
- <div class="content-wrapper" data-open=${this._isOpen}>
184
- <slot></slot>
185
- </div>
186
- `)}
187
- </div>
188
- </details>
189
- `;
190
- }
191
- _handleToggle(e) {
192
- const t = e.target;
193
- this._open$.next(t.open), this.dispatchEvent(new CustomEvent("toggle", { detail: { open: t.open }, bubbles: !0, composed: !0 }));
194
- }
195
- _handleClick(e) {
196
- e.preventDefault();
197
- const t = e.currentTarget.getBoundingClientRect(), n = e.clientX - t.left, i = e.clientY - t.top, s = this.nextRippleId++;
198
- this.ripples = [...this.ripples, { x: n, y: i, id: s }], setTimeout(() => {
199
- this.ripples = this.ripples.filter((o) => o.id !== s);
200
- }, 600), this._open$.next(!this._open$.value), this.dispatchEvent(new CustomEvent("toggle", { detail: { open: this._open$.value }, bubbles: !0, composed: !0 }));
201
- }
202
- _handleMouseDown() {
203
- this.pressed = !0;
204
- }
205
- _handleMouseUp() {
206
- this.pressed = !1;
207
- }
208
- _handleMouseLeave() {
209
- this.pressed = !1;
210
- }
211
- _handleKeyDown(e) {
212
- if (e.key === "Enter" || e.key === " ") {
213
- e.preventDefault(), this.pressed = !0;
214
- const t = e.currentTarget.getBoundingClientRect(), n = t.width / 2, i = t.height / 2, s = this.nextRippleId++;
215
- this.ripples = [...this.ripples, { x: n, y: i, id: s }], setTimeout(() => {
216
- this.ripples = this.ripples.filter((o) => o.id !== s);
217
- }, 600), this._open$.next(!this._open$.value), this.dispatchEvent(new CustomEvent("toggle", { detail: { open: this._open$.value }, bubbles: !0, composed: !0 }));
218
- }
219
- }
220
- _handleKeyUp(e) {
221
- e.key !== "Enter" && e.key !== " " || (this.pressed = !1);
222
- }
223
- };
224
- a.shadowRootOptions = { ...f.shadowRootOptions, mode: "open", delegatesFocus: !0 }, r([l()], a.prototype, "summary", 2), r([l({ type: Boolean, reflect: !0 })], a.prototype, "open", 1), r([l({ reflect: !0 })], a.prototype, "variant", 2), r([c()], a.prototype, "ripples", 2), r([c()], a.prototype, "pressed", 2), r([c()], a.prototype, "_isOpen", 2), a = r([m("schmancy-details")], a);
225
- export {
226
- a as S
227
- };
228
- //# sourceMappingURL=details-kr1zYIlK.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"details-kr1zYIlK.js","sources":["../src/details/details.ts"],"sourcesContent":["import { TailwindElement } from '@mixins/index'\r\nimport { css, html, LitElement } from 'lit'\r\nimport { customElement, property, state } from 'lit/decorators.js'\r\nimport { when } from 'lit/directives/when.js'\r\nimport { BehaviorSubject, takeUntil } from 'rxjs'\r\nimport { tap } from 'rxjs/operators'\r\n\r\n@customElement('schmancy-details')\r\nexport default class SchmancyDetails extends TailwindElement(css`\r\n\t:host {\r\n\t\tdisplay: block;\r\n\t\tposition: relative;\r\n\t}\r\n\r\n\t/* Hide browser default marker */\r\n\tsummary::-webkit-details-marker {\r\n\t\tdisplay: none;\r\n\t}\r\n\r\n\tsummary {\r\n\t\tlist-style: none;\r\n\t}\r\n\r\n\t/* Container border-radius following M3 spec */\r\n\tdetails {\r\n\t\tborder-radius: 12px; /* M3 medium component radius */\r\n\t\ttransition: all 200ms cubic-bezier(0.2, 0, 0, 1); /* M3 standard easing */\r\n\t}\r\n\r\n\t/* Variant-specific styles */\r\n\t:host([variant='outlined']) details {\r\n\t\tborder: 1px solid var(--schmancy-sys-color-outline-variant);\r\n\t\tbackground-color: var(--schmancy-sys-color-surface-default);\r\n\t}\r\n\r\n\t:host([variant='filled']) details {\r\n\t\tbackground-color: var(--schmancy-sys-color-surface-container);\r\n\t}\r\n\r\n\t:host([variant='elevated']) details {\r\n\t\tbackground-color: var(--schmancy-sys-color-surface-low);\r\n\t\tbox-shadow: var(--schmancy-sys-elevation-1);\r\n\t}\r\n\r\n\t:host([variant='elevated']) details[open] {\r\n\t\tbox-shadow: var(--schmancy-sys-elevation-2);\r\n\t\tbackground-color: var(--schmancy-sys-color-surface-container);\r\n\t}\r\n\r\n\t/* Content animation */\r\n\t@keyframes slideDown {\r\n\t\tfrom {\r\n\t\t\topacity: 0;\r\n\t\t\ttransform: translateY(-8px);\r\n\t\t}\r\n\t\tto {\r\n\t\t\topacity: 1;\r\n\t\t\ttransform: translateY(0);\r\n\t\t}\r\n\t}\r\n\r\n\t.content-wrapper[data-open='true'] {\r\n\t\tanimation: slideDown 250ms cubic-bezier(0.2, 0, 0, 1);\r\n\t}\r\n\r\n\t/* Ripple effect */\r\n\t@keyframes ripple {\r\n\t\tto {\r\n\t\t\ttransform: scale(4);\r\n\t\t\topacity: 0;\r\n\t\t}\r\n\t}\r\n\r\n\t/* Focus ring following M3 spec */\r\n\tsummary:focus-visible {\r\n\t\toutline: 2px solid var(--schmancy-sys-color-primary-default);\r\n\t\toutline-offset: 2px;\r\n\t\tborder-radius: 12px;\r\n\t}\r\n\r\n\t/* Icon rotation transition */\r\n\t.icon-wrapper {\r\n\t\ttransition: transform 200ms cubic-bezier(0.2, 0, 0, 1);\r\n\t}\r\n\r\n\t.icon-wrapper[data-open='true'] {\r\n\t\ttransform: rotate(90deg);\r\n\t}\r\n`) {\r\n\tprotected static shadowRootOptions = {\r\n\t\t...LitElement.shadowRootOptions,\r\n\t\tmode: 'open' as const,\r\n\t\tdelegatesFocus: true,\r\n\t}\r\n\r\n\t@property() summary = ''\r\n\t@property({ type: Boolean, reflect: true })\r\n\tget open() {\r\n\t\treturn this._open$.value\r\n\t}\r\n\tset open(value: boolean) {\r\n\t\tif (this._open$.value !== value) {\r\n\t\t\tthis._open$.next(value)\r\n\t\t}\r\n\t}\r\n\t@property({ reflect: true }) variant: 'default' | 'outlined' | 'filled' | 'elevated' = 'default'\r\n\r\n\t// Internal state for ripple effects\r\n\t@state() private ripples: Array<{ x: number; y: number; id: number }> = []\r\n\t@state() private pressed = false\r\n\t@state() private _isOpen = false\r\n\r\n\tprivate nextRippleId = 0\r\n\tprivate _open$ = new BehaviorSubject<boolean>(false)\r\n\r\n\tconnectedCallback() {\r\n\t\tsuper.connectedCallback()\r\n\r\n\t\t// Subscribe to open state changes\r\n\t\tthis._open$.pipe(\r\n\t\t\ttap(isOpen => {\r\n\t\t\t\tthis._isOpen = isOpen\r\n\t\t\t\tthis.requestUpdate()\r\n\t\t\t}),\r\n\t\t\ttakeUntil(this.disconnecting)\r\n\t\t).subscribe()\r\n\t}\r\n\r\n\trender() {\r\n\t\t// Define state layer opacity based on variant and state\r\n\t\tconst getStateLayerOpacity = () => {\r\n\t\t\tif (this.pressed) return 'opacity-[0.12]' // M3 pressed state\r\n\t\t\tif (this.variant === 'default') {\r\n\t\t\t\treturn 'opacity-0 hover:opacity-[0.08]' // M3 hover state\r\n\t\t\t}\r\n\t\t\treturn 'opacity-0 hover:opacity-[0.04]' // Reduced for filled/elevated variants\r\n\t\t}\r\n\r\n\t\t// Summary classes following M3 specs\r\n\t\tconst summaryClasses = this.classMap({\r\n\t\t\t'cursor-pointer': true,\r\n\t\t\t'select-none': true,\r\n\t\t\t'relative': true,\r\n\t\t\t'flex': true,\r\n\t\t\t'items-center': true,\r\n\t\t\t'gap-3': true,\r\n\t\t\t'min-h-[48px]': true, // M3 minimum touch target\r\n\t\t\t'sm:min-h-[56px]': true, // Desktop size\r\n\t\t\t'px-4': true, // M3 standard padding\r\n\t\t\t'sm:px-6': true,\r\n\t\t\t'py-3': true,\r\n\t\t\t'sm:py-4': true,\r\n\t\t\t'rounded-xl': true, // Match container radius\r\n\t\t\t'transition-colors': true,\r\n\t\t\t'duration-200': true,\r\n\t\t\t'text-surface-on': true,\r\n\t\t\t'group': true, // For hover states on icon\r\n\t\t})\r\n\r\n\t\t// State layer for interactive feedback\r\n\t\tconst stateLayerClasses = this.classMap({\r\n\t\t\t'absolute': true,\r\n\t\t\t'inset-0': true,\r\n\t\t\t'rounded-xl': true,\r\n\t\t\t'pointer-events-none': true,\r\n\t\t\t'transition-opacity': true,\r\n\t\t\t'duration-200': true,\r\n\t\t\t'bg-surface-on': true,\r\n\t\t\t[getStateLayerOpacity()]: true,\r\n\t\t})\r\n\r\n\t\t// Content wrapper classes\r\n\t\tconst contentClasses = this.classMap({\r\n\t\t\t'px-4': true,\r\n\t\t\t'sm:px-6': true,\r\n\t\t\t'pb-3': true,\r\n\t\t\t'sm:pb-4': true,\r\n\t\t\t'text-surface-onVariant': true,\r\n\t\t\t'text-sm': true,\r\n\t\t\t'sm:text-base': true,\r\n\t\t})\r\n\r\n\t\t// Icon classes with group hover\r\n\t\tconst iconClasses = this.classMap({\r\n\t\t\t'flex': true,\r\n\t\t\t'items-center': true,\r\n\t\t\t'justify-center': true,\r\n\t\t\t'w-6': true,\r\n\t\t\t'h-6': true,\r\n\t\t\t'rounded-full': true,\r\n\t\t\t'flex-shrink-0': true,\r\n\t\t\t'text-surface-onVariant': true,\r\n\t\t\t'group-hover:text-surface-on': true,\r\n\t\t\t'transition-all': true,\r\n\t\t\t'duration-200': true,\r\n\t\t})\r\n\r\n\t\treturn html`\r\n\t\t\t<details\r\n\t\t\t\t?open=${this._isOpen}\r\n\t\t\t\t@toggle=${this._handleToggle}\r\n\t\t\t\tclass=\"w-full overflow-hidden\"\r\n\t\t\t>\r\n\t\t\t\t<summary\r\n\t\t\t\t\tclass=${summaryClasses}\r\n\t\t\t\t\t@click=${this._handleClick}\r\n\t\t\t\t\t@mousedown=${this._handleMouseDown}\r\n\t\t\t\t\t@mouseup=${this._handleMouseUp}\r\n\t\t\t\t\t@mouseleave=${this._handleMouseLeave}\r\n\t\t\t\t\t@keydown=${this._handleKeyDown}\r\n\t\t\t\t\t@keyup=${this._handleKeyUp}\r\n\t\t\t\t\ttabindex=\"0\"\r\n\t\t\t\t>\r\n\t\t\t\t\t<!-- State layer for hover/focus/pressed states -->\r\n\t\t\t\t\t<div class=${stateLayerClasses}></div>\r\n\r\n\t\t\t\t\t<!-- Ripple container -->\r\n\t\t\t\t\t<div class=\"absolute inset-0 rounded-xl overflow-hidden pointer-events-none\">\r\n\t\t\t\t\t\t${this.ripples.map(\r\n\t\t\t\t\t\t\tripple => html`\r\n\t\t\t\t\t\t\t\t<span\r\n\t\t\t\t\t\t\t\t\tclass=\"absolute rounded-full scale-0 animate-[ripple_600ms_linear] bg-surface-on opacity-[0.12] pointer-events-none\"\r\n\t\t\t\t\t\t\t\t\tstyle=\"\r\n\t\t\t\t\t\t\t\t\t\tleft: ${ripple.x}px;\r\n\t\t\t\t\t\t\t\t\t\ttop: ${ripple.y}px;\r\n\t\t\t\t\t\t\t\t\t\twidth: 20px;\r\n\t\t\t\t\t\t\t\t\t\theight: 20px;\r\n\t\t\t\t\t\t\t\t\t\tmargin-left: -10px;\r\n\t\t\t\t\t\t\t\t\t\tmargin-top: -10px;\r\n\t\t\t\t\t\t\t\t\t\"\r\n\t\t\t\t\t\t\t\t></span>\r\n\t\t\t\t\t\t\t`,\r\n\t\t\t\t\t\t)}\r\n\t\t\t\t\t</div>\r\n\r\n\t\t\t\t\t<!-- Summary content -->\r\n\t\t\t\t\t<span class=\"relative flex-1 font-medium text-base sm:text-lg z-10\">\r\n\t\t\t\t\t\t<slot name=\"summary\">${this.summary}</slot>\r\n\t\t\t\t\t</span>\r\n\r\n\t\t\t\t\t<!-- Expand/collapse icon -->\r\n\t\t\t\t\t<span\r\n\t\t\t\t\t\tclass=${iconClasses}\r\n\t\t\t\t\t\tdata-open=${this._isOpen}\r\n\t\t\t\t\t\tstyle=\"transform: rotate(${this._isOpen ? '90deg' : '0deg'})\"\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t<svg\r\n\t\t\t\t\t\t\twidth=\"24\"\r\n\t\t\t\t\t\t\theight=\"24\"\r\n\t\t\t\t\t\t\tviewBox=\"0 0 24 24\"\r\n\t\t\t\t\t\t\tfill=\"none\"\r\n\t\t\t\t\t\t\txmlns=\"http://www.w3.org/2000/svg\"\r\n\t\t\t\t\t\t\tclass=\"w-5 h-5 sm:w-6 sm:h-6\"\r\n\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t<path\r\n\t\t\t\t\t\t\t\td=\"M9 6L15 12L9 18\"\r\n\t\t\t\t\t\t\t\tstroke=\"currentColor\"\r\n\t\t\t\t\t\t\t\tstroke-width=\"2\"\r\n\t\t\t\t\t\t\t\tstroke-linecap=\"round\"\r\n\t\t\t\t\t\t\t\tstroke-linejoin=\"round\"\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t</svg>\r\n\t\t\t\t\t</span>\r\n\t\t\t\t</summary>\r\n\r\n\t\t\t\t<!-- Content area -->\r\n\t\t\t\t<div\r\n\t\t\t\t\tclass=${contentClasses}\r\n\t\t\t\t\tdata-open=${this._isOpen}\r\n\t\t\t\t\tstyle=\"${this._isOpen ? '' : 'display: none;'}\"\r\n\t\t\t\t>\r\n\t\t\t\t\t${when(\r\n\t\t\t\t\t\tthis._isOpen,\r\n\t\t\t\t\t\t() => html`\r\n\t\t\t\t\t\t\t<div class=\"content-wrapper\" data-open=${this._isOpen}>\r\n\t\t\t\t\t\t\t\t<slot></slot>\r\n\t\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t`\r\n\t\t\t\t\t)}\r\n\t\t\t\t</div>\r\n\t\t\t</details>\r\n\t\t`\r\n\t}\r\n\r\n\tprivate _handleToggle(e: Event) {\r\n\t\tconst details = e.target as HTMLDetailsElement\r\n\t\t// Sync the internal state with the actual details element state\r\n\t\tthis._open$.next(details.open)\r\n\r\n\t\t// Dispatch custom event\r\n\t\tthis.dispatchEvent(\r\n\t\t\tnew CustomEvent('toggle', {\r\n\t\t\t\tdetail: { open: details.open },\r\n\t\t\t\tbubbles: true,\r\n\t\t\t\tcomposed: true,\r\n\t\t\t}),\r\n\t\t)\r\n\t}\r\n\r\n\tprivate _handleClick(e: MouseEvent) {\r\n\t\t// Prevent default to control the toggle manually\r\n\t\te.preventDefault()\r\n\r\n\t\t// Add ripple effect at click position\r\n\t\tconst rect = (e.currentTarget as HTMLElement).getBoundingClientRect()\r\n\t\tconst x = e.clientX - rect.left\r\n\t\tconst y = e.clientY - rect.top\r\n\t\tconst id = this.nextRippleId++\r\n\r\n\t\tthis.ripples = [...this.ripples, { x, y, id }]\r\n\r\n\t\t// Remove ripple after animation\r\n\t\tsetTimeout(() => {\r\n\t\t\tthis.ripples = this.ripples.filter(r => r.id !== id)\r\n\t\t}, 600)\r\n\r\n\t\t// Toggle the open state through the BehaviorSubject\r\n\t\tthis._open$.next(!this._open$.value)\r\n\r\n\t\t// Dispatch the toggle event\r\n\t\tthis.dispatchEvent(\r\n\t\t\tnew CustomEvent('toggle', {\r\n\t\t\t\tdetail: { open: this._open$.value },\r\n\t\t\t\tbubbles: true,\r\n\t\t\t\tcomposed: true,\r\n\t\t\t}),\r\n\t\t)\r\n\t}\r\n\r\n\tprivate _handleMouseDown() {\r\n\t\tthis.pressed = true\r\n\t}\r\n\r\n\tprivate _handleMouseUp() {\r\n\t\tthis.pressed = false\r\n\t}\r\n\r\n\tprivate _handleMouseLeave() {\r\n\t\tthis.pressed = false\r\n\t}\r\n\r\n\tprivate _handleKeyDown(e: KeyboardEvent) {\r\n\t\t// Handle keyboard activation\r\n\t\tif (e.key === 'Enter' || e.key === ' ') {\r\n\t\t\te.preventDefault()\r\n\t\t\tthis.pressed = true\r\n\r\n\t\t\t// Add ripple effect from center\r\n\t\t\tconst rect = (e.currentTarget as HTMLElement).getBoundingClientRect()\r\n\t\t\tconst x = rect.width / 2\r\n\t\t\tconst y = rect.height / 2\r\n\t\t\tconst id = this.nextRippleId++\r\n\r\n\t\t\tthis.ripples = [...this.ripples, { x, y, id }]\r\n\r\n\t\t\tsetTimeout(() => {\r\n\t\t\t\tthis.ripples = this.ripples.filter(r => r.id !== id)\r\n\t\t\t}, 600)\r\n\r\n\t\t\t// Toggle the open state through the BehaviorSubject\r\n\t\t\tthis._open$.next(!this._open$.value)\r\n\r\n\t\t\t// Dispatch the toggle event\r\n\t\t\tthis.dispatchEvent(\r\n\t\t\t\tnew CustomEvent('toggle', {\r\n\t\t\t\t\tdetail: { open: this._open$.value },\r\n\t\t\t\t\tbubbles: true,\r\n\t\t\t\t\tcomposed: true,\r\n\t\t\t\t}),\r\n\t\t\t)\r\n\t\t}\r\n\t}\r\n\r\n\tprivate _handleKeyUp(e: KeyboardEvent) {\r\n\t\tif (e.key === 'Enter' || e.key === ' ') {\r\n\t\t\tthis.pressed = false\r\n\t\t}\r\n\t}\r\n}\r\n\r\ndeclare global {\r\n\tinterface HTMLElementTagNameMap {\r\n\t\t'schmancy-details': SchmancyDetails\r\n\t}\r\n}\r\n"],"names":["SchmancyDetails","TailwindElement","css","super","arguments","this","summary","variant","ripples","pressed","_isOpen","nextRippleId","_open$","BehaviorSubject","open","value","next","connectedCallback","pipe","tap","isOpen","requestUpdate","takeUntil","disconnecting","subscribe","render","summaryClasses","classMap","relative","flex","group","stateLayerClasses","absolute","getStateLayerOpacity","contentClasses","iconClasses","html","_handleToggle","_handleClick","_handleMouseDown","_handleMouseUp","_handleMouseLeave","_handleKeyDown","_handleKeyUp","map","ripple","x","y","when","e","details","target","dispatchEvent","CustomEvent","detail","bubbles","composed","preventDefault","rect","currentTarget","getBoundingClientRect","clientX","left","clientY","top","id","setTimeout","filter","r","key","width","height","shadowRootOptions","LitElement","mode","delegatesFocus","__decorateClass","property","prototype","type","Boolean","reflect","state","customElement"],"mappings":"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"}
@@ -1,177 +0,0 @@
1
- "use strict";require("rxjs");const y=require("lit/directives/class-map.js");require("lit/directives/style-map.js");const a=require("lit/decorators.js"),u=require("./tailwind.mixin-BiRVB4Hl.cjs"),h=require("lit"),f=require("lit/directives/if-defined.js");var m=Object.getOwnPropertyDescriptor;let b=class extends u.TailwindElement(h.css`
2
- :host {
3
- display: flex;
4
- gap: 0.5rem;
5
- padding: 0.5rem 1rem;
6
- align-items: center;
7
- justify-content: flex-end;
8
- }
9
- `){render(){return h.html`<slot></slot>`}};b=((t,s,r,i)=>{for(var o,e=i>1?void 0:i?m(s,r):s,l=t.length-1;l>=0;l--)(o=t[l])&&(e=o(e)||e);return e})([a.customElement("schmancy-card-action")],b);var g=Object.defineProperty,w=Object.getOwnPropertyDescriptor,d=(t,s,r,i)=>{for(var o,e=i>1?void 0:i?w(s,r):s,l=t.length-1;l>=0;l--)(o=t[l])&&(e=(i?o(s,r,e):o(e))||e);return i&&e&&g(s,r,e),e};let n=class extends u.TailwindElement(h.css`
10
- :host {
11
- display: block;
12
- position: relative;
13
- border-radius: 12px; /* M3 spec: 12px for cards */
14
- transition: box-shadow 200ms cubic-bezier(0.2, 0, 0, 1);
15
- outline: none;
16
- }
17
-
18
- /* Type-specific base styles */
19
- :host([type='elevated']) {
20
- background-color: var(--schmancy-sys-color-surface-low);
21
- box-shadow: var(--shadow-1);
22
- }
23
-
24
- :host([type='filled']) {
25
- background-color: var(--schmancy-sys-color-surface-highest);
26
- box-shadow: var(--shadow-0);
27
- }
28
-
29
- :host([type='outlined']) {
30
- background-color: var(--schmancy-sys-color-surface-default);
31
- border: 1px solid var(--schmancy-sys-color-outlineVariant);
32
- box-shadow: var(--shadow-0);
33
- }
34
-
35
- /* Interactive state */
36
- :host([interactive]) {
37
- cursor: pointer;
38
- -webkit-tap-highlight-color: transparent;
39
- }
40
-
41
- /* Elevated interactive states */
42
- :host([type='elevated'][interactive]:hover:not([disabled])) {
43
- box-shadow: var(--shadow-2);
44
- }
45
-
46
- :host([type='elevated'][dragged]) {
47
- box-shadow: var(--shadow-3);
48
- }
49
-
50
- /* Filled interactive states */
51
- :host([type='filled'][interactive]:hover:not([disabled])) {
52
- box-shadow: var(--shadow-1);
53
- }
54
-
55
- :host([type='filled'][dragged]) {
56
- box-shadow: var(--shadow-3);
57
- }
58
-
59
- /* Outlined interactive states */
60
- :host([type='outlined'][interactive]:hover:not([disabled])) {
61
- box-shadow: var(--shadow-1);
62
- }
63
-
64
- :host([type='outlined'][dragged]) {
65
- box-shadow: var(--shadow-3);
66
- }
67
-
68
- /* Disabled state */
69
- :host([disabled]) {
70
- pointer-events: none;
71
- opacity: 0.38;
72
- }
73
-
74
- /* Focus ring */
75
- :host([interactive]:focus-visible:not([disabled])) {
76
- outline: 2px solid var(--schmancy-sys-color-primary-default);
77
- outline-offset: 2px;
78
- }
79
-
80
- /* Ripple effect animation */
81
- @keyframes ripple {
82
- to {
83
- transform: scale(4);
84
- opacity: 0;
85
- }
86
- }
87
- `){constructor(){super(...arguments),this.type="elevated",this.interactive=!1,this.disabled=!1,this.dragged=!1,this.role="article",this.ariaLabel="",this.pressed=!1,this.ripples=[],this.nextRippleId=0,this.handleClick=t=>{if(this.disabled||!this.interactive)return;const s=this.getBoundingClientRect(),r=t.clientX-s.left,i=t.clientY-s.top,o=this.nextRippleId++;this.ripples=[...this.ripples,{x:r,y:i,id:o}],setTimeout(()=>{this.ripples=this.ripples.filter(e=>e.id!==o)},600),this.href&&(this.target==="_blank"?window.open(this.href,"_blank"):window.location.href=this.href),this.dispatchEvent(new CustomEvent("schmancy-click",{detail:{value:this.type},bubbles:!0,composed:!0}))},this.handleKeyDown=t=>{if(!this.disabled&&this.interactive&&(t.key==="Enter"||t.key===" ")){t.preventDefault(),this.pressed=!0,this.setAttribute("pressed","");const s=this.getBoundingClientRect(),r=s.width/2,i=s.height/2,o=this.nextRippleId++;this.ripples=[...this.ripples,{x:r,y:i,id:o}],setTimeout(()=>{this.ripples=this.ripples.filter(e=>e.id!==o)},600),this.href&&(this.target==="_blank"?window.open(this.href,"_blank"):window.location.href=this.href),this.dispatchEvent(new CustomEvent("schmancy-click",{detail:{value:this.type},bubbles:!0,composed:!0}))}},this.handleKeyUp=t=>{t.key!=="Enter"&&t.key!==" "||(this.pressed=!1,this.removeAttribute("pressed"))},this.handleMouseDown=()=>{!this.disabled&&this.interactive&&(this.pressed=!0,this.setAttribute("pressed",""))},this.handleMouseUp=()=>{this.pressed=!1,this.removeAttribute("pressed")},this.handleMouseLeave=()=>{this.pressed=!1,this.removeAttribute("pressed")}}connectedCallback(){super.connectedCallback(),this.interactive&&!this.disabled&&(this.setAttribute("tabindex","0"),this.role&&this.role!=="article"||(this.role=this.href?"link":"button"))}updated(t){super.updated(t),(t.has("interactive")||t.has("disabled"))&&(this.interactive&&!this.disabled?(this.setAttribute("tabindex","0"),this.role&&this.role!=="article"||(this.role=this.href?"link":"button")):(this.removeAttribute("tabindex"),this.role!=="button"&&this.role!=="link"||(this.role="article")))}getStateLayerOpacity(){return!this.interactive||this.disabled?"opacity-0":this.pressed?"opacity-[0.1]":"opacity-0 hover:opacity-[0.08] focus-visible:opacity-[0.1]"}render(){const t=y.classMap({"relative w-full h-full rounded-xl":!0,"cursor-pointer":this.interactive&&!this.disabled}),s=y.classMap({"absolute inset-0 rounded-xl pointer-events-none transition-opacity duration-200 bg-surface-on":!0,[this.getStateLayerOpacity()]:!0});return h.html`
88
- <div
89
- class=${t}
90
- @click=${this.handleClick}
91
- @keydown=${this.handleKeyDown}
92
- @keyup=${this.handleKeyUp}
93
- @mousedown=${this.handleMouseDown}
94
- @mouseup=${this.handleMouseUp}
95
- @mouseleave=${this.handleMouseLeave}
96
- aria-label=${f.ifDefined(this.ariaLabel)}
97
- aria-disabled=${this.disabled?"true":"false"}
98
- >
99
- <!-- State layer for hover/focus/pressed states -->
100
- <div class=${s}></div>
101
-
102
- <!-- Ripple container for click effects -->
103
- ${this.interactive?h.html`
104
- <div class="absolute inset-0 rounded-xl overflow-hidden pointer-events-none">
105
- ${this.ripples.map(r=>h.html`
106
- <span
107
- class="absolute rounded-full scale-0 animate-[ripple_600ms_linear] bg-surface-on opacity-[0.12] pointer-events-none"
108
- style="
109
- left: ${r.x}px;
110
- top: ${r.y}px;
111
- width: 20px;
112
- height: 20px;
113
- margin-left: -10px;
114
- margin-top: -10px;
115
- "
116
- ></span>
117
- `)}
118
- </div>
119
- `:""}
120
-
121
- <!-- Card content -->
122
- <div class="relative h-full w-full rounded-xl">
123
- <slot></slot>
124
- </div>
125
- </div>
126
- `}};n.shadowRootOptions={...h.LitElement.shadowRootOptions,mode:"open",delegatesFocus:!0},d([a.property({reflect:!0})],n.prototype,"type",2),d([a.property({type:Boolean,reflect:!0})],n.prototype,"interactive",2),d([a.property({type:Boolean,reflect:!0})],n.prototype,"disabled",2),d([a.property({type:Boolean,reflect:!0})],n.prototype,"dragged",2),d([a.property()],n.prototype,"href",2),d([a.property()],n.prototype,"target",2),d([a.property({attribute:"role"})],n.prototype,"role",2),d([a.property({attribute:"aria-label"})],n.prototype,"ariaLabel",2),d([a.state()],n.prototype,"pressed",2),d([a.state()],n.prototype,"ripples",2),n=d([a.customElement("schmancy-card")],n);var x=Object.getOwnPropertyDescriptor;let v=class extends u.TailwindElement(h.css`
127
- :host {
128
- display: block;
129
- padding: 1rem;
130
- }
131
- `){render(){return h.html`<slot></slot>`}};v=((t,s,r,i)=>{for(var o,e=i>1?void 0:i?x(s,r):s,l=t.length-1;l>=0;l--)(o=t[l])&&(e=o(e)||e);return e})([a.customElement("schmancy-card-content")],v);var k=Object.defineProperty,E=Object.getOwnPropertyDescriptor,c=(t,s,r,i)=>{for(var o,e=i>1?void 0:i?E(s,r):s,l=t.length-1;l>=0;l--)(o=t[l])&&(e=(i?o(s,r,e):o(e))||e);return i&&e&&k(s,r,e),e};let p=class extends u.TailwindElement(h.css`
132
- :host {
133
- display: block;
134
- position: relative;
135
- height: 200px;
136
- overflow: hidden;
137
- }
138
-
139
- /* Allow height to be overridden when used in flex/grid layouts */
140
- :host-context(.h-full) {
141
- height: 100%;
142
- }
143
-
144
- ::slotted(img),
145
- img {
146
- width: 100%;
147
- height: 100%;
148
- object-position: center;
149
- }
150
-
151
- /* Object fit styles based on fit attribute */
152
- :host([fit="contain"]) img,
153
- :host([fit="contain"]) ::slotted(img) {
154
- object-fit: contain;
155
- }
156
-
157
- :host([fit="cover"]) img,
158
- :host([fit="cover"]) ::slotted(img) {
159
- object-fit: cover;
160
- }
161
-
162
- :host([fit="fill"]) img,
163
- :host([fit="fill"]) ::slotted(img) {
164
- object-fit: fill;
165
- }
166
-
167
- :host([fit="none"]) img,
168
- :host([fit="none"]) ::slotted(img) {
169
- object-fit: none;
170
- }
171
-
172
- :host([fit="scale-down"]) img,
173
- :host([fit="scale-down"]) ::slotted(img) {
174
- object-fit: scale-down;
175
- }
176
- `){constructor(){super(...arguments),this.src="",this.fit="contain",this.alt=""}render(){return this.src?h.html`<img src="${this.src}" alt="${this.alt}" />`:h.html`<slot></slot>`}};c([a.property({type:String,reflect:!0})],p.prototype,"src",2),c([a.property({type:String,reflect:!0})],p.prototype,"fit",2),c([a.property({type:String})],p.prototype,"alt",2),p=c([a.customElement("schmancy-card-media")],p);
177
- //# sourceMappingURL=media-CdM6XhRo.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"media-CdM6XhRo.cjs","sources":["../src/card/actions.ts","../src/card/card.ts","../src/card/content.ts","../src/card/media.ts"],"sourcesContent":["import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\n\n/**\n * @element schmancy-card-action\n * @slot - The content of the action\n */\n@customElement('schmancy-card-action')\nexport default class SchmancyCardAction extends TailwindElement(css`\n\t:host {\n\t\tdisplay: flex;\n\t\tgap: 0.5rem;\n\t\tpadding: 0.5rem 1rem;\n\t\talign-items: center;\n\t\tjustify-content: flex-end;\n\t}\n`) {\n\tprotected render(): unknown {\n\t\treturn html`<slot></slot>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card-action': SchmancyCardAction\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { classMap } from 'lit/directives/class-map.js'\nimport { ifDefined } from 'lit/directives/if-defined.js'\n\n@customElement('schmancy-card')\nexport default class SchmancyCard extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tposition: relative;\n\t\tborder-radius: 12px; /* M3 spec: 12px for cards */\n\t\ttransition: box-shadow 200ms cubic-bezier(0.2, 0, 0, 1);\n\t\toutline: none;\n\t}\n\n\t/* Type-specific base styles */\n\t:host([type='elevated']) {\n\t\tbackground-color: var(--schmancy-sys-color-surface-low);\n\t\tbox-shadow: var(--shadow-1);\n\t}\n\n\t:host([type='filled']) {\n\t\tbackground-color: var(--schmancy-sys-color-surface-highest);\n\t\tbox-shadow: var(--shadow-0);\n\t}\n\n\t:host([type='outlined']) {\n\t\tbackground-color: var(--schmancy-sys-color-surface-default);\n\t\tborder: 1px solid var(--schmancy-sys-color-outlineVariant);\n\t\tbox-shadow: var(--shadow-0);\n\t}\n\n\t/* Interactive state */\n\t:host([interactive]) {\n\t\tcursor: pointer;\n\t\t-webkit-tap-highlight-color: transparent;\n\t}\n\n\t/* Elevated interactive states */\n\t:host([type='elevated'][interactive]:hover:not([disabled])) {\n\t\tbox-shadow: var(--shadow-2);\n\t}\n\n\t:host([type='elevated'][dragged]) {\n\t\tbox-shadow: var(--shadow-3);\n\t}\n\n\t/* Filled interactive states */\n\t:host([type='filled'][interactive]:hover:not([disabled])) {\n\t\tbox-shadow: var(--shadow-1);\n\t}\n\n\t:host([type='filled'][dragged]) {\n\t\tbox-shadow: var(--shadow-3);\n\t}\n\n\t/* Outlined interactive states */\n\t:host([type='outlined'][interactive]:hover:not([disabled])) {\n\t\tbox-shadow: var(--shadow-1);\n\t}\n\n\t:host([type='outlined'][dragged]) {\n\t\tbox-shadow: var(--shadow-3);\n\t}\n\n\t/* Disabled state */\n\t:host([disabled]) {\n\t\tpointer-events: none;\n\t\topacity: 0.38;\n\t}\n\n\t/* Focus ring */\n\t:host([interactive]:focus-visible:not([disabled])) {\n\t\toutline: 2px solid var(--schmancy-sys-color-primary-default);\n\t\toutline-offset: 2px;\n\t}\n\n\t/* Ripple effect animation */\n\t@keyframes ripple {\n\t\tto {\n\t\t\ttransform: scale(4);\n\t\t\topacity: 0;\n\t\t}\n\t}\n`) {\n\tprotected static shadowRootOptions = {\n\t\t...LitElement.shadowRootOptions,\n\t\tmode: 'open',\n\t\tdelegatesFocus: true,\n\t}\n\n\t/**\n\t * The visual style of the card.\n\t * @default 'elevated'\n\t */\n\t@property({ reflect: true })\n\ttype: 'elevated' | 'filled' | 'outlined' = 'elevated'\n\n\t/**\n\t * Makes the card interactive (clickable).\n\t * @default false\n\t */\n\t@property({ type: Boolean, reflect: true })\n\tinteractive = false\n\n\t/**\n\t * Disables the card.\n\t * @default false\n\t */\n\t@property({ type: Boolean, reflect: true })\n\tdisabled = false\n\n\t/**\n\t * Indicates the card is being dragged.\n\t * @default false\n\t */\n\t@property({ type: Boolean, reflect: true })\n\tdragged = false\n\n\t/**\n\t * URL to navigate to when card is clicked (makes it act like a link).\n\t */\n\t@property()\n\thref?: string\n\n\t/**\n\t * Target for the link navigation.\n\t */\n\t@property()\n\ttarget?: string\n\n\t/**\n\t * ARIA role for accessibility.\n\t */\n\t@property({ attribute: 'role' })\n\toverride role = 'article'\n\n\t/**\n\t * ARIA label for accessibility.\n\t */\n\t@property({ attribute: 'aria-label' })\n\toverride ariaLabel: string = ''\n\n\t// Internal state for interaction feedback\n\t@state() pressed = false\n\t@state() private ripples: Array<{ x: number; y: number; id: number }> = []\n\n\tprivate nextRippleId = 0\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\n\t\t// Set appropriate ARIA attributes for interactive cards\n\t\tif (this.interactive && !this.disabled) {\n\t\t\tthis.setAttribute('tabindex', '0')\n\t\t\tif (!this.role || this.role === 'article') {\n\t\t\t\tthis.role = this.href ? 'link' : 'button'\n\t\t\t}\n\t\t}\n\t}\n\n\tupdated(changedProperties: Map<string, any>) {\n\t\tsuper.updated(changedProperties)\n\n\t\t// Update ARIA attributes when interactive or disabled state changes\n\t\tif (changedProperties.has('interactive') || changedProperties.has('disabled')) {\n\t\t\tif (this.interactive && !this.disabled) {\n\t\t\t\tthis.setAttribute('tabindex', '0')\n\t\t\t\tif (!this.role || this.role === 'article') {\n\t\t\t\t\tthis.role = this.href ? 'link' : 'button'\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tthis.removeAttribute('tabindex')\n\t\t\t\tif (this.role === 'button' || this.role === 'link') {\n\t\t\t\t\tthis.role = 'article'\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate handleClick = (e: MouseEvent) => {\n\t\tif (this.disabled || !this.interactive) return\n\n\t\t// Add ripple effect at click position\n\t\tconst rect = this.getBoundingClientRect()\n\t\tconst x = e.clientX - rect.left\n\t\tconst y = e.clientY - rect.top\n\t\tconst id = this.nextRippleId++\n\n\t\tthis.ripples = [...this.ripples, { x, y, id }]\n\n\t\t// Remove ripple after animation completes\n\t\tsetTimeout(() => {\n\t\t\tthis.ripples = this.ripples.filter(r => r.id !== id)\n\t\t}, 600)\n\n\t\t// Navigate if href is provided\n\t\tif (this.href) {\n\t\t\tif (this.target === '_blank') {\n\t\t\t\twindow.open(this.href, '_blank')\n\t\t\t} else {\n\t\t\t\twindow.location.href = this.href\n\t\t\t}\n\t\t}\n\n\t\t// Dispatch click event for parent components to handle\n\t\tthis.dispatchEvent(\n\t\t\tnew CustomEvent('schmancy-click', {\n\t\t\t\tdetail: { value: this.type },\n\t\t\t\tbubbles: true,\n\t\t\t\tcomposed: true,\n\t\t\t}),\n\t\t)\n\t}\n\n\tprivate handleKeyDown = (e: KeyboardEvent) => {\n\t\tif (this.disabled || !this.interactive) return\n\n\t\t// Activate on Enter or Space for keyboard navigation\n\t\tif (e.key === 'Enter' || e.key === ' ') {\n\t\t\te.preventDefault()\n\t\t\tthis.pressed = true\n\t\t\tthis.setAttribute('pressed', '')\n\n\t\t\t// Simulate click\n\t\t\tconst rect = this.getBoundingClientRect()\n\t\t\tconst x = rect.width / 2\n\t\t\tconst y = rect.height / 2\n\t\t\tconst id = this.nextRippleId++\n\n\t\t\tthis.ripples = [...this.ripples, { x, y, id }]\n\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis.ripples = this.ripples.filter(r => r.id !== id)\n\t\t\t}, 600)\n\n\t\t\tif (this.href) {\n\t\t\t\tif (this.target === '_blank') {\n\t\t\t\t\twindow.open(this.href, '_blank')\n\t\t\t\t} else {\n\t\t\t\t\twindow.location.href = this.href\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis.dispatchEvent(\n\t\t\t\tnew CustomEvent('schmancy-click', {\n\t\t\t\t\tdetail: { value: this.type },\n\t\t\t\t\tbubbles: true,\n\t\t\t\t\tcomposed: true,\n\t\t\t\t}),\n\t\t\t)\n\t\t}\n\t}\n\n\tprivate handleKeyUp = (e: KeyboardEvent) => {\n\t\tif (e.key === 'Enter' || e.key === ' ') {\n\t\t\tthis.pressed = false\n\t\t\tthis.removeAttribute('pressed')\n\t\t}\n\t}\n\n\tprivate handleMouseDown = () => {\n\t\tif (this.disabled || !this.interactive) return\n\t\tthis.pressed = true\n\t\tthis.setAttribute('pressed', '')\n\t}\n\n\tprivate handleMouseUp = () => {\n\t\tthis.pressed = false\n\t\tthis.removeAttribute('pressed')\n\t}\n\n\tprivate handleMouseLeave = () => {\n\t\tthis.pressed = false\n\t\tthis.removeAttribute('pressed')\n\t}\n\n\t// Get the classes for state layer based on current state\n\tprivate getStateLayerOpacity(): string {\n\t\tif (!this.interactive || this.disabled) return 'opacity-0'\n\t\tif (this.pressed) return 'opacity-[0.1]' // M3 pressed: 0.1\n\t\treturn 'opacity-0 hover:opacity-[0.08] focus-visible:opacity-[0.1]' // M3 hover: 0.08, focus: 0.1\n\t}\n\n\tprotected render() {\n\t\tconst containerClasses = classMap({\n\t\t\t'relative w-full h-full rounded-xl': true,\n\t\t\t'cursor-pointer': this.interactive && !this.disabled,\n\t\t})\n\n\t\tconst stateLayerClasses = classMap({\n\t\t\t'absolute inset-0 rounded-xl pointer-events-none transition-opacity duration-200 bg-surface-on': true,\n\t\t\t[this.getStateLayerOpacity()]: true,\n\t\t})\n\n\t\treturn html`\n\t\t\t<div\n\t\t\t\tclass=${containerClasses}\n\t\t\t\t@click=${this.handleClick}\n\t\t\t\t@keydown=${this.handleKeyDown}\n\t\t\t\t@keyup=${this.handleKeyUp}\n\t\t\t\t@mousedown=${this.handleMouseDown}\n\t\t\t\t@mouseup=${this.handleMouseUp}\n\t\t\t\t@mouseleave=${this.handleMouseLeave}\n\t\t\t\taria-label=${ifDefined(this.ariaLabel)}\n\t\t\t\taria-disabled=${this.disabled ? 'true' : 'false'}\n\t\t\t>\n\t\t\t\t<!-- State layer for hover/focus/pressed states -->\n\t\t\t\t<div class=${stateLayerClasses}></div>\n\n\t\t\t\t<!-- Ripple container for click effects -->\n\t\t\t\t${this.interactive\n\t\t\t\t\t? html`\n\t\t\t\t\t\t\t<div class=\"absolute inset-0 rounded-xl overflow-hidden pointer-events-none\">\n\t\t\t\t\t\t\t\t${this.ripples.map(\n\t\t\t\t\t\t\t\t\tripple => html`\n\t\t\t\t\t\t\t\t\t\t<span\n\t\t\t\t\t\t\t\t\t\t\tclass=\"absolute rounded-full scale-0 animate-[ripple_600ms_linear] bg-surface-on opacity-[0.12] pointer-events-none\"\n\t\t\t\t\t\t\t\t\t\t\tstyle=\"\n\t\t\t\t\t\t\t\t\t\t\t\tleft: ${ripple.x}px;\n\t\t\t\t\t\t\t\t\t\t\t\ttop: ${ripple.y}px;\n\t\t\t\t\t\t\t\t\t\t\t\twidth: 20px;\n\t\t\t\t\t\t\t\t\t\t\t\theight: 20px;\n\t\t\t\t\t\t\t\t\t\t\t\tmargin-left: -10px;\n\t\t\t\t\t\t\t\t\t\t\t\tmargin-top: -10px;\n\t\t\t\t\t\t\t\t\t\t\t\"\n\t\t\t\t\t\t\t\t\t\t></span>\n\t\t\t\t\t\t\t\t\t`,\n\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t`\n\t\t\t\t\t: ''}\n\n\t\t\t\t<!-- Card content -->\n\t\t\t\t<div class=\"relative h-full w-full rounded-xl\">\n\t\t\t\t\t<slot></slot>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card': SchmancyCard\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\n\n/**\n * @element schmancy-card-content\n */\n@customElement('schmancy-card-content')\nexport default class SchmancyCardContent extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tpadding: 1rem;\n\t}\n`) {\n\tprotected render(): unknown {\n\t\treturn html`<slot></slot>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card-content': SchmancyCardContent\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\n/**\n * @element schmancy-card-media\n */\n@customElement('schmancy-card-media')\nexport default class SchmancyCardMedia extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tposition: relative;\n\t\theight: 200px;\n\t\toverflow: hidden;\n\t}\n\t\n\t/* Allow height to be overridden when used in flex/grid layouts */\n\t:host-context(.h-full) {\n\t\theight: 100%;\n\t}\n\t\n\t::slotted(img),\n\timg {\n\t\twidth: 100%;\n\t\theight: 100%;\n\t\tobject-position: center;\n\t}\n\t\n\t/* Object fit styles based on fit attribute */\n\t:host([fit=\"contain\"]) img,\n\t:host([fit=\"contain\"]) ::slotted(img) {\n\t\tobject-fit: contain;\n\t}\n\t\n\t:host([fit=\"cover\"]) img,\n\t:host([fit=\"cover\"]) ::slotted(img) {\n\t\tobject-fit: cover;\n\t}\n\t\n\t:host([fit=\"fill\"]) img,\n\t:host([fit=\"fill\"]) ::slotted(img) {\n\t\tobject-fit: fill;\n\t}\n\t\n\t:host([fit=\"none\"]) img,\n\t:host([fit=\"none\"]) ::slotted(img) {\n\t\tobject-fit: none;\n\t}\n\t\n\t:host([fit=\"scale-down\"]) img,\n\t:host([fit=\"scale-down\"]) ::slotted(img) {\n\t\tobject-fit: scale-down;\n\t}\n`) {\n\t@property({ type: String, reflect: true })\n\tsrc: string = ''\n\n\t@property({ type: String, reflect: true })\n\tfit: 'contain' | 'cover' | 'fill' | 'none' | 'scale-down' = 'contain'\n\t\n\t@property({ type: String })\n\talt: string = ''\n\n\tprotected render(): unknown {\n\t\t// If src is provided, render an img element\n\t\t// Otherwise, allow users to slot their own content\n\t\treturn this.src \n\t\t\t? html`<img src=\"${this.src}\" alt=\"${this.alt}\" />` \n\t\t\t: html`<slot></slot>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card-media': SchmancyCardMedia\n\t}\n}\n"],"names":["SchmancyCardAction","TailwindElement","css","render","html","customElement","SchmancyCard","super","arguments","this","type","interactive","disabled","dragged","role","ariaLabel","pressed","ripples","nextRippleId","handleClick","e","rect","getBoundingClientRect","x","clientX","left","y","clientY","top","id","setTimeout","filter","r","href","target","window","open","location","dispatchEvent","CustomEvent","detail","value","bubbles","composed","handleKeyDown","key","preventDefault","setAttribute","width","height","handleKeyUp","removeAttribute","handleMouseDown","handleMouseUp","handleMouseLeave","connectedCallback","changedProperties","updated","has","containerClasses","classMap","stateLayerClasses","getStateLayerOpacity","ifDefined","map","ripple","shadowRootOptions","LitElement","mode","delegatesFocus","__decorateClass","property","reflect","prototype","Boolean","attribute","state","SchmancyCardContent","SchmancyCardMedia","constructor","src","fit","alt","String"],"mappings":"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"}