@sekiui/elements 0.0.55 → 0.0.57

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 (298) hide show
  1. package/dist/cdn/index.js +1053 -91
  2. package/dist/cdn/p-BJCq8m2o.js +138 -0
  3. package/dist/cdn/p-BfRJQMIU.js +111 -0
  4. package/dist/cdn/{p-bMBhrs0a.js → p-Bp7tjKwQ.js} +427 -7
  5. package/dist/cdn/seki-button.js +1 -1
  6. package/dist/cdn/seki-card-action.d.ts +11 -0
  7. package/dist/cdn/seki-card-action.js +38 -0
  8. package/dist/cdn/seki-card-content.d.ts +11 -0
  9. package/dist/cdn/seki-card-content.js +38 -0
  10. package/dist/cdn/seki-card-description.d.ts +11 -0
  11. package/dist/cdn/seki-card-description.js +38 -0
  12. package/dist/cdn/seki-card-footer.d.ts +11 -0
  13. package/dist/cdn/seki-card-footer.js +44 -0
  14. package/dist/cdn/seki-card-header.d.ts +11 -0
  15. package/dist/cdn/seki-card-header.js +38 -0
  16. package/dist/cdn/seki-card-title.d.ts +11 -0
  17. package/dist/cdn/seki-card-title.js +59 -0
  18. package/dist/cdn/seki-card.d.ts +11 -0
  19. package/dist/cdn/seki-card.js +39 -0
  20. package/dist/cdn/seki-field-description.js +2 -2
  21. package/dist/cdn/seki-field-error.js +2 -2
  22. package/dist/cdn/seki-field-group.js +2 -2
  23. package/dist/cdn/seki-field-label.js +2 -2
  24. package/dist/cdn/seki-field-legend.js +2 -2
  25. package/dist/cdn/seki-field.js +2 -2
  26. package/dist/cdn/seki-fieldset.js +2 -2
  27. package/dist/cdn/seki-input.js +2 -2
  28. package/dist/cdn/seki-select-content.js +1 -1
  29. package/dist/cdn/seki-select-group.js +2 -2
  30. package/dist/cdn/seki-select-option.js +2 -2
  31. package/dist/cdn/seki-select-trigger.js +1 -1
  32. package/dist/cdn/seki-select.js +2 -2
  33. package/dist/cdn/seki-sidebar-content.d.ts +11 -0
  34. package/dist/cdn/seki-sidebar-content.js +38 -0
  35. package/dist/cdn/seki-sidebar-footer.d.ts +11 -0
  36. package/dist/cdn/seki-sidebar-footer.js +38 -0
  37. package/dist/cdn/seki-sidebar-group.d.ts +11 -0
  38. package/dist/cdn/seki-sidebar-group.js +131 -0
  39. package/dist/cdn/seki-sidebar-header.d.ts +11 -0
  40. package/dist/cdn/seki-sidebar-header.js +38 -0
  41. package/dist/cdn/seki-sidebar-menu-item.d.ts +11 -0
  42. package/dist/cdn/seki-sidebar-menu-item.js +200 -0
  43. package/dist/cdn/seki-sidebar-menu-sub.d.ts +11 -0
  44. package/dist/cdn/seki-sidebar-menu-sub.js +123 -0
  45. package/dist/cdn/seki-sidebar-menu.d.ts +11 -0
  46. package/dist/cdn/seki-sidebar-menu.js +38 -0
  47. package/dist/cdn/seki-sidebar-trigger.d.ts +11 -0
  48. package/dist/cdn/seki-sidebar-trigger.js +109 -0
  49. package/dist/cdn/seki-sidebar.d.ts +11 -0
  50. package/dist/cdn/seki-sidebar.js +380 -0
  51. package/dist/cdn/seki-skeleton.js +2 -2
  52. package/dist/cdn/seki-switch.js +1 -1
  53. package/dist/cdn/seki-tooltip.js +1 -1
  54. package/dist/cjs/{index-Dd6_-KaR.js → index-tQYksITZ.js} +426 -6
  55. package/dist/cjs/index.cjs.js +1115 -63
  56. package/dist/cjs/keyboard-Cjl5HYES.js +142 -0
  57. package/dist/cjs/loader.cjs.js +2 -2
  58. package/dist/cjs/seki-button.cjs.entry.js +1 -1
  59. package/dist/cjs/seki-card-action.cjs.entry.js +17 -0
  60. package/dist/cjs/seki-card-content.cjs.entry.js +17 -0
  61. package/dist/cjs/seki-card-description.cjs.entry.js +17 -0
  62. package/dist/cjs/seki-card-footer.cjs.entry.js +22 -0
  63. package/dist/cjs/seki-card-header.cjs.entry.js +17 -0
  64. package/dist/cjs/seki-card-title.cjs.entry.js +37 -0
  65. package/dist/cjs/seki-card.cjs.entry.js +17 -0
  66. package/dist/cjs/seki-field-description.cjs.entry.js +2 -2
  67. package/dist/cjs/seki-field-error.cjs.entry.js +2 -2
  68. package/dist/cjs/seki-field-group.cjs.entry.js +2 -2
  69. package/dist/cjs/seki-field-label.cjs.entry.js +2 -2
  70. package/dist/cjs/seki-field-legend.cjs.entry.js +2 -2
  71. package/dist/cjs/seki-field.cjs.entry.js +2 -2
  72. package/dist/cjs/seki-fieldset.cjs.entry.js +2 -2
  73. package/dist/cjs/seki-input.cjs.entry.js +2 -2
  74. package/dist/cjs/seki-select-content.cjs.entry.js +1 -1
  75. package/dist/cjs/seki-select-group.cjs.entry.js +2 -2
  76. package/dist/cjs/seki-select-option.cjs.entry.js +2 -2
  77. package/dist/cjs/seki-select-trigger.cjs.entry.js +1 -1
  78. package/dist/cjs/seki-select.cjs.entry.js +2 -2
  79. package/dist/cjs/seki-sidebar-content.cjs.entry.js +20 -0
  80. package/dist/cjs/seki-sidebar-footer.cjs.entry.js +20 -0
  81. package/dist/cjs/seki-sidebar-group.cjs.entry.js +105 -0
  82. package/dist/cjs/seki-sidebar-header.cjs.entry.js +20 -0
  83. package/dist/cjs/seki-sidebar-menu-item.cjs.entry.js +174 -0
  84. package/dist/cjs/seki-sidebar-menu-sub.cjs.entry.js +99 -0
  85. package/dist/cjs/seki-sidebar-menu.cjs.entry.js +20 -0
  86. package/dist/cjs/seki-sidebar-trigger.cjs.entry.js +86 -0
  87. package/dist/cjs/seki-sidebar.cjs.entry.js +342 -0
  88. package/dist/cjs/seki-skeleton.cjs.entry.js +2 -2
  89. package/dist/cjs/seki-switch.cjs.entry.js +81 -3
  90. package/dist/cjs/seki-tooltip.cjs.entry.js +1 -1
  91. package/dist/cjs/sekiui.cjs.js +2 -2
  92. package/dist/collection/collection-manifest.json +16 -0
  93. package/dist/collection/components/card/seki-card-action.js +50 -0
  94. package/dist/collection/components/card/seki-card-content.js +51 -0
  95. package/dist/collection/components/card/seki-card-description.js +48 -0
  96. package/dist/collection/components/card/seki-card-footer.js +83 -0
  97. package/dist/collection/components/card/seki-card-header.js +54 -0
  98. package/dist/collection/components/card/seki-card-title.js +95 -0
  99. package/dist/collection/components/card/seki-card.a11y.js +363 -0
  100. package/dist/collection/components/card/seki-card.css +608 -0
  101. package/dist/collection/components/card/seki-card.js +72 -0
  102. package/dist/collection/components/field/seki-field.js +1 -1
  103. package/dist/collection/components/field-description/seki-field-description.js +1 -1
  104. package/dist/collection/components/field-error/seki-field-error.js +1 -1
  105. package/dist/collection/components/field-group/seki-field-group.js +1 -1
  106. package/dist/collection/components/field-label/seki-field-label.js +1 -1
  107. package/dist/collection/components/field-legend/seki-field-legend.js +1 -1
  108. package/dist/collection/components/fieldset/seki-fieldset.js +1 -1
  109. package/dist/collection/components/input/seki-input.js +1 -1
  110. package/dist/collection/components/select/seki-select.js +1 -1
  111. package/dist/collection/components/select-group/seki-select-group.js +1 -1
  112. package/dist/collection/components/select-option/seki-select-option.js +1 -1
  113. package/dist/collection/components/sidebar/seki-sidebar-content.css +82 -0
  114. package/dist/collection/components/sidebar/seki-sidebar-content.js +33 -0
  115. package/dist/collection/components/sidebar/seki-sidebar-footer.css +44 -0
  116. package/dist/collection/components/sidebar/seki-sidebar-footer.js +31 -0
  117. package/dist/collection/components/sidebar/seki-sidebar-group.css +158 -0
  118. package/dist/collection/components/sidebar/seki-sidebar-group.js +300 -0
  119. package/dist/collection/components/sidebar/seki-sidebar-header.css +44 -0
  120. package/dist/collection/components/sidebar/seki-sidebar-header.js +32 -0
  121. package/dist/collection/components/sidebar/seki-sidebar-menu-item.css +196 -0
  122. package/dist/collection/components/sidebar/seki-sidebar-menu-item.js +403 -0
  123. package/dist/collection/components/sidebar/seki-sidebar-menu-sub.css +357 -0
  124. package/dist/collection/components/sidebar/seki-sidebar-menu-sub.js +256 -0
  125. package/dist/collection/components/sidebar/seki-sidebar-menu.css +25 -0
  126. package/dist/collection/components/sidebar/seki-sidebar-menu.js +32 -0
  127. package/dist/collection/components/sidebar/seki-sidebar-trigger.css +68 -0
  128. package/dist/collection/components/sidebar/seki-sidebar-trigger.js +175 -0
  129. package/dist/collection/components/sidebar/seki-sidebar.css +352 -0
  130. package/dist/collection/components/sidebar/seki-sidebar.js +812 -0
  131. package/dist/collection/components/sidebar/types.js +18 -0
  132. package/dist/collection/components/skeleton/seki-skeleton.js +1 -1
  133. package/dist/collection/index.js +7 -0
  134. package/dist/collection/services/focus.js +192 -0
  135. package/dist/collection/services/index.js +7 -0
  136. package/dist/collection/services/keyboard.js +136 -0
  137. package/dist/collection/services/media-query.js +254 -0
  138. package/dist/collection/types.js +41 -0
  139. package/dist/collection/utils/a11y.js +291 -0
  140. package/dist/collection/utils/common.js +286 -0
  141. package/dist/components/index.js +1053 -91
  142. package/dist/components/p-BJCq8m2o.js +138 -0
  143. package/dist/components/{p-QhPshhKB.js → p-BzYKy7d3.js} +427 -7
  144. package/dist/components/p-DwTISp-i.js +111 -0
  145. package/dist/components/seki-button.js +1 -1
  146. package/dist/components/seki-card-action.d.ts +11 -0
  147. package/dist/components/seki-card-action.js +38 -0
  148. package/dist/components/seki-card-content.d.ts +11 -0
  149. package/dist/components/seki-card-content.js +38 -0
  150. package/dist/components/seki-card-description.d.ts +11 -0
  151. package/dist/components/seki-card-description.js +38 -0
  152. package/dist/components/seki-card-footer.d.ts +11 -0
  153. package/dist/components/seki-card-footer.js +44 -0
  154. package/dist/components/seki-card-header.d.ts +11 -0
  155. package/dist/components/seki-card-header.js +38 -0
  156. package/dist/components/seki-card-title.d.ts +11 -0
  157. package/dist/components/seki-card-title.js +59 -0
  158. package/dist/components/seki-card.d.ts +11 -0
  159. package/dist/components/seki-card.js +39 -0
  160. package/dist/components/seki-field-description.js +2 -2
  161. package/dist/components/seki-field-error.js +2 -2
  162. package/dist/components/seki-field-group.js +2 -2
  163. package/dist/components/seki-field-label.js +2 -2
  164. package/dist/components/seki-field-legend.js +2 -2
  165. package/dist/components/seki-field.js +2 -2
  166. package/dist/components/seki-fieldset.js +2 -2
  167. package/dist/components/seki-input.js +2 -2
  168. package/dist/components/seki-select-content.js +1 -1
  169. package/dist/components/seki-select-group.js +2 -2
  170. package/dist/components/seki-select-option.js +2 -2
  171. package/dist/components/seki-select-trigger.js +1 -1
  172. package/dist/components/seki-select.js +2 -2
  173. package/dist/components/seki-sidebar-content.d.ts +11 -0
  174. package/dist/components/seki-sidebar-content.js +38 -0
  175. package/dist/components/seki-sidebar-footer.d.ts +11 -0
  176. package/dist/components/seki-sidebar-footer.js +38 -0
  177. package/dist/components/seki-sidebar-group.d.ts +11 -0
  178. package/dist/components/seki-sidebar-group.js +131 -0
  179. package/dist/components/seki-sidebar-header.d.ts +11 -0
  180. package/dist/components/seki-sidebar-header.js +38 -0
  181. package/dist/components/seki-sidebar-menu-item.d.ts +11 -0
  182. package/dist/components/seki-sidebar-menu-item.js +200 -0
  183. package/dist/components/seki-sidebar-menu-sub.d.ts +11 -0
  184. package/dist/components/seki-sidebar-menu-sub.js +123 -0
  185. package/dist/components/seki-sidebar-menu.d.ts +11 -0
  186. package/dist/components/seki-sidebar-menu.js +38 -0
  187. package/dist/components/seki-sidebar-trigger.d.ts +11 -0
  188. package/dist/components/seki-sidebar-trigger.js +109 -0
  189. package/dist/components/seki-sidebar.d.ts +11 -0
  190. package/dist/components/seki-sidebar.js +380 -0
  191. package/dist/components/seki-skeleton.js +2 -2
  192. package/dist/components/seki-switch.js +1 -1
  193. package/dist/components/seki-tooltip.js +1 -1
  194. package/dist/esm/{index-CuXbV_yz.js → index-Dfzpqq0a.js} +426 -6
  195. package/dist/esm/index.js +1053 -63
  196. package/dist/esm/keyboard-BJCq8m2o.js +138 -0
  197. package/dist/esm/loader.js +3 -3
  198. package/dist/esm/seki-button.entry.js +1 -1
  199. package/dist/esm/seki-card-action.entry.js +15 -0
  200. package/dist/esm/seki-card-content.entry.js +15 -0
  201. package/dist/esm/seki-card-description.entry.js +15 -0
  202. package/dist/esm/seki-card-footer.entry.js +20 -0
  203. package/dist/esm/seki-card-header.entry.js +15 -0
  204. package/dist/esm/seki-card-title.entry.js +35 -0
  205. package/dist/esm/seki-card.entry.js +15 -0
  206. package/dist/esm/seki-field-description.entry.js +2 -2
  207. package/dist/esm/seki-field-error.entry.js +2 -2
  208. package/dist/esm/seki-field-group.entry.js +2 -2
  209. package/dist/esm/seki-field-label.entry.js +2 -2
  210. package/dist/esm/seki-field-legend.entry.js +2 -2
  211. package/dist/esm/seki-field.entry.js +2 -2
  212. package/dist/esm/seki-fieldset.entry.js +2 -2
  213. package/dist/esm/seki-input.entry.js +2 -2
  214. package/dist/esm/seki-select-content.entry.js +1 -1
  215. package/dist/esm/seki-select-group.entry.js +2 -2
  216. package/dist/esm/seki-select-option.entry.js +2 -2
  217. package/dist/esm/seki-select-trigger.entry.js +1 -1
  218. package/dist/esm/seki-select.entry.js +2 -2
  219. package/dist/esm/seki-sidebar-content.entry.js +18 -0
  220. package/dist/esm/seki-sidebar-footer.entry.js +18 -0
  221. package/dist/esm/seki-sidebar-group.entry.js +103 -0
  222. package/dist/esm/seki-sidebar-header.entry.js +18 -0
  223. package/dist/esm/seki-sidebar-menu-item.entry.js +172 -0
  224. package/dist/esm/seki-sidebar-menu-sub.entry.js +97 -0
  225. package/dist/esm/seki-sidebar-menu.entry.js +18 -0
  226. package/dist/esm/seki-sidebar-trigger.entry.js +84 -0
  227. package/dist/esm/seki-sidebar.entry.js +340 -0
  228. package/dist/esm/seki-skeleton.entry.js +2 -2
  229. package/dist/esm/seki-switch.entry.js +84 -2
  230. package/dist/esm/seki-tooltip.entry.js +1 -1
  231. package/dist/esm/sekiui.js +3 -3
  232. package/dist/sekiui/index.esm.js +1 -1
  233. package/dist/sekiui/p-01cfb4e7.entry.js +1 -0
  234. package/dist/sekiui/{p-431f46a1.entry.js → p-042ec460.entry.js} +1 -1
  235. package/dist/sekiui/{p-a36f1ac4.entry.js → p-10c008fc.entry.js} +1 -1
  236. package/dist/sekiui/p-352bd295.entry.js +1 -0
  237. package/dist/sekiui/p-37c5f4d9.entry.js +1 -0
  238. package/dist/sekiui/p-40fb71d6.entry.js +1 -0
  239. package/dist/sekiui/{p-eefbc037.entry.js → p-44191aed.entry.js} +1 -1
  240. package/dist/sekiui/{p-81709fc2.entry.js → p-4423d621.entry.js} +1 -1
  241. package/dist/sekiui/{p-e679d501.entry.js → p-4636588f.entry.js} +1 -1
  242. package/dist/sekiui/p-471b97a5.entry.js +1 -0
  243. package/dist/sekiui/{p-de4735fb.entry.js → p-56f0d754.entry.js} +1 -1
  244. package/dist/sekiui/p-5bc0f5aa.entry.js +1 -0
  245. package/dist/sekiui/p-6164cd8a.entry.js +1 -0
  246. package/dist/sekiui/{p-0fba4e2d.entry.js → p-635f4098.entry.js} +1 -1
  247. package/dist/sekiui/{p-434be19f.entry.js → p-743fc6d9.entry.js} +1 -1
  248. package/dist/sekiui/p-83e65cbe.entry.js +1 -0
  249. package/dist/sekiui/p-8b7bd061.entry.js +1 -0
  250. package/dist/sekiui/p-8d9a4878.entry.js +1 -0
  251. package/dist/sekiui/p-9cb9cdfe.entry.js +1 -0
  252. package/dist/sekiui/p-9f2d95d7.entry.js +1 -0
  253. package/dist/sekiui/p-BJCq8m2o.js +1 -0
  254. package/dist/sekiui/p-Dfzpqq0a.js +2 -0
  255. package/dist/sekiui/p-a1a71958.entry.js +1 -0
  256. package/dist/sekiui/{p-bf942ad5.entry.js → p-a71e0c55.entry.js} +1 -1
  257. package/dist/sekiui/{p-6ff91f7f.entry.js → p-ae227955.entry.js} +1 -1
  258. package/dist/sekiui/{p-80a41058.entry.js → p-b365f5fb.entry.js} +1 -1
  259. package/dist/sekiui/{p-6bde807e.entry.js → p-b387a2a5.entry.js} +1 -1
  260. package/dist/sekiui/p-b8590f4d.entry.js +1 -0
  261. package/dist/sekiui/p-c98b6d6a.entry.js +1 -0
  262. package/dist/sekiui/{p-7c2245be.entry.js → p-d73cdb9a.entry.js} +1 -1
  263. package/dist/sekiui/{p-a56602b3.entry.js → p-d96e770e.entry.js} +1 -1
  264. package/dist/sekiui/p-e62dd89b.entry.js +1 -0
  265. package/dist/sekiui/{p-386c00ac.entry.js → p-e7bb140c.entry.js} +1 -1
  266. package/dist/sekiui/{p-6e238adf.entry.js → p-eecc18f3.entry.js} +1 -1
  267. package/dist/sekiui/p-ff636955.entry.js +1 -0
  268. package/dist/sekiui/sekiui.esm.js +1 -1
  269. package/dist/types/components/card/seki-card-action.d.ts +16 -0
  270. package/dist/types/components/card/seki-card-content.d.ts +17 -0
  271. package/dist/types/components/card/seki-card-description.d.ts +14 -0
  272. package/dist/types/components/card/seki-card-footer.d.ts +24 -0
  273. package/dist/types/components/card/seki-card-header.d.ts +20 -0
  274. package/dist/types/components/card/seki-card-title.d.ts +20 -0
  275. package/dist/types/components/card/seki-card.a11y.d.ts +1 -0
  276. package/dist/types/components/card/seki-card.d.ts +23 -0
  277. package/dist/types/components/sidebar/seki-sidebar-content.d.ts +18 -0
  278. package/dist/types/components/sidebar/seki-sidebar-footer.d.ts +16 -0
  279. package/dist/types/components/sidebar/seki-sidebar-group.d.ts +81 -0
  280. package/dist/types/components/sidebar/seki-sidebar-header.d.ts +17 -0
  281. package/dist/types/components/sidebar/seki-sidebar-menu-item.d.ts +104 -0
  282. package/dist/types/components/sidebar/seki-sidebar-menu-sub.d.ts +81 -0
  283. package/dist/types/components/sidebar/seki-sidebar-menu.d.ts +17 -0
  284. package/dist/types/components/sidebar/seki-sidebar-trigger.d.ts +53 -0
  285. package/dist/types/components/sidebar/seki-sidebar.d.ts +185 -0
  286. package/dist/types/components/sidebar/types.d.ts +245 -0
  287. package/dist/types/components.d.ts +899 -0
  288. package/dist/types/index.d.ts +4 -0
  289. package/dist/types/services/focus.d.ts +74 -0
  290. package/dist/types/services/index.d.ts +7 -0
  291. package/dist/types/services/keyboard.d.ts +74 -0
  292. package/dist/types/services/media-query.d.ts +121 -0
  293. package/dist/types/types.d.ts +105 -0
  294. package/dist/types/utils/a11y.d.ts +130 -0
  295. package/dist/types/utils/common.d.ts +142 -0
  296. package/package.json +2 -1
  297. package/dist/sekiui/p-9fe07f6e.entry.js +0 -1
  298. package/dist/sekiui/p-CuXbV_yz.js +0 -2
