@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
@@ -1,4 +1,4 @@
1
- import type { NectaryComponentReactByType, NectaryComponentVanillaByType, TRect } from '../types';
1
+ import type { NectaryComponentReactByType, NectaryComponentVanillaByType, TRect, NectaryComponentReact, NectaryComponentVanilla } from '../types';
2
2
  export type TEmoji = {
3
3
  emoji: string;
4
4
  code: string;
@@ -40,3 +40,23 @@ export type TSinchEmojiPicker = {
40
40
  };
41
41
  export type TSinchEmojiPickerElement = NectaryComponentVanillaByType<TSinchEmojiPicker>;
42
42
  export type TSinchEmojiPickerReact = NectaryComponentReactByType<TSinchEmojiPicker>;
43
+ declare global {
44
+ interface NectaryComponentMap {
45
+ 'sinch-emoji-picker': TSinchEmojiPicker;
46
+ }
47
+ interface HTMLElementTagNameMap {
48
+ 'sinch-emoji-picker': NectaryComponentVanilla<'sinch-emoji-picker'>;
49
+ }
50
+ namespace JSX {
51
+ interface IntrinsicElements {
52
+ 'sinch-emoji-picker': NectaryComponentReact<'sinch-emoji-picker'>;
53
+ }
54
+ }
55
+ }
56
+ declare module 'react' {
57
+ namespace JSX {
58
+ interface IntrinsicElements extends globalThis.JSX.IntrinsicElements {
59
+ 'sinch-emoji-picker': NectaryComponentReact<'sinch-emoji-picker'>;
60
+ }
61
+ }
62
+ }
@@ -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-field");
package/field/index.d.ts CHANGED
@@ -1,6 +1,5 @@
1
1
  import { NectaryElement } from '../utils';
2
- import type { TSinchField } from './types';
3
- import type { NectaryComponentVanilla, NectaryComponentReact } from '../types';
2
+ export * from './types';
4
3
  export declare class Field extends NectaryElement {
5
4
  #private;
6
5
  topSection: HTMLDivElement;
@@ -21,23 +20,3 @@ export declare class Field extends NectaryElement {
21
20
  set disabled(isDisabled: boolean);
22
21
  get disabled(): boolean;
23
22
  }
24
- declare global {
25
- interface NectaryComponentMap {
26
- 'sinch-field': TSinchField;
27
- }
28
- interface HTMLElementTagNameMap {
29
- 'sinch-field': NectaryComponentVanilla<'sinch-field'>;
30
- }
31
- namespace JSX {
32
- interface IntrinsicElements {
33
- 'sinch-field': NectaryComponentReact<'sinch-field'>;
34
- }
35
- }
36
- }
37
- declare module 'react' {
38
- namespace JSX {
39
- interface IntrinsicElements extends globalThis.JSX.IntrinsicElements {
40
- 'sinch-field': NectaryComponentReact<'sinch-field'>;
41
- }
42
- }
43
- }
package/field/index.js CHANGED
@@ -1,8 +1,11 @@
1
- import { defineCustomElement, getAttribute, getBooleanAttribute, getFirstSlotElement, isAttrEqual, isAttrTrue, NectaryElement, setClass, updateAttribute, updateBooleanAttribute } from '../utils';
2
- const templateHTML = '<style>:host{display:block}#wrapper{display:flex;flex-direction:column;width:100%}#bottom,#top{display:flex;align-items:baseline}#top{height:24px;margin-bottom:2px}#top.empty{display:none}#additional,#invalid,#label,#optional{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#label{font:var(--sinch-comp-field-font-label);color:var(--sinch-comp-field-color-default-label-initial)}#optional{flex:1;font:var(--sinch-comp-field-font-optional);color:var(--sinch-comp-field-color-default-optional-initial);text-align:right}#additional{flex:1;text-align:right;font:var(--sinch-comp-field-font-additional);color:var(--sinch-comp-field-color-default-additional-initial);line-height:20px;margin-top:2px}#additional:empty{display:none}#invalid{font:var(--sinch-comp-field-font-invalid);color:var(--sinch-comp-field-color-invalid-text-initial);line-height:20px;margin-top:2px}#invalid:empty{display:none}#tooltip{align-self:center;margin:0 8px;display:flex}#tooltip.empty{display:none}:host([disabled]) #label{color:var(--sinch-comp-field-color-disabled-label-initial)}:host([disabled]) #additional{color:var(--sinch-comp-field-color-disabled-additional-initial)}:host([disabled]) #optional{color:var(--sinch-comp-field-color-disabled-optional-initial)}</style><div id="wrapper"><div id="top"><label id="label" for="input"></label><div id="tooltip"><slot name="tooltip"></slot></div><span id="optional"></span></div><slot name="input"></slot><div id="bottom"><div id="invalid"></div><div id="additional"></div></div></div>';
3
- const template = document.createElement('template');
1
+ import { getAttribute, setClass, isAttrEqual, updateBooleanAttribute, isAttrTrue, updateAttribute, getBooleanAttribute } from "../utils/dom.js";
2
+ import { defineCustomElement, NectaryElement } from "../utils/element.js";
3
+ import { getFirstSlotElement } from "../utils/slot.js";
4
+ const templateHTML = '<style>\n:host {\n display: block;\n}\n\n#wrapper {\n display: flex;\n flex-direction: column;\n width: 100%;\n}\n\n#top,\n#bottom {\n display: flex;\n align-items: baseline;\n}\n\n#top {\n height: 24px;\n margin-bottom: 2px;\n}\n\n#top.empty {\n display: none;\n}\n\n#label,\n#optional,\n#additional,\n#invalid {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n\n#label {\n font: var(--sinch-comp-field-font-label);\n color: var(--sinch-comp-field-color-default-label-initial);\n}\n\n#optional {\n flex: 1;\n font: var(--sinch-comp-field-font-optional);\n color: var(--sinch-comp-field-color-default-optional-initial);\n text-align: right;\n}\n\n#additional {\n flex: 1;\n text-align: right;\n font: var(--sinch-comp-field-font-additional);\n color: var(--sinch-comp-field-color-default-additional-initial);\n line-height: 20px;\n margin-top: 2px;\n}\n\n#additional:empty {\n display: none;\n}\n\n#invalid {\n font: var(--sinch-comp-field-font-invalid);\n color: var(--sinch-comp-field-color-invalid-text-initial);\n line-height: 20px;\n margin-top: 2px;\n}\n\n#invalid:empty {\n display: none;\n}\n\n#tooltip {\n align-self: center;\n margin: 0 8px;\n display: flex;\n}\n\n#tooltip.empty {\n display: none;\n}\n\n:host([disabled]) #label {\n color: var(--sinch-comp-field-color-disabled-label-initial);\n}\n\n:host([disabled]) #additional {\n color: var(--sinch-comp-field-color-disabled-additional-initial);\n}\n\n:host([disabled]) #optional {\n color: var(--sinch-comp-field-color-disabled-optional-initial);\n}\n\n</style>\n\n<div id="wrapper">\n <div id="top">\n <label id="label" for="input"></label>\n <div id="tooltip">\n <slot name="tooltip"></slot>\n </div>\n <span id="optional"></span>\n </div>\n <slot name="input"></slot>\n <div id="bottom">\n <div id="invalid"></div>\n <div id="additional"></div>\n </div>\n</div>\n';
5
+ const template = document.createElement("template");
4
6
  template.innerHTML = templateHTML;
5
- export class Field extends NectaryElement {
7
+ class Field extends NectaryElement {
8
+ topSection;
6
9
  #$label;
7
10
  #$optionalText;
8
11
  #$additionalText;
@@ -15,107 +18,107 @@ export class Field extends NectaryElement {
15
18
  super();
16
19
  const shadowRoot = this.attachShadow();
17
20
  shadowRoot.appendChild(template.content.cloneNode(true));
18
- this.topSection = shadowRoot.querySelector('#top');
19
- this.#$label = shadowRoot.querySelector('#label');
20
- this.#$optionalText = shadowRoot.querySelector('#optional');
21
- this.#$additionalText = shadowRoot.querySelector('#additional');
22
- this.#$invalidText = shadowRoot.querySelector('#invalid');
21
+ this.topSection = shadowRoot.querySelector("#top");
22
+ this.#$label = shadowRoot.querySelector("#label");
23
+ this.#$optionalText = shadowRoot.querySelector("#optional");
24
+ this.#$additionalText = shadowRoot.querySelector("#additional");
25
+ this.#$invalidText = shadowRoot.querySelector("#invalid");
23
26
  this.#$inputSlot = shadowRoot.querySelector('slot[name="input"]');
24
27
  this.#$tooltipSlot = shadowRoot.querySelector('slot[name="tooltip"]');
25
- this.#$tooltipWrapper = shadowRoot.querySelector('#tooltip');
28
+ this.#$tooltipWrapper = shadowRoot.querySelector("#tooltip");
26
29
  }
27
30
  connectedCallback() {
28
31
  this.#controller = new AbortController();
29
- const {
30
- signal
31
- } = this.#controller;
32
- const options = {
33
- signal
34
- };
32
+ const { signal } = this.#controller;
33
+ const options = { signal };
35
34
  this.shouldShowTopSection();
36
- this.#$label.addEventListener('click', this.#onLabelClick, options);
37
- this.#$tooltipSlot.addEventListener('slotchange', this.#onTooltipSlotChange, options);
35
+ this.#$label.addEventListener("click", this.#onLabelClick, options);
36
+ this.#$tooltipSlot.addEventListener("slotchange", this.#onTooltipSlotChange, options);
38
37
  }
39
38
  disconnectedCallback() {
40
39
  this.#controller.abort();
41
40
  this.#controller = null;
42
41
  }
43
42
  static get observedAttributes() {
44
- return ['label', 'optionaltext', 'additionaltext', 'invalidtext', 'disabled'];
43
+ return [
44
+ "label",
45
+ "optionaltext",
46
+ "additionaltext",
47
+ "invalidtext",
48
+ "disabled"
49
+ ];
45
50
  }
46
51
  shouldShowTopSection() {
47
- const label = getAttribute(this, 'label');
48
- const optionaltext = getAttribute(this, 'optionaltext');
49
- setClass(this.topSection, 'empty', label === null && optionaltext === null);
52
+ const label = getAttribute(this, "label");
53
+ const optionaltext = getAttribute(this, "optionaltext");
54
+ setClass(this.topSection, "empty", label === null && optionaltext === null);
50
55
  }
51
56
  attributeChangedCallback(name, oldVal, newVal) {
52
57
  switch (name) {
53
- case 'label':
54
- {
55
- this.#$label.textContent = newVal;
56
- break;
57
- }
58
- case 'optionaltext':
59
- {
60
- this.#$optionalText.textContent = newVal;
61
- break;
62
- }
63
- case 'additionaltext':
64
- {
65
- this.#$additionalText.textContent = newVal;
66
- break;
67
- }
68
- case 'invalidtext':
69
- {
70
- this.#$invalidText.textContent = newVal;
71
- break;
72
- }
73
- case 'disabled':
74
- {
75
- if (isAttrEqual(oldVal, newVal)) {
76
- break;
77
- }
78
- updateBooleanAttribute(this, name, isAttrTrue(newVal));
58
+ case "label": {
59
+ this.#$label.textContent = newVal;
60
+ break;
61
+ }
62
+ case "optionaltext": {
63
+ this.#$optionalText.textContent = newVal;
64
+ break;
65
+ }
66
+ case "additionaltext": {
67
+ this.#$additionalText.textContent = newVal;
68
+ break;
69
+ }
70
+ case "invalidtext": {
71
+ this.#$invalidText.textContent = newVal;
72
+ break;
73
+ }
74
+ case "disabled": {
75
+ if (isAttrEqual(oldVal, newVal)) {
79
76
  break;
80
77
  }
78
+ updateBooleanAttribute(this, name, isAttrTrue(newVal));
79
+ break;
80
+ }
81
81
  }
82
82
  this.shouldShowTopSection();
83
83
  }
84
84
  set label(value) {
85
- updateAttribute(this, 'label', value);
85
+ updateAttribute(this, "label", value);
86
86
  }
87
87
  get label() {
88
- return getAttribute(this, 'label');
88
+ return getAttribute(this, "label");
89
89
  }
90
90
  set optionalText(value) {
91
- updateAttribute(this, 'optionaltext', value);
91
+ updateAttribute(this, "optionaltext", value);
92
92
  }
93
93
  get optionalText() {
94
- return getAttribute(this, 'optionaltext');
94
+ return getAttribute(this, "optionaltext");
95
95
  }
96
96
  set additionalText(value) {
97
- updateAttribute(this, 'additionaltext', value);
97
+ updateAttribute(this, "additionaltext", value);
98
98
  }
99
99
  get additionalText() {
100
- return getAttribute(this, 'additionaltext');
100
+ return getAttribute(this, "additionaltext");
101
101
  }
102
102
  set invalidText(value) {
103
- updateAttribute(this, 'invalidtext', value);
103
+ updateAttribute(this, "invalidtext", value);
104
104
  }
105
105
  get invalidText() {
106
- return getAttribute(this, 'invalidtext');
106
+ return getAttribute(this, "invalidtext");
107
107
  }
108
108
  set disabled(isDisabled) {
109
- updateBooleanAttribute(this, 'disabled', isDisabled);
109
+ updateBooleanAttribute(this, "disabled", isDisabled);
110
110
  }
111
111
  get disabled() {
112
- return getBooleanAttribute(this, 'disabled');
112
+ return getBooleanAttribute(this, "disabled");
113
113
  }
114
114
  #onLabelClick = () => {
115
115
  getFirstSlotElement(this.#$inputSlot)?.focus?.();
116
116
  };
117
117
  #onTooltipSlotChange = () => {
118
- setClass(this.#$tooltipWrapper, 'empty', this.#$tooltipSlot.assignedElements().length === 0);
118
+ setClass(this.#$tooltipWrapper, "empty", this.#$tooltipSlot.assignedElements().length === 0);
119
119
  };
120
120
  }
121
- defineCustomElement('sinch-field', Field);
121
+ defineCustomElement("sinch-field", Field);
122
+ export {
123
+ Field
124
+ };
package/field/types.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- import type { NectaryComponentReactByType, NectaryComponentVanillaByType } from '../types';
1
+ import type { NectaryComponentReactByType, NectaryComponentVanillaByType, NectaryComponentReact, NectaryComponentVanilla } from '../types';
2
2
  export type TSinchFieldProps = {
3
3
  /** Label that shows in UI */
4
4
  label?: string;
@@ -30,3 +30,23 @@ export type TSinchField = {
30
30
  };
31
31
  export type TSinchFieldElement = NectaryComponentVanillaByType<TSinchField>;
32
32
  export type TSinchFieldReact = NectaryComponentReactByType<TSinchField>;
33
+ declare global {
34
+ interface NectaryComponentMap {
35
+ 'sinch-field': TSinchField;
36
+ }
37
+ interface HTMLElementTagNameMap {
38
+ 'sinch-field': NectaryComponentVanilla<'sinch-field'>;
39
+ }
40
+ namespace JSX {
41
+ interface IntrinsicElements {
42
+ 'sinch-field': NectaryComponentReact<'sinch-field'>;
43
+ }
44
+ }
45
+ }
46
+ declare module 'react' {
47
+ namespace JSX {
48
+ interface IntrinsicElements extends globalThis.JSX.IntrinsicElements {
49
+ 'sinch-field': NectaryComponentReact<'sinch-field'>;
50
+ }
51
+ }
52
+ }
package/field/types.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-file-drop");
@@ -1,8 +1,7 @@
1
1
  import '../text';
2
2
  import '../file-picker';
3
3
  import { NectaryElement } from '../utils';
4
- import type { TSinchFileDrop } from './types';
5
- import type { NectaryComponentVanilla, NectaryComponentReact } from '../types';
4
+ export * from './types';
6
5
  export declare class FileDrop extends NectaryElement {
7
6
  #private;
8
7
  constructor();
@@ -25,23 +24,3 @@ export declare class FileDrop extends NectaryElement {
25
24
  set invalid(isInvalid: boolean);
26
25
  get invalid(): boolean;
27
26
  }
28
- declare global {
29
- interface NectaryComponentMap {
30
- 'sinch-file-drop': TSinchFileDrop;
31
- }
32
- interface HTMLElementTagNameMap {
33
- 'sinch-file-drop': NectaryComponentVanilla<'sinch-file-drop'>;
34
- }
35
- namespace JSX {
36
- interface IntrinsicElements {
37
- 'sinch-file-drop': NectaryComponentReact<'sinch-file-drop'>;
38
- }
39
- }
40
- }
41
- declare module 'react' {
42
- namespace JSX {
43
- interface IntrinsicElements extends globalThis.JSX.IntrinsicElements {
44
- 'sinch-file-drop': NectaryComponentReact<'sinch-file-drop'>;
45
- }
46
- }
47
- }
@@ -1,11 +1,13 @@
1
- import '../text';
2
- import '../file-picker';
3
- import { defineCustomElement, getAttribute, getBooleanAttribute, getIntegerAttribute, getReactEventHandler, isAttrEqual, isAttrTrue, NectaryElement, setClass, updateAttribute, updateBooleanAttribute } from '../utils';
4
- const templateHTML = '<style>:host{display:block}#wrapper{position:relative;display:flex;flex-direction:row;flex-wrap:wrap;justify-content:center;align-content:center;gap:8px;height:148px;min-width:148px;box-sizing:border-box;padding:16px;border-radius:var(--sinch-comp-file-drop-shape-radius);background-color:var(--sinch-comp-file-drop-color-default-background-initial)}#wrapper::after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border:1px dashed var(--sinch-comp-file-drop-color-default-border-initial);border-radius:var(--sinch-comp-file-drop-shape-radius);pointer-events:none}#placeholder{align-self:center;text-align:center;--sinch-global-color-text:var(--sinch-comp-file-drop-color-default-placeholder-initial);--sinch-comp-text-font:var(--sinch-comp-file-drop-font-placeholder)}:host([invalid]) #wrapper{background-color:var(--sinch-comp-file-drop-color-invalid-background-initial)}:host([invalid]) #wrapper::after{border-color:var(--sinch-comp-file-drop-color-invalid-border-initial);border-width:1px}#wrapper.drop::after{pointer-events:all}#wrapper.drop.valid{background-color:var(--sinch-comp-file-drop-color-default-background-active)}#wrapper.drop.valid::after{border-color:var(--sinch-comp-file-drop-color-default-border-active);border-width:2px}#wrapper.drop.valid>#placeholder{--sinch-global-color-text:var(--sinch-comp-file-drop-color-default-placeholder-active)}#wrapper.drop.invalid{background-color:var(--sinch-comp-file-drop-color-invalid-background-active)}#wrapper.drop.invalid::after{border-color:var(--sinch-comp-file-drop-color-invalid-border-active);border-width:2px}#wrapper.drop.invalid>#placeholder{--sinch-global-color-text:var(--sinch-comp-file-drop-color-invalid-placeholder-active)}:host([disabled])>#wrapper>#placeholder{--sinch-global-color-text:var(--sinch-comp-file-drop-color-disabled-placeholder-initial)}:host([disabled])>#wrapper{background-color:var(--sinch-comp-file-drop-color-disabled-background-initial)}:host([disabled])>#wrapper::after{border-color:var(--sinch-comp-file-drop-color-disabled-border-initial);border-width:1px}</style><div id="wrapper"><sinch-text id="placeholder" type="m" aria-hidden="true"></sinch-text><sinch-file-picker id="file-picker"><slot></slot></sinch-file-picker></div>';
5
- import { areFilesAccepted, areItemsAccepted, doFilesSatisfySize } from './utils';
6
- const template = document.createElement('template');
1
+ import "../text/index.js";
2
+ import "../file-picker/index.js";
3
+ import { isAttrEqual, updateAttribute, updateBooleanAttribute, isAttrTrue, getBooleanAttribute, getAttribute, getIntegerAttribute, setClass } from "../utils/dom.js";
4
+ import { defineCustomElement, NectaryElement } from "../utils/element.js";
5
+ import { getReactEventHandler } from "../utils/get-react-event-handler.js";
6
+ import { areItemsAccepted, areFilesAccepted, doFilesSatisfySize } from "./utils.js";
7
+ const templateHTML = '<style>\n:host {\n display: block;\n}\n\n#wrapper {\n position: relative;\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n justify-content: center;\n align-content: center;\n gap: 8px;\n height: 148px;\n min-width: 148px;\n box-sizing: border-box;\n padding: 16px;\n border-radius: var(--sinch-comp-file-drop-shape-radius);\n background-color: var(--sinch-comp-file-drop-color-default-background-initial);\n}\n\n/* Border */\n#wrapper::after {\n content: "";\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n border: 1px dashed var(--sinch-comp-file-drop-color-default-border-initial);\n border-radius: var(--sinch-comp-file-drop-shape-radius);\n pointer-events: none;\n}\n\n#placeholder {\n align-self: center;\n text-align: center;\n\n --sinch-global-color-text: var(--sinch-comp-file-drop-color-default-placeholder-initial);\n --sinch-comp-text-font: var(--sinch-comp-file-drop-font-placeholder);\n}\n\n:host([invalid]) #wrapper {\n background-color: var(--sinch-comp-file-drop-color-invalid-background-initial);\n}\n\n:host([invalid]) #wrapper::after {\n border-color: var(--sinch-comp-file-drop-color-invalid-border-initial);\n border-width: 1px;\n}\n\n#wrapper.drop::after {\n pointer-events: all;\n}\n\n#wrapper.drop.valid {\n background-color: var(--sinch-comp-file-drop-color-default-background-active);\n}\n\n#wrapper.drop.valid::after {\n border-color: var(--sinch-comp-file-drop-color-default-border-active);\n border-width: 2px;\n}\n\n#wrapper.drop.valid > #placeholder {\n --sinch-global-color-text: var(--sinch-comp-file-drop-color-default-placeholder-active);\n}\n\n#wrapper.drop.invalid {\n background-color: var(--sinch-comp-file-drop-color-invalid-background-active);\n}\n\n#wrapper.drop.invalid::after {\n border-color: var(--sinch-comp-file-drop-color-invalid-border-active);\n border-width: 2px;\n}\n\n#wrapper.drop.invalid > #placeholder {\n --sinch-global-color-text: var(--sinch-comp-file-drop-color-invalid-placeholder-active);\n}\n\n:host([disabled]) > #wrapper > #placeholder {\n --sinch-global-color-text: var(--sinch-comp-file-drop-color-disabled-placeholder-initial);\n}\n\n:host([disabled]) > #wrapper {\n background-color: var(--sinch-comp-file-drop-color-disabled-background-initial);\n}\n\n:host([disabled]) > #wrapper::after {\n border-color: var(--sinch-comp-file-drop-color-disabled-border-initial);\n border-width: 1px;\n}\n</style>\n\n<div id="wrapper">\n <sinch-text id="placeholder" type="m" aria-hidden="true"></sinch-text>\n <sinch-file-picker id="file-picker">\n <slot></slot>\n </sinch-file-picker>\n</div>\n';
8
+ const template = document.createElement("template");
7
9
  template.innerHTML = templateHTML;
8
- export class FileDrop extends NectaryElement {
10
+ class FileDrop extends NectaryElement {
9
11
  #$filePicker;
10
12
  #$dropArea;
11
13
  #$placeholder;
@@ -14,130 +16,126 @@ export class FileDrop extends NectaryElement {
14
16
  super();
15
17
  const shadowRoot = this.attachShadow();
16
18
  shadowRoot.appendChild(template.content.cloneNode(true));
17
- this.#$dropArea = shadowRoot.querySelector('#wrapper');
18
- this.#$placeholder = shadowRoot.querySelector('#placeholder');
19
- this.#$filePicker = shadowRoot.querySelector('#file-picker');
19
+ this.#$dropArea = shadowRoot.querySelector("#wrapper");
20
+ this.#$placeholder = shadowRoot.querySelector("#placeholder");
21
+ this.#$filePicker = shadowRoot.querySelector("#file-picker");
20
22
  }
21
23
  connectedCallback() {
22
24
  this.#controller = new AbortController();
23
- const {
24
- signal
25
- } = this.#controller;
26
- const options = {
27
- signal
28
- };
29
- this.addEventListener('-change', this.#onChangeReactHandler, options);
30
- this.addEventListener('-invalid', this.#onInvalidReactHandler, options);
31
- this.addEventListener('dragenter', this.#onDragEnter, options);
32
- this.addEventListener('dragleave', this.#onDragLeave, options);
33
- this.addEventListener('dragover', this.#onDragOver, options);
34
- this.addEventListener('drop', this.#onDrop, options);
35
- this.#$filePicker.addEventListener('-change', this.#onFilePickerChange, options);
36
- this.#$filePicker.addEventListener('-invalid', this.#onFilePickerInvalid, options);
25
+ const { signal } = this.#controller;
26
+ const options = { signal };
27
+ this.addEventListener("-change", this.#onChangeReactHandler, options);
28
+ this.addEventListener("-invalid", this.#onInvalidReactHandler, options);
29
+ this.addEventListener("dragenter", this.#onDragEnter, options);
30
+ this.addEventListener("dragleave", this.#onDragLeave, options);
31
+ this.addEventListener("dragover", this.#onDragOver, options);
32
+ this.addEventListener("drop", this.#onDrop, options);
33
+ this.#$filePicker.addEventListener("-change", this.#onFilePickerChange, options);
34
+ this.#$filePicker.addEventListener("-invalid", this.#onFilePickerInvalid, options);
37
35
  }
38
36
  disconnectedCallback() {
39
37
  this.#controller.abort();
40
38
  this.#controller = null;
41
39
  }
42
40
  static get observedAttributes() {
43
- return ['accept', 'multiple', 'placeholder', 'disabled', 'invalid', 'size'];
41
+ return [
42
+ "accept",
43
+ "multiple",
44
+ "placeholder",
45
+ "disabled",
46
+ "invalid",
47
+ "size"
48
+ ];
44
49
  }
45
50
  attributeChangedCallback(name, oldVal, newVal) {
46
51
  if (isAttrEqual(oldVal, newVal)) {
47
52
  return;
48
53
  }
49
54
  switch (name) {
50
- case 'multiple':
51
- {
52
- updateAttribute(this.#$filePicker, 'multiple', newVal);
53
- break;
54
- }
55
- case 'accept':
56
- {
57
- updateAttribute(this.#$filePicker, 'accept', newVal);
58
- break;
59
- }
60
- case 'placeholder':
61
- {
62
- this.#$placeholder.textContent = newVal;
63
- break;
64
- }
65
- case 'disabled':
66
- {
67
- this.#setDragEffect(false);
68
- updateBooleanAttribute(this, 'disabled', isAttrTrue(newVal));
69
- break;
70
- }
71
- case 'invalid':
72
- {
73
- updateBooleanAttribute(this, 'invalid', isAttrTrue(newVal));
74
- break;
75
- }
76
- case 'size':
77
- {
78
- updateAttribute(this.#$filePicker, 'size', newVal);
79
- break;
80
- }
55
+ case "multiple": {
56
+ updateAttribute(this.#$filePicker, "multiple", newVal);
57
+ break;
58
+ }
59
+ case "accept": {
60
+ updateAttribute(this.#$filePicker, "accept", newVal);
61
+ break;
62
+ }
63
+ case "placeholder": {
64
+ this.#$placeholder.textContent = newVal;
65
+ break;
66
+ }
67
+ case "disabled": {
68
+ this.#setDragEffect(false);
69
+ updateBooleanAttribute(this, "disabled", isAttrTrue(newVal));
70
+ break;
71
+ }
72
+ case "invalid": {
73
+ updateBooleanAttribute(this, "invalid", isAttrTrue(newVal));
74
+ break;
75
+ }
76
+ case "size": {
77
+ updateAttribute(this.#$filePicker, "size", newVal);
78
+ break;
79
+ }
81
80
  }
82
81
  }
83
82
  set multiple(isMultiple) {
84
- updateBooleanAttribute(this, 'multiple', isMultiple);
83
+ updateBooleanAttribute(this, "multiple", isMultiple);
85
84
  }
86
85
  get multiple() {
87
- return getBooleanAttribute(this, 'multiple');
86
+ return getBooleanAttribute(this, "multiple");
88
87
  }
89
88
  set accept(value) {
90
- updateAttribute(this, 'accept', value);
89
+ updateAttribute(this, "accept", value);
91
90
  }
92
91
  get accept() {
93
- return getAttribute(this, 'accept');
92
+ return getAttribute(this, "accept");
94
93
  }
95
94
  get size() {
96
- return getIntegerAttribute(this, 'size', null);
95
+ return getIntegerAttribute(this, "size", null);
97
96
  }
98
97
  set size(value) {
99
- updateAttribute(this, 'size', value);
98
+ updateAttribute(this, "size", value);
100
99
  }
101
100
  set text(value) {
102
- updateAttribute(this, 'text', value);
101
+ updateAttribute(this, "text", value);
103
102
  }
104
103
  get text() {
105
- return getAttribute(this, 'text', '');
104
+ return getAttribute(this, "text", "");
106
105
  }
107
106
  set placeholder(value) {
108
- updateAttribute(this, 'placeholder', value);
107
+ updateAttribute(this, "placeholder", value);
109
108
  }
110
109
  get placeholder() {
111
- return getAttribute(this, 'placeholder', '');
110
+ return getAttribute(this, "placeholder", "");
112
111
  }
113
112
  set disabled(isDisabled) {
114
- updateBooleanAttribute(this, 'disabled', isDisabled);
113
+ updateBooleanAttribute(this, "disabled", isDisabled);
115
114
  }
116
115
  get disabled() {
117
- return getBooleanAttribute(this, 'disabled');
116
+ return getBooleanAttribute(this, "disabled");
118
117
  }
119
118
  set invalid(isInvalid) {
120
- updateBooleanAttribute(this, 'invalid', isInvalid);
119
+ updateBooleanAttribute(this, "invalid", isInvalid);
121
120
  }
122
121
  get invalid() {
123
- return getBooleanAttribute(this, 'invalid');
122
+ return getBooleanAttribute(this, "invalid");
124
123
  }
125
- #setDragEffect(shouldEnable) {
126
- let isValid = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
124
+ #setDragEffect(shouldEnable, isValid = false) {
127
125
  const isElementEnabled = !this.disabled;
128
126
  if (shouldEnable) {
129
127
  if (isElementEnabled) {
130
- setClass(this.#$dropArea, 'drop', true);
131
- setClass(this.#$dropArea, 'valid', isValid);
132
- setClass(this.#$dropArea, 'invalid', !isValid);
128
+ setClass(this.#$dropArea, "drop", true);
129
+ setClass(this.#$dropArea, "valid", isValid);
130
+ setClass(this.#$dropArea, "invalid", !isValid);
133
131
  }
134
132
  } else {
135
- setClass(this.#$dropArea, 'drop', false);
136
- setClass(this.#$dropArea, 'valid', false);
137
- setClass(this.#$dropArea, 'invalid', false);
133
+ setClass(this.#$dropArea, "drop", false);
134
+ setClass(this.#$dropArea, "valid", false);
135
+ setClass(this.#$dropArea, "invalid", false);
138
136
  }
139
137
  }
140
- #onDragEnter = e => {
138
+ #onDragEnter = (e) => {
141
139
  e.stopPropagation();
142
140
  e.preventDefault();
143
141
  const items = e.dataTransfer?.items;
@@ -148,16 +146,16 @@ export class FileDrop extends NectaryElement {
148
146
  }
149
147
  this.#setDragEffect(true, isValidItems);
150
148
  };
151
- #onDragLeave = e => {
149
+ #onDragLeave = (e) => {
152
150
  e.stopPropagation();
153
151
  e.preventDefault();
154
152
  this.#setDragEffect(false);
155
153
  };
156
- #onDragOver = e => {
154
+ #onDragOver = (e) => {
157
155
  e.stopPropagation();
158
156
  e.preventDefault();
159
157
  };
160
- #onDrop = e => {
158
+ #onDrop = (e) => {
161
159
  e.stopPropagation();
162
160
  e.preventDefault();
163
161
  this.#setDragEffect(false);
@@ -172,41 +170,48 @@ export class FileDrop extends NectaryElement {
172
170
  return;
173
171
  }
174
172
  if (!this.multiple && dt.files.length > 1) {
175
- this.#dispatchInvalidEvent('multiple');
173
+ this.#dispatchInvalidEvent("multiple");
176
174
  return;
177
175
  }
178
176
  const files = Array.from(dt.files);
179
177
  if (!areFilesAccepted(files, this.accept)) {
180
- this.#dispatchInvalidEvent('accept');
178
+ this.#dispatchInvalidEvent("accept");
181
179
  return;
182
180
  }
183
181
  if (!doFilesSatisfySize(files, this.size)) {
184
- this.#dispatchInvalidEvent('size');
182
+ this.#dispatchInvalidEvent("size");
185
183
  return;
186
184
  }
187
185
  this.#dispatchChangeEvent(files);
188
186
  };
189
- #onFilePickerChange = e => {
187
+ #onFilePickerChange = (e) => {
190
188
  this.#dispatchChangeEvent(e.detail);
191
189
  };
192
- #onFilePickerInvalid = e => {
190
+ #onFilePickerInvalid = (e) => {
193
191
  this.#dispatchInvalidEvent(e.detail);
194
192
  };
195
- #onChangeReactHandler = e => {
196
- getReactEventHandler(this, 'on-change')?.(e);
193
+ #onChangeReactHandler = (e) => {
194
+ getReactEventHandler(this, "on-change")?.(e);
197
195
  };
198
- #onInvalidReactHandler = e => {
199
- getReactEventHandler(this, 'on-invalid')?.(e);
196
+ #onInvalidReactHandler = (e) => {
197
+ getReactEventHandler(this, "on-invalid")?.(e);
200
198
  };
201
199
  #dispatchChangeEvent(files) {
202
- this.dispatchEvent(new CustomEvent('-change', {
203
- detail: files
204
- }));
200
+ this.dispatchEvent(
201
+ new CustomEvent("-change", {
202
+ detail: files
203
+ })
204
+ );
205
205
  }
206
206
  #dispatchInvalidEvent(type) {
207
- this.dispatchEvent(new CustomEvent('-invalid', {
208
- detail: type
209
- }));
207
+ this.dispatchEvent(
208
+ new CustomEvent("-invalid", {
209
+ detail: type
210
+ })
211
+ );
210
212
  }
211
213
  }
212
- defineCustomElement('sinch-file-drop', FileDrop);
214
+ defineCustomElement("sinch-file-drop", FileDrop);
215
+ export {
216
+ FileDrop
217
+ };