le-kit 0.1.6 → 0.1.8

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 (289) hide show
  1. package/{dist/le-kit/assets/custom-elements.json → custom-elements.json} +889 -889
  2. package/dist/cjs/{index-WzJ78D5H.js → index-D7B9TPh8.js} +41 -9
  3. package/dist/cjs/index-D7B9TPh8.js.map +1 -0
  4. package/dist/cjs/index.cjs.js +4 -2
  5. package/dist/cjs/index.cjs.js.map +1 -1
  6. package/dist/cjs/le-box.cjs.entry.js +2 -2
  7. package/dist/cjs/le-button.le-checkbox.le-component.le-popover.le-slot.le-string-input.entry.cjs.js.map +1 -1
  8. package/dist/cjs/le-button_6.cjs.entry.js +8 -10
  9. package/dist/cjs/le-card.cjs.entry.js +2 -2
  10. package/dist/cjs/le-kit.cjs.js +1 -1
  11. package/dist/cjs/le-number-input.cjs.entry.js +2 -2
  12. package/dist/cjs/le-popup.cjs.entry.js +1 -1
  13. package/dist/cjs/le-round-progress.cjs.entry.js +1 -1
  14. package/dist/cjs/le-stack.cjs.entry.js +2 -2
  15. package/dist/cjs/le-text.cjs.entry.js +2 -2
  16. package/dist/cjs/le-turntable.cjs.entry.js +1 -1
  17. package/dist/cjs/loader.cjs.js +1 -1
  18. package/dist/cjs/{utils-CBjH2E8A.js → utils-DrsoID-a.js} +3 -3
  19. package/dist/cjs/{utils-CBjH2E8A.js.map → utils-DrsoID-a.js.map} +1 -1
  20. package/dist/collection/components/le-component/le-component.js +5 -5
  21. package/dist/collection/components/le-component/le-component.js.map +1 -1
  22. package/dist/collection/components/le-popup/le-popup.js +7 -7
  23. package/dist/collection/components/le-slot/le-slot.js +5 -5
  24. package/dist/collection/components/le-slot/le-slot.js.map +1 -1
  25. package/dist/collection/global/app.js +37 -0
  26. package/dist/collection/global/app.js.map +1 -1
  27. package/dist/collection/index.js +1 -1
  28. package/dist/collection/index.js.map +1 -1
  29. package/dist/components/index.js +1 -1
  30. package/dist/components/index.js.map +1 -1
  31. package/dist/components/le-box.js +1 -1
  32. package/dist/components/le-button.js +1 -1
  33. package/dist/components/le-button2.js +45 -10
  34. package/dist/components/le-button2.js.map +1 -1
  35. package/dist/components/le-card.js +1 -1
  36. package/dist/components/le-checkbox.js +1 -1
  37. package/dist/components/le-component.js +1 -1
  38. package/dist/components/le-number-input.js +1 -1
  39. package/dist/components/le-popup.js +1 -1
  40. package/dist/components/le-slot.js +1 -1
  41. package/dist/components/le-stack.js +1 -1
  42. package/dist/components/le-string-input.js +1 -1
  43. package/dist/components/le-text.js +1 -1
  44. package/dist/core/cjs/index-D7B9TPh8.js +1835 -0
  45. package/dist/core/cjs/index-D7B9TPh8.js.map +1 -0
  46. package/dist/core/cjs/index.cjs.js +119 -0
  47. package/dist/core/cjs/index.cjs.js.map +1 -0
  48. package/dist/core/cjs/le-box.cjs.entry.js +184 -0
  49. package/dist/core/cjs/le-box.entry.cjs.js.map +1 -0
  50. package/dist/core/cjs/le-button.cjs.entry.js +92 -0
  51. package/dist/core/cjs/le-button.entry.cjs.js.map +1 -0
  52. package/dist/core/cjs/le-card.cjs.entry.js +29 -0
  53. package/dist/core/cjs/le-card.entry.cjs.js.map +1 -0
  54. package/dist/core/cjs/le-checkbox.cjs.entry.js +61 -0
  55. package/dist/core/cjs/le-checkbox.entry.cjs.js.map +1 -0
  56. package/dist/core/cjs/le-kit.cjs.js +25 -0
  57. package/dist/core/cjs/le-kit.cjs.js.map +1 -0
  58. package/dist/core/cjs/le-number-input.cjs.entry.js +202 -0
  59. package/dist/core/cjs/le-number-input.entry.cjs.js.map +1 -0
  60. package/dist/core/cjs/le-popover.cjs.entry.js +348 -0
  61. package/dist/core/cjs/le-popover.entry.cjs.js.map +1 -0
  62. package/dist/core/cjs/le-popup.cjs.entry.js +212 -0
  63. package/dist/core/cjs/le-popup.entry.cjs.js.map +1 -0
  64. package/dist/core/cjs/le-round-progress.cjs.entry.js +106 -0
  65. package/dist/core/cjs/le-round-progress.entry.cjs.js.map +1 -0
  66. package/dist/core/cjs/le-stack.cjs.entry.js +135 -0
  67. package/dist/core/cjs/le-stack.entry.cjs.js.map +1 -0
  68. package/dist/core/cjs/le-string-input.cjs.entry.js +95 -0
  69. package/dist/core/cjs/le-string-input.entry.cjs.js.map +1 -0
  70. package/dist/core/cjs/le-text.cjs.entry.js +335 -0
  71. package/dist/core/cjs/le-text.entry.cjs.js.map +1 -0
  72. package/dist/core/cjs/le-turntable.cjs.entry.js +139 -0
  73. package/dist/core/cjs/le-turntable.entry.cjs.js.map +1 -0
  74. package/dist/core/cjs/loader.cjs.js +13 -0
  75. package/dist/core/cjs/loader.cjs.js.map +1 -0
  76. package/dist/core/cjs/utils-DrsoID-a.js +152 -0
  77. package/dist/core/cjs/utils-DrsoID-a.js.map +1 -0
  78. package/dist/core/collection/collection-manifest.json +24 -0
  79. package/dist/core/collection/components/le-box/le-box.default.css +37 -0
  80. package/dist/core/collection/components/le-box/le-box.js +614 -0
  81. package/dist/core/collection/components/le-box/le-box.js.map +1 -0
  82. package/dist/core/collection/components/le-button/le-button.default.css +263 -0
  83. package/dist/core/collection/components/le-button/le-button.js +368 -0
  84. package/dist/core/collection/components/le-button/le-button.js.map +1 -0
  85. package/dist/core/collection/components/le-card/le-card.default.css +74 -0
  86. package/dist/core/collection/components/le-card/le-card.js +102 -0
  87. package/dist/core/collection/components/le-card/le-card.js.map +1 -0
  88. package/dist/core/collection/components/le-checkbox/le-checkbox.css +93 -0
  89. package/dist/core/collection/components/le-checkbox/le-checkbox.js +192 -0
  90. package/dist/core/collection/components/le-checkbox/le-checkbox.js.map +1 -0
  91. package/dist/core/collection/components/le-number-input/le-number-input.css +135 -0
  92. package/dist/core/collection/components/le-number-input/le-number-input.js +515 -0
  93. package/dist/core/collection/components/le-number-input/le-number-input.js.map +1 -0
  94. package/dist/core/collection/components/le-popover/le-popover.css +143 -0
  95. package/dist/core/collection/components/le-popover/le-popover.js +693 -0
  96. package/dist/core/collection/components/le-popover/le-popover.js.map +1 -0
  97. package/dist/core/collection/components/le-popup/le-popup.api.js +101 -0
  98. package/dist/core/collection/components/le-popup/le-popup.api.js.map +1 -0
  99. package/dist/core/collection/components/le-popup/le-popup.css +222 -0
  100. package/dist/core/collection/components/le-popup/le-popup.js +596 -0
  101. package/dist/core/collection/components/le-popup/le-popup.js.map +1 -0
  102. package/dist/core/collection/components/le-round-progress/le-round-progress.css +34 -0
  103. package/dist/core/collection/components/le-round-progress/le-round-progress.js +184 -0
  104. package/dist/core/collection/components/le-round-progress/le-round-progress.js.map +1 -0
  105. package/dist/core/collection/components/le-stack/le-stack.default.css +37 -0
  106. package/dist/core/collection/components/le-stack/le-stack.js +389 -0
  107. package/dist/core/collection/components/le-stack/le-stack.js.map +1 -0
  108. package/dist/core/collection/components/le-string-input/le-string-input.css +83 -0
  109. package/dist/core/collection/components/le-string-input/le-string-input.js +359 -0
  110. package/dist/core/collection/components/le-string-input/le-string-input.js.map +1 -0
  111. package/dist/core/collection/components/le-text/le-text.default.css +169 -0
  112. package/dist/core/collection/components/le-text/le-text.js +475 -0
  113. package/dist/core/collection/components/le-text/le-text.js.map +1 -0
  114. package/dist/core/collection/components/le-turntable/le-turntable.css +10 -0
  115. package/dist/core/collection/components/le-turntable/le-turntable.js +210 -0
  116. package/dist/core/collection/components/le-turntable/le-turntable.js.map +1 -0
  117. package/dist/core/collection/global/app.js +167 -0
  118. package/dist/core/collection/global/app.js.map +1 -0
  119. package/dist/core/collection/index.js +15 -0
  120. package/dist/core/collection/index.js.map +1 -0
  121. package/dist/core/collection/types/blocks.js +115 -0
  122. package/dist/core/collection/types/blocks.js.map +1 -0
  123. package/dist/core/collection/types/options.js +2 -0
  124. package/dist/core/collection/types/options.js.map +1 -0
  125. package/dist/core/collection/utils/utils.js +141 -0
  126. package/dist/core/collection/utils/utils.js.map +1 -0
  127. package/dist/{esm/index-CdjJ98OT.js → core/esm/index-PS-3Rz-c.js} +40 -9
  128. package/dist/core/esm/index-PS-3Rz-c.js.map +1 -0
  129. package/dist/core/esm/index.js +106 -0
  130. package/dist/core/esm/index.js.map +1 -0
  131. package/dist/core/esm/le-box.entry.js +182 -0
  132. package/dist/core/esm/le-box.entry.js.map +1 -0
  133. package/dist/core/esm/le-button.entry.js +90 -0
  134. package/dist/core/esm/le-button.entry.js.map +1 -0
  135. package/dist/core/esm/le-card.entry.js +27 -0
  136. package/dist/core/esm/le-card.entry.js.map +1 -0
  137. package/dist/core/esm/le-checkbox.entry.js +59 -0
  138. package/dist/core/esm/le-checkbox.entry.js.map +1 -0
  139. package/dist/core/esm/le-kit.js +21 -0
  140. package/dist/core/esm/le-kit.js.map +1 -0
  141. package/dist/core/esm/le-number-input.entry.js +200 -0
  142. package/dist/core/esm/le-number-input.entry.js.map +1 -0
  143. package/dist/core/esm/le-popover.entry.js +346 -0
  144. package/dist/core/esm/le-popover.entry.js.map +1 -0
  145. package/dist/core/esm/le-popup.entry.js +210 -0
  146. package/dist/core/esm/le-popup.entry.js.map +1 -0
  147. package/dist/core/esm/le-round-progress.entry.js +104 -0
  148. package/dist/core/esm/le-round-progress.entry.js.map +1 -0
  149. package/dist/core/esm/le-stack.entry.js +133 -0
  150. package/dist/core/esm/le-stack.entry.js.map +1 -0
  151. package/dist/core/esm/le-string-input.entry.js +93 -0
  152. package/dist/core/esm/le-string-input.entry.js.map +1 -0
  153. package/dist/core/esm/le-text.entry.js +333 -0
  154. package/dist/core/esm/le-text.entry.js.map +1 -0
  155. package/dist/core/esm/le-turntable.entry.js +137 -0
  156. package/dist/core/esm/le-turntable.entry.js.map +1 -0
  157. package/dist/core/esm/loader.js +11 -0
  158. package/dist/core/esm/loader.js.map +1 -0
  159. package/dist/{esm/utils-CzfSUhYB.js → core/esm/utils-lgjSfQP0.js} +3 -3
  160. package/dist/core/esm/utils-lgjSfQP0.js.map +1 -0
  161. package/dist/core/index.cjs.js +1 -0
  162. package/dist/core/index.js +1 -0
  163. package/dist/core/le-kit/index.esm.js +2 -0
  164. package/dist/core/le-kit/index.esm.js.map +1 -0
  165. package/dist/core/le-kit/le-box.entry.esm.js.map +1 -0
  166. package/dist/core/le-kit/le-button.entry.esm.js.map +1 -0
  167. package/dist/core/le-kit/le-card.entry.esm.js.map +1 -0
  168. package/dist/core/le-kit/le-checkbox.entry.esm.js.map +1 -0
  169. package/dist/core/le-kit/le-kit.css +1 -0
  170. package/dist/core/le-kit/le-kit.esm.js +2 -0
  171. package/dist/core/le-kit/le-kit.esm.js.map +1 -0
  172. package/dist/core/le-kit/le-number-input.entry.esm.js.map +1 -0
  173. package/dist/core/le-kit/le-popover.entry.esm.js.map +1 -0
  174. package/dist/core/le-kit/le-popup.entry.esm.js.map +1 -0
  175. package/dist/core/le-kit/le-round-progress.entry.esm.js.map +1 -0
  176. package/dist/core/le-kit/le-stack.entry.esm.js.map +1 -0
  177. package/dist/core/le-kit/le-string-input.entry.esm.js.map +1 -0
  178. package/dist/core/le-kit/le-text.entry.esm.js.map +1 -0
  179. package/dist/core/le-kit/le-turntable.entry.esm.js.map +1 -0
  180. package/dist/core/le-kit/loader.esm.js.map +1 -0
  181. package/dist/core/le-kit/p-1c5262eb.entry.js +2 -0
  182. package/dist/core/le-kit/p-1c5262eb.entry.js.map +1 -0
  183. package/dist/core/le-kit/p-32c08678.entry.js +2 -0
  184. package/dist/core/le-kit/p-32c08678.entry.js.map +1 -0
  185. package/dist/core/le-kit/p-38e7ec05.entry.js +2 -0
  186. package/dist/core/le-kit/p-38e7ec05.entry.js.map +1 -0
  187. package/dist/core/le-kit/p-4bf51acc.entry.js +2 -0
  188. package/dist/core/le-kit/p-4bf51acc.entry.js.map +1 -0
  189. package/dist/core/le-kit/p-86961f34.entry.js +2 -0
  190. package/dist/core/le-kit/p-86961f34.entry.js.map +1 -0
  191. package/dist/core/le-kit/p-9ee92c29.entry.js +2 -0
  192. package/dist/{le-kit/p-CvDc0yWN.js → core/le-kit/p-DN2JVY-7.js} +2 -2
  193. package/dist/core/le-kit/p-DN2JVY-7.js.map +1 -0
  194. package/dist/core/le-kit/p-PS-3Rz-c.js +3 -0
  195. package/dist/core/le-kit/p-PS-3Rz-c.js.map +1 -0
  196. package/dist/core/le-kit/p-a07048f8.entry.js +2 -0
  197. package/dist/core/le-kit/p-a07048f8.entry.js.map +1 -0
  198. package/dist/core/le-kit/p-a24b042d.entry.js +2 -0
  199. package/dist/core/le-kit/p-a24b042d.entry.js.map +1 -0
  200. package/dist/core/le-kit/p-bbc9e13e.entry.js +2 -0
  201. package/dist/core/le-kit/p-bbc9e13e.entry.js.map +1 -0
  202. package/dist/core/le-kit/p-c4223c60.entry.js +2 -0
  203. package/dist/core/le-kit/p-c4223c60.entry.js.map +1 -0
  204. package/dist/core/le-kit/p-dcf1343d.entry.js +2 -0
  205. package/dist/core/le-kit/p-fb4e68e0.entry.js +2 -0
  206. package/dist/core/le-kit/p-fb4e68e0.entry.js.map +1 -0
  207. package/dist/core/loader/cdn.js +1 -0
  208. package/dist/core/loader/index.cjs.js +1 -0
  209. package/dist/core/loader/index.d.ts +24 -0
  210. package/dist/core/loader/index.es2017.js +1 -0
  211. package/dist/core/loader/index.js +2 -0
  212. package/dist/core/types/components/le-box/le-box.d.ts +111 -0
  213. package/dist/core/types/components/le-button/le-button.d.ts +78 -0
  214. package/dist/core/types/components/le-card/le-card.d.ts +37 -0
  215. package/dist/core/types/components/le-checkbox/le-checkbox.d.ts +46 -0
  216. package/dist/core/types/components/le-number-input/le-number-input.d.ts +106 -0
  217. package/dist/core/types/components/le-popover/le-popover.d.ts +109 -0
  218. package/dist/core/types/components/le-popup/le-popup.api.d.ts +73 -0
  219. package/dist/core/types/components/le-popup/le-popup.d.ts +122 -0
  220. package/dist/core/types/components/le-round-progress/le-round-progress.d.ts +37 -0
  221. package/dist/core/types/components/le-stack/le-stack.d.ts +73 -0
  222. package/dist/core/types/components/le-string-input/le-string-input.d.ts +83 -0
  223. package/dist/core/types/components/le-text/le-text.d.ts +141 -0
  224. package/dist/core/types/components/le-turntable/le-turntable.d.ts +55 -0
  225. package/dist/core/types/components.d.ts +1752 -0
  226. package/dist/core/types/global/app.d.ts +73 -0
  227. package/dist/core/types/index.d.ts +15 -0
  228. package/dist/core/types/stencil-public-runtime.d.ts +1756 -0
  229. package/dist/core/types/types/blocks.d.ts +136 -0
  230. package/dist/core/types/types/options.d.ts +124 -0
  231. package/dist/core/types/utils/utils.d.ts +54 -0
  232. package/dist/docs.json +8 -8
  233. package/dist/esm/index-PS-3Rz-c.js +1818 -0
  234. package/dist/{le-kit/p-CdjJ98OT.js.map → esm/index-PS-3Rz-c.js.map} +1 -1
  235. package/dist/esm/index.js +2 -2
  236. package/dist/esm/le-box.entry.js +2 -2
  237. package/dist/esm/le-button.le-checkbox.le-component.le-popover.le-slot.le-string-input.entry.js.map +1 -1
  238. package/dist/esm/le-button_6.entry.js +8 -10
  239. package/dist/esm/le-card.entry.js +2 -2
  240. package/dist/esm/le-kit.js +2 -2
  241. package/dist/esm/le-number-input.entry.js +2 -2
  242. package/dist/esm/le-popup.entry.js +1 -1
  243. package/dist/esm/le-round-progress.entry.js +1 -1
  244. package/dist/esm/le-stack.entry.js +2 -2
  245. package/dist/esm/le-text.entry.js +2 -2
  246. package/dist/esm/le-turntable.entry.js +1 -1
  247. package/dist/esm/loader.js +2 -2
  248. package/dist/esm/utils-lgjSfQP0.js +146 -0
  249. package/dist/esm/{utils-CzfSUhYB.js.map → utils-lgjSfQP0.js.map} +1 -1
  250. package/dist/le-kit/index.esm.js +1 -1
  251. package/dist/le-kit/le-button.le-checkbox.le-component.le-popover.le-slot.le-string-input.entry.esm.js.map +1 -1
  252. package/dist/le-kit/le-kit.esm.js +1 -1
  253. package/dist/le-kit/p-27710b5b.entry.js +2 -0
  254. package/dist/le-kit/{p-0633b3ab.entry.js.map → p-27710b5b.entry.js.map} +1 -1
  255. package/dist/le-kit/{p-1452a995.entry.js → p-34102cef.entry.js} +2 -2
  256. package/dist/le-kit/{p-95764888.entry.js → p-56a80e6d.entry.js} +2 -2
  257. package/dist/le-kit/p-615ea10f.entry.js +2 -0
  258. package/dist/le-kit/p-615ea10f.entry.js.map +1 -0
  259. package/dist/le-kit/{p-bc20e30d.entry.js → p-935bb2d4.entry.js} +2 -2
  260. package/dist/le-kit/{p-220528ee.entry.js → p-9d3dc4e5.entry.js} +2 -2
  261. package/dist/le-kit/p-DN2JVY-7.js +2 -0
  262. package/dist/le-kit/{p-CvDc0yWN.js.map → p-DN2JVY-7.js.map} +1 -1
  263. package/dist/le-kit/p-PS-3Rz-c.js +3 -0
  264. package/dist/le-kit/p-PS-3Rz-c.js.map +1 -0
  265. package/dist/le-kit/{p-3551598e.entry.js → p-ccabc638.entry.js} +2 -2
  266. package/dist/le-kit/p-ccabc638.entry.js.map +1 -0
  267. package/dist/le-kit/{p-722899f0.entry.js → p-d8157b06.entry.js} +2 -2
  268. package/dist/le-kit/p-d8157b06.entry.js.map +1 -0
  269. package/dist/le-kit/p-e8c2ca0e.entry.js +2 -0
  270. package/dist/le-kit/{p-d32eddad.entry.js.map → p-e8c2ca0e.entry.js.map} +1 -1
  271. package/dist/types/global/app.d.ts +33 -0
  272. package/dist/types/index.d.ts +1 -1
  273. package/package.json +21 -3
  274. package/readme.md +22 -0
  275. package/dist/cjs/index-WzJ78D5H.js.map +0 -1
  276. package/dist/collection/assets/.gitkeep +0 -1
  277. package/dist/collection/assets/custom-elements.json +0 -4305
  278. package/dist/esm/index-CdjJ98OT.js.map +0 -1
  279. package/dist/le-kit/p-0633b3ab.entry.js +0 -2
  280. package/dist/le-kit/p-32ff3dbe.entry.js +0 -2
  281. package/dist/le-kit/p-32ff3dbe.entry.js.map +0 -1
  282. package/dist/le-kit/p-CdjJ98OT.js +0 -3
  283. package/dist/le-kit/p-d32eddad.entry.js +0 -2
  284. /package/dist/{le-kit/p-3551598e.entry.js.map → core/le-kit/p-9ee92c29.entry.js.map} +0 -0
  285. /package/dist/{le-kit/p-722899f0.entry.js.map → core/le-kit/p-dcf1343d.entry.js.map} +0 -0
  286. /package/dist/le-kit/{p-1452a995.entry.js.map → p-34102cef.entry.js.map} +0 -0
  287. /package/dist/le-kit/{p-95764888.entry.js.map → p-56a80e6d.entry.js.map} +0 -0
  288. /package/dist/le-kit/{p-bc20e30d.entry.js.map → p-935bb2d4.entry.js.map} +0 -0
  289. /package/dist/le-kit/{p-220528ee.entry.js.map → p-9d3dc4e5.entry.js.map} +0 -0
