@nectary/components 4.12.1 → 5.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (585) hide show
  1. package/accordion/global/index.d.ts +1 -0
  2. package/accordion/global/index.js +2 -0
  3. package/accordion/index.d.ts +1 -22
  4. package/accordion/index.js +41 -39
  5. package/accordion/types.d.ts +21 -1
  6. package/accordion/types.js +1 -1
  7. package/accordion-item/global/index.d.ts +1 -0
  8. package/accordion-item/global/index.js +2 -0
  9. package/accordion-item/index.d.ts +2 -22
  10. package/accordion-item/index.js +53 -49
  11. package/accordion-item/types.d.ts +21 -1
  12. package/accordion-item/types.js +1 -1
  13. package/accordion-item/utils.js +4 -1
  14. package/action-menu/global/index.d.ts +1 -0
  15. package/action-menu/global/index.js +2 -0
  16. package/action-menu/index.d.ts +1 -22
  17. package/action-menu/index.js +62 -77
  18. package/action-menu/types.d.ts +21 -1
  19. package/action-menu/types.js +1 -1
  20. package/action-menu-option/global/index.d.ts +1 -0
  21. package/action-menu-option/global/index.js +2 -0
  22. package/action-menu-option/index.d.ts +1 -22
  23. package/action-menu-option/index.js +39 -41
  24. package/action-menu-option/types.d.ts +21 -1
  25. package/action-menu-option/types.js +1 -1
  26. package/action-menu-option/utils.js +6 -3
  27. package/alert/global/index.d.ts +1 -0
  28. package/alert/global/index.js +2 -0
  29. package/alert/index.d.ts +2 -22
  30. package/alert/index.js +24 -21
  31. package/alert/types.d.ts +21 -1
  32. package/alert/types.js +1 -1
  33. package/alert/utils.js +4 -1
  34. package/avatar/colors.js +1 -1
  35. package/avatar/global/index.d.ts +1 -0
  36. package/avatar/global/index.js +2 -0
  37. package/avatar/index.d.ts +2 -22
  38. package/avatar/index.js +42 -41
  39. package/avatar/types.d.ts +21 -1
  40. package/avatar/types.js +1 -1
  41. package/avatar/utils.js +9 -4
  42. package/badge/global/index.d.ts +1 -0
  43. package/badge/global/index.js +2 -0
  44. package/badge/index.d.ts +3 -22
  45. package/badge/index.js +52 -51
  46. package/badge/types.d.ts +21 -1
  47. package/badge/types.js +1 -1
  48. package/badge/utils.js +4 -1
  49. package/bundle.d.ts +78 -0
  50. package/bundle.js +13069 -0
  51. package/bundle.ts +80 -0
  52. package/button/global/index.d.ts +1 -0
  53. package/button/global/index.js +2 -0
  54. package/button/index.d.ts +2 -22
  55. package/button/index.js +101 -111
  56. package/button/types.d.ts +21 -1
  57. package/button/types.js +1 -1
  58. package/button/utils.js +18 -2
  59. package/button-group/global/index.d.ts +1 -0
  60. package/button-group/global/index.js +2 -0
  61. package/button-group/index.d.ts +1 -22
  62. package/button-group/index.js +20 -18
  63. package/button-group/types.d.ts +22 -3
  64. package/button-group/types.js +1 -1
  65. package/button-group-item/global/index.d.ts +1 -0
  66. package/button-group-item/global/index.js +2 -0
  67. package/button-group-item/index.d.ts +2 -22
  68. package/button-group-item/index.js +31 -42
  69. package/button-group-item/types.d.ts +22 -3
  70. package/button-group-item/types.js +1 -1
  71. package/card-container/global/index.d.ts +1 -0
  72. package/card-container/global/index.js +2 -0
  73. package/card-container/index.d.ts +1 -21
  74. package/card-container/index.js +8 -5
  75. package/card-container/types.d.ts +21 -1
  76. package/card-container/types.js +1 -1
  77. package/card-v2/global/index.d.ts +1 -0
  78. package/card-v2/global/index.js +2 -0
  79. package/card-v2/index.d.ts +1 -22
  80. package/card-v2/index.js +59 -57
  81. package/card-v2/types.d.ts +21 -1
  82. package/card-v2/types.js +1 -1
  83. package/card-v2-title/global/index.d.ts +1 -0
  84. package/card-v2-title/global/index.js +2 -0
  85. package/card-v2-title/index.d.ts +2 -22
  86. package/card-v2-title/index.js +28 -26
  87. package/card-v2-title/types.d.ts +21 -1
  88. package/card-v2-title/types.js +1 -1
  89. package/checkbox/global/index.d.ts +1 -0
  90. package/checkbox/global/index.js +2 -0
  91. package/checkbox/index.d.ts +1 -22
  92. package/checkbox/index.js +90 -81
  93. package/checkbox/types.d.ts +21 -1
  94. package/checkbox/types.js +1 -1
  95. package/chip/colors.js +1 -1
  96. package/chip/global/index.d.ts +1 -0
  97. package/chip/global/index.js +2 -0
  98. package/chip/index.d.ts +1 -22
  99. package/chip/index.js +64 -75
  100. package/chip/types.d.ts +21 -1
  101. package/chip/types.js +1 -1
  102. package/chip/utils.js +7 -3
  103. package/code-tag/global/index.d.ts +1 -0
  104. package/code-tag/global/index.js +2 -0
  105. package/code-tag/index.d.ts +1 -22
  106. package/code-tag/index.js +17 -14
  107. package/code-tag/types.d.ts +21 -1
  108. package/code-tag/types.js +1 -1
  109. package/color-menu/global/index.d.ts +1 -0
  110. package/color-menu/global/index.js +2 -0
  111. package/color-menu/index.d.ts +2 -22
  112. package/color-menu/index.js +115 -115
  113. package/color-menu/types.d.ts +21 -1
  114. package/color-menu/types.js +1 -1
  115. package/color-menu/utils.js +6 -3
  116. package/color-menu-option/global/index.d.ts +1 -0
  117. package/color-menu-option/global/index.js +2 -0
  118. package/color-menu-option/index.d.ts +1 -22
  119. package/color-menu-option/index.js +30 -26
  120. package/color-menu-option/types.d.ts +21 -1
  121. package/color-menu-option/types.js +1 -1
  122. package/color-menu-option/utils.js +6 -3
  123. package/color-swatch/global/index.d.ts +1 -0
  124. package/color-swatch/global/index.js +2 -0
  125. package/color-swatch/index.d.ts +1 -22
  126. package/color-swatch/index.js +23 -20
  127. package/color-swatch/types.d.ts +21 -1
  128. package/color-swatch/types.js +1 -1
  129. package/color-swatch/utils.js +7 -3
  130. package/date-picker/global/index.d.ts +1 -0
  131. package/date-picker/global/index.js +2 -0
  132. package/date-picker/index.d.ts +2 -22
  133. package/date-picker/index.js +157 -150
  134. package/date-picker/types.d.ts +21 -1
  135. package/date-picker/types.js +1 -1
  136. package/date-picker/utils.js +59 -42
  137. package/dialog/global/index.d.ts +1 -0
  138. package/dialog/global/index.js +2 -0
  139. package/dialog/index.d.ts +1 -22
  140. package/dialog/index.js +71 -58
  141. package/dialog/types.d.ts +21 -1
  142. package/dialog/types.js +1 -1
  143. package/dialog/utils.js +11 -7
  144. package/emoji/global/index.d.ts +1 -0
  145. package/emoji/global/index.js +2 -0
  146. package/emoji/index.d.ts +1 -22
  147. package/emoji/index.js +19 -16
  148. package/emoji/types.d.ts +21 -1
  149. package/emoji/types.js +1 -1
  150. package/emoji/utils.js +22 -17
  151. package/emoji-picker/global/index.d.ts +1 -0
  152. package/emoji-picker/global/index.js +2 -0
  153. package/emoji-picker/index.d.ts +2 -22
  154. package/emoji-picker/index.js +138 -118
  155. package/emoji-picker/types.d.ts +21 -1
  156. package/emoji-picker/types.js +1 -1
  157. package/field/global/index.d.ts +1 -0
  158. package/field/global/index.js +2 -0
  159. package/field/index.d.ts +1 -22
  160. package/field/index.js +63 -60
  161. package/field/types.d.ts +21 -1
  162. package/field/types.js +1 -1
  163. package/file-drop/global/index.d.ts +1 -0
  164. package/file-drop/global/index.js +2 -0
  165. package/file-drop/index.d.ts +1 -22
  166. package/file-drop/index.js +103 -98
  167. package/file-drop/types.d.ts +21 -1
  168. package/file-drop/types.js +1 -1
  169. package/file-drop/utils.js +27 -22
  170. package/file-picker/global/index.d.ts +1 -0
  171. package/file-picker/global/index.js +2 -0
  172. package/file-picker/index.d.ts +1 -22
  173. package/file-picker/index.js +53 -48
  174. package/file-picker/types.d.ts +21 -1
  175. package/file-picker/types.js +1 -1
  176. package/file-picker/utils.js +6 -3
  177. package/file-status/global/index.d.ts +1 -0
  178. package/file-status/global/index.js +2 -0
  179. package/file-status/index.d.ts +2 -22
  180. package/file-status/index.js +33 -22
  181. package/file-status/types.d.ts +21 -1
  182. package/file-status/types.js +1 -1
  183. package/file-status/utils.js +4 -1
  184. package/flag/global/index.d.ts +1 -0
  185. package/flag/global/index.js +2 -0
  186. package/flag/index.d.ts +1 -22
  187. package/flag/index.js +19 -16
  188. package/flag/types.d.ts +21 -1
  189. package/flag/types.js +1 -1
  190. package/flag/utils.js +11 -8
  191. package/grid/global/index.d.ts +1 -0
  192. package/grid/global/index.js +2 -0
  193. package/grid/index.d.ts +1 -22
  194. package/grid/index.js +8 -5
  195. package/grid/types.d.ts +21 -1
  196. package/grid/types.js +1 -1
  197. package/grid-item/global/index.d.ts +1 -0
  198. package/grid-item/global/index.js +2 -0
  199. package/grid-item/index.d.ts +1 -22
  200. package/grid-item/index.js +17 -13
  201. package/grid-item/types.d.ts +21 -1
  202. package/grid-item/types.js +1 -1
  203. package/help-tooltip/global/index.d.ts +1 -0
  204. package/help-tooltip/global/index.js +2 -0
  205. package/help-tooltip/index.d.ts +1 -22
  206. package/help-tooltip/index.js +29 -26
  207. package/help-tooltip/types.d.ts +21 -1
  208. package/help-tooltip/types.js +1 -1
  209. package/icon/generated-icon-type.js +1 -1
  210. package/icon/global/index.d.ts +1 -0
  211. package/icon/global/index.js +2 -0
  212. package/icon/index.d.ts +1 -22
  213. package/icon/index.js +30 -28
  214. package/icon/types.d.ts +21 -1
  215. package/icon/types.js +1 -1
  216. package/inline-alert/global/index.d.ts +1 -0
  217. package/inline-alert/global/index.js +2 -0
  218. package/inline-alert/index.d.ts +2 -22
  219. package/inline-alert/index.js +58 -39
  220. package/inline-alert/types.d.ts +21 -1
  221. package/inline-alert/types.js +1 -1
  222. package/inline-alert/utils.js +4 -1
  223. package/input/global/index.d.ts +1 -0
  224. package/input/global/index.js +2 -0
  225. package/input/index.d.ts +2 -22
  226. package/input/index.js +295 -317
  227. package/input/types.d.ts +21 -1
  228. package/input/types.js +1 -1
  229. package/input/utils.js +56 -46
  230. package/link/global/index.d.ts +1 -0
  231. package/link/global/index.js +2 -0
  232. package/link/index.d.ts +1 -22
  233. package/link/index.js +88 -79
  234. package/link/types.d.ts +21 -1
  235. package/link/types.js +1 -1
  236. package/list/global/index.d.ts +1 -0
  237. package/list/global/index.js +2 -0
  238. package/list/index.d.ts +1 -21
  239. package/list/index.js +9 -6
  240. package/list/types.d.ts +21 -1
  241. package/list/types.js +1 -1
  242. package/list-item/global/index.d.ts +1 -0
  243. package/list-item/global/index.js +2 -0
  244. package/list-item/index.d.ts +1 -22
  245. package/list-item/index.js +9 -6
  246. package/list-item/types.d.ts +21 -1
  247. package/list-item/types.js +1 -1
  248. package/package.json +11 -5
  249. package/pagination/global/index.d.ts +1 -0
  250. package/pagination/global/index.js +2 -0
  251. package/pagination/index.d.ts +2 -22
  252. package/pagination/index.js +64 -46
  253. package/pagination/types.d.ts +21 -1
  254. package/pagination/types.js +1 -1
  255. package/persistent-overlay/global/index.d.ts +1 -0
  256. package/persistent-overlay/global/index.js +2 -0
  257. package/persistent-overlay/index.d.ts +1 -22
  258. package/persistent-overlay/index.js +42 -44
  259. package/persistent-overlay/types.d.ts +21 -1
  260. package/persistent-overlay/types.js +1 -1
  261. package/pop/global/index.d.ts +1 -0
  262. package/pop/global/index.js +2 -0
  263. package/pop/index.d.ts +3 -22
  264. package/pop/index.js +149 -150
  265. package/pop/types.d.ts +21 -1
  266. package/pop/types.js +1 -1
  267. package/pop/utils.js +24 -8
  268. package/popover/global/index.d.ts +1 -0
  269. package/popover/global/index.js +2 -0
  270. package/popover/index.d.ts +2 -22
  271. package/popover/index.js +104 -67
  272. package/popover/types.d.ts +21 -1
  273. package/popover/types.js +1 -1
  274. package/popover/utils.js +18 -7
  275. package/progress/global/index.d.ts +1 -0
  276. package/progress/global/index.js +2 -0
  277. package/progress/index.d.ts +1 -22
  278. package/progress/index.js +31 -33
  279. package/progress/types.d.ts +21 -1
  280. package/progress/types.js +1 -1
  281. package/progress-stepper/global/index.d.ts +1 -0
  282. package/progress-stepper/global/index.js +2 -0
  283. package/progress-stepper/index.d.ts +2 -22
  284. package/progress-stepper/index.js +64 -66
  285. package/progress-stepper/types.d.ts +21 -1
  286. package/progress-stepper/types.js +1 -1
  287. package/progress-stepper-item/global/index.d.ts +1 -0
  288. package/progress-stepper-item/global/index.js +2 -0
  289. package/progress-stepper-item/index.d.ts +1 -22
  290. package/progress-stepper-item/index.js +58 -50
  291. package/progress-stepper-item/types.d.ts +21 -1
  292. package/progress-stepper-item/types.js +1 -1
  293. package/progress-stepper-item/utils.js +22 -11
  294. package/radio/global/index.d.ts +1 -0
  295. package/radio/global/index.js +2 -0
  296. package/radio/index.d.ts +1 -22
  297. package/radio/index.js +79 -83
  298. package/radio/types.d.ts +21 -1
  299. package/radio/types.js +1 -1
  300. package/radio-option/global/index.d.ts +1 -0
  301. package/radio-option/global/index.js +2 -0
  302. package/radio-option/index.d.ts +1 -22
  303. package/radio-option/index.js +47 -41
  304. package/radio-option/types.d.ts +21 -1
  305. package/radio-option/types.js +1 -1
  306. package/rich-text/global/index.d.ts +1 -0
  307. package/rich-text/global/index.js +2 -0
  308. package/rich-text/index.d.ts +1 -22
  309. package/rich-text/index.js +45 -46
  310. package/rich-text/types.d.ts +21 -1
  311. package/rich-text/types.js +1 -1
  312. package/rich-text/utils.js +31 -33
  313. package/rich-textarea/global/index.d.ts +1 -0
  314. package/rich-textarea/global/index.js +2 -0
  315. package/rich-textarea/index.d.ts +1 -22
  316. package/rich-textarea/index.js +201 -194
  317. package/rich-textarea/types.d.ts +21 -1
  318. package/rich-textarea/types.js +1 -1
  319. package/rich-textarea/utils.js +313 -340
  320. package/segment-collapse/global/index.d.ts +1 -0
  321. package/segment-collapse/global/index.js +2 -0
  322. package/segment-collapse/index.d.ts +1 -22
  323. package/segment-collapse/index.js +31 -25
  324. package/segment-collapse/types.d.ts +21 -1
  325. package/segment-collapse/types.js +1 -1
  326. package/segmented-control/global/index.d.ts +1 -0
  327. package/segmented-control/global/index.js +2 -0
  328. package/segmented-control/index.d.ts +1 -22
  329. package/segmented-control/index.js +45 -45
  330. package/segmented-control/types.d.ts +21 -1
  331. package/segmented-control/types.js +1 -1
  332. package/segmented-control-option/global/index.d.ts +1 -0
  333. package/segmented-control-option/global/index.js +2 -0
  334. package/segmented-control-option/index.d.ts +1 -22
  335. package/segmented-control-option/index.js +44 -46
  336. package/segmented-control-option/types.d.ts +21 -1
  337. package/segmented-control-option/types.js +1 -1
  338. package/segmented-icon-control/global/index.d.ts +1 -0
  339. package/segmented-icon-control/global/index.js +2 -0
  340. package/segmented-icon-control/index.d.ts +1 -22
  341. package/segmented-icon-control/index.js +51 -50
  342. package/segmented-icon-control/types.d.ts +21 -1
  343. package/segmented-icon-control/types.js +1 -1
  344. package/segmented-icon-control-option/global/index.d.ts +1 -0
  345. package/segmented-icon-control-option/global/index.js +2 -0
  346. package/segmented-icon-control-option/index.d.ts +1 -22
  347. package/segmented-icon-control-option/index.js +36 -37
  348. package/segmented-icon-control-option/types.d.ts +21 -1
  349. package/segmented-icon-control-option/types.js +1 -1
  350. package/select-button/global/index.d.ts +1 -0
  351. package/select-button/global/index.js +2 -0
  352. package/select-button/index.d.ts +1 -26
  353. package/select-button/index.js +104 -112
  354. package/select-button/types.d.ts +25 -1
  355. package/select-button/types.js +1 -1
  356. package/select-menu/global/index.d.ts +1 -0
  357. package/select-menu/global/index.js +2 -0
  358. package/select-menu/index.d.ts +1 -22
  359. package/select-menu/index.js +201 -164
  360. package/select-menu/types.d.ts +21 -1
  361. package/select-menu/types.js +1 -1
  362. package/select-menu-option/global/index.d.ts +1 -0
  363. package/select-menu-option/global/index.js +2 -0
  364. package/select-menu-option/index.d.ts +1 -22
  365. package/select-menu-option/index.js +42 -33
  366. package/select-menu-option/types.d.ts +21 -1
  367. package/select-menu-option/types.js +1 -1
  368. package/select-menu-option/utils.js +4 -1
  369. package/skeleton/global/index.d.ts +1 -0
  370. package/skeleton/global/index.js +2 -0
  371. package/skeleton/index.d.ts +1 -22
  372. package/skeleton/index.js +35 -38
  373. package/skeleton/types.d.ts +21 -1
  374. package/skeleton/types.js +1 -1
  375. package/skeleton-item/global/index.d.ts +1 -0
  376. package/skeleton-item/global/index.js +2 -0
  377. package/skeleton-item/index.d.ts +1 -22
  378. package/skeleton-item/index.js +8 -5
  379. package/skeleton-item/types.d.ts +21 -1
  380. package/skeleton-item/types.js +1 -1
  381. package/spinner/global/index.d.ts +1 -0
  382. package/spinner/global/index.js +2 -0
  383. package/spinner/index.d.ts +1 -22
  384. package/spinner/index.js +31 -29
  385. package/spinner/types.d.ts +21 -1
  386. package/spinner/types.js +1 -1
  387. package/standalone.d.ts +0 -8
  388. package/standalone.js +79 -87
  389. package/standalone.ts +0 -8
  390. package/stop-events/index.js +12 -12
  391. package/table/global/index.d.ts +1 -0
  392. package/table/global/index.js +2 -0
  393. package/table/index.d.ts +1 -21
  394. package/table/index.js +9 -6
  395. package/table/types.d.ts +21 -1
  396. package/table/types.js +1 -1
  397. package/table-body/global/index.d.ts +1 -0
  398. package/table-body/global/index.js +2 -0
  399. package/table-body/index.d.ts +1 -21
  400. package/table-body/index.js +9 -6
  401. package/table-body/types.d.ts +21 -1
  402. package/table-body/types.js +1 -1
  403. package/table-cell/global/index.d.ts +1 -0
  404. package/table-cell/global/index.js +2 -0
  405. package/table-cell/index.d.ts +2 -22
  406. package/table-cell/index.js +13 -9
  407. package/table-cell/types.d.ts +21 -1
  408. package/table-cell/types.js +1 -1
  409. package/table-cell/utils.js +4 -1
  410. package/table-head/global/index.d.ts +1 -0
  411. package/table-head/global/index.js +2 -0
  412. package/table-head/index.d.ts +1 -21
  413. package/table-head/index.js +9 -6
  414. package/table-head/types.d.ts +21 -1
  415. package/table-head/types.js +1 -1
  416. package/table-head-cell/global/index.d.ts +1 -0
  417. package/table-head-cell/global/index.js +2 -0
  418. package/table-head-cell/index.d.ts +1 -22
  419. package/table-head-cell/index.js +29 -27
  420. package/table-head-cell/types.d.ts +21 -1
  421. package/table-head-cell/types.js +1 -1
  422. package/table-row/global/index.d.ts +1 -0
  423. package/table-row/global/index.js +2 -0
  424. package/table-row/index.d.ts +1 -22
  425. package/table-row/index.js +20 -17
  426. package/table-row/types.d.ts +21 -1
  427. package/table-row/types.js +1 -1
  428. package/tabs/global/index.d.ts +1 -0
  429. package/tabs/global/index.js +2 -0
  430. package/tabs/index.d.ts +2 -22
  431. package/tabs/index.js +32 -35
  432. package/tabs/types.d.ts +21 -1
  433. package/tabs/types.js +1 -1
  434. package/tabs-icon-option/global/index.d.ts +1 -0
  435. package/tabs-icon-option/global/index.js +2 -0
  436. package/tabs-icon-option/index.d.ts +1 -22
  437. package/tabs-icon-option/index.js +38 -40
  438. package/tabs-icon-option/types.d.ts +21 -1
  439. package/tabs-icon-option/types.js +1 -1
  440. package/tabs-option/global/index.d.ts +1 -0
  441. package/tabs-option/global/index.js +2 -0
  442. package/tabs-option/index.d.ts +1 -22
  443. package/tabs-option/index.js +41 -43
  444. package/tabs-option/types.d.ts +21 -1
  445. package/tabs-option/types.js +1 -1
  446. package/tag/colors.js +1 -1
  447. package/tag/global/index.d.ts +1 -0
  448. package/tag/global/index.js +2 -0
  449. package/tag/index.d.ts +1 -22
  450. package/tag/index.js +45 -44
  451. package/tag/types.d.ts +21 -1
  452. package/tag/types.js +1 -1
  453. package/tag/utils.js +7 -3
  454. package/text/global/index.d.ts +1 -0
  455. package/text/global/index.js +2 -0
  456. package/text/index.d.ts +2 -22
  457. package/text/index.js +33 -28
  458. package/text/types.d.ts +21 -1
  459. package/text/types.js +1 -1
  460. package/text/utils.js +4 -1
  461. package/textarea/global/index.d.ts +1 -0
  462. package/textarea/global/index.js +2 -0
  463. package/textarea/index.d.ts +1 -22
  464. package/textarea/index.js +147 -152
  465. package/textarea/types.d.ts +21 -1
  466. package/textarea/types.js +1 -1
  467. package/time-picker/global/index.d.ts +1 -0
  468. package/time-picker/global/index.js +2 -0
  469. package/time-picker/index.d.ts +2 -22
  470. package/time-picker/index.js +119 -123
  471. package/time-picker/types.d.ts +21 -1
  472. package/time-picker/types.js +1 -1
  473. package/time-picker/utils.js +31 -33
  474. package/title/global/index.d.ts +1 -0
  475. package/title/global/index.js +2 -0
  476. package/title/index.d.ts +2 -22
  477. package/title/index.js +32 -31
  478. package/title/types.d.ts +21 -1
  479. package/title/types.js +1 -1
  480. package/title/utils.js +18 -14
  481. package/toast/global/index.d.ts +1 -0
  482. package/toast/global/index.js +2 -0
  483. package/toast/index.d.ts +2 -22
  484. package/toast/index.js +37 -34
  485. package/toast/types.d.ts +21 -1
  486. package/toast/types.js +1 -1
  487. package/toast/utils.js +4 -1
  488. package/toast-manager/global/index.d.ts +1 -0
  489. package/toast-manager/global/index.js +2 -0
  490. package/toast-manager/index.d.ts +3 -22
  491. package/toast-manager/index.js +77 -63
  492. package/toast-manager/types.d.ts +21 -1
  493. package/toast-manager/types.js +1 -1
  494. package/toast-manager/utils.js +4 -1
  495. package/toggle/global/index.d.ts +1 -0
  496. package/toggle/global/index.js +2 -0
  497. package/toggle/index.d.ts +1 -22
  498. package/toggle/index.js +81 -75
  499. package/toggle/types.d.ts +21 -1
  500. package/toggle/types.js +1 -1
  501. package/tooltip/global/index.d.ts +1 -0
  502. package/tooltip/global/index.js +2 -0
  503. package/tooltip/index.d.ts +3 -22
  504. package/tooltip/index.js +105 -93
  505. package/tooltip/tooltip-state.js +56 -64
  506. package/tooltip/types.d.ts +21 -1
  507. package/tooltip/types.js +1 -1
  508. package/tooltip/utils.js +32 -13
  509. package/types.d.ts +12 -29
  510. package/utils/adapters.js +1 -1
  511. package/utils/component-names.d.ts +3 -0
  512. package/utils/component-names.js +85 -0
  513. package/utils/context.js +32 -42
  514. package/utils/countries.js +490 -2
  515. package/utils/csv.js +13 -6
  516. package/utils/debounce.js +10 -3
  517. package/utils/dom.js +60 -53
  518. package/utils/element.d.ts +107 -15
  519. package/utils/element.js +100 -19
  520. package/utils/event-target.js +11 -5
  521. package/utils/form.js +17 -12
  522. package/utils/get-react-event-handler.js +6 -3
  523. package/utils/global-components-constants.d.ts +3 -0
  524. package/utils/global-components-constants.js +8 -0
  525. package/utils/global-components-manager.d.ts +71 -0
  526. package/utils/global-components-manager.js +24 -0
  527. package/utils/index.js +65 -12
  528. package/utils/markdown.js +56 -43
  529. package/utils/rect.js +13 -18
  530. package/utils/shared/global-elements-manager.d.js +1 -0
  531. package/utils/shared/global-elements-manager.d.ts +62 -0
  532. package/utils/shared/global-elements-manager.js +163 -0
  533. package/utils/shared/global-elements-store.d.js +1 -0
  534. package/utils/shared/global-elements-store.d.ts +12 -0
  535. package/utils/shared/global-elements-store.js +31 -0
  536. package/utils/shared/index.d.js +11 -0
  537. package/utils/shared/index.d.ts +3 -0
  538. package/utils/shared/index.js +11 -0
  539. package/utils/shared/nectary-element-base.d.js +1 -0
  540. package/utils/shared/nectary-element-base.d.ts +9 -0
  541. package/utils/shared/nectary-element-base.js +25 -0
  542. package/utils/shared/package.json +9 -0
  543. package/utils/shared/tsconfig.json +20 -0
  544. package/utils/size.js +8 -3
  545. package/utils/slot.js +13 -9
  546. package/utils/throttle.js +5 -2
  547. package/utils/uid.js +5 -2
  548. package/card/index.d.ts +0 -40
  549. package/card/index.js +0 -134
  550. package/card/types.d.ts +0 -17
  551. package/card/types.js +0 -1
  552. package/horizontal-stepper/index.d.ts +0 -33
  553. package/horizontal-stepper/index.js +0 -62
  554. package/horizontal-stepper/types.d.ts +0 -42
  555. package/horizontal-stepper/types.js +0 -1
  556. package/horizontal-stepper-item/index.d.ts +0 -38
  557. package/horizontal-stepper-item/index.js +0 -62
  558. package/horizontal-stepper-item/types.d.ts +0 -38
  559. package/horizontal-stepper-item/types.js +0 -1
  560. package/horizontal-stepper-item/utils.d.ts +0 -2
  561. package/horizontal-stepper-item/utils.js +0 -1
  562. package/segment/index.d.ts +0 -40
  563. package/segment/index.js +0 -110
  564. package/segment/types.d.ts +0 -23
  565. package/segment/types.js +0 -1
  566. package/segment/utils.d.ts +0 -3
  567. package/segment/utils.js +0 -16
  568. package/tile-control/index.d.ts +0 -39
  569. package/tile-control/index.js +0 -111
  570. package/tile-control/types.d.ts +0 -29
  571. package/tile-control/types.js +0 -1
  572. package/tile-control-option/index.d.ts +0 -40
  573. package/tile-control-option/index.js +0 -99
  574. package/tile-control-option/types.d.ts +0 -52
  575. package/tile-control-option/types.js +0 -1
  576. package/vertical-stepper/index.d.ts +0 -33
  577. package/vertical-stepper/index.js +0 -58
  578. package/vertical-stepper/types.d.ts +0 -34
  579. package/vertical-stepper/types.js +0 -1
  580. package/vertical-stepper-item/index.d.ts +0 -38
  581. package/vertical-stepper-item/index.js +0 -62
  582. package/vertical-stepper-item/types.d.ts +0 -42
  583. package/vertical-stepper-item/types.js +0 -1
  584. package/vertical-stepper-item/utils.d.ts +0 -2
  585. package/vertical-stepper-item/utils.js +0 -1
