@synergy-design-system/metadata 1.0.0 → 3.0.1

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 (731) hide show
  1. package/CHANGELOG.md +17 -0
  2. package/README.md +96 -0
  3. package/data/core/asset/asset:sick2018-icons.json +89042 -0
  4. package/data/core/asset/asset:sick2018-logos.json +28 -0
  5. package/data/core/asset/asset:sick2018-system-icons.json +52 -0
  6. package/data/core/asset/asset:sick2025-icons-fill.json +152214 -0
  7. package/data/core/asset/asset:sick2025-icons-outline.json +152214 -0
  8. package/data/core/asset/asset:sick2025-logos.json +34 -0
  9. package/data/core/asset/asset:sick2025-system-icons.json +52 -0
  10. package/data/core/component/component:syn-accordion.json +189 -0
  11. package/data/core/component/component:syn-alert.json +244 -0
  12. package/data/core/component/component:syn-badge.json +183 -0
  13. package/data/core/component/component:syn-breadcrumb-item.json +139 -0
  14. package/data/core/component/component:syn-breadcrumb.json +188 -0
  15. package/data/core/component/component:syn-button-group.json +200 -0
  16. package/data/core/component/component:syn-button.json +273 -0
  17. package/data/core/component/component:syn-card.json +205 -0
  18. package/data/core/component/component:syn-checkbox.json +259 -0
  19. package/data/core/component/component:syn-combobox.json +421 -0
  20. package/data/core/component/component:syn-details.json +222 -0
  21. package/data/core/component/component:syn-dialog.json +219 -0
  22. package/data/core/component/component:syn-divider.json +178 -0
  23. package/data/core/component/component:syn-drawer.json +268 -0
  24. package/data/core/component/component:syn-dropdown.json +211 -0
  25. package/data/core/component/component:syn-file.json +284 -0
  26. package/data/core/component/component:syn-header.json +235 -0
  27. package/data/core/component/component:syn-icon-button.json +223 -0
  28. package/data/core/component/component:syn-icon.json +166 -0
  29. package/data/core/component/component:syn-input.json +352 -0
  30. package/data/core/component/component:syn-menu-item.json +218 -0
  31. package/data/core/component/component:syn-menu-label.json +139 -0
  32. package/data/core/component/component:syn-menu.json +161 -0
  33. package/data/core/component/component:syn-nav-item.json +259 -0
  34. package/data/core/component/component:syn-optgroup.json +126 -0
  35. package/data/core/component/component:syn-option.json +182 -0
  36. package/data/core/component/component:syn-pagination.json +125 -0
  37. package/data/core/component/component:syn-popup.json +138 -0
  38. package/data/core/component/component:syn-prio-nav.json +167 -0
  39. package/data/core/component/component:syn-progress-bar.json +183 -0
  40. package/data/core/component/component:syn-progress-ring.json +190 -0
  41. package/data/core/component/component:syn-radio-button.json +114 -0
  42. package/data/core/component/component:syn-radio-group.json +262 -0
  43. package/data/core/component/component:syn-radio.json +214 -0
  44. package/data/core/component/component:syn-range-tick.json +166 -0
  45. package/data/core/component/component:syn-range.json +333 -0
  46. package/data/core/component/component:syn-select.json +347 -0
  47. package/data/core/component/component:syn-side-nav.json +234 -0
  48. package/data/core/component/component:syn-spinner.json +172 -0
  49. package/data/core/component/component:syn-switch.json +232 -0
  50. package/data/core/component/component:syn-tab-group.json +230 -0
  51. package/data/core/component/component:syn-tab-panel.json +139 -0
  52. package/data/core/component/component:syn-tab.json +149 -0
  53. package/data/core/component/component:syn-tag-group.json +168 -0
  54. package/data/core/component/component:syn-tag.json +173 -0
  55. package/data/core/component/component:syn-textarea.json +276 -0
  56. package/data/core/component/component:syn-tooltip.json +233 -0
  57. package/data/core/component/component:syn-validate.json +245 -0
  58. package/data/core/setup/setup:angular-components-module.json +36 -0
  59. package/data/core/setup/setup:angular-forms-module.json +37 -0
  60. package/data/core/setup/setup:angular-package.json +56 -0
  61. package/data/core/setup/setup:angular-validators-module.json +37 -0
  62. package/data/core/setup/setup:assets-package.json +56 -0
  63. package/data/core/setup/setup:components-package.json +59 -0
  64. package/data/core/setup/setup:fonts-package.json +46 -0
  65. package/data/core/setup/setup:react-package.json +60 -0
  66. package/data/core/setup/setup:styles-package.json +48 -0
  67. package/data/core/setup/setup:synergy-migrations.json +63 -0
  68. package/data/core/setup/setup:tokens-package.json +66 -0
  69. package/data/core/setup/setup:vue-package.json +50 -0
  70. package/data/core/style/style:syn-body.json +37 -0
  71. package/data/core/style/style:syn-heading.json +37 -0
  72. package/data/core/style/style:syn-link-list.json +37 -0
  73. package/data/core/style/style:syn-link.json +37 -0
  74. package/data/core/style/style:syn-table-cell.json +37 -0
  75. package/data/core/style/style:syn-table.json +37 -0
  76. package/data/core/style/style:syn-weight.json +37 -0
  77. package/data/core/template/template:appshell.json +22 -0
  78. package/data/core/template/template:breadcrumb.json +22 -0
  79. package/data/core/template/template:footer.json +22 -0
  80. package/data/core/template/template:forms.json +22 -0
  81. package/data/core/template/template:localization.json +22 -0
  82. package/data/core/template/template:table.json +22 -0
  83. package/data/core/template/template:tag-group.json +22 -0
  84. package/data/core/token/token:tokens-figma-variables-sick2018-dark-json.json +32 -0
  85. package/data/core/token/token:tokens-figma-variables-sick2018-light-json.json +32 -0
  86. package/data/core/token/token:tokens-figma-variables-sick2025-dark-json.json +32 -0
  87. package/data/core/token/token:tokens-figma-variables-sick2025-light-json.json +32 -0
  88. package/data/core/token/token:tokens-js-index-d-ts.json +31 -0
  89. package/data/core/token/token:tokens-js-index-js.json +31 -0
  90. package/data/core/token/token:tokens-scss-tokens-scss.json +31 -0
  91. package/data/core/token/token:tokens-themes-sick2018-dark-css.json +32 -0
  92. package/data/core/token/token:tokens-themes-sick2018-light-css.json +32 -0
  93. package/data/core/token/token:tokens-themes-sick2025-dark-css.json +32 -0
  94. package/data/core/token/token:tokens-themes-sick2025-light-css.json +32 -0
  95. package/data/core/utility/utility:fonts-sick-intl.json +35 -0
  96. package/data/index.json +1754 -0
  97. package/data/layers/examples/component/component:syn-accordion.md +410 -0
  98. package/data/layers/examples/component/component:syn-alert.md +262 -0
  99. package/data/layers/examples/component/component:syn-badge.md +102 -0
  100. package/data/layers/examples/component/component:syn-breadcrumb-item.md +16 -0
  101. package/data/layers/examples/component/component:syn-breadcrumb.md +110 -0
  102. package/data/layers/examples/component/component:syn-button-group.md +183 -0
  103. package/data/layers/examples/component/component:syn-button.md +289 -0
  104. package/data/layers/examples/component/component:syn-card.md +257 -0
  105. package/data/layers/examples/component/component:syn-checkbox.md +159 -0
  106. package/data/layers/examples/component/component:syn-combobox.md +629 -0
  107. package/data/layers/examples/component/component:syn-details.md +202 -0
  108. package/data/layers/examples/component/component:syn-dialog.md +349 -0
  109. package/data/layers/examples/component/component:syn-divider.md +57 -0
  110. package/data/layers/examples/component/component:syn-drawer.md +346 -0
  111. package/data/layers/examples/component/component:syn-dropdown.md +165 -0
  112. package/data/layers/examples/component/component:syn-file.md +192 -0
  113. package/data/layers/examples/component/component:syn-header.md +171 -0
  114. package/data/layers/examples/component/component:syn-icon-button.md +141 -0
  115. package/data/layers/examples/component/component:syn-icon.md +130 -0
  116. package/data/layers/examples/component/component:syn-input.md +294 -0
  117. package/data/layers/examples/component/component:syn-menu-item.md +132 -0
  118. package/data/layers/examples/component/component:syn-menu-label.md +17 -0
  119. package/data/layers/examples/component/component:syn-menu.md +66 -0
  120. package/data/layers/examples/component/component:syn-nav-item.md +154 -0
  121. package/data/layers/examples/component/component:syn-optgroup.md +67 -0
  122. package/data/layers/examples/component/component:syn-option.md +54 -0
  123. package/data/layers/examples/component/component:syn-pagination.md +92 -0
  124. package/data/layers/examples/component/component:syn-popup.md +705 -0
  125. package/data/layers/examples/component/component:syn-prio-nav.md +42 -0
  126. package/data/layers/examples/component/component:syn-progress-bar.md +87 -0
  127. package/data/layers/examples/component/component:syn-progress-ring.md +99 -0
  128. package/data/layers/examples/component/component:syn-radio-group.md +184 -0
  129. package/data/layers/examples/component/component:syn-radio.md +93 -0
  130. package/data/layers/examples/component/component:syn-range-tick.md +110 -0
  131. package/data/layers/examples/component/component:syn-range.md +403 -0
  132. package/data/layers/examples/component/component:syn-select.md +359 -0
  133. package/data/layers/examples/component/component:syn-side-nav.md +627 -0
  134. package/data/layers/examples/component/component:syn-spinner.md +45 -0
  135. package/data/layers/examples/component/component:syn-switch.md +113 -0
  136. package/data/layers/examples/component/component:syn-tab-group.md +318 -0
  137. package/data/layers/examples/component/component:syn-tab-panel.md +38 -0
  138. package/data/layers/examples/component/component:syn-tab.md +11 -0
  139. package/data/layers/examples/component/component:syn-tag-group.md +197 -0
  140. package/data/layers/examples/component/component:syn-tag.md +60 -0
  141. package/data/layers/examples/component/component:syn-textarea.md +153 -0
  142. package/data/layers/examples/component/component:syn-tooltip.md +220 -0
  143. package/data/layers/examples/component/component:syn-validate.md +349 -0
  144. package/data/layers/examples/style/style:syn-body.md +5 -0
  145. package/data/layers/examples/style/style:syn-heading.md +5 -0
  146. package/data/layers/examples/style/style:syn-link-list.md +213 -0
  147. package/data/layers/examples/style/style:syn-link.md +116 -0
  148. package/data/layers/examples/style/style:syn-table-cell.md +127 -0
  149. package/data/layers/examples/style/style:syn-table.md +201 -0
  150. package/data/layers/examples/style/style:syn-weight.md +5 -0
  151. package/data/layers/examples/template/template:appshell.md +2274 -0
  152. package/data/layers/examples/template/template:breadcrumb.md +240 -0
  153. package/data/layers/examples/template/template:footer.md +353 -0
  154. package/data/layers/examples/template/template:forms.md +536 -0
  155. package/data/layers/examples/template/template:localization.md +263 -0
  156. package/data/layers/examples/template/template:table.md +1143 -0
  157. package/data/layers/examples/template/template:tag-group.md +419 -0
  158. package/data/layers/full/assets/sick2018/js/index.ts +2167 -0
  159. package/data/layers/full/assets/sick2025/js/filled.ts +3704 -0
  160. package/data/layers/full/assets/sick2025/js/outline.ts +3704 -0
  161. package/data/layers/full/component/component:syn-accordion/angular/accordion.component.ts +80 -0
  162. package/data/layers/full/component/component:syn-accordion/components/accordion.component.ts +111 -0
  163. package/data/layers/full/component/component:syn-accordion/components/accordion.styles.ts +15 -0
  164. package/data/layers/full/component/component:syn-accordion/components/accordion.ts +12 -0
  165. package/data/layers/full/component/component:syn-accordion/react/SynAccordionJSXElement.ts +1 -0
  166. package/data/layers/full/component/component:syn-accordion/react/accordion.ts +30 -0
  167. package/data/layers/full/component/component:syn-accordion/vue/SynVueAccordion.vue +64 -0
  168. package/data/layers/full/component/component:syn-alert/angular/alert.component.ts +169 -0
  169. package/data/layers/full/component/component:syn-alert/components/alert.component.ts +322 -0
  170. package/data/layers/full/component/component:syn-alert/components/alert.styles.ts +203 -0
  171. package/data/layers/full/component/component:syn-alert/components/alert.ts +13 -0
  172. package/data/layers/full/component/component:syn-alert/react/SynAlertJSXElement.ts +9 -0
  173. package/data/layers/full/component/component:syn-alert/react/alert.ts +60 -0
  174. package/data/layers/full/component/component:syn-alert/vue/SynVueAlert.vue +135 -0
  175. package/data/layers/full/component/component:syn-badge/angular/badge.component.ts +53 -0
  176. package/data/layers/full/component/component:syn-badge/components/badge.component.ts +58 -0
  177. package/data/layers/full/component/component:syn-badge/components/badge.custom.styles.ts +62 -0
  178. package/data/layers/full/component/component:syn-badge/components/badge.styles.ts +52 -0
  179. package/data/layers/full/component/component:syn-badge/components/badge.ts +13 -0
  180. package/data/layers/full/component/component:syn-badge/react/SynBadgeJSXElement.ts +1 -0
  181. package/data/layers/full/component/component:syn-badge/react/badge.ts +29 -0
  182. package/data/layers/full/component/component:syn-badge/vue/SynVueBadge.vue +53 -0
  183. package/data/layers/full/component/component:syn-breadcrumb/angular/breadcrumb.component.ts +58 -0
  184. package/data/layers/full/component/component:syn-breadcrumb/components/breadcrumb.component.ts +103 -0
  185. package/data/layers/full/component/component:syn-breadcrumb/components/breadcrumb.custom.styles.ts +5 -0
  186. package/data/layers/full/component/component:syn-breadcrumb/components/breadcrumb.styles.ts +11 -0
  187. package/data/layers/full/component/component:syn-breadcrumb/components/breadcrumb.ts +13 -0
  188. package/data/layers/full/component/component:syn-breadcrumb/react/SynBreadcrumbJSXElement.ts +1 -0
  189. package/data/layers/full/component/component:syn-breadcrumb/react/breadcrumb.ts +32 -0
  190. package/data/layers/full/component/component:syn-breadcrumb/vue/SynVueBreadcrumb.vue +58 -0
  191. package/data/layers/full/component/component:syn-breadcrumb-item/angular/breadcrumb-item.component.ts +88 -0
  192. package/data/layers/full/component/component:syn-breadcrumb-item/components/breadcrumb-item.component.ts +132 -0
  193. package/data/layers/full/component/component:syn-breadcrumb-item/components/breadcrumb-item.custom.styles.ts +78 -0
  194. package/data/layers/full/component/component:syn-breadcrumb-item/components/breadcrumb-item.styles.ts +88 -0
  195. package/data/layers/full/component/component:syn-breadcrumb-item/components/breadcrumb-item.ts +13 -0
  196. package/data/layers/full/component/component:syn-breadcrumb-item/react/SynBreadcrumbItemJSXElement.ts +4 -0
  197. package/data/layers/full/component/component:syn-breadcrumb-item/react/breadcrumb-item.ts +37 -0
  198. package/data/layers/full/component/component:syn-breadcrumb-item/vue/SynVueBreadcrumbItem.vue +76 -0
  199. package/data/layers/full/component/component:syn-button/angular/button.component.ts +318 -0
  200. package/data/layers/full/component/component:syn-button/components/button.component.ts +315 -0
  201. package/data/layers/full/component/component:syn-button/components/button.custom.styles.ts +245 -0
  202. package/data/layers/full/component/component:syn-button/components/button.styles.ts +361 -0
  203. package/data/layers/full/component/component:syn-button/components/button.ts +13 -0
  204. package/data/layers/full/component/component:syn-button/react/SynButtonJSXElement.ts +8 -0
  205. package/data/layers/full/component/component:syn-button/react/button.ts +56 -0
  206. package/data/layers/full/component/component:syn-button/vue/SynVueButton.vue +204 -0
  207. package/data/layers/full/component/component:syn-button-group/angular/button-group.component.ts +79 -0
  208. package/data/layers/full/component/component:syn-button-group/components/button-group.component.ts +171 -0
  209. package/data/layers/full/component/component:syn-button-group/components/button-group.custom.styles.ts +5 -0
  210. package/data/layers/full/component/component:syn-button-group/components/button-group.styles.ts +14 -0
  211. package/data/layers/full/component/component:syn-button-group/components/button-group.ts +13 -0
  212. package/data/layers/full/component/component:syn-button-group/react/SynButtonGroupJSXElement.ts +1 -0
  213. package/data/layers/full/component/component:syn-button-group/react/button-group.ts +29 -0
  214. package/data/layers/full/component/component:syn-button-group/vue/SynVueButtonGroup.vue +67 -0
  215. package/data/layers/full/component/component:syn-card/angular/card.component.ts +83 -0
  216. package/data/layers/full/component/component:syn-card/components/card.component.ts +65 -0
  217. package/data/layers/full/component/component:syn-card/components/card.custom.styles.ts +60 -0
  218. package/data/layers/full/component/component:syn-card/components/card.styles.ts +70 -0
  219. package/data/layers/full/component/component:syn-card/components/card.ts +13 -0
  220. package/data/layers/full/component/component:syn-card/react/SynCardJSXElement.ts +1 -0
  221. package/data/layers/full/component/component:syn-card/react/card.ts +41 -0
  222. package/data/layers/full/component/component:syn-card/vue/SynVueCard.vue +73 -0
  223. package/data/layers/full/component/component:syn-checkbox/angular/checkbox.component.ts +273 -0
  224. package/data/layers/full/component/component:syn-checkbox/components/checkbox.component.ts +287 -0
  225. package/data/layers/full/component/component:syn-checkbox/components/checkbox.styles.ts +183 -0
  226. package/data/layers/full/component/component:syn-checkbox/components/checkbox.ts +13 -0
  227. package/data/layers/full/component/component:syn-checkbox/react/SynCheckboxJSXElement.ts +10 -0
  228. package/data/layers/full/component/component:syn-checkbox/react/checkbox.ts +64 -0
  229. package/data/layers/full/component/component:syn-checkbox/vue/SynVueCheckbox.vue +191 -0
  230. package/data/layers/full/component/component:syn-combobox/angular/combobox.component.ts +516 -0
  231. package/data/layers/full/component/component:syn-combobox/components/combobox.component.ts +1684 -0
  232. package/data/layers/full/component/component:syn-combobox/components/combobox.styles.ts +393 -0
  233. package/data/layers/full/component/component:syn-combobox/components/combobox.ts +12 -0
  234. package/data/layers/full/component/component:syn-combobox/components/option-renderer.ts +47 -0
  235. package/data/layers/full/component/component:syn-combobox/components/utils.ts +134 -0
  236. package/data/layers/full/component/component:syn-combobox/react/SynComboboxJSXElement.ts +16 -0
  237. package/data/layers/full/component/component:syn-combobox/react/combobox.ts +118 -0
  238. package/data/layers/full/component/component:syn-combobox/vue/SynVueCombobox.vue +350 -0
  239. package/data/layers/full/component/component:syn-details/angular/details.component.ts +186 -0
  240. package/data/layers/full/component/component:syn-details/components/details.component.ts +261 -0
  241. package/data/layers/full/component/component:syn-details/components/details.styles.ts +181 -0
  242. package/data/layers/full/component/component:syn-details/components/details.ts +13 -0
  243. package/data/layers/full/component/component:syn-details/react/SynDetailsJSXElement.ts +9 -0
  244. package/data/layers/full/component/component:syn-details/react/details.ts +65 -0
  245. package/data/layers/full/component/component:syn-details/vue/SynVueDetails.vue +136 -0
  246. package/data/layers/full/component/component:syn-dialog/angular/dialog.component.ts +201 -0
  247. package/data/layers/full/component/component:syn-dialog/components/dialog.component.ts +367 -0
  248. package/data/layers/full/component/component:syn-dialog/components/dialog.styles.ts +130 -0
  249. package/data/layers/full/component/component:syn-dialog/components/dialog.ts +13 -0
  250. package/data/layers/full/component/component:syn-dialog/react/SynDialogJSXElement.ts +11 -0
  251. package/data/layers/full/component/component:syn-dialog/react/dialog.ts +91 -0
  252. package/data/layers/full/component/component:syn-dialog/vue/SynVueDialog.vue +169 -0
  253. package/data/layers/full/component/component:syn-divider/angular/divider.component.ts +55 -0
  254. package/data/layers/full/component/component:syn-divider/components/divider.component.ts +34 -0
  255. package/data/layers/full/component/component:syn-divider/components/divider.styles.ts +22 -0
  256. package/data/layers/full/component/component:syn-divider/components/divider.ts +13 -0
  257. package/data/layers/full/component/component:syn-divider/react/SynDividerJSXElement.ts +1 -0
  258. package/data/layers/full/component/component:syn-divider/react/divider.ts +29 -0
  259. package/data/layers/full/component/component:syn-divider/vue/SynVueDivider.vue +51 -0
  260. package/data/layers/full/component/component:syn-drawer/angular/drawer.component.ts +234 -0
  261. package/data/layers/full/component/component:syn-drawer/components/drawer.component.ts +489 -0
  262. package/data/layers/full/component/component:syn-drawer/components/drawer.custom.styles.ts +78 -0
  263. package/data/layers/full/component/component:syn-drawer/components/drawer.styles.ts +158 -0
  264. package/data/layers/full/component/component:syn-drawer/components/drawer.ts +13 -0
  265. package/data/layers/full/component/component:syn-drawer/react/SynDrawerJSXElement.ts +11 -0
  266. package/data/layers/full/component/component:syn-drawer/react/drawer.ts +98 -0
  267. package/data/layers/full/component/component:syn-drawer/vue/SynVueDrawer.vue +188 -0
  268. package/data/layers/full/component/component:syn-dropdown/angular/dropdown.component.ts +208 -0
  269. package/data/layers/full/component/component:syn-dropdown/components/dropdown.component.ts +469 -0
  270. package/data/layers/full/component/component:syn-dropdown/components/dropdown.styles.ts +51 -0
  271. package/data/layers/full/component/component:syn-dropdown/components/dropdown.ts +13 -0
  272. package/data/layers/full/component/component:syn-dropdown/react/SynDropdownJSXElement.ts +9 -0
  273. package/data/layers/full/component/component:syn-dropdown/react/dropdown.ts +59 -0
  274. package/data/layers/full/component/component:syn-dropdown/vue/SynVueDropdown.vue +152 -0
  275. package/data/layers/full/component/component:syn-file/angular/file.component.ts +372 -0
  276. package/data/layers/full/component/component:syn-file/components/file.component.ts +645 -0
  277. package/data/layers/full/component/component:syn-file/components/file.styles.ts +197 -0
  278. package/data/layers/full/component/component:syn-file/components/file.ts +12 -0
  279. package/data/layers/full/component/component:syn-file/react/SynFileJSXElement.ts +10 -0
  280. package/data/layers/full/component/component:syn-file/react/file.ts +85 -0
  281. package/data/layers/full/component/component:syn-file/vue/SynVueFile.vue +256 -0
  282. package/data/layers/full/component/component:syn-header/angular/header.component.ts +149 -0
  283. package/data/layers/full/component/component:syn-header/components/header.component.ts +310 -0
  284. package/data/layers/full/component/component:syn-header/components/header.styles.ts +143 -0
  285. package/data/layers/full/component/component:syn-header/components/header.ts +12 -0
  286. package/data/layers/full/component/component:syn-header/react/SynHeaderJSXElement.ts +8 -0
  287. package/data/layers/full/component/component:syn-header/react/header.ts +68 -0
  288. package/data/layers/full/component/component:syn-header/vue/SynVueHeader.vue +126 -0
  289. package/data/layers/full/component/component:syn-icon/angular/icon.component.ts +115 -0
  290. package/data/layers/full/component/component:syn-icon/components/icon.component.ts +227 -0
  291. package/data/layers/full/component/component:syn-icon/components/icon.custom.styles.ts +5 -0
  292. package/data/layers/full/component/component:syn-icon/components/icon.styles.ts +18 -0
  293. package/data/layers/full/component/component:syn-icon/components/icon.ts +13 -0
  294. package/data/layers/full/component/component:syn-icon/components/library.default.ts +10 -0
  295. package/data/layers/full/component/component:syn-icon/components/library.migration.ts +317 -0
  296. package/data/layers/full/component/component:syn-icon/components/library.system.ts +46 -0
  297. package/data/layers/full/component/component:syn-icon/components/library.ts +54 -0
  298. package/data/layers/full/component/component:syn-icon/components/sick2018-system-icons.ts +37 -0
  299. package/data/layers/full/component/component:syn-icon/components/sick2025-system-icons.ts +34 -0
  300. package/data/layers/full/component/component:syn-icon/react/SynIconJSXElement.ts +4 -0
  301. package/data/layers/full/component/component:syn-icon/react/icon.ts +41 -0
  302. package/data/layers/full/component/component:syn-icon/vue/SynVueIcon.vue +100 -0
  303. package/data/layers/full/component/component:syn-icon-button/angular/icon-button.component.ts +185 -0
  304. package/data/layers/full/component/component:syn-icon-button/components/icon-button.component.ts +147 -0
  305. package/data/layers/full/component/component:syn-icon-button/components/icon-button.custom.styles.ts +79 -0
  306. package/data/layers/full/component/component:syn-icon-button/components/icon-button.styles.ts +52 -0
  307. package/data/layers/full/component/component:syn-icon-button/components/icon-button.ts +13 -0
  308. package/data/layers/full/component/component:syn-icon-button/react/SynIconButtonJSXElement.ts +4 -0
  309. package/data/layers/full/component/component:syn-icon-button/react/icon-button.ts +42 -0
  310. package/data/layers/full/component/component:syn-icon-button/vue/SynVueIconButton.vue +132 -0
  311. package/data/layers/full/component/component:syn-input/angular/input.component.ts +608 -0
  312. package/data/layers/full/component/component:syn-input/components/formatter.ts +75 -0
  313. package/data/layers/full/component/component:syn-input/components/input.component.ts +941 -0
  314. package/data/layers/full/component/component:syn-input/components/input.custom.styles.ts +278 -0
  315. package/data/layers/full/component/component:syn-input/components/input.styles.ts +280 -0
  316. package/data/layers/full/component/component:syn-input/components/input.ts +13 -0
  317. package/data/layers/full/component/component:syn-input/components/strategies.ts +79 -0
  318. package/data/layers/full/component/component:syn-input/react/SynInputJSXElement.ts +12 -0
  319. package/data/layers/full/component/component:syn-input/react/input.ts +91 -0
  320. package/data/layers/full/component/component:syn-input/vue/SynVueInput.vue +370 -0
  321. package/data/layers/full/component/component:syn-menu/angular/menu.component.ts +52 -0
  322. package/data/layers/full/component/component:syn-menu/components/menu.component.ts +191 -0
  323. package/data/layers/full/component/component:syn-menu/components/menu.styles.ts +37 -0
  324. package/data/layers/full/component/component:syn-menu/components/menu.ts +13 -0
  325. package/data/layers/full/component/component:syn-menu/react/SynMenuJSXElement.ts +4 -0
  326. package/data/layers/full/component/component:syn-menu/react/menu.ts +36 -0
  327. package/data/layers/full/component/component:syn-menu/vue/SynVueMenu.vue +48 -0
  328. package/data/layers/full/component/component:syn-menu-item/angular/menu-item.component.ts +121 -0
  329. package/data/layers/full/component/component:syn-menu-item/components/menu-item.component.ts +201 -0
  330. package/data/layers/full/component/component:syn-menu-item/components/menu-item.styles.ts +285 -0
  331. package/data/layers/full/component/component:syn-menu-item/components/menu-item.ts +13 -0
  332. package/data/layers/full/component/component:syn-menu-item/components/submenu-controller.ts +285 -0
  333. package/data/layers/full/component/component:syn-menu-item/react/SynMenuItemJSXElement.ts +1 -0
  334. package/data/layers/full/component/component:syn-menu-item/react/menu-item.ts +45 -0
  335. package/data/layers/full/component/component:syn-menu-item/vue/SynVueMenuItem.vue +91 -0
  336. package/data/layers/full/component/component:syn-menu-label/angular/menu-label.component.ts +48 -0
  337. package/data/layers/full/component/component:syn-menu-label/components/menu-label.component.ts +46 -0
  338. package/data/layers/full/component/component:syn-menu-label/components/menu-label.styles.ts +31 -0
  339. package/data/layers/full/component/component:syn-menu-label/components/menu-label.ts +13 -0
  340. package/data/layers/full/component/component:syn-menu-label/react/SynMenuLabelJSXElement.ts +1 -0
  341. package/data/layers/full/component/component:syn-menu-label/react/menu-label.ts +35 -0
  342. package/data/layers/full/component/component:syn-menu-label/vue/SynVueMenuLabel.vue +41 -0
  343. package/data/layers/full/component/component:syn-nav-item/angular/nav-item.component.ts +242 -0
  344. package/data/layers/full/component/component:syn-nav-item/components/nav-item.component.ts +491 -0
  345. package/data/layers/full/component/component:syn-nav-item/components/nav-item.styles.ts +333 -0
  346. package/data/layers/full/component/component:syn-nav-item/components/nav-item.ts +12 -0
  347. package/data/layers/full/component/component:syn-nav-item/react/SynNavItemJSXElement.ts +9 -0
  348. package/data/layers/full/component/component:syn-nav-item/react/nav-item.ts +82 -0
  349. package/data/layers/full/component/component:syn-nav-item/vue/SynVueNavItem.vue +182 -0
  350. package/data/layers/full/component/component:syn-optgroup/angular/optgroup.component.ts +79 -0
  351. package/data/layers/full/component/component:syn-optgroup/components/optgroup.component.ts +176 -0
  352. package/data/layers/full/component/component:syn-optgroup/components/optgroup.styles.ts +61 -0
  353. package/data/layers/full/component/component:syn-optgroup/components/optgroup.ts +13 -0
  354. package/data/layers/full/component/component:syn-optgroup/react/SynOptgroupJSXElement.ts +1 -0
  355. package/data/layers/full/component/component:syn-optgroup/react/optgroup.ts +41 -0
  356. package/data/layers/full/component/component:syn-optgroup/vue/SynVueOptgroup.vue +71 -0
  357. package/data/layers/full/component/component:syn-option/angular/option.component.ts +79 -0
  358. package/data/layers/full/component/component:syn-option/components/option-size.styles.ts +37 -0
  359. package/data/layers/full/component/component:syn-option/components/option.component.ts +191 -0
  360. package/data/layers/full/component/component:syn-option/components/option.styles.ts +165 -0
  361. package/data/layers/full/component/component:syn-option/components/option.ts +13 -0
  362. package/data/layers/full/component/component:syn-option/components/utility.ts +11 -0
  363. package/data/layers/full/component/component:syn-option/react/SynOptionJSXElement.ts +1 -0
  364. package/data/layers/full/component/component:syn-option/react/option.ts +37 -0
  365. package/data/layers/full/component/component:syn-option/vue/SynVueOption.vue +71 -0
  366. package/data/layers/full/component/component:syn-pagination/angular/pagination.component.ts +201 -0
  367. package/data/layers/full/component/component:syn-pagination/components/pagination.component.ts +452 -0
  368. package/data/layers/full/component/component:syn-pagination/components/pagination.styles.ts +128 -0
  369. package/data/layers/full/component/component:syn-pagination/components/pagination.ts +12 -0
  370. package/data/layers/full/component/component:syn-pagination/components/utility.ts +123 -0
  371. package/data/layers/full/component/component:syn-pagination/react/SynPaginationJSXElement.ts +7 -0
  372. package/data/layers/full/component/component:syn-pagination/react/pagination.ts +56 -0
  373. package/data/layers/full/component/component:syn-pagination/vue/SynVuePagination.vue +144 -0
  374. package/data/layers/full/component/component:syn-popup/angular/popup.component.ts +372 -0
  375. package/data/layers/full/component/component:syn-popup/components/popup.component.ts +582 -0
  376. package/data/layers/full/component/component:syn-popup/components/popup.styles.ts +70 -0
  377. package/data/layers/full/component/component:syn-popup/components/popup.ts +13 -0
  378. package/data/layers/full/component/component:syn-popup/react/SynPopupJSXElement.ts +4 -0
  379. package/data/layers/full/component/component:syn-popup/react/popup.ts +55 -0
  380. package/data/layers/full/component/component:syn-popup/vue/SynVuePopup.vue +233 -0
  381. package/data/layers/full/component/component:syn-prio-nav/angular/prio-nav.component.ts +67 -0
  382. package/data/layers/full/component/component:syn-prio-nav/components/prio-nav.component.ts +288 -0
  383. package/data/layers/full/component/component:syn-prio-nav/components/prio-nav.styles.ts +48 -0
  384. package/data/layers/full/component/component:syn-prio-nav/components/prio-nav.ts +12 -0
  385. package/data/layers/full/component/component:syn-prio-nav/components/utils.ts +57 -0
  386. package/data/layers/full/component/component:syn-prio-nav/react/SynPrioNavJSXElement.ts +1 -0
  387. package/data/layers/full/component/component:syn-prio-nav/react/prio-nav.ts +54 -0
  388. package/data/layers/full/component/component:syn-prio-nav/vue/SynVuePrioNav.vue +60 -0
  389. package/data/layers/full/component/component:syn-progress-bar/angular/progress-bar.component.ts +85 -0
  390. package/data/layers/full/component/component:syn-progress-bar/components/progress-bar.component.ts +67 -0
  391. package/data/layers/full/component/component:syn-progress-bar/components/progress-bar.custom.styles.ts +24 -0
  392. package/data/layers/full/component/component:syn-progress-bar/components/progress-bar.styles.ts +87 -0
  393. package/data/layers/full/component/component:syn-progress-bar/components/progress-bar.ts +13 -0
  394. package/data/layers/full/component/component:syn-progress-bar/react/SynProgressBarJSXElement.ts +1 -0
  395. package/data/layers/full/component/component:syn-progress-bar/react/progress-bar.ts +37 -0
  396. package/data/layers/full/component/component:syn-progress-bar/vue/SynVueProgressBar.vue +71 -0
  397. package/data/layers/full/component/component:syn-progress-ring/angular/progress-ring.component.ts +72 -0
  398. package/data/layers/full/component/component:syn-progress-ring/components/progress-ring.component.ts +83 -0
  399. package/data/layers/full/component/component:syn-progress-ring/components/progress-ring.custom.styles.ts +19 -0
  400. package/data/layers/full/component/component:syn-progress-ring/components/progress-ring.styles.ts +70 -0
  401. package/data/layers/full/component/component:syn-progress-ring/components/progress-ring.ts +13 -0
  402. package/data/layers/full/component/component:syn-progress-ring/react/SynProgressRingJSXElement.ts +4 -0
  403. package/data/layers/full/component/component:syn-progress-ring/react/progress-ring.ts +37 -0
  404. package/data/layers/full/component/component:syn-progress-ring/vue/SynVueProgressRing.vue +66 -0
  405. package/data/layers/full/component/component:syn-radio/angular/radio.component.ts +122 -0
  406. package/data/layers/full/component/component:syn-radio/components/radio.component.ts +131 -0
  407. package/data/layers/full/component/component:syn-radio/components/radio.styles.ts +179 -0
  408. package/data/layers/full/component/component:syn-radio/components/radio.ts +13 -0
  409. package/data/layers/full/component/component:syn-radio/react/SynRadioJSXElement.ts +4 -0
  410. package/data/layers/full/component/component:syn-radio/react/radio.ts +48 -0
  411. package/data/layers/full/component/component:syn-radio/vue/SynVueRadio.vue +104 -0
  412. package/data/layers/full/component/component:syn-radio-button/angular/radio-button.component.ts +123 -0
  413. package/data/layers/full/component/component:syn-radio-button/components/radio-button.component.ts +142 -0
  414. package/data/layers/full/component/component:syn-radio-button/components/radio-button.styles.ts +30 -0
  415. package/data/layers/full/component/component:syn-radio-button/components/radio-button.ts +13 -0
  416. package/data/layers/full/component/component:syn-radio-button/react/SynRadioButtonJSXElement.ts +4 -0
  417. package/data/layers/full/component/component:syn-radio-button/react/radio-button.ts +49 -0
  418. package/data/layers/full/component/component:syn-radio-button/vue/SynVueRadioButton.vue +105 -0
  419. package/data/layers/full/component/component:syn-radio-group/angular/radio-group.component.ts +204 -0
  420. package/data/layers/full/component/component:syn-radio-group/components/radio-group.component.ts +440 -0
  421. package/data/layers/full/component/component:syn-radio-group/components/radio-group.styles.ts +58 -0
  422. package/data/layers/full/component/component:syn-radio-group/components/radio-group.ts +13 -0
  423. package/data/layers/full/component/component:syn-radio-group/react/SynRadioGroupJSXElement.ts +8 -0
  424. package/data/layers/full/component/component:syn-radio-group/react/radio-group.ts +56 -0
  425. package/data/layers/full/component/component:syn-radio-group/vue/SynVueRadioGroup.vue +158 -0
  426. package/data/layers/full/component/component:syn-range/angular/range.component.ts +347 -0
  427. package/data/layers/full/component/component:syn-range/components/range.component.ts +933 -0
  428. package/data/layers/full/component/component:syn-range/components/range.styles.ts +310 -0
  429. package/data/layers/full/component/component:syn-range/components/range.ts +12 -0
  430. package/data/layers/full/component/component:syn-range/components/utility.ts +38 -0
  431. package/data/layers/full/component/component:syn-range/react/SynRangeJSXElement.ts +11 -0
  432. package/data/layers/full/component/component:syn-range/react/range.ts +92 -0
  433. package/data/layers/full/component/component:syn-range/vue/SynVueRange.vue +245 -0
  434. package/data/layers/full/component/component:syn-range-tick/angular/range-tick.component.ts +59 -0
  435. package/data/layers/full/component/component:syn-range-tick/components/range-tick.component.ts +50 -0
  436. package/data/layers/full/component/component:syn-range-tick/components/range-tick.styles.ts +34 -0
  437. package/data/layers/full/component/component:syn-range-tick/components/range-tick.ts +12 -0
  438. package/data/layers/full/component/component:syn-range-tick/react/SynRangeTickJSXElement.ts +1 -0
  439. package/data/layers/full/component/component:syn-range-tick/react/range-tick.ts +33 -0
  440. package/data/layers/full/component/component:syn-range-tick/vue/SynVueRangeTick.vue +57 -0
  441. package/data/layers/full/component/component:syn-select/angular/select.component.ts +439 -0
  442. package/data/layers/full/component/component:syn-select/components/select.component.ts +1056 -0
  443. package/data/layers/full/component/component:syn-select/components/select.styles.ts +380 -0
  444. package/data/layers/full/component/component:syn-select/components/select.ts +13 -0
  445. package/data/layers/full/component/component:syn-select/components/utility.ts +41 -0
  446. package/data/layers/full/component/component:syn-select/react/SynSelectJSXElement.ts +15 -0
  447. package/data/layers/full/component/component:syn-select/react/select.ts +101 -0
  448. package/data/layers/full/component/component:syn-select/vue/SynVueSelect.vue +301 -0
  449. package/data/layers/full/component/component:syn-side-nav/angular/side-nav.component.ts +210 -0
  450. package/data/layers/full/component/component:syn-side-nav/components/side-nav.component.ts +458 -0
  451. package/data/layers/full/component/component:syn-side-nav/components/side-nav.styles.ts +142 -0
  452. package/data/layers/full/component/component:syn-side-nav/components/side-nav.ts +12 -0
  453. package/data/layers/full/component/component:syn-side-nav/react/SynSideNavJSXElement.ts +9 -0
  454. package/data/layers/full/component/component:syn-side-nav/react/side-nav.ts +95 -0
  455. package/data/layers/full/component/component:syn-side-nav/vue/SynVueSideNav.vue +188 -0
  456. package/data/layers/full/component/component:syn-spinner/angular/spinner.component.ts +44 -0
  457. package/data/layers/full/component/component:syn-spinner/components/spinner.component.ts +35 -0
  458. package/data/layers/full/component/component:syn-spinner/components/spinner.custom.styles.ts +32 -0
  459. package/data/layers/full/component/component:syn-spinner/components/spinner.styles.ts +48 -0
  460. package/data/layers/full/component/component:syn-spinner/components/spinner.ts +13 -0
  461. package/data/layers/full/component/component:syn-spinner/react/SynSpinnerJSXElement.ts +1 -0
  462. package/data/layers/full/component/component:syn-spinner/react/spinner.ts +31 -0
  463. package/data/layers/full/component/component:syn-spinner/vue/SynVueSpinner.vue +35 -0
  464. package/data/layers/full/component/component:syn-switch/angular/switch.component.ts +257 -0
  465. package/data/layers/full/component/component:syn-switch/components/switch.component.ts +279 -0
  466. package/data/layers/full/component/component:syn-switch/components/switch.styles.ts +252 -0
  467. package/data/layers/full/component/component:syn-switch/components/switch.ts +13 -0
  468. package/data/layers/full/component/component:syn-switch/react/SynSwitchJSXElement.ts +10 -0
  469. package/data/layers/full/component/component:syn-switch/react/switch.ts +63 -0
  470. package/data/layers/full/component/component:syn-switch/vue/SynVueSwitch.vue +183 -0
  471. package/data/layers/full/component/component:syn-tab/angular/tab.component.ts +109 -0
  472. package/data/layers/full/component/component:syn-tab/components/tab.component.ts +125 -0
  473. package/data/layers/full/component/component:syn-tab/components/tab.custom.styles.ts +94 -0
  474. package/data/layers/full/component/component:syn-tab/components/tab.styles.ts +70 -0
  475. package/data/layers/full/component/component:syn-tab/components/tab.ts +13 -0
  476. package/data/layers/full/component/component:syn-tab/react/SynTabJSXElement.ts +4 -0
  477. package/data/layers/full/component/component:syn-tab/react/tab.ts +42 -0
  478. package/data/layers/full/component/component:syn-tab/vue/SynVueTab.vue +91 -0
  479. package/data/layers/full/component/component:syn-tab-group/angular/tab-group.component.ts +166 -0
  480. package/data/layers/full/component/component:syn-tab-group/components/tab-group.component.ts +551 -0
  481. package/data/layers/full/component/component:syn-tab-group/components/tab-group.custom.styles.ts +218 -0
  482. package/data/layers/full/component/component:syn-tab-group/components/tab-group.styles.ts +193 -0
  483. package/data/layers/full/component/component:syn-tab-group/components/tab-group.ts +13 -0
  484. package/data/layers/full/component/component:syn-tab-group/react/SynTabGroupJSXElement.ts +4 -0
  485. package/data/layers/full/component/component:syn-tab-group/react/tab-group.ts +58 -0
  486. package/data/layers/full/component/component:syn-tab-group/vue/SynVueTabGroup.vue +126 -0
  487. package/data/layers/full/component/component:syn-tab-panel/angular/tab-panel.component.ts +68 -0
  488. package/data/layers/full/component/component:syn-tab-panel/components/tab-panel.component.ts +60 -0
  489. package/data/layers/full/component/component:syn-tab-panel/components/tab-panel.custom.styles.ts +8 -0
  490. package/data/layers/full/component/component:syn-tab-panel/components/tab-panel.styles.ts +20 -0
  491. package/data/layers/full/component/component:syn-tab-panel/components/tab-panel.ts +13 -0
  492. package/data/layers/full/component/component:syn-tab-panel/react/SynTabPanelJSXElement.ts +1 -0
  493. package/data/layers/full/component/component:syn-tab-panel/react/tab-panel.ts +31 -0
  494. package/data/layers/full/component/component:syn-tab-panel/vue/SynVueTabPanel.vue +60 -0
  495. package/data/layers/full/component/component:syn-tag/angular/tag.component.ts +83 -0
  496. package/data/layers/full/component/component:syn-tag/components/tag.component.ts +83 -0
  497. package/data/layers/full/component/component:syn-tag/components/tag.custom.styles.ts +121 -0
  498. package/data/layers/full/component/component:syn-tag/components/tag.styles.ts +58 -0
  499. package/data/layers/full/component/component:syn-tag/components/tag.ts +13 -0
  500. package/data/layers/full/component/component:syn-tag/react/SynTagJSXElement.ts +4 -0
  501. package/data/layers/full/component/component:syn-tag/react/tag.ts +43 -0
  502. package/data/layers/full/component/component:syn-tag/vue/SynVueTag.vue +81 -0
  503. package/data/layers/full/component/component:syn-tag-group/angular/tag-group.component.ts +83 -0
  504. package/data/layers/full/component/component:syn-tag-group/components/tag-group.component.ts +95 -0
  505. package/data/layers/full/component/component:syn-tag-group/components/tag-group.styles.ts +49 -0
  506. package/data/layers/full/component/component:syn-tag-group/components/tag-group.ts +12 -0
  507. package/data/layers/full/component/component:syn-tag-group/react/SynTagGroupJSXElement.ts +1 -0
  508. package/data/layers/full/component/component:syn-tag-group/react/tag-group.ts +33 -0
  509. package/data/layers/full/component/component:syn-tag-group/vue/SynVueTagGroup.vue +69 -0
  510. package/data/layers/full/component/component:syn-textarea/angular/textarea.component.ts +396 -0
  511. package/data/layers/full/component/component:syn-textarea/components/textarea.component.ts +400 -0
  512. package/data/layers/full/component/component:syn-textarea/components/textarea.styles.ts +208 -0
  513. package/data/layers/full/component/component:syn-textarea/components/textarea.ts +13 -0
  514. package/data/layers/full/component/component:syn-textarea/react/SynTextareaJSXElement.ts +10 -0
  515. package/data/layers/full/component/component:syn-textarea/react/textarea.ts +60 -0
  516. package/data/layers/full/component/component:syn-textarea/vue/SynVueTextarea.vue +244 -0
  517. package/data/layers/full/component/component:syn-tooltip/angular/tooltip.component.ts +196 -0
  518. package/data/layers/full/component/component:syn-tooltip/components/tooltip.component.ts +312 -0
  519. package/data/layers/full/component/component:syn-tooltip/components/tooltip.styles.ts +62 -0
  520. package/data/layers/full/component/component:syn-tooltip/components/tooltip.ts +13 -0
  521. package/data/layers/full/component/component:syn-tooltip/react/SynTooltipJSXElement.ts +9 -0
  522. package/data/layers/full/component/component:syn-tooltip/react/tooltip.ts +63 -0
  523. package/data/layers/full/component/component:syn-tooltip/vue/SynVueTooltip.vue +150 -0
  524. package/data/layers/full/component/component:syn-validate/angular/validate.component.ts +137 -0
  525. package/data/layers/full/component/component:syn-validate/components/utility.ts +160 -0
  526. package/data/layers/full/component/component:syn-validate/components/validate.component.ts +590 -0
  527. package/data/layers/full/component/component:syn-validate/components/validate.styles.ts +9 -0
  528. package/data/layers/full/component/component:syn-validate/components/validate.ts +12 -0
  529. package/data/layers/full/component/component:syn-validate/react/SynValidateJSXElement.ts +1 -0
  530. package/data/layers/full/component/component:syn-validate/react/validate.ts +44 -0
  531. package/data/layers/full/component/component:syn-validate/vue/SynVueValidate.vue +107 -0
  532. package/data/layers/full/fonts/sick-intl/LICENSE +3 -0
  533. package/data/layers/full/fonts/sick-intl/font.css +17 -0
  534. package/data/layers/full/setup/setup:angular-components-module/angular/index.ts +53 -0
  535. package/data/layers/full/setup/setup:angular-components-module/angular/synergy.module.ts +115 -0
  536. package/data/layers/full/setup/setup:angular-forms-module/angular/forms.module.ts +92 -0
  537. package/data/layers/full/setup/setup:angular-package/angular/CHANGELOG.md +628 -0
  538. package/data/layers/full/setup/setup:angular-package/angular/LIMITATIONS.md +32 -0
  539. package/data/layers/full/setup/setup:angular-package/angular/README.md +393 -0
  540. package/data/layers/full/setup/setup:angular-package/angular/index.ts +9 -0
  541. package/data/layers/full/setup/setup:angular-package/angular/package.json +64 -0
  542. package/data/layers/full/setup/setup:angular-validators-module/angular/validators.ts +125 -0
  543. package/data/layers/full/setup/setup:assets-package/assets/BREAKING_CHANGES.md +305 -0
  544. package/data/layers/full/setup/setup:assets-package/assets/CHANGELOG.md +382 -0
  545. package/data/layers/full/setup/setup:assets-package/assets/README.md +103 -0
  546. package/data/layers/full/setup/setup:assets-package/assets/package.json +98 -0
  547. package/data/layers/full/setup/setup:components-package/components/BREAKING_CHANGES.md +908 -0
  548. package/data/layers/full/setup/setup:components-package/components/CHANGELOG.md +2166 -0
  549. package/data/layers/full/setup/setup:components-package/components/LIMITATIONS.md +433 -0
  550. package/data/layers/full/setup/setup:components-package/components/README.md +231 -0
  551. package/data/layers/full/setup/setup:components-package/components/package.json +125 -0
  552. package/data/layers/full/setup/setup:components-package/docs/icon-usage.md +411 -0
  553. package/data/layers/full/setup/setup:components-package/docs/prerequisites.md +319 -0
  554. package/data/layers/full/setup/setup:fonts-package/fonts/CHANGELOG.md +65 -0
  555. package/data/layers/full/setup/setup:fonts-package/fonts/README.md +164 -0
  556. package/data/layers/full/setup/setup:fonts-package/fonts/package.json +72 -0
  557. package/data/layers/full/setup/setup:react-package/react/CHANGELOG.md +551 -0
  558. package/data/layers/full/setup/setup:react-package/react/LIMITATIONS.md +31 -0
  559. package/data/layers/full/setup/setup:react-package/react/README.md +262 -0
  560. package/data/layers/full/setup/setup:react-package/react/index.ts +53 -0
  561. package/data/layers/full/setup/setup:react-package/react/package.json +54 -0
  562. package/data/layers/full/setup/setup:react-package/react/syn-jsx-elements.ts +2830 -0
  563. package/data/layers/full/setup/setup:styles-package/styles/BREAKING_CHANGES.md +105 -0
  564. package/data/layers/full/setup/setup:styles-package/styles/CHANGELOG.md +196 -0
  565. package/data/layers/full/setup/setup:styles-package/styles/README.md +132 -0
  566. package/data/layers/full/setup/setup:styles-package/styles/package.json +57 -0
  567. package/data/layers/full/setup/setup:synergy-migrations/components/BREAKING_CHANGES.md +908 -0
  568. package/data/layers/full/setup/setup:synergy-migrations/davinci/basic-elements.md +1859 -0
  569. package/data/layers/full/setup/setup:synergy-migrations/migration/index.md +57 -0
  570. package/data/layers/full/setup/setup:synergy-migrations/migration/v2-2018-to-v2-2025.md +481 -0
  571. package/data/layers/full/setup/setup:synergy-migrations/migration/v2-2018-to-v3-2018.md +147 -0
  572. package/data/layers/full/setup/setup:synergy-migrations/migration/v2-2018-to-v3-2025.md +150 -0
  573. package/data/layers/full/setup/setup:synergy-migrations/migration/v2-2025-to-v3-2025.md +133 -0
  574. package/data/layers/full/setup/setup:tokens-package/tokens/BREAKING_CHANGES.md +180 -0
  575. package/data/layers/full/setup/setup:tokens-package/tokens/CHANGELOG.md +967 -0
  576. package/data/layers/full/setup/setup:tokens-package/tokens/README.md +435 -0
  577. package/data/layers/full/setup/setup:tokens-package/tokens/package.json +81 -0
  578. package/data/layers/full/setup/setup:vue-package/vue/CHANGELOG.md +618 -0
  579. package/data/layers/full/setup/setup:vue-package/vue/LIMITATIONS.md +53 -0
  580. package/data/layers/full/setup/setup:vue-package/vue/README.md +252 -0
  581. package/data/layers/full/setup/setup:vue-package/vue/index.ts +53 -0
  582. package/data/layers/full/setup/setup:vue-package/vue/package.json +58 -0
  583. package/data/layers/full/styles/link/index.css +89 -0
  584. package/data/layers/full/styles/link-list/index.css +51 -0
  585. package/data/layers/full/styles/tables/table-cell.css +125 -0
  586. package/data/layers/full/styles/tables/table.css +16 -0
  587. package/data/layers/full/styles/typography/body.css +19 -0
  588. package/data/layers/full/styles/typography/heading.css +19 -0
  589. package/data/layers/full/styles/typography/weight.css +16 -0
  590. package/data/layers/full/tokens/figma-variables/sick2018-dark.json +2268 -0
  591. package/data/layers/full/tokens/figma-variables/sick2018-light.json +2268 -0
  592. package/data/layers/full/tokens/figma-variables/sick2025-dark.json +2268 -0
  593. package/data/layers/full/tokens/figma-variables/sick2025-light.json +2268 -0
  594. package/data/layers/full/tokens/js/index.d.ts +2224 -0
  595. package/data/layers/full/tokens/js/index.js +2224 -0
  596. package/data/layers/full/tokens/scss/_tokens.scss +448 -0
  597. package/data/layers/full/tokens/themes/sick2018_dark.css +454 -0
  598. package/data/layers/full/tokens/themes/sick2018_light.css +454 -0
  599. package/data/layers/full/tokens/themes/sick2025_dark.css +454 -0
  600. package/data/layers/full/tokens/themes/sick2025_light.css +454 -0
  601. package/data/layers/interface/component/component:syn-accordion.json +95 -0
  602. package/data/layers/interface/component/component:syn-accordion.md +57 -0
  603. package/data/layers/interface/component/component:syn-alert.json +182 -0
  604. package/data/layers/interface/component/component:syn-alert.md +135 -0
  605. package/data/layers/interface/component/component:syn-badge.json +43 -0
  606. package/data/layers/interface/component/component:syn-badge.md +39 -0
  607. package/data/layers/interface/component/component:syn-breadcrumb-item.json +114 -0
  608. package/data/layers/interface/component/component:syn-breadcrumb-item.md +64 -0
  609. package/data/layers/interface/component/component:syn-breadcrumb.json +61 -0
  610. package/data/layers/interface/component/component:syn-breadcrumb.md +44 -0
  611. package/data/layers/interface/component/component:syn-button-group.json +86 -0
  612. package/data/layers/interface/component/component:syn-button-group.md +57 -0
  613. package/data/layers/interface/component/component:syn-button.json +424 -0
  614. package/data/layers/interface/component/component:syn-button.md +287 -0
  615. package/data/layers/interface/component/component:syn-card.json +86 -0
  616. package/data/layers/interface/component/component:syn-card.md +55 -0
  617. package/data/layers/interface/component/component:syn-checkbox.json +330 -0
  618. package/data/layers/interface/component/component:syn-checkbox.md +237 -0
  619. package/data/layers/interface/component/component:syn-combobox.json +667 -0
  620. package/data/layers/interface/component/component:syn-combobox.md +388 -0
  621. package/data/layers/interface/component/component:syn-details.json +202 -0
  622. package/data/layers/interface/component/component:syn-details.md +129 -0
  623. package/data/layers/interface/component/component:syn-dialog.json +194 -0
  624. package/data/layers/interface/component/component:syn-dialog.md +136 -0
  625. package/data/layers/interface/component/component:syn-divider.json +39 -0
  626. package/data/layers/interface/component/component:syn-divider.md +31 -0
  627. package/data/layers/interface/component/component:syn-drawer.json +239 -0
  628. package/data/layers/interface/component/component:syn-drawer.md +154 -0
  629. package/data/layers/interface/component/component:syn-dropdown.json +272 -0
  630. package/data/layers/interface/component/component:syn-dropdown.md +171 -0
  631. package/data/layers/interface/component/component:syn-file.json +445 -0
  632. package/data/layers/interface/component/component:syn-file.md +280 -0
  633. package/data/layers/interface/component/component:syn-header.json +149 -0
  634. package/data/layers/interface/component/component:syn-header.md +102 -0
  635. package/data/layers/interface/component/component:syn-icon-button.json +201 -0
  636. package/data/layers/interface/component/component:syn-icon-button.md +157 -0
  637. package/data/layers/interface/component/component:syn-icon.json +105 -0
  638. package/data/layers/interface/component/component:syn-icon.md +77 -0
  639. package/data/layers/interface/component/component:syn-input.json +758 -0
  640. package/data/layers/interface/component/component:syn-input.md +522 -0
  641. package/data/layers/interface/component/component:syn-menu-item.json +185 -0
  642. package/data/layers/interface/component/component:syn-menu-item.md +100 -0
  643. package/data/layers/interface/component/component:syn-menu-label.json +36 -0
  644. package/data/layers/interface/component/component:syn-menu-label.md +34 -0
  645. package/data/layers/interface/component/component:syn-menu.json +41 -0
  646. package/data/layers/interface/component/component:syn-menu.md +32 -0
  647. package/data/layers/interface/component/component:syn-nav-item.json +269 -0
  648. package/data/layers/interface/component/component:syn-nav-item.md +198 -0
  649. package/data/layers/interface/component/component:syn-optgroup.json +98 -0
  650. package/data/layers/interface/component/component:syn-optgroup.md +60 -0
  651. package/data/layers/interface/component/component:syn-option.json +149 -0
  652. package/data/layers/interface/component/component:syn-option.md +74 -0
  653. package/data/layers/interface/component/component:syn-pagination.json +200 -0
  654. package/data/layers/interface/component/component:syn-pagination.md +128 -0
  655. package/data/layers/interface/component/component:syn-popup.json +360 -0
  656. package/data/layers/interface/component/component:syn-popup.md +258 -0
  657. package/data/layers/interface/component/component:syn-prio-nav.json +51 -0
  658. package/data/layers/interface/component/component:syn-prio-nav.md +43 -0
  659. package/data/layers/interface/component/component:syn-progress-bar.json +81 -0
  660. package/data/layers/interface/component/component:syn-progress-bar.md +59 -0
  661. package/data/layers/interface/component/component:syn-progress-ring.json +74 -0
  662. package/data/layers/interface/component/component:syn-progress-ring.md +49 -0
  663. package/data/layers/interface/component/component:syn-radio-button.json +164 -0
  664. package/data/layers/interface/component/component:syn-radio-button.md +102 -0
  665. package/data/layers/interface/component/component:syn-radio-group.json +259 -0
  666. package/data/layers/interface/component/component:syn-radio-group.md +161 -0
  667. package/data/layers/interface/component/component:syn-radio.json +140 -0
  668. package/data/layers/interface/component/component:syn-radio.md +88 -0
  669. package/data/layers/interface/component/component:syn-range-tick.json +51 -0
  670. package/data/layers/interface/component/component:syn-range-tick.md +41 -0
  671. package/data/layers/interface/component/component:syn-range.json +429 -0
  672. package/data/layers/interface/component/component:syn-range.md +266 -0
  673. package/data/layers/interface/component/component:syn-select.json +580 -0
  674. package/data/layers/interface/component/component:syn-select.md +341 -0
  675. package/data/layers/interface/component/component:syn-side-nav.json +189 -0
  676. package/data/layers/interface/component/component:syn-side-nav.md +123 -0
  677. package/data/layers/interface/component/component:syn-spinner.json +21 -0
  678. package/data/layers/interface/component/component:syn-spinner.md +24 -0
  679. package/data/layers/interface/component/component:syn-switch.json +301 -0
  680. package/data/layers/interface/component/component:syn-switch.md +220 -0
  681. package/data/layers/interface/component/component:syn-tab-group.json +234 -0
  682. package/data/layers/interface/component/component:syn-tab-group.md +120 -0
  683. package/data/layers/interface/component/component:syn-tab-panel.json +64 -0
  684. package/data/layers/interface/component/component:syn-tab-panel.md +48 -0
  685. package/data/layers/interface/component/component:syn-tab.json +121 -0
  686. package/data/layers/interface/component/component:syn-tab.md +80 -0
  687. package/data/layers/interface/component/component:syn-tag-group.json +98 -0
  688. package/data/layers/interface/component/component:syn-tag-group.md +61 -0
  689. package/data/layers/interface/component/component:syn-tag.json +78 -0
  690. package/data/layers/interface/component/component:syn-tag.md +63 -0
  691. package/data/layers/interface/component/component:syn-textarea.json +532 -0
  692. package/data/layers/interface/component/component:syn-textarea.md +350 -0
  693. package/data/layers/interface/component/component:syn-tooltip.json +216 -0
  694. package/data/layers/interface/component/component:syn-tooltip.md +154 -0
  695. package/data/layers/interface/component/component:syn-validate.json +226 -0
  696. package/data/layers/interface/component/component:syn-validate.md +102 -0
  697. package/data/manifest.json +47 -0
  698. package/data/schemas/core-entity.schema.json +130 -0
  699. package/data/schemas/layer-ref.schema.json +22 -0
  700. package/data/schemas/manifest.schema.json +76 -0
  701. package/dist/index.d.ts +5 -0
  702. package/dist/index.js +5 -0
  703. package/dist/public/domains/assets.d.ts +34 -0
  704. package/dist/public/domains/assets.js +238 -0
  705. package/dist/public/domains/clusters.d.ts +21 -0
  706. package/dist/public/domains/clusters.js +189 -0
  707. package/dist/public/domains/components.d.ts +66 -0
  708. package/dist/public/domains/components.js +286 -0
  709. package/dist/public/domains/fonts.d.ts +21 -0
  710. package/dist/public/domains/fonts.js +141 -0
  711. package/dist/public/domains/migrations.d.ts +13 -0
  712. package/dist/public/domains/migrations.js +59 -0
  713. package/dist/public/domains/setup.d.ts +39 -0
  714. package/dist/public/domains/setup.js +144 -0
  715. package/dist/public/domains/styles.d.ts +47 -0
  716. package/dist/public/domains/styles.js +182 -0
  717. package/dist/public/domains/templates.d.ts +47 -0
  718. package/dist/public/domains/templates.js +182 -0
  719. package/dist/public/domains/tokens.d.ts +46 -0
  720. package/dist/public/domains/tokens.js +165 -0
  721. package/dist/public/index.d.ts +21 -0
  722. package/dist/public/index.js +11 -0
  723. package/dist/public/store.d.ts +19 -0
  724. package/dist/public/store.js +184 -0
  725. package/dist/public/types.d.ts +374 -0
  726. package/dist/public/types.js +5 -0
  727. package/dist/public/utils.d.ts +48 -0
  728. package/dist/public/utils.js +98 -0
  729. package/package.json +49 -7
  730. package/LICENSE +0 -9
  731. package/src/index.js +0 -1
