@mhmo91/schmancy 0.8.3 → 0.8.6

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 (365) hide show
  1. package/dist/{animated-text-Bc3qyXjp.cjs → animated-text-B3DQRJBy.cjs} +2 -2
  2. package/dist/{animated-text-Bc3qyXjp.cjs.map → animated-text-B3DQRJBy.cjs.map} +1 -1
  3. package/dist/{animated-text-CNx6Pmlo.js → animated-text-BAj4-6hE.js} +3 -3
  4. package/dist/{animated-text-CNx6Pmlo.js.map → animated-text-BAj4-6hE.js.map} +1 -1
  5. package/dist/animated-text.cjs +1 -1
  6. package/dist/animated-text.js +1 -1
  7. package/dist/area.cjs +1 -1
  8. package/dist/{area.component-7mWxekxE.js → area.component-CP4DZ0d8.js} +3 -3
  9. package/dist/{area.component-7mWxekxE.js.map → area.component-CP4DZ0d8.js.map} +1 -1
  10. package/dist/{area.component-CS_gSutH.cjs → area.component-ChxSLt16.cjs} +2 -2
  11. package/dist/{area.component-CS_gSutH.cjs.map → area.component-ChxSLt16.cjs.map} +1 -1
  12. package/dist/area.js +1 -1
  13. package/dist/{autocomplete-y-IyzH4r.cjs → autocomplete-CAaVSg4g.cjs} +2 -2
  14. package/dist/{autocomplete-y-IyzH4r.cjs.map → autocomplete-CAaVSg4g.cjs.map} +1 -1
  15. package/dist/{autocomplete-Ci4jo3Ur.js → autocomplete-CGbACUYd.js} +4 -4
  16. package/dist/{autocomplete-Ci4jo3Ur.js.map → autocomplete-CGbACUYd.js.map} +1 -1
  17. package/dist/autocomplete.cjs +1 -1
  18. package/dist/autocomplete.js +1 -1
  19. package/dist/{avatar-DBfJucB9.cjs → avatar-nWOZXEsW.cjs} +3 -3
  20. package/dist/avatar-nWOZXEsW.cjs.map +1 -0
  21. package/dist/{avatar-BdyuuIk7.js → avatar-rLCF6MSI.js} +58 -58
  22. package/dist/avatar-rLCF6MSI.js.map +1 -0
  23. package/dist/badge.cjs +1 -1
  24. package/dist/badge.js +1 -1
  25. package/dist/{boat-CowHieO2.js → boat-Ckt9v__d.js} +3 -3
  26. package/dist/{boat-CowHieO2.js.map → boat-Ckt9v__d.js.map} +1 -1
  27. package/dist/{boat-DkNUc1UO.cjs → boat-yNAZ2LLB.cjs} +2 -2
  28. package/dist/{boat-DkNUc1UO.cjs.map → boat-yNAZ2LLB.cjs.map} +1 -1
  29. package/dist/boat.cjs +1 -1
  30. package/dist/boat.js +1 -1
  31. package/dist/busy.cjs +1 -1
  32. package/dist/busy.js +1 -1
  33. package/dist/button.cjs +1 -1
  34. package/dist/button.js +1 -1
  35. package/dist/card.cjs +1 -1
  36. package/dist/card.js +1 -1
  37. package/dist/charts.cjs +1 -1
  38. package/dist/charts.js +1 -1
  39. package/dist/{checkbox-BvWcABPr.cjs → checkbox-BnAlpsJN.cjs} +2 -2
  40. package/dist/{checkbox-BvWcABPr.cjs.map → checkbox-BnAlpsJN.cjs.map} +1 -1
  41. package/dist/{checkbox-BY4Sn8F2.js → checkbox-D22yfGe3.js} +2 -2
  42. package/dist/{checkbox-BY4Sn8F2.js.map → checkbox-D22yfGe3.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-CYjmAxfs.js → code-preview-DPlQayFd.js} +2 -2
  50. package/dist/{code-preview-CYjmAxfs.js.map → code-preview-DPlQayFd.js.map} +1 -1
  51. package/dist/{code-preview-BIFIJigy.cjs → code-preview-jPnX60FF.cjs} +2 -2
  52. package/dist/{code-preview-BIFIJigy.cjs.map → code-preview-jPnX60FF.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-BdIqI7LC.js → date-range-GFm5NG33.js} +4 -4
  58. package/dist/{date-range-BdIqI7LC.js.map → date-range-GFm5NG33.js.map} +1 -1
  59. package/dist/{date-range-inline-Df8u6Ecy.cjs → date-range-inline-CgX2o0FP.cjs} +2 -2
  60. package/dist/{date-range-inline-Df8u6Ecy.cjs.map → date-range-inline-CgX2o0FP.cjs.map} +1 -1
  61. package/dist/{date-range-inline-Cnhs9atd.js → date-range-inline-DTQLESAZ.js} +3 -3
  62. package/dist/{date-range-inline-Cnhs9atd.js.map → date-range-inline-DTQLESAZ.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-B80Ummtv.cjs → date-range-ug3B9CFT.cjs} +2 -2
  66. package/dist/{date-range-B80Ummtv.cjs.map → date-range-ug3B9CFT.cjs.map} +1 -1
  67. package/dist/date-range.cjs +1 -1
  68. package/dist/date-range.js +1 -1
  69. package/dist/{delay-BWsVHQib.cjs → delay-CWtBL0VD.cjs} +2 -2
  70. package/dist/{delay-BWsVHQib.cjs.map → delay-CWtBL0VD.cjs.map} +1 -1
  71. package/dist/{delay-CCa9nN4A.js → delay-DEe1CmHc.js} +2 -2
  72. package/dist/{delay-CCa9nN4A.js.map → delay-DEe1CmHc.js.map} +1 -1
  73. package/dist/delay.cjs +1 -1
  74. package/dist/delay.js +1 -1
  75. package/dist/{details-Bee5ya0L.js → details-D-LXW23W.js} +2 -2
  76. package/dist/{details-Bee5ya0L.js.map → details-D-LXW23W.js.map} +1 -1
  77. package/dist/{details-oaVHXU7U.cjs → details-DVke77dU.cjs} +2 -2
  78. package/dist/{details-oaVHXU7U.cjs.map → details-DVke77dU.cjs.map} +1 -1
  79. package/dist/details.cjs +1 -1
  80. package/dist/details.js +1 -1
  81. package/dist/dialog.cjs +1 -1
  82. package/dist/{dialog.component-BriB-kFi.cjs → dialog.component-BM0D-hK9.cjs} +2 -2
  83. package/dist/{dialog.component-BriB-kFi.cjs.map → dialog.component-BM0D-hK9.cjs.map} +1 -1
  84. package/dist/{dialog.component-CMUoCC7O.js → dialog.component-a7FlKhGD.js} +3 -3
  85. package/dist/{dialog.component-CMUoCC7O.js.map → dialog.component-a7FlKhGD.js.map} +1 -1
  86. package/dist/dialog.js +1 -1
  87. package/dist/{divider-B7DBbYFI.js → divider-CzTpxOqt.js} +3 -3
  88. package/dist/{divider-B7DBbYFI.js.map → divider-CzTpxOqt.js.map} +1 -1
  89. package/dist/{divider-Dl4TToQZ.cjs → divider-D8KStUhN.cjs} +2 -2
  90. package/dist/{divider-Dl4TToQZ.cjs.map → divider-D8KStUhN.cjs.map} +1 -1
  91. package/dist/divider.cjs +1 -1
  92. package/dist/divider.js +1 -1
  93. package/dist/{dropdown-content-C2W7OttQ.cjs → dropdown-content-CngZN3vv.cjs} +2 -2
  94. package/dist/{dropdown-content-C2W7OttQ.cjs.map → dropdown-content-CngZN3vv.cjs.map} +1 -1
  95. package/dist/{dropdown-content-DzhOtilY.js → dropdown-content-DCn-g0-f.js} +3 -3
  96. package/dist/{dropdown-content-DzhOtilY.js.map → dropdown-content-DCn-g0-f.js.map} +1 -1
  97. package/dist/dropdown.cjs +1 -1
  98. package/dist/dropdown.js +1 -1
  99. package/dist/{email-recipients-Bh5VC0rc.cjs → email-recipients-BhntMZMf.cjs} +2 -2
  100. package/dist/{email-recipients-Bh5VC0rc.cjs.map → email-recipients-BhntMZMf.cjs.map} +1 -1
  101. package/dist/{email-recipients-BWqZKo3m.js → email-recipients-BzjAKNJ0.js} +6 -6
  102. package/dist/{email-recipients-BWqZKo3m.js.map → email-recipients-BzjAKNJ0.js.map} +1 -1
  103. package/dist/extra.cjs +1 -1
  104. package/dist/extra.js +1 -1
  105. package/dist/{flex-53G-PJx7.js → flex-5dR48zie.js} +2 -2
  106. package/dist/{flex-53G-PJx7.js.map → flex-5dR48zie.js.map} +1 -1
  107. package/dist/{flex-DFSIy0t4.cjs → flex-oHl2EfYB.cjs} +2 -2
  108. package/dist/{flex-DFSIy0t4.cjs.map → flex-oHl2EfYB.cjs.map} +1 -1
  109. package/dist/{form-Zq7g2JS8.cjs → form-BlPiAPt7.cjs} +2 -2
  110. package/dist/{form-Zq7g2JS8.cjs.map → form-BlPiAPt7.cjs.map} +1 -1
  111. package/dist/{form-BtRK9bnp.js → form-BxVM6JTn.js} +2 -2
  112. package/dist/{form-BtRK9bnp.js.map → form-BxVM6JTn.js.map} +1 -1
  113. package/dist/form.cjs +1 -1
  114. package/dist/form.js +1 -1
  115. package/dist/{formField.mixin-2jSL7WF_.js → formField.mixin-BCGA7Ea3.js} +2 -2
  116. package/dist/{formField.mixin-2jSL7WF_.js.map → formField.mixin-BCGA7Ea3.js.map} +1 -1
  117. package/dist/{formField.mixin-DkN2ufR_.cjs → formField.mixin-BfJMifU9.cjs} +2 -2
  118. package/dist/{formField.mixin-DkN2ufR_.cjs.map → formField.mixin-BfJMifU9.cjs.map} +1 -1
  119. package/dist/{icon-pU_cfmpD.cjs → icon-DHEXr3c-.cjs} +2 -2
  120. package/dist/{icon-pU_cfmpD.cjs.map → icon-DHEXr3c-.cjs.map} +1 -1
  121. package/dist/{icon-B5qeYrDu.js → icon-DYpLoegR.js} +2 -2
  122. package/dist/{icon-B5qeYrDu.js.map → icon-DYpLoegR.js.map} +1 -1
  123. package/dist/{icon-button-HSYaQBNF.js → icon-button-CmZBLHWC.js} +3 -3
  124. package/dist/{icon-button-HSYaQBNF.js.map → icon-button-CmZBLHWC.js.map} +1 -1
  125. package/dist/{icon-button-BpmGFjaR.cjs → icon-button-IbSX8C98.cjs} +2 -2
  126. package/dist/{icon-button-BpmGFjaR.cjs.map → icon-button-IbSX8C98.cjs.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 +56 -56
  131. package/dist/{input-8G9YY9qv.cjs → input-BByjYlgl.cjs} +2 -2
  132. package/dist/{input-8G9YY9qv.cjs.map → input-BByjYlgl.cjs.map} +1 -1
  133. package/dist/{input-BJMF5Fyk.js → input-D0cQ9DOY.js} +3 -3
  134. package/dist/{input-BJMF5Fyk.js.map → input-D0cQ9DOY.js.map} +1 -1
  135. package/dist/{input-chip-tbrw56ix.js → input-chip-B5ErXgCB.js} +2 -2
  136. package/dist/{input-chip-tbrw56ix.js.map → input-chip-B5ErXgCB.js.map} +1 -1
  137. package/dist/{input-chip-CocdqTzr.cjs → input-chip-DkWaTciP.cjs} +2 -2
  138. package/dist/{input-chip-CocdqTzr.cjs.map → input-chip-DkWaTciP.cjs.map} +1 -1
  139. package/dist/input.cjs +1 -1
  140. package/dist/input.js +1 -1
  141. package/dist/{json-DPnyOA3K.cjs → json-BZVe74np.cjs} +2 -2
  142. package/dist/{json-DPnyOA3K.cjs.map → json-BZVe74np.cjs.map} +1 -1
  143. package/dist/{json-CvcloKQv.js → json-PKewOWuJ.js} +3 -3
  144. package/dist/{json-CvcloKQv.js.map → json-PKewOWuJ.js.map} +1 -1
  145. package/dist/json.cjs +1 -1
  146. package/dist/json.js +1 -1
  147. package/dist/layout.cjs +1 -1
  148. package/dist/layout.js +2 -2
  149. package/dist/{lightbox-service-3mHqBKEh.cjs → lightbox-service-D-0JtxB1.cjs} +2 -2
  150. package/dist/lightbox-service-D-0JtxB1.cjs.map +1 -0
  151. package/dist/{lightbox-service-DxbYZAuv.js → lightbox-service-DZMnb1eU.js} +3 -3
  152. package/dist/lightbox-service-DZMnb1eU.js.map +1 -0
  153. package/dist/lightbox.cjs +1 -1
  154. package/dist/lightbox.js +1 -1
  155. package/dist/{list-JjR7WOrd.cjs → list-B_2m7l3g.cjs} +6 -6
  156. package/dist/list-B_2m7l3g.cjs.map +1 -0
  157. package/dist/{list-FWXmY-eQ.js → list-CW56LV-v.js} +13 -13
  158. package/dist/list-CW56LV-v.js.map +1 -0
  159. package/dist/list.cjs +1 -1
  160. package/dist/list.js +1 -1
  161. package/dist/{litElement.mixin-BVBdv0GP.cjs → litElement.mixin-CrpeGpZ7.cjs} +2 -2
  162. package/dist/{litElement.mixin-BVBdv0GP.cjs.map → litElement.mixin-CrpeGpZ7.cjs.map} +1 -1
  163. package/dist/{litElement.mixin-Wcu4yIIs.js → litElement.mixin-DHZXtvYq.js} +2 -2
  164. package/dist/{litElement.mixin-Wcu4yIIs.js.map → litElement.mixin-DHZXtvYq.js.map} +1 -1
  165. package/dist/mailbox.cjs +1 -1
  166. package/dist/mailbox.js +1 -1
  167. package/dist/{map-Br6xJFxG.js → map-2Hl60a0A.js} +6 -6
  168. package/dist/{map-Br6xJFxG.js.map → map-2Hl60a0A.js.map} +1 -1
  169. package/dist/{map-D9R3OCne.cjs → map-DyPS9G7M.cjs} +3 -3
  170. package/dist/{map-D9R3OCne.cjs.map → map-DyPS9G7M.cjs.map} +1 -1
  171. package/dist/map.cjs +1 -1
  172. package/dist/map.js +1 -1
  173. package/dist/{media-DibPwAjJ.cjs → media-CS8HpKnK.cjs} +2 -2
  174. package/dist/{media-DibPwAjJ.cjs.map → media-CS8HpKnK.cjs.map} +1 -1
  175. package/dist/{media-BV_1DfcW.js → media-DtWbcRxL.js} +2 -2
  176. package/dist/{media-BV_1DfcW.js.map → media-DtWbcRxL.js.map} +1 -1
  177. package/dist/{menu-HKqlq99V.js → menu-Caju5-zd.js} +3 -3
  178. package/dist/{menu-HKqlq99V.js.map → menu-Caju5-zd.js.map} +1 -1
  179. package/dist/{menu-vNrV-Nuq.cjs → menu-rX5RPAI2.cjs} +2 -2
  180. package/dist/{menu-vNrV-Nuq.cjs.map → menu-rX5RPAI2.cjs.map} +1 -1
  181. package/dist/menu.cjs +1 -1
  182. package/dist/menu.js +1 -1
  183. package/dist/mixins.cjs +1 -1
  184. package/dist/mixins.js +3 -3
  185. package/dist/nav-drawer.cjs +1 -1
  186. package/dist/nav-drawer.js +1 -1
  187. package/dist/navigation-bar.cjs +1 -1
  188. package/dist/navigation-bar.js +1 -1
  189. package/dist/{navigation-rail-DKXumnmt.js → navigation-rail-Ctketq5a.js} +32 -25
  190. package/dist/navigation-rail-Ctketq5a.js.map +1 -0
  191. package/dist/{navigation-rail-D1o3qDe_.cjs → navigation-rail-DC9_oSIM.cjs} +12 -12
  192. package/dist/navigation-rail-DC9_oSIM.cjs.map +1 -0
  193. package/dist/navigation-rail.cjs +1 -1
  194. package/dist/navigation-rail.js +1 -1
  195. package/dist/{notification-service-B5ljba4P.js → notification-service-CUlfXqmj.js} +3 -3
  196. package/dist/{notification-service-B5ljba4P.js.map → notification-service-CUlfXqmj.js.map} +1 -1
  197. package/dist/{notification-service-ICRT05L0.cjs → notification-service-DknbpqTt.cjs} +2 -2
  198. package/dist/{notification-service-ICRT05L0.cjs.map → notification-service-DknbpqTt.cjs.map} +1 -1
  199. package/dist/notification.cjs +1 -1
  200. package/dist/notification.js +2 -2
  201. package/dist/{notify-B9CpO1Ru.js → notify-DJSOWTxv.js} +2 -2
  202. package/dist/{notify-B9CpO1Ru.js.map → notify-DJSOWTxv.js.map} +1 -1
  203. package/dist/{notify-NX-dl60E.cjs → notify-DickIEHW.cjs} +2 -2
  204. package/dist/{notify-NX-dl60E.cjs.map → notify-DickIEHW.cjs.map} +1 -1
  205. package/dist/{option-B4JKMrLg.js → option-Bng41-rY.js} +2 -2
  206. package/dist/{option-B4JKMrLg.js.map → option-Bng41-rY.js.map} +1 -1
  207. package/dist/{option-epyXLWoY.cjs → option-DYT5Rkgy.cjs} +2 -2
  208. package/dist/{option-epyXLWoY.cjs.map → option-DYT5Rkgy.cjs.map} +1 -1
  209. package/dist/option.cjs +1 -1
  210. package/dist/option.js +1 -1
  211. package/dist/{page-Bmi1QHtq.cjs → page-BLn9gtSd.cjs} +2 -2
  212. package/dist/{page-Bmi1QHtq.cjs.map → page-BLn9gtSd.cjs.map} +1 -1
  213. package/dist/{page-BpygEntU.js → page-D-ROcQDd.js} +4 -4
  214. package/dist/{page-BpygEntU.js.map → page-D-ROcQDd.js.map} +1 -1
  215. package/dist/page.cjs +1 -1
  216. package/dist/page.js +1 -1
  217. package/dist/{payment-card-form-3kAXDbXf.cjs → payment-card-form-5UtfWzoW.cjs} +2 -2
  218. package/dist/{payment-card-form-3kAXDbXf.cjs.map → payment-card-form-5UtfWzoW.cjs.map} +1 -1
  219. package/dist/{payment-card-form-BxkHuSls.js → payment-card-form-BJa4RgF2.js} +3 -3
  220. package/dist/{payment-card-form-BxkHuSls.js.map → payment-card-form-BJa4RgF2.js.map} +1 -1
  221. package/dist/{pills-C3fIvfn8.js → pills-BS5rZ6C3.js} +3 -3
  222. package/dist/{pills-C3fIvfn8.js.map → pills-BS5rZ6C3.js.map} +1 -1
  223. package/dist/{pills-MmHyBGQu.cjs → pills-Blf7IAeq.cjs} +2 -2
  224. package/dist/{pills-MmHyBGQu.cjs.map → pills-Blf7IAeq.cjs.map} +1 -1
  225. package/dist/{progress-qx8jtrOA.cjs → progress-DlhYniW_.cjs} +5 -5
  226. package/dist/progress-DlhYniW_.cjs.map +1 -0
  227. package/dist/{progress-0POmJs5o.js → progress-yTIX6EqC.js} +10 -13
  228. package/dist/progress-yTIX6EqC.js.map +1 -0
  229. package/dist/progress.cjs +1 -1
  230. package/dist/progress.js +1 -1
  231. package/dist/{qr-scanner-DQq-WLyo.cjs → qr-scanner-DOs7uNS_.cjs} +2 -2
  232. package/dist/{qr-scanner-DQq-WLyo.cjs.map → qr-scanner-DOs7uNS_.cjs.map} +1 -1
  233. package/dist/{qr-scanner-jwOSrD0N.js → qr-scanner-DjZ8mgHV.js} +2 -2
  234. package/dist/{qr-scanner-jwOSrD0N.js.map → qr-scanner-DjZ8mgHV.js.map} +1 -1
  235. package/dist/qr-scanner.cjs +1 -1
  236. package/dist/qr-scanner.js +1 -1
  237. package/dist/{radio-button-DraEYR2R.cjs → radio-button-N_PrrxKB.cjs} +2 -2
  238. package/dist/{radio-button-DraEYR2R.cjs.map → radio-button-N_PrrxKB.cjs.map} +1 -1
  239. package/dist/{radio-button-B0EUK_wg.js → radio-button-me3SRHGu.js} +3 -3
  240. package/dist/{radio-button-B0EUK_wg.js.map → radio-button-me3SRHGu.js.map} +1 -1
  241. package/dist/radio-group.cjs +1 -1
  242. package/dist/radio-group.js +1 -1
  243. package/dist/{schmancy-steps-container-C2StAA5K.js → schmancy-steps-container-J6P-NNNj.js} +2 -2
  244. package/dist/{schmancy-steps-container-C2StAA5K.js.map → schmancy-steps-container-J6P-NNNj.js.map} +1 -1
  245. package/dist/{schmancy-steps-container-B5aiqgMA.cjs → schmancy-steps-container-T57BKMzi.cjs} +2 -2
  246. package/dist/{schmancy-steps-container-B5aiqgMA.cjs.map → schmancy-steps-container-T57BKMzi.cjs.map} +1 -1
  247. package/dist/{scroll-Bu-vAg3d.js → scroll-C_gfUgjn.js} +2 -2
  248. package/dist/{scroll-Bu-vAg3d.js.map → scroll-C_gfUgjn.js.map} +1 -1
  249. package/dist/{scroll-BqT7bvhu.cjs → scroll-CecsowP7.cjs} +2 -2
  250. package/dist/{scroll-BqT7bvhu.cjs.map → scroll-CecsowP7.cjs.map} +1 -1
  251. package/dist/{select-i-uKur-W.js → select-BBA0gBHf.js} +3 -3
  252. package/dist/{select-i-uKur-W.js.map → select-BBA0gBHf.js.map} +1 -1
  253. package/dist/{select-HiEGJvOX.cjs → select-D9oCjv7N.cjs} +2 -2
  254. package/dist/{select-HiEGJvOX.cjs.map → select-D9oCjv7N.cjs.map} +1 -1
  255. package/dist/select.cjs +1 -1
  256. package/dist/select.js +1 -1
  257. package/dist/{sheet-BbrRW0S5.cjs → sheet-0oUfBmXX.cjs} +2 -2
  258. package/dist/{sheet-BbrRW0S5.cjs.map → sheet-0oUfBmXX.cjs.map} +1 -1
  259. package/dist/{sheet-B1g7E4dQ.js → sheet-CNcDT3VP.js} +5 -5
  260. package/dist/{sheet-B1g7E4dQ.js.map → sheet-CNcDT3VP.js.map} +1 -1
  261. package/dist/sheet.cjs +1 -1
  262. package/dist/sheet.js +2 -2
  263. package/dist/{sheet.service-4etIM-p6.js → sheet.service-2MobB-9z.js} +2 -2
  264. package/dist/{sheet.service-4etIM-p6.js.map → sheet.service-2MobB-9z.js.map} +1 -1
  265. package/dist/{sheet.service-BiRZjCdN.cjs → sheet.service-su_7yDQ-.cjs} +2 -2
  266. package/dist/{sheet.service-BiRZjCdN.cjs.map → sheet.service-su_7yDQ-.cjs.map} +1 -1
  267. package/dist/{slider-VYnbIRH2.cjs → slider-CV-Ehp_5.cjs} +2 -2
  268. package/dist/{slider-VYnbIRH2.cjs.map → slider-CV-Ehp_5.cjs.map} +1 -1
  269. package/dist/{slider-8E3Wad0t.js → slider-CkE-iFUy.js} +3 -3
  270. package/dist/{slider-8E3Wad0t.js.map → slider-CkE-iFUy.js.map} +1 -1
  271. package/dist/slider.cjs +1 -1
  272. package/dist/slider.js +1 -1
  273. package/dist/{spinner-DJgcI5wr.cjs → spinner-Bfn8KC-9.cjs} +2 -2
  274. package/dist/{spinner-DJgcI5wr.cjs.map → spinner-Bfn8KC-9.cjs.map} +1 -1
  275. package/dist/{spinner-CKm13CKN.js → spinner-DiMbWXp9.js} +2 -2
  276. package/dist/{spinner-CKm13CKN.js.map → spinner-DiMbWXp9.js.map} +1 -1
  277. package/dist/steps.cjs +1 -1
  278. package/dist/steps.js +1 -1
  279. package/dist/{suggestion-chip-6njXvvHm.js → suggestion-chip-CEDqUNoS.js} +3 -3
  280. package/dist/{suggestion-chip-6njXvvHm.js.map → suggestion-chip-CEDqUNoS.js.map} +1 -1
  281. package/dist/{suggestion-chip-DdLfqk7o.cjs → suggestion-chip-HhsLtZXR.cjs} +2 -2
  282. package/dist/{suggestion-chip-DdLfqk7o.cjs.map → suggestion-chip-HhsLtZXR.cjs.map} +1 -1
  283. package/dist/{surface-DcqbWGub.cjs → surface-CW3H23Va.cjs} +2 -2
  284. package/dist/{surface-DcqbWGub.cjs.map → surface-CW3H23Va.cjs.map} +1 -1
  285. package/dist/{surface-BYU3l_Q2.js → surface-eBfnSwQS.js} +2 -2
  286. package/dist/{surface-BYU3l_Q2.js.map → surface-eBfnSwQS.js.map} +1 -1
  287. package/dist/surface.cjs +1 -1
  288. package/dist/surface.js +1 -1
  289. package/dist/{table-C9fzDjjk.cjs → table-D0tiSL_u.cjs} +2 -2
  290. package/dist/{table-C9fzDjjk.cjs.map → table-D0tiSL_u.cjs.map} +1 -1
  291. package/dist/{table-Dq12ollZ.js → table-Dmo4TvTx.js} +2 -2
  292. package/dist/{table-Dq12ollZ.js.map → table-Dmo4TvTx.js.map} +1 -1
  293. package/dist/table.cjs +1 -1
  294. package/dist/table.js +1 -1
  295. package/dist/{tabs-compatibility-wnzlHtln.js → tabs-compatibility-Bit6y6en.js} +2 -2
  296. package/dist/{tabs-compatibility-wnzlHtln.js.map → tabs-compatibility-Bit6y6en.js.map} +1 -1
  297. package/dist/{tabs-compatibility-Dwtjfkcf.cjs → tabs-compatibility-Vq_2-ekz.cjs} +2 -2
  298. package/dist/{tabs-compatibility-Dwtjfkcf.cjs.map → tabs-compatibility-Vq_2-ekz.cjs.map} +1 -1
  299. package/dist/tabs.cjs +1 -1
  300. package/dist/tabs.js +1 -1
  301. package/dist/{tailwind.mixin-Ddt05Frc.js → tailwind.mixin-Bp_PR6yc.js} +2 -2
  302. package/dist/{tailwind.mixin-Ddt05Frc.js.map → tailwind.mixin-Bp_PR6yc.js.map} +1 -1
  303. package/dist/{tailwind.mixin-UijsBrYW.cjs → tailwind.mixin-Cp4PyXok.cjs} +2 -2
  304. package/dist/{tailwind.mixin-UijsBrYW.cjs.map → tailwind.mixin-Cp4PyXok.cjs.map} +1 -1
  305. package/dist/teleport.cjs +1 -1
  306. package/dist/teleport.js +1 -1
  307. package/dist/{textarea-Vd3zayJZ.js → textarea-B1d1QCqT.js} +2 -2
  308. package/dist/{textarea-Vd3zayJZ.js.map → textarea-B1d1QCqT.js.map} +1 -1
  309. package/dist/{textarea-DGmsw1B_.cjs → textarea-DG8CHhZA.cjs} +2 -2
  310. package/dist/{textarea-DGmsw1B_.cjs.map → textarea-DG8CHhZA.cjs.map} +1 -1
  311. package/dist/textarea.cjs +1 -1
  312. package/dist/textarea.js +1 -1
  313. package/dist/{theme-button-DG_Xwg9H.cjs → theme-button-CPL6Eaqd.cjs} +2 -2
  314. package/dist/{theme-button-DG_Xwg9H.cjs.map → theme-button-CPL6Eaqd.cjs.map} +1 -1
  315. package/dist/{theme-button-rGpEW_xS.js → theme-button-CrLuMQNe.js} +2 -2
  316. package/dist/{theme-button-rGpEW_xS.js.map → theme-button-CrLuMQNe.js.map} +1 -1
  317. package/dist/theme-button.cjs +1 -1
  318. package/dist/theme-button.js +1 -1
  319. package/dist/{theme-controller-boat-pLzK5zxL.cjs → theme-controller-boat-CXbNJSI3.cjs} +2 -2
  320. package/dist/{theme-controller-boat-pLzK5zxL.cjs.map → theme-controller-boat-CXbNJSI3.cjs.map} +1 -1
  321. package/dist/{theme-controller-boat-B1fjcqJI.js → theme-controller-boat-CzSmjyKq.js} +3 -3
  322. package/dist/{theme-controller-boat-B1fjcqJI.js.map → theme-controller-boat-CzSmjyKq.js.map} +1 -1
  323. package/dist/theme.cjs +1 -1
  324. package/dist/theme.js +1 -1
  325. package/dist/{timezone-IQkwr6Oh.js → timezone-4vwX0BgA.js} +3 -3
  326. package/dist/{timezone-IQkwr6Oh.js.map → timezone-4vwX0BgA.js.map} +1 -1
  327. package/dist/{timezone-BhUaIAV7.cjs → timezone-BxvQcqe1.cjs} +2 -2
  328. package/dist/{timezone-BhUaIAV7.cjs.map → timezone-BxvQcqe1.cjs.map} +1 -1
  329. package/dist/{tooltip-CwaiZC8f.js → tooltip-CjdvBf4X.js} +2 -2
  330. package/dist/{tooltip-CwaiZC8f.js.map → tooltip-CjdvBf4X.js.map} +1 -1
  331. package/dist/{tooltip-iEvxKg8g.cjs → tooltip-ZtnGjoJd.cjs} +2 -2
  332. package/dist/{tooltip-iEvxKg8g.cjs.map → tooltip-ZtnGjoJd.cjs.map} +1 -1
  333. package/dist/tooltip.cjs +1 -1
  334. package/dist/tooltip.js +1 -1
  335. package/dist/{tree-D9EbEsxn.js → tree-CBEjV7jP.js} +2 -2
  336. package/dist/{tree-D9EbEsxn.js.map → tree-CBEjV7jP.js.map} +1 -1
  337. package/dist/{tree-Bclu6uvv.cjs → tree-DP5U00NA.cjs} +2 -2
  338. package/dist/{tree-Bclu6uvv.cjs.map → tree-DP5U00NA.cjs.map} +1 -1
  339. package/dist/tree.cjs +1 -1
  340. package/dist/tree.js +1 -1
  341. package/dist/{typewriter-Bscwd-36.cjs → typewriter-C6kFjLcX.cjs} +2 -2
  342. package/dist/{typewriter-Bscwd-36.cjs.map → typewriter-C6kFjLcX.cjs.map} +1 -1
  343. package/dist/{typewriter-BjDPgRlj.js → typewriter-Eo5qXoGC.js} +4 -4
  344. package/dist/{typewriter-BjDPgRlj.js.map → typewriter-Eo5qXoGC.js.map} +1 -1
  345. package/dist/typewriter.cjs +1 -1
  346. package/dist/typewriter.js +1 -1
  347. package/dist/{typography-CConBBFH.js → typography-C_1gdM2I.js} +2 -2
  348. package/dist/{typography-CConBBFH.js.map → typography-C_1gdM2I.js.map} +1 -1
  349. package/dist/{typography-DLGT3DGz.cjs → typography-DGyjlLCE.cjs} +2 -2
  350. package/dist/{typography-DLGT3DGz.cjs.map → typography-DGyjlLCE.cjs.map} +1 -1
  351. package/dist/typography.cjs +1 -1
  352. package/dist/typography.js +1 -1
  353. package/package.json +1 -1
  354. package/types/src/navigation-rail/navigation-rail.d.ts +2 -0
  355. package/types/src/progress/progress.d.ts +1 -1
  356. package/dist/avatar-BdyuuIk7.js.map +0 -1
  357. package/dist/avatar-DBfJucB9.cjs.map +0 -1
  358. package/dist/lightbox-service-3mHqBKEh.cjs.map +0 -1
  359. package/dist/lightbox-service-DxbYZAuv.js.map +0 -1
  360. package/dist/list-FWXmY-eQ.js.map +0 -1
  361. package/dist/list-JjR7WOrd.cjs.map +0 -1
  362. package/dist/navigation-rail-D1o3qDe_.cjs.map +0 -1
  363. package/dist/navigation-rail-DKXumnmt.js.map +0 -1
  364. package/dist/progress-0POmJs5o.js.map +0 -1
  365. package/dist/progress-qx8jtrOA.cjs.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"pills-C3fIvfn8.js","sources":["../src/charts/utils.ts","../src/charts/area-chart.ts","../src/charts/pills.ts"],"sourcesContent":["/**\n * Catmull-Rom spline interpolation for smooth curves\n * Returns the interpolated point between p1 and p2\n */\nexport function catmullRomSpline(\n\tp0: { x: number; y: number },\n\tp1: { x: number; y: number },\n\tp2: { x: number; y: number },\n\tp3: { x: number; y: number },\n\tt: number\n): { x: number; y: number } {\n\tconst t2 = t * t\n\tconst t3 = t2 * t\n\n\tconst x =\n\t\t0.5 *\n\t\t(2 * p1.x +\n\t\t\t(-p0.x + p2.x) * t +\n\t\t\t(2 * p0.x - 5 * p1.x + 4 * p2.x - p3.x) * t2 +\n\t\t\t(-p0.x + 3 * p1.x - 3 * p2.x + p3.x) * t3)\n\n\tconst y =\n\t\t0.5 *\n\t\t(2 * p1.y +\n\t\t\t(-p0.y + p2.y) * t +\n\t\t\t(2 * p0.y - 5 * p1.y + 4 * p2.y - p3.y) * t2 +\n\t\t\t(-p0.y + 3 * p1.y - 3 * p2.y + p3.y) * t3)\n\n\treturn { x, y }\n}\n\n/**\n * Converts hex or rgb color to rgba string\n */\nexport function hexToRgba(color: string, alpha: number): string {\n\t// Handle rgb/rgba format\n\tif (color.startsWith('rgb')) {\n\t\tconst match = color.match(/[\\d.]+/g)\n\t\tif (match && match.length >= 3) {\n\t\t\treturn `rgba(${match[0]}, ${match[1]}, ${match[2]}, ${alpha})`\n\t\t}\n\t}\n\n\t// Handle hex format\n\tlet hex = color.replace('#', '')\n\tif (hex.length === 3) {\n\t\thex = hex\n\t\t\t.split('')\n\t\t\t.map(c => c + c)\n\t\t\t.join('')\n\t}\n\n\tconst r = parseInt(hex.substring(0, 2), 16)\n\tconst g = parseInt(hex.substring(2, 4), 16)\n\tconst b = parseInt(hex.substring(4, 6), 16)\n\n\treturn `rgba(${r}, ${g}, ${b}, ${alpha})`\n}\n\n/**\n * Cubic ease-out animation function\n */\nexport function easeOutCubic(t: number): number {\n\treturn 1 - Math.pow(1 - t, 3)\n}\n","import { html, css, PropertyValues } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { ref, createRef, Ref } from 'lit/directives/ref.js'\nimport { $LitElement } from '@mixins/index'\nimport type { ChartDataPoint, ChartTheme, ProcessedDataPoint } from './types'\nimport { catmullRomSpline, hexToRgba, easeOutCubic } from './utils'\n\ninterface TooltipData {\n\tvisible: boolean\n\tx: number\n\ty: number\n\tlabel: string\n\tvalue: number\n\tmetadata?: Record<string, unknown>\n}\n\n@customElement('schmancy-area-chart')\nexport class SchmancyAreaChart extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n`) {\n\t/** Chart data points */\n\t@property({ type: Array })\n\tdata: ChartDataPoint[] = []\n\n\t/** Chart height in pixels */\n\t@property({ type: Number })\n\theight = 200\n\n\t/** Show grid lines */\n\t@property({ type: Boolean })\n\tshowGrid = true\n\n\t/** Show x-axis labels */\n\t@property({ type: Boolean })\n\tshowLabels = true\n\n\t/** Enable tooltips */\n\t@property({ type: Boolean })\n\tshowTooltip = true\n\n\t/** Number of peaks to highlight */\n\t@property({ type: Number })\n\tpeakCount = 3\n\n\t/** Animation duration in milliseconds */\n\t@property({ type: Number })\n\tanimationDuration = 800\n\n\t/** Enable entrance animation */\n\t@property({ type: Boolean })\n\tanimated = true\n\n\t/** Prefix for values (e.g., \"EUR \") */\n\t@property({ type: String })\n\tvaluePrefix = ''\n\n\t/** Suffix for values (e.g., \"%\") */\n\t@property({ type: String })\n\tvalueSuffix = ''\n\n\t/** Decimal places for value display */\n\t@property({ type: Number })\n\tvalueDecimals = 2\n\n\t/** Theme overrides */\n\t@property({ type: Object })\n\ttheme: Partial<ChartTheme> = {}\n\n\t@state() private tooltipData: TooltipData = {\n\t\tvisible: false,\n\t\tx: 0,\n\t\ty: 0,\n\t\tlabel: '',\n\t\tvalue: 0,\n\t}\n\n\t@state() private animationProgress = 0\n\t@state() private isVisible = false\n\n\tprivate canvasRef: Ref<HTMLCanvasElement> = createRef()\n\tprivate containerRef: Ref<HTMLDivElement> = createRef()\n\tprivate animationFrameId: number | null = null\n\tprivate observer: IntersectionObserver | null = null\n\tprivate processedData: ProcessedDataPoint[] = []\n\tprivate resizeObserver: ResizeObserver | null = null\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\t\tthis.setupIntersectionObserver()\n\t}\n\n\tdisconnectedCallback() {\n\t\tsuper.disconnectedCallback()\n\t\tthis.cleanup()\n\t}\n\n\tprivate cleanup() {\n\t\tif (this.animationFrameId !== null) {\n\t\t\tcancelAnimationFrame(this.animationFrameId)\n\t\t\tthis.animationFrameId = null\n\t\t}\n\t\tif (this.observer) {\n\t\t\tthis.observer.disconnect()\n\t\t\tthis.observer = null\n\t\t}\n\t\tif (this.resizeObserver) {\n\t\t\tthis.resizeObserver.disconnect()\n\t\t\tthis.resizeObserver = null\n\t\t}\n\t}\n\n\tprivate setupIntersectionObserver() {\n\t\tthis.observer = new IntersectionObserver(\n\t\t\tentries => {\n\t\t\t\tconst entry = entries[0]\n\t\t\t\tif (entry.isIntersecting && !this.isVisible) {\n\t\t\t\t\tthis.isVisible = true\n\t\t\t\t\tif (this.animated) {\n\t\t\t\t\t\tthis.startAnimation()\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.animationProgress = 1\n\t\t\t\t\t\tthis.drawChart()\n\t\t\t\t\t}\n\t\t\t\t} else if (!entry.isIntersecting) {\n\t\t\t\t\tthis.isVisible = false\n\t\t\t\t\tif (this.animationFrameId !== null) {\n\t\t\t\t\t\tcancelAnimationFrame(this.animationFrameId)\n\t\t\t\t\t\tthis.animationFrameId = null\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t\t{ threshold: 0.1 }\n\t\t)\n\t}\n\n\tprotected updated(changedProperties: PropertyValues) {\n\t\tsuper.updated(changedProperties)\n\n\t\tif (this.containerRef.value && this.observer) {\n\t\t\tthis.observer.observe(this.containerRef.value)\n\t\t}\n\n\t\tif (this.canvasRef.value && !this.resizeObserver) {\n\t\t\tthis.resizeObserver = new ResizeObserver(() => {\n\t\t\t\tthis.drawChart()\n\t\t\t})\n\t\t\tthis.resizeObserver.observe(this.canvasRef.value)\n\t\t}\n\n\t\t// Redraw when data changes\n\t\tif (changedProperties.has('data') && this.isVisible) {\n\t\t\tif (this.animated) {\n\t\t\t\tthis.animationProgress = 0\n\t\t\t\tthis.startAnimation()\n\t\t\t} else {\n\t\t\t\tthis.animationProgress = 1\n\t\t\t\tthis.drawChart()\n\t\t\t}\n\t\t}\n\n\t\t// Redraw on theme or config changes\n\t\tif (\n\t\t\t(changedProperties.has('theme') ||\n\t\t\t\tchangedProperties.has('showGrid') ||\n\t\t\t\tchangedProperties.has('showLabels') ||\n\t\t\t\tchangedProperties.has('peakCount')) &&\n\t\t\tthis.isVisible\n\t\t) {\n\t\t\tthis.drawChart()\n\t\t}\n\t}\n\n\tprivate startAnimation() {\n\t\tconst startTime = performance.now()\n\t\tconst duration = this.animationDuration\n\n\t\tconst animateFrame = (currentTime: number) => {\n\t\t\tconst elapsed = currentTime - startTime\n\t\t\tconst progress = Math.min(elapsed / duration, 1)\n\n\t\t\tthis.animationProgress = easeOutCubic(progress)\n\t\t\tthis.drawChart()\n\n\t\t\tif (progress < 1 && this.isVisible) {\n\t\t\t\tthis.animationFrameId = requestAnimationFrame(animateFrame)\n\t\t\t}\n\t\t}\n\n\t\tthis.animationFrameId = requestAnimationFrame(animateFrame)\n\t}\n\n\tprivate processData(): ProcessedDataPoint[] {\n\t\tif (!this.data || this.data.length === 0) return []\n\n\t\t// Find top N peak values\n\t\tconst sortedByValue = [...this.data].sort((a, b) => b.value - a.value)\n\t\tconst peakLabels = new Set(sortedByValue.slice(0, this.peakCount).map(d => d.label))\n\n\t\treturn this.data.map(d => ({\n\t\t\t...d,\n\t\t\tx: 0, // Will be calculated during draw\n\t\t\ty: 0, // Will be calculated during draw\n\t\t\tisPeak: peakLabels.has(d.label),\n\t\t}))\n\t}\n\n\tprivate getThemeValue<K extends keyof ChartTheme>(\n\t\tkey: K,\n\t\tdefaultValue: NonNullable<ChartTheme[K]>\n\t): NonNullable<ChartTheme[K]> {\n\t\treturn (this.theme[key] as NonNullable<ChartTheme[K]>) ?? defaultValue\n\t}\n\n\tprivate drawChart() {\n\t\tconst canvas = this.canvasRef.value\n\t\tif (!canvas) return\n\n\t\tconst ctx = canvas.getContext('2d')\n\t\tif (!ctx) return\n\n\t\tconst dpr = window.devicePixelRatio || 1\n\t\tconst rect = canvas.getBoundingClientRect()\n\t\tconst width = rect.width\n\t\tconst height = rect.height\n\n\t\t// Set canvas size for high DPI\n\t\tcanvas.width = width * dpr\n\t\tcanvas.height = height * dpr\n\t\tctx.scale(dpr, dpr)\n\n\t\t// Clear canvas\n\t\tctx.clearRect(0, 0, width, height)\n\n\t\tconst data = this.processData()\n\t\tif (data.length === 0) return\n\n\t\tconst padding = { top: 20, right: 20, bottom: this.showLabels ? 40 : 20, left: 20 }\n\t\tconst chartWidth = width - padding.left - padding.right\n\t\tconst chartHeight = height - padding.top - padding.bottom\n\n\t\t// Find max value for scaling\n\t\tconst maxValue = Math.max(...data.map(d => d.value), 1)\n\n\t\t// Calculate positions\n\t\tconst points = data.map((d, i) => ({\n\t\t\t...d,\n\t\t\tx: padding.left + (data.length > 1 ? (i / (data.length - 1)) * chartWidth : chartWidth / 2),\n\t\t\ty: padding.top + chartHeight - (d.value / maxValue) * chartHeight,\n\t\t}))\n\n\t\tthis.processedData = points\n\n\t\t// Get primary color from CSS or theme\n\t\tconst computedStyle = getComputedStyle(this)\n\t\tconst defaultPrimaryColor =\n\t\t\tcomputedStyle.getPropertyValue('--schmancy-sys-color-primary').trim() || '#6750A4'\n\t\tconst primaryColor = this.getThemeValue('primaryColor', defaultPrimaryColor)\n\t\tconst [gradientOpacityTop, gradientOpacityBottom] = this.getThemeValue('gradientOpacity', [0.4, 0.05])\n\t\tconst strokeWidth = this.getThemeValue('strokeWidth', 2)\n\t\tconst pointRadius = this.getThemeValue('pointRadius', 4)\n\t\tconst peakRadius = this.getThemeValue('peakRadius', 6)\n\n\t\t// Draw grid lines\n\t\tif (this.showGrid) {\n\t\t\tctx.strokeStyle = 'rgba(128, 128, 128, 0.15)'\n\t\t\tctx.lineWidth = 1\n\t\t\tctx.setLineDash([4, 4])\n\n\t\t\tfor (let i = 1; i <= 3; i++) {\n\t\t\t\tconst y = padding.top + (chartHeight * i) / 4\n\t\t\t\tctx.beginPath()\n\t\t\t\tctx.moveTo(padding.left, y)\n\t\t\t\tctx.lineTo(width - padding.right, y)\n\t\t\t\tctx.stroke()\n\t\t\t}\n\n\t\t\tctx.setLineDash([])\n\t\t}\n\n\t\t// Create smooth curve path using Catmull-Rom spline\n\t\tconst curvePath = new Path2D()\n\t\tconst areaPath = new Path2D()\n\n\t\tif (points.length >= 2) {\n\t\t\t// Start area path from bottom left\n\t\t\tareaPath.moveTo(points[0].x, padding.top + chartHeight)\n\t\t\tcurvePath.moveTo(points[0].x, points[0].y)\n\t\t\tareaPath.lineTo(points[0].x, points[0].y)\n\n\t\t\tfor (let i = 0; i < points.length - 1; i++) {\n\t\t\t\tconst p0 = points[Math.max(0, i - 1)]\n\t\t\t\tconst p1 = points[i]\n\t\t\t\tconst p2 = points[Math.min(points.length - 1, i + 1)]\n\t\t\t\tconst p3 = points[Math.min(points.length - 1, i + 2)]\n\n\t\t\t\t// Draw curve segments\n\t\t\t\tconst segments = 16\n\t\t\t\tfor (let j = 1; j <= segments; j++) {\n\t\t\t\t\tconst t = j / segments\n\t\t\t\t\tconst point = catmullRomSpline(p0, p1, p2, p3, t)\n\t\t\t\t\tcurvePath.lineTo(point.x, point.y)\n\t\t\t\t\tareaPath.lineTo(point.x, point.y)\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Close area path\n\t\t\tareaPath.lineTo(points[points.length - 1].x, padding.top + chartHeight)\n\t\t\tareaPath.closePath()\n\t\t} else if (points.length === 1) {\n\t\t\t// Single point - draw a dot\n\t\t\tcurvePath.arc(points[0].x, points[0].y, pointRadius, 0, Math.PI * 2)\n\t\t}\n\n\t\t// Apply animation clipping\n\t\tctx.save()\n\t\tctx.beginPath()\n\t\tctx.rect(0, 0, padding.left + chartWidth * this.animationProgress, height)\n\t\tctx.clip()\n\n\t\t// Draw gradient fill\n\t\tif (points.length >= 2) {\n\t\t\tconst gradient = ctx.createLinearGradient(0, padding.top, 0, padding.top + chartHeight)\n\t\t\tgradient.addColorStop(0, hexToRgba(primaryColor, gradientOpacityTop))\n\t\t\tgradient.addColorStop(1, hexToRgba(primaryColor, gradientOpacityBottom))\n\n\t\t\tctx.fillStyle = gradient\n\t\t\tctx.fill(areaPath)\n\t\t}\n\n\t\t// Draw stroke\n\t\tctx.strokeStyle = primaryColor\n\t\tctx.lineWidth = strokeWidth\n\t\tctx.lineCap = 'round'\n\t\tctx.lineJoin = 'round'\n\t\tctx.stroke(curvePath)\n\n\t\t// Draw data points\n\t\tpoints.forEach((point, index) => {\n\t\t\tconst pointProgress = (index / (points.length - 1 || 1)) * this.animationProgress\n\t\t\tif (pointProgress < index / (points.length || 1)) return\n\n\t\t\tconst radius = point.isPeak ? peakRadius - 1 : pointRadius - 1\n\t\t\tconst outerRadius = point.isPeak ? peakRadius + 4 : pointRadius + 2\n\n\t\t\t// Outer glow for peaks\n\t\t\tif (point.isPeak) {\n\t\t\t\tctx.beginPath()\n\t\t\t\tctx.arc(point.x, point.y, outerRadius, 0, Math.PI * 2)\n\t\t\t\tctx.fillStyle = hexToRgba(primaryColor, 0.2)\n\t\t\t\tctx.fill()\n\t\t\t}\n\n\t\t\t// Inner dot\n\t\t\tctx.beginPath()\n\t\t\tctx.arc(point.x, point.y, radius, 0, Math.PI * 2)\n\t\t\tctx.fillStyle = primaryColor\n\t\t\tctx.fill()\n\n\t\t\t// White center for peaks\n\t\t\tif (point.isPeak) {\n\t\t\t\tctx.beginPath()\n\t\t\t\tctx.arc(point.x, point.y, 2, 0, Math.PI * 2)\n\t\t\t\tctx.fillStyle = 'white'\n\t\t\t\tctx.fill()\n\t\t\t}\n\t\t})\n\n\t\tctx.restore()\n\n\t\t// Draw labels\n\t\tif (this.showLabels && points.length > 0) {\n\t\t\tctx.fillStyle = 'rgba(128, 128, 128, 0.8)'\n\t\t\tctx.font = '11px system-ui, sans-serif'\n\t\t\tctx.textAlign = 'center'\n\t\t\tctx.textBaseline = 'top'\n\n\t\t\t// Show fewer labels on narrow charts\n\t\t\tconst labelStep = width < 400 ? 3 : width < 600 ? 2 : 1\n\t\t\tpoints.forEach((point, index) => {\n\t\t\t\tif (index % labelStep === 0) {\n\t\t\t\t\tctx.fillText(point.label, point.x, height - padding.bottom + 8)\n\t\t\t\t}\n\t\t\t})\n\t\t}\n\t}\n\n\tprivate formatValue(value: number): string {\n\t\tconst formatted = value.toFixed(this.valueDecimals)\n\t\treturn `${this.valuePrefix}${formatted}${this.valueSuffix}`\n\t}\n\n\tprivate handlePointerMove = (e: PointerEvent) => {\n\t\tif (this.processedData.length === 0 || !this.showTooltip) return\n\n\t\tconst canvas = this.canvasRef.value\n\t\tif (!canvas) return\n\n\t\tconst rect = canvas.getBoundingClientRect()\n\t\tconst x = e.clientX - rect.left\n\n\t\t// Find closest data point\n\t\tlet closestPoint: ProcessedDataPoint | null = null\n\t\tlet minDistance = Infinity\n\n\t\tthis.processedData.forEach(point => {\n\t\t\tconst distance = Math.abs(point.x - x)\n\t\t\tif (distance < minDistance) {\n\t\t\t\tminDistance = distance\n\t\t\t\tclosestPoint = point\n\t\t\t}\n\t\t})\n\n\t\tif (closestPoint && minDistance < 30) {\n\t\t\tthis.tooltipData = {\n\t\t\t\tvisible: true,\n\t\t\t\tx: closestPoint.x,\n\t\t\t\ty: closestPoint.y,\n\t\t\t\tlabel: closestPoint.label,\n\t\t\t\tvalue: closestPoint.value,\n\t\t\t\tmetadata: closestPoint.metadata,\n\t\t\t}\n\t\t} else {\n\t\t\tthis.tooltipData = { ...this.tooltipData, visible: false }\n\t\t}\n\t}\n\n\tprivate handlePointerLeave = () => {\n\t\tthis.tooltipData = { ...this.tooltipData, visible: false }\n\t}\n\n\tprivate renderMetadata() {\n\t\tif (!this.tooltipData.metadata) return ''\n\t\treturn Object.entries(this.tooltipData.metadata).map(\n\t\t\t([key, value]) => html`\n\t\t\t\t<schmancy-typography type=\"body\" token=\"sm\" class=\"text-surface-onVariant\">\n\t\t\t\t\t${key}: ${String(value)}\n\t\t\t\t</schmancy-typography>\n\t\t\t`\n\t\t)\n\t}\n\n\trender() {\n\t\tif (!this.data || this.data.length === 0) {\n\t\t\treturn html``\n\t\t}\n\n\t\treturn html`\n\t\t\t<div ${ref(this.containerRef)} class=\"relative\">\n\t\t\t\t<div class=\"relative\" style=\"height: ${this.height}px; touch-action: pan-y;\">\n\t\t\t\t\t<canvas\n\t\t\t\t\t\t${ref(this.canvasRef)}\n\t\t\t\t\t\tclass=\"w-full h-full\"\n\t\t\t\t\t\tstyle=\"display: block;\"\n\t\t\t\t\t\t@pointermove=${this.handlePointerMove}\n\t\t\t\t\t\t@pointerleave=${this.handlePointerLeave}\n\t\t\t\t\t></canvas>\n\n\t\t\t\t\t<!-- Tooltip -->\n\t\t\t\t\t${this.showTooltip\n\t\t\t\t\t\t? html`\n\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\tclass=\"absolute pointer-events-none transition-opacity duration-150 ${this.tooltipData.visible\n\t\t\t\t\t\t\t\t\t\t? 'opacity-100'\n\t\t\t\t\t\t\t\t\t\t: 'opacity-0'}\"\n\t\t\t\t\t\t\t\t\tstyle=\"\n left: ${this.tooltipData.x}px;\n top: ${this.tooltipData.y - 60}px;\n transform: translateX(-50%);\n \"\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t<schmancy-surface elevation=\"3\" rounded=\"all\" class=\"px-3 py-2 min-w-max\">\n\t\t\t\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"sm\" class=\"text-surface-onVariant\">\n\t\t\t\t\t\t\t\t\t\t\t${this.tooltipData.label}\n\t\t\t\t\t\t\t\t\t\t</schmancy-typography>\n\t\t\t\t\t\t\t\t\t\t<schmancy-typography type=\"title\" token=\"md\" class=\"text-surface-on font-semibold\">\n\t\t\t\t\t\t\t\t\t\t\t${this.formatValue(this.tooltipData.value)}\n\t\t\t\t\t\t\t\t\t\t</schmancy-typography>\n\t\t\t\t\t\t\t\t\t\t${this.renderMetadata()}\n\t\t\t\t\t\t\t\t\t</schmancy-surface>\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t `\n\t\t\t\t\t\t: ''}\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-area-chart': SchmancyAreaChart\n\t}\n}\n","import { html, css, PropertyValues } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { repeat } from 'lit/directives/repeat.js'\nimport { $LitElement } from '@mixins/index'\nimport type { PillDataPoint, PillSegment } from './types'\n\n/** Default color palette for segments - expanded for uniqueness */\nconst DEFAULT_COLORS = [\n\t'bg-primary',\n\t'bg-secondary',\n\t'bg-tertiary',\n\t'bg-success',\n\t'bg-warning',\n\t'bg-error',\n\t'bg-primary/70',\n\t'bg-secondary/70',\n\t'bg-tertiary/70',\n\t'bg-success/70',\n\t'bg-warning/70',\n\t'bg-error/70',\n\t'bg-primary/40',\n\t'bg-secondary/40',\n\t'bg-tertiary/40',\n]\n\n@customElement('schmancy-pills')\nexport class SchmancyPills extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n`) {\n\t/** Chart data points */\n\t@property({ type: Array })\n\tdata: PillDataPoint[] = []\n\n\t/** Prefix for values (e.g., \"EUR \") */\n\t@property({ type: String })\n\tvaluePrefix = ''\n\n\t/** Suffix for values (e.g., \"%\") */\n\t@property({ type: String })\n\tvalueSuffix = ''\n\n\t/** Decimal places for value display */\n\t@property({ type: Number })\n\tvalueDecimals = 2\n\n\t/** Show medals for top 3 */\n\t@property({ type: Boolean })\n\tshowMedals = true\n\n\t/** Show legend for segments */\n\t@property({ type: Boolean })\n\tshowLegend = true\n\n\t/** Animation duration in milliseconds */\n\t@property({ type: Number })\n\tanimationDuration = 500\n\n\t/** Enable entrance animation */\n\t@property({ type: Boolean })\n\tanimated = true\n\n\t/** Label column width (Tailwind class) */\n\t@property({ type: String })\n\tlabelWidth = 'w-14'\n\n\t/** Value column width (Tailwind class) */\n\t@property({ type: String })\n\tvalueWidth = 'w-20'\n\n\t@state() private animationProgress = 0\n\t@state() private isVisible = false\n\t@state() private categoryColorMap = new Map<string, string>()\n\n\tprivate observer: IntersectionObserver | null = null\n\tprivate animationFrameId: number | null = null\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\t\tthis.setupIntersectionObserver()\n\t}\n\n\tdisconnectedCallback() {\n\t\tsuper.disconnectedCallback()\n\t\tthis.cleanup()\n\t}\n\n\tprivate cleanup() {\n\t\tif (this.animationFrameId !== null) {\n\t\t\tcancelAnimationFrame(this.animationFrameId)\n\t\t\tthis.animationFrameId = null\n\t\t}\n\t\tif (this.observer) {\n\t\t\tthis.observer.disconnect()\n\t\t\tthis.observer = null\n\t\t}\n\t}\n\n\tprivate setupIntersectionObserver() {\n\t\tthis.observer = new IntersectionObserver(\n\t\t\tentries => {\n\t\t\t\tconst entry = entries[0]\n\t\t\t\tif (entry.isIntersecting && !this.isVisible) {\n\t\t\t\t\tthis.isVisible = true\n\t\t\t\t\tif (this.animated) {\n\t\t\t\t\t\tthis.startAnimation()\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.animationProgress = 1\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t\t{ threshold: 0.1 }\n\t\t)\n\t}\n\n\tprotected firstUpdated() {\n\t\tif (this.observer) {\n\t\t\tthis.observer.observe(this)\n\t\t}\n\t}\n\n\tprotected updated(changedProperties: PropertyValues) {\n\t\tsuper.updated(changedProperties)\n\n\t\t// Restart animation when data changes\n\t\tif (changedProperties.has('data') && this.isVisible && this.animated) {\n\t\t\tthis.animationProgress = 0\n\t\t\tthis.startAnimation()\n\t\t}\n\t}\n\n\tprivate startAnimation() {\n\t\tconst startTime = performance.now()\n\t\tconst duration = this.animationDuration\n\n\t\tconst animateFrame = (currentTime: number) => {\n\t\t\tconst elapsed = currentTime - startTime\n\t\t\tconst progress = Math.min(elapsed / duration, 1)\n\n\t\t\t// Ease out cubic\n\t\t\tthis.animationProgress = 1 - Math.pow(1 - progress, 3)\n\n\t\t\tif (progress < 1 && this.isVisible) {\n\t\t\t\tthis.animationFrameId = requestAnimationFrame(animateFrame)\n\t\t\t}\n\t\t}\n\n\t\tthis.animationFrameId = requestAnimationFrame(animateFrame)\n\t}\n\n\tprivate initializeCategoryColors(): void {\n\t\t// Build consistent color map from all segments in data\n\t\tconst categoryTotals = new Map<string, number>()\n\t\tconst explicitColors = new Map<string, string>()\n\n\t\tthis.data.forEach(d => {\n\t\t\tif (d.segments) {\n\t\t\t\td.segments.forEach(seg => {\n\t\t\t\t\tcategoryTotals.set(seg.label, (categoryTotals.get(seg.label) || 0) + seg.value)\n\t\t\t\t\t// Capture explicit colors from segments\n\t\t\t\t\tif (seg.color && !explicitColors.has(seg.label)) {\n\t\t\t\t\t\texplicitColors.set(seg.label, seg.color)\n\t\t\t\t\t}\n\t\t\t\t})\n\t\t\t}\n\t\t})\n\n\t\t// Sort by total value (most = first color)\n\t\tconst sortedCategories = Array.from(categoryTotals.entries())\n\t\t\t.sort((a, b) => b[1] - a[1])\n\t\t\t.map(([cat]) => cat)\n\n\t\t// Clear and rebuild - use explicit colors if available, otherwise default palette\n\t\tthis.categoryColorMap.clear()\n\t\tlet defaultColorIndex = 0\n\t\tsortedCategories.forEach(cat => {\n\t\t\tif (explicitColors.has(cat)) {\n\t\t\t\tthis.categoryColorMap.set(cat, explicitColors.get(cat)!)\n\t\t\t} else {\n\t\t\t\tthis.categoryColorMap.set(cat, DEFAULT_COLORS[defaultColorIndex % DEFAULT_COLORS.length])\n\t\t\t\tdefaultColorIndex++\n\t\t\t}\n\t\t})\n\t}\n\n\tprivate getSegmentColor(segment: PillSegment): string {\n\t\t// Use explicit color if provided\n\t\tif (segment.color) return segment.color\n\t\t// Otherwise use from color map\n\t\treturn this.categoryColorMap.get(segment.label) || 'bg-primary'\n\t}\n\n\tprivate formatValue(value: number): string {\n\t\tconst formatted = value.toFixed(this.valueDecimals)\n\t\treturn `${this.valuePrefix}${formatted}${this.valueSuffix}`\n\t}\n\n\tprivate getMedalEmoji(rank: number | undefined): string {\n\t\tif (!this.showMedals || !rank) return ''\n\t\tif (rank === 1) return '🥇'\n\t\tif (rank === 2) return '🥈'\n\t\tif (rank === 3) return '🥉'\n\t\treturn ''\n\t}\n\n\tprivate getMaxValue(): number {\n\t\tif (this.data.length === 0) return 0\n\t\treturn Math.max(...this.data.map(d => d.value), 1)\n\t}\n\n\tprivate renderBar(dataPoint: PillDataPoint, maxValue: number): ReturnType<typeof html> {\n\t\tconst percentage = maxValue > 0 ? (dataPoint.value / maxValue) * 100 : 0\n\t\tconst animatedPercentage = percentage * this.animationProgress\n\n\t\t// If no segments, render solid bar\n\t\tif (!dataPoint.segments || dataPoint.segments.length === 0) {\n\t\t\tconst barColorClass = dataPoint.isPeak\n\t\t\t\t? 'bg-success'\n\t\t\t\t: dataPoint.isLow\n\t\t\t\t\t? 'bg-tertiary opacity-70'\n\t\t\t\t\t: dataPoint.value === 0\n\t\t\t\t\t\t? 'bg-tertiary/40'\n\t\t\t\t\t\t: 'bg-primary'\n\n\t\t\treturn html`\n\t\t\t\t<div\n\t\t\t\t\tclass=\"${barColorClass} h-full transition-all rounded-full\"\n\t\t\t\t\tstyle=\"width: ${Math.max(animatedPercentage, dataPoint.value > 0 ? 2 : 0)}%; transition-duration: ${this.animated ? '0ms' : '300ms'}\"\n\t\t\t\t\ttitle=\"${this.formatValue(dataPoint.value)}\"\n\t\t\t\t></div>\n\t\t\t`\n\t\t}\n\n\t\t// Stacked bar with segments\n\t\treturn html`\n\t\t\t<div\n\t\t\t\tclass=\"h-full flex\"\n\t\t\t\tstyle=\"width: ${Math.max(animatedPercentage, 2)}%; transition-duration: ${this.animated ? '0ms' : '300ms'}\"\n\t\t\t>\n\t\t\t\t${repeat(\n\t\t\t\t\tdataPoint.segments,\n\t\t\t\t\tseg => seg.label,\n\t\t\t\t\t(seg, index) => {\n\t\t\t\t\t\tconst segmentPercentage = dataPoint.value > 0 ? (seg.value / dataPoint.value) * 100 : 0\n\t\t\t\t\t\tconst marginLeft = index > 0 ? 'ml-px' : ''\n\t\t\t\t\t\tconst brightenClass = dataPoint.isPeak ? 'brightness-110' : ''\n\t\t\t\t\t\tconst colorClass = this.getSegmentColor(seg)\n\n\t\t\t\t\t\treturn html`\n\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\tclass=\"${colorClass} ${marginLeft} ${brightenClass} h-full transition-all\n\t\t\t\t\t\t\t\t\t${index === 0 ? 'rounded-l-full' : ''}\n\t\t\t\t\t\t\t\t\t${index === dataPoint.segments!.length - 1 ? 'rounded-r-full' : ''}\"\n\t\t\t\t\t\t\t\tstyle=\"width: ${segmentPercentage}%\"\n\t\t\t\t\t\t\t\ttitle=\"${seg.label}: ${this.formatValue(seg.value)}\"\n\t\t\t\t\t\t\t></div>\n\t\t\t\t\t\t`\n\t\t\t\t\t}\n\t\t\t\t)}\n\t\t\t</div>\n\t\t`\n\t}\n\n\tprivate renderLegend(): ReturnType<typeof html> {\n\t\tif (!this.showLegend || this.categoryColorMap.size === 0) {\n\t\t\treturn html``\n\t\t}\n\n\t\treturn html`\n\t\t\t<div class=\"flex flex-wrap gap-3 mt-4 pt-4 border-t border-outline-variant\">\n\t\t\t\t${repeat(\n\t\t\t\t\tArray.from(this.categoryColorMap.entries()),\n\t\t\t\t\t([cat]) => cat,\n\t\t\t\t\t([cat, color]) => html`\n\t\t\t\t\t\t<div class=\"flex items-center gap-1.5\">\n\t\t\t\t\t\t\t<div class=\"${color} w-3 h-3 rounded-sm\"></div>\n\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"sm\" class=\"text-surface-onVariant\">\n\t\t\t\t\t\t\t\t${cat}\n\t\t\t\t\t\t\t</schmancy-typography>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t`\n\t\t\t\t)}\n\t\t\t</div>\n\t\t`\n\t}\n\n\trender() {\n\t\t// Initialize colors before rendering\n\t\tthis.initializeCategoryColors()\n\n\t\tif (!this.data || this.data.length === 0) {\n\t\t\treturn html``\n\t\t}\n\n\t\tconst maxValue = this.getMaxValue()\n\n\t\treturn html`\n\t\t\t<div class=\"space-y-1\">\n\t\t\t\t${repeat(\n\t\t\t\t\tthis.data,\n\t\t\t\t\td => d.label,\n\t\t\t\t\td => {\n\t\t\t\t\t\tconst rowBgClass = d.isPeak ? 'bg-success/10 rounded-lg' : ''\n\t\t\t\t\t\tconst textColorClass = d.isPeak ? 'text-success font-bold' : 'text-surface-on'\n\n\t\t\t\t\t\treturn html`\n\t\t\t\t\t\t\t<div class=\"flex items-center gap-3 py-2 px-2 ${rowBgClass}\">\n\t\t\t\t\t\t\t\t<!-- Label -->\n\t\t\t\t\t\t\t\t<div class=\"${this.labelWidth} shrink-0 text-right\">\n\t\t\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"md\" class=\"${textColorClass}\">\n\t\t\t\t\t\t\t\t\t\t${d.label}\n\t\t\t\t\t\t\t\t\t</schmancy-typography>\n\t\t\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t\t\t<!-- Medal -->\n\t\t\t\t\t\t\t\t<div class=\"w-6 shrink-0 text-center\">\n\t\t\t\t\t\t\t\t\t${d.isPeak || (d.rank && d.rank <= 3)\n\t\t\t\t\t\t\t\t\t\t? html`<span class=\"text-sm\">${this.getMedalEmoji(d.rank)}</span>`\n\t\t\t\t\t\t\t\t\t\t: ''}\n\t\t\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t\t\t<!-- Bar -->\n\t\t\t\t\t\t\t\t<div class=\"flex-1 h-6 bg-secondary/15 rounded-full overflow-hidden\">\n\t\t\t\t\t\t\t\t\t${this.renderBar(d, maxValue)}\n\t\t\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t\t\t<!-- Value -->\n\t\t\t\t\t\t\t\t<div class=\"${this.valueWidth} shrink-0 text-right\">\n\t\t\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"md\" class=\"${textColorClass}\">\n\t\t\t\t\t\t\t\t\t\t${this.formatValue(d.value)}\n\t\t\t\t\t\t\t\t\t</schmancy-typography>\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t`\n\t\t\t\t\t}\n\t\t\t\t)}\n\t\t\t</div>\n\n\t\t\t<!-- Legend -->\n\t\t\t${this.renderLegend()}\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-pills': SchmancyPills\n\t}\n}\n"],"names":["catmullRomSpline","p0","p1","p2","p3","t","t2","t3","x","y","hexToRgba","color","alpha","startsWith","match","length","hex","replace","split","map","c","join","parseInt","substring","easeOutCubic","Math","pow","SchmancyAreaChart","$LitElement","css","constructor","super","arguments","this","data","height","showGrid","showLabels","showTooltip","peakCount","animationDuration","animated","valuePrefix","valueSuffix","valueDecimals","theme","tooltipData","visible","label","value","animationProgress","isVisible","canvasRef","createRef","containerRef","animationFrameId","observer","processedData","resizeObserver","handlePointerMove","e","canvas","rect","getBoundingClientRect","clientX","left","closestPoint","minDistance","Infinity","forEach","point","distance","abs","metadata","handlePointerLeave","connectedCallback","setupIntersectionObserver","disconnectedCallback","cleanup","cancelAnimationFrame","disconnect","IntersectionObserver","entries","entry","isIntersecting","startAnimation","drawChart","threshold","changedProperties","updated","observe","ResizeObserver","has","startTime","performance","now","duration","animateFrame","currentTime","elapsed","progress","min","requestAnimationFrame","processData","sortedByValue","sort","a","b","peakLabels","Set","slice","d","isPeak","key","defaultValue","ctx","getContext","dpr","window","devicePixelRatio","width","scale","clearRect","padding","chartWidth","chartHeight","maxValue","max","points","i","defaultPrimaryColor","getComputedStyle","getPropertyValue","trim","primaryColor","getThemeValue","gradientOpacityTop","gradientOpacityBottom","strokeWidth","pointRadius","peakRadius","strokeStyle","lineWidth","setLineDash","beginPath","moveTo","lineTo","stroke","curvePath","Path2D","areaPath","segments","j","closePath","arc","PI","save","clip","gradient","createLinearGradient","addColorStop","fillStyle","fill","lineCap","lineJoin","index","radius","outerRadius","restore","font","textAlign","textBaseline","labelStep","fillText","formatted","toFixed","renderMetadata","Object","html","String","render","ref","formatValue","__decorateClass","property","type","Array","prototype","Number","Boolean","state","customElement","DEFAULT_COLORS","SchmancyPills","showMedals","showLegend","labelWidth","valueWidth","categoryColorMap","Map","firstUpdated","categoryTotals","explicitColors","seg","set","get","sortedCategories","from","cat","clear","defaultColorIndex","segment","rank","getMaxValue","dataPoint","animatedPercentage","barColorClass","isLow","repeat","segmentPercentage","marginLeft","brightenClass","colorClass","getSegmentColor","size","initializeCategoryColors","rowBgClass","textColorClass","getMedalEmoji","renderBar","renderLegend"],"mappings":"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"}
