snice 1.13.2 → 1.13.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 (295) hide show
  1. package/bin/templates/base/README.md +1 -1
  2. package/dist/components/accordion/snice-accordion-item.d.ts +25 -0
  3. package/dist/components/accordion/snice-accordion-item.js +260 -0
  4. package/dist/components/accordion/snice-accordion-item.js.map +1 -0
  5. package/dist/components/accordion/snice-accordion.d.ts +28 -0
  6. package/dist/components/accordion/snice-accordion.js +221 -0
  7. package/dist/components/accordion/snice-accordion.js.map +1 -0
  8. package/dist/components/accordion/snice-accordion.types.d.ts +29 -0
  9. package/dist/components/accordion/snice-accordion.types.js +2 -0
  10. package/dist/components/accordion/snice-accordion.types.js.map +1 -0
  11. package/dist/components/alert/snice-alert.d.ts +26 -0
  12. package/dist/components/alert/snice-alert.js +191 -0
  13. package/dist/components/alert/snice-alert.js.map +1 -0
  14. package/dist/components/alert/snice-alert.types.d.ts +11 -0
  15. package/dist/components/alert/snice-alert.types.js +2 -0
  16. package/dist/components/alert/snice-alert.types.js.map +1 -0
  17. package/dist/components/avatar/snice-avatar.d.ts +24 -0
  18. package/dist/components/avatar/snice-avatar.js +177 -0
  19. package/dist/components/avatar/snice-avatar.js.map +1 -0
  20. package/dist/components/avatar/snice-avatar.types.d.ts +12 -0
  21. package/dist/components/avatar/snice-avatar.types.js +2 -0
  22. package/dist/components/avatar/snice-avatar.types.js.map +1 -0
  23. package/dist/components/badge/snice-badge.d.ts +25 -0
  24. package/dist/components/badge/snice-badge.js +157 -0
  25. package/dist/components/badge/snice-badge.js.map +1 -0
  26. package/dist/components/badge/snice-badge.types.d.ts +15 -0
  27. package/dist/components/badge/snice-badge.types.js +2 -0
  28. package/dist/components/badge/snice-badge.types.js.map +1 -0
  29. package/dist/components/breadcrumbs/snice-breadcrumbs.d.ts +27 -0
  30. package/dist/components/breadcrumbs/snice-breadcrumbs.js +212 -0
  31. package/dist/components/breadcrumbs/snice-breadcrumbs.js.map +1 -0
  32. package/dist/components/breadcrumbs/snice-breadcrumbs.types.d.ts +23 -0
  33. package/dist/components/breadcrumbs/snice-breadcrumbs.types.js +2 -0
  34. package/dist/components/breadcrumbs/snice-breadcrumbs.types.js.map +1 -0
  35. package/dist/components/breadcrumbs/snice-crumb.d.ts +9 -0
  36. package/dist/components/breadcrumbs/snice-crumb.js +50 -0
  37. package/dist/components/breadcrumbs/snice-crumb.js.map +1 -0
  38. package/dist/components/button/snice-button.d.ts +32 -0
  39. package/dist/components/button/snice-button.js +212 -0
  40. package/dist/components/button/snice-button.js.map +1 -0
  41. package/dist/components/button/snice-button.types.d.ts +23 -0
  42. package/dist/components/button/snice-button.types.js +2 -0
  43. package/dist/components/button/snice-button.types.js.map +1 -0
  44. package/dist/components/card/snice-card.d.ts +19 -0
  45. package/dist/components/card/snice-card.js +132 -0
  46. package/dist/components/card/snice-card.js.map +1 -0
  47. package/dist/components/card/snice-card.types.d.ts +9 -0
  48. package/dist/components/card/snice-card.types.js +2 -0
  49. package/dist/components/card/snice-card.types.js.map +1 -0
  50. package/dist/components/checkbox/snice-checkbox.d.ts +34 -0
  51. package/dist/components/checkbox/snice-checkbox.js +289 -0
  52. package/dist/components/checkbox/snice-checkbox.js.map +1 -0
  53. package/dist/components/checkbox/snice-checkbox.types.d.ts +20 -0
  54. package/dist/components/checkbox/snice-checkbox.types.js +2 -0
  55. package/dist/components/checkbox/snice-checkbox.types.js.map +1 -0
  56. package/dist/components/chip/snice-chip.d.ts +28 -0
  57. package/dist/components/chip/snice-chip.js +203 -0
  58. package/dist/components/chip/snice-chip.js.map +1 -0
  59. package/dist/components/chip/snice-chip.types.d.ts +14 -0
  60. package/dist/components/chip/snice-chip.types.js +2 -0
  61. package/dist/components/chip/snice-chip.types.js.map +1 -0
  62. package/dist/components/date-picker/snice-date-picker.d.ts +82 -0
  63. package/dist/components/date-picker/snice-date-picker.js +880 -0
  64. package/dist/components/date-picker/snice-date-picker.js.map +1 -0
  65. package/dist/components/date-picker/snice-date-picker.types.d.ts +71 -0
  66. package/dist/components/date-picker/snice-date-picker.types.js +2 -0
  67. package/dist/components/date-picker/snice-date-picker.types.js.map +1 -0
  68. package/dist/components/divider/snice-divider.d.ts +17 -0
  69. package/dist/components/divider/snice-divider.js +111 -0
  70. package/dist/components/divider/snice-divider.js.map +1 -0
  71. package/dist/components/divider/snice-divider.types.d.ts +14 -0
  72. package/dist/components/divider/snice-divider.types.js +2 -0
  73. package/dist/components/divider/snice-divider.types.js.map +1 -0
  74. package/dist/components/drawer/snice-drawer.d.ts +37 -0
  75. package/dist/components/drawer/snice-drawer.js +335 -0
  76. package/dist/components/drawer/snice-drawer.js.map +1 -0
  77. package/dist/components/drawer/snice-drawer.types.d.ts +16 -0
  78. package/dist/components/drawer/snice-drawer.types.js +2 -0
  79. package/dist/components/drawer/snice-drawer.types.js.map +1 -0
  80. package/dist/components/input/snice-input.d.ts +65 -0
  81. package/dist/components/input/snice-input.js +603 -0
  82. package/dist/components/input/snice-input.js.map +1 -0
  83. package/dist/components/input/snice-input.types.d.ts +53 -0
  84. package/dist/components/input/snice-input.types.js +2 -0
  85. package/dist/components/input/snice-input.types.js.map +1 -0
  86. package/dist/components/layout/snice-layout-blog.d.ts +4 -0
  87. package/dist/components/layout/snice-layout-blog.js +56 -0
  88. package/dist/components/layout/snice-layout-blog.js.map +1 -0
  89. package/dist/components/layout/snice-layout-card.d.ts +6 -0
  90. package/dist/components/layout/snice-layout-card.js +53 -0
  91. package/dist/components/layout/snice-layout-card.js.map +1 -0
  92. package/dist/components/layout/snice-layout-centered.d.ts +5 -0
  93. package/dist/components/layout/snice-layout-centered.js +38 -0
  94. package/dist/components/layout/snice-layout-centered.js.map +1 -0
  95. package/dist/components/layout/snice-layout-dashboard.d.ts +4 -0
  96. package/dist/components/layout/snice-layout-dashboard.js +53 -0
  97. package/dist/components/layout/snice-layout-dashboard.js.map +1 -0
  98. package/dist/components/layout/snice-layout-fullscreen.d.ts +5 -0
  99. package/dist/components/layout/snice-layout-fullscreen.js +50 -0
  100. package/dist/components/layout/snice-layout-fullscreen.js.map +1 -0
  101. package/dist/components/layout/snice-layout-landing.d.ts +4 -0
  102. package/dist/components/layout/snice-layout-landing.js +55 -0
  103. package/dist/components/layout/snice-layout-landing.js.map +1 -0
  104. package/dist/components/layout/snice-layout-minimal.d.ts +4 -0
  105. package/dist/components/layout/snice-layout-minimal.js +27 -0
  106. package/dist/components/layout/snice-layout-minimal.js.map +1 -0
  107. package/dist/components/layout/snice-layout-sidebar.d.ts +5 -0
  108. package/dist/components/layout/snice-layout-sidebar.js +64 -0
  109. package/dist/components/layout/snice-layout-sidebar.js.map +1 -0
  110. package/dist/components/layout/snice-layout-split.d.ts +6 -0
  111. package/dist/components/layout/snice-layout-split.js +47 -0
  112. package/dist/components/layout/snice-layout-split.js.map +1 -0
  113. package/dist/components/layout/snice-layout.d.ts +4 -0
  114. package/dist/components/layout/snice-layout.js +43 -0
  115. package/dist/components/layout/snice-layout.js.map +1 -0
  116. package/dist/components/layout/snice-layout.types.d.ts +3 -0
  117. package/dist/components/layout/snice-layout.types.js +2 -0
  118. package/dist/components/layout/snice-layout.types.js.map +1 -0
  119. package/dist/components/login/snice-login.d.ts +45 -0
  120. package/dist/components/login/snice-login.js +385 -0
  121. package/dist/components/login/snice-login.js.map +1 -0
  122. package/dist/components/login/snice-login.types.d.ts +31 -0
  123. package/dist/components/login/snice-login.types.js +2 -0
  124. package/dist/components/login/snice-login.types.js.map +1 -0
  125. package/dist/components/modal/snice-modal.d.ts +32 -0
  126. package/dist/components/modal/snice-modal.js +288 -0
  127. package/dist/components/modal/snice-modal.js.map +1 -0
  128. package/dist/components/modal/snice-modal.types.d.ts +18 -0
  129. package/dist/components/modal/snice-modal.types.js +2 -0
  130. package/dist/components/modal/snice-modal.types.js.map +1 -0
  131. package/dist/components/pagination/snice-pagination.d.ts +26 -0
  132. package/dist/components/pagination/snice-pagination.js +373 -0
  133. package/dist/components/pagination/snice-pagination.js.map +1 -0
  134. package/dist/components/pagination/snice-pagination.types.d.ts +18 -0
  135. package/dist/components/pagination/snice-pagination.types.js +2 -0
  136. package/dist/components/pagination/snice-pagination.types.js.map +1 -0
  137. package/dist/components/progress/snice-progress.d.ts +35 -0
  138. package/dist/components/progress/snice-progress.js +295 -0
  139. package/dist/components/progress/snice-progress.js.map +1 -0
  140. package/dist/components/progress/snice-progress.types.d.ts +18 -0
  141. package/dist/components/progress/snice-progress.types.js +2 -0
  142. package/dist/components/progress/snice-progress.types.js.map +1 -0
  143. package/dist/components/radio/snice-radio.d.ts +33 -0
  144. package/dist/components/radio/snice-radio.js +286 -0
  145. package/dist/components/radio/snice-radio.js.map +1 -0
  146. package/dist/components/radio/snice-radio.types.d.ts +19 -0
  147. package/dist/components/radio/snice-radio.types.js +2 -0
  148. package/dist/components/radio/snice-radio.types.js.map +1 -0
  149. package/dist/components/select/snice-option.d.ts +17 -0
  150. package/dist/components/select/snice-option.js +77 -0
  151. package/dist/components/select/snice-option.js.map +1 -0
  152. package/dist/components/select/snice-option.types.d.ts +14 -0
  153. package/dist/components/select/snice-option.types.js +2 -0
  154. package/dist/components/select/snice-option.types.js.map +1 -0
  155. package/dist/components/select/snice-select.d.ts +89 -0
  156. package/dist/components/select/snice-select.js +900 -0
  157. package/dist/components/select/snice-select.js.map +1 -0
  158. package/dist/components/select/snice-select.types.d.ts +49 -0
  159. package/dist/components/select/snice-select.types.js +2 -0
  160. package/dist/components/select/snice-select.types.js.map +1 -0
  161. package/dist/components/skeleton/snice-skeleton.d.ts +16 -0
  162. package/dist/components/skeleton/snice-skeleton.js +159 -0
  163. package/dist/components/skeleton/snice-skeleton.js.map +1 -0
  164. package/dist/components/skeleton/snice-skeleton.types.d.ts +10 -0
  165. package/dist/components/skeleton/snice-skeleton.types.js +2 -0
  166. package/dist/components/skeleton/snice-skeleton.types.js.map +1 -0
  167. package/dist/components/switch/snice-switch.d.ts +38 -0
  168. package/dist/components/switch/snice-switch.js +309 -0
  169. package/dist/components/switch/snice-switch.js.map +1 -0
  170. package/dist/components/switch/snice-switch.types.d.ts +21 -0
  171. package/dist/components/switch/snice-switch.types.js +2 -0
  172. package/dist/components/switch/snice-switch.types.js.map +1 -0
  173. package/dist/components/symbols.d.ts +1 -0
  174. package/dist/components/symbols.js +20 -0
  175. package/dist/components/symbols.js.map +1 -0
  176. package/dist/components/table/snice-cell-boolean.d.ts +21 -0
  177. package/dist/components/table/snice-cell-boolean.js +152 -0
  178. package/dist/components/table/snice-cell-boolean.js.map +1 -0
  179. package/dist/components/table/snice-cell-date.d.ts +24 -0
  180. package/dist/components/table/snice-cell-date.js +240 -0
  181. package/dist/components/table/snice-cell-date.js.map +1 -0
  182. package/dist/components/table/snice-cell-duration.d.ts +16 -0
  183. package/dist/components/table/snice-cell-duration.js +123 -0
  184. package/dist/components/table/snice-cell-duration.js.map +1 -0
  185. package/dist/components/table/snice-cell-filesize.d.ts +16 -0
  186. package/dist/components/table/snice-cell-filesize.js +119 -0
  187. package/dist/components/table/snice-cell-filesize.js.map +1 -0
  188. package/dist/components/table/snice-cell-number.d.ts +23 -0
  189. package/dist/components/table/snice-cell-number.js +202 -0
  190. package/dist/components/table/snice-cell-number.js.map +1 -0
  191. package/dist/components/table/snice-cell-progress.d.ts +17 -0
  192. package/dist/components/table/snice-cell-progress.js +114 -0
  193. package/dist/components/table/snice-cell-progress.js.map +1 -0
  194. package/dist/components/table/snice-cell-rating.d.ts +17 -0
  195. package/dist/components/table/snice-cell-rating.js +113 -0
  196. package/dist/components/table/snice-cell-rating.js.map +1 -0
  197. package/dist/components/table/snice-cell-sparkline.d.ts +29 -0
  198. package/dist/components/table/snice-cell-sparkline.js +290 -0
  199. package/dist/components/table/snice-cell-sparkline.js.map +1 -0
  200. package/dist/components/table/snice-cell-text.d.ts +19 -0
  201. package/dist/components/table/snice-cell-text.js +153 -0
  202. package/dist/components/table/snice-cell-text.js.map +1 -0
  203. package/dist/components/table/snice-cell.d.ts +32 -0
  204. package/dist/components/table/snice-cell.js +451 -0
  205. package/dist/components/table/snice-cell.js.map +1 -0
  206. package/dist/components/table/snice-column.d.ts +62 -0
  207. package/dist/components/table/snice-column.js +440 -0
  208. package/dist/components/table/snice-column.js.map +1 -0
  209. package/dist/components/table/snice-header.d.ts +33 -0
  210. package/dist/components/table/snice-header.js +303 -0
  211. package/dist/components/table/snice-header.js.map +1 -0
  212. package/dist/components/table/snice-progress.d.ts +10 -0
  213. package/dist/components/table/snice-progress.js +91 -0
  214. package/dist/components/table/snice-progress.js.map +1 -0
  215. package/dist/components/table/snice-rating.d.ts +9 -0
  216. package/dist/components/table/snice-rating.js +68 -0
  217. package/dist/components/table/snice-rating.js.map +1 -0
  218. package/dist/components/table/snice-row.d.ts +43 -0
  219. package/dist/components/table/snice-row.js +365 -0
  220. package/dist/components/table/snice-row.js.map +1 -0
  221. package/dist/components/table/snice-table.d.ts +69 -0
  222. package/dist/components/table/snice-table.js +814 -0
  223. package/dist/components/table/snice-table.js.map +1 -0
  224. package/dist/components/table/snice-table.types.d.ts +137 -0
  225. package/dist/components/table/snice-table.types.js +2 -0
  226. package/dist/components/table/snice-table.types.js.map +1 -0
  227. package/dist/components/tabs/snice-tab-panel.d.ts +12 -0
  228. package/dist/components/tabs/snice-tab-panel.js +78 -0
  229. package/dist/components/tabs/snice-tab-panel.js.map +1 -0
  230. package/dist/components/tabs/snice-tab.d.ts +13 -0
  231. package/dist/components/tabs/snice-tab.js +90 -0
  232. package/dist/components/tabs/snice-tab.js.map +1 -0
  233. package/dist/components/tabs/snice-tabs.d.ts +34 -0
  234. package/dist/components/tabs/snice-tabs.js +367 -0
  235. package/dist/components/tabs/snice-tabs.js.map +1 -0
  236. package/dist/components/tabs/snice-tabs.types.d.ts +23 -0
  237. package/dist/components/tabs/snice-tabs.types.js +2 -0
  238. package/dist/components/tabs/snice-tabs.types.js.map +1 -0
  239. package/dist/components/toast/snice-toast-container.d.ts +25 -0
  240. package/dist/components/toast/snice-toast-container.js +251 -0
  241. package/dist/components/toast/snice-toast-container.js.map +1 -0
  242. package/dist/components/toast/snice-toast.d.ts +23 -0
  243. package/dist/components/toast/snice-toast.js +316 -0
  244. package/dist/components/toast/snice-toast.js.map +1 -0
  245. package/dist/components/toast/snice-toast.types.d.ts +30 -0
  246. package/dist/components/toast/snice-toast.types.js +2 -0
  247. package/dist/components/toast/snice-toast.types.js.map +1 -0
  248. package/dist/components/tooltip/snice-tooltip.d.ts +50 -0
  249. package/dist/components/tooltip/snice-tooltip.js +656 -0
  250. package/dist/components/tooltip/snice-tooltip.js.map +1 -0
  251. package/dist/components/tooltip/snice-tooltip.types.d.ts +18 -0
  252. package/dist/components/tooltip/snice-tooltip.types.js +2 -0
  253. package/dist/components/tooltip/snice-tooltip.types.js.map +1 -0
  254. package/dist/components/transitions.d.ts +11 -0
  255. package/dist/components/transitions.js +69 -0
  256. package/dist/components/transitions.js.map +1 -0
  257. package/dist/src/controller.d.ts +61 -0
  258. package/dist/src/controller.js +297 -0
  259. package/dist/src/controller.js.map +1 -0
  260. package/dist/src/element.d.ts +77 -0
  261. package/dist/src/element.js +805 -0
  262. package/dist/src/element.js.map +1 -0
  263. package/dist/src/events.d.ts +37 -0
  264. package/dist/src/events.js +289 -0
  265. package/dist/src/events.js.map +1 -0
  266. package/dist/src/global.d.ts +7 -0
  267. package/dist/src/global.js +23 -0
  268. package/dist/src/global.js.map +1 -0
  269. package/{src/index.ts → dist/src/index.d.ts} +1 -1
  270. package/dist/src/index.js +8 -0
  271. package/dist/src/index.js.map +1 -0
  272. package/dist/src/observe.d.ts +26 -0
  273. package/dist/src/observe.js +329 -0
  274. package/dist/src/observe.js.map +1 -0
  275. package/dist/src/request-response.d.ts +46 -0
  276. package/dist/src/request-response.js +267 -0
  277. package/dist/src/request-response.js.map +1 -0
  278. package/dist/src/router.d.ts +87 -0
  279. package/dist/src/router.js +375 -0
  280. package/dist/src/router.js.map +1 -0
  281. package/dist/src/symbols.d.ts +29 -0
  282. package/{src/symbols.ts → dist/src/symbols.js} +2 -12
  283. package/dist/src/symbols.js.map +1 -0
  284. package/dist/src/transitions.d.ts +50 -0
  285. package/dist/src/transitions.js +199 -0
  286. package/dist/src/transitions.js.map +1 -0
  287. package/package.json +6 -8
  288. package/src/controller.ts +0 -347
  289. package/src/element.ts +0 -897
  290. package/src/events.ts +0 -349
  291. package/src/global.ts +0 -31
  292. package/src/observe.ts +0 -414
  293. package/src/request-response.ts +0 -336
  294. package/src/router.ts +0 -552
  295. package/src/transitions.ts +0 -264
