@nectary/components 4.12.1 → 5.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 (585) hide show
  1. package/accordion/global/index.d.ts +1 -0
  2. package/accordion/global/index.js +2 -0
  3. package/accordion/index.d.ts +1 -22
  4. package/accordion/index.js +41 -39
  5. package/accordion/types.d.ts +21 -1
  6. package/accordion/types.js +1 -1
  7. package/accordion-item/global/index.d.ts +1 -0
  8. package/accordion-item/global/index.js +2 -0
  9. package/accordion-item/index.d.ts +2 -22
  10. package/accordion-item/index.js +53 -49
  11. package/accordion-item/types.d.ts +21 -1
  12. package/accordion-item/types.js +1 -1
  13. package/accordion-item/utils.js +4 -1
  14. package/action-menu/global/index.d.ts +1 -0
  15. package/action-menu/global/index.js +2 -0
  16. package/action-menu/index.d.ts +1 -22
  17. package/action-menu/index.js +62 -77
  18. package/action-menu/types.d.ts +21 -1
  19. package/action-menu/types.js +1 -1
  20. package/action-menu-option/global/index.d.ts +1 -0
  21. package/action-menu-option/global/index.js +2 -0
  22. package/action-menu-option/index.d.ts +1 -22
  23. package/action-menu-option/index.js +39 -41
  24. package/action-menu-option/types.d.ts +21 -1
  25. package/action-menu-option/types.js +1 -1
  26. package/action-menu-option/utils.js +6 -3
  27. package/alert/global/index.d.ts +1 -0
  28. package/alert/global/index.js +2 -0
  29. package/alert/index.d.ts +2 -22
  30. package/alert/index.js +24 -21
  31. package/alert/types.d.ts +21 -1
  32. package/alert/types.js +1 -1
  33. package/alert/utils.js +4 -1
  34. package/avatar/colors.js +1 -1
  35. package/avatar/global/index.d.ts +1 -0
  36. package/avatar/global/index.js +2 -0
  37. package/avatar/index.d.ts +2 -22
  38. package/avatar/index.js +42 -41
  39. package/avatar/types.d.ts +21 -1
  40. package/avatar/types.js +1 -1
  41. package/avatar/utils.js +9 -4
  42. package/badge/global/index.d.ts +1 -0
  43. package/badge/global/index.js +2 -0
  44. package/badge/index.d.ts +3 -22
  45. package/badge/index.js +52 -51
  46. package/badge/types.d.ts +21 -1
  47. package/badge/types.js +1 -1
  48. package/badge/utils.js +4 -1
  49. package/bundle.d.ts +78 -0
  50. package/bundle.js +13069 -0
  51. package/bundle.ts +80 -0
  52. package/button/global/index.d.ts +1 -0
  53. package/button/global/index.js +2 -0
  54. package/button/index.d.ts +2 -22
  55. package/button/index.js +101 -111
  56. package/button/types.d.ts +21 -1
  57. package/button/types.js +1 -1
  58. package/button/utils.js +18 -2
  59. package/button-group/global/index.d.ts +1 -0
  60. package/button-group/global/index.js +2 -0
  61. package/button-group/index.d.ts +1 -22
  62. package/button-group/index.js +20 -18
  63. package/button-group/types.d.ts +22 -3
  64. package/button-group/types.js +1 -1
  65. package/button-group-item/global/index.d.ts +1 -0
  66. package/button-group-item/global/index.js +2 -0
  67. package/button-group-item/index.d.ts +2 -22
  68. package/button-group-item/index.js +31 -42
  69. package/button-group-item/types.d.ts +22 -3
  70. package/button-group-item/types.js +1 -1
  71. package/card-container/global/index.d.ts +1 -0
  72. package/card-container/global/index.js +2 -0
  73. package/card-container/index.d.ts +1 -21
  74. package/card-container/index.js +8 -5
  75. package/card-container/types.d.ts +21 -1
  76. package/card-container/types.js +1 -1
  77. package/card-v2/global/index.d.ts +1 -0
  78. package/card-v2/global/index.js +2 -0
  79. package/card-v2/index.d.ts +1 -22
  80. package/card-v2/index.js +59 -57
  81. package/card-v2/types.d.ts +21 -1
  82. package/card-v2/types.js +1 -1
  83. package/card-v2-title/global/index.d.ts +1 -0
  84. package/card-v2-title/global/index.js +2 -0
  85. package/card-v2-title/index.d.ts +2 -22
  86. package/card-v2-title/index.js +28 -26
  87. package/card-v2-title/types.d.ts +21 -1
  88. package/card-v2-title/types.js +1 -1
  89. package/checkbox/global/index.d.ts +1 -0
  90. package/checkbox/global/index.js +2 -0
  91. package/checkbox/index.d.ts +1 -22
  92. package/checkbox/index.js +90 -81
  93. package/checkbox/types.d.ts +21 -1
  94. package/checkbox/types.js +1 -1
  95. package/chip/colors.js +1 -1
  96. package/chip/global/index.d.ts +1 -0
  97. package/chip/global/index.js +2 -0
  98. package/chip/index.d.ts +1 -22
  99. package/chip/index.js +64 -75
  100. package/chip/types.d.ts +21 -1
  101. package/chip/types.js +1 -1
  102. package/chip/utils.js +7 -3
  103. package/code-tag/global/index.d.ts +1 -0
  104. package/code-tag/global/index.js +2 -0
  105. package/code-tag/index.d.ts +1 -22
  106. package/code-tag/index.js +17 -14
  107. package/code-tag/types.d.ts +21 -1
  108. package/code-tag/types.js +1 -1
  109. package/color-menu/global/index.d.ts +1 -0
  110. package/color-menu/global/index.js +2 -0
  111. package/color-menu/index.d.ts +2 -22
  112. package/color-menu/index.js +115 -115
  113. package/color-menu/types.d.ts +21 -1
  114. package/color-menu/types.js +1 -1
  115. package/color-menu/utils.js +6 -3
  116. package/color-menu-option/global/index.d.ts +1 -0
  117. package/color-menu-option/global/index.js +2 -0
  118. package/color-menu-option/index.d.ts +1 -22
  119. package/color-menu-option/index.js +30 -26
  120. package/color-menu-option/types.d.ts +21 -1
  121. package/color-menu-option/types.js +1 -1
  122. package/color-menu-option/utils.js +6 -3
  123. package/color-swatch/global/index.d.ts +1 -0
  124. package/color-swatch/global/index.js +2 -0
  125. package/color-swatch/index.d.ts +1 -22
  126. package/color-swatch/index.js +23 -20
  127. package/color-swatch/types.d.ts +21 -1
  128. package/color-swatch/types.js +1 -1
  129. package/color-swatch/utils.js +7 -3
  130. package/date-picker/global/index.d.ts +1 -0
  131. package/date-picker/global/index.js +2 -0
  132. package/date-picker/index.d.ts +2 -22
  133. package/date-picker/index.js +157 -150
  134. package/date-picker/types.d.ts +21 -1
  135. package/date-picker/types.js +1 -1
  136. package/date-picker/utils.js +59 -42
  137. package/dialog/global/index.d.ts +1 -0
  138. package/dialog/global/index.js +2 -0
  139. package/dialog/index.d.ts +1 -22
  140. package/dialog/index.js +71 -58
  141. package/dialog/types.d.ts +21 -1
  142. package/dialog/types.js +1 -1
  143. package/dialog/utils.js +11 -7
  144. package/emoji/global/index.d.ts +1 -0
  145. package/emoji/global/index.js +2 -0
  146. package/emoji/index.d.ts +1 -22
  147. package/emoji/index.js +19 -16
  148. package/emoji/types.d.ts +21 -1
  149. package/emoji/types.js +1 -1
  150. package/emoji/utils.js +22 -17
  151. package/emoji-picker/global/index.d.ts +1 -0
  152. package/emoji-picker/global/index.js +2 -0
  153. package/emoji-picker/index.d.ts +2 -22
  154. package/emoji-picker/index.js +138 -118
  155. package/emoji-picker/types.d.ts +21 -1
  156. package/emoji-picker/types.js +1 -1
  157. package/field/global/index.d.ts +1 -0
  158. package/field/global/index.js +2 -0
  159. package/field/index.d.ts +1 -22
  160. package/field/index.js +63 -60
  161. package/field/types.d.ts +21 -1
  162. package/field/types.js +1 -1
  163. package/file-drop/global/index.d.ts +1 -0
  164. package/file-drop/global/index.js +2 -0
  165. package/file-drop/index.d.ts +1 -22
  166. package/file-drop/index.js +103 -98
  167. package/file-drop/types.d.ts +21 -1
  168. package/file-drop/types.js +1 -1
  169. package/file-drop/utils.js +27 -22
  170. package/file-picker/global/index.d.ts +1 -0
  171. package/file-picker/global/index.js +2 -0
  172. package/file-picker/index.d.ts +1 -22
  173. package/file-picker/index.js +53 -48
  174. package/file-picker/types.d.ts +21 -1
  175. package/file-picker/types.js +1 -1
  176. package/file-picker/utils.js +6 -3
  177. package/file-status/global/index.d.ts +1 -0
  178. package/file-status/global/index.js +2 -0
  179. package/file-status/index.d.ts +2 -22
  180. package/file-status/index.js +33 -22
  181. package/file-status/types.d.ts +21 -1
  182. package/file-status/types.js +1 -1
  183. package/file-status/utils.js +4 -1
  184. package/flag/global/index.d.ts +1 -0
  185. package/flag/global/index.js +2 -0
  186. package/flag/index.d.ts +1 -22
  187. package/flag/index.js +19 -16
  188. package/flag/types.d.ts +21 -1
  189. package/flag/types.js +1 -1
  190. package/flag/utils.js +11 -8
  191. package/grid/global/index.d.ts +1 -0
  192. package/grid/global/index.js +2 -0
  193. package/grid/index.d.ts +1 -22
  194. package/grid/index.js +8 -5
  195. package/grid/types.d.ts +21 -1
  196. package/grid/types.js +1 -1
  197. package/grid-item/global/index.d.ts +1 -0
  198. package/grid-item/global/index.js +2 -0
  199. package/grid-item/index.d.ts +1 -22
  200. package/grid-item/index.js +17 -13
  201. package/grid-item/types.d.ts +21 -1
  202. package/grid-item/types.js +1 -1
  203. package/help-tooltip/global/index.d.ts +1 -0
  204. package/help-tooltip/global/index.js +2 -0
  205. package/help-tooltip/index.d.ts +1 -22
  206. package/help-tooltip/index.js +29 -26
  207. package/help-tooltip/types.d.ts +21 -1
  208. package/help-tooltip/types.js +1 -1
  209. package/icon/generated-icon-type.js +1 -1
  210. package/icon/global/index.d.ts +1 -0
  211. package/icon/global/index.js +2 -0
  212. package/icon/index.d.ts +1 -22
  213. package/icon/index.js +30 -28
  214. package/icon/types.d.ts +21 -1
  215. package/icon/types.js +1 -1
  216. package/inline-alert/global/index.d.ts +1 -0
  217. package/inline-alert/global/index.js +2 -0
  218. package/inline-alert/index.d.ts +2 -22
  219. package/inline-alert/index.js +58 -39
  220. package/inline-alert/types.d.ts +21 -1
  221. package/inline-alert/types.js +1 -1
  222. package/inline-alert/utils.js +4 -1
  223. package/input/global/index.d.ts +1 -0
  224. package/input/global/index.js +2 -0
  225. package/input/index.d.ts +2 -22
  226. package/input/index.js +295 -317
  227. package/input/types.d.ts +21 -1
  228. package/input/types.js +1 -1
  229. package/input/utils.js +56 -46
  230. package/link/global/index.d.ts +1 -0
  231. package/link/global/index.js +2 -0
  232. package/link/index.d.ts +1 -22
  233. package/link/index.js +88 -79
  234. package/link/types.d.ts +21 -1
  235. package/link/types.js +1 -1
  236. package/list/global/index.d.ts +1 -0
  237. package/list/global/index.js +2 -0
  238. package/list/index.d.ts +1 -21
  239. package/list/index.js +9 -6
  240. package/list/types.d.ts +21 -1
  241. package/list/types.js +1 -1
  242. package/list-item/global/index.d.ts +1 -0
  243. package/list-item/global/index.js +2 -0
  244. package/list-item/index.d.ts +1 -22
  245. package/list-item/index.js +9 -6
  246. package/list-item/types.d.ts +21 -1
  247. package/list-item/types.js +1 -1
  248. package/package.json +11 -5
  249. package/pagination/global/index.d.ts +1 -0
  250. package/pagination/global/index.js +2 -0
  251. package/pagination/index.d.ts +2 -22
  252. package/pagination/index.js +64 -46
  253. package/pagination/types.d.ts +21 -1
  254. package/pagination/types.js +1 -1
  255. package/persistent-overlay/global/index.d.ts +1 -0
  256. package/persistent-overlay/global/index.js +2 -0
  257. package/persistent-overlay/index.d.ts +1 -22
  258. package/persistent-overlay/index.js +42 -44
  259. package/persistent-overlay/types.d.ts +21 -1
  260. package/persistent-overlay/types.js +1 -1
  261. package/pop/global/index.d.ts +1 -0
  262. package/pop/global/index.js +2 -0
  263. package/pop/index.d.ts +3 -22
  264. package/pop/index.js +149 -150
  265. package/pop/types.d.ts +21 -1
  266. package/pop/types.js +1 -1
  267. package/pop/utils.js +24 -8
  268. package/popover/global/index.d.ts +1 -0
  269. package/popover/global/index.js +2 -0
  270. package/popover/index.d.ts +2 -22
  271. package/popover/index.js +104 -67
  272. package/popover/types.d.ts +21 -1
  273. package/popover/types.js +1 -1
  274. package/popover/utils.js +18 -7
  275. package/progress/global/index.d.ts +1 -0
  276. package/progress/global/index.js +2 -0
  277. package/progress/index.d.ts +1 -22
  278. package/progress/index.js +31 -33
  279. package/progress/types.d.ts +21 -1
  280. package/progress/types.js +1 -1
  281. package/progress-stepper/global/index.d.ts +1 -0
  282. package/progress-stepper/global/index.js +2 -0
  283. package/progress-stepper/index.d.ts +2 -22
  284. package/progress-stepper/index.js +64 -66
  285. package/progress-stepper/types.d.ts +21 -1
  286. package/progress-stepper/types.js +1 -1
  287. package/progress-stepper-item/global/index.d.ts +1 -0
  288. package/progress-stepper-item/global/index.js +2 -0
  289. package/progress-stepper-item/index.d.ts +1 -22
  290. package/progress-stepper-item/index.js +58 -50
  291. package/progress-stepper-item/types.d.ts +21 -1
  292. package/progress-stepper-item/types.js +1 -1
  293. package/progress-stepper-item/utils.js +22 -11
  294. package/radio/global/index.d.ts +1 -0
  295. package/radio/global/index.js +2 -0
  296. package/radio/index.d.ts +1 -22
  297. package/radio/index.js +79 -83
  298. package/radio/types.d.ts +21 -1
  299. package/radio/types.js +1 -1
  300. package/radio-option/global/index.d.ts +1 -0
  301. package/radio-option/global/index.js +2 -0
  302. package/radio-option/index.d.ts +1 -22
  303. package/radio-option/index.js +47 -41
  304. package/radio-option/types.d.ts +21 -1
  305. package/radio-option/types.js +1 -1
  306. package/rich-text/global/index.d.ts +1 -0
  307. package/rich-text/global/index.js +2 -0
  308. package/rich-text/index.d.ts +1 -22
  309. package/rich-text/index.js +45 -46
  310. package/rich-text/types.d.ts +21 -1
  311. package/rich-text/types.js +1 -1
  312. package/rich-text/utils.js +31 -33
  313. package/rich-textarea/global/index.d.ts +1 -0
  314. package/rich-textarea/global/index.js +2 -0
  315. package/rich-textarea/index.d.ts +1 -22
  316. package/rich-textarea/index.js +201 -194
  317. package/rich-textarea/types.d.ts +21 -1
  318. package/rich-textarea/types.js +1 -1
  319. package/rich-textarea/utils.js +313 -340
  320. package/segment-collapse/global/index.d.ts +1 -0
  321. package/segment-collapse/global/index.js +2 -0
  322. package/segment-collapse/index.d.ts +1 -22
  323. package/segment-collapse/index.js +31 -25
  324. package/segment-collapse/types.d.ts +21 -1
  325. package/segment-collapse/types.js +1 -1
  326. package/segmented-control/global/index.d.ts +1 -0
  327. package/segmented-control/global/index.js +2 -0
  328. package/segmented-control/index.d.ts +1 -22
  329. package/segmented-control/index.js +45 -45
  330. package/segmented-control/types.d.ts +21 -1
  331. package/segmented-control/types.js +1 -1
  332. package/segmented-control-option/global/index.d.ts +1 -0
  333. package/segmented-control-option/global/index.js +2 -0
  334. package/segmented-control-option/index.d.ts +1 -22
  335. package/segmented-control-option/index.js +44 -46
  336. package/segmented-control-option/types.d.ts +21 -1
  337. package/segmented-control-option/types.js +1 -1
  338. package/segmented-icon-control/global/index.d.ts +1 -0
  339. package/segmented-icon-control/global/index.js +2 -0
  340. package/segmented-icon-control/index.d.ts +1 -22
  341. package/segmented-icon-control/index.js +51 -50
  342. package/segmented-icon-control/types.d.ts +21 -1
  343. package/segmented-icon-control/types.js +1 -1
  344. package/segmented-icon-control-option/global/index.d.ts +1 -0
  345. package/segmented-icon-control-option/global/index.js +2 -0
  346. package/segmented-icon-control-option/index.d.ts +1 -22
  347. package/segmented-icon-control-option/index.js +36 -37
  348. package/segmented-icon-control-option/types.d.ts +21 -1
  349. package/segmented-icon-control-option/types.js +1 -1
  350. package/select-button/global/index.d.ts +1 -0
  351. package/select-button/global/index.js +2 -0
  352. package/select-button/index.d.ts +1 -26
  353. package/select-button/index.js +104 -112
  354. package/select-button/types.d.ts +25 -1
  355. package/select-button/types.js +1 -1
  356. package/select-menu/global/index.d.ts +1 -0
  357. package/select-menu/global/index.js +2 -0
  358. package/select-menu/index.d.ts +1 -22
  359. package/select-menu/index.js +201 -164
  360. package/select-menu/types.d.ts +21 -1
  361. package/select-menu/types.js +1 -1
  362. package/select-menu-option/global/index.d.ts +1 -0
  363. package/select-menu-option/global/index.js +2 -0
  364. package/select-menu-option/index.d.ts +1 -22
  365. package/select-menu-option/index.js +42 -33
  366. package/select-menu-option/types.d.ts +21 -1
  367. package/select-menu-option/types.js +1 -1
  368. package/select-menu-option/utils.js +4 -1
  369. package/skeleton/global/index.d.ts +1 -0
  370. package/skeleton/global/index.js +2 -0
  371. package/skeleton/index.d.ts +1 -22
  372. package/skeleton/index.js +35 -38
  373. package/skeleton/types.d.ts +21 -1
  374. package/skeleton/types.js +1 -1
  375. package/skeleton-item/global/index.d.ts +1 -0
  376. package/skeleton-item/global/index.js +2 -0
  377. package/skeleton-item/index.d.ts +1 -22
  378. package/skeleton-item/index.js +8 -5
  379. package/skeleton-item/types.d.ts +21 -1
  380. package/skeleton-item/types.js +1 -1
  381. package/spinner/global/index.d.ts +1 -0
  382. package/spinner/global/index.js +2 -0
  383. package/spinner/index.d.ts +1 -22
  384. package/spinner/index.js +31 -29
  385. package/spinner/types.d.ts +21 -1
  386. package/spinner/types.js +1 -1
  387. package/standalone.d.ts +0 -8
  388. package/standalone.js +79 -87
  389. package/standalone.ts +0 -8
  390. package/stop-events/index.js +12 -12
  391. package/table/global/index.d.ts +1 -0
  392. package/table/global/index.js +2 -0
  393. package/table/index.d.ts +1 -21
  394. package/table/index.js +9 -6
  395. package/table/types.d.ts +21 -1
  396. package/table/types.js +1 -1
  397. package/table-body/global/index.d.ts +1 -0
  398. package/table-body/global/index.js +2 -0
  399. package/table-body/index.d.ts +1 -21
  400. package/table-body/index.js +9 -6
  401. package/table-body/types.d.ts +21 -1
  402. package/table-body/types.js +1 -1
  403. package/table-cell/global/index.d.ts +1 -0
  404. package/table-cell/global/index.js +2 -0
  405. package/table-cell/index.d.ts +2 -22
  406. package/table-cell/index.js +13 -9
  407. package/table-cell/types.d.ts +21 -1
  408. package/table-cell/types.js +1 -1
  409. package/table-cell/utils.js +4 -1
  410. package/table-head/global/index.d.ts +1 -0
  411. package/table-head/global/index.js +2 -0
  412. package/table-head/index.d.ts +1 -21
  413. package/table-head/index.js +9 -6
  414. package/table-head/types.d.ts +21 -1
  415. package/table-head/types.js +1 -1
  416. package/table-head-cell/global/index.d.ts +1 -0
  417. package/table-head-cell/global/index.js +2 -0
  418. package/table-head-cell/index.d.ts +1 -22
  419. package/table-head-cell/index.js +29 -27
  420. package/table-head-cell/types.d.ts +21 -1
  421. package/table-head-cell/types.js +1 -1
  422. package/table-row/global/index.d.ts +1 -0
  423. package/table-row/global/index.js +2 -0
  424. package/table-row/index.d.ts +1 -22
  425. package/table-row/index.js +20 -17
  426. package/table-row/types.d.ts +21 -1
  427. package/table-row/types.js +1 -1
  428. package/tabs/global/index.d.ts +1 -0
  429. package/tabs/global/index.js +2 -0
  430. package/tabs/index.d.ts +2 -22
  431. package/tabs/index.js +32 -35
  432. package/tabs/types.d.ts +21 -1
  433. package/tabs/types.js +1 -1
  434. package/tabs-icon-option/global/index.d.ts +1 -0
  435. package/tabs-icon-option/global/index.js +2 -0
  436. package/tabs-icon-option/index.d.ts +1 -22
  437. package/tabs-icon-option/index.js +38 -40
  438. package/tabs-icon-option/types.d.ts +21 -1
  439. package/tabs-icon-option/types.js +1 -1
  440. package/tabs-option/global/index.d.ts +1 -0
  441. package/tabs-option/global/index.js +2 -0
  442. package/tabs-option/index.d.ts +1 -22
  443. package/tabs-option/index.js +41 -43
  444. package/tabs-option/types.d.ts +21 -1
  445. package/tabs-option/types.js +1 -1
  446. package/tag/colors.js +1 -1
  447. package/tag/global/index.d.ts +1 -0
  448. package/tag/global/index.js +2 -0
  449. package/tag/index.d.ts +1 -22
  450. package/tag/index.js +45 -44
  451. package/tag/types.d.ts +21 -1
  452. package/tag/types.js +1 -1
  453. package/tag/utils.js +7 -3
  454. package/text/global/index.d.ts +1 -0
  455. package/text/global/index.js +2 -0
  456. package/text/index.d.ts +2 -22
  457. package/text/index.js +33 -28
  458. package/text/types.d.ts +21 -1
  459. package/text/types.js +1 -1
  460. package/text/utils.js +4 -1
  461. package/textarea/global/index.d.ts +1 -0
  462. package/textarea/global/index.js +2 -0
  463. package/textarea/index.d.ts +1 -22
  464. package/textarea/index.js +147 -152
  465. package/textarea/types.d.ts +21 -1
  466. package/textarea/types.js +1 -1
  467. package/time-picker/global/index.d.ts +1 -0
  468. package/time-picker/global/index.js +2 -0
  469. package/time-picker/index.d.ts +2 -22
  470. package/time-picker/index.js +119 -123
  471. package/time-picker/types.d.ts +21 -1
  472. package/time-picker/types.js +1 -1
  473. package/time-picker/utils.js +31 -33
  474. package/title/global/index.d.ts +1 -0
  475. package/title/global/index.js +2 -0
  476. package/title/index.d.ts +2 -22
  477. package/title/index.js +32 -31
  478. package/title/types.d.ts +21 -1
  479. package/title/types.js +1 -1
  480. package/title/utils.js +18 -14
  481. package/toast/global/index.d.ts +1 -0
  482. package/toast/global/index.js +2 -0
  483. package/toast/index.d.ts +2 -22
  484. package/toast/index.js +37 -34
  485. package/toast/types.d.ts +21 -1
  486. package/toast/types.js +1 -1
  487. package/toast/utils.js +4 -1
  488. package/toast-manager/global/index.d.ts +1 -0
  489. package/toast-manager/global/index.js +2 -0
  490. package/toast-manager/index.d.ts +3 -22
  491. package/toast-manager/index.js +77 -63
  492. package/toast-manager/types.d.ts +21 -1
  493. package/toast-manager/types.js +1 -1
  494. package/toast-manager/utils.js +4 -1
  495. package/toggle/global/index.d.ts +1 -0
  496. package/toggle/global/index.js +2 -0
  497. package/toggle/index.d.ts +1 -22
  498. package/toggle/index.js +81 -75
  499. package/toggle/types.d.ts +21 -1
  500. package/toggle/types.js +1 -1
  501. package/tooltip/global/index.d.ts +1 -0
  502. package/tooltip/global/index.js +2 -0
  503. package/tooltip/index.d.ts +3 -22
  504. package/tooltip/index.js +105 -93
  505. package/tooltip/tooltip-state.js +56 -64
  506. package/tooltip/types.d.ts +21 -1
  507. package/tooltip/types.js +1 -1
  508. package/tooltip/utils.js +32 -13
  509. package/types.d.ts +12 -29
  510. package/utils/adapters.js +1 -1
  511. package/utils/component-names.d.ts +3 -0
  512. package/utils/component-names.js +85 -0
  513. package/utils/context.js +32 -42
  514. package/utils/countries.js +490 -2
  515. package/utils/csv.js +13 -6
  516. package/utils/debounce.js +10 -3
  517. package/utils/dom.js +60 -53
  518. package/utils/element.d.ts +107 -15
  519. package/utils/element.js +100 -19
  520. package/utils/event-target.js +11 -5
  521. package/utils/form.js +17 -12
  522. package/utils/get-react-event-handler.js +6 -3
  523. package/utils/global-components-constants.d.ts +3 -0
  524. package/utils/global-components-constants.js +8 -0
  525. package/utils/global-components-manager.d.ts +71 -0
  526. package/utils/global-components-manager.js +24 -0
  527. package/utils/index.js +65 -12
  528. package/utils/markdown.js +56 -43
  529. package/utils/rect.js +13 -18
  530. package/utils/shared/global-elements-manager.d.js +1 -0
  531. package/utils/shared/global-elements-manager.d.ts +62 -0
  532. package/utils/shared/global-elements-manager.js +163 -0
  533. package/utils/shared/global-elements-store.d.js +1 -0
  534. package/utils/shared/global-elements-store.d.ts +12 -0
  535. package/utils/shared/global-elements-store.js +31 -0
  536. package/utils/shared/index.d.js +11 -0
  537. package/utils/shared/index.d.ts +3 -0
  538. package/utils/shared/index.js +11 -0
  539. package/utils/shared/nectary-element-base.d.js +1 -0
  540. package/utils/shared/nectary-element-base.d.ts +9 -0
  541. package/utils/shared/nectary-element-base.js +25 -0
  542. package/utils/shared/package.json +9 -0
  543. package/utils/shared/tsconfig.json +20 -0
  544. package/utils/size.js +8 -3
  545. package/utils/slot.js +13 -9
  546. package/utils/throttle.js +5 -2
  547. package/utils/uid.js +5 -2
  548. package/card/index.d.ts +0 -40
  549. package/card/index.js +0 -134
  550. package/card/types.d.ts +0 -17
  551. package/card/types.js +0 -1
  552. package/horizontal-stepper/index.d.ts +0 -33
  553. package/horizontal-stepper/index.js +0 -62
  554. package/horizontal-stepper/types.d.ts +0 -42
  555. package/horizontal-stepper/types.js +0 -1
  556. package/horizontal-stepper-item/index.d.ts +0 -38
  557. package/horizontal-stepper-item/index.js +0 -62
  558. package/horizontal-stepper-item/types.d.ts +0 -38
  559. package/horizontal-stepper-item/types.js +0 -1
  560. package/horizontal-stepper-item/utils.d.ts +0 -2
  561. package/horizontal-stepper-item/utils.js +0 -1
  562. package/segment/index.d.ts +0 -40
  563. package/segment/index.js +0 -110
  564. package/segment/types.d.ts +0 -23
  565. package/segment/types.js +0 -1
  566. package/segment/utils.d.ts +0 -3
  567. package/segment/utils.js +0 -16
  568. package/tile-control/index.d.ts +0 -39
  569. package/tile-control/index.js +0 -111
  570. package/tile-control/types.d.ts +0 -29
  571. package/tile-control/types.js +0 -1
  572. package/tile-control-option/index.d.ts +0 -40
  573. package/tile-control-option/index.js +0 -99
  574. package/tile-control-option/types.d.ts +0 -52
  575. package/tile-control-option/types.js +0 -1
  576. package/vertical-stepper/index.d.ts +0 -33
  577. package/vertical-stepper/index.js +0 -58
  578. package/vertical-stepper/types.d.ts +0 -34
  579. package/vertical-stepper/types.js +0 -1
  580. package/vertical-stepper-item/index.d.ts +0 -38
  581. package/vertical-stepper-item/index.js +0 -62
  582. package/vertical-stepper-item/types.d.ts +0 -42
  583. package/vertical-stepper-item/types.js +0 -1
  584. package/vertical-stepper-item/utils.d.ts +0 -2
  585. package/vertical-stepper-item/utils.js +0 -1