@@ -0,0 +1,141 @@
1
+ /**
2
+ * Utility functions for le-kit components
3
+ */
4
+ import { getMode } from "../global/app";
5
+ /**
6
+ * Generates a unique ID for component instances
7
+ */
8
+ export function generateId(prefix = 'le') {
9
+ return `${prefix}-${Math.random().toString(36).substring(2, 9)}`;
10
+ }
11
+ /**
12
+ * Parses a comma-separated string into an array
13
+ */
14
+ export function parseCommaSeparated(value) {
15
+ if (!value)
16
+ return [];
17
+ return value
18
+ .split(',')
19
+ .map(s => s.trim())
20
+ .filter(Boolean);
21
+ }
22
+ /**
23
+ * Checks if a slot has content
24
+ */
25
+ export function slotHasContent(el, slotName = '') {
26
+ const selector = slotName ? `[slot="${slotName}"]` : ':not([slot])';
27
+ return el.querySelector(selector) !== null;
28
+ }
29
+ /**
30
+ * Sets up a MutationObserver to track mode changes on ancestor elements.
31
+ * Returns a cleanup function to disconnect the observer.
32
+ *
33
+ * If the element or any ancestor has an explicit `mode` attribute, that creates
34
+ * a "mode boundary" - the mode is determined from that point, not from further up.
35
+ * This allows components like le-popover to force default mode for their children.
36
+ *
37
+ * @param el - The component's host element
38
+ * @param callback - Function to call when mode changes, receives the new mode
39
+ * @returns Cleanup function to disconnect the observer
40
+ *
41
+ * @example
42
+ * ```tsx
43
+ * export class MyComponent {
44
+ * @Element() el: HTMLElement;
45
+ * @State() adminMode: boolean = false;
46
+ * private disconnectModeObserver?: () => void;
47
+ *
48
+ * connectedCallback() {
49
+ * this.disconnectModeObserver = observeModeChanges(this.el, (mode) => {
50
+ * this.adminMode = mode === 'admin';
51
+ * });
52
+ * }
53
+ *
54
+ * disconnectedCallback() {
55
+ * this.disconnectModeObserver?.();
56
+ * }
57
+ * }
58
+ * ```
59
+ */
60
+ export function observeModeChanges(el, callback) {
61
+ // Call immediately with current mode
62
+ callback(getMode(el));
63
+ // Set up observer for mode attribute changes
64
+ const observer = new MutationObserver(() => {
65
+ callback(getMode(el));
66
+ });
67
+ // Observe the element itself (for mode boundary changes)
68
+ observer.observe(el, {
69
+ attributes: true,
70
+ attributeFilter: ['mode'],
71
+ });
72
+ // Observe document root
73
+ observer.observe(document.documentElement, {
74
+ attributes: true,
75
+ attributeFilter: ['mode'],
76
+ });
77
+ // Traverse up, crossing shadow boundaries, and observe each element
78
+ let current = el;
79
+ while (current) {
80
+ if (current instanceof Element && current.parentElement) {
81
+ current = current.parentElement;
82
+ observer.observe(current, {
83
+ attributes: true,
84
+ attributeFilter: ['mode'],
85
+ });
86
+ // If this element has an explicit mode, it's a boundary
87
+ if (current.hasAttribute('mode')) {
88
+ break;
89
+ }
90
+ }
91
+ else {
92
+ // Check if we're in a shadow root
93
+ const root = current.getRootNode();
94
+ if (root instanceof ShadowRoot) {
95
+ // Cross the shadow boundary and observe the host
96
+ current = root.host;
97
+ observer.observe(current, {
98
+ attributes: true,
99
+ attributeFilter: ['mode'],
100
+ });
101
+ // If the host has an explicit mode, it's a boundary
102
+ if (current.hasAttribute('mode')) {
103
+ break;
104
+ }
105
+ }
106
+ else {
107
+ break;
108
+ }
109
+ }
110
+ }
111
+ // Return cleanup function
112
+ return () => observer.disconnect();
113
+ }
114
+ /**
115
+ * Combines multiple class names into a single string, filtering out falsy values.
116
+ *
117
+ * @param classes - arguments of class names, undefined, arrays, objects with boolean values and nested combinations of these
118
+ * @returns Combined class names string
119
+ */
120
+ export function classnames(...classes) {
121
+ const result = [];
122
+ classes.forEach(cls => {
123
+ if (!cls)
124
+ return;
125
+ if (typeof cls === 'string') {
126
+ result.push(cls);
127
+ }
128
+ else if (Array.isArray(cls)) {
129
+ result.push(classnames(...cls));
130
+ }
131
+ else if (typeof cls === 'object') {
132
+ Object.entries(cls).forEach(([key, value]) => {
133
+ if (value) {
134
+ result.push(key);
135
+ }
136
+ });
137
+ }
138
+ });
139
+ return result.join(' ');
140
+ }
141
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src-core/utils/utils.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Utility functions for le-kit components\n */\n\nimport { getMode } from '../global/app';\n\n/**\n * Generates a unique ID for component instances\n */\nexport function generateId(prefix: string = 'le'): string {\n return `${prefix}-${Math.random().toString(36).substring(2, 9)}`;\n}\n\n/**\n * Parses a comma-separated string into an array\n */\nexport function parseCommaSeparated(value: string | undefined): string[] {\n if (!value) return [];\n return value\n .split(',')\n .map(s => s.trim())\n .filter(Boolean);\n}\n\n/**\n * Checks if a slot has content\n */\nexport function slotHasContent(el: HTMLElement, slotName: string = ''): boolean {\n const selector = slotName ? `[slot=\"${slotName}\"]` : ':not([slot])';\n return el.querySelector(selector) !== null;\n}\n\n/**\n * Sets up a MutationObserver to track mode changes on ancestor elements.\n * Returns a cleanup function to disconnect the observer.\n * \n * If the element or any ancestor has an explicit `mode` attribute, that creates\n * a \"mode boundary\" - the mode is determined from that point, not from further up.\n * This allows components like le-popover to force default mode for their children.\n * \n * @param el - The component's host element\n * @param callback - Function to call when mode changes, receives the new mode\n * @returns Cleanup function to disconnect the observer\n * \n * @example\n * ```tsx\n * export class MyComponent {\n * @Element() el: HTMLElement;\n * @State() adminMode: boolean = false;\n * private disconnectModeObserver?: () => void;\n * \n * connectedCallback() {\n * this.disconnectModeObserver = observeModeChanges(this.el, (mode) => {\n * this.adminMode = mode === 'admin';\n * });\n * }\n * \n * disconnectedCallback() {\n * this.disconnectModeObserver?.();\n * }\n * }\n * ```\n */\nexport function observeModeChanges(\n el: HTMLElement,\n callback: (mode: string) => void\n): () => void {\n // Call immediately with current mode\n callback(getMode(el));\n\n // Set up observer for mode attribute changes\n const observer = new MutationObserver(() => {\n callback(getMode(el));\n });\n\n // Observe the element itself (for mode boundary changes)\n observer.observe(el, {\n attributes: true,\n attributeFilter: ['mode'],\n });\n\n // Observe document root\n observer.observe(document.documentElement, {\n attributes: true,\n attributeFilter: ['mode'],\n });\n\n // Traverse up, crossing shadow boundaries, and observe each element\n let current: Node | null = el;\n while (current) {\n if (current instanceof Element && current.parentElement) {\n current = current.parentElement;\n observer.observe(current, {\n attributes: true,\n attributeFilter: ['mode'],\n });\n // If this element has an explicit mode, it's a boundary\n if ((current as Element).hasAttribute('mode')) {\n break;\n }\n } else {\n // Check if we're in a shadow root\n const root = current.getRootNode();\n if (root instanceof ShadowRoot) {\n // Cross the shadow boundary and observe the host\n current = root.host;\n observer.observe(current, {\n attributes: true,\n attributeFilter: ['mode'],\n });\n // If the host has an explicit mode, it's a boundary\n if ((current as Element).hasAttribute('mode')) {\n break;\n }\n } else {\n break;\n }\n }\n }\n\n // Return cleanup function\n return () => observer.disconnect();\n}\n\n/**\n * Combines multiple class names into a single string, filtering out falsy values.\n * \n * @param classes - arguments of class names, undefined, arrays, objects with boolean values and nested combinations of these\n * @returns Combined class names string\n */\nexport function classnames(...classes: any[]): string {\n const result: string[] = [];\n\n classes.forEach(cls => {\n if (!cls) return;\n\n if (typeof cls === 'string') {\n result.push(cls);\n } else if (Array.isArray(cls)) {\n result.push(classnames(...cls));\n } else if (typeof cls === 'object') {\n Object.entries(cls).forEach(([key, value]) => {\n if (value) {\n result.push(key);\n }\n });\n }\n });\n\n return result.join(' ');\n}\n"]}
@@ -104,6 +104,43 @@ function setGlobalMode(mode) {
104
104
  function setGlobalTheme(theme) {
105
105
  document.documentElement.setAttribute('theme', theme);
106
106
  }
107
+ /**
108
+ * Global configuration for le-kit
109
+ */
110
+ let leKitConfig = {
111
+ /**
112
+ * URL to the custom-elements.json manifest.
113
+ * Used by admin components (le-component, le-slot) to load component metadata.
114
+ *
115
+ * Default: '/custom-elements.json' (served from app root)
116
+ *
117
+ * For apps using le-kit, you may need to:
118
+ * 1. Copy the manifest from node_modules/le-kit/custom-elements.json to your public folder
119
+ * 2. Or set this to point to where the manifest is served
120
+ */
121
+ manifestUrl: '/custom-elements.json',
122
+ };
123
+ /**
124
+ * Configure le-kit global settings.
125
+ *
126
+ * @example
127
+ * ```ts
128
+ * import { configureLeki } from 'le-kit';
129
+ *
130
+ * configureLeki({
131
+ * manifestUrl: '/assets/custom-elements.json'
132
+ * });
133
+ * ```
134
+ */
135
+ function configureLeki(config) {
136
+ leKitConfig = { ...leKitConfig, ...config };
137
+ }
138
+ /**
139
+ * Get the current le-kit configuration.
140
+ */
141
+ function getLeKitConfig() {
142
+ return leKitConfig;
143
+ }
107
144
 
108
145
  const globalScripts = initializeMode;
109
146
  const globalStyles = ":root{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--le-spacing-0:0;--le-spacing-1:0.25rem;--le-spacing-2:0.5rem;--le-spacing-3:0.75rem;--le-spacing-4:1rem;--le-spacing-5:1.25rem;--le-spacing-6:1.5rem;--le-spacing-8:2rem;--le-spacing-10:2.5rem;--le-spacing-12:3rem;--le-spacing-16:4rem;--le-font-family-base:-apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;--le-font-family-mono:'SF Mono', 'Monaco', 'Inconsolata', 'Fira Code', monospace;--le-font-size-xs:0.75rem;--le-font-size-sm:0.875rem;--le-font-size-md:1rem;--le-font-size-lg:1.125rem;--le-font-size-xl:1.25rem;--le-font-size-2xl:1.5rem;--le-font-size-3xl:1.875rem;--le-font-size-4xl:2.25rem;--le-font-weight-normal:400;--le-font-weight-medium:500;--le-font-weight-semibold:600;--le-font-weight-bold:700;--le-line-height-tight:1.25;--le-line-height-normal:1.5;--le-line-height-relaxed:1.75;--le-radius-none:0;--le-radius-xs:0.066rem;--le-radius-sm:0.125rem;--le-radius-md:0.25rem;--le-radius-lg:0.5rem;--le-radius-xl:0.75rem;--le-radius-2xl:1rem;--le-radius-full:9999px;--le-transition-fast:100ms;--le-transition-normal:200ms;--le-transition-slow:300ms;--le-transition-easing:cubic-bezier(0.4, 0, 0.2, 1);--le-z-dropdown:1000;--le-z-sticky:1020;--le-z-fixed:1030;--le-z-modal-backdrop:1040;--le-z-modal:1050;--le-z-popover:1060;--le-z-tooltip:1070}:root,[theme=\"default\"]{--le-color-primary:#0088ff;--le-color-primary-light:#4da6ff;--le-color-primary-dark:#0066cc;--le-color-primary-contrast:#ffffff;--le-color-secondary:#6c757d;--le-color-secondary-light:#868e96;--le-color-secondary-dark:#545b62;--le-color-secondary-contrast:#ffffff;--le-color-success:#28a745;--le-color-success-light:#48c764;--le-color-success-dark:#1e7e34;--le-color-success-contrast:#ffffff;--le-color-warning:#ffc107;--le-color-warning-light:#ffcd39;--le-color-warning-dark:#d39e00;--le-color-warning-contrast:#212529;--le-color-danger:#dc3545;--le-color-danger-light:#e4606d;--le-color-danger-dark:#bd2130;--le-color-danger-contrast:#ffffff;--le-color-info:#17a2b8;--le-color-info-light:#3ab0c3;--le-color-info-dark:#117a8b;--le-color-info-contrast:#ffffff;--le-color-white:#ffffff;--le-color-black:#000000;--le-color-gray-50:#fafafa;--le-color-gray-100:#f5f5f5;--le-color-gray-200:#eeeeee;--le-color-gray-300:#e0e0e0;--le-color-gray-400:#bdbdbd;--le-color-gray-500:#9e9e9e;--le-color-gray-600:#757575;--le-color-gray-700:#616161;--le-color-gray-800:#424242;--le-color-gray-900:#212121;--le-color-background:#ffffff;--le-color-background-secondary:#f5f5f5;--le-color-background-tertiary:#eeeeee;--le-color-surface:#ffffff;--le-color-surface-elevated:#ffffff;--le-color-text-primary:#212121;--le-color-text-secondary:#757575;--le-color-text-disabled:#9e9e9e;--le-color-text-inverse:#ffffff;--le-color-border:#e0e0e0;--le-color-border-light:#eeeeee;--le-color-border-dark:#bdbdbd;--le-border-width:2px;--le-color-border-input:#c4d6e6;--le-color-focus:rgba(0, 136, 255, 0.5);--le-radius-none:0;--le-radius-sm:0.125rem;--le-radius-md:0.25rem;--le-radius-lg:0.5rem;--le-radius-xl:0.75rem;--le-radius-2xl:1rem;--le-radius-full:9999px;--le-shadow-none:none;--le-shadow-sm:0 1px 2px rgba(0, 0, 0, 0.05);--le-shadow-md:0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 2px rgba(0, 0, 0, 0.06);--le-shadow-lg:0 4px 6px rgba(0, 0, 0, 0.1), 0 2px 4px rgba(0, 0, 0, 0.06);--le-shadow-xl:0 10px 15px rgba(0, 0, 0, 0.1), 0 4px 6px rgba(0, 0, 0, 0.05);--le-shadow-2xl:0 20px 25px rgba(0, 0, 0, 0.1), 0 10px 10px rgba(0, 0, 0, 0.04)}[theme=\"dark\"]{--le-color-primary:#4da6ff;--le-color-primary-light:#80c1ff;--le-color-primary-dark:#0088ff;--le-color-primary-contrast:#000000;--le-color-secondary:#868e96;--le-color-secondary-light:#adb5bd;--le-color-secondary-dark:#6c757d;--le-color-secondary-contrast:#000000;--le-color-success:#48c764;--le-color-success-light:#6dd587;--le-color-success-dark:#28a745;--le-color-success-contrast:#000000;--le-color-warning:#ffcd39;--le-color-warning-light:#ffda6a;--le-color-warning-dark:#ffc107;--le-color-warning-contrast:#000000;--le-color-danger:#e4606d;--le-color-danger-light:#ea868f;--le-color-danger-dark:#dc3545;--le-color-danger-contrast:#000000;--le-color-info:#3ab0c3;--le-color-info-light:#6dc4d3;--le-color-info-dark:#17a2b8;--le-color-info-contrast:#000000;--le-color-white:#ffffff;--le-color-black:#000000;--le-color-gray-50:#212121;--le-color-gray-100:#424242;--le-color-gray-200:#616161;--le-color-gray-300:#757575;--le-color-gray-400:#9e9e9e;--le-color-gray-500:#bdbdbd;--le-color-gray-600:#e0e0e0;--le-color-gray-700:#eeeeee;--le-color-gray-800:#f5f5f5;--le-color-gray-900:#fafafa;--le-color-background:#121212;--le-color-background-secondary:#1e1e1e;--le-color-background-tertiary:#2d2d2d;--le-color-surface:#1e1e1e;--le-color-surface-elevated:#2d2d2d;--le-color-text-primary:#ffffff;--le-color-text-secondary:#b3b3b3;--le-color-text-disabled:#666666;--le-color-text-inverse:#121212;--le-color-border:#333333;--le-color-border-light:#2d2d2d;--le-color-border-dark:#444444;--le-border-width:2px;--le-color-border-input:#515c6b;--le-color-focus:rgba(77, 166, 255, 0.5);--le-radius-none:0;--le-radius-sm:0.125rem;--le-radius-md:0.25rem;--le-radius-lg:0.5rem;--le-radius-xl:0.75rem;--le-radius-2xl:1rem;--le-radius-full:9999px;--le-shadow-none:none;--le-shadow-sm:0 1px 2px rgba(0, 0, 0, 0.3);--le-shadow-md:0 1px 3px rgba(0, 0, 0, 0.4), 0 1px 2px rgba(0, 0, 0, 0.3);--le-shadow-lg:0 4px 6px rgba(0, 0, 0, 0.4), 0 2px 4px rgba(0, 0, 0, 0.3);--le-shadow-xl:0 10px 15px rgba(0, 0, 0, 0.4), 0 4px 6px rgba(0, 0, 0, 0.3);--le-shadow-2xl:0 20px 25px rgba(0, 0, 0, 0.4), 0 10px 10px rgba(0, 0, 0, 0.3)}[theme=\"gradient\"]{--le-color-primary:#8b5cf6;--le-color-primary-light:#a78bfa;--le-color-primary-dark:#7c3aed;--le-color-primary-contrast:#ffffff;--le-color-secondary:#ec4899;--le-color-secondary-light:#f472b6;--le-color-secondary-dark:#db2777;--le-color-secondary-contrast:#ffffff;--le-color-success:#10b981;--le-color-success-light:#34d399;--le-color-success-dark:#059669;--le-color-success-contrast:#ffffff;--le-color-warning:#f59e0b;--le-color-warning-light:#fbbf24;--le-color-warning-dark:#d97706;--le-color-warning-contrast:#000000;--le-color-danger:#ef4444;--le-color-danger-light:#f87171;--le-color-danger-dark:#dc2626;--le-color-danger-contrast:#ffffff;--le-color-info:#06b6d4;--le-color-info-light:#22d3ee;--le-color-info-dark:#0891b2;--le-color-info-contrast:#ffffff;--le-color-white:#ffffff;--le-color-black:#000000;--le-color-gray-50:#faf5ff;--le-color-gray-100:#f3e8ff;--le-color-gray-200:#e9d5ff;--le-color-gray-300:#d8b4fe;--le-color-gray-400:#c084fc;--le-color-gray-500:#a855f7;--le-color-gray-600:#9333ea;--le-color-gray-700:#7e22ce;--le-color-gray-800:#6b21a8;--le-color-gray-900:#581c87;--le-color-background:linear-gradient(135deg, #667eea 0%, #764ba2 100%);--le-color-background-secondary:rgba(255, 255, 255, 0.1);--le-color-background-tertiary:rgba(255, 255, 255, 0.05);--le-color-surface:rgba(255, 255, 255, 0.95);--le-color-surface-elevated:#ffffff;--le-color-text-primary:#1f2937;--le-color-text-secondary:#6b7280;--le-color-text-disabled:#9ca3af;--le-color-text-inverse:#ffffff;--le-color-border:rgba(139, 92, 246, 0.3);--le-color-border-light:rgba(139, 92, 246, 0.1);--le-color-border-dark:rgba(139, 92, 246, 0.5);--le-border-width:2px;--le-color-border-input:#eccddd;--le-color-focus:rgba(139, 92, 246, 0.5);--le-radius-none:0;--le-radius-sm:0.25rem;--le-radius-md:0.5rem;--le-radius-lg:1rem;--le-radius-xl:1.5rem;--le-radius-2xl:2rem;--le-radius-full:9999px;--le-shadow-none:none;--le-shadow-sm:0 1px 2px rgba(139, 92, 246, 0.1);--le-shadow-md:0 4px 6px rgba(139, 92, 246, 0.15), 0 2px 4px rgba(139, 92, 246, 0.1);--le-shadow-lg:0 10px 20px rgba(139, 92, 246, 0.2), 0 4px 8px rgba(139, 92, 246, 0.1);--le-shadow-xl:0 20px 40px rgba(139, 92, 246, 0.25), 0 8px 16px rgba(139, 92, 246, 0.15);--le-shadow-2xl:0 30px 60px rgba(139, 92, 246, 0.3), 0 15px 30px rgba(139, 92, 246, 0.2)}[theme=\"minimal\"]{--le-color-primary:#111827;--le-color-primary-light:#374151;--le-color-primary-dark:#030712;--le-color-primary-contrast:#ffffff;--le-color-secondary:#6b7280;--le-color-secondary-light:#9ca3af;--le-color-secondary-dark:#4b5563;--le-color-secondary-contrast:#ffffff;--le-color-success:#059669;--le-color-success-light:#10b981;--le-color-success-dark:#047857;--le-color-success-contrast:#ffffff;--le-color-warning:#d97706;--le-color-warning-light:#f59e0b;--le-color-warning-dark:#b45309;--le-color-warning-contrast:#ffffff;--le-color-danger:#dc2626;--le-color-danger-light:#ef4444;--le-color-danger-dark:#b91c1c;--le-color-danger-contrast:#ffffff;--le-color-info:#0284c7;--le-color-info-light:#0ea5e9;--le-color-info-dark:#0369a1;--le-color-info-contrast:#ffffff;--le-color-white:#ffffff;--le-color-black:#000000;--le-color-gray-50:#f9fafb;--le-color-gray-100:#f3f4f6;--le-color-gray-200:#e5e7eb;--le-color-gray-300:#d1d5db;--le-color-gray-400:#9ca3af;--le-color-gray-500:#6b7280;--le-color-gray-600:#4b5563;--le-color-gray-700:#374151;--le-color-gray-800:#1f2937;--le-color-gray-900:#111827;--le-color-background:#ffffff;--le-color-background-secondary:#fafafa;--le-color-background-tertiary:#f5f5f5;--le-color-surface:#ffffff;--le-color-surface-elevated:#ffffff;--le-color-text-primary:#111827;--le-color-text-secondary:#6b7280;--le-color-text-disabled:#9ca3af;--le-color-text-inverse:#ffffff;--le-color-border:#e5e7eb;--le-color-border-light:#f3f4f6;--le-color-border-dark:#d1d5db;--le-border-width:1px;--le-color-border-input:#c8cfdd;--le-color-focus:rgba(17, 24, 39, 0.3);--le-radius-none:0;--le-radius-sm:0;--le-radius-md:2px;--le-radius-lg:4px;--le-radius-xl:6px;--le-radius-2xl:8px;--le-radius-full:9999px;--le-shadow-none:none;--le-shadow-sm:none;--le-shadow-md:0 1px 2px rgba(0, 0, 0, 0.05);--le-shadow-lg:0 1px 3px rgba(0, 0, 0, 0.08);--le-shadow-xl:0 2px 4px rgba(0, 0, 0, 0.1);--le-shadow-2xl:0 4px 8px rgba(0, 0, 0, 0.1)}[theme=\"warm\"]{--le-color-primary:#ea580c;--le-color-primary-light:#fb923c;--le-color-primary-dark:#c2410c;--le-color-primary-contrast:#ffffff;--le-color-secondary:#b45309;--le-color-secondary-light:#d97706;--le-color-secondary-dark:#92400e;--le-color-secondary-contrast:#ffffff;--le-color-success:#16a34a;--le-color-success-light:#22c55e;--le-color-success-dark:#15803d;--le-color-success-contrast:#ffffff;--le-color-warning:#ca8a04;--le-color-warning-light:#eab308;--le-color-warning-dark:#a16207;--le-color-warning-contrast:#000000;--le-color-danger:#dc2626;--le-color-danger-light:#ef4444;--le-color-danger-dark:#b91c1c;--le-color-danger-contrast:#ffffff;--le-color-info:#0891b2;--le-color-info-light:#06b6d4;--le-color-info-dark:#0e7490;--le-color-info-contrast:#ffffff;--le-color-white:#ffffff;--le-color-black:#000000;--le-color-gray-50:#fffbeb;--le-color-gray-100:#fef3c7;--le-color-gray-200:#fde68a;--le-color-gray-300:#fcd34d;--le-color-gray-400:#fbbf24;--le-color-gray-500:#f59e0b;--le-color-gray-600:#d97706;--le-color-gray-700:#b45309;--le-color-gray-800:#92400e;--le-color-gray-900:#78350f;--le-color-background:#fffbeb;--le-color-background-secondary:#fef3c7;--le-color-background-tertiary:#fde68a;--le-color-surface:#ffffff;--le-color-surface-elevated:#ffffff;--le-color-text-primary:#78350f;--le-color-text-secondary:#92400e;--le-color-text-disabled:#d97706;--le-color-text-inverse:#ffffff;--le-color-border:#fcd34d;--le-color-border-light:#fde68a;--le-color-border-dark:#fbbf24;--le-border-width:2px;--le-color-border-input:#e7d4c4;--le-color-focus:rgba(234, 88, 12, 0.5);--le-radius-none:0;--le-radius-sm:0.125rem;--le-radius-md:0.375rem;--le-radius-lg:0.625rem;--le-radius-xl:0.875rem;--le-radius-2xl:1.125rem;--le-radius-full:9999px;--le-shadow-none:none;--le-shadow-sm:0 1px 2px rgba(234, 88, 12, 0.05);--le-shadow-md:0 4px 6px rgba(234, 88, 12, 0.1), 0 2px 4px rgba(234, 88, 12, 0.06);--le-shadow-lg:0 10px 15px rgba(234, 88, 12, 0.15), 0 4px 6px rgba(234, 88, 12, 0.08);--le-shadow-xl:0 20px 25px rgba(234, 88, 12, 0.15), 0 10px 10px rgba(234, 88, 12, 0.1);--le-shadow-2xl:0 25px 50px rgba(234, 88, 12, 0.2), 0 12px 24px rgba(234, 88, 12, 0.12)}:root{--le-space-xs:4px;--le-space-sm:8px;--le-space-md:16px;--le-space-lg:24px;--le-space-xl:32px;--le-space-2xl:48px;--le-space-3xl:64px;--le-font-family:system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;--le-font-family-mono:'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', Consolas, monospace;--le-font-size-xs:0.75rem;--le-font-size-sm:0.875rem;--le-font-size-md:1rem;--le-font-size-lg:1.125rem;--le-font-size-xl:1.25rem;--le-font-size-2xl:1.5rem;--le-font-size-3xl:2rem;--le-font-size-4xl:2.5rem;--le-font-weight-normal:400;--le-font-weight-medium:500;--le-font-weight-semibold:600;--le-font-weight-bold:700;--le-line-height-tight:1.25;--le-line-height-normal:1.5;--le-line-height-relaxed:1.75;--le-transition-fast:150ms ease;--le-transition-normal:250ms ease;--le-transition-slow:400ms ease;--le-transition-bounce:400ms cubic-bezier(0.68, -0.55, 0.265, 1.55);--le-z-dropdown:1000;--le-z-sticky:1020;--le-z-fixed:1030;--le-z-modal-backdrop:1040;--le-z-modal:1050;--le-z-popover:1060;--le-z-tooltip:1070}:root,[theme=\"default\"]{--le-color-primary:#3b82f6;--le-color-primary-hover:#2563eb;--le-color-primary-active:#1d4ed8;--le-color-primary-subtle:#eff6ff;--le-color-on-primary:#ffffff;--le-color-secondary:#64748b;--le-color-secondary-hover:#475569;--le-color-secondary-active:#334155;--le-color-secondary-subtle:#f1f5f9;--le-color-on-secondary:#ffffff;--le-color-success:#22c55e;--le-color-success-subtle:#f0fdf4;--le-color-on-success:#ffffff;--le-color-warning:#f59e0b;--le-color-warning-subtle:#fffbeb;--le-color-on-warning:#000000;--le-color-error:#ef4444;--le-color-error-subtle:#fef2f2;--le-color-on-error:#ffffff;--le-color-info:#06b6d4;--le-color-info-subtle:#ecfeff;--le-color-on-info:#ffffff;--le-color-background:#ffffff;--le-color-surface:#ffffff;--le-color-surface-raised:#ffffff;--le-color-surface-overlay:rgba(0, 0, 0, 0.5);--le-color-text:#1e293b;--le-color-text-secondary:#64748b;--le-color-text-muted:#94a3b8;--le-color-text-inverse:#ffffff;--le-color-border:#e2e8f0;--le-color-border-strong:#cbd5e1;--le-color-border-focus:var(--le-color-primary);--le-radius-none:0;--le-radius-sm:4px;--le-radius-md:7px;--le-radius-lg:12px;--le-radius-xl:16px;--le-radius-2xl:24px;--le-radius-full:9999px;--le-shadow-sm:0 1px 2px 0 rgba(0, 0, 0, 0.05);--le-shadow-md:0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.1);--le-shadow-lg:0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1);--le-shadow-xl:0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);--le-shadow-focus:0 0 0 3px rgba(59, 130, 246, 0.3)}[theme=\"dark\"]{--le-color-primary:#60a5fa;--le-color-primary-hover:#93c5fd;--le-color-primary-active:#3b82f6;--le-color-primary-subtle:#1e3a5f;--le-color-on-primary:#0f172a;--le-color-secondary:#94a3b8;--le-color-secondary-hover:#cbd5e1;--le-color-secondary-active:#64748b;--le-color-secondary-subtle:#1e293b;--le-color-on-secondary:#0f172a;--le-color-success:#4ade80;--le-color-success-subtle:#14532d;--le-color-on-success:#0f172a;--le-color-warning:#fbbf24;--le-color-warning-subtle:#422006;--le-color-on-warning:#0f172a;--le-color-error:#f87171;--le-color-error-subtle:#450a0a;--le-color-on-error:#0f172a;--le-color-info:#22d3ee;--le-color-info-subtle:#164e63;--le-color-on-info:#0f172a;--le-color-background:#0f172a;--le-color-surface:#1e293b;--le-color-surface-raised:#334155;--le-color-surface-overlay:rgba(0, 0, 0, 0.7);--le-color-text:#f1f5f9;--le-color-text-secondary:#94a3b8;--le-color-text-muted:#64748b;--le-color-text-inverse:#0f172a;--le-color-border:#334155;--le-color-border-strong:#475569;--le-color-border-focus:var(--le-color-primary);--le-shadow-sm:0 1px 2px 0 rgba(0, 0, 0, 0.3);--le-shadow-md:0 4px 6px -1px rgba(0, 0, 0, 0.4), 0 2px 4px -2px rgba(0, 0, 0, 0.3);--le-shadow-lg:0 10px 15px -3px rgba(0, 0, 0, 0.4), 0 4px 6px -4px rgba(0, 0, 0, 0.3);--le-shadow-xl:0 20px 25px -5px rgba(0, 0, 0, 0.5), 0 8px 10px -6px rgba(0, 0, 0, 0.4);--le-shadow-focus:0 0 0 3px rgba(96, 165, 250, 0.4)}[theme=\"gradient\"]{--le-color-primary:#8b5cf6;--le-color-primary-hover:#a78bfa;--le-color-primary-active:#7c3aed;--le-color-primary-subtle:#f5f3ff;--le-color-on-primary:#ffffff;--le-color-secondary:#ec4899;--le-color-secondary-hover:#f472b6;--le-color-secondary-active:#db2777;--le-color-secondary-subtle:#fdf2f8;--le-color-on-secondary:#ffffff;--le-color-success:#10b981;--le-color-success-subtle:#ecfdf5;--le-color-on-success:#ffffff;--le-color-warning:#f59e0b;--le-color-warning-subtle:#fffbeb;--le-color-on-warning:#000000;--le-color-error:#f43f5e;--le-color-error-subtle:#fff1f2;--le-color-on-error:#ffffff;--le-color-info:#06b6d4;--le-color-info-subtle:#ecfeff;--le-color-on-info:#ffffff;--le-color-background:linear-gradient(135deg, #faf5ff 0%, #fdf2f8 50%, #fff7ed 100%);--le-color-surface:rgba(255, 255, 255, 0.9);--le-color-surface-raised:#ffffff;--le-color-surface-overlay:rgba(139, 92, 246, 0.3);--le-color-text:#1f2937;--le-color-text-secondary:#6b7280;--le-color-text-muted:#9ca3af;--le-color-text-inverse:#ffffff;--le-color-border:rgba(139, 92, 246, 0.2);--le-color-border-strong:rgba(139, 92, 246, 0.4);--le-color-border-focus:var(--le-color-primary);--le-radius-sm:6px;--le-radius-md:12px;--le-radius-lg:16px;--le-radius-xl:20px;--le-radius-2xl:28px;--le-shadow-sm:0 1px 3px 0 rgba(139, 92, 246, 0.1);--le-shadow-md:0 4px 6px -1px rgba(139, 92, 246, 0.15), 0 2px 4px -2px rgba(236, 72, 153, 0.1);--le-shadow-lg:0 10px 15px -3px rgba(139, 92, 246, 0.2), 0 4px 6px -4px rgba(236, 72, 153, 0.15);--le-shadow-xl:0 20px 25px -5px rgba(139, 92, 246, 0.25), 0 8px 10px -6px rgba(236, 72, 153, 0.2);--le-shadow-focus:0 0 0 3px rgba(139, 92, 246, 0.4)}[theme=\"minimal\"]{--le-color-primary:#374151;--le-color-primary-hover:#1f2937;--le-color-primary-active:#111827;--le-color-primary-subtle:#f3f4f6;--le-color-on-primary:#ffffff;--le-color-secondary:#9ca3af;--le-color-secondary-hover:#6b7280;--le-color-secondary-active:#4b5563;--le-color-secondary-subtle:#f9fafb;--le-color-on-secondary:#ffffff;--le-color-success:#059669;--le-color-success-subtle:#f0fdf4;--le-color-on-success:#ffffff;--le-color-warning:#d97706;--le-color-warning-subtle:#fffbeb;--le-color-on-warning:#ffffff;--le-color-error:#dc2626;--le-color-error-subtle:#fef2f2;--le-color-on-error:#ffffff;--le-color-info:#0891b2;--le-color-info-subtle:#ecfeff;--le-color-on-info:#ffffff;--le-color-background:#fafafa;--le-color-surface:#ffffff;--le-color-surface-raised:#ffffff;--le-color-surface-overlay:rgba(0, 0, 0, 0.4);--le-color-text:#111827;--le-color-text-secondary:#6b7280;--le-color-text-muted:#9ca3af;--le-color-text-inverse:#ffffff;--le-color-border:#e5e7eb;--le-color-border-strong:#d1d5db;--le-color-border-focus:var(--le-color-primary);--le-radius-none:0;--le-radius-sm:2px;--le-radius-md:4px;--le-radius-lg:6px;--le-radius-xl:8px;--le-radius-2xl:12px;--le-radius-full:9999px;--le-shadow-sm:0 1px 2px 0 rgba(0, 0, 0, 0.03);--le-shadow-md:0 2px 4px -1px rgba(0, 0, 0, 0.06);--le-shadow-lg:0 4px 8px -2px rgba(0, 0, 0, 0.08);--le-shadow-xl:0 8px 16px -4px rgba(0, 0, 0, 0.1);--le-shadow-focus:0 0 0 2px rgba(55, 65, 81, 0.2)}[theme=\"warm\"]{--le-color-primary:#ea580c;--le-color-primary-hover:#f97316;--le-color-primary-active:#c2410c;--le-color-primary-subtle:#fff7ed;--le-color-on-primary:#ffffff;--le-color-secondary:#78716c;--le-color-secondary-hover:#57534e;--le-color-secondary-active:#44403c;--le-color-secondary-subtle:#fafaf9;--le-color-on-secondary:#ffffff;--le-color-success:#65a30d;--le-color-success-subtle:#f7fee7;--le-color-on-success:#ffffff;--le-color-warning:#d97706;--le-color-warning-subtle:#fffbeb;--le-color-on-warning:#000000;--le-color-error:#dc2626;--le-color-error-subtle:#fef2f2;--le-color-on-error:#ffffff;--le-color-info:#0891b2;--le-color-info-subtle:#ecfeff;--le-color-on-info:#ffffff;--le-color-background:#fffbf5;--le-color-surface:#ffffff;--le-color-surface-raised:#ffffff;--le-color-surface-overlay:rgba(120, 53, 15, 0.4);--le-color-text:#292524;--le-color-text-secondary:#78716c;--le-color-text-muted:#a8a29e;--le-color-text-inverse:#ffffff;--le-color-border:#e7e5e4;--le-color-border-strong:#d6d3d1;--le-color-border-focus:var(--le-color-primary);--le-radius-sm:4px;--le-radius-md:8px;--le-radius-lg:12px;--le-radius-xl:16px;--le-radius-2xl:24px;--le-shadow-sm:0 1px 2px 0 rgba(120, 53, 15, 0.05);--le-shadow-md:0 4px 6px -1px rgba(120, 53, 15, 0.1), 0 2px 4px -2px rgba(120, 53, 15, 0.08);--le-shadow-lg:0 10px 15px -3px rgba(120, 53, 15, 0.12), 0 4px 6px -4px rgba(120, 53, 15, 0.1);--le-shadow-xl:0 20px 25px -5px rgba(120, 53, 15, 0.15), 0 8px 10px -6px rgba(120, 53, 15, 0.12);--le-shadow-focus:0 0 0 3px rgba(234, 88, 12, 0.3)}";
@@ -303,12 +340,6 @@ var flush = () => {
303
340
  };
304
341
  var nextTick = (cb) => promiseResolve().then(cb);
305
342
  var writeTask = /* @__PURE__ */ queueTask(queueDomWrites, true);
306
-
307
- // src/runtime/asset-path.ts
308
- var getAssetPath = (path) => {
309
- const assetUrl = new URL(path, plt.$resourcesUrl$);
310
- return assetUrl.origin !== win.location.origin ? assetUrl.href : assetUrl.pathname;
311
- };
312
343
  var isComplexType = (o) => {
313
344
  o = typeof o;
314
345
  return o === "object" || o === "function";
@@ -1781,7 +1812,7 @@ var hostListenerOpts = (flags) => supportsListenerOptions ? {
1781
1812
  // src/runtime/nonce.ts
1782
1813
  var setNonce = (nonce) => plt.$nonce$ = nonce;
1783
1814
 
1784
- export { Fragment as F, Host as H, getMode as a, bootstrapLazy as b, setGlobalMode as c, getTheme as d, setGlobalTheme as e, createEvent as f, globalScripts as g, getElement as h, h as i, getAssetPath as j, promiseResolve as p, registerInstance as r, setNonce as s };
1785
- //# sourceMappingURL=index-CdjJ98OT.js.map
1815
+ export { Fragment as F, Host as H, getMode as a, bootstrapLazy as b, setGlobalMode as c, getTheme as d, setGlobalTheme as e, configureLeki as f, globalScripts as g, getLeKitConfig as h, createEvent as i, getElement as j, h as k, promiseResolve as p, registerInstance as r, setNonce as s };
1816
+ //# sourceMappingURL=index-PS-3Rz-c.js.map
1786
1817
 
1787
- //# sourceMappingURL=index-CdjJ98OT.js.map
1818
+ //# sourceMappingURL=index-PS-3Rz-c.js.map