@nectary/components 4.12.1 → 5.0.0

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 +13033 -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 +88 -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 +62 -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 +12 -6
  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 +75 -68
  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 +30 -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 +41 -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/alert/utils.js CHANGED
@@ -1 +1,4 @@
1
- export const typeValues = ['info', 'warn', 'error'];
1
+ const typeValues = ["info", "warn", "error"];
2
+ export {
3
+ typeValues
4
+ };
package/avatar/colors.js CHANGED
@@ -1 +1 @@
1
- export {};
1
+
@@ -0,0 +1 @@
1
+ export * from '../types';
@@ -0,0 +1,2 @@
1
+ import { defineCustomElement } from "../../utils/element.js";
2
+ defineCustomElement("sinch-avatar");
package/avatar/index.d.ts CHANGED
@@ -1,7 +1,7 @@
1
1
  import { NectaryElement } from '../utils';
2
- import type { TSinchAvatarStatus, TSinchAvatar } from './types';
3
- import type { NectaryComponentReact, NectaryComponentVanilla } from '../types';
2
+ import type { TSinchAvatarStatus } from './types';
4
3
  import type { TSinchSize } from '../utils/size';
4
+ export * from './types';
5
5
  export declare class Avatar extends NectaryElement {
6
6
  #private;
7
7
  constructor();
@@ -20,23 +20,3 @@ export declare class Avatar extends NectaryElement {
20
20
  get status(): TSinchAvatarStatus | null;
21
21
  set status(value: TSinchAvatarStatus | null);
22
22
  }
23
- declare global {
24
- interface NectaryComponentMap {
25
- 'sinch-avatar': TSinchAvatar;
26
- }
27
- interface HTMLElementTagNameMap {
28
- 'sinch-avatar': NectaryComponentVanilla<'sinch-avatar'>;
29
- }
30
- namespace JSX {
31
- interface IntrinsicElements {
32
- 'sinch-avatar': NectaryComponentReact<'sinch-avatar'>;
33
- }
34
- }
35
- }
36
- declare module 'react' {
37
- namespace JSX {
38
- interface IntrinsicElements extends globalThis.JSX.IntrinsicElements {
39
- 'sinch-avatar': NectaryComponentReact<'sinch-avatar'>;
40
- }
41
- }
42
- }
package/avatar/index.js CHANGED
@@ -1,10 +1,11 @@
1
- import { defineCustomElement, getAttribute, getLiteralAttribute, NectaryElement, updateAttribute, updateLiteralAttribute } from '../utils';
2
- import { DEFAULT_SIZE, sizeValues } from '../utils/size';
3
- const templateHTML = '<style>:host{display:inline-block;vertical-align:middle;outline:0}#wrapper{position:relative;width:var(--sinch-local-size);height:var(--sinch-local-size);border-radius:var(--sinch-comp-avatar-shape-radius);--sinch-local-size:var(--sinch-comp-avatar-size-m)}:host([size="l"]) #wrapper{--sinch-local-size:var(--sinch-comp-avatar-size-l)}:host([size="s"]) #wrapper{--sinch-local-size:var(--sinch-comp-avatar-size-s)}#text{display:block;width:100%;height:100%;font:var(--sinch-comp-avatar-container-font-size-m-text);line-height:calc(var(--sinch-local-size) - 2px);text-transform:uppercase;text-align:center}:host([size="l"]) #text{font:var(--sinch-comp-avatar-container-font-size-l-text);line-height:calc(var(--sinch-local-size) - 2px)}:host([size="s"]) #text{font:var(--sinch-comp-avatar-container-font-size-s-text);line-height:calc(var(--sinch-local-size) - 2px)}#circle{position:relative;width:calc(100% - 2px);height:calc(100% - 2px);left:1px;top:1px;border-radius:50%;-webkit-mask:linear-gradient(#fff,#000);mask:linear-gradient(#fff,#000);background-color:var(--sinch-comp-avatar-container-color-default-background);color:var(--sinch-comp-avatar-container-color-default-foreground)}#image{display:none;position:absolute;left:0;top:0;width:100%;height:100%;object-fit:contain}:host([src]:not([src=""])) #image{display:block}#person{display:none;position:absolute;left:0;top:0;width:100%;height:100%;fill:var(--sinch-comp-avatar-container-color-default-foreground)}:host(:not([src]):is(:not([alt]),[alt=""])) #person{display:block}#status-wrapper{position:absolute;left:calc(85% - 5px);top:calc(85% - 5px);width:10px;height:10px;padding:1px;box-sizing:border-box;border-radius:50%;background-color:var(--sinch-comp-avatar-status-color-border);display:none;pointer-events:none}#status{width:8px;height:8px;border-radius:50%}:host([status=away]) #status-wrapper,:host([status=busy]) #status-wrapper,:host([status=offline]) #status-wrapper,:host([status=online]) #status-wrapper{display:block}:host([status=online]) #status{background-color:var(--sinch-comp-avatar-status-color-online-default-background)}:host([status=away]) #status{background-color:var(--sinch-comp-avatar-status-color-away-default-background)}:host([status=busy]) #status{background-color:var(--sinch-comp-avatar-status-color-busy-default-background)}:host([status=offline]) #status{background-color:var(--sinch-comp-avatar-status-color-offline-default-background)}</style><div id="wrapper"><div id="circle"><span id="text"></span><img id="image" alt=""/><svg id="person" viewBox="0 0 40 40" fill="none"><path d="M29.451 15.785a9.451 9.451 0 1 1-18.902 0 9.452 9.452 0 0 1 18.902 0ZM4.734 40.5c.119-7.085 5.899-12.792 13.012-12.792h4.508c7.113 0 12.893 5.707 13.012 12.792H4.734Z"/></svg></div><div id="status-wrapper"><div id="status"></div></div></div>';
4
- import { getAvatarColorBg, getAvatarColorFg, statusValues } from './utils';
5
- const template = document.createElement('template');
1
+ import { getAttribute, updateAttribute, getLiteralAttribute, updateLiteralAttribute } from "../utils/dom.js";
2
+ import { defineCustomElement, NectaryElement } from "../utils/element.js";
3
+ import { DEFAULT_SIZE, sizeValues } from "../utils/size.js";
4
+ import { statusValues, getAvatarColorBg, getAvatarColorFg } from "./utils.js";
5
+ const templateHTML = '<style>\n :host {\n display: inline-block;\n vertical-align: middle;\n outline: none;\n }\n\n #wrapper {\n position: relative;\n width: var(--sinch-local-size);\n height: var(--sinch-local-size);\n border-radius: var(--sinch-comp-avatar-shape-radius);\n\n --sinch-local-size: var(--sinch-comp-avatar-size-m);\n }\n\n :host([size="l"]) #wrapper {\n --sinch-local-size: var(--sinch-comp-avatar-size-l);\n }\n\n :host([size="s"]) #wrapper {\n --sinch-local-size: var(--sinch-comp-avatar-size-s);\n }\n\n #text {\n display: block;\n width: 100%;\n height: 100%;\n font: var(--sinch-comp-avatar-container-font-size-m-text);\n line-height: calc(var(--sinch-local-size) - 2px);\n text-transform: uppercase;\n text-align: center;\n }\n\n :host([size="l"]) #text {\n font: var(--sinch-comp-avatar-container-font-size-l-text);\n line-height: calc(var(--sinch-local-size) - 2px);\n }\n\n :host([size="s"]) #text {\n font: var(--sinch-comp-avatar-container-font-size-s-text);\n line-height: calc(var(--sinch-local-size) - 2px);\n }\n\n #circle {\n position: relative;\n width: calc(100% - 2px);\n height: calc(100% - 2px);\n left: 1px;\n top: 1px;\n border-radius: 50%;\n /* stylelint-disable-next-line property-no-vendor-prefix */\n -webkit-mask: linear-gradient(#fff, #000);\n mask: linear-gradient(#fff, #000);\n background-color: var(--sinch-comp-avatar-container-color-default-background);\n color: var(--sinch-comp-avatar-container-color-default-foreground);\n }\n\n #image {\n display: none;\n position: absolute;\n left: 0;\n top: 0;\n width: 100%;\n height: 100%;\n object-fit: contain;\n }\n\n :host([src]:not([src=""])) #image {\n display: block;\n }\n\n #person {\n display: none;\n position: absolute;\n left: 0;\n top: 0;\n width: 100%;\n height: 100%;\n fill: var(--sinch-comp-avatar-container-color-default-foreground);\n }\n\n :host(:not([src]):is(:not([alt]), [alt=""])) #person {\n display: block;\n }\n\n #status-wrapper {\n position: absolute;\n left: calc(85% - 5px);\n top: calc(85% - 5px);\n width: 10px;\n height: 10px;\n padding: 1px;\n box-sizing: border-box;\n border-radius: 50%;\n background-color: var(--sinch-comp-avatar-status-color-border);\n display: none;\n pointer-events: none;\n }\n\n #status {\n width: 8px;\n height: 8px;\n border-radius: 50%;\n }\n\n :host([status="online"]) #status-wrapper,\n :host([status="away"]) #status-wrapper,\n :host([status="busy"]) #status-wrapper,\n :host([status="offline"]) #status-wrapper {\n display: block;\n }\n\n :host([status="online"]) #status {\n background-color: var(--sinch-comp-avatar-status-color-online-default-background);\n }\n\n :host([status="away"]) #status {\n background-color: var(--sinch-comp-avatar-status-color-away-default-background);\n }\n\n :host([status="busy"]) #status {\n background-color: var(--sinch-comp-avatar-status-color-busy-default-background);\n }\n\n :host([status="offline"]) #status {\n background-color: var(--sinch-comp-avatar-status-color-offline-default-background);\n }\n</style>\n\n<div id="wrapper">\n <div id="circle">\n <span id="text"></span>\n <img id="image" alt="" />\n <svg id="person" viewBox="0 0 40 40" fill="none">\n <path\n d="M29.451 15.785a9.451 9.451 0 1 1-18.902 0 9.452 9.452 0 0 1 18.902 0ZM4.734 40.5c.119-7.085 5.899-12.792 13.012-12.792h4.508c7.113 0 12.893 5.707 13.012 12.792H4.734Z" />\n </svg>\n </div>\n <div id="status-wrapper">\n <div id="status"></div>\n </div>\n</div>';
6
+ const template = document.createElement("template");
6
7
  template.innerHTML = templateHTML;
7
- export class Avatar extends NectaryElement {
8
+ class Avatar extends NectaryElement {
8
9
  #$circle;
9
10
  #$text;
10
11
  #$image;
@@ -12,9 +13,9 @@ export class Avatar extends NectaryElement {
12
13
  super();
13
14
  const shadowRoot = this.attachShadow();
14
15
  shadowRoot.appendChild(template.content.cloneNode(true));
15
- this.#$circle = shadowRoot.querySelector('#circle');
16
- this.#$text = shadowRoot.querySelector('#text');
17
- this.#$image = shadowRoot.querySelector('#image');
16
+ this.#$circle = shadowRoot.querySelector("#circle");
17
+ this.#$text = shadowRoot.querySelector("#text");
18
+ this.#$image = shadowRoot.querySelector("#image");
18
19
  }
19
20
  connectedCallback() {
20
21
  super.connectedCallback();
@@ -24,57 +25,54 @@ export class Avatar extends NectaryElement {
24
25
  super.disconnectedCallback();
25
26
  }
26
27
  static get observedAttributes() {
27
- return ['alt', 'src', 'color'];
28
+ return ["alt", "src", "color"];
28
29
  }
29
30
  attributeChangedCallback(name, _, newVal) {
30
31
  switch (name) {
31
- case 'alt':
32
- {
33
- this.#$text.textContent = newVal;
34
- this.#$image.alt = newVal ?? '';
35
- break;
36
- }
37
- case 'src':
38
- {
39
- this.#$image.src = newVal ?? '';
40
- break;
41
- }
42
- case 'color':
43
- {
44
- this.#updateColor();
45
- break;
46
- }
32
+ case "alt": {
33
+ this.#$text.textContent = newVal;
34
+ this.#$image.alt = newVal ?? "";
35
+ break;
36
+ }
37
+ case "src": {
38
+ this.#$image.src = newVal ?? "";
39
+ break;
40
+ }
41
+ case "color": {
42
+ this.#updateColor();
43
+ break;
44
+ }
47
45
  }
48
46
  }
49
47
  get src() {
50
- return getAttribute(this, 'src');
48
+ return getAttribute(this, "src");
51
49
  }
52
50
  set src(value) {
53
- updateAttribute(this, 'src', value);
51
+ updateAttribute(this, "src", value);
54
52
  }
55
53
  get alt() {
56
- return getAttribute(this, 'alt', '');
54
+ return getAttribute(this, "alt", "");
57
55
  }
58
56
  set alt(value) {
59
- updateAttribute(this, 'alt', value);
57
+ updateAttribute(this, "alt", value);
60
58
  }
61
59
  get color() {
62
- return getAttribute(this, 'color');
60
+ return getAttribute(this, "color");
63
61
  }
64
62
  set color(value) {
65
- updateAttribute(this, 'color', value);
63
+ updateAttribute(this, "color", value);
66
64
  }
67
65
  get size() {
68
- return getLiteralAttribute(this, sizeValues, 'size', DEFAULT_SIZE);
66
+ return getLiteralAttribute(this, sizeValues, "size", DEFAULT_SIZE);
69
67
  }
70
68
  set size(value) {
71
- updateLiteralAttribute(this, sizeValues, 'size', value);
69
+ updateLiteralAttribute(this, sizeValues, "size", value);
72
70
  }
73
71
  get status() {
74
- return getLiteralAttribute(this, statusValues, 'status', null);
72
+ return getLiteralAttribute(this, statusValues, "status", null);
75
73
  }
76
74
  set status(value) {
77
- updateLiteralAttribute(this, statusValues, 'status', value);
75
+ updateLiteralAttribute(this, statusValues, "status", value);
78
76
  }
79
77
  #updateColor() {
80
78
  if (!this.isDomConnected) {
@@ -84,12 +82,15 @@ export class Avatar extends NectaryElement {
84
82
  if (colorName !== null && colorName.length > 0) {
85
83
  const bg = getAvatarColorBg(colorName);
86
84
  const fg = getAvatarColorFg(colorName);
87
- this.#$circle.style.setProperty('background-color', bg);
88
- this.#$circle.style.setProperty('color', fg);
85
+ this.#$circle.style.setProperty("background-color", bg);
86
+ this.#$circle.style.setProperty("color", fg);
89
87
  } else {
90
- this.#$circle.style.removeProperty('background-color');
91
- this.#$circle.style.removeProperty('color');
88
+ this.#$circle.style.removeProperty("background-color");
89
+ this.#$circle.style.removeProperty("color");
92
90
  }
93
91
  }
94
92
  }
95
- defineCustomElement('sinch-avatar', Avatar);
93
+ defineCustomElement("sinch-avatar", Avatar);
94
+ export {
95
+ Avatar
96
+ };
package/avatar/types.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  import type { TSinchAvatarColor } from './colors';
2
- import type { NectaryComponentReactByType, NectaryComponentVanillaByType } from '../types';
2
+ import type { NectaryComponentReactByType, NectaryComponentVanillaByType, NectaryComponentReact, NectaryComponentVanilla } from '../types';
3
3
  import type { TSinchSize } from '../utils/size';
4
4
  export type { TSinchAvatarColor };
5
5
  export type TSinchAvatarStatus = 'online' | 'busy' | 'away' | 'offline';
@@ -56,3 +56,23 @@ export type TSinchAvatar = {
56
56
  };
57
57
  export type TSinchAvatarElement = NectaryComponentVanillaByType<TSinchAvatar>;
58
58
  export type TSinchAvatarReact = NectaryComponentReactByType<TSinchAvatar>;
59
+ declare global {
60
+ interface NectaryComponentMap {
61
+ 'sinch-avatar': TSinchAvatar;
62
+ }
63
+ interface HTMLElementTagNameMap {
64
+ 'sinch-avatar': NectaryComponentVanilla<'sinch-avatar'>;
65
+ }
66
+ namespace JSX {
67
+ interface IntrinsicElements {
68
+ 'sinch-avatar': NectaryComponentReact<'sinch-avatar'>;
69
+ }
70
+ }
71
+ }
72
+ declare module 'react' {
73
+ namespace JSX {
74
+ interface IntrinsicElements extends globalThis.JSX.IntrinsicElements {
75
+ 'sinch-avatar': NectaryComponentReact<'sinch-avatar'>;
76
+ }
77
+ }
78
+ }
package/avatar/types.js CHANGED
@@ -1 +1 @@
1
- export {};
1
+
package/avatar/utils.js CHANGED
@@ -1,7 +1,12 @@
1
- export const statusValues = ['online', 'busy', 'away', 'offline'];
2
- export const getAvatarColorBg = id => {
1
+ const statusValues = ["online", "busy", "away", "offline"];
2
+ const getAvatarColorBg = (id) => {
3
3
  return `var(--sinch-comp-avatar-container-color-${id}-background)`;
4
4
  };
5
- export const getAvatarColorFg = id => {
5
+ const getAvatarColorFg = (id) => {
6
6
  return `var(--sinch-comp-avatar-container-color-${id}-foreground)`;
7
- };
7
+ };
8
+ export {
9
+ getAvatarColorBg,
10
+ getAvatarColorFg,
11
+ statusValues
12
+ };
@@ -0,0 +1 @@
1
+ export * from '../types';
@@ -0,0 +1,2 @@
1
+ import { defineCustomElement } from "../../utils/element.js";
2
+ defineCustomElement("sinch-badge");
package/badge/index.d.ts CHANGED
@@ -1,7 +1,8 @@
1
1
  import { NectaryElement } from '../utils';
2
- import type { TSinchBadgeMode, TSinchBadge } from './types';
3
- import type { TRect, NectaryComponentReact, NectaryComponentVanilla } from '../types';
2
+ import type { TSinchBadgeMode } from './types';
3
+ import type { TRect } from '../types';
4
4
  import type { TSinchSize } from '../utils/size';
5
+ export * from './types';
5
6
  export declare class Badge extends NectaryElement {
6
7
  #private;
7
8
  constructor();
@@ -19,23 +20,3 @@ export declare class Badge extends NectaryElement {
19
20
  set hidden(isHidden: boolean);
20
21
  get badgeRect(): TRect;
21
22
  }
22
- declare global {
23
- interface NectaryComponentMap {
24
- 'sinch-badge': TSinchBadge;
25
- }
26
- interface HTMLElementTagNameMap {
27
- 'sinch-badge': NectaryComponentVanilla<'sinch-badge'>;
28
- }
29
- namespace JSX {
30
- interface IntrinsicElements {
31
- 'sinch-badge': NectaryComponentReact<'sinch-badge'>;
32
- }
33
- }
34
- }
35
- declare module 'react' {
36
- namespace JSX {
37
- interface IntrinsicElements extends globalThis.JSX.IntrinsicElements {
38
- 'sinch-badge': NectaryComponentReact<'sinch-badge'>;
39
- }
40
- }
41
- }
package/badge/index.js CHANGED
@@ -1,10 +1,12 @@
1
- import { defineCustomElement, getAttribute, getBooleanAttribute, getLiteralAttribute, getRect, isAttrEqual, isAttrTrue, NectaryElement, setClass, updateAttribute, updateBooleanAttribute, updateLiteralAttribute } from '../utils';
2
- import { DEFAULT_SIZE, sizeValues } from '../utils/size';
3
- const templateHTML = '<style>:host{display:inline-flex;flex-direction:column;position:relative}#badge-wrapper{position:absolute;left:0;top:0;width:fit-content;border-radius:var(--sinch-comp-badge-shape-radius);padding:1px;pointer-events:none;background-color:var(--sinch-comp-badge-color-border)}#badge{box-sizing:border-box;color:var(--sinch-comp-badge-color-text);background-color:var(--sinch-comp-badge-color-background);width:20px;height:20px;border-radius:var(--sinch-comp-badge-shape-radius)}#badge.long{width:fit-content;padding:0 5px}#text{display:block;width:100%;height:100%;text-align:center;font:var(--sinch-comp-badge-font-size-l);line-height:20px;text-rendering:optimizelegibility}:host([size="m"]) #badge-wrapper{left:calc(100% - 8px);top:-8px}:host([size="m"]) #badge{width:14px;height:14px}:host([size="m"]) #badge.long{width:fit-content;padding:0 3px}:host([size="m"]) #text{font:var(--sinch-comp-badge-font-size-m);line-height:14px}:host([size="s"]) #badge{width:8px;height:8px;padding:0}:host([size="s"]) #text{display:none}:host([hidden]) #badge-wrapper{display:none}</style><slot id="slot"></slot><div id="badge-wrapper"><div id="badge"><span id="text"></span></div></div>';
4
- import { modeValues } from './utils';
5
- const template = document.createElement('template');
1
+ import { isAttrEqual, updateBooleanAttribute, isAttrTrue, setClass, getAttribute, updateAttribute, getLiteralAttribute, updateLiteralAttribute, getBooleanAttribute } from "../utils/dom.js";
2
+ import { defineCustomElement, NectaryElement } from "../utils/element.js";
3
+ import { getRect } from "../utils/rect.js";
4
+ import { DEFAULT_SIZE, sizeValues } from "../utils/size.js";
5
+ import { modeValues } from "./utils.js";
6
+ const templateHTML = '<style>\n:host {\n display: inline-flex;\n flex-direction: column;\n position: relative;\n}\n\n#badge-wrapper {\n position: absolute;\n left: 0;\n top: 0;\n width: fit-content;\n border-radius: var(--sinch-comp-badge-shape-radius);\n padding: 1px;\n pointer-events: none;\n background-color: var(--sinch-comp-badge-color-border);\n}\n\n#badge {\n box-sizing: border-box;\n color: var(--sinch-comp-badge-color-text);\n background-color: var(--sinch-comp-badge-color-background);\n width: 20px;\n height: 20px;\n border-radius: var(--sinch-comp-badge-shape-radius);\n}\n\n#badge.long {\n width: fit-content;\n padding: 0 5px;\n}\n\n#text {\n display: block;\n width: 100%;\n height: 100%;\n text-align: center;\n font: var(--sinch-comp-badge-font-size-l);\n line-height: 20px;\n text-rendering: optimizelegibility;\n}\n\n:host([size="m"]) #badge-wrapper {\n left: calc(100% - 8px);\n top: -8px;\n}\n\n:host([size="m"]) #badge {\n width: 14px;\n height: 14px;\n}\n\n:host([size="m"]) #badge.long {\n width: fit-content;\n padding: 0 3px;\n}\n\n:host([size="m"]) #text {\n font: var(--sinch-comp-badge-font-size-m);\n line-height: 14px;\n}\n\n:host([size="s"]) #badge {\n width: 8px;\n height: 8px;\n padding: 0;\n}\n\n:host([size="s"]) #text {\n display: none;\n}\n\n:host([hidden]) #badge-wrapper {\n display: none;\n}\n</style>\n\n<slot id="slot"></slot>\n<div id="badge-wrapper">\n <div id="badge">\n <span id="text"></span>\n </div>\n</div>\n';
7
+ const template = document.createElement("template");
6
8
  template.innerHTML = templateHTML;
7
- export class Badge extends NectaryElement {
9
+ class Badge extends NectaryElement {
8
10
  #$badgeWrapper;
9
11
  #$badge;
10
12
  #$text;
@@ -13,9 +15,9 @@ export class Badge extends NectaryElement {
13
15
  super();
14
16
  const shadowRoot = this.attachShadow();
15
17
  shadowRoot.appendChild(template.content.cloneNode(true));
16
- this.#$badgeWrapper = shadowRoot.querySelector('#badge-wrapper');
17
- this.#$badge = shadowRoot.querySelector('#badge');
18
- this.#$text = shadowRoot.querySelector('#text');
18
+ this.#$badgeWrapper = shadowRoot.querySelector("#badge-wrapper");
19
+ this.#$badge = shadowRoot.querySelector("#badge");
20
+ this.#$text = shadowRoot.querySelector("#text");
19
21
  this.#observer = new ResizeObserver(this.#onResize);
20
22
  }
21
23
  connectedCallback() {
@@ -27,70 +29,66 @@ export class Badge extends NectaryElement {
27
29
  this.#observer.unobserve(this);
28
30
  }
29
31
  static get observedAttributes() {
30
- return ['text', 'size', 'mode', 'hidden'];
32
+ return [
33
+ "text",
34
+ "size",
35
+ "mode",
36
+ "hidden"
37
+ ];
31
38
  }
32
39
  attributeChangedCallback(name, oldVal, newVal) {
33
40
  if (isAttrEqual(oldVal, newVal)) {
34
41
  return;
35
42
  }
36
43
  switch (name) {
37
- case 'text':
38
- {
39
- this.#$text.textContent = newVal;
40
- setClass(this.#$badge, 'long', newVal !== null && newVal.length > 1);
41
- break;
42
- }
43
- case 'size':
44
- {
45
- this.#updatePosition();
46
- break;
47
- }
48
- case 'mode':
49
- {
50
- this.#updatePosition();
51
- break;
52
- }
53
- case 'hidden':
54
- {
55
- this.#updatePosition();
56
- updateBooleanAttribute(this, name, isAttrTrue(newVal));
57
- break;
58
- }
44
+ case "text": {
45
+ this.#$text.textContent = newVal;
46
+ setClass(this.#$badge, "long", newVal !== null && newVal.length > 1);
47
+ break;
48
+ }
49
+ case "size": {
50
+ this.#updatePosition();
51
+ break;
52
+ }
53
+ case "mode": {
54
+ this.#updatePosition();
55
+ break;
56
+ }
57
+ case "hidden": {
58
+ this.#updatePosition();
59
+ updateBooleanAttribute(this, name, isAttrTrue(newVal));
60
+ break;
61
+ }
59
62
  }
60
63
  }
61
64
  get text() {
62
- return getAttribute(this, 'text', '');
65
+ return getAttribute(this, "text", "");
63
66
  }
64
67
  set text(value) {
65
- updateAttribute(this, 'text', value);
68
+ updateAttribute(this, "text", value);
66
69
  }
67
70
  get size() {
68
- return getLiteralAttribute(this, sizeValues, 'size', DEFAULT_SIZE);
71
+ return getLiteralAttribute(this, sizeValues, "size", DEFAULT_SIZE);
69
72
  }
70
73
  set size(value) {
71
- updateLiteralAttribute(this, sizeValues, 'size', value);
74
+ updateLiteralAttribute(this, sizeValues, "size", value);
72
75
  }
73
76
  get mode() {
74
- return getLiteralAttribute(this, modeValues, 'mode', 'square');
77
+ return getLiteralAttribute(this, modeValues, "mode", "square");
75
78
  }
76
79
  set mode(value) {
77
- updateLiteralAttribute(this, modeValues, 'mode', value);
80
+ updateLiteralAttribute(this, modeValues, "mode", value);
78
81
  }
79
82
  get hidden() {
80
- return getBooleanAttribute(this, 'hidden');
83
+ return getBooleanAttribute(this, "hidden");
81
84
  }
82
85
  set hidden(isHidden) {
83
- updateBooleanAttribute(this, 'hidden', isHidden);
86
+ updateBooleanAttribute(this, "hidden", isHidden);
84
87
  }
85
88
  get badgeRect() {
86
89
  if (this.hidden) {
87
90
  const selfRect = getRect(this);
88
- return {
89
- x: selfRect.x + selfRect.width,
90
- y: selfRect.y,
91
- width: 0,
92
- height: 0
93
- };
91
+ return { x: selfRect.x + selfRect.width, y: selfRect.y, width: 0, height: 0 };
94
92
  }
95
93
  return getRect(this.#$badgeWrapper);
96
94
  }
@@ -101,15 +99,18 @@ export class Badge extends NectaryElement {
101
99
  const mode = this.mode;
102
100
  const targetRect = this.getBoundingClientRect();
103
101
  const badgeRect = this.#$badgeWrapper.getBoundingClientRect();
104
- const offsetMultX = mode === 'circle' ? 0.85 : 1;
105
- const offsetMultY = mode === 'circle' ? 0.15 : 0;
102
+ const offsetMultX = mode === "circle" ? 0.85 : 1;
103
+ const offsetMultY = mode === "circle" ? 0.15 : 0;
106
104
  const posX = Math.round(targetRect.width * offsetMultX - badgeRect.height / 2);
107
105
  const posY = Math.round(targetRect.height * offsetMultY - badgeRect.height / 2);
108
- this.#$badgeWrapper.style.setProperty('left', `${posX}px`);
109
- this.#$badgeWrapper.style.setProperty('top', `${posY}px`);
106
+ this.#$badgeWrapper.style.setProperty("left", `${posX}px`);
107
+ this.#$badgeWrapper.style.setProperty("top", `${posY}px`);
110
108
  }
111
109
  #onResize = () => {
112
110
  this.#updatePosition();
113
111
  };
114
112
  }
115
- defineCustomElement('sinch-badge', Badge);
113
+ defineCustomElement("sinch-badge", Badge);
114
+ export {
115
+ Badge
116
+ };
package/badge/types.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- import type { NectaryComponentReactByType, NectaryComponentVanillaByType, TRect } from '../types';
1
+ import type { NectaryComponentReactByType, NectaryComponentVanillaByType, TRect, NectaryComponentReact, NectaryComponentVanilla } from '../types';
2
2
  import type { TSinchSize } from '../utils/size';
3
3
  export type TSinchBadgeMode = 'square' | 'circle';
4
4
  export type TSinchBadgeProps = {
@@ -27,3 +27,23 @@ export type TSinchBadge = {
27
27
  };
28
28
  export type TSinchBadgeElement = NectaryComponentVanillaByType<TSinchBadge>;
29
29
  export type TSinchBadgeReact = NectaryComponentReactByType<TSinchBadge>;
30
+ declare global {
31
+ interface NectaryComponentMap {
32
+ 'sinch-badge': TSinchBadge;
33
+ }
34
+ interface HTMLElementTagNameMap {
35
+ 'sinch-badge': NectaryComponentVanilla<'sinch-badge'>;
36
+ }
37
+ namespace JSX {
38
+ interface IntrinsicElements {
39
+ 'sinch-badge': NectaryComponentReact<'sinch-badge'>;
40
+ }
41
+ }
42
+ }
43
+ declare module 'react' {
44
+ namespace JSX {
45
+ interface IntrinsicElements extends globalThis.JSX.IntrinsicElements {
46
+ 'sinch-badge': NectaryComponentReact<'sinch-badge'>;
47
+ }
48
+ }
49
+ }
package/badge/types.js CHANGED
@@ -1 +1 @@
1
- export {};
1
+
package/badge/utils.js CHANGED
@@ -1 +1,4 @@
1
- export const modeValues = ['square', 'circle'];
1
+ const modeValues = ["square", "circle"];
2
+ export {
3
+ modeValues
4
+ };
package/bundle.d.ts ADDED
@@ -0,0 +1,78 @@
1
+ export * from './accordion-item/index.js';
2
+ export * from './accordion/index.js';
3
+ export * from './action-menu-option/index.js';
4
+ export * from './action-menu/index.js';
5
+ export * from './alert/index.js';
6
+ export * from './avatar/index.js';
7
+ export * from './badge/index.js';
8
+ export * from './button-group-item/index.js';
9
+ export * from './button-group/index.js';
10
+ export * from './button/index.js';
11
+ export * from './card-container/index.js';
12
+ export * from './card-v2-title/index.js';
13
+ export * from './card-v2/index.js';
14
+ export * from './checkbox/index.js';
15
+ export * from './chip/index.js';
16
+ export * from './code-tag/index.js';
17
+ export * from './color-menu-option/index.js';
18
+ export * from './color-menu/index.js';
19
+ export * from './color-swatch/index.js';
20
+ export * from './date-picker/index.js';
21
+ export * from './dialog/index.js';
22
+ export * from './emoji-picker/index.js';
23
+ export * from './emoji/index.js';
24
+ export * from './field/index.js';
25
+ export * from './file-drop/index.js';
26
+ export * from './file-picker/index.js';
27
+ export * from './file-status/index.js';
28
+ export * from './flag/index.js';
29
+ export * from './grid-item/index.js';
30
+ export * from './grid/index.js';
31
+ export * from './help-tooltip/index.js';
32
+ export * from './icon/index.js';
33
+ export * from './inline-alert/index.js';
34
+ export * from './input/index.js';
35
+ export * from './link/index.js';
36
+ export * from './list-item/index.js';
37
+ export * from './list/index.js';
38
+ export * from './pagination/index.js';
39
+ export * from './persistent-overlay/index.js';
40
+ export * from './pop/index.js';
41
+ export * from './popover/index.js';
42
+ export * from './progress-stepper-item/index.js';
43
+ export * from './progress-stepper/index.js';
44
+ export * from './progress/index.js';
45
+ export * from './radio-option/index.js';
46
+ export * from './radio/index.js';
47
+ export * from './rich-text/index.js';
48
+ export * from './rich-textarea/index.js';
49
+ export * from './segment-collapse/index.js';
50
+ export * from './segmented-control-option/index.js';
51
+ export * from './segmented-control/index.js';
52
+ export * from './segmented-icon-control-option/index.js';
53
+ export * from './segmented-icon-control/index.js';
54
+ export * from './select-button/index.js';
55
+ export * from './select-menu-option/index.js';
56
+ export * from './select-menu/index.js';
57
+ export * from './skeleton-item/index.js';
58
+ export * from './skeleton/index.js';
59
+ export * from './spinner/index.js';
60
+ export * from './stop-events/index.js';
61
+ export * from './table-body/index.js';
62
+ export * from './table-cell/index.js';
63
+ export * from './table-head-cell/index.js';
64
+ export * from './table-head/index.js';
65
+ export * from './table-row/index.js';
66
+ export * from './table/index.js';
67
+ export * from './tabs-icon-option/index.js';
68
+ export * from './tabs-option/index.js';
69
+ export * from './tabs/index.js';
70
+ export * from './tag/index.js';
71
+ export * from './text/index.js';
72
+ export * from './textarea/index.js';
73
+ export * from './time-picker/index.js';
74
+ export * from './title/index.js';
75
+ export * from './toast-manager/index.js';
76
+ export * from './toast/index.js';
77
+ export * from './toggle/index.js';
78
+ export * from './tooltip/index.js';