package/segment/index.js DELETED
@@ -1,110 +0,0 @@
1
- import '../title';
2
- import { getTitleLevelFromType } from '../title/utils';
3
- import { defineCustomElement, getAttribute, getBooleanAttribute, getLiteralAttribute, getRect, isAttrEqual, isAttrTrue, NectaryElement, setClass, updateAttribute, updateBooleanAttribute, updateLiteralAttribute } from '../utils';
4
- import { DEFAULT_SIZE, sizeValues } from '../utils/size';
5
- const templateHTML = '<style>:host{display:block}#wrapper{display:flex;flex-direction:column;gap:12px;width:100%;height:100%;border:1px solid var(--sinch-comp-segment-color-default-border-initial);border-radius:var(--sinch-comp-segment-shape-radius);box-sizing:border-box;background-color:var(--sinch-comp-segment-color-default-background-initial);padding:8px 0 16px}#header{display:flex;flex-direction:row;align-items:center;height:48px;gap:8px;padding:0 24px}#icon{--sinch-global-size-icon:32px}#caption{min-width:1em;--sinch-comp-title-font:var(--sinch-comp-segment-font-size-m-title)}:host([size="l"]) #caption{--sinch-comp-title-font:var(--sinch-comp-segment-font-size-l-title)}:host([size="s"]) #caption{--sinch-comp-title-font:var(--sinch-comp-segment-font-size-s-title)}#info{display:flex;flex-direction:row;align-items:center;gap:8px;margin-left:auto;align-self:stretch}#info.empty{display:none}#preview{flex:1;flex-basis:auto;height:48px;min-width:0;overflow:hidden;margin-left:24px}#preview.empty{display:none}#info.empty+#collapse{margin-left:auto}#collapse.empty{display:none}#preview:not(.empty)+#info.empty+#collapse:not(.empty),#preview:not(.empty)+#info:not(.empty){margin-left:24px}#content-wrapper{flex:1;min-height:0;overflow-y:auto;padding:4px 24px}#action{display:flex;flex-direction:row;justify-content:flex-end;gap:16px;padding:0 24px}#action.empty{display:none}:host([collapsed]) :is(#content-wrapper,#action){display:none}:host([collapsed]) #wrapper{padding-bottom:8px}::slotted([slot=icon]){margin-right:8px}</style><div id="wrapper"><div id="header"><slot id="icon" name="icon"></slot><sinch-title id="caption" level="3" type="m" ellipsis></sinch-title><div id="preview"><slot name="preview"></slot></div><div id="info"><slot name="info"></slot></div><div id="collapse"><slot name="collapse"></slot></div></div><div id="content-wrapper"><slot name="content"></slot></div><div id="action"><slot name="action"></slot></div></div>';
6
- import { getTitleTypeFromSize } from './utils';
7
- const template = document.createElement('template');
8
- template.innerHTML = templateHTML;
9
- export class Segment extends NectaryElement {
10
- #$caption;
11
- #$previewSlot;
12
- #$previewWrapper;
13
- #$infoSlot;
14
- #$infoWrapper;
15
- #$collapseSlot;
16
- #$collapseWrapper;
17
- #$actionSlot;
18
- #$actionWrapper;
19
- constructor() {
20
- super();
21
- const shadowRoot = this.attachShadow();
22
- shadowRoot.appendChild(template.content.cloneNode(true));
23
- this.#$caption = shadowRoot.querySelector('#caption');
24
- this.#$previewSlot = shadowRoot.querySelector('slot[name="preview"]');
25
- this.#$infoSlot = shadowRoot.querySelector('slot[name="info"]');
26
- this.#$collapseSlot = shadowRoot.querySelector('slot[name="collapse"]');
27
- this.#$actionSlot = shadowRoot.querySelector('slot[name="action"]');
28
- this.#$previewWrapper = shadowRoot.querySelector('#preview');
29
- this.#$infoWrapper = shadowRoot.querySelector('#info');
30
- this.#$collapseWrapper = shadowRoot.querySelector('#collapse');
31
- this.#$actionWrapper = shadowRoot.querySelector('#action');
32
- }
33
- connectedCallback() {
34
- this.#$previewSlot.addEventListener('slotchange', this.#onPreviewSlotChange);
35
- this.#$infoSlot.addEventListener('slotchange', this.#onInfoSlotChange);
36
- this.#$collapseSlot.addEventListener('slotchange', this.#onCollapseSlotChange);
37
- this.#$actionSlot.addEventListener('slotchange', this.#onActionSlotChange);
38
- this.#onPreviewSlotChange();
39
- this.#onInfoSlotChange();
40
- this.#onCollapseSlotChange();
41
- this.#onActionSlotChange();
42
- }
43
- disconnectedCallback() {
44
- this.#$previewSlot.removeEventListener('slotchange', this.#onPreviewSlotChange);
45
- this.#$infoSlot.removeEventListener('slotchange', this.#onInfoSlotChange);
46
- this.#$collapseSlot.removeEventListener('slotchange', this.#onCollapseSlotChange);
47
- this.#$actionSlot.removeEventListener('slotchange', this.#onActionSlotChange);
48
- }
49
- static get observedAttributes() {
50
- return ['caption', 'collapsed', 'size'];
51
- }
52
- attributeChangedCallback(name, oldVal, newVal) {
53
- switch (name) {
54
- case 'caption':
55
- {
56
- updateAttribute(this.#$caption, 'text', newVal);
57
- break;
58
- }
59
- case 'collapsed':
60
- {
61
- if (isAttrEqual(oldVal, newVal)) {
62
- return;
63
- }
64
- updateBooleanAttribute(this, name, isAttrTrue(newVal));
65
- break;
66
- }
67
- case 'size':
68
- {
69
- const titleType = getTitleTypeFromSize(this.size);
70
- updateAttribute(this.#$caption, 'level', getTitleLevelFromType(titleType));
71
- break;
72
- }
73
- }
74
- }
75
- set caption(caption) {
76
- updateAttribute(this, 'caption', caption);
77
- }
78
- get caption() {
79
- return getAttribute(this, 'caption', '');
80
- }
81
- set collapsed(isChecked) {
82
- updateBooleanAttribute(this, 'collapsed', isChecked);
83
- }
84
- get collapsed() {
85
- return getBooleanAttribute(this, 'collapsed');
86
- }
87
- get size() {
88
- return getLiteralAttribute(this, sizeValues, 'size', DEFAULT_SIZE);
89
- }
90
- set size(value) {
91
- updateLiteralAttribute(this, sizeValues, 'size', value);
92
- }
93
- get collapseButtonRect() {
94
- const $collapseButton = this.#$collapseSlot.assignedElements()[0];
95
- return $collapseButton != null ? getRect($collapseButton) : null;
96
- }
97
- #onPreviewSlotChange = () => {
98
- setClass(this.#$previewWrapper, 'empty', this.#$previewSlot.assignedElements().length === 0);
99
- };
100
- #onInfoSlotChange = () => {
101
- setClass(this.#$infoWrapper, 'empty', this.#$infoSlot.assignedElements().length === 0);
102
- };
103
- #onCollapseSlotChange = () => {
104
- setClass(this.#$collapseWrapper, 'empty', this.#$collapseSlot.assignedElements().length === 0);
105
- };
106
- #onActionSlotChange = () => {
107
- setClass(this.#$actionWrapper, 'empty', this.#$actionSlot.assignedElements().length === 0);
108
- };
109
- }
110
- defineCustomElement('sinch-segment', Segment);
@@ -1,23 +0,0 @@
1
- import type { NectaryComponentReactByType, NectaryComponentVanillaByType, TRect } from '../types';
2
- import type { TSinchSize } from '../utils/size';
3
- export type TSinchSegmentProps = {
4
- caption: string;
5
- collapsed?: boolean;
6
- size?: TSinchSize;
7
- readonly collapseButtonRect?: TRect | null;
8
- };
9
- export type TSinchSegmentStyle = {
10
- '--sinch-comp-segment-shape-radius'?: string;
11
- '--sinch-comp-segment-color-default-border-initial'?: string;
12
- '--sinch-comp-segment-color-default-background-initial'?: string;
13
- '--sinch-comp-segment-font-size-m-title'?: string;
14
- '--sinch-comp-segment-font-size-l-title'?: string;
15
- '--sinch-comp-segment-font-size-s-title'?: string;
16
- '--sinch-global-size-icon'?: string;
17
- };
18
- export type TSinchSegment = {
19
- props: TSinchSegmentProps;
20
- style: TSinchSegmentStyle;
21
- };
22
- export type TSinchSegmentElement = NectaryComponentVanillaByType<TSinchSegment>;
23
- export type TSinchSegmentReact = NectaryComponentReactByType<TSinchSegment>;
package/segment/types.js DELETED
@@ -1 +0,0 @@
1
- export {};
@@ -1,3 +0,0 @@
1
- import type { TSinchTitleType } from '../title/types';
2
- import type { TSinchSize } from '../utils/size';
3
- export declare const getTitleTypeFromSize: (size: TSinchSize) => TSinchTitleType;
package/segment/utils.js DELETED
@@ -1,16 +0,0 @@
1
- export const getTitleTypeFromSize = size => {
2
- switch (size) {
3
- case 'l':
4
- {
5
- return 'l';
6
- }
7
- case 's':
8
- {
9
- return 's';
10
- }
11
- default:
12
- {
13
- return 'm';
14
- }
15
- }
16
- };
@@ -1,39 +0,0 @@
1
- import { NectaryElement } from '../utils';
2
- import type { TSinchTileControl } from './types';
3
- import type { NectaryComponentVanilla, NectaryComponentReact } from '../types';
4
- export declare class TileControl extends NectaryElement {
5
- #private;
6
- constructor();
7
- connectedCallback(): void;
8
- disconnectedCallback(): void;
9
- static get observedAttributes(): string[];
10
- attributeChangedCallback(name: string, oldVal: string | null, newVal: string | null): void;
11
- set value(value: string);
12
- get value(): string;
13
- set small(isSmall: boolean);
14
- get small(): boolean;
15
- set multiple(isMultiple: boolean);
16
- get multiple(): boolean;
17
- set cols(value: number);
18
- get cols(): number;
19
- }
20
- declare global {
21
- interface NectaryComponentMap {
22
- 'sinch-tile-control': TSinchTileControl;
23
- }
24
- interface HTMLElementTagNameMap {
25
- 'sinch-tile-control': NectaryComponentVanilla<'sinch-tile-control'>;
26
- }
27
- namespace JSX {
28
- interface IntrinsicElements {
29
- 'sinch-tile-control': NectaryComponentReact<'sinch-tile-control'>;
30
- }
31
- }
32
- }
33
- declare module 'react' {
34
- namespace JSX {
35
- interface IntrinsicElements extends globalThis.JSX.IntrinsicElements {
36
- 'sinch-tile-control': NectaryComponentReact<'sinch-tile-control'>;
37
- }
38
- }
39
- }
@@ -1,111 +0,0 @@
1
- import { defineCustomElement, getAttribute, getBooleanAttribute, unpackCsv, getFirstCsvValue, getIntegerAttribute, getReactEventHandler, NectaryElement, updateAttribute, updateBooleanAttribute, updateCsv, updateIntegerAttribute, isAttrTrue, isAttrEqual } from '../utils';
2
- const templateHTML = '<style>:host{display:block;outline:0;--sinch-grid-num-columns:1}#wrapper{display:grid;grid-template-columns:repeat(var(--sinch-grid-num-columns),auto);gap:16px;width:fit-content}:host([small]) #wrapper{gap:8px}:host([cols="2"]){--sinch-grid-num-columns:2}:host([cols="3"]){--sinch-grid-num-columns:3}:host([cols="4"]){--sinch-grid-num-columns:4}:host([cols="5"]){--sinch-grid-num-columns:5}:host([cols="6"]){--sinch-grid-num-columns:6}:host([cols="7"]){--sinch-grid-num-columns:7}:host([cols="8"]){--sinch-grid-num-columns:8}:host([cols="9"]){--sinch-grid-num-columns:9}:host([cols="10"]){--sinch-grid-num-columns:10}</style><div id="wrapper"><slot></slot></div>';
3
- const template = document.createElement('template');
4
- template.innerHTML = templateHTML;
5
- export class TileControl extends NectaryElement {
6
- #$slot;
7
- constructor() {
8
- super();
9
- const shadowRoot = this.attachShadow();
10
- shadowRoot.appendChild(template.content.cloneNode(true));
11
- this.#$slot = shadowRoot.querySelector('slot');
12
- }
13
- connectedCallback() {
14
- this.setAttribute('role', 'tablist');
15
- this.#$slot.addEventListener('option-change', this.#onOptionChange);
16
- this.#$slot.addEventListener('slotchange', this.#onSlotChange);
17
- this.addEventListener('-change', this.#onChangeReactHandler);
18
- }
19
- disconnectedCallback() {
20
- this.#$slot.removeEventListener('option-change', this.#onOptionChange);
21
- this.#$slot.removeEventListener('slotchange', this.#onSlotChange);
22
- this.removeEventListener('-change', this.#onChangeReactHandler);
23
- }
24
- static get observedAttributes() {
25
- return ['value', 'small', 'multiple'];
26
- }
27
- attributeChangedCallback(name, oldVal, newVal) {
28
- if (isAttrEqual(oldVal, newVal)) {
29
- return;
30
- }
31
- switch (name) {
32
- case 'value':
33
- {
34
- this.#onValueChange(newVal ?? '');
35
- break;
36
- }
37
- case 'small':
38
- {
39
- this.#onSmallChange();
40
- updateBooleanAttribute(this, name, isAttrTrue(newVal));
41
- break;
42
- }
43
- case 'multiple':
44
- {
45
- this.#onValueChange(this.value);
46
- }
47
- }
48
- }
49
- set value(value) {
50
- updateAttribute(this, 'value', value);
51
- }
52
- get value() {
53
- return getAttribute(this, 'value', '');
54
- }
55
- set small(isSmall) {
56
- updateBooleanAttribute(this, 'small', isSmall);
57
- }
58
- get small() {
59
- return getBooleanAttribute(this, 'small');
60
- }
61
- set multiple(isMultiple) {
62
- updateBooleanAttribute(this, 'multiple', isMultiple);
63
- }
64
- get multiple() {
65
- return getBooleanAttribute(this, 'multiple');
66
- }
67
- set cols(value) {
68
- updateIntegerAttribute(this, 'cols', value);
69
- }
70
- get cols() {
71
- return getIntegerAttribute(this, 'cols', 1);
72
- }
73
- #onSlotChange = () => {
74
- this.#onValueChange(this.value);
75
- this.#onSmallChange();
76
- };
77
- #onOptionChange = e => {
78
- e.stopPropagation();
79
- const $elem = e.target;
80
- const value = e.detail;
81
- const detail = this.multiple ? updateCsv(this.value, value, !getBooleanAttribute($elem, 'data-checked')) : value;
82
- this.dispatchEvent(new CustomEvent('-change', {
83
- detail
84
- }));
85
- };
86
- #onValueChange(csv) {
87
- if (this.multiple) {
88
- const values = unpackCsv(csv);
89
- for (const $option of this.#$slot.assignedElements()) {
90
- const isChecked = !getBooleanAttribute($option, 'disabled') && values.includes(getAttribute($option, 'value', ''));
91
- updateBooleanAttribute($option, 'data-checked', isChecked);
92
- }
93
- } else {
94
- const value = getFirstCsvValue(csv);
95
- for (const $option of this.#$slot.assignedElements()) {
96
- const isChecked = !getBooleanAttribute($option, 'disabled') && value === getAttribute($option, 'value', '');
97
- updateBooleanAttribute($option, 'data-checked', isChecked);
98
- }
99
- }
100
- }
101
- #onSmallChange() {
102
- const isSmall = this.small;
103
- for (const $opt of this.#$slot.assignedElements()) {
104
- updateBooleanAttribute($opt, 'data-small', isSmall);
105
- }
106
- }
107
- #onChangeReactHandler = e => {
108
- getReactEventHandler(this, 'on-change')?.(e);
109
- };
110
- }
111
- defineCustomElement('sinch-tile-control', TileControl);
@@ -1,29 +0,0 @@
1
- import type { NectaryComponentReactByType, NectaryComponentVanillaByType } from '../types';
2
- /** Number of coumns from 1 to 10 */
3
- export type TSinchTileControlColumns = 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | number;
4
- export type TSinchTileControlProps = {
5
- /** Value */
6
- value: string;
7
- /** Multiple */
8
- multiple?: boolean;
9
- /** Small */
10
- small?: boolean;
11
- /** Number of columns from 1 to 10 */
12
- cols: TSinchTileControlColumns;
13
- /** Label that is used for a11y */
14
- 'aria-label': string;
15
- };
16
- export type TSinchTileControlEvents = {
17
- /** Change value handler */
18
- '-change'?: (e: CustomEvent<string>) => void;
19
- };
20
- export type TSinchTileControlStyle = {
21
- '--sinch-grid-num-columns'?: string;
22
- };
23
- export type TSinchTileControl = {
24
- props: TSinchTileControlProps;
25
- events: TSinchTileControlEvents;
26
- style: TSinchTileControlStyle;
27
- };
28
- export type TSinchTileControlElement = NectaryComponentVanillaByType<TSinchTileControl>;
29
- export type TSinchTileControlReact = NectaryComponentReactByType<TSinchTileControl>;
@@ -1 +0,0 @@
1
- export {};
@@ -1,40 +0,0 @@
1
- import { NectaryElement } from '../utils';
2
- import type { TSinchTileControlOption } from './types';
3
- import type { NectaryComponentReact, NectaryComponentVanilla } from '../types';
4
- export declare class TileControlOption extends NectaryElement {
5
- #private;
6
- constructor();
7
- connectedCallback(): void;
8
- disconnectedCallback(): void;
9
- static get observedAttributes(): string[];
10
- attributeChangedCallback(name: string, oldVal: string | null, newVal: string | null): void;
11
- set value(value: string);
12
- get value(): string;
13
- set disabled(isDisabled: boolean);
14
- get disabled(): boolean;
15
- set text(value: string);
16
- get text(): string;
17
- get focusable(): boolean;
18
- focus(): void;
19
- blur(): void;
20
- }
21
- declare global {
22
- interface NectaryComponentMap {
23
- 'sinch-tile-control-option': TSinchTileControlOption;
24
- }
25
- interface HTMLElementTagNameMap {
26
- 'sinch-tile-control-option': NectaryComponentVanilla<'sinch-tile-control-option'>;
27
- }
28
- namespace JSX {
29
- interface IntrinsicElements {
30
- 'sinch-tile-control-option': NectaryComponentReact<'sinch-tile-control-option'>;
31
- }
32
- }
33
- }
34
- declare module 'react' {
35
- namespace JSX {
36
- interface IntrinsicElements extends globalThis.JSX.IntrinsicElements {
37
- 'sinch-tile-control-option': NectaryComponentReact<'sinch-tile-control-option'>;
38
- }
39
- }
40
- }
@@ -1,99 +0,0 @@
1
- import { defineCustomElement, getAttribute, getBooleanAttribute, getReactEventHandler, isAttrTrue, NectaryElement, updateAttribute, updateBooleanAttribute, updateExplicitBooleanAttribute } from '../utils';
2
- const templateHTML = '<style>:host{display:inline-block;vertical-align:middle;outline:0}button{all:initial;position:relative;display:flex;flex-direction:column;justify-content:space-between;box-sizing:border-box;width:var(--sinch-local-size);height:var(--sinch-local-size);padding:16px 8px 8px;border-radius:var(--sinch-local-shape-radius);background-color:var(--sinch-local-color-background);box-shadow:var(--sinch-local-shadow);cursor:pointer;--sinch-local-color-background:var(--sinch-comp-tile-control-color-default-background-initial);--sinch-local-color-border:var(--sinch-comp-tile-control-color-default-border-initial);--sinch-local-color-text:var(--sinch-comp-tile-control-color-default-text-initial);--sinch-local-color-icon:var(--sinch-comp-tile-control-color-default-icon-initial);--sinch-local-shadow:var(--sinch-comp-tile-control-shadow-initial);--sinch-local-shape-radius:var(--sinch-comp-tile-control-shape-radius-l);--sinch-local-size:88px;--sinch-local-size-icon:var(--sinch-comp-tile-control-size-m-icon)}button::before{content:"";position:absolute;inset:0;border:1px solid var(--sinch-local-color-border);border-radius:var(--sinch-local-shape-radius);pointer-events:none}button:focus-visible::after{position:absolute;content:"";inset:-4px;padding:2px;border:2px solid var(--sinch-comp-tile-control-color-default-outline-focus);border-radius:calc(var(--sinch-local-shape-radius) + 4px);pointer-events:none}:host([data-small])>button{padding:12px 4px 4px;--sinch-local-shape-radius:var(--sinch-comp-tile-control-shape-radius-s);--sinch-local-size:64px;--sinch-local-size-icon:var(--sinch-comp-tile-control-size-s-icon)}button:enabled:hover{--sinch-local-color-background:var(--sinch-comp-tile-control-color-default-background-hover);--sinch-local-color-border:var(--sinch-comp-tile-control-color-default-border-hover);--sinch-local-shadow:var(--sinch-comp-tile-control-shadow-hover)}:host([data-checked])>button:enabled,button:enabled:active{--sinch-local-color-background:var(--sinch-comp-tile-control-color-checked-background-initial);--sinch-local-color-border:var(--sinch-comp-tile-control-color-checked-border-initial);--sinch-local-color-text:var(--sinch-comp-tile-control-color-checked-text-initial);--sinch-local-color-icon:var(--sinch-comp-tile-control-color-checked-icon-initial);--sinch-local-shadow:var(--sinch-comp-tile-control-shadow-active)}:host([data-checked])>button:enabled::before,button:enabled:active::before{border-width:2px}button:disabled{cursor:initial;--sinch-local-color-background:var(--sinch-comp-tile-control-color-disabled-background-initial);--sinch-local-color-border:var(--sinch-comp-tile-control-color-disabled-border-initial);--sinch-local-color-text:var(--sinch-comp-tile-control-color-disabled-text-initial);--sinch-local-color-icon:var(--sinch-comp-tile-control-color-disabled-icon-initial);--sinch-local-shadow:var(--sinch-comp-tile-control-shadow-disabled)}#text{display:inline-block;min-height:20px;text-align:center;font:var(--sinch-comp-tile-control-font-label);color:var(--sinch-local-color-text);overflow:hidden;white-space:nowrap;text-overflow:ellipsis}#icon{width:var(--sinch-local-size-icon);height:var(--sinch-local-size-icon);align-self:center;--sinch-global-size-icon:var(--sinch-local-size-icon);--sinch-global-color-icon:var(--sinch-local-color-icon)}</style><button><div id="icon"><slot name="icon"></slot></div><span id="text"></span></button>';
3
- const template = document.createElement('template');
4
- template.innerHTML = templateHTML;
5
- export class TileControlOption extends NectaryElement {
6
- #$button;
7
- #$text;
8
- constructor() {
9
- super();
10
- const shadowRoot = this.attachShadow();
11
- shadowRoot.appendChild(template.content.cloneNode(true));
12
- this.#$button = shadowRoot.querySelector('button');
13
- this.#$text = shadowRoot.querySelector('#text');
14
- }
15
- connectedCallback() {
16
- this.setAttribute('role', 'tab');
17
- this.#$button.addEventListener('click', this.#onButtonClick);
18
- this.#$button.addEventListener('focus', this.#onButtonFocus);
19
- this.#$button.addEventListener('blur', this.#onButtonBlur);
20
- this.addEventListener('-focus', this.#onFocusReactHandler);
21
- this.addEventListener('-blur', this.#onBlurReactHandler);
22
- }
23
- disconnectedCallback() {
24
- this.#$button.removeEventListener('click', this.#onButtonClick);
25
- this.#$button.removeEventListener('focus', this.#onButtonFocus);
26
- this.#$button.removeEventListener('blur', this.#onButtonBlur);
27
- this.removeEventListener('-focus', this.#onFocusReactHandler);
28
- this.removeEventListener('-blur', this.#onBlurReactHandler);
29
- }
30
- static get observedAttributes() {
31
- return ['data-checked', 'text', 'disabled'];
32
- }
33
- attributeChangedCallback(name, oldVal, newVal) {
34
- switch (name) {
35
- case 'text':
36
- {
37
- this.#$text.textContent = newVal;
38
- break;
39
- }
40
- case 'data-checked':
41
- {
42
- updateExplicitBooleanAttribute(this, 'aria-selected', isAttrTrue(newVal));
43
- break;
44
- }
45
- case 'disabled':
46
- {
47
- this.#$button.disabled = isAttrTrue(newVal);
48
- break;
49
- }
50
- }
51
- }
52
- set value(value) {
53
- updateAttribute(this, 'value', value);
54
- }
55
- get value() {
56
- return getAttribute(this, 'value', '');
57
- }
58
- set disabled(isDisabled) {
59
- updateBooleanAttribute(this, 'disabled', isDisabled);
60
- }
61
- get disabled() {
62
- return getBooleanAttribute(this, 'disabled');
63
- }
64
- set text(value) {
65
- updateAttribute(this, 'text', value);
66
- }
67
- get text() {
68
- return getAttribute(this, 'text', '');
69
- }
70
- get focusable() {
71
- return true;
72
- }
73
- focus() {
74
- this.#$button.focus();
75
- }
76
- blur() {
77
- this.#$button.blur();
78
- }
79
- #onButtonClick = e => {
80
- e.stopPropagation();
81
- this.dispatchEvent(new CustomEvent('option-change', {
82
- detail: this.value,
83
- bubbles: true
84
- }));
85
- };
86
- #onButtonFocus = () => {
87
- this.dispatchEvent(new CustomEvent('-focus'));
88
- };
89
- #onButtonBlur = () => {
90
- this.dispatchEvent(new CustomEvent('-blur'));
91
- };
92
- #onFocusReactHandler = () => {
93
- getReactEventHandler(this, 'on-focus')?.();
94
- };
95
- #onBlurReactHandler = () => {
96
- getReactEventHandler(this, 'on-blur')?.();
97
- };
98
- }
99
- defineCustomElement('sinch-tile-control-option', TileControlOption);
@@ -1,52 +0,0 @@
1
- import type { NectaryComponentReactByType, NectaryComponentVanillaByType } from '../types';
2
- export type TSinchTileControlOptionProps = {
3
- /** Value */
4
- value: string;
5
- /** Text content */
6
- text: string;
7
- /** Label that is used for a11y */
8
- 'aria-label': string;
9
- /** Disabled */
10
- disabled?: boolean;
11
- };
12
- export type TSinchTileControlOptionEvents = {
13
- /** Focus handler */
14
- '-focus'?: (e: CustomEvent<void>) => void;
15
- /** Blur handler */
16
- '-blur'?: (e: CustomEvent<void>) => void;
17
- };
18
- export type TSinchTileControlOptionStyle = {
19
- '--sinch-comp-tile-control-shape-radius-l'?: string;
20
- '--sinch-comp-tile-control-shape-radius-s'?: string;
21
- '--sinch-comp-tile-control-font-label'?: string;
22
- '--sinch-comp-tile-control-size-m-icon'?: string;
23
- '--sinch-comp-tile-control-size-s-icon'?: string;
24
- '--sinch-comp-tile-control-color-default-background-initial'?: string;
25
- '--sinch-comp-tile-control-color-default-border-initial'?: string;
26
- '--sinch-comp-tile-control-color-default-text-initial'?: string;
27
- '--sinch-comp-tile-control-color-default-icon-initial'?: string;
28
- '--sinch-comp-tile-control-color-default-background-hover'?: string;
29
- '--sinch-comp-tile-control-color-default-border-hover'?: string;
30
- '--sinch-comp-tile-control-color-default-outline-focus'?: string;
31
- '--sinch-comp-tile-control-color-checked-background-initial'?: string;
32
- '--sinch-comp-tile-control-color-checked-border-initial'?: string;
33
- '--sinch-comp-tile-control-color-checked-text-initial'?: string;
34
- '--sinch-comp-tile-control-color-checked-icon-initial'?: string;
35
- '--sinch-comp-tile-control-color-disabled-background-initial'?: string;
36
- '--sinch-comp-tile-control-color-disabled-border-initial'?: string;
37
- '--sinch-comp-tile-control-color-disabled-text-initial'?: string;
38
- '--sinch-comp-tile-control-color-disabled-icon-initial'?: string;
39
- '--sinch-comp-tile-control-shadow-initial'?: string;
40
- '--sinch-comp-tile-control-shadow-hover'?: string;
41
- '--sinch-comp-tile-control-shadow-active'?: string;
42
- '--sinch-comp-tile-control-shadow-disabled'?: string;
43
- '--sinch-global-size-icon'?: string;
44
- '--sinch-global-color-icon'?: string;
45
- };
46
- export type TSinchTileControlOption = {
47
- props: TSinchTileControlOptionProps;
48
- events: TSinchTileControlOptionEvents;
49
- style: TSinchTileControlOptionStyle;
50
- };
51
- export type TSinchTileControlOptionElement = NectaryComponentVanillaByType<TSinchTileControlOption>;
52
- export type TSinchTileControlOptionReact = NectaryComponentReactByType<TSinchTileControlOption>;
@@ -1 +0,0 @@
1
- export {};
@@ -1,33 +0,0 @@
1
- import { NectaryElement } from '../utils';
2
- import type { TSinchVerticalStepper } from './types';
3
- import type { NectaryComponentReact, NectaryComponentVanilla } from '../types';
4
- export declare class VerticalStepper extends NectaryElement {
5
- #private;
6
- constructor();
7
- connectedCallback(): void;
8
- disconnectedCallback(): void;
9
- static get observedAttributes(): string[];
10
- attributeChangedCallback(name: string): void;
11
- set index(value: string);
12
- get index(): string;
13
- }
14
- declare global {
15
- interface NectaryComponentMap {
16
- 'sinch-vertical-stepper': TSinchVerticalStepper;
17
- }
18
- interface HTMLElementTagNameMap {
19
- 'sinch-vertical-stepper': NectaryComponentVanilla<'sinch-vertical-stepper'>;
20
- }
21
- namespace JSX {
22
- interface IntrinsicElements {
23
- 'sinch-vertical-stepper': NectaryComponentReact<'sinch-vertical-stepper'>;
24
- }
25
- }
26
- }
27
- declare module 'react' {
28
- namespace JSX {
29
- interface IntrinsicElements extends globalThis.JSX.IntrinsicElements {
30
- 'sinch-vertical-stepper': NectaryComponentReact<'sinch-vertical-stepper'>;
31
- }
32
- }
33
- }
@@ -1,58 +0,0 @@
1
- import { clampNumber, defineCustomElement, getAttribute, getIntegerAttribute, NectaryElement, updateAttribute } from '../utils';
2
- const templateHTML = '<style>:host{display:block;outline:0;--sinch-comp-vertical-stepper-color-background-default:var(--sinch-sys-color-surface-tertiary-default);--sinch-comp-vertical-stepper-color-background-visited-skip:var(--sinch-sys-color-surface-tertiary-default);--sinch-comp-vertical-stepper-color-background-active:var(--sinch-ref-color-neutral-700);--sinch-comp-vertical-stepper-color-background-visited:var(--sinch-ref-color-neutral-350);--sinch-comp-vertical-stepper-color-background-visited-error:var(--sinch-sys-color-feedback-danger-strong);--sinch-comp-vertical-stepper-color-border-default:transparent;--sinch-comp-vertical-stepper-color-border-visited-skip:var(--sinch-ref-color-neutral-700);--sinch-comp-vertical-stepper-color-border-active:transparent;--sinch-comp-vertical-stepper-color-border-visited:var(--sinch-ref-color-neutral-700);--sinch-comp-vertical-stepper-color-border-visited-error:var(--sinch-ref-color-neutral-700);--sinch-comp-vertical-stepper-color-icon-default:var(--sinch-ref-color-neutral-900);--sinch-comp-vertical-stepper-color-icon-visited-skip:var(--sinch-ref-color-neutral-900);--sinch-comp-vertical-stepper-color-icon-active:var(--sinch-sys-color-basic-pure);--sinch-comp-vertical-stepper-color-icon-visited:var(--sinch-ref-color-neutral-900);--sinch-comp-vertical-stepper-color-icon-visited-error:var(--sinch-ref-color-neutral-900);--sinch-comp-vertical-stepper-color-label:var(--sinch-sys-color-text-default);--sinch-comp-vertical-stepper-color-description:var(--sinch-sys-color-text-muted);--sinch-comp-vertical-stepper-color-progress:var(--sinch-ref-color-neutral-350);--sinch-comp-vertical-stepper-color-progress-visited:var(--sinch-ref-color-neutral-700)}#wrapper{position:relative;display:flex;flex-direction:column;width:100%}</style><div id="wrapper"><slot></slot></div>';
3
- const template = document.createElement('template');
4
- template.innerHTML = templateHTML;
5
- export class VerticalStepper extends NectaryElement {
6
- #$itemsSlot;
7
- constructor() {
8
- super();
9
- const shadowRoot = this.attachShadow();
10
- shadowRoot.appendChild(template.content.cloneNode(true));
11
- this.#$itemsSlot = shadowRoot.querySelector('slot');
12
- }
13
- connectedCallback() {
14
- this.setAttribute('role', 'progressbar');
15
- this.setAttribute('aria-valuemin', '0');
16
- this.#$itemsSlot.addEventListener('slotchange', this.#updateItems);
17
- }
18
- disconnectedCallback() {
19
- this.#$itemsSlot.removeEventListener('slotchange', this.#updateItems);
20
- }
21
- static get observedAttributes() {
22
- return ['index'];
23
- }
24
- attributeChangedCallback(name) {
25
- switch (name) {
26
- case 'index':
27
- {
28
- this.#updateItems();
29
- break;
30
- }
31
- }
32
- }
33
- set index(value) {
34
- updateAttribute(this, 'index', value);
35
- }
36
- get index() {
37
- return getAttribute(this, 'index', '1');
38
- }
39
- #updateItems = () => {
40
- const $items = this.#$itemsSlot.assignedElements();
41
- const activeIndex = clampNumber(getIntegerAttribute(this, 'index', 0), 0, $items.length + 1);
42
- for (let i = 0; i < $items.length; i++) {
43
- const $el = $items[i];
44
- const itemIndex = i + 1;
45
- $el.setAttribute('data-index', String(itemIndex));
46
- if (itemIndex === activeIndex) {
47
- $el.setAttribute('data-progress', 'active');
48
- } else if (itemIndex < activeIndex) {
49
- $el.setAttribute('data-progress', 'done');
50
- } else {
51
- $el.removeAttribute('data-progress');
52
- }
53
- }
54
- this.setAttribute('aria-valuemax', String($items.length));
55
- this.setAttribute('aria-valuenow', String(clampNumber(activeIndex, 0, $items.length)));
56
- };
57
- }
58
- defineCustomElement('sinch-vertical-stepper', VerticalStepper);