@@ -0,0 +1,452 @@
1
+ import {
2
+ type CSSResultGroup,
3
+ type PropertyValues,
4
+ html,
5
+ nothing,
6
+ } from 'lit';
7
+ import { property } from 'lit/decorators.js';
8
+ import { createRef, ref } from 'lit/directives/ref.js';
9
+ import { LocalizeController } from '../../utilities/localize.js';
10
+ import SynergyElement from '../../internal/synergy-element.js';
11
+ import componentStyles from '../../styles/component.styles.js';
12
+ import styles from './pagination.styles.js';
13
+ import SynDivider from '../divider/divider.component.js';
14
+ import SynIconButton from '../icon-button/icon-button.component.js';
15
+ import SynInput from '../input/input.component.js';
16
+ import SynOption from '../option/option.component.js';
17
+ import SynSelect from '../select/select.component.js';
18
+ import {
19
+ calculatePageItemIndices,
20
+ calculateTotalPages,
21
+ clampPage,
22
+ getMaxOptionCharCount,
23
+ getPreviousOrDefault,
24
+ getTotalPages,
25
+ getTotalPagesCharCount,
26
+ isValidNonNegativeInteger,
27
+ isValidPositiveInteger,
28
+ sanitizePageSizeOptions,
29
+ } from './utility.js';
30
+ import type { SynInputEvent } from '../../events/events.js';
31
+ import { enableDefaultSettings } from '../../utilities/defaultSettings/decorator.js';
32
+
33
+ /**
34
+ * @summary <syn-pagination /> provides page navigation, direct page input, and page-size selection for large data sets.
35
+ *
36
+ * @documentation https://synergy-design-system.github.io/?path=/docs/components-syn-pagination--docs
37
+ * @status stable
38
+ * @since 3.12.0
39
+ *
40
+ * @event syn-pagination-page-changed - Emitted when the current page changes
41
+ * @event syn-pagination-page-size-changed - Emitted when the page size changes
42
+ *
43
+ * @csspart base - The component's base wrapper.
44
+ * @csspart divider - The divider element displayed at the top of the pagination component.
45
+ * @csspart page-size-select-wrapper - The wrapper element containing the page size select and page item summary.
46
+ * @csspart page-size-select - The page size select element.
47
+ * @csspart page-item-summary - The text element displaying the current page item range and total items.
48
+ * @csspart page-input-section - The section containing the page number input and total pages display.
49
+ * @csspart page-input - The page number input element.
50
+ * @csspart navigation - The pagination navigation element.
51
+ * @csspart navigation-action - The individual navigation action buttons (first, previous, next, last).
52
+ *
53
+ * @accessibility
54
+ * The entire component is wrapped in a semantic `<nav>` landmark with an `aria-label` for screen reader accessibility.
55
+ * Use the `aria-label` attribute to provide a unique, descriptive label when multiple pagination controls exist on the page.
56
+ * Example: `<syn-pagination aria-label="Search results pagination"></syn-pagination>`
57
+ */
58
+ @enableDefaultSettings('SynPagination')
59
+ export default class SynPagination extends SynergyElement {
60
+ private static readonly DEFAULT_PAGE_SIZE = 25;
61
+
62
+ private static readonly DEFAULT_CURRENT_PAGE = 1;
63
+
64
+ private static readonly DEFAULT_TOTAL_ITEMS = 0;
65
+
66
+ private readonly baseRef = createRef<HTMLElement>();
67
+
68
+ private readonly localize = new LocalizeController(this);
69
+
70
+ static styles: CSSResultGroup = [
71
+ componentStyles,
72
+ styles,
73
+ ];
74
+
75
+ static dependencies = {
76
+ 'syn-divider': SynDivider,
77
+ 'syn-icon-button': SynIconButton,
78
+ 'syn-input': SynInput,
79
+ 'syn-option': SynOption,
80
+ 'syn-select': SynSelect,
81
+ };
82
+
83
+ /**
84
+ * When true, a divider is displayed at the top of the pagination component.
85
+ */
86
+ @property({ type: Boolean }) divider = false;
87
+
88
+ /**
89
+ * When true, the pagination controls are disabled and non-interactive.
90
+ */
91
+ @property({ reflect: true, type: Boolean }) disabled = false;
92
+
93
+ /**
94
+ * The size of the pagination controls.
95
+ */
96
+ @property({ reflect: true }) size: 'small' | 'medium' | 'large' = 'medium';
97
+
98
+ /**
99
+ * The current page number. The default value is 1.
100
+ * The component will emit a `syn-pagination-page-changed` event whenever the page changes, allowing you to respond to page changes in your application.
101
+ */
102
+ @property({ attribute: 'current-page', reflect: true, type: Number }) currentPage = 1;
103
+
104
+ /**
105
+ * The number of items to display per page. The default value is 25.
106
+ * The component will emit a `syn-pagination-page-size-changed` event whenever the page size changes, allowing you to respond to page size changes in your application.
107
+ */
108
+ @property({ attribute: 'page-size', reflect: true, type: Number }) pageSize = 25;
109
+
110
+ /**
111
+ * An array of numbers representing the available options for the number of items to display per page. The default value is [10, 25, 50, 100].
112
+ * The component will use this array to populate the rows-per-page selector, allowing users to choose from the specified options.
113
+ */
114
+ @property({
115
+ attribute: 'page-size-options',
116
+ converter: {
117
+ fromAttribute: (value: string) => value
118
+ .split(',')
119
+ .map(val => {
120
+ const num = parseInt(val.trim(), 10);
121
+ return Number.isSafeInteger(num) ? num : null;
122
+ })
123
+ .filter(Boolean),
124
+ },
125
+ type: Array,
126
+ }) pageSizeOptions: number[] = [10, 25, 50, 100];
127
+
128
+ /**
129
+ * Total amount of items. The component will use this value to calculate the total number of pages based on the selected rows per page.
130
+ */
131
+ @property({ attribute: 'total-items', reflect: true, type: Number }) totalItems = 0;
132
+
133
+ /**
134
+ * The pagination variant to use. The "full" variant includes comprehensive controls for navigating between pages and adjusting the number of displayed rows,
135
+ * while the "compact" variant offers a streamlined interface with essential navigation controls.
136
+ * The default value is "full".
137
+ */
138
+ @property({ attribute: 'variant', reflect: true }) variant: 'full' | 'compact' = 'full';
139
+
140
+ /**
141
+ * An accessible label for the navigation landmark. Customize for multiple paginations on a page.
142
+ */
143
+ @property({ attribute: 'aria-label' }) ariaLabel = 'Pagination';
144
+
145
+ private pageChangedViaUserInput(e: SynInputEvent) {
146
+ const newPage = (e.target as SynInput).valueAsNumber;
147
+ // Ignore invalid page inputs
148
+ if (!isValidPositiveInteger(newPage)) {
149
+ return;
150
+ }
151
+ this.updateCurrentPage(newPage);
152
+ }
153
+
154
+ private navigationClicked(event: MouseEvent, newPage: number) {
155
+ // Blur first so icon-button focus state settles before this render cycle disables it.
156
+ (event.currentTarget as SynIconButton | null)?.blur();
157
+ this.updateCurrentPage(newPage);
158
+ }
159
+
160
+ private sanitizeInvalidPropertyValues(changed: PropertyValues<this>) {
161
+ if (changed.has('pageSize') && !isValidPositiveInteger(this.pageSize)) {
162
+ this.pageSize = getPreviousOrDefault(
163
+ changed,
164
+ 'pageSize',
165
+ SynPagination.DEFAULT_PAGE_SIZE,
166
+ isValidPositiveInteger,
167
+ );
168
+ }
169
+
170
+ if (changed.has('currentPage') && !isValidPositiveInteger(this.currentPage)) {
171
+ this.currentPage = getPreviousOrDefault(
172
+ changed,
173
+ 'currentPage',
174
+ SynPagination.DEFAULT_CURRENT_PAGE,
175
+ isValidPositiveInteger,
176
+ );
177
+ }
178
+
179
+ if (changed.has('totalItems') && !isValidNonNegativeInteger(this.totalItems)) {
180
+ this.totalItems = getPreviousOrDefault(
181
+ changed,
182
+ 'totalItems',
183
+ SynPagination.DEFAULT_TOTAL_ITEMS,
184
+ isValidNonNegativeInteger,
185
+ );
186
+ }
187
+
188
+ if (changed.has('pageSizeOptions')) {
189
+ const sanitizedPageSizeOptions = sanitizePageSizeOptions(this.pageSizeOptions);
190
+ const hasChanged = this.pageSizeOptions.length !== sanitizedPageSizeOptions.length
191
+ || this.pageSizeOptions.some((option, index) => option !== sanitizedPageSizeOptions[index]);
192
+
193
+ if (hasChanged) {
194
+ this.pageSizeOptions = sanitizedPageSizeOptions;
195
+ }
196
+ }
197
+ }
198
+
199
+ /**
200
+ * Updates the current page number and emits a "syn-pagination-page-changed" event with the new and previous page numbers.
201
+ * This method is called when the page number is changed via the page input or the navigation buttons.
202
+ */
203
+ private updateCurrentPage(newPage: number) {
204
+ const totalPages = getTotalPages(this.pageSize, this.totalItems);
205
+ const safeNewPage = clampPage(newPage, totalPages);
206
+ const { currentPage } = this;
207
+
208
+ if (safeNewPage === currentPage) {
209
+ return;
210
+ }
211
+
212
+ this.emit('syn-pagination-page-changed', {
213
+ detail: {
214
+ currentPage: safeNewPage,
215
+ previousPage: currentPage,
216
+ },
217
+ });
218
+
219
+ this.currentPage = safeNewPage;
220
+ }
221
+
222
+ /**
223
+ * Called when the page size is changed via the page size select.
224
+ * Emits a `syn-pagination-page-size-changed` event with the new and previous page sizes.
225
+ */
226
+ private pageSizeChanged(e: SynInputEvent) {
227
+ const { currentPage, pageSize } = this;
228
+ const currentTarget = e.target as SynSelect;
229
+ const { value } = currentTarget;
230
+ const nextPageSize = parseInt(value as string, 10);
231
+
232
+ // Validate the new page size before applying it
233
+ if (!Number.isSafeInteger(nextPageSize) || nextPageSize <= 0) return;
234
+
235
+ // When we switch from a smaller value to a larger one,
236
+ // we also have to adjust the current page marker.
237
+ const oldStartIndex = (currentPage - 1) * pageSize + 1;
238
+ const nextTotalPages = getTotalPages(nextPageSize, this.totalItems);
239
+
240
+ const nextPage = clampPage(
241
+ Math.floor((oldStartIndex - 1) / nextPageSize) + 1,
242
+ nextTotalPages,
243
+ );
244
+
245
+ this.pageSize = nextPageSize;
246
+ this.currentPage = nextPage;
247
+
248
+ this.emit('syn-pagination-page-size-changed', {
249
+ detail: {
250
+ currentPageSize: nextPageSize,
251
+ previousPageSize: pageSize,
252
+ },
253
+ });
254
+
255
+ if (nextPage !== currentPage) {
256
+ this.emit('syn-pagination-page-changed', {
257
+ detail: {
258
+ currentPage: nextPage,
259
+ previousPage: currentPage,
260
+ },
261
+ });
262
+ }
263
+ }
264
+
265
+ protected willUpdate(changed: PropertyValues<this>) {
266
+ super.willUpdate(changed);
267
+
268
+ this.sanitizeInvalidPropertyValues(changed);
269
+
270
+ const previousPageSizeOptions = changed.get('pageSizeOptions');
271
+ const hasPreviousPageSizeOptions = Array.isArray(previousPageSizeOptions);
272
+
273
+ if (hasPreviousPageSizeOptions && !this.pageSizeOptions.includes(this.pageSize)) {
274
+ const nextPageSize = this.pageSizeOptions[0];
275
+ const oldStartIndex = (this.currentPage - 1) * this.pageSize + 1;
276
+ const nextTotalPages = getTotalPages(nextPageSize, this.totalItems);
277
+
278
+ const nextPage = clampPage(
279
+ Math.floor((oldStartIndex - 1) / nextPageSize) + 1,
280
+ nextTotalPages,
281
+ );
282
+
283
+ this.pageSize = nextPageSize;
284
+ this.currentPage = nextPage;
285
+ }
286
+
287
+ if (changed.has('currentPage') || changed.has('pageSize') || changed.has('totalItems')) {
288
+ // If the current page exceeds the total number of pages based on the new page size or total items,
289
+ // we need to adjust it to ensure it remains within valid bounds.
290
+ const totalPages = getTotalPages(this.pageSize, this.totalItems);
291
+ const clamped = clampPage(this.currentPage, totalPages);
292
+ if (clamped !== this.currentPage) {
293
+ this.currentPage = clamped;
294
+ }
295
+ }
296
+ }
297
+
298
+ protected updated(changed: PropertyValues<this>) {
299
+ super.updated(changed);
300
+
301
+ // When the size of available options or the page size changes,
302
+ // we have to adjust the width of our page size select/input controls.
303
+ if (changed.has('pageSizeOptions') || changed.has('pageSize') || changed.has('totalItems')) {
304
+ const maxOptionCharCount = getMaxOptionCharCount(this.pageSizeOptions);
305
+ const totalPagesCharCount = getTotalPagesCharCount(this.pageSize, this.totalItems);
306
+ const baseElement = this.baseRef.value;
307
+
308
+ if (baseElement) {
309
+ baseElement.style.setProperty('--pagination-page-size-option-char-count', String(maxOptionCharCount));
310
+ baseElement.style.setProperty('--pagination-total-pages-char-count', String(totalPagesCharCount));
311
+ }
312
+ }
313
+ }
314
+
315
+ render() {
316
+ // List of total pages.
317
+ // Used to determine the disabled state of navigation buttons and to calculate the page item indices for display.
318
+ const totalPages = calculateTotalPages(this.totalItems, this.pageSize);
319
+
320
+ // Determine if we're in compact mode to conditionally apply styles and layout adjustments.
321
+ const isCompact = this.variant === 'compact';
322
+
323
+ // Condition to determine if the pagination controls should be disabled.
324
+ const isDisabled = this.disabled || totalPages === 0;
325
+
326
+ // Calculate the start and end item indices for the current page to display in the pagination summary (e.g., "11-20 of 100 items").
327
+ const pageItemIndices = calculatePageItemIndices(this.totalItems, this.pageSize, this.currentPage);
328
+
329
+ // If the current page size is not included in the available options,
330
+ // we select the first option as the default value to ensure the select input displays a valid option.
331
+ const selectedPageSizeOption = this.pageSizeOptions.includes(this.pageSize)
332
+ ? this.pageSize
333
+ : this.pageSizeOptions[0];
334
+
335
+ const isFirstPage = this.currentPage === 1;
336
+ const isLastPage = this.currentPage === totalPages;
337
+
338
+ /* eslint-disable @typescript-eslint/unbound-method */
339
+ return html`
340
+ ${this.divider ? html`<syn-divider part="divider"></syn-divider>` : nothing}
341
+ <nav
342
+ aria-label=${this.ariaLabel}
343
+ class="pagination"
344
+ part="base"
345
+ ${ref(this.baseRef)}
346
+ >
347
+ ${!isCompact ? html`
348
+ <div class="pagination__page-size-select-wrapper" part="page-size-select-wrapper">
349
+ <syn-select
350
+ class="pagination__page-size-select"
351
+ ?disabled=${isDisabled}
352
+ label=${this.localize.term('paginationItemsPerPage')}
353
+ part="page-size-select"
354
+ value=${selectedPageSizeOption}
355
+ size=${this.size}
356
+ @syn-change=${this.pageSizeChanged}
357
+ >
358
+ ${this.pageSizeOptions.map(option => html`
359
+ <syn-option value="${option}">
360
+ ${option}
361
+ </syn-option>
362
+ `)}
363
+ </syn-select>
364
+ <!-- /.pagination__page-size-select -->
365
+
366
+ <span part="page-item-summary">
367
+ ${this.localize.term(
368
+ 'paginationItemSummary',
369
+ pageItemIndices.startIndex,
370
+ pageItemIndices.endIndex,
371
+ this.totalItems,
372
+ )}
373
+ </span>
374
+ <!-- /.pagination__page-item-summary -->
375
+ </div>
376
+ <!-- /.pagination__page-size-select-wrapper -->
377
+ `: nothing}
378
+
379
+ <div class="pagination__navigation" part="navigation">
380
+ <section>
381
+ <syn-icon-button
382
+ @click=${(e: MouseEvent) => this.navigationClicked(e, 1)}
383
+ color="primary"
384
+ ?disabled=${isFirstPage || isDisabled}
385
+ label=${this.localize.term('paginationFirstPage')}
386
+ library="system"
387
+ name="first-page"
388
+ part="navigation-action"
389
+ size=${this.size}
390
+ ></syn-icon-button>
391
+
392
+ <syn-icon-button
393
+ @click=${(e: MouseEvent) => this.navigationClicked(e, this.currentPage - 1)}
394
+ color="primary"
395
+ ?disabled=${isFirstPage || isDisabled}
396
+ label=${this.localize.term('paginationPreviousPage')}
397
+ library="system"
398
+ name="previous-page"
399
+ part="navigation-action"
400
+ size=${this.size}
401
+ ></syn-icon-button>
402
+ </section>
403
+
404
+ <section part="page-input-section">
405
+ <syn-input
406
+ class="pagination__page-input"
407
+ ?disabled=${isDisabled}
408
+ label=${this.localize.term('paginationInputLabel')}
409
+ max=${totalPages}
410
+ min="1"
411
+ no-spin-buttons
412
+ numeric-strategy="modern"
413
+ part="page-input"
414
+ size=${this.size}
415
+ @syn-change=${this.pageChangedViaUserInput}
416
+ type="number"
417
+ value=${this.currentPage}
418
+ ></syn-input>
419
+
420
+ <span>${this.localize.term('paginationOfTotalPages', totalPages)}</span>
421
+ </section>
422
+
423
+ <section>
424
+ <syn-icon-button
425
+ @click=${(e: MouseEvent) => this.navigationClicked(e, this.currentPage + 1)}
426
+ color="primary"
427
+ ?disabled=${isLastPage || isDisabled}
428
+ label=${this.localize.term('paginationNextPage')}
429
+ library="system"
430
+ name="next-page"
431
+ part="navigation-action"
432
+ size=${this.size}
433
+ ></syn-icon-button>
434
+
435
+ <syn-icon-button
436
+ @click=${(e: MouseEvent) => this.navigationClicked(e, totalPages)}
437
+ color="primary"
438
+ ?disabled=${isLastPage || isDisabled}
439
+ label=${this.localize.term('paginationLastPage')}
440
+ library="system"
441
+ name="last-page"
442
+ part="navigation-action"
443
+ size=${this.size}
444
+ ></syn-icon-button>
445
+ </section>
446
+ </div>
447
+ <!-- /.pagination__navigation -->
448
+ </nav>
449
+ `;
450
+ /* eslint-enable @typescript-eslint/unbound-method */
451
+ }
452
+ }
@@ -0,0 +1,128 @@
1
+ import { css } from 'lit';
2
+
3
+ export default css`
4
+ :host {
5
+ display: block;
6
+ }
7
+
8
+ .pagination {
9
+ --base-font: var(--syn-body-medium-regular);
10
+ --base-gap: var(--syn-spacing-small);
11
+ --navigation-gap: var(--syn-spacing-small);
12
+ --pagination-page-size-option-char-count: 2;
13
+ --pagination-total-pages-char-count: 3;
14
+
15
+ align-items: center;
16
+ display: flex;
17
+ flex-wrap: wrap;
18
+ font: var(--base-font);
19
+ gap: var(--base-gap) var(--syn-spacing-large);
20
+ }
21
+
22
+ /* Sizes */
23
+ :host([size="small"]) .pagination {
24
+ --base-gap: var(--syn-spacing-x-small);
25
+ --base-font: var(--syn-body-small-regular);
26
+ }
27
+
28
+ :host([size="large"]) .pagination {
29
+ --base-gap: var(--syn-spacing-medium);
30
+ --base-font: var(--syn-body-large-regular);
31
+ }
32
+
33
+ /* Divider */
34
+ syn-divider {
35
+ --divider-spacing: var(--syn-spacing-small);
36
+ --spacing: 0 auto var(--divider-spacing);
37
+ }
38
+
39
+ :host([size="small"]) syn-divider {
40
+ --divider-spacing: var(--syn-spacing-x-small);
41
+ }
42
+
43
+ :host([size="large"]) syn-divider {
44
+ --divider-spacing: var(--syn-spacing-medium);
45
+ }
46
+
47
+ /* Select */
48
+ .pagination__page-size-select-wrapper {
49
+ align-items: center;
50
+ display: flex;
51
+ gap: var(--base-gap);
52
+ }
53
+
54
+ .pagination__page-size-select::part(form-control) {
55
+ align-items: center;
56
+ display: flex;
57
+ gap: var(--base-gap);
58
+ }
59
+
60
+ .pagination__page-size-select::part(form-control-label) {
61
+ font: var(--base-font);
62
+ margin-bottom: 0;
63
+ }
64
+
65
+ .pagination__page-size-select::part(display-input) {
66
+ width: calc((var(--pagination-page-size-option-char-count) * 1ch) + 1ch);
67
+ }
68
+
69
+ /* Navigation */
70
+ .pagination__navigation {
71
+ align-items: center;
72
+ display: flex;
73
+ flex: 1;
74
+ flex-wrap: nowrap;
75
+ gap: var(--navigation-gap);
76
+ justify-content: end;
77
+ }
78
+
79
+ .pagination__navigation > section {
80
+ align-items: center;
81
+ display: flex;
82
+ flex-wrap: nowrap;
83
+ }
84
+
85
+ .pagination__page-input {
86
+ margin-inline-end: var(--navigation-gap);
87
+ }
88
+
89
+ .pagination__page-input::part(input) {
90
+ text-align: center;
91
+ width: calc((var(--pagination-total-pages-char-count) * 1ch) + 3ch);
92
+ }
93
+
94
+ /**
95
+ * Make sure to hide the label of the page input, but keep it accessible for screen readers.
96
+ * We can't use the label slot of syn-input for this, because it would mess with the layout.
97
+ */
98
+ .pagination__page-input::part(form-control-label) {
99
+ border: 0;
100
+ /* stylelint-disable-next-line property-no-deprecated */
101
+ clip: rect(0, 0, 0, 0);
102
+ height: 1px;
103
+ margin: -1px;
104
+ overflow: hidden;
105
+ padding: 0;
106
+ position: absolute;
107
+ white-space: nowrap;
108
+ width: 1px;
109
+ }
110
+
111
+ /* Compact Version */
112
+ :host([variant="compact"]) .pagination__navigation {
113
+ justify-content: center;
114
+ }
115
+
116
+ /* Adjustments for really small container widths */
117
+ @supports (container-type: inline-size) {
118
+ :host {
119
+ container-type: inline-size;
120
+ }
121
+
122
+ @container (max-width: 400px) {
123
+ .pagination__navigation {
124
+ justify-content: center;
125
+ }
126
+ }
127
+ }
128
+ `;
@@ -0,0 +1,12 @@
1
+ import SynPagination from './pagination.component.js';
2
+
3
+ export * from './pagination.component.js';
4
+ export default SynPagination;
5
+
6
+ SynPagination.define('syn-pagination');
7
+
8
+ declare global {
9
+ interface HTMLElementTagNameMap {
10
+ 'syn-pagination': SynPagination;
11
+ }
12
+ }