1
+ {"version":3,"file":"pills-BS5rZ6C3.js","sources":["../src/charts/utils.ts","../src/charts/area-chart.ts","../src/charts/pills.ts"],"sourcesContent":["/**\n * Catmull-Rom spline interpolation for smooth curves\n * Returns the interpolated point between p1 and p2\n */\nexport function catmullRomSpline(\n\tp0: { x: number; y: number },\n\tp1: { x: number; y: number },\n\tp2: { x: number; y: number },\n\tp3: { x: number; y: number },\n\tt: number\n): { x: number; y: number } {\n\tconst t2 = t * t\n\tconst t3 = t2 * t\n\n\tconst x =\n\t\t0.5 *\n\t\t(2 * p1.x +\n\t\t\t(-p0.x + p2.x) * t +\n\t\t\t(2 * p0.x - 5 * p1.x + 4 * p2.x - p3.x) * t2 +\n\t\t\t(-p0.x + 3 * p1.x - 3 * p2.x + p3.x) * t3)\n\n\tconst y =\n\t\t0.5 *\n\t\t(2 * p1.y +\n\t\t\t(-p0.y + p2.y) * t +\n\t\t\t(2 * p0.y - 5 * p1.y + 4 * p2.y - p3.y) * t2 +\n\t\t\t(-p0.y + 3 * p1.y - 3 * p2.y + p3.y) * t3)\n\n\treturn { x, y }\n}\n\n/**\n * Converts hex or rgb color to rgba string\n */\nexport function hexToRgba(color: string, alpha: number): string {\n\t// Handle rgb/rgba format\n\tif (color.startsWith('rgb')) {\n\t\tconst match = color.match(/[\\d.]+/g)\n\t\tif (match && match.length >= 3) {\n\t\t\treturn `rgba(${match[0]}, ${match[1]}, ${match[2]}, ${alpha})`\n\t\t}\n\t}\n\n\t// Handle hex format\n\tlet hex = color.replace('#', '')\n\tif (hex.length === 3) {\n\t\thex = hex\n\t\t\t.split('')\n\t\t\t.map(c => c + c)\n\t\t\t.join('')\n\t}\n\n\tconst r = parseInt(hex.substring(0, 2), 16)\n\tconst g = parseInt(hex.substring(2, 4), 16)\n\tconst b = parseInt(hex.substring(4, 6), 16)\n\n\treturn `rgba(${r}, ${g}, ${b}, ${alpha})`\n}\n\n/**\n * Cubic ease-out animation function\n */\nexport function easeOutCubic(t: number): number {\n\treturn 1 - Math.pow(1 - t, 3)\n}\n","import { html, css, PropertyValues } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { ref, createRef, Ref } from 'lit/directives/ref.js'\nimport { $LitElement } from '@mixins/index'\nimport type { ChartDataPoint, ChartTheme, ProcessedDataPoint } from './types'\nimport { catmullRomSpline, hexToRgba, easeOutCubic } from './utils'\n\ninterface TooltipData {\n\tvisible: boolean\n\tx: number\n\ty: number\n\tlabel: string\n\tvalue: number\n\tmetadata?: Record<string, unknown>\n}\n\n@customElement('schmancy-area-chart')\nexport class SchmancyAreaChart extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n`) {\n\t/** Chart data points */\n\t@property({ type: Array })\n\tdata: ChartDataPoint[] = []\n\n\t/** Chart height in pixels */\n\t@property({ type: Number })\n\theight = 200\n\n\t/** Show grid lines */\n\t@property({ type: Boolean })\n\tshowGrid = true\n\n\t/** Show x-axis labels */\n\t@property({ type: Boolean })\n\tshowLabels = true\n\n\t/** Enable tooltips */\n\t@property({ type: Boolean })\n\tshowTooltip = true\n\n\t/** Number of peaks to highlight */\n\t@property({ type: Number })\n\tpeakCount = 3\n\n\t/** Animation duration in milliseconds */\n\t@property({ type: Number })\n\tanimationDuration = 800\n\n\t/** Enable entrance animation */\n\t@property({ type: Boolean })\n\tanimated = true\n\n\t/** Prefix for values (e.g., \"EUR \") */\n\t@property({ type: String })\n\tvaluePrefix = ''\n\n\t/** Suffix for values (e.g., \"%\") */\n\t@property({ type: String })\n\tvalueSuffix = ''\n\n\t/** Decimal places for value display */\n\t@property({ type: Number })\n\tvalueDecimals = 2\n\n\t/** Theme overrides */\n\t@property({ type: Object })\n\ttheme: Partial<ChartTheme> = {}\n\n\t@state() private tooltipData: TooltipData = {\n\t\tvisible: false,\n\t\tx: 0,\n\t\ty: 0,\n\t\tlabel: '',\n\t\tvalue: 0,\n\t}\n\n\t@state() private animationProgress = 0\n\t@state() private isVisible = false\n\n\tprivate canvasRef: Ref<HTMLCanvasElement> = createRef()\n\tprivate containerRef: Ref<HTMLDivElement> = createRef()\n\tprivate animationFrameId: number | null = null\n\tprivate observer: IntersectionObserver | null = null\n\tprivate processedData: ProcessedDataPoint[] = []\n\tprivate resizeObserver: ResizeObserver | null = null\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\t\tthis.setupIntersectionObserver()\n\t}\n\n\tdisconnectedCallback() {\n\t\tsuper.disconnectedCallback()\n\t\tthis.cleanup()\n\t}\n\n\tprivate cleanup() {\n\t\tif (this.animationFrameId !== null) {\n\t\t\tcancelAnimationFrame(this.animationFrameId)\n\t\t\tthis.animationFrameId = null\n\t\t}\n\t\tif (this.observer) {\n\t\t\tthis.observer.disconnect()\n\t\t\tthis.observer = null\n\t\t}\n\t\tif (this.resizeObserver) {\n\t\t\tthis.resizeObserver.disconnect()\n\t\t\tthis.resizeObserver = null\n\t\t}\n\t}\n\n\tprivate setupIntersectionObserver() {\n\t\tthis.observer = new IntersectionObserver(\n\t\t\tentries => {\n\t\t\t\tconst entry = entries[0]\n\t\t\t\tif (entry.isIntersecting && !this.isVisible) {\n\t\t\t\t\tthis.isVisible = true\n\t\t\t\t\tif (this.animated) {\n\t\t\t\t\t\tthis.startAnimation()\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.animationProgress = 1\n\t\t\t\t\t\tthis.drawChart()\n\t\t\t\t\t}\n\t\t\t\t} else if (!entry.isIntersecting) {\n\t\t\t\t\tthis.isVisible = false\n\t\t\t\t\tif (this.animationFrameId !== null) {\n\t\t\t\t\t\tcancelAnimationFrame(this.animationFrameId)\n\t\t\t\t\t\tthis.animationFrameId = null\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t\t{ threshold: 0.1 }\n\t\t)\n\t}\n\n\tprotected updated(changedProperties: PropertyValues) {\n\t\tsuper.updated(changedProperties)\n\n\t\tif (this.containerRef.value && this.observer) {\n\t\t\tthis.observer.observe(this.containerRef.value)\n\t\t}\n\n\t\tif (this.canvasRef.value && !this.resizeObserver) {\n\t\t\tthis.resizeObserver = new ResizeObserver(() => {\n\t\t\t\tthis.drawChart()\n\t\t\t})\n\t\t\tthis.resizeObserver.observe(this.canvasRef.value)\n\t\t}\n\n\t\t// Redraw when data changes\n\t\tif (changedProperties.has('data') && this.isVisible) {\n\t\t\tif (this.animated) {\n\t\t\t\tthis.animationProgress = 0\n\t\t\t\tthis.startAnimation()\n\t\t\t} else {\n\t\t\t\tthis.animationProgress = 1\n\t\t\t\tthis.drawChart()\n\t\t\t}\n\t\t}\n\n\t\t// Redraw on theme or config changes\n\t\tif (\n\t\t\t(changedProperties.has('theme') ||\n\t\t\t\tchangedProperties.has('showGrid') ||\n\t\t\t\tchangedProperties.has('showLabels') ||\n\t\t\t\tchangedProperties.has('peakCount')) &&\n\t\t\tthis.isVisible\n\t\t) {\n\t\t\tthis.drawChart()\n\t\t}\n\t}\n\n\tprivate startAnimation() {\n\t\tconst startTime = performance.now()\n\t\tconst duration = this.animationDuration\n\n\t\tconst animateFrame = (currentTime: number) => {\n\t\t\tconst elapsed = currentTime - startTime\n\t\t\tconst progress = Math.min(elapsed / duration, 1)\n\n\t\t\tthis.animationProgress = easeOutCubic(progress)\n\t\t\tthis.drawChart()\n\n\t\t\tif (progress < 1 && this.isVisible) {\n\t\t\t\tthis.animationFrameId = requestAnimationFrame(animateFrame)\n\t\t\t}\n\t\t}\n\n\t\tthis.animationFrameId = requestAnimationFrame(animateFrame)\n\t}\n\n\tprivate processData(): ProcessedDataPoint[] {\n\t\tif (!this.data || this.data.length === 0) return []\n\n\t\t// Find top N peak values\n\t\tconst sortedByValue = [...this.data].sort((a, b) => b.value - a.value)\n\t\tconst peakLabels = new Set(sortedByValue.slice(0, this.peakCount).map(d => d.label))\n\n\t\treturn this.data.map(d => ({\n\t\t\t...d,\n\t\t\tx: 0, // Will be calculated during draw\n\t\t\ty: 0, // Will be calculated during draw\n\t\t\tisPeak: peakLabels.has(d.label),\n\t\t}))\n\t}\n\n\tprivate getThemeValue<K extends keyof ChartTheme>(\n\t\tkey: K,\n\t\tdefaultValue: NonNullable<ChartTheme[K]>\n\t): NonNullable<ChartTheme[K]> {\n\t\treturn (this.theme[key] as NonNullable<ChartTheme[K]>) ?? defaultValue\n\t}\n\n\tprivate drawChart() {\n\t\tconst canvas = this.canvasRef.value\n\t\tif (!canvas) return\n\n\t\tconst ctx = canvas.getContext('2d')\n\t\tif (!ctx) return\n\n\t\tconst dpr = window.devicePixelRatio || 1\n\t\tconst rect = canvas.getBoundingClientRect()\n\t\tconst width = rect.width\n\t\tconst height = rect.height\n\n\t\t// Set canvas size for high DPI\n\t\tcanvas.width = width * dpr\n\t\tcanvas.height = height * dpr\n\t\tctx.scale(dpr, dpr)\n\n\t\t// Clear canvas\n\t\tctx.clearRect(0, 0, width, height)\n\n\t\tconst data = this.processData()\n\t\tif (data.length === 0) return\n\n\t\tconst padding = { top: 20, right: 20, bottom: this.showLabels ? 40 : 20, left: 20 }\n\t\tconst chartWidth = width - padding.left - padding.right\n\t\tconst chartHeight = height - padding.top - padding.bottom\n\n\t\t// Find max value for scaling\n\t\tconst maxValue = Math.max(...data.map(d => d.value), 1)\n\n\t\t// Calculate positions\n\t\tconst points = data.map((d, i) => ({\n\t\t\t...d,\n\t\t\tx: padding.left + (data.length > 1 ? (i / (data.length - 1)) * chartWidth : chartWidth / 2),\n\t\t\ty: padding.top + chartHeight - (d.value / maxValue) * chartHeight,\n\t\t}))\n\n\t\tthis.processedData = points\n\n\t\t// Get primary color from CSS or theme\n\t\tconst computedStyle = getComputedStyle(this)\n\t\tconst defaultPrimaryColor =\n\t\t\tcomputedStyle.getPropertyValue('--schmancy-sys-color-primary').trim() || '#6750A4'\n\t\tconst primaryColor = this.getThemeValue('primaryColor', defaultPrimaryColor)\n\t\tconst [gradientOpacityTop, gradientOpacityBottom] = this.getThemeValue('gradientOpacity', [0.4, 0.05])\n\t\tconst strokeWidth = this.getThemeValue('strokeWidth', 2)\n\t\tconst pointRadius = this.getThemeValue('pointRadius', 4)\n\t\tconst peakRadius = this.getThemeValue('peakRadius', 6)\n\n\t\t// Draw grid lines\n\t\tif (this.showGrid) {\n\t\t\tctx.strokeStyle = 'rgba(128, 128, 128, 0.15)'\n\t\t\tctx.lineWidth = 1\n\t\t\tctx.setLineDash([4, 4])\n\n\t\t\tfor (let i = 1; i <= 3; i++) {\n\t\t\t\tconst y = padding.top + (chartHeight * i) / 4\n\t\t\t\tctx.beginPath()\n\t\t\t\tctx.moveTo(padding.left, y)\n\t\t\t\tctx.lineTo(width - padding.right, y)\n\t\t\t\tctx.stroke()\n\t\t\t}\n\n\t\t\tctx.setLineDash([])\n\t\t}\n\n\t\t// Create smooth curve path using Catmull-Rom spline\n\t\tconst curvePath = new Path2D()\n\t\tconst areaPath = new Path2D()\n\n\t\tif (points.length >= 2) {\n\t\t\t// Start area path from bottom left\n\t\t\tareaPath.moveTo(points[0].x, padding.top + chartHeight)\n\t\t\tcurvePath.moveTo(points[0].x, points[0].y)\n\t\t\tareaPath.lineTo(points[0].x, points[0].y)\n\n\t\t\tfor (let i = 0; i < points.length - 1; i++) {\n\t\t\t\tconst p0 = points[Math.max(0, i - 1)]\n\t\t\t\tconst p1 = points[i]\n\t\t\t\tconst p2 = points[Math.min(points.length - 1, i + 1)]\n\t\t\t\tconst p3 = points[Math.min(points.length - 1, i + 2)]\n\n\t\t\t\t// Draw curve segments\n\t\t\t\tconst segments = 16\n\t\t\t\tfor (let j = 1; j <= segments; j++) {\n\t\t\t\t\tconst t = j / segments\n\t\t\t\t\tconst point = catmullRomSpline(p0, p1, p2, p3, t)\n\t\t\t\t\tcurvePath.lineTo(point.x, point.y)\n\t\t\t\t\tareaPath.lineTo(point.x, point.y)\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Close area path\n\t\t\tareaPath.lineTo(points[points.length - 1].x, padding.top + chartHeight)\n\t\t\tareaPath.closePath()\n\t\t} else if (points.length === 1) {\n\t\t\t// Single point - draw a dot\n\t\t\tcurvePath.arc(points[0].x, points[0].y, pointRadius, 0, Math.PI * 2)\n\t\t}\n\n\t\t// Apply animation clipping\n\t\tctx.save()\n\t\tctx.beginPath()\n\t\tctx.rect(0, 0, padding.left + chartWidth * this.animationProgress, height)\n\t\tctx.clip()\n\n\t\t// Draw gradient fill\n\t\tif (points.length >= 2) {\n\t\t\tconst gradient = ctx.createLinearGradient(0, padding.top, 0, padding.top + chartHeight)\n\t\t\tgradient.addColorStop(0, hexToRgba(primaryColor, gradientOpacityTop))\n\t\t\tgradient.addColorStop(1, hexToRgba(primaryColor, gradientOpacityBottom))\n\n\t\t\tctx.fillStyle = gradient\n\t\t\tctx.fill(areaPath)\n\t\t}\n\n\t\t// Draw stroke\n\t\tctx.strokeStyle = primaryColor\n\t\tctx.lineWidth = strokeWidth\n\t\tctx.lineCap = 'round'\n\t\tctx.lineJoin = 'round'\n\t\tctx.stroke(curvePath)\n\n\t\t// Draw data points\n\t\tpoints.forEach((point, index) => {\n\t\t\tconst pointProgress = (index / (points.length - 1 || 1)) * this.animationProgress\n\t\t\tif (pointProgress < index / (points.length || 1)) return\n\n\t\t\tconst radius = point.isPeak ? peakRadius - 1 : pointRadius - 1\n\t\t\tconst outerRadius = point.isPeak ? peakRadius + 4 : pointRadius + 2\n\n\t\t\t// Outer glow for peaks\n\t\t\tif (point.isPeak) {\n\t\t\t\tctx.beginPath()\n\t\t\t\tctx.arc(point.x, point.y, outerRadius, 0, Math.PI * 2)\n\t\t\t\tctx.fillStyle = hexToRgba(primaryColor, 0.2)\n\t\t\t\tctx.fill()\n\t\t\t}\n\n\t\t\t// Inner dot\n\t\t\tctx.beginPath()\n\t\t\tctx.arc(point.x, point.y, radius, 0, Math.PI * 2)\n\t\t\tctx.fillStyle = primaryColor\n\t\t\tctx.fill()\n\n\t\t\t// White center for peaks\n\t\t\tif (point.isPeak) {\n\t\t\t\tctx.beginPath()\n\t\t\t\tctx.arc(point.x, point.y, 2, 0, Math.PI * 2)\n\t\t\t\tctx.fillStyle = 'white'\n\t\t\t\tctx.fill()\n\t\t\t}\n\t\t})\n\n\t\tctx.restore()\n\n\t\t// Draw labels\n\t\tif (this.showLabels && points.length > 0) {\n\t\t\tctx.fillStyle = 'rgba(128, 128, 128, 0.8)'\n\t\t\tctx.font = '11px system-ui, sans-serif'\n\t\t\tctx.textAlign = 'center'\n\t\t\tctx.textBaseline = 'top'\n\n\t\t\t// Show fewer labels on narrow charts\n\t\t\tconst labelStep = width < 400 ? 3 : width < 600 ? 2 : 1\n\t\t\tpoints.forEach((point, index) => {\n\t\t\t\tif (index % labelStep === 0) {\n\t\t\t\t\tctx.fillText(point.label, point.x, height - padding.bottom + 8)\n\t\t\t\t}\n\t\t\t})\n\t\t}\n\t}\n\n\tprivate formatValue(value: number): string {\n\t\tconst formatted = value.toFixed(this.valueDecimals)\n\t\treturn `${this.valuePrefix}${formatted}${this.valueSuffix}`\n\t}\n\n\tprivate handlePointerMove = (e: PointerEvent) => {\n\t\tif (this.processedData.length === 0 || !this.showTooltip) return\n\n\t\tconst canvas = this.canvasRef.value\n\t\tif (!canvas) return\n\n\t\tconst rect = canvas.getBoundingClientRect()\n\t\tconst x = e.clientX - rect.left\n\n\t\t// Find closest data point\n\t\tlet closestPoint: ProcessedDataPoint | null = null\n\t\tlet minDistance = Infinity\n\n\t\tthis.processedData.forEach(point => {\n\t\t\tconst distance = Math.abs(point.x - x)\n\t\t\tif (distance < minDistance) {\n\t\t\t\tminDistance = distance\n\t\t\t\tclosestPoint = point\n\t\t\t}\n\t\t})\n\n\t\tif (closestPoint && minDistance < 30) {\n\t\t\tthis.tooltipData = {\n\t\t\t\tvisible: true,\n\t\t\t\tx: closestPoint.x,\n\t\t\t\ty: closestPoint.y,\n\t\t\t\tlabel: closestPoint.label,\n\t\t\t\tvalue: closestPoint.value,\n\t\t\t\tmetadata: closestPoint.metadata,\n\t\t\t}\n\t\t} else {\n\t\t\tthis.tooltipData = { ...this.tooltipData, visible: false }\n\t\t}\n\t}\n\n\tprivate handlePointerLeave = () => {\n\t\tthis.tooltipData = { ...this.tooltipData, visible: false }\n\t}\n\n\tprivate renderMetadata() {\n\t\tif (!this.tooltipData.metadata) return ''\n\t\treturn Object.entries(this.tooltipData.metadata).map(\n\t\t\t([key, value]) => html`\n\t\t\t\t<schmancy-typography type=\"body\" token=\"sm\" class=\"text-surface-onVariant\">\n\t\t\t\t\t${key}: ${String(value)}\n\t\t\t\t</schmancy-typography>\n\t\t\t`\n\t\t)\n\t}\n\n\trender() {\n\t\tif (!this.data || this.data.length === 0) {\n\t\t\treturn html``\n\t\t}\n\n\t\treturn html`\n\t\t\t<div ${ref(this.containerRef)} class=\"relative\">\n\t\t\t\t<div class=\"relative\" style=\"height: ${this.height}px; touch-action: pan-y;\">\n\t\t\t\t\t<canvas\n\t\t\t\t\t\t${ref(this.canvasRef)}\n\t\t\t\t\t\tclass=\"w-full h-full\"\n\t\t\t\t\t\tstyle=\"display: block;\"\n\t\t\t\t\t\t@pointermove=${this.handlePointerMove}\n\t\t\t\t\t\t@pointerleave=${this.handlePointerLeave}\n\t\t\t\t\t></canvas>\n\n\t\t\t\t\t<!-- Tooltip -->\n\t\t\t\t\t${this.showTooltip\n\t\t\t\t\t\t? html`\n\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\tclass=\"absolute pointer-events-none transition-opacity duration-150 ${this.tooltipData.visible\n\t\t\t\t\t\t\t\t\t\t? 'opacity-100'\n\t\t\t\t\t\t\t\t\t\t: 'opacity-0'}\"\n\t\t\t\t\t\t\t\t\tstyle=\"\n left: ${this.tooltipData.x}px;\n top: ${this.tooltipData.y - 60}px;\n transform: translateX(-50%);\n \"\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t<schmancy-surface elevation=\"3\" rounded=\"all\" class=\"px-3 py-2 min-w-max\">\n\t\t\t\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"sm\" class=\"text-surface-onVariant\">\n\t\t\t\t\t\t\t\t\t\t\t${this.tooltipData.label}\n\t\t\t\t\t\t\t\t\t\t</schmancy-typography>\n\t\t\t\t\t\t\t\t\t\t<schmancy-typography type=\"title\" token=\"md\" class=\"text-surface-on font-semibold\">\n\t\t\t\t\t\t\t\t\t\t\t${this.formatValue(this.tooltipData.value)}\n\t\t\t\t\t\t\t\t\t\t</schmancy-typography>\n\t\t\t\t\t\t\t\t\t\t${this.renderMetadata()}\n\t\t\t\t\t\t\t\t\t</schmancy-surface>\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t `\n\t\t\t\t\t\t: ''}\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-area-chart': SchmancyAreaChart\n\t}\n}\n","import { html, css, PropertyValues } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { repeat } from 'lit/directives/repeat.js'\nimport { $LitElement } from '@mixins/index'\nimport type { PillDataPoint, PillSegment } from './types'\n\n/** Default color palette for segments - expanded for uniqueness */\nconst DEFAULT_COLORS = [\n\t'bg-primary',\n\t'bg-secondary',\n\t'bg-tertiary',\n\t'bg-success',\n\t'bg-warning',\n\t'bg-error',\n\t'bg-primary/70',\n\t'bg-secondary/70',\n\t'bg-tertiary/70',\n\t'bg-success/70',\n\t'bg-warning/70',\n\t'bg-error/70',\n\t'bg-primary/40',\n\t'bg-secondary/40',\n\t'bg-tertiary/40',\n]\n\n@customElement('schmancy-pills')\nexport class SchmancyPills extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n`) {\n\t/** Chart data points */\n\t@property({ type: Array })\n\tdata: PillDataPoint[] = []\n\n\t/** Prefix for values (e.g., \"EUR \") */\n\t@property({ type: String })\n\tvaluePrefix = ''\n\n\t/** Suffix for values (e.g., \"%\") */\n\t@property({ type: String })\n\tvalueSuffix = ''\n\n\t/** Decimal places for value display */\n\t@property({ type: Number })\n\tvalueDecimals = 2\n\n\t/** Show medals for top 3 */\n\t@property({ type: Boolean })\n\tshowMedals = true\n\n\t/** Show legend for segments */\n\t@property({ type: Boolean })\n\tshowLegend = true\n\n\t/** Animation duration in milliseconds */\n\t@property({ type: Number })\n\tanimationDuration = 500\n\n\t/** Enable entrance animation */\n\t@property({ type: Boolean })\n\tanimated = true\n\n\t/** Label column width (Tailwind class) */\n\t@property({ type: String })\n\tlabelWidth = 'w-14'\n\n\t/** Value column width (Tailwind class) */\n\t@property({ type: String })\n\tvalueWidth = 'w-20'\n\n\t@state() private animationProgress = 0\n\t@state() private isVisible = false\n\t@state() private categoryColorMap = new Map<string, string>()\n\n\tprivate observer: IntersectionObserver | null = null\n\tprivate animationFrameId: number | null = null\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\t\tthis.setupIntersectionObserver()\n\t}\n\n\tdisconnectedCallback() {\n\t\tsuper.disconnectedCallback()\n\t\tthis.cleanup()\n\t}\n\n\tprivate cleanup() {\n\t\tif (this.animationFrameId !== null) {\n\t\t\tcancelAnimationFrame(this.animationFrameId)\n\t\t\tthis.animationFrameId = null\n\t\t}\n\t\tif (this.observer) {\n\t\t\tthis.observer.disconnect()\n\t\t\tthis.observer = null\n\t\t}\n\t}\n\n\tprivate setupIntersectionObserver() {\n\t\tthis.observer = new IntersectionObserver(\n\t\t\tentries => {\n\t\t\t\tconst entry = entries[0]\n\t\t\t\tif (entry.isIntersecting && !this.isVisible) {\n\t\t\t\t\tthis.isVisible = true\n\t\t\t\t\tif (this.animated) {\n\t\t\t\t\t\tthis.startAnimation()\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.animationProgress = 1\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t\t{ threshold: 0.1 }\n\t\t)\n\t}\n\n\tprotected firstUpdated() {\n\t\tif (this.observer) {\n\t\t\tthis.observer.observe(this)\n\t\t}\n\t}\n\n\tprotected updated(changedProperties: PropertyValues) {\n\t\tsuper.updated(changedProperties)\n\n\t\t// Restart animation when data changes\n\t\tif (changedProperties.has('data') && this.isVisible && this.animated) {\n\t\t\tthis.animationProgress = 0\n\t\t\tthis.startAnimation()\n\t\t}\n\t}\n\n\tprivate startAnimation() {\n\t\tconst startTime = performance.now()\n\t\tconst duration = this.animationDuration\n\n\t\tconst animateFrame = (currentTime: number) => {\n\t\t\tconst elapsed = currentTime - startTime\n\t\t\tconst progress = Math.min(elapsed / duration, 1)\n\n\t\t\t// Ease out cubic\n\t\t\tthis.animationProgress = 1 - Math.pow(1 - progress, 3)\n\n\t\t\tif (progress < 1 && this.isVisible) {\n\t\t\t\tthis.animationFrameId = requestAnimationFrame(animateFrame)\n\t\t\t}\n\t\t}\n\n\t\tthis.animationFrameId = requestAnimationFrame(animateFrame)\n\t}\n\n\tprivate initializeCategoryColors(): void {\n\t\t// Build consistent color map from all segments in data\n\t\tconst categoryTotals = new Map<string, number>()\n\t\tconst explicitColors = new Map<string, string>()\n\n\t\tthis.data.forEach(d => {\n\t\t\tif (d.segments) {\n\t\t\t\td.segments.forEach(seg => {\n\t\t\t\t\tcategoryTotals.set(seg.label, (categoryTotals.get(seg.label) || 0) + seg.value)\n\t\t\t\t\t// Capture explicit colors from segments\n\t\t\t\t\tif (seg.color && !explicitColors.has(seg.label)) {\n\t\t\t\t\t\texplicitColors.set(seg.label, seg.color)\n\t\t\t\t\t}\n\t\t\t\t})\n\t\t\t}\n\t\t})\n\n\t\t// Sort by total value (most = first color)\n\t\tconst sortedCategories = Array.from(categoryTotals.entries())\n\t\t\t.sort((a, b) => b[1] - a[1])\n\t\t\t.map(([cat]) => cat)\n\n\t\t// Clear and rebuild - use explicit colors if available, otherwise default palette\n\t\tthis.categoryColorMap.clear()\n\t\tlet defaultColorIndex = 0\n\t\tsortedCategories.forEach(cat => {\n\t\t\tif (explicitColors.has(cat)) {\n\t\t\t\tthis.categoryColorMap.set(cat, explicitColors.get(cat)!)\n\t\t\t} else {\n\t\t\t\tthis.categoryColorMap.set(cat, DEFAULT_COLORS[defaultColorIndex % DEFAULT_COLORS.length])\n\t\t\t\tdefaultColorIndex++\n\t\t\t}\n\t\t})\n\t}\n\n\tprivate getSegmentColor(segment: PillSegment): string {\n\t\t// Use explicit color if provided\n\t\tif (segment.color) return segment.color\n\t\t// Otherwise use from color map\n\t\treturn this.categoryColorMap.get(segment.label) || 'bg-primary'\n\t}\n\n\tprivate formatValue(value: number): string {\n\t\tconst formatted = value.toFixed(this.valueDecimals)\n\t\treturn `${this.valuePrefix}${formatted}${this.valueSuffix}`\n\t}\n\n\tprivate getMedalEmoji(rank: number | undefined): string {\n\t\tif (!this.showMedals || !rank) return ''\n\t\tif (rank === 1) return '🥇'\n\t\tif (rank === 2) return '🥈'\n\t\tif (rank === 3) return '🥉'\n\t\treturn ''\n\t}\n\n\tprivate getMaxValue(): number {\n\t\tif (this.data.length === 0) return 0\n\t\treturn Math.max(...this.data.map(d => d.value), 1)\n\t}\n\n\tprivate renderBar(dataPoint: PillDataPoint, maxValue: number): ReturnType<typeof html> {\n\t\tconst percentage = maxValue > 0 ? (dataPoint.value / maxValue) * 100 : 0\n\t\tconst animatedPercentage = percentage * this.animationProgress\n\n\t\t// If no segments, render solid bar\n\t\tif (!dataPoint.segments || dataPoint.segments.length === 0) {\n\t\t\tconst barColorClass = dataPoint.isPeak\n\t\t\t\t? 'bg-success'\n\t\t\t\t: dataPoint.isLow\n\t\t\t\t\t? 'bg-tertiary opacity-70'\n\t\t\t\t\t: dataPoint.value === 0\n\t\t\t\t\t\t? 'bg-tertiary/40'\n\t\t\t\t\t\t: 'bg-primary'\n\n\t\t\treturn html`\n\t\t\t\t<div\n\t\t\t\t\tclass=\"${barColorClass} h-full transition-all rounded-full\"\n\t\t\t\t\tstyle=\"width: ${Math.max(animatedPercentage, dataPoint.value > 0 ? 2 : 0)}%; transition-duration: ${this.animated ? '0ms' : '300ms'}\"\n\t\t\t\t\ttitle=\"${this.formatValue(dataPoint.value)}\"\n\t\t\t\t></div>\n\t\t\t`\n\t\t}\n\n\t\t// Stacked bar with segments\n\t\treturn html`\n\t\t\t<div\n\t\t\t\tclass=\"h-full flex\"\n\t\t\t\tstyle=\"width: ${Math.max(animatedPercentage, 2)}%; transition-duration: ${this.animated ? '0ms' : '300ms'}\"\n\t\t\t>\n\t\t\t\t${repeat(\n\t\t\t\t\tdataPoint.segments,\n\t\t\t\t\tseg => seg.label,\n\t\t\t\t\t(seg, index) => {\n\t\t\t\t\t\tconst segmentPercentage = dataPoint.value > 0 ? (seg.value / dataPoint.value) * 100 : 0\n\t\t\t\t\t\tconst marginLeft = index > 0 ? 'ml-px' : ''\n\t\t\t\t\t\tconst brightenClass = dataPoint.isPeak ? 'brightness-110' : ''\n\t\t\t\t\t\tconst colorClass = this.getSegmentColor(seg)\n\n\t\t\t\t\t\treturn html`\n\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\tclass=\"${colorClass} ${marginLeft} ${brightenClass} h-full transition-all\n\t\t\t\t\t\t\t\t\t${index === 0 ? 'rounded-l-full' : ''}\n\t\t\t\t\t\t\t\t\t${index === dataPoint.segments!.length - 1 ? 'rounded-r-full' : ''}\"\n\t\t\t\t\t\t\t\tstyle=\"width: ${segmentPercentage}%\"\n\t\t\t\t\t\t\t\ttitle=\"${seg.label}: ${this.formatValue(seg.value)}\"\n\t\t\t\t\t\t\t></div>\n\t\t\t\t\t\t`\n\t\t\t\t\t}\n\t\t\t\t)}\n\t\t\t</div>\n\t\t`\n\t}\n\n\tprivate renderLegend(): ReturnType<typeof html> {\n\t\tif (!this.showLegend || this.categoryColorMap.size === 0) {\n\t\t\treturn html``\n\t\t}\n\n\t\treturn html`\n\t\t\t<div class=\"flex flex-wrap gap-3 mt-4 pt-4 border-t border-outline-variant\">\n\t\t\t\t${repeat(\n\t\t\t\t\tArray.from(this.categoryColorMap.entries()),\n\t\t\t\t\t([cat]) => cat,\n\t\t\t\t\t([cat, color]) => html`\n\t\t\t\t\t\t<div class=\"flex items-center gap-1.5\">\n\t\t\t\t\t\t\t<div class=\"${color} w-3 h-3 rounded-sm\"></div>\n\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"sm\" class=\"text-surface-onVariant\">\n\t\t\t\t\t\t\t\t${cat}\n\t\t\t\t\t\t\t</schmancy-typography>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t`\n\t\t\t\t)}\n\t\t\t</div>\n\t\t`\n\t}\n\n\trender() {\n\t\t// Initialize colors before rendering\n\t\tthis.initializeCategoryColors()\n\n\t\tif (!this.data || this.data.length === 0) {\n\t\t\treturn html``\n\t\t}\n\n\t\tconst maxValue = this.getMaxValue()\n\n\t\treturn html`\n\t\t\t<div class=\"space-y-1\">\n\t\t\t\t${repeat(\n\t\t\t\t\tthis.data,\n\t\t\t\t\td => d.label,\n\t\t\t\t\td => {\n\t\t\t\t\t\tconst rowBgClass = d.isPeak ? 'bg-success/10 rounded-lg' : ''\n\t\t\t\t\t\tconst textColorClass = d.isPeak ? 'text-success font-bold' : 'text-surface-on'\n\n\t\t\t\t\t\treturn html`\n\t\t\t\t\t\t\t<div class=\"flex items-center gap-3 py-2 px-2 ${rowBgClass}\">\n\t\t\t\t\t\t\t\t<!-- Label -->\n\t\t\t\t\t\t\t\t<div class=\"${this.labelWidth} shrink-0 text-right\">\n\t\t\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"md\" class=\"${textColorClass}\">\n\t\t\t\t\t\t\t\t\t\t${d.label}\n\t\t\t\t\t\t\t\t\t</schmancy-typography>\n\t\t\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t\t\t<!-- Medal -->\n\t\t\t\t\t\t\t\t<div class=\"w-6 shrink-0 text-center\">\n\t\t\t\t\t\t\t\t\t${d.isPeak || (d.rank && d.rank <= 3)\n\t\t\t\t\t\t\t\t\t\t? html`<span class=\"text-sm\">${this.getMedalEmoji(d.rank)}</span>`\n\t\t\t\t\t\t\t\t\t\t: ''}\n\t\t\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t\t\t<!-- Bar -->\n\t\t\t\t\t\t\t\t<div class=\"flex-1 h-6 bg-secondary/15 rounded-full overflow-hidden\">\n\t\t\t\t\t\t\t\t\t${this.renderBar(d, maxValue)}\n\t\t\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t\t\t<!-- Value -->\n\t\t\t\t\t\t\t\t<div class=\"${this.valueWidth} shrink-0 text-right\">\n\t\t\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"md\" class=\"${textColorClass}\">\n\t\t\t\t\t\t\t\t\t\t${this.formatValue(d.value)}\n\t\t\t\t\t\t\t\t\t</schmancy-typography>\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t`\n\t\t\t\t\t}\n\t\t\t\t)}\n\t\t\t</div>\n\n\t\t\t<!-- Legend -->\n\t\t\t${this.renderLegend()}\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-pills': SchmancyPills\n\t}\n}\n"],"names":["catmullRomSpline","p0","p1","p2","p3","t","t2","t3","x","y","hexToRgba","color","alpha","startsWith","match","length","hex","replace","split","map","c","join","parseInt","substring","easeOutCubic","Math","pow","SchmancyAreaChart","$LitElement","css","constructor","super","arguments","this","data","height","showGrid","showLabels","showTooltip","peakCount","animationDuration","animated","valuePrefix","valueSuffix","valueDecimals","theme","tooltipData","visible","label","value","animationProgress","isVisible","canvasRef","createRef","containerRef","animationFrameId","observer","processedData","resizeObserver","handlePointerMove","e","canvas","rect","getBoundingClientRect","clientX","left","closestPoint","minDistance","Infinity","forEach","point","distance","abs","metadata","handlePointerLeave","connectedCallback","setupIntersectionObserver","disconnectedCallback","cleanup","cancelAnimationFrame","disconnect","IntersectionObserver","entries","entry","isIntersecting","startAnimation","drawChart","threshold","changedProperties","updated","observe","ResizeObserver","has","startTime","performance","now","duration","animateFrame","currentTime","elapsed","progress","min","requestAnimationFrame","processData","sortedByValue","sort","a","b","peakLabels","Set","slice","d","isPeak","key","defaultValue","ctx","getContext","dpr","window","devicePixelRatio","width","scale","clearRect","padding","chartWidth","chartHeight","maxValue","max","points","i","defaultPrimaryColor","getComputedStyle","getPropertyValue","trim","primaryColor","getThemeValue","gradientOpacityTop","gradientOpacityBottom","strokeWidth","pointRadius","peakRadius","strokeStyle","lineWidth","setLineDash","beginPath","moveTo","lineTo","stroke","curvePath","Path2D","areaPath","segments","j","closePath","arc","PI","save","clip","gradient","createLinearGradient","addColorStop","fillStyle","fill","lineCap","lineJoin","index","radius","outerRadius","restore","font","textAlign","textBaseline","labelStep","fillText","formatted","toFixed","renderMetadata","Object","html","String","render","ref","formatValue","__decorateClass","property","type","Array","prototype","Number","Boolean","state","customElement","DEFAULT_COLORS","SchmancyPills","showMedals","showLegend","labelWidth","valueWidth","categoryColorMap","Map","firstUpdated","categoryTotals","explicitColors","seg","set","get","sortedCategories","from","cat","clear","defaultColorIndex","segment","rank","getMaxValue","dataPoint","animatedPercentage","barColorClass","isLow","repeat","segmentPercentage","marginLeft","brightenClass","colorClass","getSegmentColor","size","initializeCategoryColors","rowBgClass","textColorClass","getMedalEmoji","renderBar","renderLegend"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- "use strict";const p=require("lit"),o=require("lit/decorators.js"),$=require("lit/directives/ref.js");require("rxjs"),require("rxjs/operators"),require("lit/directives/class-map.js"),require("lit/directives/style-map.js"),require("./tailwind.mixin-UijsBrYW.cjs");const R=require("./litElement.mixin-BVBdv0GP.cjs"),D=require("lit/directives/repeat.js");function T(e,t,i,a,s){const r=s*s,h=r*s;return{x:.5*(2*t.x+(-e.x+i.x)*s+(2*e.x-5*t.x+4*i.x-a.x)*r+(-e.x+3*t.x-3*i.x+a.x)*h),y:.5*(2*t.y+(-e.y+i.y)*s+(2*e.y-5*t.y+4*i.y-a.y)*r+(-e.y+3*t.y-3*i.y+a.y)*h)}}function w(e,t){if(e.startsWith("rgb")){const a=e.match(/[\d.]+/g);if(a&&a.length>=3)return`rgba(${a[0]}, ${a[1]}, ${a[2]}, ${t})`}let i=e.replace("#","");return i.length===3&&(i=i.split("").map(a=>a+a).join("")),`rgba(${parseInt(i.substring(0,2),16)}, ${parseInt(i.substring(2,4),16)}, ${parseInt(i.substring(4,6),16)}, ${t})`}function L(e){return 1-Math.pow(1-e,3)}var N=Object.defineProperty,G=Object.getOwnPropertyDescriptor,c=(e,t,i,a)=>{for(var s,r=a>1?void 0:a?G(t,i):t,h=e.length-1;h>=0;h--)(s=e[h])&&(r=(a?s(t,i,r):s(r))||r);return a&&r&&N(t,i,r),r};exports.SchmancyAreaChart=class extends R.$LitElement(p.css`
1
+ "use strict";const p=require("lit"),o=require("lit/decorators.js"),$=require("lit/directives/ref.js");require("rxjs"),require("rxjs/operators"),require("lit/directives/class-map.js"),require("lit/directives/style-map.js"),require("./tailwind.mixin-Cp4PyXok.cjs");const R=require("./litElement.mixin-CrpeGpZ7.cjs"),D=require("lit/directives/repeat.js");function T(e,t,i,a,s){const r=s*s,h=r*s;return{x:.5*(2*t.x+(-e.x+i.x)*s+(2*e.x-5*t.x+4*i.x-a.x)*r+(-e.x+3*t.x-3*i.x+a.x)*h),y:.5*(2*t.y+(-e.y+i.y)*s+(2*e.y-5*t.y+4*i.y-a.y)*r+(-e.y+3*t.y-3*i.y+a.y)*h)}}function w(e,t){if(e.startsWith("rgb")){const a=e.match(/[\d.]+/g);if(a&&a.length>=3)return`rgba(${a[0]}, ${a[1]}, ${a[2]}, ${t})`}let i=e.replace("#","");return i.length===3&&(i=i.split("").map(a=>a+a).join("")),`rgba(${parseInt(i.substring(0,2),16)}, ${parseInt(i.substring(2,4),16)}, ${parseInt(i.substring(4,6),16)}, ${t})`}function L(e){return 1-Math.pow(1-e,3)}var N=Object.defineProperty,G=Object.getOwnPropertyDescriptor,c=(e,t,i,a)=>{for(var s,r=a>1?void 0:a?G(t,i):t,h=e.length-1;h>=0;h--)(s=e[h])&&(r=(a?s(t,i,r):s(r))||r);return a&&r&&N(t,i,r),r};exports.SchmancyAreaChart=class extends R.$LitElement(p.css`
2
2
  :host {
3
3
  display: block;
4
4
  }
@@ -110,4 +110,4 @@
110
110
  <!-- Legend -->
111
111
  ${this.renderLegend()}
112
112
  `}},m([o.property({type:Array})],exports.SchmancyPills.prototype,"data",2),m([o.property({type:String})],exports.SchmancyPills.prototype,"valuePrefix",2),m([o.property({type:String})],exports.SchmancyPills.prototype,"valueSuffix",2),m([o.property({type:Number})],exports.SchmancyPills.prototype,"valueDecimals",2),m([o.property({type:Boolean})],exports.SchmancyPills.prototype,"showMedals",2),m([o.property({type:Boolean})],exports.SchmancyPills.prototype,"showLegend",2),m([o.property({type:Number})],exports.SchmancyPills.prototype,"animationDuration",2),m([o.property({type:Boolean})],exports.SchmancyPills.prototype,"animated",2),m([o.property({type:String})],exports.SchmancyPills.prototype,"labelWidth",2),m([o.property({type:String})],exports.SchmancyPills.prototype,"valueWidth",2),m([o.state()],exports.SchmancyPills.prototype,"animationProgress",2),m([o.state()],exports.SchmancyPills.prototype,"isVisible",2),m([o.state()],exports.SchmancyPills.prototype,"categoryColorMap",2),exports.SchmancyPills=m([o.customElement("schmancy-pills")],exports.SchmancyPills),exports.catmullRomSpline=T,exports.easeOutCubic=L,exports.hexToRgba=w;
113
- //# sourceMappingURL=pills-MmHyBGQu.cjs.map
113
+ //# sourceMappingURL=pills-Blf7IAeq.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"pills-MmHyBGQu.cjs","sources":["../src/charts/utils.ts","../src/charts/area-chart.ts","../src/charts/pills.ts"],"sourcesContent":["/**\n * Catmull-Rom spline interpolation for smooth curves\n * Returns the interpolated point between p1 and p2\n */\nexport function catmullRomSpline(\n\tp0: { x: number; y: number },\n\tp1: { x: number; y: number },\n\tp2: { x: number; y: number },\n\tp3: { x: number; y: number },\n\tt: number\n): { x: number; y: number } {\n\tconst t2 = t * t\n\tconst t3 = t2 * t\n\n\tconst x =\n\t\t0.5 *\n\t\t(2 * p1.x +\n\t\t\t(-p0.x + p2.x) * t +\n\t\t\t(2 * p0.x - 5 * p1.x + 4 * p2.x - p3.x) * t2 +\n\t\t\t(-p0.x + 3 * p1.x - 3 * p2.x + p3.x) * t3)\n\n\tconst y =\n\t\t0.5 *\n\t\t(2 * p1.y +\n\t\t\t(-p0.y + p2.y) * t +\n\t\t\t(2 * p0.y - 5 * p1.y + 4 * p2.y - p3.y) * t2 +\n\t\t\t(-p0.y + 3 * p1.y - 3 * p2.y + p3.y) * t3)\n\n\treturn { x, y }\n}\n\n/**\n * Converts hex or rgb color to rgba string\n */\nexport function hexToRgba(color: string, alpha: number): string {\n\t// Handle rgb/rgba format\n\tif (color.startsWith('rgb')) {\n\t\tconst match = color.match(/[\\d.]+/g)\n\t\tif (match && match.length >= 3) {\n\t\t\treturn `rgba(${match[0]}, ${match[1]}, ${match[2]}, ${alpha})`\n\t\t}\n\t}\n\n\t// Handle hex format\n\tlet hex = color.replace('#', '')\n\tif (hex.length === 3) {\n\t\thex = hex\n\t\t\t.split('')\n\t\t\t.map(c => c + c)\n\t\t\t.join('')\n\t}\n\n\tconst r = parseInt(hex.substring(0, 2), 16)\n\tconst g = parseInt(hex.substring(2, 4), 16)\n\tconst b = parseInt(hex.substring(4, 6), 16)\n\n\treturn `rgba(${r}, ${g}, ${b}, ${alpha})`\n}\n\n/**\n * Cubic ease-out animation function\n */\nexport function easeOutCubic(t: number): number {\n\treturn 1 - Math.pow(1 - t, 3)\n}\n","import { html, css, PropertyValues } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { ref, createRef, Ref } from 'lit/directives/ref.js'\nimport { $LitElement } from '@mixins/index'\nimport type { ChartDataPoint, ChartTheme, ProcessedDataPoint } from './types'\nimport { catmullRomSpline, hexToRgba, easeOutCubic } from './utils'\n\ninterface TooltipData {\n\tvisible: boolean\n\tx: number\n\ty: number\n\tlabel: string\n\tvalue: number\n\tmetadata?: Record<string, unknown>\n}\n\n@customElement('schmancy-area-chart')\nexport class SchmancyAreaChart extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n`) {\n\t/** Chart data points */\n\t@property({ type: Array })\n\tdata: ChartDataPoint[] = []\n\n\t/** Chart height in pixels */\n\t@property({ type: Number })\n\theight = 200\n\n\t/** Show grid lines */\n\t@property({ type: Boolean })\n\tshowGrid = true\n\n\t/** Show x-axis labels */\n\t@property({ type: Boolean })\n\tshowLabels = true\n\n\t/** Enable tooltips */\n\t@property({ type: Boolean })\n\tshowTooltip = true\n\n\t/** Number of peaks to highlight */\n\t@property({ type: Number })\n\tpeakCount = 3\n\n\t/** Animation duration in milliseconds */\n\t@property({ type: Number })\n\tanimationDuration = 800\n\n\t/** Enable entrance animation */\n\t@property({ type: Boolean })\n\tanimated = true\n\n\t/** Prefix for values (e.g., \"EUR \") */\n\t@property({ type: String })\n\tvaluePrefix = ''\n\n\t/** Suffix for values (e.g., \"%\") */\n\t@property({ type: String })\n\tvalueSuffix = ''\n\n\t/** Decimal places for value display */\n\t@property({ type: Number })\n\tvalueDecimals = 2\n\n\t/** Theme overrides */\n\t@property({ type: Object })\n\ttheme: Partial<ChartTheme> = {}\n\n\t@state() private tooltipData: TooltipData = {\n\t\tvisible: false,\n\t\tx: 0,\n\t\ty: 0,\n\t\tlabel: '',\n\t\tvalue: 0,\n\t}\n\n\t@state() private animationProgress = 0\n\t@state() private isVisible = false\n\n\tprivate canvasRef: Ref<HTMLCanvasElement> = createRef()\n\tprivate containerRef: Ref<HTMLDivElement> = createRef()\n\tprivate animationFrameId: number | null = null\n\tprivate observer: IntersectionObserver | null = null\n\tprivate processedData: ProcessedDataPoint[] = []\n\tprivate resizeObserver: ResizeObserver | null = null\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\t\tthis.setupIntersectionObserver()\n\t}\n\n\tdisconnectedCallback() {\n\t\tsuper.disconnectedCallback()\n\t\tthis.cleanup()\n\t}\n\n\tprivate cleanup() {\n\t\tif (this.animationFrameId !== null) {\n\t\t\tcancelAnimationFrame(this.animationFrameId)\n\t\t\tthis.animationFrameId = null\n\t\t}\n\t\tif (this.observer) {\n\t\t\tthis.observer.disconnect()\n\t\t\tthis.observer = null\n\t\t}\n\t\tif (this.resizeObserver) {\n\t\t\tthis.resizeObserver.disconnect()\n\t\t\tthis.resizeObserver = null\n\t\t}\n\t}\n\n\tprivate setupIntersectionObserver() {\n\t\tthis.observer = new IntersectionObserver(\n\t\t\tentries => {\n\t\t\t\tconst entry = entries[0]\n\t\t\t\tif (entry.isIntersecting && !this.isVisible) {\n\t\t\t\t\tthis.isVisible = true\n\t\t\t\t\tif (this.animated) {\n\t\t\t\t\t\tthis.startAnimation()\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.animationProgress = 1\n\t\t\t\t\t\tthis.drawChart()\n\t\t\t\t\t}\n\t\t\t\t} else if (!entry.isIntersecting) {\n\t\t\t\t\tthis.isVisible = false\n\t\t\t\t\tif (this.animationFrameId !== null) {\n\t\t\t\t\t\tcancelAnimationFrame(this.animationFrameId)\n\t\t\t\t\t\tthis.animationFrameId = null\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t\t{ threshold: 0.1 }\n\t\t)\n\t}\n\n\tprotected updated(changedProperties: PropertyValues) {\n\t\tsuper.updated(changedProperties)\n\n\t\tif (this.containerRef.value && this.observer) {\n\t\t\tthis.observer.observe(this.containerRef.value)\n\t\t}\n\n\t\tif (this.canvasRef.value && !this.resizeObserver) {\n\t\t\tthis.resizeObserver = new ResizeObserver(() => {\n\t\t\t\tthis.drawChart()\n\t\t\t})\n\t\t\tthis.resizeObserver.observe(this.canvasRef.value)\n\t\t}\n\n\t\t// Redraw when data changes\n\t\tif (changedProperties.has('data') && this.isVisible) {\n\t\t\tif (this.animated) {\n\t\t\t\tthis.animationProgress = 0\n\t\t\t\tthis.startAnimation()\n\t\t\t} else {\n\t\t\t\tthis.animationProgress = 1\n\t\t\t\tthis.drawChart()\n\t\t\t}\n\t\t}\n\n\t\t// Redraw on theme or config changes\n\t\tif (\n\t\t\t(changedProperties.has('theme') ||\n\t\t\t\tchangedProperties.has('showGrid') ||\n\t\t\t\tchangedProperties.has('showLabels') ||\n\t\t\t\tchangedProperties.has('peakCount')) &&\n\t\t\tthis.isVisible\n\t\t) {\n\t\t\tthis.drawChart()\n\t\t}\n\t}\n\n\tprivate startAnimation() {\n\t\tconst startTime = performance.now()\n\t\tconst duration = this.animationDuration\n\n\t\tconst animateFrame = (currentTime: number) => {\n\t\t\tconst elapsed = currentTime - startTime\n\t\t\tconst progress = Math.min(elapsed / duration, 1)\n\n\t\t\tthis.animationProgress = easeOutCubic(progress)\n\t\t\tthis.drawChart()\n\n\t\t\tif (progress < 1 && this.isVisible) {\n\t\t\t\tthis.animationFrameId = requestAnimationFrame(animateFrame)\n\t\t\t}\n\t\t}\n\n\t\tthis.animationFrameId = requestAnimationFrame(animateFrame)\n\t}\n\n\tprivate processData(): ProcessedDataPoint[] {\n\t\tif (!this.data || this.data.length === 0) return []\n\n\t\t// Find top N peak values\n\t\tconst sortedByValue = [...this.data].sort((a, b) => b.value - a.value)\n\t\tconst peakLabels = new Set(sortedByValue.slice(0, this.peakCount).map(d => d.label))\n\n\t\treturn this.data.map(d => ({\n\t\t\t...d,\n\t\t\tx: 0, // Will be calculated during draw\n\t\t\ty: 0, // Will be calculated during draw\n\t\t\tisPeak: peakLabels.has(d.label),\n\t\t}))\n\t}\n\n\tprivate getThemeValue<K extends keyof ChartTheme>(\n\t\tkey: K,\n\t\tdefaultValue: NonNullable<ChartTheme[K]>\n\t): NonNullable<ChartTheme[K]> {\n\t\treturn (this.theme[key] as NonNullable<ChartTheme[K]>) ?? defaultValue\n\t}\n\n\tprivate drawChart() {\n\t\tconst canvas = this.canvasRef.value\n\t\tif (!canvas) return\n\n\t\tconst ctx = canvas.getContext('2d')\n\t\tif (!ctx) return\n\n\t\tconst dpr = window.devicePixelRatio || 1\n\t\tconst rect = canvas.getBoundingClientRect()\n\t\tconst width = rect.width\n\t\tconst height = rect.height\n\n\t\t// Set canvas size for high DPI\n\t\tcanvas.width = width * dpr\n\t\tcanvas.height = height * dpr\n\t\tctx.scale(dpr, dpr)\n\n\t\t// Clear canvas\n\t\tctx.clearRect(0, 0, width, height)\n\n\t\tconst data = this.processData()\n\t\tif (data.length === 0) return\n\n\t\tconst padding = { top: 20, right: 20, bottom: this.showLabels ? 40 : 20, left: 20 }\n\t\tconst chartWidth = width - padding.left - padding.right\n\t\tconst chartHeight = height - padding.top - padding.bottom\n\n\t\t// Find max value for scaling\n\t\tconst maxValue = Math.max(...data.map(d => d.value), 1)\n\n\t\t// Calculate positions\n\t\tconst points = data.map((d, i) => ({\n\t\t\t...d,\n\t\t\tx: padding.left + (data.length > 1 ? (i / (data.length - 1)) * chartWidth : chartWidth / 2),\n\t\t\ty: padding.top + chartHeight - (d.value / maxValue) * chartHeight,\n\t\t}))\n\n\t\tthis.processedData = points\n\n\t\t// Get primary color from CSS or theme\n\t\tconst computedStyle = getComputedStyle(this)\n\t\tconst defaultPrimaryColor =\n\t\t\tcomputedStyle.getPropertyValue('--schmancy-sys-color-primary').trim() || '#6750A4'\n\t\tconst primaryColor = this.getThemeValue('primaryColor', defaultPrimaryColor)\n\t\tconst [gradientOpacityTop, gradientOpacityBottom] = this.getThemeValue('gradientOpacity', [0.4, 0.05])\n\t\tconst strokeWidth = this.getThemeValue('strokeWidth', 2)\n\t\tconst pointRadius = this.getThemeValue('pointRadius', 4)\n\t\tconst peakRadius = this.getThemeValue('peakRadius', 6)\n\n\t\t// Draw grid lines\n\t\tif (this.showGrid) {\n\t\t\tctx.strokeStyle = 'rgba(128, 128, 128, 0.15)'\n\t\t\tctx.lineWidth = 1\n\t\t\tctx.setLineDash([4, 4])\n\n\t\t\tfor (let i = 1; i <= 3; i++) {\n\t\t\t\tconst y = padding.top + (chartHeight * i) / 4\n\t\t\t\tctx.beginPath()\n\t\t\t\tctx.moveTo(padding.left, y)\n\t\t\t\tctx.lineTo(width - padding.right, y)\n\t\t\t\tctx.stroke()\n\t\t\t}\n\n\t\t\tctx.setLineDash([])\n\t\t}\n\n\t\t// Create smooth curve path using Catmull-Rom spline\n\t\tconst curvePath = new Path2D()\n\t\tconst areaPath = new Path2D()\n\n\t\tif (points.length >= 2) {\n\t\t\t// Start area path from bottom left\n\t\t\tareaPath.moveTo(points[0].x, padding.top + chartHeight)\n\t\t\tcurvePath.moveTo(points[0].x, points[0].y)\n\t\t\tareaPath.lineTo(points[0].x, points[0].y)\n\n\t\t\tfor (let i = 0; i < points.length - 1; i++) {\n\t\t\t\tconst p0 = points[Math.max(0, i - 1)]\n\t\t\t\tconst p1 = points[i]\n\t\t\t\tconst p2 = points[Math.min(points.length - 1, i + 1)]\n\t\t\t\tconst p3 = points[Math.min(points.length - 1, i + 2)]\n\n\t\t\t\t// Draw curve segments\n\t\t\t\tconst segments = 16\n\t\t\t\tfor (let j = 1; j <= segments; j++) {\n\t\t\t\t\tconst t = j / segments\n\t\t\t\t\tconst point = catmullRomSpline(p0, p1, p2, p3, t)\n\t\t\t\t\tcurvePath.lineTo(point.x, point.y)\n\t\t\t\t\tareaPath.lineTo(point.x, point.y)\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Close area path\n\t\t\tareaPath.lineTo(points[points.length - 1].x, padding.top + chartHeight)\n\t\t\tareaPath.closePath()\n\t\t} else if (points.length === 1) {\n\t\t\t// Single point - draw a dot\n\t\t\tcurvePath.arc(points[0].x, points[0].y, pointRadius, 0, Math.PI * 2)\n\t\t}\n\n\t\t// Apply animation clipping\n\t\tctx.save()\n\t\tctx.beginPath()\n\t\tctx.rect(0, 0, padding.left + chartWidth * this.animationProgress, height)\n\t\tctx.clip()\n\n\t\t// Draw gradient fill\n\t\tif (points.length >= 2) {\n\t\t\tconst gradient = ctx.createLinearGradient(0, padding.top, 0, padding.top + chartHeight)\n\t\t\tgradient.addColorStop(0, hexToRgba(primaryColor, gradientOpacityTop))\n\t\t\tgradient.addColorStop(1, hexToRgba(primaryColor, gradientOpacityBottom))\n\n\t\t\tctx.fillStyle = gradient\n\t\t\tctx.fill(areaPath)\n\t\t}\n\n\t\t// Draw stroke\n\t\tctx.strokeStyle = primaryColor\n\t\tctx.lineWidth = strokeWidth\n\t\tctx.lineCap = 'round'\n\t\tctx.lineJoin = 'round'\n\t\tctx.stroke(curvePath)\n\n\t\t// Draw data points\n\t\tpoints.forEach((point, index) => {\n\t\t\tconst pointProgress = (index / (points.length - 1 || 1)) * this.animationProgress\n\t\t\tif (pointProgress < index / (points.length || 1)) return\n\n\t\t\tconst radius = point.isPeak ? peakRadius - 1 : pointRadius - 1\n\t\t\tconst outerRadius = point.isPeak ? peakRadius + 4 : pointRadius + 2\n\n\t\t\t// Outer glow for peaks\n\t\t\tif (point.isPeak) {\n\t\t\t\tctx.beginPath()\n\t\t\t\tctx.arc(point.x, point.y, outerRadius, 0, Math.PI * 2)\n\t\t\t\tctx.fillStyle = hexToRgba(primaryColor, 0.2)\n\t\t\t\tctx.fill()\n\t\t\t}\n\n\t\t\t// Inner dot\n\t\t\tctx.beginPath()\n\t\t\tctx.arc(point.x, point.y, radius, 0, Math.PI * 2)\n\t\t\tctx.fillStyle = primaryColor\n\t\t\tctx.fill()\n\n\t\t\t// White center for peaks\n\t\t\tif (point.isPeak) {\n\t\t\t\tctx.beginPath()\n\t\t\t\tctx.arc(point.x, point.y, 2, 0, Math.PI * 2)\n\t\t\t\tctx.fillStyle = 'white'\n\t\t\t\tctx.fill()\n\t\t\t}\n\t\t})\n\n\t\tctx.restore()\n\n\t\t// Draw labels\n\t\tif (this.showLabels && points.length > 0) {\n\t\t\tctx.fillStyle = 'rgba(128, 128, 128, 0.8)'\n\t\t\tctx.font = '11px system-ui, sans-serif'\n\t\t\tctx.textAlign = 'center'\n\t\t\tctx.textBaseline = 'top'\n\n\t\t\t// Show fewer labels on narrow charts\n\t\t\tconst labelStep = width < 400 ? 3 : width < 600 ? 2 : 1\n\t\t\tpoints.forEach((point, index) => {\n\t\t\t\tif (index % labelStep === 0) {\n\t\t\t\t\tctx.fillText(point.label, point.x, height - padding.bottom + 8)\n\t\t\t\t}\n\t\t\t})\n\t\t}\n\t}\n\n\tprivate formatValue(value: number): string {\n\t\tconst formatted = value.toFixed(this.valueDecimals)\n\t\treturn `${this.valuePrefix}${formatted}${this.valueSuffix}`\n\t}\n\n\tprivate handlePointerMove = (e: PointerEvent) => {\n\t\tif (this.processedData.length === 0 || !this.showTooltip) return\n\n\t\tconst canvas = this.canvasRef.value\n\t\tif (!canvas) return\n\n\t\tconst rect = canvas.getBoundingClientRect()\n\t\tconst x = e.clientX - rect.left\n\n\t\t// Find closest data point\n\t\tlet closestPoint: ProcessedDataPoint | null = null\n\t\tlet minDistance = Infinity\n\n\t\tthis.processedData.forEach(point => {\n\t\t\tconst distance = Math.abs(point.x - x)\n\t\t\tif (distance < minDistance) {\n\t\t\t\tminDistance = distance\n\t\t\t\tclosestPoint = point\n\t\t\t}\n\t\t})\n\n\t\tif (closestPoint && minDistance < 30) {\n\t\t\tthis.tooltipData = {\n\t\t\t\tvisible: true,\n\t\t\t\tx: closestPoint.x,\n\t\t\t\ty: closestPoint.y,\n\t\t\t\tlabel: closestPoint.label,\n\t\t\t\tvalue: closestPoint.value,\n\t\t\t\tmetadata: closestPoint.metadata,\n\t\t\t}\n\t\t} else {\n\t\t\tthis.tooltipData = { ...this.tooltipData, visible: false }\n\t\t}\n\t}\n\n\tprivate handlePointerLeave = () => {\n\t\tthis.tooltipData = { ...this.tooltipData, visible: false }\n\t}\n\n\tprivate renderMetadata() {\n\t\tif (!this.tooltipData.metadata) return ''\n\t\treturn Object.entries(this.tooltipData.metadata).map(\n\t\t\t([key, value]) => html`\n\t\t\t\t<schmancy-typography type=\"body\" token=\"sm\" class=\"text-surface-onVariant\">\n\t\t\t\t\t${key}: ${String(value)}\n\t\t\t\t</schmancy-typography>\n\t\t\t`\n\t\t)\n\t}\n\n\trender() {\n\t\tif (!this.data || this.data.length === 0) {\n\t\t\treturn html``\n\t\t}\n\n\t\treturn html`\n\t\t\t<div ${ref(this.containerRef)} class=\"relative\">\n\t\t\t\t<div class=\"relative\" style=\"height: ${this.height}px; touch-action: pan-y;\">\n\t\t\t\t\t<canvas\n\t\t\t\t\t\t${ref(this.canvasRef)}\n\t\t\t\t\t\tclass=\"w-full h-full\"\n\t\t\t\t\t\tstyle=\"display: block;\"\n\t\t\t\t\t\t@pointermove=${this.handlePointerMove}\n\t\t\t\t\t\t@pointerleave=${this.handlePointerLeave}\n\t\t\t\t\t></canvas>\n\n\t\t\t\t\t<!-- Tooltip -->\n\t\t\t\t\t${this.showTooltip\n\t\t\t\t\t\t? html`\n\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\tclass=\"absolute pointer-events-none transition-opacity duration-150 ${this.tooltipData.visible\n\t\t\t\t\t\t\t\t\t\t? 'opacity-100'\n\t\t\t\t\t\t\t\t\t\t: 'opacity-0'}\"\n\t\t\t\t\t\t\t\t\tstyle=\"\n left: ${this.tooltipData.x}px;\n top: ${this.tooltipData.y - 60}px;\n transform: translateX(-50%);\n \"\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t<schmancy-surface elevation=\"3\" rounded=\"all\" class=\"px-3 py-2 min-w-max\">\n\t\t\t\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"sm\" class=\"text-surface-onVariant\">\n\t\t\t\t\t\t\t\t\t\t\t${this.tooltipData.label}\n\t\t\t\t\t\t\t\t\t\t</schmancy-typography>\n\t\t\t\t\t\t\t\t\t\t<schmancy-typography type=\"title\" token=\"md\" class=\"text-surface-on font-semibold\">\n\t\t\t\t\t\t\t\t\t\t\t${this.formatValue(this.tooltipData.value)}\n\t\t\t\t\t\t\t\t\t\t</schmancy-typography>\n\t\t\t\t\t\t\t\t\t\t${this.renderMetadata()}\n\t\t\t\t\t\t\t\t\t</schmancy-surface>\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t `\n\t\t\t\t\t\t: ''}\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-area-chart': SchmancyAreaChart\n\t}\n}\n","import { html, css, PropertyValues } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { repeat } from 'lit/directives/repeat.js'\nimport { $LitElement } from '@mixins/index'\nimport type { PillDataPoint, PillSegment } from './types'\n\n/** Default color palette for segments - expanded for uniqueness */\nconst DEFAULT_COLORS = [\n\t'bg-primary',\n\t'bg-secondary',\n\t'bg-tertiary',\n\t'bg-success',\n\t'bg-warning',\n\t'bg-error',\n\t'bg-primary/70',\n\t'bg-secondary/70',\n\t'bg-tertiary/70',\n\t'bg-success/70',\n\t'bg-warning/70',\n\t'bg-error/70',\n\t'bg-primary/40',\n\t'bg-secondary/40',\n\t'bg-tertiary/40',\n]\n\n@customElement('schmancy-pills')\nexport class SchmancyPills extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n`) {\n\t/** Chart data points */\n\t@property({ type: Array })\n\tdata: PillDataPoint[] = []\n\n\t/** Prefix for values (e.g., \"EUR \") */\n\t@property({ type: String })\n\tvaluePrefix = ''\n\n\t/** Suffix for values (e.g., \"%\") */\n\t@property({ type: String })\n\tvalueSuffix = ''\n\n\t/** Decimal places for value display */\n\t@property({ type: Number })\n\tvalueDecimals = 2\n\n\t/** Show medals for top 3 */\n\t@property({ type: Boolean })\n\tshowMedals = true\n\n\t/** Show legend for segments */\n\t@property({ type: Boolean })\n\tshowLegend = true\n\n\t/** Animation duration in milliseconds */\n\t@property({ type: Number })\n\tanimationDuration = 500\n\n\t/** Enable entrance animation */\n\t@property({ type: Boolean })\n\tanimated = true\n\n\t/** Label column width (Tailwind class) */\n\t@property({ type: String })\n\tlabelWidth = 'w-14'\n\n\t/** Value column width (Tailwind class) */\n\t@property({ type: String })\n\tvalueWidth = 'w-20'\n\n\t@state() private animationProgress = 0\n\t@state() private isVisible = false\n\t@state() private categoryColorMap = new Map<string, string>()\n\n\tprivate observer: IntersectionObserver | null = null\n\tprivate animationFrameId: number | null = null\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\t\tthis.setupIntersectionObserver()\n\t}\n\n\tdisconnectedCallback() {\n\t\tsuper.disconnectedCallback()\n\t\tthis.cleanup()\n\t}\n\n\tprivate cleanup() {\n\t\tif (this.animationFrameId !== null) {\n\t\t\tcancelAnimationFrame(this.animationFrameId)\n\t\t\tthis.animationFrameId = null\n\t\t}\n\t\tif (this.observer) {\n\t\t\tthis.observer.disconnect()\n\t\t\tthis.observer = null\n\t\t}\n\t}\n\n\tprivate setupIntersectionObserver() {\n\t\tthis.observer = new IntersectionObserver(\n\t\t\tentries => {\n\t\t\t\tconst entry = entries[0]\n\t\t\t\tif (entry.isIntersecting && !this.isVisible) {\n\t\t\t\t\tthis.isVisible = true\n\t\t\t\t\tif (this.animated) {\n\t\t\t\t\t\tthis.startAnimation()\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.animationProgress = 1\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t\t{ threshold: 0.1 }\n\t\t)\n\t}\n\n\tprotected firstUpdated() {\n\t\tif (this.observer) {\n\t\t\tthis.observer.observe(this)\n\t\t}\n\t}\n\n\tprotected updated(changedProperties: PropertyValues) {\n\t\tsuper.updated(changedProperties)\n\n\t\t// Restart animation when data changes\n\t\tif (changedProperties.has('data') && this.isVisible && this.animated) {\n\t\t\tthis.animationProgress = 0\n\t\t\tthis.startAnimation()\n\t\t}\n\t}\n\n\tprivate startAnimation() {\n\t\tconst startTime = performance.now()\n\t\tconst duration = this.animationDuration\n\n\t\tconst animateFrame = (currentTime: number) => {\n\t\t\tconst elapsed = currentTime - startTime\n\t\t\tconst progress = Math.min(elapsed / duration, 1)\n\n\t\t\t// Ease out cubic\n\t\t\tthis.animationProgress = 1 - Math.pow(1 - progress, 3)\n\n\t\t\tif (progress < 1 && this.isVisible) {\n\t\t\t\tthis.animationFrameId = requestAnimationFrame(animateFrame)\n\t\t\t}\n\t\t}\n\n\t\tthis.animationFrameId = requestAnimationFrame(animateFrame)\n\t}\n\n\tprivate initializeCategoryColors(): void {\n\t\t// Build consistent color map from all segments in data\n\t\tconst categoryTotals = new Map<string, number>()\n\t\tconst explicitColors = new Map<string, string>()\n\n\t\tthis.data.forEach(d => {\n\t\t\tif (d.segments) {\n\t\t\t\td.segments.forEach(seg => {\n\t\t\t\t\tcategoryTotals.set(seg.label, (categoryTotals.get(seg.label) || 0) + seg.value)\n\t\t\t\t\t// Capture explicit colors from segments\n\t\t\t\t\tif (seg.color && !explicitColors.has(seg.label)) {\n\t\t\t\t\t\texplicitColors.set(seg.label, seg.color)\n\t\t\t\t\t}\n\t\t\t\t})\n\t\t\t}\n\t\t})\n\n\t\t// Sort by total value (most = first color)\n\t\tconst sortedCategories = Array.from(categoryTotals.entries())\n\t\t\t.sort((a, b) => b[1] - a[1])\n\t\t\t.map(([cat]) => cat)\n\n\t\t// Clear and rebuild - use explicit colors if available, otherwise default palette\n\t\tthis.categoryColorMap.clear()\n\t\tlet defaultColorIndex = 0\n\t\tsortedCategories.forEach(cat => {\n\t\t\tif (explicitColors.has(cat)) {\n\t\t\t\tthis.categoryColorMap.set(cat, explicitColors.get(cat)!)\n\t\t\t} else {\n\t\t\t\tthis.categoryColorMap.set(cat, DEFAULT_COLORS[defaultColorIndex % DEFAULT_COLORS.length])\n\t\t\t\tdefaultColorIndex++\n\t\t\t}\n\t\t})\n\t}\n\n\tprivate getSegmentColor(segment: PillSegment): string {\n\t\t// Use explicit color if provided\n\t\tif (segment.color) return segment.color\n\t\t// Otherwise use from color map\n\t\treturn this.categoryColorMap.get(segment.label) || 'bg-primary'\n\t}\n\n\tprivate formatValue(value: number): string {\n\t\tconst formatted = value.toFixed(this.valueDecimals)\n\t\treturn `${this.valuePrefix}${formatted}${this.valueSuffix}`\n\t}\n\n\tprivate getMedalEmoji(rank: number | undefined): string {\n\t\tif (!this.showMedals || !rank) return ''\n\t\tif (rank === 1) return '🥇'\n\t\tif (rank === 2) return '🥈'\n\t\tif (rank === 3) return '🥉'\n\t\treturn ''\n\t}\n\n\tprivate getMaxValue(): number {\n\t\tif (this.data.length === 0) return 0\n\t\treturn Math.max(...this.data.map(d => d.value), 1)\n\t}\n\n\tprivate renderBar(dataPoint: PillDataPoint, maxValue: number): ReturnType<typeof html> {\n\t\tconst percentage = maxValue > 0 ? (dataPoint.value / maxValue) * 100 : 0\n\t\tconst animatedPercentage = percentage * this.animationProgress\n\n\t\t// If no segments, render solid bar\n\t\tif (!dataPoint.segments || dataPoint.segments.length === 0) {\n\t\t\tconst barColorClass = dataPoint.isPeak\n\t\t\t\t? 'bg-success'\n\t\t\t\t: dataPoint.isLow\n\t\t\t\t\t? 'bg-tertiary opacity-70'\n\t\t\t\t\t: dataPoint.value === 0\n\t\t\t\t\t\t? 'bg-tertiary/40'\n\t\t\t\t\t\t: 'bg-primary'\n\n\t\t\treturn html`\n\t\t\t\t<div\n\t\t\t\t\tclass=\"${barColorClass} h-full transition-all rounded-full\"\n\t\t\t\t\tstyle=\"width: ${Math.max(animatedPercentage, dataPoint.value > 0 ? 2 : 0)}%; transition-duration: ${this.animated ? '0ms' : '300ms'}\"\n\t\t\t\t\ttitle=\"${this.formatValue(dataPoint.value)}\"\n\t\t\t\t></div>\n\t\t\t`\n\t\t}\n\n\t\t// Stacked bar with segments\n\t\treturn html`\n\t\t\t<div\n\t\t\t\tclass=\"h-full flex\"\n\t\t\t\tstyle=\"width: ${Math.max(animatedPercentage, 2)}%; transition-duration: ${this.animated ? '0ms' : '300ms'}\"\n\t\t\t>\n\t\t\t\t${repeat(\n\t\t\t\t\tdataPoint.segments,\n\t\t\t\t\tseg => seg.label,\n\t\t\t\t\t(seg, index) => {\n\t\t\t\t\t\tconst segmentPercentage = dataPoint.value > 0 ? (seg.value / dataPoint.value) * 100 : 0\n\t\t\t\t\t\tconst marginLeft = index > 0 ? 'ml-px' : ''\n\t\t\t\t\t\tconst brightenClass = dataPoint.isPeak ? 'brightness-110' : ''\n\t\t\t\t\t\tconst colorClass = this.getSegmentColor(seg)\n\n\t\t\t\t\t\treturn html`\n\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\tclass=\"${colorClass} ${marginLeft} ${brightenClass} h-full transition-all\n\t\t\t\t\t\t\t\t\t${index === 0 ? 'rounded-l-full' : ''}\n\t\t\t\t\t\t\t\t\t${index === dataPoint.segments!.length - 1 ? 'rounded-r-full' : ''}\"\n\t\t\t\t\t\t\t\tstyle=\"width: ${segmentPercentage}%\"\n\t\t\t\t\t\t\t\ttitle=\"${seg.label}: ${this.formatValue(seg.value)}\"\n\t\t\t\t\t\t\t></div>\n\t\t\t\t\t\t`\n\t\t\t\t\t}\n\t\t\t\t)}\n\t\t\t</div>\n\t\t`\n\t}\n\n\tprivate renderLegend(): ReturnType<typeof html> {\n\t\tif (!this.showLegend || this.categoryColorMap.size === 0) {\n\t\t\treturn html``\n\t\t}\n\n\t\treturn html`\n\t\t\t<div class=\"flex flex-wrap gap-3 mt-4 pt-4 border-t border-outline-variant\">\n\t\t\t\t${repeat(\n\t\t\t\t\tArray.from(this.categoryColorMap.entries()),\n\t\t\t\t\t([cat]) => cat,\n\t\t\t\t\t([cat, color]) => html`\n\t\t\t\t\t\t<div class=\"flex items-center gap-1.5\">\n\t\t\t\t\t\t\t<div class=\"${color} w-3 h-3 rounded-sm\"></div>\n\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"sm\" class=\"text-surface-onVariant\">\n\t\t\t\t\t\t\t\t${cat}\n\t\t\t\t\t\t\t</schmancy-typography>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t`\n\t\t\t\t)}\n\t\t\t</div>\n\t\t`\n\t}\n\n\trender() {\n\t\t// Initialize colors before rendering\n\t\tthis.initializeCategoryColors()\n\n\t\tif (!this.data || this.data.length === 0) {\n\t\t\treturn html``\n\t\t}\n\n\t\tconst maxValue = this.getMaxValue()\n\n\t\treturn html`\n\t\t\t<div class=\"space-y-1\">\n\t\t\t\t${repeat(\n\t\t\t\t\tthis.data,\n\t\t\t\t\td => d.label,\n\t\t\t\t\td => {\n\t\t\t\t\t\tconst rowBgClass = d.isPeak ? 'bg-success/10 rounded-lg' : ''\n\t\t\t\t\t\tconst textColorClass = d.isPeak ? 'text-success font-bold' : 'text-surface-on'\n\n\t\t\t\t\t\treturn html`\n\t\t\t\t\t\t\t<div class=\"flex items-center gap-3 py-2 px-2 ${rowBgClass}\">\n\t\t\t\t\t\t\t\t<!-- Label -->\n\t\t\t\t\t\t\t\t<div class=\"${this.labelWidth} shrink-0 text-right\">\n\t\t\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"md\" class=\"${textColorClass}\">\n\t\t\t\t\t\t\t\t\t\t${d.label}\n\t\t\t\t\t\t\t\t\t</schmancy-typography>\n\t\t\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t\t\t<!-- Medal -->\n\t\t\t\t\t\t\t\t<div class=\"w-6 shrink-0 text-center\">\n\t\t\t\t\t\t\t\t\t${d.isPeak || (d.rank && d.rank <= 3)\n\t\t\t\t\t\t\t\t\t\t? html`<span class=\"text-sm\">${this.getMedalEmoji(d.rank)}</span>`\n\t\t\t\t\t\t\t\t\t\t: ''}\n\t\t\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t\t\t<!-- Bar -->\n\t\t\t\t\t\t\t\t<div class=\"flex-1 h-6 bg-secondary/15 rounded-full overflow-hidden\">\n\t\t\t\t\t\t\t\t\t${this.renderBar(d, maxValue)}\n\t\t\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t\t\t<!-- Value -->\n\t\t\t\t\t\t\t\t<div class=\"${this.valueWidth} shrink-0 text-right\">\n\t\t\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"md\" class=\"${textColorClass}\">\n\t\t\t\t\t\t\t\t\t\t${this.formatValue(d.value)}\n\t\t\t\t\t\t\t\t\t</schmancy-typography>\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t`\n\t\t\t\t\t}\n\t\t\t\t)}\n\t\t\t</div>\n\n\t\t\t<!-- Legend -->\n\t\t\t${this.renderLegend()}\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-pills': SchmancyPills\n\t}\n}\n"],"names":["catmullRomSpline","p0","p1","p2","p3","t","t2","t3","x","y","hexToRgba","color","alpha","startsWith","match","length","hex","replace","split","map","c","join","parseInt","substring","easeOutCubic","Math","pow","SchmancyAreaChart","$LitElement","css","constructor","super","arguments","this","data","height","showGrid","showLabels","showTooltip","peakCount","animationDuration","animated","valuePrefix","valueSuffix","valueDecimals","theme","tooltipData","visible","label","value","animationProgress","isVisible","canvasRef","createRef","containerRef","animationFrameId","observer","processedData","resizeObserver","handlePointerMove","e","canvas","rect","getBoundingClientRect","clientX","left","closestPoint","minDistance","Infinity","forEach","point","distance","abs","metadata","handlePointerLeave","connectedCallback","setupIntersectionObserver","disconnectedCallback","cleanup","cancelAnimationFrame","disconnect","IntersectionObserver","entries","entry","isIntersecting","startAnimation","drawChart","threshold","changedProperties","updated","observe","ResizeObserver","has","startTime","performance","now","duration","animateFrame","currentTime","elapsed","progress","min","requestAnimationFrame","processData","sortedByValue","sort","a","b","peakLabels","Set","slice","d","isPeak","key","defaultValue","ctx","getContext","dpr","window","devicePixelRatio","width","scale","clearRect","padding","chartWidth","chartHeight","maxValue","max","points","i","defaultPrimaryColor","getComputedStyle","getPropertyValue","trim","primaryColor","getThemeValue","gradientOpacityTop","gradientOpacityBottom","strokeWidth","pointRadius","peakRadius","strokeStyle","lineWidth","setLineDash","beginPath","moveTo","lineTo","stroke","curvePath","Path2D","areaPath","segments","j","closePath","arc","PI","save","clip","gradient","createLinearGradient","addColorStop","fillStyle","fill","lineCap","lineJoin","index","radius","outerRadius","restore","font","textAlign","textBaseline","labelStep","fillText","formatted","toFixed","renderMetadata","Object","html","String","render","ref","formatValue","__decorateClass","property","type","Array","prototype","Number","Boolean","state","customElement","DEFAULT_COLORS","SchmancyPills","showMedals","showLegend","labelWidth","valueWidth","categoryColorMap","Map","firstUpdated","initializeCategoryColors","categoryTotals","explicitColors","seg","set","get","sortedCategories","from","cat","clear","defaultColorIndex","segment","rank","dataPoint","animatedPercentage","barColorClass","isLow","repeat","segmentPercentage","marginLeft","brightenClass","colorClass","getSegmentColor","renderLegend","size","getMaxValue","rowBgClass","textColorClass","getMedalEmoji","renderBar"],"mappings":"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"}
1
+ {"version":3,"file":"pills-Blf7IAeq.cjs","sources":["../src/charts/utils.ts","../src/charts/area-chart.ts","../src/charts/pills.ts"],"sourcesContent":["/**\n * Catmull-Rom spline interpolation for smooth curves\n * Returns the interpolated point between p1 and p2\n */\nexport function catmullRomSpline(\n\tp0: { x: number; y: number },\n\tp1: { x: number; y: number },\n\tp2: { x: number; y: number },\n\tp3: { x: number; y: number },\n\tt: number\n): { x: number; y: number } {\n\tconst t2 = t * t\n\tconst t3 = t2 * t\n\n\tconst x =\n\t\t0.5 *\n\t\t(2 * p1.x +\n\t\t\t(-p0.x + p2.x) * t +\n\t\t\t(2 * p0.x - 5 * p1.x + 4 * p2.x - p3.x) * t2 +\n\t\t\t(-p0.x + 3 * p1.x - 3 * p2.x + p3.x) * t3)\n\n\tconst y =\n\t\t0.5 *\n\t\t(2 * p1.y +\n\t\t\t(-p0.y + p2.y) * t +\n\t\t\t(2 * p0.y - 5 * p1.y + 4 * p2.y - p3.y) * t2 +\n\t\t\t(-p0.y + 3 * p1.y - 3 * p2.y + p3.y) * t3)\n\n\treturn { x, y }\n}\n\n/**\n * Converts hex or rgb color to rgba string\n */\nexport function hexToRgba(color: string, alpha: number): string {\n\t// Handle rgb/rgba format\n\tif (color.startsWith('rgb')) {\n\t\tconst match = color.match(/[\\d.]+/g)\n\t\tif (match && match.length >= 3) {\n\t\t\treturn `rgba(${match[0]}, ${match[1]}, ${match[2]}, ${alpha})`\n\t\t}\n\t}\n\n\t// Handle hex format\n\tlet hex = color.replace('#', '')\n\tif (hex.length === 3) {\n\t\thex = hex\n\t\t\t.split('')\n\t\t\t.map(c => c + c)\n\t\t\t.join('')\n\t}\n\n\tconst r = parseInt(hex.substring(0, 2), 16)\n\tconst g = parseInt(hex.substring(2, 4), 16)\n\tconst b = parseInt(hex.substring(4, 6), 16)\n\n\treturn `rgba(${r}, ${g}, ${b}, ${alpha})`\n}\n\n/**\n * Cubic ease-out animation function\n */\nexport function easeOutCubic(t: number): number {\n\treturn 1 - Math.pow(1 - t, 3)\n}\n","import { html, css, PropertyValues } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { ref, createRef, Ref } from 'lit/directives/ref.js'\nimport { $LitElement } from '@mixins/index'\nimport type { ChartDataPoint, ChartTheme, ProcessedDataPoint } from './types'\nimport { catmullRomSpline, hexToRgba, easeOutCubic } from './utils'\n\ninterface TooltipData {\n\tvisible: boolean\n\tx: number\n\ty: number\n\tlabel: string\n\tvalue: number\n\tmetadata?: Record<string, unknown>\n}\n\n@customElement('schmancy-area-chart')\nexport class SchmancyAreaChart extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n`) {\n\t/** Chart data points */\n\t@property({ type: Array })\n\tdata: ChartDataPoint[] = []\n\n\t/** Chart height in pixels */\n\t@property({ type: Number })\n\theight = 200\n\n\t/** Show grid lines */\n\t@property({ type: Boolean })\n\tshowGrid = true\n\n\t/** Show x-axis labels */\n\t@property({ type: Boolean })\n\tshowLabels = true\n\n\t/** Enable tooltips */\n\t@property({ type: Boolean })\n\tshowTooltip = true\n\n\t/** Number of peaks to highlight */\n\t@property({ type: Number })\n\tpeakCount = 3\n\n\t/** Animation duration in milliseconds */\n\t@property({ type: Number })\n\tanimationDuration = 800\n\n\t/** Enable entrance animation */\n\t@property({ type: Boolean })\n\tanimated = true\n\n\t/** Prefix for values (e.g., \"EUR \") */\n\t@property({ type: String })\n\tvaluePrefix = ''\n\n\t/** Suffix for values (e.g., \"%\") */\n\t@property({ type: String })\n\tvalueSuffix = ''\n\n\t/** Decimal places for value display */\n\t@property({ type: Number })\n\tvalueDecimals = 2\n\n\t/** Theme overrides */\n\t@property({ type: Object })\n\ttheme: Partial<ChartTheme> = {}\n\n\t@state() private tooltipData: TooltipData = {\n\t\tvisible: false,\n\t\tx: 0,\n\t\ty: 0,\n\t\tlabel: '',\n\t\tvalue: 0,\n\t}\n\n\t@state() private animationProgress = 0\n\t@state() private isVisible = false\n\n\tprivate canvasRef: Ref<HTMLCanvasElement> = createRef()\n\tprivate containerRef: Ref<HTMLDivElement> = createRef()\n\tprivate animationFrameId: number | null = null\n\tprivate observer: IntersectionObserver | null = null\n\tprivate processedData: ProcessedDataPoint[] = []\n\tprivate resizeObserver: ResizeObserver | null = null\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\t\tthis.setupIntersectionObserver()\n\t}\n\n\tdisconnectedCallback() {\n\t\tsuper.disconnectedCallback()\n\t\tthis.cleanup()\n\t}\n\n\tprivate cleanup() {\n\t\tif (this.animationFrameId !== null) {\n\t\t\tcancelAnimationFrame(this.animationFrameId)\n\t\t\tthis.animationFrameId = null\n\t\t}\n\t\tif (this.observer) {\n\t\t\tthis.observer.disconnect()\n\t\t\tthis.observer = null\n\t\t}\n\t\tif (this.resizeObserver) {\n\t\t\tthis.resizeObserver.disconnect()\n\t\t\tthis.resizeObserver = null\n\t\t}\n\t}\n\n\tprivate setupIntersectionObserver() {\n\t\tthis.observer = new IntersectionObserver(\n\t\t\tentries => {\n\t\t\t\tconst entry = entries[0]\n\t\t\t\tif (entry.isIntersecting && !this.isVisible) {\n\t\t\t\t\tthis.isVisible = true\n\t\t\t\t\tif (this.animated) {\n\t\t\t\t\t\tthis.startAnimation()\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.animationProgress = 1\n\t\t\t\t\t\tthis.drawChart()\n\t\t\t\t\t}\n\t\t\t\t} else if (!entry.isIntersecting) {\n\t\t\t\t\tthis.isVisible = false\n\t\t\t\t\tif (this.animationFrameId !== null) {\n\t\t\t\t\t\tcancelAnimationFrame(this.animationFrameId)\n\t\t\t\t\t\tthis.animationFrameId = null\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t\t{ threshold: 0.1 }\n\t\t)\n\t}\n\n\tprotected updated(changedProperties: PropertyValues) {\n\t\tsuper.updated(changedProperties)\n\n\t\tif (this.containerRef.value && this.observer) {\n\t\t\tthis.observer.observe(this.containerRef.value)\n\t\t}\n\n\t\tif (this.canvasRef.value && !this.resizeObserver) {\n\t\t\tthis.resizeObserver = new ResizeObserver(() => {\n\t\t\t\tthis.drawChart()\n\t\t\t})\n\t\t\tthis.resizeObserver.observe(this.canvasRef.value)\n\t\t}\n\n\t\t// Redraw when data changes\n\t\tif (changedProperties.has('data') && this.isVisible) {\n\t\t\tif (this.animated) {\n\t\t\t\tthis.animationProgress = 0\n\t\t\t\tthis.startAnimation()\n\t\t\t} else {\n\t\t\t\tthis.animationProgress = 1\n\t\t\t\tthis.drawChart()\n\t\t\t}\n\t\t}\n\n\t\t// Redraw on theme or config changes\n\t\tif (\n\t\t\t(changedProperties.has('theme') ||\n\t\t\t\tchangedProperties.has('showGrid') ||\n\t\t\t\tchangedProperties.has('showLabels') ||\n\t\t\t\tchangedProperties.has('peakCount')) &&\n\t\t\tthis.isVisible\n\t\t) {\n\t\t\tthis.drawChart()\n\t\t}\n\t}\n\n\tprivate startAnimation() {\n\t\tconst startTime = performance.now()\n\t\tconst duration = this.animationDuration\n\n\t\tconst animateFrame = (currentTime: number) => {\n\t\t\tconst elapsed = currentTime - startTime\n\t\t\tconst progress = Math.min(elapsed / duration, 1)\n\n\t\t\tthis.animationProgress = easeOutCubic(progress)\n\t\t\tthis.drawChart()\n\n\t\t\tif (progress < 1 && this.isVisible) {\n\t\t\t\tthis.animationFrameId = requestAnimationFrame(animateFrame)\n\t\t\t}\n\t\t}\n\n\t\tthis.animationFrameId = requestAnimationFrame(animateFrame)\n\t}\n\n\tprivate processData(): ProcessedDataPoint[] {\n\t\tif (!this.data || this.data.length === 0) return []\n\n\t\t// Find top N peak values\n\t\tconst sortedByValue = [...this.data].sort((a, b) => b.value - a.value)\n\t\tconst peakLabels = new Set(sortedByValue.slice(0, this.peakCount).map(d => d.label))\n\n\t\treturn this.data.map(d => ({\n\t\t\t...d,\n\t\t\tx: 0, // Will be calculated during draw\n\t\t\ty: 0, // Will be calculated during draw\n\t\t\tisPeak: peakLabels.has(d.label),\n\t\t}))\n\t}\n\n\tprivate getThemeValue<K extends keyof ChartTheme>(\n\t\tkey: K,\n\t\tdefaultValue: NonNullable<ChartTheme[K]>\n\t): NonNullable<ChartTheme[K]> {\n\t\treturn (this.theme[key] as NonNullable<ChartTheme[K]>) ?? defaultValue\n\t}\n\n\tprivate drawChart() {\n\t\tconst canvas = this.canvasRef.value\n\t\tif (!canvas) return\n\n\t\tconst ctx = canvas.getContext('2d')\n\t\tif (!ctx) return\n\n\t\tconst dpr = window.devicePixelRatio || 1\n\t\tconst rect = canvas.getBoundingClientRect()\n\t\tconst width = rect.width\n\t\tconst height = rect.height\n\n\t\t// Set canvas size for high DPI\n\t\tcanvas.width = width * dpr\n\t\tcanvas.height = height * dpr\n\t\tctx.scale(dpr, dpr)\n\n\t\t// Clear canvas\n\t\tctx.clearRect(0, 0, width, height)\n\n\t\tconst data = this.processData()\n\t\tif (data.length === 0) return\n\n\t\tconst padding = { top: 20, right: 20, bottom: this.showLabels ? 40 : 20, left: 20 }\n\t\tconst chartWidth = width - padding.left - padding.right\n\t\tconst chartHeight = height - padding.top - padding.bottom\n\n\t\t// Find max value for scaling\n\t\tconst maxValue = Math.max(...data.map(d => d.value), 1)\n\n\t\t// Calculate positions\n\t\tconst points = data.map((d, i) => ({\n\t\t\t...d,\n\t\t\tx: padding.left + (data.length > 1 ? (i / (data.length - 1)) * chartWidth : chartWidth / 2),\n\t\t\ty: padding.top + chartHeight - (d.value / maxValue) * chartHeight,\n\t\t}))\n\n\t\tthis.processedData = points\n\n\t\t// Get primary color from CSS or theme\n\t\tconst computedStyle = getComputedStyle(this)\n\t\tconst defaultPrimaryColor =\n\t\t\tcomputedStyle.getPropertyValue('--schmancy-sys-color-primary').trim() || '#6750A4'\n\t\tconst primaryColor = this.getThemeValue('primaryColor', defaultPrimaryColor)\n\t\tconst [gradientOpacityTop, gradientOpacityBottom] = this.getThemeValue('gradientOpacity', [0.4, 0.05])\n\t\tconst strokeWidth = this.getThemeValue('strokeWidth', 2)\n\t\tconst pointRadius = this.getThemeValue('pointRadius', 4)\n\t\tconst peakRadius = this.getThemeValue('peakRadius', 6)\n\n\t\t// Draw grid lines\n\t\tif (this.showGrid) {\n\t\t\tctx.strokeStyle = 'rgba(128, 128, 128, 0.15)'\n\t\t\tctx.lineWidth = 1\n\t\t\tctx.setLineDash([4, 4])\n\n\t\t\tfor (let i = 1; i <= 3; i++) {\n\t\t\t\tconst y = padding.top + (chartHeight * i) / 4\n\t\t\t\tctx.beginPath()\n\t\t\t\tctx.moveTo(padding.left, y)\n\t\t\t\tctx.lineTo(width - padding.right, y)\n\t\t\t\tctx.stroke()\n\t\t\t}\n\n\t\t\tctx.setLineDash([])\n\t\t}\n\n\t\t// Create smooth curve path using Catmull-Rom spline\n\t\tconst curvePath = new Path2D()\n\t\tconst areaPath = new Path2D()\n\n\t\tif (points.length >= 2) {\n\t\t\t// Start area path from bottom left\n\t\t\tareaPath.moveTo(points[0].x, padding.top + chartHeight)\n\t\t\tcurvePath.moveTo(points[0].x, points[0].y)\n\t\t\tareaPath.lineTo(points[0].x, points[0].y)\n\n\t\t\tfor (let i = 0; i < points.length - 1; i++) {\n\t\t\t\tconst p0 = points[Math.max(0, i - 1)]\n\t\t\t\tconst p1 = points[i]\n\t\t\t\tconst p2 = points[Math.min(points.length - 1, i + 1)]\n\t\t\t\tconst p3 = points[Math.min(points.length - 1, i + 2)]\n\n\t\t\t\t// Draw curve segments\n\t\t\t\tconst segments = 16\n\t\t\t\tfor (let j = 1; j <= segments; j++) {\n\t\t\t\t\tconst t = j / segments\n\t\t\t\t\tconst point = catmullRomSpline(p0, p1, p2, p3, t)\n\t\t\t\t\tcurvePath.lineTo(point.x, point.y)\n\t\t\t\t\tareaPath.lineTo(point.x, point.y)\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Close area path\n\t\t\tareaPath.lineTo(points[points.length - 1].x, padding.top + chartHeight)\n\t\t\tareaPath.closePath()\n\t\t} else if (points.length === 1) {\n\t\t\t// Single point - draw a dot\n\t\t\tcurvePath.arc(points[0].x, points[0].y, pointRadius, 0, Math.PI * 2)\n\t\t}\n\n\t\t// Apply animation clipping\n\t\tctx.save()\n\t\tctx.beginPath()\n\t\tctx.rect(0, 0, padding.left + chartWidth * this.animationProgress, height)\n\t\tctx.clip()\n\n\t\t// Draw gradient fill\n\t\tif (points.length >= 2) {\n\t\t\tconst gradient = ctx.createLinearGradient(0, padding.top, 0, padding.top + chartHeight)\n\t\t\tgradient.addColorStop(0, hexToRgba(primaryColor, gradientOpacityTop))\n\t\t\tgradient.addColorStop(1, hexToRgba(primaryColor, gradientOpacityBottom))\n\n\t\t\tctx.fillStyle = gradient\n\t\t\tctx.fill(areaPath)\n\t\t}\n\n\t\t// Draw stroke\n\t\tctx.strokeStyle = primaryColor\n\t\tctx.lineWidth = strokeWidth\n\t\tctx.lineCap = 'round'\n\t\tctx.lineJoin = 'round'\n\t\tctx.stroke(curvePath)\n\n\t\t// Draw data points\n\t\tpoints.forEach((point, index) => {\n\t\t\tconst pointProgress = (index / (points.length - 1 || 1)) * this.animationProgress\n\t\t\tif (pointProgress < index / (points.length || 1)) return\n\n\t\t\tconst radius = point.isPeak ? peakRadius - 1 : pointRadius - 1\n\t\t\tconst outerRadius = point.isPeak ? peakRadius + 4 : pointRadius + 2\n\n\t\t\t// Outer glow for peaks\n\t\t\tif (point.isPeak) {\n\t\t\t\tctx.beginPath()\n\t\t\t\tctx.arc(point.x, point.y, outerRadius, 0, Math.PI * 2)\n\t\t\t\tctx.fillStyle = hexToRgba(primaryColor, 0.2)\n\t\t\t\tctx.fill()\n\t\t\t}\n\n\t\t\t// Inner dot\n\t\t\tctx.beginPath()\n\t\t\tctx.arc(point.x, point.y, radius, 0, Math.PI * 2)\n\t\t\tctx.fillStyle = primaryColor\n\t\t\tctx.fill()\n\n\t\t\t// White center for peaks\n\t\t\tif (point.isPeak) {\n\t\t\t\tctx.beginPath()\n\t\t\t\tctx.arc(point.x, point.y, 2, 0, Math.PI * 2)\n\t\t\t\tctx.fillStyle = 'white'\n\t\t\t\tctx.fill()\n\t\t\t}\n\t\t})\n\n\t\tctx.restore()\n\n\t\t// Draw labels\n\t\tif (this.showLabels && points.length > 0) {\n\t\t\tctx.fillStyle = 'rgba(128, 128, 128, 0.8)'\n\t\t\tctx.font = '11px system-ui, sans-serif'\n\t\t\tctx.textAlign = 'center'\n\t\t\tctx.textBaseline = 'top'\n\n\t\t\t// Show fewer labels on narrow charts\n\t\t\tconst labelStep = width < 400 ? 3 : width < 600 ? 2 : 1\n\t\t\tpoints.forEach((point, index) => {\n\t\t\t\tif (index % labelStep === 0) {\n\t\t\t\t\tctx.fillText(point.label, point.x, height - padding.bottom + 8)\n\t\t\t\t}\n\t\t\t})\n\t\t}\n\t}\n\n\tprivate formatValue(value: number): string {\n\t\tconst formatted = value.toFixed(this.valueDecimals)\n\t\treturn `${this.valuePrefix}${formatted}${this.valueSuffix}`\n\t}\n\n\tprivate handlePointerMove = (e: PointerEvent) => {\n\t\tif (this.processedData.length === 0 || !this.showTooltip) return\n\n\t\tconst canvas = this.canvasRef.value\n\t\tif (!canvas) return\n\n\t\tconst rect = canvas.getBoundingClientRect()\n\t\tconst x = e.clientX - rect.left\n\n\t\t// Find closest data point\n\t\tlet closestPoint: ProcessedDataPoint | null = null\n\t\tlet minDistance = Infinity\n\n\t\tthis.processedData.forEach(point => {\n\t\t\tconst distance = Math.abs(point.x - x)\n\t\t\tif (distance < minDistance) {\n\t\t\t\tminDistance = distance\n\t\t\t\tclosestPoint = point\n\t\t\t}\n\t\t})\n\n\t\tif (closestPoint && minDistance < 30) {\n\t\t\tthis.tooltipData = {\n\t\t\t\tvisible: true,\n\t\t\t\tx: closestPoint.x,\n\t\t\t\ty: closestPoint.y,\n\t\t\t\tlabel: closestPoint.label,\n\t\t\t\tvalue: closestPoint.value,\n\t\t\t\tmetadata: closestPoint.metadata,\n\t\t\t}\n\t\t} else {\n\t\t\tthis.tooltipData = { ...this.tooltipData, visible: false }\n\t\t}\n\t}\n\n\tprivate handlePointerLeave = () => {\n\t\tthis.tooltipData = { ...this.tooltipData, visible: false }\n\t}\n\n\tprivate renderMetadata() {\n\t\tif (!this.tooltipData.metadata) return ''\n\t\treturn Object.entries(this.tooltipData.metadata).map(\n\t\t\t([key, value]) => html`\n\t\t\t\t<schmancy-typography type=\"body\" token=\"sm\" class=\"text-surface-onVariant\">\n\t\t\t\t\t${key}: ${String(value)}\n\t\t\t\t</schmancy-typography>\n\t\t\t`\n\t\t)\n\t}\n\n\trender() {\n\t\tif (!this.data || this.data.length === 0) {\n\t\t\treturn html``\n\t\t}\n\n\t\treturn html`\n\t\t\t<div ${ref(this.containerRef)} class=\"relative\">\n\t\t\t\t<div class=\"relative\" style=\"height: ${this.height}px; touch-action: pan-y;\">\n\t\t\t\t\t<canvas\n\t\t\t\t\t\t${ref(this.canvasRef)}\n\t\t\t\t\t\tclass=\"w-full h-full\"\n\t\t\t\t\t\tstyle=\"display: block;\"\n\t\t\t\t\t\t@pointermove=${this.handlePointerMove}\n\t\t\t\t\t\t@pointerleave=${this.handlePointerLeave}\n\t\t\t\t\t></canvas>\n\n\t\t\t\t\t<!-- Tooltip -->\n\t\t\t\t\t${this.showTooltip\n\t\t\t\t\t\t? html`\n\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\tclass=\"absolute pointer-events-none transition-opacity duration-150 ${this.tooltipData.visible\n\t\t\t\t\t\t\t\t\t\t? 'opacity-100'\n\t\t\t\t\t\t\t\t\t\t: 'opacity-0'}\"\n\t\t\t\t\t\t\t\t\tstyle=\"\n left: ${this.tooltipData.x}px;\n top: ${this.tooltipData.y - 60}px;\n transform: translateX(-50%);\n \"\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t<schmancy-surface elevation=\"3\" rounded=\"all\" class=\"px-3 py-2 min-w-max\">\n\t\t\t\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"sm\" class=\"text-surface-onVariant\">\n\t\t\t\t\t\t\t\t\t\t\t${this.tooltipData.label}\n\t\t\t\t\t\t\t\t\t\t</schmancy-typography>\n\t\t\t\t\t\t\t\t\t\t<schmancy-typography type=\"title\" token=\"md\" class=\"text-surface-on font-semibold\">\n\t\t\t\t\t\t\t\t\t\t\t${this.formatValue(this.tooltipData.value)}\n\t\t\t\t\t\t\t\t\t\t</schmancy-typography>\n\t\t\t\t\t\t\t\t\t\t${this.renderMetadata()}\n\t\t\t\t\t\t\t\t\t</schmancy-surface>\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t `\n\t\t\t\t\t\t: ''}\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-area-chart': SchmancyAreaChart\n\t}\n}\n","import { html, css, PropertyValues } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { repeat } from 'lit/directives/repeat.js'\nimport { $LitElement } from '@mixins/index'\nimport type { PillDataPoint, PillSegment } from './types'\n\n/** Default color palette for segments - expanded for uniqueness */\nconst DEFAULT_COLORS = [\n\t'bg-primary',\n\t'bg-secondary',\n\t'bg-tertiary',\n\t'bg-success',\n\t'bg-warning',\n\t'bg-error',\n\t'bg-primary/70',\n\t'bg-secondary/70',\n\t'bg-tertiary/70',\n\t'bg-success/70',\n\t'bg-warning/70',\n\t'bg-error/70',\n\t'bg-primary/40',\n\t'bg-secondary/40',\n\t'bg-tertiary/40',\n]\n\n@customElement('schmancy-pills')\nexport class SchmancyPills extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n`) {\n\t/** Chart data points */\n\t@property({ type: Array })\n\tdata: PillDataPoint[] = []\n\n\t/** Prefix for values (e.g., \"EUR \") */\n\t@property({ type: String })\n\tvaluePrefix = ''\n\n\t/** Suffix for values (e.g., \"%\") */\n\t@property({ type: String })\n\tvalueSuffix = ''\n\n\t/** Decimal places for value display */\n\t@property({ type: Number })\n\tvalueDecimals = 2\n\n\t/** Show medals for top 3 */\n\t@property({ type: Boolean })\n\tshowMedals = true\n\n\t/** Show legend for segments */\n\t@property({ type: Boolean })\n\tshowLegend = true\n\n\t/** Animation duration in milliseconds */\n\t@property({ type: Number })\n\tanimationDuration = 500\n\n\t/** Enable entrance animation */\n\t@property({ type: Boolean })\n\tanimated = true\n\n\t/** Label column width (Tailwind class) */\n\t@property({ type: String })\n\tlabelWidth = 'w-14'\n\n\t/** Value column width (Tailwind class) */\n\t@property({ type: String })\n\tvalueWidth = 'w-20'\n\n\t@state() private animationProgress = 0\n\t@state() private isVisible = false\n\t@state() private categoryColorMap = new Map<string, string>()\n\n\tprivate observer: IntersectionObserver | null = null\n\tprivate animationFrameId: number | null = null\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\t\tthis.setupIntersectionObserver()\n\t}\n\n\tdisconnectedCallback() {\n\t\tsuper.disconnectedCallback()\n\t\tthis.cleanup()\n\t}\n\n\tprivate cleanup() {\n\t\tif (this.animationFrameId !== null) {\n\t\t\tcancelAnimationFrame(this.animationFrameId)\n\t\t\tthis.animationFrameId = null\n\t\t}\n\t\tif (this.observer) {\n\t\t\tthis.observer.disconnect()\n\t\t\tthis.observer = null\n\t\t}\n\t}\n\n\tprivate setupIntersectionObserver() {\n\t\tthis.observer = new IntersectionObserver(\n\t\t\tentries => {\n\t\t\t\tconst entry = entries[0]\n\t\t\t\tif (entry.isIntersecting && !this.isVisible) {\n\t\t\t\t\tthis.isVisible = true\n\t\t\t\t\tif (this.animated) {\n\t\t\t\t\t\tthis.startAnimation()\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.animationProgress = 1\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t\t{ threshold: 0.1 }\n\t\t)\n\t}\n\n\tprotected firstUpdated() {\n\t\tif (this.observer) {\n\t\t\tthis.observer.observe(this)\n\t\t}\n\t}\n\n\tprotected updated(changedProperties: PropertyValues) {\n\t\tsuper.updated(changedProperties)\n\n\t\t// Restart animation when data changes\n\t\tif (changedProperties.has('data') && this.isVisible && this.animated) {\n\t\t\tthis.animationProgress = 0\n\t\t\tthis.startAnimation()\n\t\t}\n\t}\n\n\tprivate startAnimation() {\n\t\tconst startTime = performance.now()\n\t\tconst duration = this.animationDuration\n\n\t\tconst animateFrame = (currentTime: number) => {\n\t\t\tconst elapsed = currentTime - startTime\n\t\t\tconst progress = Math.min(elapsed / duration, 1)\n\n\t\t\t// Ease out cubic\n\t\t\tthis.animationProgress = 1 - Math.pow(1 - progress, 3)\n\n\t\t\tif (progress < 1 && this.isVisible) {\n\t\t\t\tthis.animationFrameId = requestAnimationFrame(animateFrame)\n\t\t\t}\n\t\t}\n\n\t\tthis.animationFrameId = requestAnimationFrame(animateFrame)\n\t}\n\n\tprivate initializeCategoryColors(): void {\n\t\t// Build consistent color map from all segments in data\n\t\tconst categoryTotals = new Map<string, number>()\n\t\tconst explicitColors = new Map<string, string>()\n\n\t\tthis.data.forEach(d => {\n\t\t\tif (d.segments) {\n\t\t\t\td.segments.forEach(seg => {\n\t\t\t\t\tcategoryTotals.set(seg.label, (categoryTotals.get(seg.label) || 0) + seg.value)\n\t\t\t\t\t// Capture explicit colors from segments\n\t\t\t\t\tif (seg.color && !explicitColors.has(seg.label)) {\n\t\t\t\t\t\texplicitColors.set(seg.label, seg.color)\n\t\t\t\t\t}\n\t\t\t\t})\n\t\t\t}\n\t\t})\n\n\t\t// Sort by total value (most = first color)\n\t\tconst sortedCategories = Array.from(categoryTotals.entries())\n\t\t\t.sort((a, b) => b[1] - a[1])\n\t\t\t.map(([cat]) => cat)\n\n\t\t// Clear and rebuild - use explicit colors if available, otherwise default palette\n\t\tthis.categoryColorMap.clear()\n\t\tlet defaultColorIndex = 0\n\t\tsortedCategories.forEach(cat => {\n\t\t\tif (explicitColors.has(cat)) {\n\t\t\t\tthis.categoryColorMap.set(cat, explicitColors.get(cat)!)\n\t\t\t} else {\n\t\t\t\tthis.categoryColorMap.set(cat, DEFAULT_COLORS[defaultColorIndex % DEFAULT_COLORS.length])\n\t\t\t\tdefaultColorIndex++\n\t\t\t}\n\t\t})\n\t}\n\n\tprivate getSegmentColor(segment: PillSegment): string {\n\t\t// Use explicit color if provided\n\t\tif (segment.color) return segment.color\n\t\t// Otherwise use from color map\n\t\treturn this.categoryColorMap.get(segment.label) || 'bg-primary'\n\t}\n\n\tprivate formatValue(value: number): string {\n\t\tconst formatted = value.toFixed(this.valueDecimals)\n\t\treturn `${this.valuePrefix}${formatted}${this.valueSuffix}`\n\t}\n\n\tprivate getMedalEmoji(rank: number | undefined): string {\n\t\tif (!this.showMedals || !rank) return ''\n\t\tif (rank === 1) return '🥇'\n\t\tif (rank === 2) return '🥈'\n\t\tif (rank === 3) return '🥉'\n\t\treturn ''\n\t}\n\n\tprivate getMaxValue(): number {\n\t\tif (this.data.length === 0) return 0\n\t\treturn Math.max(...this.data.map(d => d.value), 1)\n\t}\n\n\tprivate renderBar(dataPoint: PillDataPoint, maxValue: number): ReturnType<typeof html> {\n\t\tconst percentage = maxValue > 0 ? (dataPoint.value / maxValue) * 100 : 0\n\t\tconst animatedPercentage = percentage * this.animationProgress\n\n\t\t// If no segments, render solid bar\n\t\tif (!dataPoint.segments || dataPoint.segments.length === 0) {\n\t\t\tconst barColorClass = dataPoint.isPeak\n\t\t\t\t? 'bg-success'\n\t\t\t\t: dataPoint.isLow\n\t\t\t\t\t? 'bg-tertiary opacity-70'\n\t\t\t\t\t: dataPoint.value === 0\n\t\t\t\t\t\t? 'bg-tertiary/40'\n\t\t\t\t\t\t: 'bg-primary'\n\n\t\t\treturn html`\n\t\t\t\t<div\n\t\t\t\t\tclass=\"${barColorClass} h-full transition-all rounded-full\"\n\t\t\t\t\tstyle=\"width: ${Math.max(animatedPercentage, dataPoint.value > 0 ? 2 : 0)}%; transition-duration: ${this.animated ? '0ms' : '300ms'}\"\n\t\t\t\t\ttitle=\"${this.formatValue(dataPoint.value)}\"\n\t\t\t\t></div>\n\t\t\t`\n\t\t}\n\n\t\t// Stacked bar with segments\n\t\treturn html`\n\t\t\t<div\n\t\t\t\tclass=\"h-full flex\"\n\t\t\t\tstyle=\"width: ${Math.max(animatedPercentage, 2)}%; transition-duration: ${this.animated ? '0ms' : '300ms'}\"\n\t\t\t>\n\t\t\t\t${repeat(\n\t\t\t\t\tdataPoint.segments,\n\t\t\t\t\tseg => seg.label,\n\t\t\t\t\t(seg, index) => {\n\t\t\t\t\t\tconst segmentPercentage = dataPoint.value > 0 ? (seg.value / dataPoint.value) * 100 : 0\n\t\t\t\t\t\tconst marginLeft = index > 0 ? 'ml-px' : ''\n\t\t\t\t\t\tconst brightenClass = dataPoint.isPeak ? 'brightness-110' : ''\n\t\t\t\t\t\tconst colorClass = this.getSegmentColor(seg)\n\n\t\t\t\t\t\treturn html`\n\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\tclass=\"${colorClass} ${marginLeft} ${brightenClass} h-full transition-all\n\t\t\t\t\t\t\t\t\t${index === 0 ? 'rounded-l-full' : ''}\n\t\t\t\t\t\t\t\t\t${index === dataPoint.segments!.length - 1 ? 'rounded-r-full' : ''}\"\n\t\t\t\t\t\t\t\tstyle=\"width: ${segmentPercentage}%\"\n\t\t\t\t\t\t\t\ttitle=\"${seg.label}: ${this.formatValue(seg.value)}\"\n\t\t\t\t\t\t\t></div>\n\t\t\t\t\t\t`\n\t\t\t\t\t}\n\t\t\t\t)}\n\t\t\t</div>\n\t\t`\n\t}\n\n\tprivate renderLegend(): ReturnType<typeof html> {\n\t\tif (!this.showLegend || this.categoryColorMap.size === 0) {\n\t\t\treturn html``\n\t\t}\n\n\t\treturn html`\n\t\t\t<div class=\"flex flex-wrap gap-3 mt-4 pt-4 border-t border-outline-variant\">\n\t\t\t\t${repeat(\n\t\t\t\t\tArray.from(this.categoryColorMap.entries()),\n\t\t\t\t\t([cat]) => cat,\n\t\t\t\t\t([cat, color]) => html`\n\t\t\t\t\t\t<div class=\"flex items-center gap-1.5\">\n\t\t\t\t\t\t\t<div class=\"${color} w-3 h-3 rounded-sm\"></div>\n\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"sm\" class=\"text-surface-onVariant\">\n\t\t\t\t\t\t\t\t${cat}\n\t\t\t\t\t\t\t</schmancy-typography>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t`\n\t\t\t\t)}\n\t\t\t</div>\n\t\t`\n\t}\n\n\trender() {\n\t\t// Initialize colors before rendering\n\t\tthis.initializeCategoryColors()\n\n\t\tif (!this.data || this.data.length === 0) {\n\t\t\treturn html``\n\t\t}\n\n\t\tconst maxValue = this.getMaxValue()\n\n\t\treturn html`\n\t\t\t<div class=\"space-y-1\">\n\t\t\t\t${repeat(\n\t\t\t\t\tthis.data,\n\t\t\t\t\td => d.label,\n\t\t\t\t\td => {\n\t\t\t\t\t\tconst rowBgClass = d.isPeak ? 'bg-success/10 rounded-lg' : ''\n\t\t\t\t\t\tconst textColorClass = d.isPeak ? 'text-success font-bold' : 'text-surface-on'\n\n\t\t\t\t\t\treturn html`\n\t\t\t\t\t\t\t<div class=\"flex items-center gap-3 py-2 px-2 ${rowBgClass}\">\n\t\t\t\t\t\t\t\t<!-- Label -->\n\t\t\t\t\t\t\t\t<div class=\"${this.labelWidth} shrink-0 text-right\">\n\t\t\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"md\" class=\"${textColorClass}\">\n\t\t\t\t\t\t\t\t\t\t${d.label}\n\t\t\t\t\t\t\t\t\t</schmancy-typography>\n\t\t\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t\t\t<!-- Medal -->\n\t\t\t\t\t\t\t\t<div class=\"w-6 shrink-0 text-center\">\n\t\t\t\t\t\t\t\t\t${d.isPeak || (d.rank && d.rank <= 3)\n\t\t\t\t\t\t\t\t\t\t? html`<span class=\"text-sm\">${this.getMedalEmoji(d.rank)}</span>`\n\t\t\t\t\t\t\t\t\t\t: ''}\n\t\t\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t\t\t<!-- Bar -->\n\t\t\t\t\t\t\t\t<div class=\"flex-1 h-6 bg-secondary/15 rounded-full overflow-hidden\">\n\t\t\t\t\t\t\t\t\t${this.renderBar(d, maxValue)}\n\t\t\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t\t\t<!-- Value -->\n\t\t\t\t\t\t\t\t<div class=\"${this.valueWidth} shrink-0 text-right\">\n\t\t\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"md\" class=\"${textColorClass}\">\n\t\t\t\t\t\t\t\t\t\t${this.formatValue(d.value)}\n\t\t\t\t\t\t\t\t\t</schmancy-typography>\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t`\n\t\t\t\t\t}\n\t\t\t\t)}\n\t\t\t</div>\n\n\t\t\t<!-- Legend -->\n\t\t\t${this.renderLegend()}\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-pills': SchmancyPills\n\t}\n}\n"],"names":["catmullRomSpline","p0","p1","p2","p3","t","t2","t3","x","y","hexToRgba","color","alpha","startsWith","match","length","hex","replace","split","map","c","join","parseInt","substring","easeOutCubic","Math","pow","SchmancyAreaChart","$LitElement","css","constructor","super","arguments","this","data","height","showGrid","showLabels","showTooltip","peakCount","animationDuration","animated","valuePrefix","valueSuffix","valueDecimals","theme","tooltipData","visible","label","value","animationProgress","isVisible","canvasRef","createRef","containerRef","animationFrameId","observer","processedData","resizeObserver","handlePointerMove","e","canvas","rect","getBoundingClientRect","clientX","left","closestPoint","minDistance","Infinity","forEach","point","distance","abs","metadata","handlePointerLeave","connectedCallback","setupIntersectionObserver","disconnectedCallback","cleanup","cancelAnimationFrame","disconnect","IntersectionObserver","entries","entry","isIntersecting","startAnimation","drawChart","threshold","changedProperties","updated","observe","ResizeObserver","has","startTime","performance","now","duration","animateFrame","currentTime","elapsed","progress","min","requestAnimationFrame","processData","sortedByValue","sort","a","b","peakLabels","Set","slice","d","isPeak","key","defaultValue","ctx","getContext","dpr","window","devicePixelRatio","width","scale","clearRect","padding","chartWidth","chartHeight","maxValue","max","points","i","defaultPrimaryColor","getComputedStyle","getPropertyValue","trim","primaryColor","getThemeValue","gradientOpacityTop","gradientOpacityBottom","strokeWidth","pointRadius","peakRadius","strokeStyle","lineWidth","setLineDash","beginPath","moveTo","lineTo","stroke","curvePath","Path2D","areaPath","segments","j","closePath","arc","PI","save","clip","gradient","createLinearGradient","addColorStop","fillStyle","fill","lineCap","lineJoin","index","radius","outerRadius","restore","font","textAlign","textBaseline","labelStep","fillText","formatted","toFixed","renderMetadata","Object","html","String","render","ref","formatValue","__decorateClass","property","type","Array","prototype","Number","Boolean","state","customElement","DEFAULT_COLORS","SchmancyPills","showMedals","showLegend","labelWidth","valueWidth","categoryColorMap","Map","firstUpdated","initializeCategoryColors","categoryTotals","explicitColors","seg","set","get","sortedCategories","from","cat","clear","defaultColorIndex","segment","rank","dataPoint","animatedPercentage","barColorClass","isLow","repeat","segmentPercentage","marginLeft","brightenClass","colorClass","getSegmentColor","renderLegend","size","getMaxValue","rowBgClass","textColorClass","getMedalEmoji","renderBar"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- "use strict";const c=require("lit"),s=require("lit/decorators.js"),u=require("lit/directives/class-map.js"),d=require("lit/directives/style-map.js");require("rxjs"),require("rxjs/operators"),require("./tailwind.mixin-UijsBrYW.cjs");const p=require("./litElement.mixin-BVBdv0GP.cjs");var g=Object.defineProperty,m=Object.getOwnPropertyDescriptor,r=(o,i,l,a)=>{for(var n,t=a>1?void 0:a?m(i,l):i,h=o.length-1;h>=0;h--)(n=o[h])&&(t=(a?n(i,l,t):n(t))||t);return a&&t&&g(i,l,t),t};let e=class extends p.$LitElement(c.css`
1
+ "use strict";const u=require("./litElement.mixin-CrpeGpZ7.cjs"),c=require("lit"),s=require("lit/decorators.js"),d=require("lit/directives/class-map.js"),p=require("lit/directives/style-map.js");var g=Object.defineProperty,m=Object.getOwnPropertyDescriptor,r=(o,i,l,a)=>{for(var n,t=a>1?void 0:a?m(i,l):i,h=o.length-1;h>=0;h--)(n=o[h])&&(t=(a?n(i,l,t):n(t))||t);return a&&t&&g(i,l,t),t};let e=class extends u.$LitElement(c.css`
2
2
  :host {
3
3
  display: block;
4
4
  }
@@ -16,10 +16,10 @@
16
16
  animation: indeterminate 1.5s infinite ease-in-out;
17
17
  }
18
18
  `){constructor(){super(...arguments),this.value=0,this.max=100,this.indeterminate=!1,this.size="md",this.color="primary",this.glass=!1}get percentage(){return this.indeterminate?0:Math.min(100,Math.max(0,this.value/this.max*100))}render(){const o={"w-full":!0,relative:!0,"overflow-hidden":!0,"rounded-full":!0,"h-px":this.size==="xs","h-0.5":this.size==="sm","h-1":this.size==="md","h-2":this.size==="lg","backdrop-blur-xl":this.glass,"backdrop-saturate-150":this.glass,"bg-surface-container/20":this.glass&&!this.indeterminate,"bg-surface-container":!this.glass,"shadow-[inset_0_1px_2px_0_rgba(0,0,0,0.1)]":this.glass,border:this.glass,"border-outline/20":this.glass},i={"h-full":!0,"rounded-full":!0,"transition-all":!0,"duration-300":!0,"ease-in-out":!0,relative:!0,"bg-primary-default":this.color==="primary"&&!this.glass,"bg-secondary-default":this.color==="secondary"&&!this.glass,"bg-tertiary-default":this.color==="tertiary"&&!this.glass,"bg-error-default":this.color==="error"&&!this.glass,"bg-success-default":this.color==="success"&&!this.glass,"w-[30%]":this.indeterminate,absolute:this.indeterminate,"indeterminate-animation":this.indeterminate},l=this.indeterminate?{}:{width:`${this.percentage}%`},a={"backdrop-blur-sm":this.glass,"shadow-[0_0_20px_rgba(0,0,0,0.1)]":this.glass,"bg-primary-default/70":this.glass&&this.color==="primary","bg-secondary-default/70":this.glass&&this.color==="secondary","bg-tertiary-default/70":this.glass&&this.color==="tertiary","bg-error-default/70":this.glass&&this.color==="error","bg-success-default/70":this.glass&&this.color==="success"};return c.html`
19
- <div class="${u.classMap(o)}">
19
+ <div class="${d.classMap(o)}">
20
20
  <div
21
- class="${u.classMap({...i,...a})}"
22
- style="${d.styleMap(l)}"
21
+ class="${d.classMap({...i,...a})}"
22
+ style="${p.styleMap(l)}"
23
23
  role="progressbar"
24
24
  aria-valuenow="${this.value}"
25
25
  aria-valuemin="0"
@@ -32,4 +32,4 @@
32
32
  </div>
33
33
  </div>
34
34
  `}};r([s.property({type:Number,reflect:!0})],e.prototype,"value",2),r([s.property({type:Number,reflect:!0})],e.prototype,"max",2),r([s.property({type:Boolean,reflect:!0})],e.prototype,"indeterminate",2),r([s.property({type:String,reflect:!0})],e.prototype,"size",2),r([s.property({type:String,reflect:!0})],e.prototype,"color",2),r([s.property({type:Boolean,reflect:!0})],e.prototype,"glass",2),e=r([s.customElement("schmancy-progress")],e);
35
- //# sourceMappingURL=progress-qx8jtrOA.cjs.map
35
+ //# sourceMappingURL=progress-DlhYniW_.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"progress-DlhYniW_.cjs","sources":["../src/progress/progress.ts"],"sourcesContent":["import { $LitElement } from '@mixins/litElement.mixin'\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { classMap } from 'lit/directives/class-map.js'\nimport { styleMap } from 'lit/directives/style-map.js'\n\n@customElement('schmancy-progress')\nexport default class SchmancyProgress extends $LitElement(css`\n :host {\n display: block;\n }\n\n @keyframes indeterminate {\n 0% {\n left: -30%;\n }\n 100% {\n left: 100%;\n }\n }\n\n .indeterminate-animation {\n animation: indeterminate 1.5s infinite ease-in-out;\n }\n`) {\n @property({ type: Number, reflect: true })\n value = 0\n\n @property({ type: Number, reflect: true })\n max = 100\n\n @property({ type: Boolean, reflect: true })\n indeterminate = false\n\n // M3 aligned track heights: xs=1px, sm=2px, md=4px, lg=8px\n @property({ type: String, reflect: true })\n size: 'xs' | 'sm' | 'md' | 'lg' = 'md'\n\n @property({ type: String, reflect: true })\n color: 'primary' | 'secondary' | 'tertiary' | 'error' | 'success' = 'primary'\n\n @property({ type: Boolean, reflect: true })\n glass = false\n\n private get percentage(): number {\n if (this.indeterminate) return 0\n return Math.min(100, Math.max(0, (this.value / this.max) * 100))\n }\n\n protected render() {\n const containerClasses = {\n 'w-full': true,\n 'relative': true,\n 'overflow-hidden': true,\n 'rounded-full': true,\n 'h-px': this.size === 'xs', // 1px - M3 linear indicator track\n 'h-0.5': this.size === 'sm', // 2px\n 'h-1': this.size === 'md', // 4px - M3 default\n 'h-2': this.size === 'lg', // 8px\n // Glass effect background\n 'backdrop-blur-xl': this.glass,\n 'backdrop-saturate-150': this.glass,\n 'bg-surface-container/20': this.glass && !this.indeterminate,\n 'bg-surface-container': !this.glass,\n 'shadow-[inset_0_1px_2px_0_rgba(0,0,0,0.1)]': this.glass,\n 'border': this.glass,\n 'border-outline/20': this.glass\n }\n\n const barClasses = {\n 'h-full': true,\n 'rounded-full': true,\n 'transition-all': true,\n 'duration-300': true,\n 'ease-in-out': true,\n 'relative': true,\n 'bg-primary-default': this.color === 'primary' && !this.glass,\n 'bg-secondary-default': this.color === 'secondary' && !this.glass,\n 'bg-tertiary-default': this.color === 'tertiary' && !this.glass,\n 'bg-error-default': this.color === 'error' && !this.glass,\n 'bg-success-default': this.color === 'success' && !this.glass,\n 'w-[30%]': this.indeterminate,\n 'absolute': this.indeterminate,\n 'indeterminate-animation': this.indeterminate\n }\n\n const barStyles = this.indeterminate \n ? {} \n : { width: `${this.percentage}%` }\n\n // Glass effect bar classes\n const glassBarClasses = {\n 'backdrop-blur-sm': this.glass,\n 'shadow-[0_0_20px_rgba(0,0,0,0.1)]': this.glass,\n // Use semi-transparent background colors for glass effect\n 'bg-primary-default/70': this.glass && this.color === 'primary',\n 'bg-secondary-default/70': this.glass && this.color === 'secondary',\n 'bg-tertiary-default/70': this.glass && this.color === 'tertiary',\n 'bg-error-default/70': this.glass && this.color === 'error',\n 'bg-success-default/70': this.glass && this.color === 'success',\n }\n\n return html`\n <div class=\"${classMap(containerClasses)}\">\n <div \n class=\"${classMap({...barClasses, ...glassBarClasses})}\"\n style=\"${styleMap(barStyles)}\"\n role=\"progressbar\"\n aria-valuenow=\"${this.value}\"\n aria-valuemin=\"0\"\n aria-valuemax=\"${this.max}\"\n >\n ${this.glass ? html`\n <!-- Glass shine effect -->\n <div class=\"absolute inset-0 bg-linear-to-b from-surface-on/20 to-transparent rounded-full\"></div>\n ` : ''}\n </div>\n </div>\n `\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'schmancy-progress': SchmancyProgress\n }\n}\n"],"names":["SchmancyProgress","$LitElement","css","constructor","super","arguments","this","value","max","indeterminate","size","color","glass","percentage","Math","min","render","containerClasses","relative","border","barClasses","absolute","barStyles","width","glassBarClasses","html","classMap","styleMap","__decorateClass","property","type","Number","reflect","prototype","Boolean","String","customElement"],"mappings":"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"}