@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,590 @@
1
+ import type { CSSResultGroup, PropertyValues } from 'lit';
2
+ import { html } from 'lit';
3
+ import {
4
+ property,
5
+ query,
6
+ queryAssignedElements,
7
+ state,
8
+ } from 'lit/decorators.js';
9
+ import { ifDefined } from 'lit/directives/if-defined.js';
10
+ import componentStyles from '../../styles/component.styles.js';
11
+ import SynergyElement from '../../internal/synergy-element.js';
12
+ import type SynInput from '../input/input.component.js';
13
+ import { watch } from '../../internal/watch.js';
14
+ import SynAlert from '../alert/alert.component.js';
15
+ import SynTooltip from '../tooltip/tooltip.component.js';
16
+ import {
17
+ alertSizeForInput,
18
+ getActualInputElement,
19
+ getEventNameForElement,
20
+ isBlurEvent,
21
+ isInvalidEvent,
22
+ isSynergyElement,
23
+ normalizeEventAttribute,
24
+ } from './utility.js';
25
+ import styles from './validate.styles.js';
26
+ import { enableDefaultSettings } from '../../utilities/defaultSettings/decorator.js';
27
+
28
+ /**
29
+ * Utility function that renders the default slot content.
30
+ * This is needed to avoid code duplication when rendering the default slot in both the tooltip and the regular render function.
31
+ */
32
+ const renderDefaultSlot = () => html`
33
+ <slot
34
+ class="validate__input-wrapper"
35
+ part="input-wrapper"
36
+ ></slot>
37
+ `;
38
+
39
+ /**
40
+ * @summary Validate provides form field validation messages in a unified way.
41
+ * It does this by using [the native browser validation](https://developer.mozilla.org/en-US/docs/Learn/Forms/Form_validation)
42
+ * and showing the validation message in a consistent, user defined way.
43
+ * @documentation https://synergy-design-system.github.io/?path=/docs/components-syn-validate--docs
44
+ * @dependency syn-alert
45
+ * @dependency syn-tooltip
46
+ *
47
+ * @slot - The form field that should be validated.
48
+ * Avoid slotting in more than one element, as subsequent ones will be ignored.
49
+ *
50
+ * @csspart base - The component's base wrapper.
51
+ * @csspart input-wrapper - The container that wraps the form field.
52
+ *
53
+ * @csspart alert - The syn-alert that is shown when the variant is set to "inline".
54
+ * @csspart alert__base - The container that wraps the alert.
55
+ * @csspart alert__message - The container that wraps the alert message.
56
+ * @csspart alert__icon - The container that wraps the alert icon.
57
+ *
58
+ * @csspart tooltip - The syn-tooltip that is shown when the variant is set to "tooltip".
59
+ * @csspart tooltip__base - The container that wraps the tooltip.
60
+ * @csspart tooltip__popup - The container that wraps the tooltip popup.
61
+ * @csspart tooltip__arrow - The container that wraps the tooltip arrow.
62
+ * @csspart tooltip__body - The container that wraps the tooltip body.
63
+ */
64
+ @enableDefaultSettings('SynValidate')
65
+ export default class SynValidate extends SynergyElement {
66
+ static styles: CSSResultGroup = [componentStyles, styles];
67
+
68
+ static dependencies = {
69
+ 'syn-alert': SynAlert,
70
+ 'syn-tooltip': SynTooltip,
71
+ };
72
+
73
+ controller = new AbortController();
74
+
75
+ observer: MutationObserver;
76
+
77
+ sizeObserver: MutationObserver;
78
+
79
+ @queryAssignedElements() private slottedChildren: HTMLElement[];
80
+
81
+ @query('syn-tooltip') private tooltipElement?: SynTooltip;
82
+
83
+ @state() validationMessage = '';
84
+
85
+ @state() eagerFirstMount = true;
86
+
87
+ @state() isInternalTriggeredInvalid = false;
88
+
89
+ @state() isValid = true;
90
+
91
+ @state() alertSize?: SynInput['size'];
92
+
93
+ @state() hasFocus = false;
94
+
95
+ /**
96
+ * The variant that should be used to show validation alerts.
97
+ *
98
+ * The following variants are supported:
99
+ * - **native** (default): Uses the native browser validation, usually a browser tooltip.
100
+ * - **tooltip**: Show the validation message as a tooltip using a `<syn-tooltip>`.
101
+ * - **inline**: Show the validation message underneath the element, using a `<syn-alert>`
102
+ */
103
+ @property({ reflect: true }) variant: 'native' | 'tooltip' | 'inline' = 'native';
104
+
105
+ /** Do not show the error icon when using the inline variant validation */
106
+ @property({ attribute: 'hide-icon', reflect: true, type: Boolean }) hideIcon = false;
107
+
108
+ /**
109
+ * Defines the events that trigger the validation.
110
+ * `invalid` will always automatically be included.
111
+ * You may also use the `live` keyword to validate on every input change.
112
+ * `live` will make sure to listen to the `invalid`, `input` and `blur` events.
113
+ *
114
+ * Please have a look at the [documentation for native form validation](https://developer.mozilla.org/en-US/docs/Learn/Forms/Form_validation)
115
+ * and [the use of form invalid events](https://developer.mozilla.org/en-US/docs/Web/API/HTMLInputElement/invalid_event) for further information.
116
+ *
117
+ * @example ```html
118
+ * <!-- Validate on invalid and change events (invalid, change) -->
119
+ * <syn-validate on="invalid change"></syn-validate>
120
+ *
121
+ * <!-- Validate on live events (invalid, blur, input)-->
122
+ * <syn-validate on="live"></syn-validate>
123
+ *
124
+ * <!-- Validate on live and custom events (invalid, blur, input, focus, change) -->
125
+ * <syn-validate on="live focus change"></syn-validate>
126
+ * ```
127
+ */
128
+ @property({ reflect: true }) on: string = '';
129
+
130
+ /**
131
+ * Custom validation message to be displayed when the input is invalid.
132
+ * Will override the default browser validation message.
133
+ * Set to an empty string to reset the validation message.
134
+ */
135
+ @property({ attribute: 'custom-validation-message', type: String }) customValidationMessage = '';
136
+
137
+ /**
138
+ * Set this to true to validate the input immediately when it is rendered.
139
+ * Best used with a `variant` of `inline`.
140
+ * When setting eager, the input will not be focused automatically.
141
+ *
142
+ * When using a `variant` of `native` the browser will focus
143
+ * the last eager field as it is using a tooltip.
144
+ * In this case it is better to just provide one eager field.
145
+ */
146
+ @property({ type: Boolean }) eager = false;
147
+
148
+ // Automatically refresh all event listeners when the on property changes.
149
+ @watch('on', { waitUntilFirstUpdate: true })
150
+ handleListenerChange() {
151
+ this.updateEvents();
152
+ }
153
+
154
+ @watch('eager', { waitUntilFirstUpdate: false })
155
+ async handleEagerChange() {
156
+ if (this.eager) {
157
+ const input = this.getInput();
158
+ await this.updateComplete;
159
+ input?.reportValidity();
160
+ this.eagerFirstMount = true;
161
+ } else {
162
+ this.eagerFirstMount = false;
163
+ }
164
+ }
165
+
166
+ // Synchronize the validation message on the wrapped input with the custom message
167
+ @watch('customValidationMessage', { waitUntilFirstUpdate: true })
168
+ handleCustomValidationMessageChange() {
169
+ const input = this.getInput();
170
+ if (input) {
171
+ this.setCustomValidationMessage(input);
172
+ this.setValidationMessage(input);
173
+ }
174
+ }
175
+
176
+ /**
177
+ * Returns the validity state of the input component.
178
+ * `true` for valid and `false` for invalid.
179
+ */
180
+ getValidity() {
181
+ return this.isValid;
182
+ }
183
+
184
+ /**
185
+ * Get the input element to validate. Defined as the first slotted element
186
+ * @returns The input element or undefined if not found
187
+ */
188
+ private getInput() {
189
+ const input = this.slottedChildren[0];
190
+ return input ? input as HTMLInputElement : undefined;
191
+ }
192
+
193
+ private setAlertSize() {
194
+ this.alertSize = alertSizeForInput(this.getInput());
195
+ }
196
+
197
+ /**
198
+ * Get the event names to listen for.
199
+ * If the input is a synergy element, will use syn- prefixes.
200
+ * @returns The event names to listen for
201
+ */
202
+ // eslint-disable-next-line complexity
203
+ private getUsedEventNames() {
204
+ const input = this.getInput();
205
+
206
+ // If there is no input, skip before doing any harm
207
+ if (!input) {
208
+ return [];
209
+ }
210
+
211
+ // Make sure to always use an array of events
212
+ // This is needed because on may be a special value like "live"
213
+ const on = normalizeEventAttribute(this.on);
214
+
215
+ // Filter makes sure to remove empty values, e.g.
216
+ // <syn-validate on=""></syn-validate>
217
+ const [...events] = on.filter(Boolean);
218
+
219
+ // Make sure to always have an invalid event
220
+ if (!events.includes('invalid')) {
221
+ events.push('invalid');
222
+ }
223
+
224
+ // Special handling for the live keyword:
225
+ // live always means on input and blur
226
+ if (events.includes('live')) {
227
+ events.push('input');
228
+ events.push('blur');
229
+ }
230
+
231
+ // Make sure to remove duplicated events and the live property
232
+ // and map the events to the correct event names
233
+ return Array.from(new Set(
234
+ events
235
+ .filter(e => e !== 'live')
236
+ .map(e => getEventNameForElement(input, e)),
237
+ ));
238
+ }
239
+
240
+ /**
241
+ * Update the events on the input element.
242
+ */
243
+ private updateEvents() {
244
+ this.controller.abort();
245
+ this.controller = new AbortController();
246
+ const input = this.getInput();
247
+
248
+ if (!input) {
249
+ return;
250
+ }
251
+
252
+ const events = this.getUsedEventNames();
253
+ events.forEach(eventName => {
254
+ // eslint-disable-next-line @typescript-eslint/no-misused-promises
255
+ input.addEventListener(eventName, this.validate, {
256
+ capture: isInvalidEvent(eventName),
257
+ signal: this.controller.signal,
258
+ });
259
+ });
260
+
261
+ // If the change event is not included,
262
+ // make sure to attach a custom listener that resets the validation message
263
+ // This is needed as the custom message may be set on change
264
+ const usedChangeEvent = getEventNameForElement(input, 'change');
265
+ if (!events.includes(usedChangeEvent)) {
266
+ input.addEventListener(usedChangeEvent, this.internalRevalidate, {
267
+ signal: this.controller.signal,
268
+ });
269
+ }
270
+
271
+ // #664: Add focus/blur listeners specifically for tooltip variant
272
+ // This is needed because we want to show the tooltip on focus and hide it on blur, but only when using the tooltip variant.
273
+ // Otherwise, this would interfere with the native validation tooltip, which also relies on focus and blur events.
274
+ const focusEvent = getEventNameForElement(input, 'focus');
275
+ const blurEvent = getEventNameForElement(input, 'blur');
276
+
277
+ input.addEventListener(focusEvent, this.handleInputFocus, {
278
+ signal: this.controller.signal,
279
+ });
280
+
281
+ input.addEventListener(blurEvent, this.handleInputBlur, {
282
+ signal: this.controller.signal,
283
+ });
284
+ }
285
+
286
+ /**
287
+ * #851: Get the validation message that should be displayed to the user.
288
+ * Prioritizes customValidationMessage over the internal validationMessage state.
289
+ * This is needed because frameworks may clear the internal validation message on
290
+ * dynamically rendered elements, but the customValidationMessage is still valid.
291
+ */
292
+ private getDisplayValidationMessage(): string {
293
+ return this.customValidationMessage || this.validationMessage;
294
+ }
295
+
296
+ private setValidationMessage(input: HTMLInputElement) {
297
+ const { customValidationMessage } = this;
298
+ const validationMessage = customValidationMessage || input.validationMessage;
299
+ this.validationMessage = validationMessage;
300
+ }
301
+
302
+ /**
303
+ * Set the custom validation message to the input. This will make sure to either:
304
+ * - use the custom message if one is set or
305
+ * - use the default message if the custom message is empty
306
+ */
307
+ private setCustomValidationMessage(input: HTMLInputElement) {
308
+ // Set the custom validation message on the input only once, when the customValidationMessage
309
+ // is changed. Otherwise there could be problems with `variant="native"` and `on="live"` or
310
+ // `on="blur"`, because the browser popup will never disappear even if clicking somewhere else.
311
+ input.setCustomValidity(this.customValidationMessage);
312
+ }
313
+
314
+ /**
315
+ * Set the validation message from the input element
316
+ * @param e The event that was received
317
+ */
318
+ private internalRevalidate = (e: Event) => {
319
+ const input = e.currentTarget as HTMLInputElement;
320
+ if (input.validity?.valid) {
321
+ this.validationMessage = '';
322
+ }
323
+ };
324
+
325
+ /**
326
+ * Handle focus/blur events for tooltip variant
327
+ */
328
+ private handleInputFocus = () => {
329
+ this.hasFocus = true;
330
+ };
331
+
332
+ private handleInputBlur = () => {
333
+ this.hasFocus = false;
334
+ };
335
+
336
+ /**
337
+ * Handle the blur event during validation
338
+ */
339
+ // eslint-disable-next-line class-methods-use-this
340
+ private handleFocus(input: HTMLInputElement) {
341
+ const activeElement = document.activeElement! as HTMLInputElement;
342
+ const activeElementIsWrapped = activeElement.closest('syn-validate');
343
+
344
+ if (!activeElement.validity?.valid && activeElementIsWrapped) {
345
+ // The active element is invalid do not scroll
346
+ return;
347
+ }
348
+
349
+ input.scrollIntoView({ block: 'nearest' });
350
+ input.focus();
351
+ }
352
+
353
+ /**
354
+ * Triggers a validation run, showing the validation message if needed.
355
+ */
356
+ // eslint-disable-next-line complexity
357
+ private validate = async (e: Event) => {
358
+ // Make sure to stop the validate component from going into an endless cycle of triggering
359
+ if (isInvalidEvent(e.type) && this.variant === 'native' && this.isInternalTriggeredInvalid === true) {
360
+ this.isInternalTriggeredInvalid = false;
361
+ return;
362
+ }
363
+
364
+ // Make sure to always prevent the invalid event when not using native validation
365
+ if (isInvalidEvent(e.type) && this.variant !== 'native') {
366
+ e.preventDefault();
367
+ e.stopPropagation();
368
+ }
369
+
370
+ const input = e.currentTarget as HTMLInputElement;
371
+ if (isSynergyElement(input)) {
372
+ // When using a synergy element, we need to wait for it to be ready!
373
+ // This is needed as the validity state of the element may not be set yet.
374
+ await input.updateComplete;
375
+ }
376
+ this.isValid = input.validity?.valid;
377
+
378
+ // When we are using eager, make sure to skip focus on the first mount
379
+ if (this.eager && this.eagerFirstMount) {
380
+ this.eagerFirstMount = false;
381
+ this.setValidationMessage(input);
382
+ return;
383
+ }
384
+
385
+ // If the active element that has focus is placed in a validate component,
386
+ // make sure to not loose focus.
387
+ if (!this.isValid && !isBlurEvent(e.type)) {
388
+ this.handleFocus(input);
389
+ }
390
+
391
+ this.setValidationMessage(input);
392
+
393
+ // Trigger reportValidity when using native validation, so the browser popup is also shown
394
+ // for other events than `invalid`. All events except the blur event, should trigger this.
395
+ if (!isBlurEvent(e.type) && this.variant === 'native') {
396
+ // eslint-disable-next-line @typescript-eslint/no-floating-promises
397
+ this.updateComplete.then(() => {
398
+ this.isInternalTriggeredInvalid = true;
399
+ input.reportValidity();
400
+ });
401
+ }
402
+ };
403
+
404
+ // eslint-disable-next-line @typescript-eslint/no-misused-promises
405
+ async firstUpdated(changedProperties: PropertyValues) {
406
+ super.firstUpdated(changedProperties);
407
+ this.updateEvents();
408
+
409
+ // #713: Make sure to set the custom validation message on mount
410
+ // When we have a custom element, we need to wait for it to be ready!
411
+ const input = this.getInput();
412
+
413
+ if (this.customValidationMessage) {
414
+ if (isSynergyElement(input)) {
415
+ await input.updateComplete;
416
+ }
417
+ input?.setCustomValidity(this.customValidationMessage);
418
+ }
419
+
420
+ // Make sure to run validation on mount if eager is set
421
+ if (this.eager) {
422
+ await this.updateComplete;
423
+ this.isValid = input?.validity?.valid ?? false;
424
+ input?.reportValidity();
425
+ }
426
+ }
427
+
428
+ connectedCallback() {
429
+ super.connectedCallback();
430
+
431
+ // #1119: Update alert size when the input size changes
432
+ // Note that we need to create our own observer here,
433
+ // as the size attribute may be changed on the input element directly,
434
+ // which would not be captured by the synergy-element observer.
435
+ this.sizeObserver = new MutationObserver(entries => {
436
+ const input = this.getInput();
437
+
438
+ if (!input) {
439
+ return;
440
+ }
441
+
442
+ const hasSizeChanged = entries
443
+ .filter(({ target }) => target === input)
444
+ .every(
445
+ entry => entry.attributeName === 'size',
446
+ );
447
+
448
+ if (hasSizeChanged) {
449
+ this.setAlertSize();
450
+ }
451
+ });
452
+
453
+ this.sizeObserver.observe(this, {
454
+ attributeFilter: ['size'],
455
+ attributes: true,
456
+ subtree: true,
457
+ });
458
+
459
+ // #717: Make sure to remove to rerun validation when
460
+ // disabled or readonly properties change on the input
461
+ this.observer = new MutationObserver(entries => {
462
+ const input = this.getInput();
463
+
464
+ if (!input) {
465
+ return;
466
+ }
467
+
468
+ // Check if the input is disabled or readonly
469
+ const hasDisabledOrReadonly = entries
470
+ .filter(({ target }) => target === input)
471
+ .every(entry => {
472
+ const target = entry.target as HTMLInputElement;
473
+ return target.hasAttribute('disabled') || target.hasAttribute('readonly');
474
+ });
475
+
476
+ if (hasDisabledOrReadonly) {
477
+ this.isValid = true;
478
+ this.validationMessage = '';
479
+ } else {
480
+ // When using a synergy element, we need to check the validity after the element is updated,
481
+ // as we cannot rely on the validity state of the element itself.
482
+ // Unfortunately, this depends on used browser :(.
483
+ const waitForPromise = isSynergyElement(input)
484
+ ? input.updateComplete
485
+ : Promise.resolve();
486
+
487
+ // eslint-disable-next-line @typescript-eslint/no-floating-promises
488
+ waitForPromise.then(() => {
489
+ this.isValid = input?.validity?.valid ?? false;
490
+ this.validationMessage = input?.validationMessage ?? '';
491
+ });
492
+ }
493
+ });
494
+
495
+ this.observer.observe(this, {
496
+ attributeFilter: ['disabled', 'readonly'],
497
+ attributes: true,
498
+ subtree: true,
499
+ });
500
+ }
501
+
502
+ disconnectedCallback() {
503
+ super.disconnectedCallback();
504
+ this.controller.abort();
505
+ this?.observer?.disconnect();
506
+ this?.sizeObserver?.disconnect();
507
+ }
508
+
509
+ updated(changedProperties: PropertyValues) {
510
+ super.updated(changedProperties);
511
+
512
+ // #664: Make sure to update the syn-tooltip if the validation state changes when using the tooltip variant
513
+ if (this.variant !== 'tooltip') {
514
+ return;
515
+ }
516
+
517
+ const tooltip = this.tooltipElement;
518
+
519
+ if (!tooltip) {
520
+ return;
521
+ }
522
+
523
+ // When we have a valid tooltip,
524
+ // we need to update the content and show or hide it based on the validation state and focus state.
525
+ // We have to do this manually, as there is a problem when updating open and content at the same time.
526
+ // The order is critical: fill before showing, don´t update the content during hide.
527
+ const displayMessage = this.getDisplayValidationMessage();
528
+ const shouldShowTooltip = !this.isValid && displayMessage && this.hasFocus;
529
+
530
+ if (shouldShowTooltip) {
531
+ tooltip.content = displayMessage;
532
+ // eslint-disable-next-line @typescript-eslint/no-floating-promises
533
+ tooltip.show();
534
+ } else {
535
+ // eslint-disable-next-line @typescript-eslint/no-floating-promises
536
+ tooltip.hide();
537
+ }
538
+ }
539
+
540
+ private renderInlineValidation() {
541
+ const messageToShow = this.getDisplayValidationMessage();
542
+
543
+ if (this.variant !== 'inline' || !messageToShow) {
544
+ return '';
545
+ }
546
+
547
+ return html`
548
+ <syn-alert
549
+ open
550
+ exportparts="base:alert__base,message:alert__message,icon:alert__icon"
551
+ part="alert"
552
+ size=${ifDefined(this.alertSize)}
553
+ variant="danger"
554
+ >
555
+ ${!this.hideIcon
556
+ ? html`<syn-icon slot="icon" name="status-error" library="system"></syn-icon>`
557
+ : ''
558
+ }
559
+ ${messageToShow}
560
+ </syn-alert>
561
+ `;
562
+ }
563
+
564
+ render() {
565
+ // #664: When using the tooltip variant, we need to wrap the default slot in a tooltip when the input is invalid and has a validation message.
566
+ const slotContent = this.variant === 'tooltip'
567
+ ? html`
568
+ <syn-tooltip
569
+ .anchor=${getActualInputElement(this.getInput()) ?? undefined}
570
+ exportparts="base:tooltip__base,base__popup:tooltip__popup,base__arrow:tooltip__arrow,body:tooltip__body"
571
+ .open=${this.eager ? !this.isValid && this.getDisplayValidationMessage().length > 0 : false}
572
+ part="tooltip"
573
+ placement="bottom"
574
+ trigger="manual"
575
+ >
576
+ ${renderDefaultSlot()}
577
+ </syn-tooltip>
578
+ ` : renderDefaultSlot();
579
+
580
+ return html`
581
+ <div
582
+ class="validate"
583
+ part="base"
584
+ >
585
+ ${slotContent}
586
+ ${this.renderInlineValidation()}
587
+ </div>
588
+ `;
589
+ }
590
+ }
@@ -0,0 +1,9 @@
1
+ import { css } from 'lit';
2
+
3
+ export default css`
4
+ .validate {
5
+ display: flex;
6
+ flex-direction: column;
7
+ gap: var(--syn-spacing-small);
8
+ }
9
+ `;
@@ -0,0 +1,12 @@
1
+ import SynValidate from './validate.component.js';
2
+
3
+ export * from './validate.component.js';
4
+ export default SynValidate;
5
+
6
+ SynValidate.define('syn-validate');
7
+
8
+ declare global {
9
+ interface HTMLElementTagNameMap {
10
+ 'syn-validate': SynValidate;
11
+ }
12
+ }
@@ -0,0 +1 @@
1
+ export type SynValidateJSXElement = SynCustomElement<SynValidate, []>;
@@ -0,0 +1,44 @@
1
+ // ---------------------------------------------------------------------
2
+ // 🔒 AUTOGENERATED @synergy-design-system/react wrappers for @synergy-design-system/components
3
+ // Please do not edit this file directly!
4
+ // It will get recreated when running pnpm build.
5
+ // ---------------------------------------------------------------------
6
+ import * as React from 'react';
7
+ import { createComponent } from '@lit/react';
8
+ import Component from '@synergy-design-system/components/components/validate/validate.component.js';
9
+
10
+ const tagName = 'syn-validate';
11
+ Component.define('syn-validate');
12
+
13
+ /**
14
+ * @summary Validate provides form field validation messages in a unified way.
15
+ * It does this by using [the native browser validation](https://developer.mozilla.org/en-US/docs/Learn/Forms/Form_validation)
16
+ * and showing the validation message in a consistent, user defined way.
17
+ * @documentation https://synergy-design-system.github.io/?path=/docs/components-syn-validate--docs
18
+ * @dependency syn-alert
19
+ * @dependency syn-tooltip
20
+ *
21
+ * @slot - The form field that should be validated.
22
+ * Avoid slotting in more than one element, as subsequent ones will be ignored.
23
+ *
24
+ * @csspart base - The component's base wrapper.
25
+ * @csspart input-wrapper - The container that wraps the form field.
26
+ *
27
+ * @csspart alert - The syn-alert that is shown when the variant is set to "inline".
28
+ * @csspart alert__base - The container that wraps the alert.
29
+ * @csspart alert__message - The container that wraps the alert message.
30
+ * @csspart alert__icon - The container that wraps the alert icon.
31
+ *
32
+ * @csspart tooltip - The syn-tooltip that is shown when the variant is set to "tooltip".
33
+ * @csspart tooltip__base - The container that wraps the tooltip.
34
+ * @csspart tooltip__popup - The container that wraps the tooltip popup.
35
+ * @csspart tooltip__arrow - The container that wraps the tooltip arrow.
36
+ * @csspart tooltip__body - The container that wraps the tooltip body.
37
+ */
38
+ export const SynValidate = createComponent({
39
+ displayName: 'SynValidate',
40
+ elementClass: Component,
41
+ events: {},
42
+ react: React,
43
+ tagName,
44
+ });