package/text/index.js CHANGED
@@ -1,9 +1,10 @@
1
- import { defineCustomElement, getBooleanAttribute, updateBooleanAttribute, NectaryElement, getLiteralAttribute, updateLiteralAttribute, isAttrTrue, isAttrEqual } from '../utils';
2
- const templateHTML = '<style>:host{text-align:var(--sinch-comp-text-align);display:block;font:var(--sinch-comp-text-font);color:var(--sinch-global-color-text,var(--sinch-sys-color-text-default));--sinch-comp-text-font:var(--sinch-sys-font-body-m);--sinch-comp-text-align:unset}:host([inline]){display:inline}:host([type="s"]){--sinch-comp-text-font:var(--sinch-sys-font-body-s)}:host([type=xs]){--sinch-comp-text-font:var(--sinch-sys-font-body-xs)}:host([type=xxs]){--sinch-comp-text-font:var(--sinch-sys-font-body-xxs)}:host([type="m"][emphasized]){--sinch-comp-text-font:var(--sinch-sys-font-body-emphasize)}:host([type="s"][emphasized]){--sinch-comp-text-font:var(--sinch-sys-font-body-emphasize-s)}:host([ellipsis]){overflow:hidden;text-overflow:ellipsis;white-space:nowrap;--sinch-global-text-white-space:nowrap}</style><slot></slot>';
3
- import { typeValues } from './utils';
4
- const template = document.createElement('template');
1
+ import { isAttrEqual, updateBooleanAttribute, getLiteralAttribute, updateLiteralAttribute, getBooleanAttribute, isAttrTrue } from "../utils/dom.js";
2
+ import { defineCustomElement, NectaryElement } from "../utils/element.js";
3
+ import { typeValues } from "./utils.js";
4
+ const templateHTML = '<style>\n :host {\n text-align: var(--sinch-comp-text-align);\n display: block;\n font: var(--sinch-comp-text-font);\n color: var(--sinch-global-color-text, var(--sinch-sys-color-text-default));\n\n --sinch-comp-text-font: var(--sinch-sys-font-body-m);\n --sinch-comp-text-align: unset;\n }\n\n :host([inline]) {\n display: inline;\n }\n\n :host([type="s"]) {\n --sinch-comp-text-font: var(--sinch-sys-font-body-s);\n }\n\n :host([type="xs"]) {\n --sinch-comp-text-font: var(--sinch-sys-font-body-xs);\n }\n\n :host([type="xxs"]) {\n --sinch-comp-text-font: var(--sinch-sys-font-body-xxs);\n }\n\n :host([type="m"][emphasized]) {\n --sinch-comp-text-font: var(--sinch-sys-font-body-emphasize);\n }\n\n :host([type="s"][emphasized]) {\n --sinch-comp-text-font: var(--sinch-sys-font-body-emphasize-s);\n }\n\n :host([ellipsis]) {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n\n --sinch-global-text-white-space: nowrap;\n }\n</style>\n\n<slot></slot>';
5
+ const template = document.createElement("template");
5
6
  template.innerHTML = templateHTML;
