le-kit 0.5.2 → 0.5.4

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 (475) hide show
  1. package/LLM_CONTEXT.md +22 -33
  2. package/package.json +3 -1
  3. package/readme.md +2 -0
  4. package/dist/cjs/index-BzadfLTc.js +0 -1864
  5. package/dist/cjs/index-BzadfLTc.js.map +0 -1
  6. package/dist/cjs/index.cjs.js +0 -124
  7. package/dist/cjs/index.cjs.js.map +0 -1
  8. package/dist/cjs/le-bar_16.cjs.entry.js +0 -3709
  9. package/dist/cjs/le-box.cjs.entry.js +0 -184
  10. package/dist/cjs/le-card.cjs.entry.js +0 -29
  11. package/dist/cjs/le-code-input.cjs.entry.js +0 -181
  12. package/dist/cjs/le-combobox.cjs.entry.js +0 -237
  13. package/dist/cjs/le-header-placeholder.cjs.entry.js +0 -18
  14. package/dist/cjs/le-kit.cjs.js +0 -27
  15. package/dist/cjs/le-kit.cjs.js.map +0 -1
  16. package/dist/cjs/le-multiselect.cjs.entry.js +0 -306
  17. package/dist/cjs/le-number-input.cjs.entry.js +0 -202
  18. package/dist/cjs/le-round-progress.cjs.entry.js +0 -106
  19. package/dist/cjs/le-segmented-control.cjs.entry.js +0 -245
  20. package/dist/cjs/le-side-panel-toggle.cjs.entry.js +0 -229
  21. package/dist/cjs/le-side-panel.cjs.entry.js +0 -546
  22. package/dist/cjs/le-stack.cjs.entry.js +0 -135
  23. package/dist/cjs/le-tab-bar.cjs.entry.js +0 -242
  24. package/dist/cjs/le-tab-panel.cjs.entry.js +0 -100
  25. package/dist/cjs/le-tab.cjs.entry.js +0 -136
  26. package/dist/cjs/le-tabs.cjs.entry.js +0 -307
  27. package/dist/cjs/le-tag.cjs.entry.js +0 -68
  28. package/dist/cjs/le-text.cjs.entry.js +0 -335
  29. package/dist/cjs/le-turntable.cjs.entry.js +0 -139
  30. package/dist/cjs/loader.cjs.js +0 -15
  31. package/dist/cjs/loader.cjs.js.map +0 -1
  32. package/dist/cjs/utils-Dxx9WhWK.js +0 -152
  33. package/dist/cjs/utils-Dxx9WhWK.js.map +0 -1
  34. package/dist/collection/assets/icons/chevron-down.svg +0 -3
  35. package/dist/collection/collection-manifest.json +0 -47
  36. package/dist/collection/components/le-bar/le-bar.css +0 -255
  37. package/dist/collection/components/le-bar/le-bar.js +0 -680
  38. package/dist/collection/components/le-bar/le-bar.js.map +0 -1
  39. package/dist/collection/components/le-box/le-box.css +0 -37
  40. package/dist/collection/components/le-box/le-box.js +0 -614
  41. package/dist/collection/components/le-box/le-box.js.map +0 -1
  42. package/dist/collection/components/le-button/le-button.css +0 -290
  43. package/dist/collection/components/le-button/le-button.js +0 -460
  44. package/dist/collection/components/le-button/le-button.js.map +0 -1
  45. package/dist/collection/components/le-card/le-card.css +0 -74
  46. package/dist/collection/components/le-card/le-card.js +0 -102
  47. package/dist/collection/components/le-card/le-card.js.map +0 -1
  48. package/dist/collection/components/le-checkbox/le-checkbox.css +0 -93
  49. package/dist/collection/components/le-checkbox/le-checkbox.js +0 -192
  50. package/dist/collection/components/le-checkbox/le-checkbox.js.map +0 -1
  51. package/dist/collection/components/le-code-input/le-code-input.css +0 -106
  52. package/dist/collection/components/le-code-input/le-code-input.js +0 -466
  53. package/dist/collection/components/le-code-input/le-code-input.js.map +0 -1
  54. package/dist/collection/components/le-collapse/le-collapse.css +0 -31
  55. package/dist/collection/components/le-collapse/le-collapse.js +0 -184
  56. package/dist/collection/components/le-collapse/le-collapse.js.map +0 -1
  57. package/dist/collection/components/le-combobox/le-combobox.css +0 -144
  58. package/dist/collection/components/le-combobox/le-combobox.js +0 -659
  59. package/dist/collection/components/le-combobox/le-combobox.js.map +0 -1
  60. package/dist/collection/components/le-component/le-component.css +0 -189
  61. package/dist/collection/components/le-component/le-component.js +0 -367
  62. package/dist/collection/components/le-component/le-component.js.map +0 -1
  63. package/dist/collection/components/le-current-heading/le-current-heading.css +0 -13
  64. package/dist/collection/components/le-current-heading/le-current-heading.js +0 -130
  65. package/dist/collection/components/le-current-heading/le-current-heading.js.map +0 -1
  66. package/dist/collection/components/le-dropdown-base/le-dropdown-base.css +0 -167
  67. package/dist/collection/components/le-dropdown-base/le-dropdown-base.js +0 -761
  68. package/dist/collection/components/le-dropdown-base/le-dropdown-base.js.map +0 -1
  69. package/dist/collection/components/le-header/le-header.css +0 -120
  70. package/dist/collection/components/le-header/le-header.js +0 -508
  71. package/dist/collection/components/le-header/le-header.js.map +0 -1
  72. package/dist/collection/components/le-header-placeholder/le-header-placeholder.js +0 -21
  73. package/dist/collection/components/le-header-placeholder/le-header-placeholder.js.map +0 -1
  74. package/dist/collection/components/le-icon/le-icon.css +0 -13
  75. package/dist/collection/components/le-icon/le-icon.js +0 -185
  76. package/dist/collection/components/le-icon/le-icon.js.map +0 -1
  77. package/dist/collection/components/le-multiselect/le-multiselect.css +0 -163
  78. package/dist/collection/components/le-multiselect/le-multiselect.js +0 -734
  79. package/dist/collection/components/le-multiselect/le-multiselect.js.map +0 -1
  80. package/dist/collection/components/le-navigation/le-navigation.css +0 -330
  81. package/dist/collection/components/le-navigation/le-navigation.js +0 -700
  82. package/dist/collection/components/le-navigation/le-navigation.js.map +0 -1
  83. package/dist/collection/components/le-number-input/le-number-input.css +0 -135
  84. package/dist/collection/components/le-number-input/le-number-input.js +0 -515
  85. package/dist/collection/components/le-number-input/le-number-input.js.map +0 -1
  86. package/dist/collection/components/le-popover/le-popover.css +0 -163
  87. package/dist/collection/components/le-popover/le-popover.js +0 -853
  88. package/dist/collection/components/le-popover/le-popover.js.map +0 -1
  89. package/dist/collection/components/le-popup/le-popup.api.js +0 -102
  90. package/dist/collection/components/le-popup/le-popup.api.js.map +0 -1
  91. package/dist/collection/components/le-popup/le-popup.css +0 -222
  92. package/dist/collection/components/le-popup/le-popup.js +0 -626
  93. package/dist/collection/components/le-popup/le-popup.js.map +0 -1
  94. package/dist/collection/components/le-round-progress/le-round-progress.css +0 -34
  95. package/dist/collection/components/le-round-progress/le-round-progress.js +0 -184
  96. package/dist/collection/components/le-round-progress/le-round-progress.js.map +0 -1
  97. package/dist/collection/components/le-scroll-progress/le-scroll-progress.css +0 -29
  98. package/dist/collection/components/le-scroll-progress/le-scroll-progress.js +0 -186
  99. package/dist/collection/components/le-scroll-progress/le-scroll-progress.js.map +0 -1
  100. package/dist/collection/components/le-segmented-control/le-segmented-control.css +0 -78
  101. package/dist/collection/components/le-segmented-control/le-segmented-control.js +0 -445
  102. package/dist/collection/components/le-segmented-control/le-segmented-control.js.map +0 -1
  103. package/dist/collection/components/le-select/le-select.css +0 -121
  104. package/dist/collection/components/le-select/le-select.js +0 -578
  105. package/dist/collection/components/le-select/le-select.js.map +0 -1
  106. package/dist/collection/components/le-side-panel/le-side-panel.css +0 -193
  107. package/dist/collection/components/le-side-panel/le-side-panel.js +0 -953
  108. package/dist/collection/components/le-side-panel/le-side-panel.js.map +0 -1
  109. package/dist/collection/components/le-side-panel-toggle/le-side-panel-toggle.js +0 -610
  110. package/dist/collection/components/le-side-panel-toggle/le-side-panel-toggle.js.map +0 -1
  111. package/dist/collection/components/le-slot/le-slot.default.css +0 -222
  112. package/dist/collection/components/le-slot/le-slot.js +0 -638
  113. package/dist/collection/components/le-slot/le-slot.js.map +0 -1
  114. package/dist/collection/components/le-stack/le-stack.default.css +0 -37
  115. package/dist/collection/components/le-stack/le-stack.js +0 -389
  116. package/dist/collection/components/le-stack/le-stack.js.map +0 -1
  117. package/dist/collection/components/le-string-input/le-string-input.css +0 -83
  118. package/dist/collection/components/le-string-input/le-string-input.js +0 -413
  119. package/dist/collection/components/le-string-input/le-string-input.js.map +0 -1
  120. package/dist/collection/components/le-tab/le-tab.css +0 -289
  121. package/dist/collection/components/le-tab/le-tab.js +0 -565
  122. package/dist/collection/components/le-tab/le-tab.js.map +0 -1
  123. package/dist/collection/components/le-tab-bar/le-tab-bar.css +0 -89
  124. package/dist/collection/components/le-tab-bar/le-tab-bar.js +0 -467
  125. package/dist/collection/components/le-tab-bar/le-tab-bar.js.map +0 -1
  126. package/dist/collection/components/le-tab-panel/le-tab-panel.css +0 -30
  127. package/dist/collection/components/le-tab-panel/le-tab-panel.js +0 -302
  128. package/dist/collection/components/le-tab-panel/le-tab-panel.js.map +0 -1
  129. package/dist/collection/components/le-tabs/le-tabs.css +0 -146
  130. package/dist/collection/components/le-tabs/le-tabs.js +0 -588
  131. package/dist/collection/components/le-tabs/le-tabs.js.map +0 -1
  132. package/dist/collection/components/le-tag/le-tag.css +0 -139
  133. package/dist/collection/components/le-tag/le-tag.js +0 -266
  134. package/dist/collection/components/le-tag/le-tag.js.map +0 -1
  135. package/dist/collection/components/le-text/le-text.css +0 -169
  136. package/dist/collection/components/le-text/le-text.js +0 -475
  137. package/dist/collection/components/le-text/le-text.js.map +0 -1
  138. package/dist/collection/components/le-turntable/le-turntable.css +0 -10
  139. package/dist/collection/components/le-turntable/le-turntable.js +0 -210
  140. package/dist/collection/components/le-turntable/le-turntable.js.map +0 -1
  141. package/dist/collection/dist/components/assets/custom-elements.json +0 -11935
  142. package/dist/collection/dist/components/assets/icons/chevron-down.json +0 -13
  143. package/dist/collection/dist/components/assets/icons/chevron-down.svg +0 -3
  144. package/dist/collection/dist/components/assets/icons/ellipsis-horizontal.json +0 -14
  145. package/dist/collection/dist/components/assets/icons/ellipsis-vertical.json +0 -14
  146. package/dist/collection/dist/components/assets/icons/hamburger.json +0 -14
  147. package/dist/collection/dist/components/assets/icons/side-panel.json +0 -61
  148. package/dist/collection/dist/themes/base.css +0 -89
  149. package/dist/collection/dist/themes/dark.css +0 -104
  150. package/dist/collection/dist/themes/default.css +0 -112
  151. package/dist/collection/dist/themes/gradient.css +0 -104
  152. package/dist/collection/dist/themes/index.css +0 -76
  153. package/dist/collection/dist/themes/minimal.css +0 -104
  154. package/dist/collection/dist/themes/warm.css +0 -104
  155. package/dist/collection/global/app.js +0 -177
  156. package/dist/collection/global/app.js.map +0 -1
  157. package/dist/collection/index.js +0 -16
  158. package/dist/collection/index.js.map +0 -1
  159. package/dist/collection/types/blocks.js +0 -115
  160. package/dist/collection/types/blocks.js.map +0 -1
  161. package/dist/collection/types/options.js +0 -2
  162. package/dist/collection/types/options.js.map +0 -1
  163. package/dist/collection/utils/utils.js +0 -141
  164. package/dist/collection/utils/utils.js.map +0 -1
  165. package/dist/components/app.js +0 -180
  166. package/dist/components/app.js.map +0 -1
  167. package/dist/components/assets/custom-elements.json +0 -11935
  168. package/dist/components/assets/icons/chevron-down.json +0 -13
  169. package/dist/components/assets/icons/chevron-down.svg +0 -3
  170. package/dist/components/assets/icons/ellipsis-horizontal.json +0 -14
  171. package/dist/components/assets/icons/ellipsis-vertical.json +0 -14
  172. package/dist/components/assets/icons/hamburger.json +0 -14
  173. package/dist/components/assets/icons/side-panel.json +0 -61
  174. package/dist/components/index.d.ts +0 -33
  175. package/dist/components/index.js +0 -12
  176. package/dist/components/index.js.map +0 -1
  177. package/dist/components/le-bar.d.ts +0 -11
  178. package/dist/components/le-bar.js +0 -9
  179. package/dist/components/le-bar.js.map +0 -1
  180. package/dist/components/le-bar2.js +0 -506
  181. package/dist/components/le-bar2.js.map +0 -1
  182. package/dist/components/le-box.d.ts +0 -11
  183. package/dist/components/le-box.js +0 -273
  184. package/dist/components/le-box.js.map +0 -1
  185. package/dist/components/le-button.d.ts +0 -11
  186. package/dist/components/le-button.js +0 -9
  187. package/dist/components/le-button.js.map +0 -1
  188. package/dist/components/le-button2.js +0 -1791
  189. package/dist/components/le-button2.js.map +0 -1
  190. package/dist/components/le-card.d.ts +0 -11
  191. package/dist/components/le-card.js +0 -100
  192. package/dist/components/le-card.js.map +0 -1
  193. package/dist/components/le-checkbox.d.ts +0 -11
  194. package/dist/components/le-checkbox.js +0 -9
  195. package/dist/components/le-checkbox.js.map +0 -1
  196. package/dist/components/le-code-input.d.ts +0 -11
  197. package/dist/components/le-code-input.js +0 -265
  198. package/dist/components/le-code-input.js.map +0 -1
  199. package/dist/components/le-collapse.d.ts +0 -11
  200. package/dist/components/le-collapse.js +0 -9
  201. package/dist/components/le-collapse.js.map +0 -1
  202. package/dist/components/le-collapse2.js +0 -138
  203. package/dist/components/le-collapse2.js.map +0 -1
  204. package/dist/components/le-combobox.d.ts +0 -11
  205. package/dist/components/le-combobox.js +0 -326
  206. package/dist/components/le-combobox.js.map +0 -1
  207. package/dist/components/le-component.d.ts +0 -11
  208. package/dist/components/le-component.js +0 -9
  209. package/dist/components/le-component.js.map +0 -1
  210. package/dist/components/le-current-heading.d.ts +0 -11
  211. package/dist/components/le-current-heading.js +0 -93
  212. package/dist/components/le-current-heading.js.map +0 -1
  213. package/dist/components/le-dropdown-base.d.ts +0 -11
  214. package/dist/components/le-dropdown-base.js +0 -9
  215. package/dist/components/le-dropdown-base.js.map +0 -1
  216. package/dist/components/le-dropdown-base2.js +0 -393
  217. package/dist/components/le-dropdown-base2.js.map +0 -1
  218. package/dist/components/le-header-placeholder.d.ts +0 -11
  219. package/dist/components/le-header-placeholder.js +0 -37
  220. package/dist/components/le-header-placeholder.js.map +0 -1
  221. package/dist/components/le-header.d.ts +0 -11
  222. package/dist/components/le-header.js +0 -349
  223. package/dist/components/le-header.js.map +0 -1
  224. package/dist/components/le-icon.d.ts +0 -11
  225. package/dist/components/le-icon.js +0 -9
  226. package/dist/components/le-icon.js.map +0 -1
  227. package/dist/components/le-icon2.js +0 -150
  228. package/dist/components/le-icon2.js.map +0 -1
  229. package/dist/components/le-multiselect.d.ts +0 -11
  230. package/dist/components/le-multiselect.js +0 -405
  231. package/dist/components/le-multiselect.js.map +0 -1
  232. package/dist/components/le-navigation.d.ts +0 -11
  233. package/dist/components/le-navigation.js +0 -502
  234. package/dist/components/le-navigation.js.map +0 -1
  235. package/dist/components/le-number-input.d.ts +0 -11
  236. package/dist/components/le-number-input.js +0 -288
  237. package/dist/components/le-number-input.js.map +0 -1
  238. package/dist/components/le-popover.d.ts +0 -11
  239. package/dist/components/le-popover.js +0 -9
  240. package/dist/components/le-popover.js.map +0 -1
  241. package/dist/components/le-popover2.js +0 -667
  242. package/dist/components/le-popover2.js.map +0 -1
  243. package/dist/components/le-popup.api.js +0 -106
  244. package/dist/components/le-popup.api.js.map +0 -1
  245. package/dist/components/le-popup.d.ts +0 -11
  246. package/dist/components/le-popup.js +0 -9
  247. package/dist/components/le-popup.js.map +0 -1
  248. package/dist/components/le-round-progress.d.ts +0 -11
  249. package/dist/components/le-round-progress.js +0 -135
  250. package/dist/components/le-round-progress.js.map +0 -1
  251. package/dist/components/le-scroll-progress.d.ts +0 -11
  252. package/dist/components/le-scroll-progress.js +0 -142
  253. package/dist/components/le-scroll-progress.js.map +0 -1
  254. package/dist/components/le-segmented-control.d.ts +0 -11
  255. package/dist/components/le-segmented-control.js +0 -331
  256. package/dist/components/le-segmented-control.js.map +0 -1
  257. package/dist/components/le-select.d.ts +0 -11
  258. package/dist/components/le-select.js +0 -9
  259. package/dist/components/le-select.js.map +0 -1
  260. package/dist/components/le-side-panel-toggle.d.ts +0 -11
  261. package/dist/components/le-side-panel-toggle.js +0 -9
  262. package/dist/components/le-side-panel-toggle.js.map +0 -1
  263. package/dist/components/le-side-panel-toggle2.js +0 -311
  264. package/dist/components/le-side-panel-toggle2.js.map +0 -1
  265. package/dist/components/le-side-panel.d.ts +0 -11
  266. package/dist/components/le-side-panel.js +0 -660
  267. package/dist/components/le-side-panel.js.map +0 -1
  268. package/dist/components/le-slot.d.ts +0 -11
  269. package/dist/components/le-slot.js +0 -9
  270. package/dist/components/le-slot.js.map +0 -1
  271. package/dist/components/le-stack.d.ts +0 -11
  272. package/dist/components/le-stack.js +0 -215
  273. package/dist/components/le-stack.js.map +0 -1
  274. package/dist/components/le-string-input.d.ts +0 -11
  275. package/dist/components/le-string-input.js +0 -9
  276. package/dist/components/le-string-input.js.map +0 -1
  277. package/dist/components/le-tab-bar.d.ts +0 -11
  278. package/dist/components/le-tab-bar.js +0 -330
  279. package/dist/components/le-tab-bar.js.map +0 -1
  280. package/dist/components/le-tab-panel.d.ts +0 -11
  281. package/dist/components/le-tab-panel.js +0 -182
  282. package/dist/components/le-tab-panel.js.map +0 -1
  283. package/dist/components/le-tab.d.ts +0 -11
  284. package/dist/components/le-tab.js +0 -9
  285. package/dist/components/le-tab.js.map +0 -1
  286. package/dist/components/le-tab2.js +0 -220
  287. package/dist/components/le-tab2.js.map +0 -1
  288. package/dist/components/le-tabs.d.ts +0 -11
  289. package/dist/components/le-tabs.js +0 -397
  290. package/dist/components/le-tabs.js.map +0 -1
  291. package/dist/components/le-tag.d.ts +0 -11
  292. package/dist/components/le-tag.js +0 -9
  293. package/dist/components/le-tag.js.map +0 -1
  294. package/dist/components/le-tag2.js +0 -141
  295. package/dist/components/le-tag2.js.map +0 -1
  296. package/dist/components/le-text.d.ts +0 -11
  297. package/dist/components/le-text.js +0 -415
  298. package/dist/components/le-text.js.map +0 -1
  299. package/dist/components/le-turntable.d.ts +0 -11
  300. package/dist/components/le-turntable.js +0 -164
  301. package/dist/components/le-turntable.js.map +0 -1
  302. package/dist/components/utils.js +0 -146
  303. package/dist/components/utils.js.map +0 -1
  304. package/dist/docs.d.ts +0 -443
  305. package/dist/docs.json +0 -14289
  306. package/dist/esm/index-DFTm5BqT.js +0 -1844
  307. package/dist/esm/index-DFTm5BqT.js.map +0 -1
  308. package/dist/esm/index.js +0 -109
  309. package/dist/esm/index.js.map +0 -1
  310. package/dist/esm/le-bar_16.entry.js +0 -3692
  311. package/dist/esm/le-box.entry.js +0 -182
  312. package/dist/esm/le-box.entry.js.map +0 -1
  313. package/dist/esm/le-card.entry.js +0 -27
  314. package/dist/esm/le-card.entry.js.map +0 -1
  315. package/dist/esm/le-code-input.entry.js +0 -179
  316. package/dist/esm/le-code-input.entry.js.map +0 -1
  317. package/dist/esm/le-combobox.entry.js +0 -235
  318. package/dist/esm/le-combobox.entry.js.map +0 -1
  319. package/dist/esm/le-header-placeholder.entry.js +0 -16
  320. package/dist/esm/le-header-placeholder.entry.js.map +0 -1
  321. package/dist/esm/le-kit.js +0 -23
  322. package/dist/esm/le-kit.js.map +0 -1
  323. package/dist/esm/le-multiselect.entry.js +0 -304
  324. package/dist/esm/le-multiselect.entry.js.map +0 -1
  325. package/dist/esm/le-number-input.entry.js +0 -200
  326. package/dist/esm/le-number-input.entry.js.map +0 -1
  327. package/dist/esm/le-round-progress.entry.js +0 -104
  328. package/dist/esm/le-round-progress.entry.js.map +0 -1
  329. package/dist/esm/le-segmented-control.entry.js +0 -243
  330. package/dist/esm/le-segmented-control.entry.js.map +0 -1
  331. package/dist/esm/le-side-panel-toggle.entry.js +0 -227
  332. package/dist/esm/le-side-panel-toggle.entry.js.map +0 -1
  333. package/dist/esm/le-side-panel.entry.js +0 -544
  334. package/dist/esm/le-side-panel.entry.js.map +0 -1
  335. package/dist/esm/le-stack.entry.js +0 -133
  336. package/dist/esm/le-stack.entry.js.map +0 -1
  337. package/dist/esm/le-tab-bar.entry.js +0 -240
  338. package/dist/esm/le-tab-bar.entry.js.map +0 -1
  339. package/dist/esm/le-tab-panel.entry.js +0 -98
  340. package/dist/esm/le-tab-panel.entry.js.map +0 -1
  341. package/dist/esm/le-tab.entry.js +0 -134
  342. package/dist/esm/le-tab.entry.js.map +0 -1
  343. package/dist/esm/le-tabs.entry.js +0 -305
  344. package/dist/esm/le-tabs.entry.js.map +0 -1
  345. package/dist/esm/le-tag.entry.js +0 -66
  346. package/dist/esm/le-tag.entry.js.map +0 -1
  347. package/dist/esm/le-text.entry.js +0 -333
  348. package/dist/esm/le-text.entry.js.map +0 -1
  349. package/dist/esm/le-turntable.entry.js +0 -137
  350. package/dist/esm/le-turntable.entry.js.map +0 -1
  351. package/dist/esm/loader.js +0 -13
  352. package/dist/esm/loader.js.map +0 -1
  353. package/dist/esm/utils-DZYCZLrF.js +0 -146
  354. package/dist/esm/utils-DZYCZLrF.js.map +0 -1
  355. package/dist/index.cjs.js +0 -1
  356. package/dist/index.js +0 -1
  357. package/dist/le-kit/dist/components/assets/custom-elements.json +0 -11935
  358. package/dist/le-kit/dist/components/assets/icons/chevron-down.json +0 -13
  359. package/dist/le-kit/dist/components/assets/icons/chevron-down.svg +0 -3
  360. package/dist/le-kit/dist/components/assets/icons/ellipsis-horizontal.json +0 -14
  361. package/dist/le-kit/dist/components/assets/icons/ellipsis-vertical.json +0 -14
  362. package/dist/le-kit/dist/components/assets/icons/hamburger.json +0 -14
  363. package/dist/le-kit/dist/components/assets/icons/side-panel.json +0 -61
  364. package/dist/le-kit/dist/themes/base.css +0 -89
  365. package/dist/le-kit/dist/themes/dark.css +0 -104
  366. package/dist/le-kit/dist/themes/default.css +0 -112
  367. package/dist/le-kit/dist/themes/gradient.css +0 -104
  368. package/dist/le-kit/dist/themes/index.css +0 -76
  369. package/dist/le-kit/dist/themes/minimal.css +0 -104
  370. package/dist/le-kit/dist/themes/warm.css +0 -104
  371. package/dist/le-kit/index.esm.js +0 -2
  372. package/dist/le-kit/index.esm.js.map +0 -1
  373. package/dist/le-kit/le-kit.css +0 -1
  374. package/dist/le-kit/le-kit.esm.js +0 -2
  375. package/dist/le-kit/le-kit.esm.js.map +0 -1
  376. package/dist/le-kit/loader.esm.js.map +0 -1
  377. package/dist/le-kit/p-221d379a.entry.js +0 -2
  378. package/dist/le-kit/p-221d379a.entry.js.map +0 -1
  379. package/dist/le-kit/p-24112ca3.entry.js +0 -2
  380. package/dist/le-kit/p-24112ca3.entry.js.map +0 -1
  381. package/dist/le-kit/p-2c6d080d.entry.js +0 -2
  382. package/dist/le-kit/p-2c6d080d.entry.js.map +0 -1
  383. package/dist/le-kit/p-46276e77.entry.js +0 -2
  384. package/dist/le-kit/p-46276e77.entry.js.map +0 -1
  385. package/dist/le-kit/p-516c8531.entry.js +0 -2
  386. package/dist/le-kit/p-516c8531.entry.js.map +0 -1
  387. package/dist/le-kit/p-6ae60ba5.entry.js +0 -2
  388. package/dist/le-kit/p-6ae60ba5.entry.js.map +0 -1
  389. package/dist/le-kit/p-6b69f9a2.entry.js +0 -2
  390. package/dist/le-kit/p-6b69f9a2.entry.js.map +0 -1
  391. package/dist/le-kit/p-6d14306f.entry.js +0 -2
  392. package/dist/le-kit/p-6d14306f.entry.js.map +0 -1
  393. package/dist/le-kit/p-7bcdf2d4.entry.js +0 -2
  394. package/dist/le-kit/p-7bcdf2d4.entry.js.map +0 -1
  395. package/dist/le-kit/p-7cf1e23c.entry.js +0 -2
  396. package/dist/le-kit/p-7cf1e23c.entry.js.map +0 -1
  397. package/dist/le-kit/p-85f2fd4d.entry.js +0 -2
  398. package/dist/le-kit/p-85f2fd4d.entry.js.map +0 -1
  399. package/dist/le-kit/p-98242429.entry.js +0 -2
  400. package/dist/le-kit/p-98242429.entry.js.map +0 -1
  401. package/dist/le-kit/p-D8RYDS9p.js +0 -2
  402. package/dist/le-kit/p-D8RYDS9p.js.map +0 -1
  403. package/dist/le-kit/p-DFTm5BqT.js +0 -3
  404. package/dist/le-kit/p-DFTm5BqT.js.map +0 -1
  405. package/dist/le-kit/p-ab6c1def.entry.js +0 -2
  406. package/dist/le-kit/p-ab6c1def.entry.js.map +0 -1
  407. package/dist/le-kit/p-ae4ead64.entry.js +0 -2
  408. package/dist/le-kit/p-ae4ead64.entry.js.map +0 -1
  409. package/dist/le-kit/p-b05d4511.entry.js +0 -2
  410. package/dist/le-kit/p-b05d4511.entry.js.map +0 -1
  411. package/dist/le-kit/p-b6ac02ff.entry.js +0 -2
  412. package/dist/le-kit/p-b6ac02ff.entry.js.map +0 -1
  413. package/dist/le-kit/p-c24769e2.entry.js +0 -2
  414. package/dist/le-kit/p-c24769e2.entry.js.map +0 -1
  415. package/dist/le-kit/p-dc0445ad.entry.js +0 -2
  416. package/dist/le-kit/p-dc0445ad.entry.js.map +0 -1
  417. package/dist/le-kit/p-eb5286f2.entry.js +0 -2
  418. package/dist/le-kit/p-eb5286f2.entry.js.map +0 -1
  419. package/dist/le-kit/p-f78b1ee6.entry.js +0 -2
  420. package/dist/le-kit/p-f78b1ee6.entry.js.map +0 -1
  421. package/dist/themes/base.css +0 -89
  422. package/dist/themes/dark.css +0 -104
  423. package/dist/themes/default.css +0 -112
  424. package/dist/themes/gradient.css +0 -104
  425. package/dist/themes/index.css +0 -76
  426. package/dist/themes/minimal.css +0 -104
  427. package/dist/themes/warm.css +0 -104
  428. package/dist/types/components/le-bar/le-bar.d.ts +0 -131
  429. package/dist/types/components/le-box/le-box.d.ts +0 -111
  430. package/dist/types/components/le-button/le-button.d.ts +0 -93
  431. package/dist/types/components/le-card/le-card.d.ts +0 -37
  432. package/dist/types/components/le-checkbox/le-checkbox.d.ts +0 -46
  433. package/dist/types/components/le-code-input/le-code-input.d.ts +0 -102
  434. package/dist/types/components/le-collapse/le-collapse.d.ts +0 -43
  435. package/dist/types/components/le-combobox/le-combobox.d.ts +0 -128
  436. package/dist/types/components/le-component/le-component.d.ts +0 -115
  437. package/dist/types/components/le-current-heading/le-current-heading.d.ts +0 -25
  438. package/dist/types/components/le-dropdown-base/le-dropdown-base.d.ts +0 -118
  439. package/dist/types/components/le-header/le-header.d.ts +0 -115
  440. package/dist/types/components/le-header-placeholder/le-header-placeholder.d.ts +0 -13
  441. package/dist/types/components/le-icon/le-icon.d.ts +0 -28
  442. package/dist/types/components/le-multiselect/le-multiselect.d.ts +0 -143
  443. package/dist/types/components/le-navigation/le-navigation.d.ts +0 -125
  444. package/dist/types/components/le-number-input/le-number-input.d.ts +0 -106
  445. package/dist/types/components/le-popover/le-popover.d.ts +0 -129
  446. package/dist/types/components/le-popup/le-popup.api.d.ts +0 -73
  447. package/dist/types/components/le-popup/le-popup.d.ts +0 -127
  448. package/dist/types/components/le-round-progress/le-round-progress.d.ts +0 -37
  449. package/dist/types/components/le-scroll-progress/le-scroll-progress.d.ts +0 -40
  450. package/dist/types/components/le-segmented-control/le-segmented-control.d.ts +0 -82
  451. package/dist/types/components/le-select/le-select.d.ts +0 -125
  452. package/dist/types/components/le-side-panel/le-side-panel.d.ts +0 -100
  453. package/dist/types/components/le-side-panel-toggle/le-side-panel-toggle.d.ts +0 -48
  454. package/dist/types/components/le-slot/le-slot.d.ts +0 -149
  455. package/dist/types/components/le-stack/le-stack.d.ts +0 -73
  456. package/dist/types/components/le-string-input/le-string-input.d.ts +0 -91
  457. package/dist/types/components/le-tab/le-tab.d.ts +0 -116
  458. package/dist/types/components/le-tab-bar/le-tab-bar.d.ts +0 -88
  459. package/dist/types/components/le-tab-panel/le-tab-panel.d.ts +0 -75
  460. package/dist/types/components/le-tabs/le-tabs.d.ts +0 -108
  461. package/dist/types/components/le-tag/le-tag.d.ts +0 -78
  462. package/dist/types/components/le-text/le-text.d.ts +0 -141
  463. package/dist/types/components/le-turntable/le-turntable.d.ts +0 -55
  464. package/dist/types/components.d.ts +0 -5716
  465. package/dist/types/global/app.d.ts +0 -96
  466. package/dist/types/index.d.ts +0 -16
  467. package/dist/types/stencil-public-runtime.d.ts +0 -1799
  468. package/dist/types/types/blocks.d.ts +0 -136
  469. package/dist/types/types/options.d.ts +0 -143
  470. package/dist/types/utils/utils.d.ts +0 -54
  471. package/loader/cdn.js +0 -1
  472. package/loader/index.cjs.js +0 -1
  473. package/loader/index.d.ts +0 -24
  474. package/loader/index.es2017.js +0 -1
  475. package/loader/index.js +0 -2