@@ -0,0 +1,68 @@
1
+ /**
2
+ * SekiSidebarTrigger Styles
3
+ */
4
+
5
+ :host {
6
+ display: inline-block;
7
+ }
8
+
9
+ .trigger-button {
10
+ display: flex;
11
+ align-items: center;
12
+ justify-content: center;
13
+ width: 44px;
14
+ height: 44px;
15
+ padding: 0;
16
+ background: transparent;
17
+ border: 1px solid transparent;
18
+ border-radius: 0.375rem;
19
+ color: var(--sidebar-foreground);
20
+ font-size: 1.25rem;
21
+ cursor: pointer;
22
+ transition: background-color 200ms ease-in-out, border-color 200ms ease-in-out;
23
+ }
24
+
25
+ .trigger-button:hover:not(:disabled) {
26
+ background-color: rgba(0, 0, 0, 0.05);
27
+ border-color: var(--sidebar-border);
28
+ }
29
+
30
+ .trigger-button:active:not(:disabled) {
31
+ background-color: rgba(0, 0, 0, 0.1);
32
+ }
33
+
34
+ .trigger-button:focus-visible {
35
+ outline: 2px solid var(--sidebar-primary);
36
+ outline-offset: 2px;
37
+ }
38
+
39
+ .trigger-button:disabled {
40
+ opacity: 0.5;
41
+ cursor: not-allowed;
42
+ }
43
+
44
+ .trigger-icon {
45
+ display: flex;
46
+ align-items: center;
47
+ justify-content: center;
48
+ }
49
+
50
+ .trigger-icon-default {
51
+ font-size: 1.25rem;
52
+ }
53
+
54
+ /* Dark mode */
55
+ :host-context([data-theme="dark"]) .trigger-button:hover:not(:disabled) {
56
+ background-color: rgba(255, 255, 255, 0.1);
57
+ }
58
+
59
+ :host-context([data-theme="dark"]) .trigger-button:active:not(:disabled) {
60
+ background-color: rgba(255, 255, 255, 0.15);
61
+ }
62
+
63
+ /* Reduce motion */
64
+ @media (prefers-reduced-motion: reduce) {
65
+ .trigger-button {
66
+ transition: none;
67
+ }
68
+ }
@@ -0,0 +1,175 @@
1
+ /**
2
+ * SekiSidebarTrigger Component
3
+ * @description Toggle button for opening/closing the sidebar
4
+ * Manages focus, keyboard activation (Space, Enter), and ARIA attributes
5
+ * @component
6
+ * @example
7
+ * <seki-sidebar-trigger aria-label="Toggle sidebar"></seki-sidebar-trigger>
8
+ */
9
+ import { h, Host } from "@stencil/core";
10
+ export class SekiSidebarTrigger {
11
+ constructor() {
12
+ /**
13
+ * Accessibility label for the button
14
+ * @type {string}
15
+ * @default 'Toggle sidebar'
16
+ */
17
+ this.ariaLabel = 'Toggle sidebar';
18
+ /**
19
+ * Track the sidebar's open state for aria-expanded attribute
20
+ */
21
+ this.isOpen = true;
22
+ /**
23
+ * Reference to parent sidebar
24
+ */
25
+ this.parentSidebar = null;
26
+ /**
27
+ * Handle button click - finds parent seki-sidebar or nearest sidebar in document
28
+ */
29
+ this.handleClick = async () => {
30
+ // First try to find parent sidebar
31
+ let sidebar = this.parentSidebar;
32
+ // If no parent found, look for nearest sidebar in the document
33
+ if (!sidebar) {
34
+ sidebar = document.querySelector('seki-sidebar');
35
+ this.parentSidebar = sidebar;
36
+ }
37
+ if (!sidebar)
38
+ return;
39
+ const state = await sidebar.getState();
40
+ await sidebar.setState({ isOpen: !state.isOpen });
41
+ };
42
+ /**
43
+ * Handle keyboard activation (Space, Enter)
44
+ */
45
+ this.handleKeyDown = (e) => {
46
+ if (e.key === ' ' || e.key === 'Enter') {
47
+ e.preventDefault();
48
+ this.handleClick();
49
+ }
50
+ };
51
+ }
52
+ /**
53
+ * Initialize - find parent sidebar and listen to state changes
54
+ */
55
+ connectedCallback() {
56
+ var _a, _b;
57
+ this.parentSidebar = (_a = this.el) === null || _a === void 0 ? void 0 : _a.closest('seki-sidebar');
58
+ if (!this.parentSidebar) {
59
+ this.parentSidebar = document.querySelector('seki-sidebar');
60
+ }
61
+ // Get initial state from parent sidebar
62
+ if (this.parentSidebar) {
63
+ const sidebarEl = this.parentSidebar;
64
+ (_b = sidebarEl.getState) === null || _b === void 0 ? void 0 : _b.call(sidebarEl).then(state => {
65
+ this.isOpen = state.isOpen;
66
+ });
67
+ }
68
+ }
69
+ /**
70
+ * Listen to openChange event from parent sidebar
71
+ */
72
+ handleOpenChange(event) {
73
+ // Update local state when parent sidebar changes
74
+ if (event.detail && typeof event.detail.isOpen === 'boolean') {
75
+ this.isOpen = event.detail.isOpen;
76
+ }
77
+ }
78
+ /**
79
+ * Render the component
80
+ */
81
+ render() {
82
+ return (h(Host, { key: 'f031872df0db62782e7736739a4ec21890bedb5a' }, h("button", { key: 'f673e56848c712deca471b9b28c7f52ba346f809', class: "trigger-button", "aria-expanded": this.isOpen, "aria-label": this.ariaLabel, onClick: this.handleClick, onKeyDown: this.handleKeyDown, type: "button" }, this.icon && h("span", { key: '17a389fc5025ce39e9c7e7ac4711efa7bc8477ee', class: "trigger-icon", innerHTML: this.icon }), !this.icon && h("span", { key: 'a2e7692e62bc23ee325d2f3e02bf34a2900d1873', class: "trigger-icon-default" }, "\u2630"))));
83
+ }
84
+ static get is() { return "seki-sidebar-trigger"; }
85
+ static get encapsulation() { return "shadow"; }
86
+ static get originalStyleUrls() {
87
+ return {
88
+ "$": ["seki-sidebar-trigger.css"]
89
+ };
90
+ }
91
+ static get styleUrls() {
92
+ return {
93
+ "$": ["seki-sidebar-trigger.css"]
94
+ };
95
+ }
96
+ static get properties() {
97
+ return {
98
+ "ariaLabel": {
99
+ "type": "string",
100
+ "mutable": false,
101
+ "complexType": {
102
+ "original": "SidebarTriggerProps['ariaLabel']",
103
+ "resolved": "string | undefined",
104
+ "references": {
105
+ "SidebarTriggerProps": {
106
+ "location": "import",
107
+ "path": "./types",
108
+ "id": "src/components/sidebar/types.ts::SidebarTriggerProps"
109
+ }
110
+ }
111
+ },
112
+ "required": false,
113
+ "optional": false,
114
+ "docs": {
115
+ "tags": [{
116
+ "name": "type",
117
+ "text": "{string}"
118
+ }, {
119
+ "name": "default",
120
+ "text": "'Toggle sidebar'"
121
+ }],
122
+ "text": "Accessibility label for the button"
123
+ },
124
+ "getter": false,
125
+ "setter": false,
126
+ "reflect": false,
127
+ "attribute": "aria-label",
128
+ "defaultValue": "'Toggle sidebar'"
129
+ },
130
+ "icon": {
131
+ "type": "string",
132
+ "mutable": false,
133
+ "complexType": {
134
+ "original": "SidebarTriggerProps['icon']",
135
+ "resolved": "string | undefined",
136
+ "references": {
137
+ "SidebarTriggerProps": {
138
+ "location": "import",
139
+ "path": "./types",
140
+ "id": "src/components/sidebar/types.ts::SidebarTriggerProps"
141
+ }
142
+ }
143
+ },
144
+ "required": false,
145
+ "optional": false,
146
+ "docs": {
147
+ "tags": [{
148
+ "name": "type",
149
+ "text": "{string}"
150
+ }],
151
+ "text": "Icon name or SVG path (optional)"
152
+ },
153
+ "getter": false,
154
+ "setter": false,
155
+ "reflect": false,
156
+ "attribute": "icon"
157
+ }
158
+ };
159
+ }
160
+ static get states() {
161
+ return {
162
+ "isOpen": {}
163
+ };
164
+ }
165
+ static get elementRef() { return "el"; }
166
+ static get listeners() {
167
+ return [{
168
+ "name": "openChange",
169
+ "method": "handleOpenChange",
170
+ "target": "body",
171
+ "capture": false,
172
+ "passive": false
173
+ }];
174
+ }
175
+ }
@@ -0,0 +1,352 @@
1
+ /**
2
+ * Sidebar Component Styles
3
+ * @description Scoped styles for seki-sidebar and sub-components
4
+ * Includes design tokens for theming, responsive breakpoints, and accessibility
5
+ */
6
+
7
+ /* ============================================================================
8
+ CSS Custom Properties (Design Tokens)
9
+ ============================================================================ */
10
+
11
+ :host {
12
+ /* Background and text colors */
13
+ --sidebar-bg: var(--color-sidebar-bg, #f9fafb);
14
+ --sidebar-foreground: var(--color-sidebar-foreground, #1f2937);
15
+ --sidebar-primary: var(--color-sidebar-primary, #2563eb);
16
+ --sidebar-accent: var(--color-sidebar-accent, #10b981);
17
+ --sidebar-border: var(--color-sidebar-border, #e5e7eb);
18
+
19
+ /* Sizing */
20
+ --sidebar-width: var(--sizing-sidebar-width, 250px);
21
+ --sidebar-collapsed-width: var(--sizing-sidebar-collapsed-width, 64px);
22
+
23
+ /* Spacing */
24
+ --sidebar-padding: var(--spacing-sidebar-padding, 1rem);
25
+ --sidebar-gap: var(--spacing-sidebar-gap, 0.5rem);
26
+ --sidebar-item-padding: var(--spacing-sidebar-item-padding, 0.75rem 1rem);
27
+ --sidebar-item-height: var(--sizing-sidebar-item-height, 44px);
28
+
29
+ /* Styling */
30
+ --sidebar-item-border-radius: var(--radius-sidebar-item, 0.375rem);
31
+ --sidebar-transition-duration: var(--duration-sidebar-transition, 200ms);
32
+
33
+ /* Z-index layers */
34
+ --sidebar-z-header: 10;
35
+ --sidebar-z-footer: 10;
36
+ --sidebar-z-content: 1;
37
+ --sidebar-z-overlay: 40;
38
+ }
39
+
40
+ /* Dark mode overrides */
41
+ :host([data-theme="dark"]),
42
+ :host-context([data-theme="dark"]) {
43
+ --sidebar-bg: var(--color-sidebar-bg-dark, #1f2937);
44
+ --sidebar-foreground: var(--color-sidebar-foreground-dark, #f1f5f9);
45
+ --sidebar-primary: var(--color-sidebar-primary-dark, #60a5fa);
46
+ --sidebar-accent: var(--color-sidebar-accent-dark, #34d399);
47
+ --sidebar-border: var(--color-sidebar-border-dark, #374151);
48
+ }
49
+
50
+ /* ============================================================================
51
+ Main Container Layout
52
+ ============================================================================ */
53
+
54
+ :host {
55
+ display: flex;
56
+ flex-direction: column;
57
+ height: 100%;
58
+ width: var(--sidebar-width);
59
+ background-color: var(--sidebar-bg);
60
+ color: var(--sidebar-foreground);
61
+ border-right: 1px solid var(--sidebar-border);
62
+ transition: width 200ms ease-linear;
63
+ contain: layout style paint;
64
+ }
65
+
66
+ :host([data-state="closed"][data-collapse-mode="icon"]) {
67
+ width: var(--sidebar-collapsed-width);
68
+ }
69
+
70
+ /* Group-based selectors for child components to respond to sidebar state */
71
+ :host([data-collapsible="icon"]) {
72
+ --group-collapsible: icon;
73
+ }
74
+
75
+ :host([data-collapsible="offcanvas"]) {
76
+ --group-collapsible: offcanvas;
77
+ }
78
+
79
+ :host([data-collapsible="none"]) {
80
+ --group-collapsible: none;
81
+ }
82
+
83
+ :host([data-state="closed"][data-collapse-mode="offcanvas"]) {
84
+ position: fixed;
85
+ left: 0;
86
+ top: 0;
87
+ height: 100vh;
88
+ width: var(--sidebar-width);
89
+ transform: translateX(-100%);
90
+ border-right: none;
91
+ box-shadow: 2px 0 8px rgba(0, 0, 0, 0.1);
92
+ z-index: var(--sidebar-z-overlay);
93
+ opacity: 0;
94
+ pointer-events: none;
95
+ }
96
+
97
+ :host([data-state="open"][data-collapse-mode="offcanvas"]) {
98
+ position: fixed;
99
+ left: 0;
100
+ top: 0;
101
+ height: 100vh;
102
+ width: var(--sidebar-width);
103
+ transform: translateX(0);
104
+ box-shadow: 2px 0 8px rgba(0, 0, 0, 0.1);
105
+ z-index: var(--sidebar-z-overlay);
106
+ opacity: 1;
107
+ pointer-events: auto;
108
+ }
109
+
110
+ /* Floating variant */
111
+ :host([data-variant="floating"]) {
112
+ position: absolute;
113
+ border-radius: 0.5rem;
114
+ box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
115
+ border: 1px solid var(--sidebar-border);
116
+ }
117
+
118
+ /* Inset variant - integrated into layout */
119
+ :host([data-variant="inset"]) {
120
+ border-right: 1px solid var(--sidebar-border);
121
+ }
122
+
123
+ /* Container for all sidebar content */
124
+ .sidebar-container {
125
+ display: flex;
126
+ flex-direction: column;
127
+ height: 100%;
128
+ overflow: hidden;
129
+ }
130
+
131
+ /* ============================================================================
132
+ Header Section (Sticky Top)
133
+ ============================================================================ */
134
+
135
+ .sidebar-header {
136
+ flex-shrink: 0;
137
+ padding: var(--sidebar-padding);
138
+ border-bottom: 1px solid var(--sidebar-border);
139
+ position: sticky;
140
+ top: 0;
141
+ z-index: var(--sidebar-z-header);
142
+ background-color: var(--sidebar-bg);
143
+ }
144
+
145
+ .sidebar-header:empty {
146
+ display: none;
147
+ }
148
+
149
+ /* Hide text in header when collapsed to icon mode */
150
+ :host([data-state="closed"][data-collapse-mode="icon"]) .sidebar-header {
151
+ padding: 0.5rem;
152
+ justify-content: center;
153
+ align-items: center;
154
+ }
155
+
156
+ :host([data-state="closed"][data-collapse-mode="icon"]) .sidebar-header > * {
157
+ transition: margin 200ms ease-linear, opacity 200ms ease-linear;
158
+ }
159
+
160
+ :host([data-state="closed"][data-collapse-mode="icon"]) .sidebar-header > :not(svg) {
161
+ margin: -0.5rem 0;
162
+ opacity: 0;
163
+ }
164
+
165
+ /* ============================================================================
166
+ Content Section (Scrollable)
167
+ ============================================================================ */
168
+
169
+ .sidebar-content {
170
+ flex: 1;
171
+ overflow-y: auto;
172
+ overflow-x: hidden;
173
+ padding: var(--sidebar-padding);
174
+ gap: var(--sidebar-gap);
175
+ display: flex;
176
+ flex-direction: column;
177
+
178
+ /* Smooth scroll behavior */
179
+ scroll-behavior: smooth;
180
+ -webkit-overflow-scrolling: touch;
181
+
182
+ /* Allow horizontal ellipsis in collapsed state */
183
+ min-width: 0;
184
+ }
185
+
186
+ /* Scrollbar styling */
187
+ .sidebar-content::-webkit-scrollbar {
188
+ width: 8px;
189
+ }
190
+
191
+ .sidebar-content::-webkit-scrollbar-track {
192
+ background: transparent;
193
+ }
194
+
195
+ .sidebar-content::-webkit-scrollbar-thumb {
196
+ background-color: var(--sidebar-accent);
197
+ border-radius: 4px;
198
+ opacity: 0.5;
199
+ }
200
+
201
+ .sidebar-content::-webkit-scrollbar-thumb:hover {
202
+ opacity: 0.7;
203
+ }
204
+
205
+ /* ============================================================================
206
+ Footer Section (Sticky Bottom)
207
+ ============================================================================ */
208
+
209
+ .sidebar-footer {
210
+ flex-shrink: 0;
211
+ padding: var(--sidebar-padding);
212
+ border-top: 1px solid var(--sidebar-border);
213
+ position: sticky;
214
+ bottom: 0;
215
+ z-index: var(--sidebar-z-footer);
216
+ background-color: var(--sidebar-bg);
217
+ }
218
+
219
+ .sidebar-footer:empty {
220
+ display: none;
221
+ }
222
+
223
+ /* Hide text in footer when collapsed to icon mode, but keep first child (avatar) */
224
+ :host([data-state="closed"][data-collapse-mode="icon"]) .sidebar-footer {
225
+ padding: 0.5rem;
226
+ justify-content: center;
227
+ display: flex;
228
+ align-items: center;
229
+ }
230
+
231
+ :host([data-state="closed"][data-collapse-mode="icon"]) .sidebar-footer > * {
232
+ transition: margin 200ms ease-linear, opacity 200ms ease-linear;
233
+ }
234
+
235
+ :host([data-state="closed"][data-collapse-mode="icon"]) .sidebar-footer > :not(:first-child) {
236
+ margin: -0.5rem 0;
237
+ opacity: 0;
238
+ }
239
+
240
+ /* ============================================================================
241
+ Responsive Behavior
242
+ ============================================================================ */
243
+
244
+ /* Mobile devices (<768px default) */
245
+ @media (max-width: 767px) {
246
+ :host {
247
+ /* Default to offcanvas on mobile */
248
+ position: fixed;
249
+ left: 0;
250
+ top: 0;
251
+ height: 100vh;
252
+ width: var(--sidebar-width);
253
+ transform: translateX(-100%);
254
+ transition: transform var(--sidebar-transition-duration) ease-in-out;
255
+ border-right: none;
256
+ box-shadow: 2px 0 8px rgba(0, 0, 0, 0.1);
257
+ z-index: var(--sidebar-z-overlay);
258
+ opacity: 0;
259
+ pointer-events: none;
260
+ }
261
+
262
+ :host([data-state="open"]) {
263
+ transform: translateX(0);
264
+ opacity: 1;
265
+ pointer-events: auto;
266
+ }
267
+
268
+ :host([data-collapse-mode="none"]) {
269
+ /* Fixed sidebar on mobile */
270
+ position: static;
271
+ width: 100%;
272
+ height: auto;
273
+ border-right: none;
274
+ border-bottom: 1px solid var(--sidebar-border);
275
+ }
276
+ }
277
+
278
+ /* Tablet devices (768px - 1024px) */
279
+ @media (min-width: 768px) and (max-width: 1023px) {
280
+ :host {
281
+ width: var(--sidebar-width);
282
+ }
283
+
284
+ :host([data-state="closed"][data-collapse-mode="icon"]) {
285
+ width: var(--sidebar-collapsed-width);
286
+ }
287
+ }
288
+
289
+ /* Desktop devices (1024px+) */
290
+ @media (min-width: 1024px) {
291
+ :host {
292
+ position: relative;
293
+ width: var(--sidebar-width);
294
+ height: 100%;
295
+ transform: none;
296
+ z-index: auto;
297
+ }
298
+ }
299
+
300
+ /* ============================================================================
301
+ Accessibility Features
302
+ ============================================================================ */
303
+
304
+ /* Focus indicators */
305
+ :host-context(:focus-visible),
306
+ :host:focus-visible {
307
+ outline: 2px solid var(--sidebar-primary);
308
+ outline-offset: -2px;
309
+ }
310
+
311
+ /* Reduce motion preference */
312
+ @media (prefers-reduced-motion: reduce) {
313
+ :host {
314
+ transition: none;
315
+ }
316
+
317
+ .sidebar-content {
318
+ scroll-behavior: auto;
319
+ }
320
+ }
321
+
322
+ /* Print styles */
323
+ @media print {
324
+ :host {
325
+ display: none;
326
+ }
327
+ }
328
+
329
+ /* ============================================================================
330
+ High contrast mode
331
+ ============================================================================ */
332
+
333
+ @media (prefers-contrast: more) {
334
+ :host {
335
+ border-width: 2px;
336
+ }
337
+
338
+ .sidebar-header,
339
+ .sidebar-footer {
340
+ border-width: 2px;
341
+ }
342
+ }
343
+
344
+ /* ============================================================================
345
+ Container queries (future enhancement)
346
+ ============================================================================ */
347
+
348
+ @supports (container-type: inline-size) {
349
+ :host {
350
+ container-type: inline-size;
351
+ }
352
+ }