@@ -0,0 +1,303 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ var __metadata = (this && this.__metadata) || function (k, v) {
8
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
9
+ };
10
+ import { element, property, on, watch, ready, dispatch } from '../../src/index';
11
+ let SniceHeader = class SniceHeader extends HTMLElement {
12
+ constructor() {
13
+ super(...arguments);
14
+ this.sticky = false;
15
+ this.columns = [];
16
+ this.selectable = false;
17
+ this.sortable = false;
18
+ this.currentSort = { column: '', direction: null };
19
+ this.allSelected = false;
20
+ this.someSelected = false;
21
+ }
22
+ html() {
23
+ return `
24
+ <div class="header-container" part="container">
25
+ ${this.selectable ? this.renderSelectAllCheckbox() : ''}
26
+ ${this.renderHeaderCells()}
27
+ </div>
28
+ `;
29
+ }
30
+ init() {
31
+ this.updateHeaderAttributes();
32
+ }
33
+ updateHeaderAttributes() {
34
+ this.classList.toggle('header--sticky', this.sticky);
35
+ this.classList.toggle('header--selectable', this.selectable);
36
+ this.classList.toggle('header--sortable', this.sortable);
37
+ }
38
+ updateHeaderCells() {
39
+ const cellsContainer = this.shadowRoot?.querySelector('.cells-container');
40
+ if (cellsContainer) {
41
+ cellsContainer.innerHTML = this.renderHeaderCells();
42
+ }
43
+ }
44
+ updateSelectAllCheckbox() {
45
+ const checkbox = this.shadowRoot?.querySelector('.select-all-checkbox');
46
+ if (checkbox) {
47
+ checkbox.checked = this.allSelected;
48
+ checkbox.indeterminate = this.someSelected && !this.allSelected;
49
+ }
50
+ }
51
+ handleSort(e) {
52
+ const cell = e.currentTarget;
53
+ const columnKey = cell.dataset.columnKey;
54
+ if (columnKey && this.sortable) {
55
+ this.dispatchSort(columnKey);
56
+ }
57
+ }
58
+ handleSelectAll(e) {
59
+ const checkbox = e.target;
60
+ this.dispatchSelectAll(checkbox.checked);
61
+ }
62
+ handleKeyDown(e) {
63
+ if (e.key === 'Enter' || e.key === ' ') {
64
+ e.preventDefault();
65
+ const cell = e.currentTarget;
66
+ const columnKey = cell.dataset.columnKey;
67
+ if (columnKey && this.sortable) {
68
+ this.dispatchSort(columnKey);
69
+ }
70
+ }
71
+ }
72
+ renderSelectAllCheckbox() {
73
+ return `
74
+ <div class="header-cell header-cell--checkbox" part="checkbox-cell">
75
+ <input
76
+ type="checkbox"
77
+ class="select-all-checkbox"
78
+ ${this.allSelected ? 'checked' : ''}
79
+ title="Select all rows"
80
+ tabindex="0"
81
+ />
82
+ </div>
83
+ `;
84
+ }
85
+ renderHeaderCells() {
86
+ if (!this.columns.length) {
87
+ return '';
88
+ }
89
+ return `
90
+ <div class="cells-container">
91
+ ${this.columns.map((column, index) => this.renderHeaderCell(column, index)).join('')}
92
+ </div>
93
+ `;
94
+ }
95
+ renderHeaderCell(column, index) {
96
+ const isSortable = this.sortable && column.sortable !== false;
97
+ const isCurrentSort = this.currentSort.column === column.key;
98
+ const sortDirection = isCurrentSort ? this.currentSort.direction : null;
99
+ return `
100
+ <div
101
+ class="header-cell header-cell--${column.type || 'text'}"
102
+ part="cell"
103
+ data-column-key="${column.key}"
104
+ data-column-index="${index}"
105
+ data-sortable="${isSortable}"
106
+ style="${this.getHeaderCellStyles(column)}"
107
+ ${isSortable ? 'role="button" tabindex="0"' : ''}
108
+ ${isSortable ? `aria-label="Sort by ${column.label}"` : ''}
109
+ ${isCurrentSort ? `aria-sort="${this.getAriaSortValue(sortDirection)}"` : ''}
110
+ >
111
+ <div class="header-cell-content">
112
+ <span class="header-cell-label">${column.label}</span>
113
+ ${isSortable ? this.renderSortIndicator(sortDirection) : ''}
114
+ </div>
115
+ ${column.filterable ? this.renderFilterButton(column) : ''}
116
+ </div>
117
+ `;
118
+ }
119
+ renderSortIndicator(direction) {
120
+ const ascIcon = '▲';
121
+ const descIcon = '▼';
122
+ const neutralIcon = '⇅';
123
+ let icon = neutralIcon;
124
+ let state = 'neutral';
125
+ if (direction === 'asc') {
126
+ icon = ascIcon;
127
+ state = 'ascending';
128
+ }
129
+ else if (direction === 'desc') {
130
+ icon = descIcon;
131
+ state = 'descending';
132
+ }
133
+ return `
134
+ <span
135
+ class="sort-indicator sort-indicator--${state}"
136
+ part="sort-indicator"
137
+ aria-hidden="true"
138
+ >${icon}</span>
139
+ `;
140
+ }
141
+ renderFilterButton(column) {
142
+ return `
143
+ <button
144
+ class="filter-button"
145
+ part="filter-button"
146
+ data-column-key="${column.key}"
147
+ title="Filter ${column.label}"
148
+ tabindex="-1"
149
+ >
150
+ 🔽
151
+ </button>
152
+ `;
153
+ }
154
+ getHeaderCellStyles(column) {
155
+ let styles = [];
156
+ if (column.width) {
157
+ styles.push(`width: ${column.width}`);
158
+ styles.push(`min-width: ${column.width}`);
159
+ styles.push(`max-width: ${column.width}`);
160
+ }
161
+ if (column.align) {
162
+ styles.push(`text-align: ${column.align}`);
163
+ }
164
+ return styles.join('; ');
165
+ }
166
+ getAriaSortValue(direction) {
167
+ switch (direction) {
168
+ case 'asc':
169
+ return 'ascending';
170
+ case 'desc':
171
+ return 'descending';
172
+ default:
173
+ return 'none';
174
+ }
175
+ }
176
+ dispatchSort(columnKey) {
177
+ return { column: columnKey };
178
+ }
179
+ dispatchSelectAll(checked) {
180
+ return { checked };
181
+ }
182
+ dispatchFilter(columnKey) {
183
+ return { column: columnKey };
184
+ }
185
+ // Public API methods
186
+ setSortState(column, direction) {
187
+ this.currentSort = { column, direction };
188
+ }
189
+ setSelectionState(allSelected, someSelected = false) {
190
+ this.allSelected = allSelected;
191
+ this.someSelected = someSelected && !allSelected;
192
+ }
193
+ getColumnElement(columnKey) {
194
+ return this.shadowRoot?.querySelector(`[data-column-key="${columnKey}"]`) || null;
195
+ }
196
+ // Method to update column definitions
197
+ updateColumns(columns) {
198
+ this.columns = columns;
199
+ }
200
+ // Method to highlight a column temporarily
201
+ highlightColumn(columnKey, duration = 2000) {
202
+ const columnElement = this.getColumnElement(columnKey);
203
+ if (columnElement) {
204
+ columnElement.classList.add('header-cell--highlighted');
205
+ setTimeout(() => {
206
+ columnElement.classList.remove('header-cell--highlighted');
207
+ }, duration);
208
+ }
209
+ }
210
+ };
211
+ __decorate([
212
+ property({ type: Boolean, reflect: true }),
213
+ __metadata("design:type", Boolean)
214
+ ], SniceHeader.prototype, "sticky", void 0);
215
+ __decorate([
216
+ property({ type: Array }),
217
+ __metadata("design:type", Array)
218
+ ], SniceHeader.prototype, "columns", void 0);
219
+ __decorate([
220
+ property({ type: Boolean, reflect: true }),
221
+ __metadata("design:type", Boolean)
222
+ ], SniceHeader.prototype, "selectable", void 0);
223
+ __decorate([
224
+ property({ type: Boolean, reflect: true }),
225
+ __metadata("design:type", Boolean)
226
+ ], SniceHeader.prototype, "sortable", void 0);
227
+ __decorate([
228
+ property({ type: Object }),
229
+ __metadata("design:type", Object)
230
+ ], SniceHeader.prototype, "currentSort", void 0);
231
+ __decorate([
232
+ property({ type: Boolean, reflect: true, attribute: 'all-selected' }),
233
+ __metadata("design:type", Boolean)
234
+ ], SniceHeader.prototype, "allSelected", void 0);
235
+ __decorate([
236
+ property({ type: Boolean, reflect: true, attribute: 'some-selected' }),
237
+ __metadata("design:type", Boolean)
238
+ ], SniceHeader.prototype, "someSelected", void 0);
239
+ __decorate([
240
+ ready(),
241
+ __metadata("design:type", Function),
242
+ __metadata("design:paramtypes", []),
243
+ __metadata("design:returntype", void 0)
244
+ ], SniceHeader.prototype, "init", null);
245
+ __decorate([
246
+ watch('sticky', 'selectable', 'sortable'),
247
+ __metadata("design:type", Function),
248
+ __metadata("design:paramtypes", []),
249
+ __metadata("design:returntype", void 0)
250
+ ], SniceHeader.prototype, "updateHeaderAttributes", null);
251
+ __decorate([
252
+ watch('columns', 'currentSort'),
253
+ __metadata("design:type", Function),
254
+ __metadata("design:paramtypes", []),
255
+ __metadata("design:returntype", void 0)
256
+ ], SniceHeader.prototype, "updateHeaderCells", null);
257
+ __decorate([
258
+ watch('allSelected', 'someSelected'),
259
+ __metadata("design:type", Function),
260
+ __metadata("design:paramtypes", []),
261
+ __metadata("design:returntype", void 0)
262
+ ], SniceHeader.prototype, "updateSelectAllCheckbox", null);
263
+ __decorate([
264
+ on('click', '.header-cell[data-sortable="true"]'),
265
+ __metadata("design:type", Function),
266
+ __metadata("design:paramtypes", [MouseEvent]),
267
+ __metadata("design:returntype", void 0)
268
+ ], SniceHeader.prototype, "handleSort", null);
269
+ __decorate([
270
+ on('change', '.select-all-checkbox'),
271
+ __metadata("design:type", Function),
272
+ __metadata("design:paramtypes", [Event]),
273
+ __metadata("design:returntype", void 0)
274
+ ], SniceHeader.prototype, "handleSelectAll", null);
275
+ __decorate([
276
+ on('keydown', '.header-cell[data-sortable="true"]'),
277
+ __metadata("design:type", Function),
278
+ __metadata("design:paramtypes", [KeyboardEvent]),
279
+ __metadata("design:returntype", void 0)
280
+ ], SniceHeader.prototype, "handleKeyDown", null);
281
+ __decorate([
282
+ dispatch('@snice/header-sort', { bubbles: true, composed: true }),
283
+ __metadata("design:type", Function),
284
+ __metadata("design:paramtypes", [String]),
285
+ __metadata("design:returntype", void 0)
286
+ ], SniceHeader.prototype, "dispatchSort", null);
287
+ __decorate([
288
+ dispatch('@snice/header-select-all', { bubbles: true, composed: true }),
289
+ __metadata("design:type", Function),
290
+ __metadata("design:paramtypes", [Boolean]),
291
+ __metadata("design:returntype", void 0)
292
+ ], SniceHeader.prototype, "dispatchSelectAll", null);
293
+ __decorate([
294
+ dispatch('@snice/header-filter', { bubbles: true, composed: true }),
295
+ __metadata("design:type", Function),
296
+ __metadata("design:paramtypes", [String]),
297
+ __metadata("design:returntype", void 0)
298
+ ], SniceHeader.prototype, "dispatchFilter", null);
299
+ SniceHeader = __decorate([
300
+ element('snice-header')
301
+ ], SniceHeader);
302
+ export { SniceHeader };
303
+ //# sourceMappingURL=snice-header.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"snice-header.js","sourceRoot":"","sources":["../../../components/table/snice-header.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ export declare class SniceProgress extends HTMLElement {
2
+ value: number;
3
+ max: number;
4
+ color: string;
5
+ backgroundColor: string;
6
+ height: string;
7
+ showPercentage: boolean;
8
+ html(): string;
9
+ css(): string;
10
+ }
@@ -0,0 +1,91 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ var __metadata = (this && this.__metadata) || function (k, v) {
8
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
9
+ };
10
+ import { element, property } from '../../src/index';
11
+ let SniceProgress = class SniceProgress extends HTMLElement {
12
+ constructor() {
13
+ super(...arguments);
14
+ this.value = 0;
15
+ this.max = 100;
16
+ this.color = '#3b82f6';
17
+ this.backgroundColor = '#e5e7eb';
18
+ this.height = '0.5rem'; /* 8px */
19
+ this.showPercentage = false;
20
+ }
21
+ html() {
22
+ const percentage = Math.min(100, (this.value / this.max) * 100);
23
+ return `
24
+ <div class="progress-container">
25
+ <div class="progress-bar" style="width: ${percentage}%"></div>
26
+ </div>
27
+ ${this.showPercentage ? `
28
+ <span class="percentage">${percentage.toFixed(0)}%</span>
29
+ ` : ''}
30
+ `;
31
+ }
32
+ css() {
33
+ return `
34
+ :host {
35
+ display: inline-flex;
36
+ align-items: center;
37
+ width: 100%;
38
+ gap: 0.5rem; /* 8px */
39
+ }
40
+
41
+ .progress-container {
42
+ flex: 1;
43
+ height: ${this.height};
44
+ background: ${this.backgroundColor};
45
+ border-radius: 0.25rem; /* 4px */
46
+ overflow: hidden;
47
+ }
48
+
49
+ .progress-bar {
50
+ height: 100%;
51
+ background: ${this.color};
52
+ transition: width 0.3s ease;
53
+ }
54
+
55
+ .percentage {
56
+ font-size: 0.875rem; /* 14px */
57
+ color: #6b7280;
58
+ min-width: 2.1875rem; /* 35px */
59
+ }
60
+ `;
61
+ }
62
+ };
63
+ __decorate([
64
+ property({ type: Number }),
65
+ __metadata("design:type", Object)
66
+ ], SniceProgress.prototype, "value", void 0);
67
+ __decorate([
68
+ property({ type: Number }),
69
+ __metadata("design:type", Object)
70
+ ], SniceProgress.prototype, "max", void 0);
71
+ __decorate([
72
+ property(),
73
+ __metadata("design:type", Object)
74
+ ], SniceProgress.prototype, "color", void 0);
75
+ __decorate([
76
+ property(),
77
+ __metadata("design:type", Object)
78
+ ], SniceProgress.prototype, "backgroundColor", void 0);
79
+ __decorate([
80
+ property(),
81
+ __metadata("design:type", Object)
82
+ ], SniceProgress.prototype, "height", void 0);
83
+ __decorate([
84
+ property({ type: Boolean }),
85
+ __metadata("design:type", Object)
86
+ ], SniceProgress.prototype, "showPercentage", void 0);
87
+ SniceProgress = __decorate([
88
+ element('snice-progress')
89
+ ], SniceProgress);
90
+ export { SniceProgress };
91
+ //# sourceMappingURL=snice-progress.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"snice-progress.js","sourceRoot":"","sources":["../../../components/table/snice-progress.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAG7C,IAAM,aAAa,GAAnB,MAAM,aAAc,SAAQ,WAAW;IAAvC;;QAEL,UAAK,GAAG,CAAC,CAAC;QAGV,QAAG,GAAG,GAAG,CAAC;QAGV,UAAK,GAAG,SAAS,CAAC;QAGlB,oBAAe,GAAG,SAAS,CAAC;QAG5B,WAAM,GAAG,QAAQ,CAAC,CAAC,SAAS;QAG5B,mBAAc,GAAG,KAAK,CAAC;IA6CzB,CAAC;IA3CC,IAAI;QACF,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC;QAEhE,OAAO;;kDAEuC,UAAU;;QAEpD,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC;mCACK,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC;OACjD,CAAC,CAAC,CAAC,EAAE;KACP,CAAC;IACJ,CAAC;IAED,GAAG;QACD,OAAO;;;;;;;;;;kBAUO,IAAI,CAAC,MAAM;sBACP,IAAI,CAAC,eAAe;;;;;;;sBAOpB,IAAI,CAAC,KAAK;;;;;;;;;KAS3B,CAAC;IACJ,CAAC;CACF,CAAA;AA5DC;IADC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;4CACjB;AAGV;IADC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;0CACjB;AAGV;IADC,QAAQ,EAAE;;4CACO;AAGlB;IADC,QAAQ,EAAE;;sDACiB;AAG5B;IADC,QAAQ,EAAE;;6CACO;AAGlB;IADC,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;;qDACL;AAjBZ,aAAa;IADzB,OAAO,CAAC,gBAAgB,CAAC;GACb,aAAa,CA8DzB"}
@@ -0,0 +1,9 @@
1
+ export declare class SniceRating extends HTMLElement {
2
+ value: number;
3
+ max: number;
4
+ symbol: string;
5
+ emptySymbol: string;
6
+ color: string;
7
+ html(): string;
8
+ css(): string;
9
+ }
@@ -0,0 +1,68 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ var __metadata = (this && this.__metadata) || function (k, v) {
8
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
9
+ };
10
+ import { element, property } from '../../src/index';
11
+ let SniceRating = class SniceRating extends HTMLElement {
12
+ constructor() {
13
+ super(...arguments);
14
+ this.value = 0;
15
+ this.max = 5;
16
+ this.symbol = '★';
17
+ this.emptySymbol = '☆';
18
+ this.color = '#facc15';
19
+ }
20
+ html() {
21
+ const filled = Math.round(this.value);
22
+ const empty = this.max - filled;
23
+ return `
24
+ <span class="filled">${this.symbol.repeat(filled)}</span><span class="empty">${this.emptySymbol.repeat(empty)}</span>
25
+ `;
26
+ }
27
+ css() {
28
+ return `
29
+ :host {
30
+ display: inline-block;
31
+ font-size: 1.2em;
32
+ }
33
+
34
+ .filled {
35
+ color: ${this.color};
36
+ }
37
+
38
+ .empty {
39
+ color: #d1d5db;
40
+ }
41
+ `;
42
+ }
43
+ };
44
+ __decorate([
45
+ property({ type: Number }),
46
+ __metadata("design:type", Object)
47
+ ], SniceRating.prototype, "value", void 0);
48
+ __decorate([
49
+ property({ type: Number }),
50
+ __metadata("design:type", Object)
51
+ ], SniceRating.prototype, "max", void 0);
52
+ __decorate([
53
+ property(),
54
+ __metadata("design:type", Object)
55
+ ], SniceRating.prototype, "symbol", void 0);
56
+ __decorate([
57
+ property(),
58
+ __metadata("design:type", Object)
59
+ ], SniceRating.prototype, "emptySymbol", void 0);
60
+ __decorate([
61
+ property(),
62
+ __metadata("design:type", Object)
63
+ ], SniceRating.prototype, "color", void 0);
64
+ SniceRating = __decorate([
65
+ element('snice-rating')
66
+ ], SniceRating);
67
+ export { SniceRating };
68
+ //# sourceMappingURL=snice-rating.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"snice-rating.js","sourceRoot":"","sources":["../../../components/table/snice-rating.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAG7C,IAAM,WAAW,GAAjB,MAAM,WAAY,SAAQ,WAAW;IAArC;;QAEL,UAAK,GAAG,CAAC,CAAC;QAGV,QAAG,GAAG,CAAC,CAAC;QAGR,WAAM,GAAG,GAAG,CAAC;QAGb,gBAAW,GAAG,GAAG,CAAC;QAGlB,UAAK,GAAG,SAAS,CAAC;IA2BpB,CAAC;IAzBC,IAAI;QACF,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACtC,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,GAAG,MAAM,CAAC;QAEhC,OAAO;6BACkB,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,8BAA8B,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,CAAC;KAC9G,CAAC;IACJ,CAAC;IAED,GAAG;QACD,OAAO;;;;;;;iBAOM,IAAI,CAAC,KAAK;;;;;;KAMtB,CAAC;IACJ,CAAC;CACF,CAAA;AAvCC;IADC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;0CACjB;AAGV;IADC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;wCACnB;AAGR;IADC,QAAQ,EAAE;;2CACE;AAGb;IADC,QAAQ,EAAE;;gDACO;AAGlB;IADC,QAAQ,EAAE;;0CACO;AAdP,WAAW;IADvB,OAAO,CAAC,cAAc,CAAC;GACX,WAAW,CAyCvB"}
@@ -0,0 +1,43 @@
1
+ import type { SniceRowElement, ColumnDefinition, SniceCellElement } from './snice-table.types';
2
+ import './snice-cell';
3
+ import './snice-cell-text';
4
+ import './snice-cell-number';
5
+ import './snice-cell-date';
6
+ import './snice-cell-sparkline';
7
+ export declare class SniceRow extends HTMLElement implements SniceRowElement {
8
+ selected: boolean;
9
+ hoverable: boolean;
10
+ clickable: boolean;
11
+ selectable: boolean;
12
+ data: any;
13
+ private extractDataFromAttributes;
14
+ index: number;
15
+ columns: ColumnDefinition[];
16
+ html(): string;
17
+ css(): string;
18
+ init(): void;
19
+ private configureCells;
20
+ updateSelection(): void;
21
+ updateRowAttributes(): void;
22
+ updateCells(): void;
23
+ handleRowClick(e: MouseEvent): void;
24
+ handleCheckboxChange(e: Event): void;
25
+ handleKeyDown(e: KeyboardEvent): void;
26
+ private renderCheckbox;
27
+ private renderCells;
28
+ private renderCell;
29
+ private getCellComponent;
30
+ private getCellStyles;
31
+ private escapeHtml;
32
+ private toggleSelection;
33
+ private dispatchRowClick;
34
+ private dispatchRowSelect;
35
+ private dispatchRowHover;
36
+ select(): void;
37
+ deselect(): void;
38
+ focusRow(): void;
39
+ getCellValue(columnKey: string): any;
40
+ setCellValue(columnKey: string, value: any): void;
41
+ getCellElement(columnKey: string): SniceCellElement | null;
42
+ highlight(duration?: number): void;
43
+ }