@@ -1,953 +0,0 @@
1
- import { Build, h, } from "@stencil/core";
2
- function clamp(value, min, max) {
3
- return Math.min(max, Math.max(min, value));
4
- }
5
- function readCssVariablePixels(varName) {
6
- if (!Build.isBrowser) {
7
- return undefined;
8
- }
9
- const v = getComputedStyle(document.documentElement).getPropertyValue(varName).trim();
10
- if (!v) {
11
- return undefined;
12
- }
13
- const parsed = Number.parseFloat(v);
14
- return Number.isFinite(parsed) ? parsed : undefined;
15
- }
16
- function parseCollapseAtPx(value) {
17
- if (!value) {
18
- return undefined;
19
- }
20
- const trimmed = value.trim();
21
- if (!trimmed) {
22
- return undefined;
23
- }
24
- if (trimmed.startsWith('--')) {
25
- const fromVar = readCssVariablePixels(trimmed);
26
- return fromVar;
27
- }
28
- const numeric = Number.parseFloat(trimmed);
29
- return Number.isFinite(numeric) ? numeric : undefined;
30
- }
31
- export class LeSidePanel {
32
- el;
33
- /**
34
- * Optional id used to match toggle requests.
35
- * If set, the panel only responds to toggle events with the same `panelId`.
36
- */
37
- panelId;
38
- /** Which side the panel is attached to. */
39
- side = 'start';
40
- /** Width breakpoint (in px or a CSS var like `--le-breakpoint-md`) below which the panel enters "narrow" mode. */
41
- collapseAt;
42
- /** Behavior when in narrow mode. */
43
- narrowBehavior = 'overlay';
44
- /**
45
- * Panel open state for narrow mode.
46
- * - overlay: controls modal drawer visibility
47
- * - push: controls whether panel is shown (non-modal)
48
- */
49
- open = false;
50
- /** Panel collapsed state for wide mode (fully hidden). */
51
- collapsed = false;
52
- /** Default panel width in pixels. */
53
- panelWidth = 280;
54
- /** Minimum allowed width when resizable. */
55
- minPanelWidth = 220;
56
- /** Maximum allowed width when resizable. */
57
- maxPanelWidth = 420;
58
- /** Allows users to resize the panel by dragging its edge. */
59
- resizable = false;
60
- /** When set, panel width + collapsed state are persisted in localStorage. */
61
- persistKey;
62
- /** Show a close button inside the panel (primarily used in narrow overlay mode). */
63
- showCloseButton = true;
64
- /** When crossing to wide mode, automatically show the panel (collapsed=false). */
65
- autoShowOnWide = true;
66
- /** When crossing to narrow mode, automatically hide the panel (open=false). */
67
- autoHideOnNarrow = true;
68
- /** Accessible label for the panel navigation region. */
69
- panelLabel = 'Navigation';
70
- leSidePanelOpenChange;
71
- leSidePanelCollapsedChange;
72
- leSidePanelWidthChange;
73
- isNarrow = false;
74
- responsiveReady = false;
75
- overlayMounted = false;
76
- overlayVisible = false;
77
- currentWidthPx;
78
- resizing = false;
79
- resizeObserver;
80
- panelEl;
81
- overlayWrapEl;
82
- focusedBeforeOpen;
83
- dragPointerId;
84
- dragStartX;
85
- dragStartWidth;
86
- connectedCallback() {
87
- this.restorePersistedState();
88
- this.currentWidthPx = clamp(this.currentWidthPx || this.panelWidth, this.minPanelWidth, this.maxPanelWidth);
89
- if (Build.isBrowser && 'ResizeObserver' in window) {
90
- this.resizeObserver = new ResizeObserver(() => {
91
- this.recomputeNarrow();
92
- });
93
- this.resizeObserver.observe(this.el);
94
- }
95
- // Ensure we get at least one post-layout measurement.
96
- if (Build.isBrowser) {
97
- requestAnimationFrame(() => this.recomputeNarrow());
98
- }
99
- }
100
- componentWillLoad() {
101
- this.recomputeNarrow();
102
- }
103
- disconnectedCallback() {
104
- this.resizeObserver?.disconnect();
105
- this.teardownDragListeners();
106
- }
107
- isModalOverlayActive() {
108
- return this.isNarrow && this.narrowBehavior === 'overlay' && this.open;
109
- }
110
- syncOverlayToState() {
111
- const shouldUseOverlay = this.isNarrow && this.narrowBehavior === 'overlay';
112
- if (!shouldUseOverlay) {
113
- this.overlayVisible = false;
114
- this.overlayMounted = false;
115
- return;
116
- }
117
- if (this.open) {
118
- if (!this.overlayMounted) {
119
- this.overlayMounted = true;
120
- this.overlayVisible = false;
121
- requestAnimationFrame(() => {
122
- if (this.isNarrow && this.narrowBehavior === 'overlay' && this.open) {
123
- this.overlayVisible = true;
124
- this.focusFirstInsidePanel();
125
- }
126
- });
127
- }
128
- return;
129
- }
130
- // Closed: allow unmount to be handled by transition end / fallback timeout.
131
- this.overlayVisible = false;
132
- }
133
- onPanelWidthChanged() {
134
- if (!Number.isFinite(this.panelWidth)) {
135
- return;
136
- }
137
- if (!this.resizing) {
138
- this.currentWidthPx = clamp(this.panelWidth, this.minPanelWidth, this.maxPanelWidth);
139
- this.persistState();
140
- }
141
- }
142
- onCollapsedChanged() {
143
- this.persistState();
144
- this.leSidePanelCollapsedChange.emit({ collapsed: this.collapsed, panelId: this.panelId });
145
- }
146
- onOpenChanged(newValue) {
147
- const shouldUseOverlay = this.isNarrow && this.narrowBehavior === 'overlay';
148
- if (!shouldUseOverlay) {
149
- this.persistState();
150
- this.leSidePanelOpenChange.emit({ open: this.open, panelId: this.panelId });
151
- return;
152
- }
153
- if (newValue) {
154
- this.focusedBeforeOpen = document.activeElement || null;
155
- this.overlayMounted = true;
156
- this.overlayVisible = false;
157
- requestAnimationFrame(() => {
158
- this.overlayVisible = true;
159
- this.focusFirstInsidePanel();
160
- });
161
- }
162
- else {
163
- this.overlayVisible = false;
164
- this.persistState();
165
- this.restoreFocusAfterClose();
166
- // Fallback: if transitionend doesn't fire, ensure overlay unmounts.
167
- // (e.g. interrupted transitions or unusual browser behavior)
168
- window.setTimeout(() => {
169
- const shouldUseOverlay = this.isNarrow && this.narrowBehavior === 'overlay';
170
- if (shouldUseOverlay && !this.open && !this.overlayVisible) {
171
- this.overlayMounted = false;
172
- }
173
- }, 350);
174
- }
175
- this.leSidePanelOpenChange.emit({ open: this.open, panelId: this.panelId });
176
- }
177
- onResponsivePropChanged() {
178
- this.recomputeNarrow();
179
- }
180
- onDocumentKeyDown(ev) {
181
- if (!Build.isBrowser) {
182
- return;
183
- }
184
- if (!this.isModalOverlayActive()) {
185
- return;
186
- }
187
- if (ev.key === 'Escape') {
188
- ev.preventDefault();
189
- ev.stopPropagation();
190
- this.open = false;
191
- return;
192
- }
193
- if (ev.key !== 'Tab') {
194
- return;
195
- }
196
- const panel = this.panelEl;
197
- if (!panel) {
198
- return;
199
- }
200
- const focusables = this.getFocusableElements(panel);
201
- if (focusables.length === 0) {
202
- ev.preventDefault();
203
- try {
204
- panel.focus();
205
- }
206
- catch {
207
- // ignore
208
- }
209
- return;
210
- }
211
- const first = focusables[0];
212
- const last = focusables[focusables.length - 1];
213
- const active = document.activeElement;
214
- if (ev.shiftKey) {
215
- if (!active || active === first || !panel.contains(active)) {
216
- ev.preventDefault();
217
- try {
218
- last.focus();
219
- }
220
- catch {
221
- // ignore
222
- }
223
- }
224
- }
225
- else {
226
- if (active === last) {
227
- ev.preventDefault();
228
- try {
229
- first.focus();
230
- }
231
- catch {
232
- // ignore
233
- }
234
- }
235
- }
236
- }
237
- onToggleRequest(ev) {
238
- const detail = ev.detail;
239
- if (!detail || !detail.action) {
240
- return;
241
- }
242
- // panelId matching rules:
243
- // - If this panel has panelId: respond only when detail.panelId matches.
244
- // - If this panel has no panelId: respond only when detail.panelId is empty.
245
- const requestedId = detail.panelId || '';
246
- const myId = this.panelId || '';
247
- if (myId !== requestedId) {
248
- return;
249
- }
250
- if (this.isNarrow) {
251
- this.applyActionToOpen(detail.action);
252
- }
253
- else {
254
- this.applyActionToCollapsed(detail.action);
255
- }
256
- }
257
- applyActionToOpen(action) {
258
- if (action === 'open') {
259
- this.open = true;
260
- return;
261
- }
262
- if (action === 'close') {
263
- this.open = false;
264
- return;
265
- }
266
- this.open = !this.open;
267
- }
268
- applyActionToCollapsed(action) {
269
- if (action === 'open') {
270
- this.collapsed = false;
271
- return;
272
- }
273
- if (action === 'close') {
274
- this.collapsed = true;
275
- return;
276
- }
277
- this.collapsed = !this.collapsed;
278
- }
279
- recomputeNarrow() {
280
- const collapseAtPx = parseCollapseAtPx(this.collapseAt);
281
- if (!collapseAtPx) {
282
- this.isNarrow = false;
283
- this.responsiveReady = true;
284
- this.syncOverlayToState();
285
- return;
286
- }
287
- const width = this.el.clientWidth;
288
- // If we can't measure yet (common on first paint), don't guess a mode.
289
- // This prevents a brief "wide" flash before ResizeObserver kicks in.
290
- if (!(width > 0)) {
291
- this.responsiveReady = false;
292
- return;
293
- }
294
- this.responsiveReady = true;
295
- const nextIsNarrow = width < collapseAtPx;
296
- const prevIsNarrow = this.isNarrow;
297
- this.isNarrow = nextIsNarrow;
298
- if (prevIsNarrow !== nextIsNarrow) {
299
- if (nextIsNarrow) {
300
- if (this.autoHideOnNarrow) {
301
- this.open = false;
302
- }
303
- }
304
- else {
305
- // entering wide mode
306
- this.open = false;
307
- this.overlayVisible = false;
308
- this.overlayMounted = false;
309
- if (this.autoShowOnWide) {
310
- this.collapsed = false;
311
- }
312
- }
313
- }
314
- this.syncOverlayToState();
315
- }
316
- restorePersistedState() {
317
- if (!Build.isBrowser || !this.persistKey) {
318
- return;
319
- }
320
- try {
321
- const raw = window.localStorage.getItem(this.persistKey);
322
- if (!raw) {
323
- return;
324
- }
325
- const parsed = JSON.parse(raw);
326
- if (typeof parsed.width === 'number' && Number.isFinite(parsed.width)) {
327
- this.currentWidthPx = parsed.width;
328
- }
329
- if (typeof parsed.collapsed === 'boolean') {
330
- this.collapsed = parsed.collapsed;
331
- }
332
- }
333
- catch {
334
- // ignore
335
- }
336
- }
337
- persistState() {
338
- if (!Build.isBrowser || !this.persistKey) {
339
- return;
340
- }
341
- const payload = {
342
- width: this.currentWidthPx,
343
- collapsed: this.collapsed,
344
- };
345
- try {
346
- window.localStorage.setItem(this.persistKey, JSON.stringify(payload));
347
- }
348
- catch {
349
- // ignore
350
- }
351
- }
352
- focusFirstInsidePanel() {
353
- if (!Build.isBrowser) {
354
- return;
355
- }
356
- const root = this.panelEl;
357
- if (!root) {
358
- return;
359
- }
360
- const candidates = this.getFocusableElements(root);
361
- for (const el of candidates) {
362
- if (el.hasAttribute('disabled')) {
363
- continue;
364
- }
365
- const tabindex = el.getAttribute('tabindex');
366
- if (tabindex === '-1') {
367
- continue;
368
- }
369
- try {
370
- el.focus();
371
- return;
372
- }
373
- catch {
374
- // ignore
375
- }
376
- }
377
- }
378
- getFocusableElements(root) {
379
- const selector = 'button,[href],input,select,textarea,[tabindex]:not([tabindex="-1"])';
380
- const all = Array.from(root.querySelectorAll(selector));
381
- return all.filter(el => {
382
- if (el.hasAttribute('disabled')) {
383
- return false;
384
- }
385
- const tabindex = el.getAttribute('tabindex');
386
- if (tabindex === '-1') {
387
- return false;
388
- }
389
- return true;
390
- });
391
- }
392
- restoreFocusAfterClose() {
393
- if (!Build.isBrowser) {
394
- return;
395
- }
396
- const prev = this.focusedBeforeOpen;
397
- this.focusedBeforeOpen = null;
398
- if (prev && document.contains(prev)) {
399
- try {
400
- prev.focus();
401
- }
402
- catch {
403
- // ignore
404
- }
405
- }
406
- }
407
- onOverlayTransitionEnd = (ev) => {
408
- if (ev.target !== this.overlayWrapEl) {
409
- return;
410
- }
411
- if (ev.propertyName !== 'transform') {
412
- return;
413
- }
414
- const shouldUseOverlay = this.isNarrow && this.narrowBehavior === 'overlay';
415
- if (!shouldUseOverlay) {
416
- return;
417
- }
418
- if (!this.open && !this.overlayVisible) {
419
- this.overlayMounted = false;
420
- }
421
- };
422
- onOverlayPointerDown = (ev) => {
423
- // Close on any click outside the panel.
424
- const panel = this.panelEl;
425
- if (!panel) {
426
- return;
427
- }
428
- const path = ev.composedPath();
429
- if (!path.includes(panel)) {
430
- this.open = false;
431
- }
432
- };
433
- startResizeDrag = (ev) => {
434
- if (!this.resizable) {
435
- return;
436
- }
437
- // No resizing if fully hidden.
438
- if (!this.isNarrow && this.collapsed) {
439
- return;
440
- }
441
- if (this.isNarrow && this.narrowBehavior === 'overlay' && !this.open) {
442
- return;
443
- }
444
- if (this.isNarrow && this.narrowBehavior === 'push' && !this.open) {
445
- return;
446
- }
447
- this.resizing = true;
448
- this.dragPointerId = ev.pointerId;
449
- this.dragStartX = ev.clientX;
450
- this.dragStartWidth = this.currentWidthPx;
451
- ev.currentTarget?.setPointerCapture?.(ev.pointerId);
452
- window.addEventListener('pointermove', this.onResizeDragMove, { passive: false });
453
- window.addEventListener('pointerup', this.onResizeDragEnd, { passive: true });
454
- window.addEventListener('pointercancel', this.onResizeDragEnd, { passive: true });
455
- };
456
- onResizeDragMove = (ev) => {
457
- if (!this.resizing || this.dragPointerId !== ev.pointerId) {
458
- return;
459
- }
460
- ev.preventDefault();
461
- const startX = this.dragStartX ?? ev.clientX;
462
- const startWidth = this.dragStartWidth ?? this.currentWidthPx;
463
- const delta = ev.clientX - startX;
464
- const dir = this.side === 'start' ? 1 : -1;
465
- const nextWidth = clamp(startWidth + delta * dir, this.minPanelWidth, this.maxPanelWidth);
466
- this.currentWidthPx = nextWidth;
467
- this.leSidePanelWidthChange.emit({ width: this.currentWidthPx, panelId: this.panelId });
468
- };
469
- onResizeDragEnd = (ev) => {
470
- if (!this.resizing || this.dragPointerId !== ev.pointerId) {
471
- return;
472
- }
473
- this.resizing = false;
474
- this.dragPointerId = undefined;
475
- this.dragStartX = undefined;
476
- this.dragStartWidth = undefined;
477
- this.teardownDragListeners();
478
- this.persistState();
479
- this.leSidePanelWidthChange.emit({ width: this.currentWidthPx, panelId: this.panelId });
480
- };
481
- teardownDragListeners() {
482
- window.removeEventListener('pointermove', this.onResizeDragMove);
483
- window.removeEventListener('pointerup', this.onResizeDragEnd);
484
- window.removeEventListener('pointercancel', this.onResizeDragEnd);
485
- }
486
- renderPanelInner(opts) {
487
- const renderPanelSlot = opts?.renderPanelSlot ?? true;
488
- const showClose = this.showCloseButton && this.isNarrow && this.narrowBehavior === 'overlay';
489
- const tabIndex = this.isNarrow && this.narrowBehavior === 'overlay' ? -1 : null;
490
- return (h("div", { class: {
491
- panel: true,
492
- start: this.side === 'start',
493
- end: this.side === 'end',
494
- resizing: this.resizing,
495
- }, part: "panel", ref: el => (this.panelEl = el), role: "navigation", "aria-label": this.panelLabel, tabindex: tabIndex }, showClose ? (h("le-side-panel-toggle", { "panel-id": "demo-side", action: "toggle", shortcut: "Mod+B", variant: "clear", class: "close", part: "close-button", "aria-label": "Close panel", "icon-only": "true", style: {
496
- '--le-button-icon-only-padding': 'var(--le-space-sm)',
497
- }, onClick: () => (this.open = false) }, h("slot", { name: "close-icon", slot: "icon-only" }, h("le-icon", { name: "side-panel" })))) : null, h("div", { class: "panel-scroller", part: "panel-scroller" }, renderPanelSlot ? h("slot", { name: "panel" }) : null), this.resizable ? (h("div", { class: {
498
- handle: true,
499
- start: this.side === 'start',
500
- end: this.side === 'end',
501
- }, part: "resize-handle", role: "separator", "aria-orientation": "vertical", tabindex: -1, onPointerDown: this.startResizeDrag })) : null));
502
- }
503
- render() {
504
- const widthStyle = {
505
- '--le-side-panel-width': `${this.currentWidthPx}px`,
506
- };
507
- const isOverlay = this.isNarrow && this.narrowBehavior === 'overlay';
508
- const isModalOverlayOpen = isOverlay && this.open;
509
- const allowPanel = this.responsiveReady;
510
- const showWidePanel = allowPanel && !this.isNarrow && !this.collapsed;
511
- const showNarrowPushPanel = allowPanel && this.isNarrow && this.narrowBehavior === 'push' && this.open;
512
- const layoutHasInlinePanel = showWidePanel || showNarrowPushPanel;
513
- return (h("div", { key: '692aa465f1a1b8c40ec21d0780eb61d9cebdc6bf', class: {
514
- host: true,
515
- narrow: this.isNarrow,
516
- wide: !this.isNarrow,
517
- overlay: isOverlay,
518
- push: !isOverlay,
519
- collapsed: !this.isNarrow && this.collapsed,
520
- }, style: widthStyle, "data-resizing": this.resizing ? 'true' : null }, h("div", { key: 'a01741c802b6eaa8f70bd9265e0b2a19e5cf29cf', class: {
521
- 'layout': true,
522
- 'has-panel': layoutHasInlinePanel,
523
- 'start': this.side === 'start',
524
- 'end': this.side === 'end',
525
- } }, h("div", { key: '8795da430749e8af45175166a51848ca9c673f06', class: {
526
- inlinePanel: true,
527
- hidden: !layoutHasInlinePanel,
528
- }, "aria-hidden": !layoutHasInlinePanel ? 'true' : null }, this.renderPanelInner({ renderPanelSlot: !isOverlay })), h("div", { key: '16ed86717a59b27b2bc96ee703b53a74a9963595', class: "content", part: "content", "aria-hidden": isModalOverlayOpen ? 'true' : null }, h("slot", { key: '445b23491194a96bbca4f7c7dc869dc0ba327daa' }))), allowPanel && isOverlay && this.overlayMounted ? (h("div", { class: { overlayRoot: true, visible: this.overlayVisible }, part: "scrim", role: "presentation", onPointerDown: this.onOverlayPointerDown, "aria-hidden": isModalOverlayOpen ? null : 'true' }, h("div", { class: {
529
- overlayPanelWrap: true,
530
- visible: this.overlayVisible,
531
- start: this.side === 'start',
532
- end: this.side === 'end',
533
- }, part: "overlay", ref: el => (this.overlayWrapEl = el), onTransitionEnd: this.onOverlayTransitionEnd, role: "dialog", "aria-modal": "true" }, this.renderPanelInner({ renderPanelSlot: true })))) : null));
534
- }
535
- static get is() { return "le-side-panel"; }
536
- static get encapsulation() { return "shadow"; }
537
- static get originalStyleUrls() {
538
- return {
539
- "$": ["le-side-panel.css"]
540
- };
541
- }
542
- static get styleUrls() {
543
- return {
544
- "$": ["le-side-panel.css"]
545
- };
546
- }
547
- static get properties() {
548
- return {
549
- "panelId": {
550
- "type": "string",
551
- "mutable": false,
552
- "complexType": {
553
- "original": "string",
554
- "resolved": "string",
555
- "references": {}
556
- },
557
- "required": false,
558
- "optional": true,
559
- "docs": {
560
- "tags": [],
561
- "text": "Optional id used to match toggle requests.\nIf set, the panel only responds to toggle events with the same `panelId`."
562
- },
563
- "getter": false,
564
- "setter": false,
565
- "reflect": false,
566
- "attribute": "panel-id"
567
- },
568
- "side": {
569
- "type": "string",
570
- "mutable": false,
571
- "complexType": {
572
- "original": "LeSidePanelSide",
573
- "resolved": "\"end\" | \"start\"",
574
- "references": {
575
- "LeSidePanelSide": {
576
- "location": "local",
577
- "path": "/home/runner/work/le-kit/le-kit/src/components/le-side-panel/le-side-panel.tsx",
578
- "id": "src/components/le-side-panel/le-side-panel.tsx::LeSidePanelSide"
579
- }
580
- }
581
- },
582
- "required": false,
583
- "optional": false,
584
- "docs": {
585
- "tags": [],
586
- "text": "Which side the panel is attached to."
587
- },
588
- "getter": false,
589
- "setter": false,
590
- "reflect": false,
591
- "attribute": "side",
592
- "defaultValue": "'start'"
593
- },
594
- "collapseAt": {
595
- "type": "string",
596
- "mutable": false,
597
- "complexType": {
598
- "original": "string",
599
- "resolved": "string",
600
- "references": {}
601
- },
602
- "required": false,
603
- "optional": true,
604
- "docs": {
605
- "tags": [],
606
- "text": "Width breakpoint (in px or a CSS var like `--le-breakpoint-md`) below which the panel enters \"narrow\" mode."
607
- },
608
- "getter": false,
609
- "setter": false,
610
- "reflect": false,
611
- "attribute": "collapse-at"
612
- },
613
- "narrowBehavior": {
614
- "type": "string",
615
- "mutable": false,
616
- "complexType": {
617
- "original": "LeSidePanelNarrowBehavior",
618
- "resolved": "\"overlay\" | \"push\"",
619
- "references": {
620
- "LeSidePanelNarrowBehavior": {
621
- "location": "local",
622
- "path": "/home/runner/work/le-kit/le-kit/src/components/le-side-panel/le-side-panel.tsx",
623
- "id": "src/components/le-side-panel/le-side-panel.tsx::LeSidePanelNarrowBehavior"
624
- }
625
- }
626
- },
627
- "required": false,
628
- "optional": false,
629
- "docs": {
630
- "tags": [],
631
- "text": "Behavior when in narrow mode."
632
- },
633
- "getter": false,
634
- "setter": false,
635
- "reflect": false,
636
- "attribute": "narrow-behavior",
637
- "defaultValue": "'overlay'"
638
- },
639
- "open": {
640
- "type": "boolean",
641
- "mutable": true,
642
- "complexType": {
643
- "original": "boolean",
644
- "resolved": "boolean",
645
- "references": {}
646
- },
647
- "required": false,
648
- "optional": false,
649
- "docs": {
650
- "tags": [],
651
- "text": "Panel open state for narrow mode.\n- overlay: controls modal drawer visibility\n- push: controls whether panel is shown (non-modal)"
652
- },
653
- "getter": false,
654
- "setter": false,
655
- "reflect": true,
656
- "attribute": "open",
657
- "defaultValue": "false"
658
- },
659
- "collapsed": {
660
- "type": "boolean",
661
- "mutable": true,
662
- "complexType": {
663
- "original": "boolean",
664
- "resolved": "boolean",
665
- "references": {}
666
- },
667
- "required": false,
668
- "optional": false,
669
- "docs": {
670
- "tags": [],
671
- "text": "Panel collapsed state for wide mode (fully hidden)."
672
- },
673
- "getter": false,
674
- "setter": false,
675
- "reflect": true,
676
- "attribute": "collapsed",
677
- "defaultValue": "false"
678
- },
679
- "panelWidth": {
680
- "type": "number",
681
- "mutable": false,
682
- "complexType": {
683
- "original": "number",
684
- "resolved": "number",
685
- "references": {}
686
- },
687
- "required": false,
688
- "optional": false,
689
- "docs": {
690
- "tags": [],
691
- "text": "Default panel width in pixels."
692
- },
693
- "getter": false,
694
- "setter": false,
695
- "reflect": false,
696
- "attribute": "panel-width",
697
- "defaultValue": "280"
698
- },
699
- "minPanelWidth": {
700
- "type": "number",
701
- "mutable": false,
702
- "complexType": {
703
- "original": "number",
704
- "resolved": "number",
705
- "references": {}
706
- },
707
- "required": false,
708
- "optional": false,
709
- "docs": {
710
- "tags": [],
711
- "text": "Minimum allowed width when resizable."
712
- },
713
- "getter": false,
714
- "setter": false,
715
- "reflect": false,
716
- "attribute": "min-panel-width",
717
- "defaultValue": "220"
718
- },
719
- "maxPanelWidth": {
720
- "type": "number",
721
- "mutable": false,
722
- "complexType": {
723
- "original": "number",
724
- "resolved": "number",
725
- "references": {}
726
- },
727
- "required": false,
728
- "optional": false,
729
- "docs": {
730
- "tags": [],
731
- "text": "Maximum allowed width when resizable."
732
- },
733
- "getter": false,
734
- "setter": false,
735
- "reflect": false,
736
- "attribute": "max-panel-width",
737
- "defaultValue": "420"
738
- },
739
- "resizable": {
740
- "type": "boolean",
741
- "mutable": false,
742
- "complexType": {
743
- "original": "boolean",
744
- "resolved": "boolean",
745
- "references": {}
746
- },
747
- "required": false,
748
- "optional": false,
749
- "docs": {
750
- "tags": [],
751
- "text": "Allows users to resize the panel by dragging its edge."
752
- },
753
- "getter": false,
754
- "setter": false,
755
- "reflect": false,
756
- "attribute": "resizable",
757
- "defaultValue": "false"
758
- },
759
- "persistKey": {
760
- "type": "string",
761
- "mutable": false,
762
- "complexType": {
763
- "original": "string",
764
- "resolved": "string",
765
- "references": {}
766
- },
767
- "required": false,
768
- "optional": true,
769
- "docs": {
770
- "tags": [],
771
- "text": "When set, panel width + collapsed state are persisted in localStorage."
772
- },
773
- "getter": false,
774
- "setter": false,
775
- "reflect": false,
776
- "attribute": "persist-key"
777
- },
778
- "showCloseButton": {
779
- "type": "boolean",
780
- "mutable": false,
781
- "complexType": {
782
- "original": "boolean",
783
- "resolved": "boolean",
784
- "references": {}
785
- },
786
- "required": false,
787
- "optional": false,
788
- "docs": {
789
- "tags": [],
790
- "text": "Show a close button inside the panel (primarily used in narrow overlay mode)."
791
- },
792
- "getter": false,
793
- "setter": false,
794
- "reflect": false,
795
- "attribute": "show-close-button",
796
- "defaultValue": "true"
797
- },
798
- "autoShowOnWide": {
799
- "type": "boolean",
800
- "mutable": false,
801
- "complexType": {
802
- "original": "boolean",
803
- "resolved": "boolean",
804
- "references": {}
805
- },
806
- "required": false,
807
- "optional": false,
808
- "docs": {
809
- "tags": [],
810
- "text": "When crossing to wide mode, automatically show the panel (collapsed=false)."
811
- },
812
- "getter": false,
813
- "setter": false,
814
- "reflect": false,
815
- "attribute": "auto-show-on-wide",
816
- "defaultValue": "true"
817
- },
818
- "autoHideOnNarrow": {
819
- "type": "boolean",
820
- "mutable": false,
821
- "complexType": {
822
- "original": "boolean",
823
- "resolved": "boolean",
824
- "references": {}
825
- },
826
- "required": false,
827
- "optional": false,
828
- "docs": {
829
- "tags": [],
830
- "text": "When crossing to narrow mode, automatically hide the panel (open=false)."
831
- },
832
- "getter": false,
833
- "setter": false,
834
- "reflect": false,
835
- "attribute": "auto-hide-on-narrow",
836
- "defaultValue": "true"
837
- },
838
- "panelLabel": {
839
- "type": "string",
840
- "mutable": false,
841
- "complexType": {
842
- "original": "string",
843
- "resolved": "string",
844
- "references": {}
845
- },
846
- "required": false,
847
- "optional": false,
848
- "docs": {
849
- "tags": [],
850
- "text": "Accessible label for the panel navigation region."
851
- },
852
- "getter": false,
853
- "setter": false,
854
- "reflect": false,
855
- "attribute": "panel-label",
856
- "defaultValue": "'Navigation'"
857
- }
858
- };
859
- }
860
- static get states() {
861
- return {
862
- "isNarrow": {},
863
- "responsiveReady": {},
864
- "overlayMounted": {},
865
- "overlayVisible": {},
866
- "currentWidthPx": {},
867
- "resizing": {}
868
- };
869
- }
870
- static get events() {
871
- return [{
872
- "method": "leSidePanelOpenChange",
873
- "name": "leSidePanelOpenChange",
874
- "bubbles": true,
875
- "cancelable": true,
876
- "composed": true,
877
- "docs": {
878
- "tags": [],
879
- "text": ""
880
- },
881
- "complexType": {
882
- "original": "{ open: boolean; panelId?: string }",
883
- "resolved": "{ open: boolean; panelId?: string; }",
884
- "references": {}
885
- }
886
- }, {
887
- "method": "leSidePanelCollapsedChange",
888
- "name": "leSidePanelCollapsedChange",
889
- "bubbles": true,
890
- "cancelable": true,
891
- "composed": true,
892
- "docs": {
893
- "tags": [],
894
- "text": ""
895
- },
896
- "complexType": {
897
- "original": "{ collapsed: boolean; panelId?: string }",
898
- "resolved": "{ collapsed: boolean; panelId?: string; }",
899
- "references": {}
900
- }
901
- }, {
902
- "method": "leSidePanelWidthChange",
903
- "name": "leSidePanelWidthChange",
904
- "bubbles": true,
905
- "cancelable": true,
906
- "composed": true,
907
- "docs": {
908
- "tags": [],
909
- "text": ""
910
- },
911
- "complexType": {
912
- "original": "{ width: number; panelId?: string }",
913
- "resolved": "{ width: number; panelId?: string; }",
914
- "references": {}
915
- }
916
- }];
917
- }
918
- static get elementRef() { return "el"; }
919
- static get watchers() {
920
- return [{
921
- "propName": "panelWidth",
922
- "methodName": "onPanelWidthChanged"
923
- }, {
924
- "propName": "collapsed",
925
- "methodName": "onCollapsedChanged"
926
- }, {
927
- "propName": "open",
928
- "methodName": "onOpenChanged"
929
- }, {
930
- "propName": "collapseAt",
931
- "methodName": "onResponsivePropChanged"
932
- }, {
933
- "propName": "narrowBehavior",
934
- "methodName": "onResponsivePropChanged"
935
- }];
936
- }
937
- static get listeners() {
938
- return [{
939
- "name": "keydown",
940
- "method": "onDocumentKeyDown",
941
- "target": "document",
942
- "capture": true,
943
- "passive": false
944
- }, {
945
- "name": "leSidePanelRequestToggle",
946
- "method": "onToggleRequest",
947
- "target": "document",
948
- "capture": false,
949
- "passive": false
950
- }];
951
- }
952
- }
953
- //# sourceMappingURL=le-side-panel.js.map