6
- export class Text extends NectaryElement {
7
+ class Text extends NectaryElement {
7
8
  constructor() {
8
9
  super();
9
10
  const shadowRoot = this.attachShadow();
@@ -13,53 +14,57 @@ export class Text extends NectaryElement {
13
14
  this.#updateRole();
14
15
  }
15
16
  static get observedAttributes() {
16
- return ['inline', 'ellipsis', 'emphasized'];
17
+ return ["inline", "ellipsis", "emphasized"];
17
18
  }
18
19
  attributeChangedCallback(name, oldVal, newVal) {
19
20
  if (isAttrEqual(oldVal, newVal)) {
20
21
  return;
21
22
  }
22
23
  switch (name) {
23
- case 'inline':
24
- {
25
- this.#updateRole();
26
- updateBooleanAttribute(this, name, isAttrTrue(newVal));
27
- break;
28
- }
29
- case 'ellipsis':
30
- case 'emphasized':
31
- {
32
- updateBooleanAttribute(this, name, isAttrTrue(newVal));
33
- break;
34
- }
24
+ case "inline": {
25
+ this.#updateRole();
26
+ updateBooleanAttribute(this, name, isAttrTrue(newVal));
27
+ break;
28
+ }
29
+ case "ellipsis":
30
+ case "emphasized": {
31
+ updateBooleanAttribute(this, name, isAttrTrue(newVal));
32
+ break;
33
+ }
35
34
  }
36
35
  }
37
36
  get type() {
38
- return getLiteralAttribute(this, typeValues, 'type');
37
+ return getLiteralAttribute(this, typeValues, "type");
39
38
  }
40
39
  set type(value) {
41
- updateLiteralAttribute(this, typeValues, 'type', value);
40
+ updateLiteralAttribute(this, typeValues, "type", value);
42
41
  }
43
42
  set inline(isInline) {
44
- updateBooleanAttribute(this, 'inline', isInline);
43
+ updateBooleanAttribute(this, "inline", isInline);
45
44
  }
46
45
  get inline() {
47
- return getBooleanAttribute(this, 'inline');
46
+ return getBooleanAttribute(this, "inline");
48
47
  }
49
48
  set ellipsis(isEllipsis) {
50
- updateBooleanAttribute(this, 'ellipsis', isEllipsis);
49
+ updateBooleanAttribute(this, "ellipsis", isEllipsis);
51
50
  }
52
51
  get ellipsis() {
53
- return getBooleanAttribute(this, 'ellipsis');
52
+ return getBooleanAttribute(this, "ellipsis");
54
53
  }
55
54
  set emphasized(isEmphasized) {
56
- updateBooleanAttribute(this, 'emphasized', isEmphasized);
55
+ updateBooleanAttribute(this, "emphasized", isEmphasized);
57
56
  }
58
57
  get emphasized() {
59
- return getBooleanAttribute(this, 'emphasized');
58
+ return getBooleanAttribute(this, "emphasized");
60
59
  }
61
60
  #updateRole() {
62
- this.setAttribute('role', getBooleanAttribute(this, 'inline') ? 'text' : 'paragraph');
61
+ this.setAttribute(
62
+ "role",
63
+ getBooleanAttribute(this, "inline") ? "text" : "paragraph"
64
+ );
63
65
  }
64
66
  }
65
- defineCustomElement('sinch-text', Text);
67
+ defineCustomElement("sinch-text", Text);
68
+ export {
69
+ Text
70
+ };
package/text/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 TSinchTextType = 'm' | 's' | 'xs' | 'xxs';
3
3
  export type TSinchTextProps = {
4
4
  /** Type */
@@ -29,3 +29,23 @@ export type TSinchText = {
29
29
  };
30
30
  export type TSinchTextElement = NectaryComponentVanillaByType<TSinchText>;
31
31
  export type TSinchTextReact = NectaryComponentReactByType<TSinchText>;
32
+ declare global {
33
+ interface NectaryComponentMap {
34
+ 'sinch-text': TSinchText;
35
+ }
36
+ interface HTMLElementTagNameMap {
37
+ 'sinch-text': NectaryComponentVanilla<'sinch-text'>;
38
+ }
39
+ namespace JSX {
40
+ interface IntrinsicElements {
41
+ 'sinch-text': NectaryComponentReact<'sinch-text'>;
42
+ }
43
+ }
44
+ }
45
+ declare module 'react' {
46
+ namespace JSX {
47
+ interface IntrinsicElements extends globalThis.JSX.IntrinsicElements {
48
+ 'sinch-text': NectaryComponentReact<'sinch-text'>;
49
+ }
50
+ }
51
+ }
package/text/types.js CHANGED
@@ -1 +1 @@
1
- export {};
1
+
package/text/utils.js CHANGED
@@ -1 +1,4 @@
1
- export const typeValues = ['m', 's', 'xs', 'xxs'];
1
+ const typeValues = ["m", "s", "xs", "xxs"];
2
+ export {
3
+ typeValues
4
+ };
@@ -0,0 +1 @@
1
+ export * from '../types';
@@ -0,0 +1,2 @@
1
+ import { defineCustomElement } from "../../utils/element.js";
2
+ defineCustomElement("sinch-textarea");
@@ -1,6 +1,5 @@
1
1
  import { NectaryElement } from '../utils';
2
- import type { TSinchTextarea } from './types';
3
- import type { NectaryComponentReact, NectaryComponentVanilla } from '../types';
2
+ export * from './types';
4
3
  export declare class Textarea extends NectaryElement {
5
4
  #private;
6
5
  static formAssociated: boolean;
@@ -38,23 +37,3 @@ export declare class Textarea extends NectaryElement {
38
37
  focus(): void;
39
38
  blur(): void;
40
39
  }
41
- declare global {
42
- interface NectaryComponentMap {
43
- 'sinch-textarea': TSinchTextarea;
44
- }
45
- interface HTMLElementTagNameMap {
46
- 'sinch-textarea': NectaryComponentVanilla<'sinch-textarea'>;
47
- }
48
- namespace JSX {
49
- interface IntrinsicElements {
50
- 'sinch-textarea': NectaryComponentReact<'sinch-textarea'>;
51
- }
52
- }
53
- }
54
- declare module 'react' {
55
- namespace JSX {
56
- interface IntrinsicElements extends globalThis.JSX.IntrinsicElements {
57
- 'sinch-textarea': NectaryComponentReact<'sinch-textarea'>;
58
- }
59
- }
60
- }
package/textarea/index.js CHANGED
@@ -1,10 +1,14 @@
1
- import { Context, defineCustomElement, getAttribute, getBooleanAttribute, getIntegerAttribute, getReactEventHandler, getRect, hasClass, isAttrEqual, isAttrTrue, NectaryElement, setClass, updateAttribute, updateBooleanAttribute } from '../utils';
2
- import { setFormValue } from '../utils/form';
3
- import { DEFAULT_SIZE } from '../utils/size';
4
- const templateHTML = '<style>:host{display:block}#wrapper{display:flex;flex-direction:column;position:relative;width:100%;box-sizing:border-box;background-color:var(--sinch-comp-textarea-color-default-background-initial);border-radius:var(--sinch-local-shape-radius);padding-right:2px;overflow:hidden;--sinch-local-shape-radius:var(--sinch-comp-textarea-shape-radius)}#input{all:initial;display:block;font:var(--sinch-comp-textarea-font-input);color:var(--sinch-comp-textarea-color-default-text-initial);resize:none;white-space:pre-wrap;overflow-wrap:break-word;padding:8px 10px 8px 12px;border:none;box-sizing:border-box}#input::placeholder{color:var(--sinch-comp-textarea-color-default-text-placeholder);opacity:1}#input:disabled{color:var(--sinch-comp-textarea-color-disabled-text-initial);-webkit-text-fill-color:var(--sinch-comp-textarea-color-disabled-text-initial)}#border{position:absolute;border:1px solid var(--sinch-comp-textarea-color-default-border-initial);border-radius:var(--sinch-local-shape-radius);inset:0;pointer-events:none}:host([invalid]) #border{border-color:var(--sinch-comp-textarea-color-invalid-border-initial)}#input:focus+#border{border-color:var(--sinch-comp-textarea-color-default-border-focus);border-width:2px}#input:disabled+#border{border-color:var(--sinch-comp-textarea-color-disabled-border-initial)}#bottom{display:flex;flex-direction:row;align-items:center;gap:8px;padding:12px 4px 4px}#bottom.empty{display:none}:host([resizable]) #bottom{padding-right:calc(var(--sinch-comp-textarea-size-resize-handle) + 4px)}#resize-handle{display:none;position:absolute;width:var(--sinch-comp-textarea-size-resize-handle);height:var(--sinch-comp-textarea-size-resize-handle);bottom:0;right:0;cursor:ns-resize}:host([resizable]) #resize-handle{display:block}#resize-icon{display:block;pointer-events:none;fill:var(--sinch-comp-textarea-color-default-border-initial)}</style><div id="wrapper"><textarea id="input"></textarea><div id="border"></div><div id="bottom"><slot name="bottom"></slot><div id="resize-handle"><svg id="resize-icon" width="16" height="16"><path d="m14.833 4.724-9.61 9.61-.942-.944 9.61-9.609.942.943ZM15.443 10 10.5 14.943 9.557 14 14.5 9.057l.943.943Z"/></svg></div></div></div>';
5
- const template = document.createElement('template');
1
+ import { Context } from "../utils/context.js";
2
+ import { getBooleanAttribute, isAttrEqual, updateBooleanAttribute, hasClass, setClass, updateAttribute, isAttrTrue, getAttribute, getIntegerAttribute } from "../utils/dom.js";
3
+ import { defineCustomElement, NectaryElement } from "../utils/element.js";
4
+ import { getRect } from "../utils/rect.js";
5
+ import { getReactEventHandler } from "../utils/get-react-event-handler.js";
6
+ import { setFormValue } from "../utils/form.js";
7
+ import { DEFAULT_SIZE } from "../utils/size.js";
8
+ const templateHTML = '<style>\n:host {\n display: block;\n}\n\n#wrapper {\n display: flex;\n flex-direction: column;\n position: relative;\n width: 100%;\n box-sizing: border-box;\n background-color: var(--sinch-comp-textarea-color-default-background-initial);\n border-radius: var(--sinch-local-shape-radius);\n padding-right: 2px;\n overflow: hidden;\n\n --sinch-local-shape-radius: var(--sinch-comp-textarea-shape-radius);\n}\n\n#input {\n all: initial;\n display: block;\n font: var(--sinch-comp-textarea-font-input);\n color: var(--sinch-comp-textarea-color-default-text-initial);\n resize: none;\n white-space: pre-wrap;\n overflow-wrap: break-word;\n padding: 8px 10px 8px 12px;\n border: none;\n box-sizing: border-box;\n}\n\n/* #input::-webkit-resizer {\n\n} */\n\n#input::placeholder {\n color: var(--sinch-comp-textarea-color-default-text-placeholder);\n opacity: 1;\n}\n\n#input:disabled {\n color: var(--sinch-comp-textarea-color-disabled-text-initial);\n -webkit-text-fill-color: var(--sinch-comp-textarea-color-disabled-text-initial);\n}\n\n#border {\n position: absolute;\n border: 1px solid var(--sinch-comp-textarea-color-default-border-initial);\n border-radius: var(--sinch-local-shape-radius);\n inset: 0;\n pointer-events: none;\n}\n\n:host([invalid]) #border {\n border-color: var(--sinch-comp-textarea-color-invalid-border-initial);\n}\n\n#input:focus + #border {\n border-color: var(--sinch-comp-textarea-color-default-border-focus);\n border-width: 2px;\n}\n\n#input:disabled + #border {\n border-color: var(--sinch-comp-textarea-color-disabled-border-initial);\n}\n\n#bottom {\n display: flex;\n flex-direction: row;\n align-items: center;\n gap: 8px;\n padding: 12px 4px 4px;\n}\n\n#bottom.empty {\n display: none;\n}\n\n:host([resizable]) #bottom {\n padding-right: calc(var(--sinch-comp-textarea-size-resize-handle) + 4px);\n}\n\n#resize-handle {\n display: none;\n position: absolute;\n width: var(--sinch-comp-textarea-size-resize-handle);\n height: var(--sinch-comp-textarea-size-resize-handle);\n bottom: 0;\n right: 0;\n cursor: ns-resize;\n}\n\n:host([resizable]) #resize-handle {\n display: block;\n}\n\n#resize-icon {\n display: block;\n pointer-events: none;\n fill: var(--sinch-comp-textarea-color-default-border-initial);\n}\n</style>\n\n<div id="wrapper">\n <textarea id="input"></textarea>\n <div id="border"></div>\n <div id="bottom">\n <slot name="bottom"></slot>\n <div id="resize-handle">\n <svg id="resize-icon" width="16" height="16">\n <path d="m14.833 4.724-9.61 9.61-.942-.944 9.61-9.609.942.943ZM15.443 10 10.5 14.943 9.557 14 14.5 9.057l.943.943Z"/>\n </svg>\n </div>\n </div>\n</div>\n';
9
+ const template = document.createElement("template");
6
10
  template.innerHTML = templateHTML;
7
- export class Textarea extends NectaryElement {
11
+ class Textarea extends NectaryElement {
8
12
  #$input;
9
13
  #$bottomSlot;
10
14
  #$bottomWrapper;
@@ -20,16 +24,14 @@ export class Textarea extends NectaryElement {
20
24
  static formAssociated = true;
21
25
  constructor() {
22
26
  super();
23
- const shadowRoot = this.attachShadow({
24
- delegatesFocus: true
25
- });
27
+ const shadowRoot = this.attachShadow({ delegatesFocus: true });
26
28
  shadowRoot.appendChild(template.content.cloneNode(true));
27
29
  this.#internals = this.attachInternals();
28
- this.#$input = shadowRoot.querySelector('#input');
30
+ this.#$input = shadowRoot.querySelector("#input");
29
31
  this.#$bottomSlot = shadowRoot.querySelector('slot[name="bottom"]');
30
- this.#$bottomWrapper = shadowRoot.querySelector('#bottom');
31
- this.#$resizeHandle = shadowRoot.querySelector('#resize-handle');
32
- this.#sizeContext = new Context(this.#$bottomWrapper, 'size');
32
+ this.#$bottomWrapper = shadowRoot.querySelector("#bottom");
33
+ this.#$resizeHandle = shadowRoot.querySelector("#resize-handle");
34
+ this.#sizeContext = new Context(this.#$bottomWrapper, "size");
33
35
  }
34
36
  connectedCallback() {
35
37
  super.connectedCallback();
@@ -37,21 +39,21 @@ export class Textarea extends NectaryElement {
37
39
  const options = {
38
40
  signal: this.#controller.signal
39
41
  };
40
- this.setAttribute('role', 'textbox');
41
- this.#internals.role = 'textbox';
42
- this.ariaMultiLine = 'true';
43
- this.#internals.ariaMultiLine = 'true';
44
- this.#$input.addEventListener('input', this.#onInput, options);
45
- this.#$input.addEventListener('compositionstart', this.#onCompositionStart, options);
46
- this.#$input.addEventListener('mousedown', this.#onSelectionChange, options);
47
- this.#$input.addEventListener('keydown', this.#onSelectionChange, options);
48
- this.#$input.addEventListener('focus', this.#onInputFocus, options);
49
- this.#$input.addEventListener('blur', this.#onInputBlur, options);
50
- this.#$resizeHandle.addEventListener('mousedown', this.#onDragStart, options);
51
- this.#$bottomSlot.addEventListener('slotchange', this.#onBottomSlotChange, options);
52
- this.addEventListener('-change', this.#onChangeReactHandler, options);
53
- this.addEventListener('-focus', this.#onFocusReactHandler, options);
54
- this.addEventListener('-blur', this.#onBlurReactHandler, options);
42
+ this.setAttribute("role", "textbox");
43
+ this.#internals.role = "textbox";
44
+ this.ariaMultiLine = "true";
45
+ this.#internals.ariaMultiLine = "true";
46
+ this.#$input.addEventListener("input", this.#onInput, options);
47
+ this.#$input.addEventListener("compositionstart", this.#onCompositionStart, options);
48
+ this.#$input.addEventListener("mousedown", this.#onSelectionChange, options);
49
+ this.#$input.addEventListener("keydown", this.#onSelectionChange, options);
50
+ this.#$input.addEventListener("focus", this.#onInputFocus, options);
51
+ this.#$input.addEventListener("blur", this.#onInputBlur, options);
52
+ this.#$resizeHandle.addEventListener("mousedown", this.#onDragStart, options);
53
+ this.#$bottomSlot.addEventListener("slotchange", this.#onBottomSlotChange, options);
54
+ this.addEventListener("-change", this.#onChangeReactHandler, options);
55
+ this.addEventListener("-focus", this.#onFocusReactHandler, options);
56
+ this.addEventListener("-blur", this.#onBlurReactHandler, options);
55
57
  this.#sizeContext.listen(this.#controller.signal);
56
58
  this.#onBottomSlotChange();
57
59
  this.#updateMinRows();
@@ -70,149 +72,150 @@ export class Textarea extends NectaryElement {
70
72
  setFormValue(this.#internals, this.#$input.value);
71
73
  }
72
74
  formResetCallback() {
73
- this.#$input.value = '';
74
- setFormValue(this.#internals, '');
75
+ this.#$input.value = "";
76
+ setFormValue(this.#internals, "");
75
77
  }
76
78
  formStateRestoreCallback(state) {
77
- if (this.#internals.form === null || getBooleanAttribute(this.#internals.form, 'data-form-state-restore') === false) {
79
+ if (this.#internals.form === null || getBooleanAttribute(this.#internals.form, "data-form-state-restore") === false) {
78
80
  return;
79
81
  }
80
82
  if (state !== null) {
81
- const value = typeof state === 'string' ? state : state.get(this.name);
82
- this.#$input.value = value?.toString() ?? '';
83
- setFormValue(this.#internals, value?.toString() ?? '');
83
+ const value = typeof state === "string" ? state : state.get(this.name);
84
+ this.#$input.value = value?.toString() ?? "";
85
+ setFormValue(this.#internals, value?.toString() ?? "");
84
86
  }
85
87
  }
86
88
  static get observedAttributes() {
87
- return ['value', 'placeholder', 'invalid', 'disabled', 'rows', 'minrows', 'resizable'];
89
+ return [
90
+ "value",
91
+ "placeholder",
92
+ "invalid",
93
+ "disabled",
94
+ "rows",
95
+ "minrows",
96
+ "resizable"
97
+ ];
88
98
  }
89
99
  attributeChangedCallback(name, oldVal, newVal) {
90
100
  switch (name) {
91
- case 'value':
92
- {
93
- const nextVal = newVal ?? '';
94
- const prevVal = this.#$input.value;
95
- if (nextVal !== prevVal) {
96
- const prevCursorPos = this.#$input.selectionEnd;
97
- const isPrevCursorEnd = prevCursorPos === prevVal.length;
98
- const isShrinkingContent = nextVal.length < prevVal.length;
99
- this.#$input.value = nextVal;
100
- setFormValue(this.#internals, nextVal);
101
- if (!this.resizable) {
102
- if (isShrinkingContent) {
103
- this.#$input.style.removeProperty('height');
104
- }
105
- const nextContentHeight = this.#$input.scrollHeight;
106
- if (isShrinkingContent || nextContentHeight !== this.#prevContentHeight) {
107
- this.#prevContentHeight = nextContentHeight;
108
- this.#$input.style.setProperty('height', `${this.#prevContentHeight}px`);
109
- }
101
+ case "value": {
102
+ const nextVal = newVal ?? "";
103
+ const prevVal = this.#$input.value;
104
+ if (nextVal !== prevVal) {
105
+ const prevCursorPos = this.#$input.selectionEnd;
106
+ const isPrevCursorEnd = prevCursorPos === prevVal.length;
107
+ const isShrinkingContent = nextVal.length < prevVal.length;
108
+ this.#$input.value = nextVal;
109
+ setFormValue(this.#internals, nextVal);
110
+ if (!this.resizable) {
111
+ if (isShrinkingContent) {
112
+ this.#$input.style.removeProperty("height");
110
113
  }
111
- if (!isPrevCursorEnd) {
112
- this.#$input.setSelectionRange(this.#cursorPos, this.#cursorPos);
114
+ const nextContentHeight = this.#$input.scrollHeight;
115
+ if (isShrinkingContent || nextContentHeight !== this.#prevContentHeight) {
116
+ this.#prevContentHeight = nextContentHeight;
117
+ this.#$input.style.setProperty("height", `${this.#prevContentHeight}px`);
113
118
  }
114
119
  }
115
- break;
116
- }
117
- case 'placeholder':
118
- {
119
- this.#$input.placeholder = newVal ?? '';
120
- updateAttribute(this, 'aria-placeholder', newVal);
121
- this.#internals.ariaPlaceholder = newVal ?? '';
122
- break;
123
- }
124
- case 'invalid':
125
- {
126
- if (isAttrEqual(oldVal, newVal)) {
127
- break;
120
+ if (!isPrevCursorEnd) {
121
+ this.#$input.setSelectionRange(this.#cursorPos, this.#cursorPos);
128
122
  }
129
- const isInvalid = isAttrTrue(newVal);
130
- this.ariaInvalid = isInvalid.toString();
131
- this.#internals.ariaInvalid = isInvalid.toString();
132
- updateBooleanAttribute(this, 'invalid', isInvalid);
133
- break;
134
123
  }
135
- case 'disabled':
136
- {
137
- if (isAttrEqual(oldVal, newVal)) {
138
- break;
139
- }
140
- const isDisabled = isAttrTrue(newVal);
141
- this.#$input.disabled = isDisabled;
142
- updateBooleanAttribute(this, 'disabled', isDisabled);
124
+ break;
125
+ }
126
+ case "placeholder": {
127
+ this.#$input.placeholder = newVal ?? "";
128
+ updateAttribute(this, "aria-placeholder", newVal);
129
+ this.#internals.ariaPlaceholder = newVal ?? "";
130
+ break;
131
+ }
132
+ case "invalid": {
133
+ if (isAttrEqual(oldVal, newVal)) {
143
134
  break;
144
135
  }
145
- case 'rows':
146
- {
147
- updateAttribute(this.#$input, 'rows', newVal);
136
+ const isInvalid = isAttrTrue(newVal);
137
+ this.ariaInvalid = isInvalid.toString();
138
+ this.#internals.ariaInvalid = isInvalid.toString();
139
+ updateBooleanAttribute(this, "invalid", isInvalid);
140
+ break;
141
+ }
142
+ case "disabled": {
143
+ if (isAttrEqual(oldVal, newVal)) {
148
144
  break;
149
145
  }
150
- case 'minrows':
151
- {
152
- this.#updateMinRows();
146
+ const isDisabled = isAttrTrue(newVal);
147
+ this.#$input.disabled = isDisabled;
148
+ updateBooleanAttribute(this, "disabled", isDisabled);
149
+ break;
150
+ }
151
+ case "rows": {
152
+ updateAttribute(this.#$input, "rows", newVal);
153
+ break;
154
+ }
155
+ case "minrows": {
156
+ this.#updateMinRows();
157
+ break;
158
+ }
159
+ case "resizable": {
160
+ if (isAttrEqual(oldVal, newVal)) {
153
161
  break;
154
162
  }
155
- case 'resizable':
156
- {
157
- if (isAttrEqual(oldVal, newVal)) {
158
- break;
159
- }
160
- const isNewValTrue = isAttrTrue(newVal);
161
- updateBooleanAttribute(this, name, isNewValTrue);
162
- if (hasClass(this.#$bottomWrapper, 'empty') && isNewValTrue) {
163
- setClass(this.#$bottomWrapper, 'empty', false);
164
- }
165
- break;
163
+ const isNewValTrue = isAttrTrue(newVal);
164
+ updateBooleanAttribute(this, name, isNewValTrue);
165
+ if (hasClass(this.#$bottomWrapper, "empty") && isNewValTrue) {
166
+ setClass(this.#$bottomWrapper, "empty", false);
166
167
  }
168
+ break;
169
+ }
167
170
  }
168
171
  }
169
172
  set name(value) {
170
- updateAttribute(this, 'name', value);
173
+ updateAttribute(this, "name", value);
171
174
  }
172
175
  get name() {
173
- return getAttribute(this, 'name', '');
176
+ return getAttribute(this, "name", "");
174
177
  }
175
178
  set value(value) {
176
- updateAttribute(this, 'value', value);
179
+ updateAttribute(this, "value", value);
177
180
  }
178
181
  get value() {
179
- return getAttribute(this, 'value', '');
182
+ return getAttribute(this, "value", "");
180
183
  }
181
184
  set placeholder(value) {
182
- updateAttribute(this, 'placeholder', value);
185
+ updateAttribute(this, "placeholder", value);
183
186
  }
184
187
  get placeholder() {
185
- return getAttribute(this, 'placeholder');
188
+ return getAttribute(this, "placeholder");
186
189
  }
187
190
  set invalid(value) {
188
- updateBooleanAttribute(this, 'invalid', value);
191
+ updateBooleanAttribute(this, "invalid", value);
189
192
  }
190
193
  get invalid() {
191
- return getBooleanAttribute(this, 'invalid');
194
+ return getBooleanAttribute(this, "invalid");
192
195
  }
193
196
  set disabled(isDisabled) {
194
- updateBooleanAttribute(this, 'disabled', isDisabled);
197
+ updateBooleanAttribute(this, "disabled", isDisabled);
195
198
  }
196
199
  get disabled() {
197
- return getBooleanAttribute(this, 'disabled');
200
+ return getBooleanAttribute(this, "disabled");
198
201
  }
199
202
  set resizable(isResizable) {
200
- updateBooleanAttribute(this, 'resizable', isResizable);
203
+ updateBooleanAttribute(this, "resizable", isResizable);
201
204
  }
202
205
  get resizable() {
203
- return getBooleanAttribute(this, 'resizable');
206
+ return getBooleanAttribute(this, "resizable");
204
207
  }
205
208
  set rows(value) {
206
- updateAttribute(this, 'rows', value);
209
+ updateAttribute(this, "rows", value);
207
210
  }
208
211
  get rows() {
209
- return getIntegerAttribute(this, 'rows', 0);
212
+ return getIntegerAttribute(this, "rows", 0);
210
213
  }
211
214
  set minRows(value) {
212
- updateAttribute(this, 'minrows', value);
215
+ updateAttribute(this, "minrows", value);
213
216
  }
214
217
  get minRows() {
215
- return getIntegerAttribute(this, 'minrows', 0);
218
+ return getIntegerAttribute(this, "minrows", 0);
216
219
  }
217
220
  get selectionStart() {
218
221
  return this.#$input.selectionStart;
@@ -244,7 +247,7 @@ export class Textarea extends NectaryElement {
244
247
  #updateMinRows() {
245
248
  const minRows = this.minRows;
246
249
  if (minRows <= 0) {
247
- this.#$input.style.removeProperty('min-height');
250
+ this.#$input.style.removeProperty("min-height");
248
251
  if (this.#intersectionObserver !== null) {
249
252
  this.#intersectionObserver.disconnect();
250
253
  this.#intersectionObserver = null;
@@ -254,22 +257,19 @@ export class Textarea extends NectaryElement {
254
257
  this.#calcMinRows();
255
258
  }
256
259
  if (this.#intersectionObserver === null) {
257
- this.#intersectionObserver = new IntersectionObserver(this.#intersectionObserverCallback, {
258
- root: null
259
- });
260
+ this.#intersectionObserver = new IntersectionObserver(this.#intersectionObserverCallback, { root: null });
260
261
  this.#intersectionObserver.observe(this.#$input);
261
262
  }
262
263
  }
263
264
  }
264
- #intersectionObserverCallback = _ref => {
265
- let [entry] = _ref;
265
+ #intersectionObserverCallback = ([entry]) => {
266
266
  if (entry != null && entry.isIntersecting) {
267
267
  this.#calcMinRows();
268
268
  }
269
269
  };
270
270
  #calcMinRows() {
271
271
  this.#$input.rows = this.minRows;
272
- this.#$input.style.setProperty('min-height', `${getRect(this.#$input).height}px`);
272
+ this.#$input.style.setProperty("min-height", `${getRect(this.#$input).height}px`);
273
273
  this.#$input.rows = this.rows;
274
274
  }
275
275
  #onCompositionStart = () => {
@@ -278,7 +278,7 @@ export class Textarea extends NectaryElement {
278
278
  #onSelectionChange = () => {
279
279
  this.#cursorPos = this.#$input.selectionEnd;
280
280
  };
281
- #onInput = e => {
281
+ #onInput = (e) => {
282
282
  e.stopPropagation();
283
283
  const nextValue = this.#$input.value;
284
284
  const prevValue = this.value;
@@ -295,68 +295,63 @@ export class Textarea extends NectaryElement {
295
295
  }
296
296
  this.#isPendingDk = false;
297
297
  this.#cursorPos = nextCursorPos;
298
- this.dispatchEvent(new CustomEvent('-change', {
299
- detail: nextValue
300
- }));
298
+ this.dispatchEvent(
299
+ new CustomEvent("-change", {
300
+ detail: nextValue
301
+ })
302
+ );
301
303
  }
302
304
  };
303
- #onDragStart = e => {
305
+ #onDragStart = (e) => {
304
306
  if (this.#dragStartY !== 0) {
305
307
  return;
306
308
  }
307
309
  this.#dragStartY = e.clientY;
308
310
  this.#prevContentHeight = getRect(this.#$input).height;
309
- window.addEventListener('mousemove', this.#onDragResize, {
310
- signal: this.#controller.signal,
311
- capture: true
312
- });
313
- window.addEventListener('mouseup', this.#onDragEnd, {
314
- signal: this.#controller.signal,
315
- capture: true
316
- });
311
+ window.addEventListener("mousemove", this.#onDragResize, { signal: this.#controller.signal, capture: true });
312
+ window.addEventListener("mouseup", this.#onDragEnd, { signal: this.#controller.signal, capture: true });
317
313
  };
318
- #onDragResize = e => {
314
+ #onDragResize = (e) => {
319
315
  const dy = e.clientY - this.#dragStartY;
320
316
  const height = Math.round(Math.max(0, this.#prevContentHeight + dy));
321
- this.#$input.style.setProperty('height', `${height}px`);
317
+ this.#$input.style.setProperty("height", `${height}px`);
322
318
  };
323
319
  #onDragEnd = () => {
324
- window.removeEventListener('mousemove', this.#onDragResize, {
325
- capture: true
326
- });
327
- window.removeEventListener('mouseup', this.#onDragEnd, {
328
- capture: true
329
- });
320
+ window.removeEventListener("mousemove", this.#onDragResize, { capture: true });
321
+ window.removeEventListener("mouseup", this.#onDragEnd, { capture: true });
330
322
  this.#dragStartY = 0;
331
323
  this.#prevContentHeight = 0;
332
324
  };
333
325
  #onInputFocus = () => {
334
- this.dispatchEvent(new CustomEvent('-focus'));
326
+ this.dispatchEvent(new CustomEvent("-focus"));
335
327
  };
336
328
  #onInputBlur = () => {
337
- this.dispatchEvent(new CustomEvent('-blur'));
329
+ this.dispatchEvent(new CustomEvent("-blur"));
338
330
  };
339
331
  #onBottomSlotChange = () => {
340
332
  const isEmpty = this.#$bottomSlot.assignedElements().length === 0;
341
333
  if (!this.resizable) {
342
- setClass(this.#$bottomWrapper, 'empty', isEmpty);
334
+ setClass(this.#$bottomWrapper, "empty", isEmpty);
343
335
  }
344
336
  };
345
337
  #onSizeUpdate() {
346
338
  if (!this.isDomConnected) {
347
339
  return;
348
340
  }
349
- const size = this.getAttribute('data-size') ?? DEFAULT_SIZE;
341
+ const size = this.getAttribute("data-size") ?? DEFAULT_SIZE;
350
342
  this.#sizeContext.dispatch(size);
351
343
  }
352
- #onChangeReactHandler = e => {
353
- getReactEventHandler(this, 'on-change')?.(e);
344
+ #onChangeReactHandler = (e) => {
345
+ getReactEventHandler(this, "on-change")?.(e);
354
346
  };
355
347
  #onFocusReactHandler = () => {
356
- getReactEventHandler(this, 'on-focus')?.();
348
+ getReactEventHandler(this, "on-focus")?.();
357
349
  };
358
350
  #onBlurReactHandler = () => {
359
- getReactEventHandler(this, 'on-blur')?.();
351
+ getReactEventHandler(this, "on-blur")?.();
360
352
  };
361
353
  }
362
- defineCustomElement('sinch-textarea', Textarea);
354
+ defineCustomElement("sinch-textarea", Textarea);
355
+ export {
356
+ Textarea
357
+ };