@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,12 +1,17 @@
1
- import '../icon';
2
- import '../text';
3
- import { defineCustomElement, getAttribute, getBooleanAttribute, getReactEventHandler, getRect, getTargetAttribute, isAttrTrue, NectaryElement, packCsv, setClass, unpackCsv, updateAttribute, updateBooleanAttribute } from '../utils';
4
- import { setFormValue } from '../utils/form';
5
- const templateHTML = '<style>:host{display:block;outline:0}#content{width:fit-content;box-sizing:border-box;padding:16px;display:flex;flex-direction:column;gap:8px}#month{display:flex;flex-direction:column;row-gap:8px}.week{display:flex;flex-direction:row;column-gap:8px}.week.empty{display:none}.day{all:initial;font:var(--sinch-comp-date-picker-font-day);width:24px;height:24px;line-height:22px;color:var(--sinch-comp-date-picker-day-color-default-text-initial);background-color:var(--sinch-comp-date-picker-day-color-default-background-initial);border:1px solid var(--sinch-comp-date-picker-day-color-default-border-initial);border-radius:var(--sinch-comp-date-picker-day-shape-radius);text-align:center;box-sizing:border-box;user-select:none;cursor:pointer}.day:focus-visible{outline:1px solid var(--sinch-comp-date-picker-day-color-default-outline-focus);outline-offset:1px}.day:disabled{cursor:initial;color:var(--sinch-comp-date-picker-day-color-disabled-text-initial)}.day:enabled:hover{background-color:var(--sinch-comp-date-picker-day-color-default-background-hover)}.day:enabled.range{background-color:var(--sinch-comp-date-picker-day-color-default-range-background)}.day:enabled.selected{color:var(--sinch-comp-date-picker-day-color-checked-text-initial);background-color:var(--sinch-comp-date-picker-day-color-checked-background-initial);border-color:var(--sinch-comp-date-picker-day-color-checked-border-initial)}.day.today{font:var(--sinch-comp-date-picker-font-today);color:var(--sinch-comp-date-picker-today-color-default-text-initial);background-color:var(--sinch-comp-date-picker-today-color-default-background-initial);border-color:var(--sinch-comp-date-picker-today-color-default-border-initial)}.day.today:hover{background-color:var(--sinch-comp-date-picker-today-color-default-background-hover)}.day.today:disabled{color:var(--sinch-comp-date-picker-today-color-disabled-text-initial);border-color:var(--sinch-comp-date-picker-today-color-disabled-border-initial)}.day.today.selected{color:var(--sinch-comp-date-picker-today-color-checked-text-initial);background-color:var(--sinch-comp-date-picker-today-color-checked-background-initial);border-color:var(--sinch-comp-date-picker-today-color-checked-border-initial)}#week-day-names{display:flex;flex-direction:row;gap:8px;height:24px}.week-day-name{font:var(--sinch-comp-date-picker-font-weekday);color:var(--sinch-comp-date-picker-weekday-color-default-text-initial);text-align:center;width:24px;height:24px;line-height:24px;user-select:none;text-transform:uppercase}#content-header{display:flex;flex-direction:row;height:32px;align-items:center}#date{flex:1;text-align:center;text-transform:capitalize;--sinch-com-text-font:var(--sinch-comp-date-picker-font-header);--sinch-global-color-text:var(--sinch-comp-date-picker-header-color-default-text-initial)}#prev-year{margin-left:-4px}#next-year{margin-right:-4px}</style><div id="content"><div id="content-header"><sinch-button id="prev-year" size="s"><sinch-icon icons-version="2" name="fa-angles-left" id="icon-prev-year" slot="icon"></sinch-icon></sinch-button><sinch-button id="prev-month" size="s"><sinch-icon icons-version="2" name="fa-angle-left" id="icon-prev-month" slot="icon"></sinch-icon></sinch-button><sinch-text id="date" type="m" emphasized aria-live="polite"></sinch-text><sinch-button id="next-month" size="s"><sinch-icon icons-version="2" name="fa-angle-right" id="icon-next-month" slot="icon"></sinch-icon></sinch-button><sinch-button id="next-year" size="s"><sinch-icon icons-version="2" name="fa-angles-right" id="icon-next-year" slot="icon"></sinch-icon></sinch-button></div><div id="week-day-names"><div class="week-day-name"></div><div class="week-day-name"></div><div class="week-day-name"></div><div class="week-day-name"></div><div class="week-day-name"></div><div class="week-day-name"></div><div class="week-day-name"></div></div><div id="month"><div class="week"><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button></div><div class="week"><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button></div><div class="week"><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button></div><div class="week"><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button></div><div class="week"><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button></div><div class="week"><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button></div></div></div>';
6
- import { areDatesEqual, canGoNextMonth, canGoNextYear, canGoPrevMonth, canGoPrevYear, clampMaxDate, clampMinDate, cloneDate, dateToIso, decMonth, decYear, getCalendarMonth, getDayNames, getMonthNames, incMonth, incYear, isDateBetween, isDateOnScreen, isoToDate, isValidDate, sortDates, today } from './utils';
7
- const template = document.createElement('template');
1
+ import "../icon/index.js";
2
+ import "../text/index.js";
3
+ import { packCsv, unpackCsv } from "../utils/csv.js";
4
+ import { getBooleanAttribute, updateAttribute, getAttribute, updateBooleanAttribute, setClass, isAttrTrue } from "../utils/dom.js";
5
+ import { defineCustomElement, NectaryElement } from "../utils/element.js";
6
+ import { getRect } from "../utils/rect.js";
7
+ import { getReactEventHandler } from "../utils/get-react-event-handler.js";
8
+ import { getTargetAttribute } from "../utils/event-target.js";
9
+ import { setFormValue } from "../utils/form.js";
10
+ import { getDayNames, getMonthNames, isoToDate, clampMaxDate, clampMinDate, decMonth, incMonth, decYear, incYear, today, isDateBetween, areDatesEqual, sortDates, dateToIso, isValidDate, isDateOnScreen, cloneDate, getCalendarMonth, canGoPrevMonth, canGoNextMonth, canGoPrevYear, canGoNextYear } from "./utils.js";
11
+ const templateHTML = '<style>\n :host {\n display: block;\n outline: none;\n }\n\n #content {\n width: fit-content;\n box-sizing: border-box;\n padding: 16px;\n display: flex;\n flex-direction: column;\n gap: 8px;\n }\n\n #month {\n display: flex;\n flex-direction: column;\n row-gap: 8px;\n }\n\n .week {\n display: flex;\n flex-direction: row;\n column-gap: 8px;\n }\n\n .week.empty {\n display: none;\n }\n\n .day {\n all: initial;\n font: var(--sinch-comp-date-picker-font-day);\n width: 24px;\n height: 24px;\n line-height: 22px;\n color: var(--sinch-comp-date-picker-day-color-default-text-initial);\n background-color:\n var(\n --sinch-comp-date-picker-day-color-default-background-initial\n );\n border:\n 1px solid\n var(--sinch-comp-date-picker-day-color-default-border-initial);\n border-radius: var(--sinch-comp-date-picker-day-shape-radius);\n text-align: center;\n box-sizing: border-box;\n user-select: none;\n cursor: pointer;\n }\n\n .day:focus-visible {\n outline:\n 1px solid\n var(--sinch-comp-date-picker-day-color-default-outline-focus);\n outline-offset: 1px;\n }\n\n .day:disabled {\n cursor: initial;\n color: var(--sinch-comp-date-picker-day-color-disabled-text-initial);\n }\n\n .day:enabled:hover {\n background-color:\n var(\n --sinch-comp-date-picker-day-color-default-background-hover\n );\n }\n\n .day:enabled.range {\n background-color:\n var(\n --sinch-comp-date-picker-day-color-default-range-background\n );\n }\n\n .day:enabled.selected {\n color: var(--sinch-comp-date-picker-day-color-checked-text-initial);\n background-color:\n var(\n --sinch-comp-date-picker-day-color-checked-background-initial\n );\n border-color:\n var(\n --sinch-comp-date-picker-day-color-checked-border-initial\n );\n }\n\n .day.today {\n font: var(--sinch-comp-date-picker-font-today);\n color: var(--sinch-comp-date-picker-today-color-default-text-initial);\n background-color:\n var(\n --sinch-comp-date-picker-today-color-default-background-initial\n );\n border-color:\n var(\n --sinch-comp-date-picker-today-color-default-border-initial\n );\n }\n\n .day.today:hover {\n background-color:\n var(\n --sinch-comp-date-picker-today-color-default-background-hover\n );\n }\n\n .day.today:disabled {\n color: var(--sinch-comp-date-picker-today-color-disabled-text-initial);\n border-color:\n var(\n --sinch-comp-date-picker-today-color-disabled-border-initial\n );\n }\n\n .day.today.selected {\n color: var(--sinch-comp-date-picker-today-color-checked-text-initial);\n background-color:\n var(\n --sinch-comp-date-picker-today-color-checked-background-initial\n );\n border-color:\n var(\n --sinch-comp-date-picker-today-color-checked-border-initial\n );\n }\n\n #week-day-names {\n display: flex;\n flex-direction: row;\n gap: 8px;\n height: 24px;\n }\n\n .week-day-name {\n font: var(--sinch-comp-date-picker-font-weekday);\n color: var(--sinch-comp-date-picker-weekday-color-default-text-initial);\n text-align: center;\n width: 24px;\n height: 24px;\n line-height: 24px;\n user-select: none;\n text-transform: uppercase;\n }\n\n #content-header {\n display: flex;\n flex-direction: row;\n height: 32px;\n align-items: center;\n }\n\n #date {\n flex: 1;\n text-align: center;\n text-transform: capitalize;\n\n --sinch-com-text-font: var(--sinch-comp-date-picker-font-header);\n --sinch-global-color-text:\n var(\n --sinch-comp-date-picker-header-color-default-text-initial\n );\n }\n\n #prev-year {\n margin-left: -4px;\n }\n\n #next-year {\n margin-right: -4px;\n }\n</style>\n\n<div id="content">\n <div id="content-header">\n <sinch-button id="prev-year" size="s">\n <sinch-icon icons-version="2" name="fa-angles-left"\n id="icon-prev-year"\n slot="icon"\n ></sinch-icon>\n </sinch-button>\n <sinch-button id="prev-month" size="s">\n <sinch-icon icons-version="2" name="fa-angle-left"\n id="icon-prev-month"\n slot="icon"\n ></sinch-icon>\n </sinch-button>\n <sinch-text id="date" type="m" emphasized aria-live="polite"></sinch-text>\n <sinch-button id="next-month" size="s">\n <sinch-icon icons-version="2" name="fa-angle-right"\n id="icon-next-month"\n slot="icon"\n ></sinch-icon>\n </sinch-button>\n <sinch-button id="next-year" size="s">\n <sinch-icon icons-version="2" name="fa-angles-right"\n id="icon-next-year"\n slot="icon"\n ></sinch-icon>\n </sinch-button>\n </div>\n <div id="week-day-names">\n <div class="week-day-name"></div>\n <div class="week-day-name"></div>\n <div class="week-day-name"></div>\n <div class="week-day-name"></div>\n <div class="week-day-name"></div>\n <div class="week-day-name"></div>\n <div class="week-day-name"></div>\n </div>\n <div id="month">\n <div class="week">\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n </div>\n <div class="week">\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n </div>\n <div class="week">\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n </div>\n <div class="week">\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n </div>\n <div class="week">\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n </div>\n <div class="week">\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n <button class="day"></button>\n </div>\n </div>\n</div>\n';
12
+ const template = document.createElement("template");
8
13
  template.innerHTML = templateHTML;
9
- export class DatePicker extends NectaryElement {
14
+ class DatePicker extends NectaryElement {
10
15
  #$month;
11
16
  #$weeks;
12
17
  #$days;
@@ -28,40 +33,38 @@ export class DatePicker extends NectaryElement {
28
33
  static formAssociated = true;
29
34
  constructor() {
30
35
  super();
31
- const shadowRoot = this.attachShadow({
32
- delegatesFocus: true
33
- });
36
+ const shadowRoot = this.attachShadow({ delegatesFocus: true });
34
37
  shadowRoot.appendChild(template.content.cloneNode(true));
35
38
  this.#internals = this.attachInternals();
36
- this.#$prevMonth = shadowRoot.querySelector('#prev-month');
37
- this.#$nextMonth = shadowRoot.querySelector('#next-month');
38
- this.#$prevYear = shadowRoot.querySelector('#prev-year');
39
- this.#$nextYear = shadowRoot.querySelector('#next-year');
40
- this.#$date = shadowRoot.querySelector('#date');
41
- this.#$month = shadowRoot.querySelector('#month');
39
+ this.#$prevMonth = shadowRoot.querySelector("#prev-month");
40
+ this.#$nextMonth = shadowRoot.querySelector("#next-month");
41
+ this.#$prevYear = shadowRoot.querySelector("#prev-year");
42
+ this.#$nextYear = shadowRoot.querySelector("#next-year");
43
+ this.#$date = shadowRoot.querySelector("#date");
44
+ this.#$month = shadowRoot.querySelector("#month");
42
45
  this.#$days = [];
43
46
  this.#$weeks = [];
44
47
  this.#monthNames = [];
45
- shadowRoot.querySelectorAll('.week').forEach((week, i) => {
48
+ shadowRoot.querySelectorAll(".week").forEach((week, i) => {
46
49
  this.#$weeks.push(week);
47
50
  this.#$days[i] = [];
48
- week.querySelectorAll('.day').forEach(day => {
51
+ week.querySelectorAll(".day").forEach((day) => {
49
52
  this.#$days[i].push(day);
50
53
  });
51
54
  });
52
- this.#$weekDayNames = Array.from(shadowRoot.querySelectorAll('#week-day-names > .week-day-name'));
55
+ this.#$weekDayNames = Array.from(shadowRoot.querySelectorAll("#week-day-names > .week-day-name"));
53
56
  }
54
57
  connectedCallback() {
55
58
  this.#controller = new AbortController();
56
59
  const options = {
57
60
  signal: this.#controller.signal
58
61
  };
59
- this.#$prevMonth.addEventListener('click', this.#onPrevMonthClick, options);
60
- this.#$nextMonth.addEventListener('click', this.#onNextMonthClick, options);
61
- this.#$prevYear.addEventListener('click', this.#onPrevYearClick, options);
62
- this.#$nextYear.addEventListener('click', this.#onNextYearClick, options);
63
- this.#$month.addEventListener('click', this.#onDateClick, options);
64
- this.addEventListener('-change', this.#onChangeReactHandler, options);
62
+ this.#$prevMonth.addEventListener("click", this.#onPrevMonthClick, options);
63
+ this.#$nextMonth.addEventListener("click", this.#onNextMonthClick, options);
64
+ this.#$prevYear.addEventListener("click", this.#onPrevYearClick, options);
65
+ this.#$nextYear.addEventListener("click", this.#onNextYearClick, options);
66
+ this.#$month.addEventListener("click", this.#onDateClick, options);
67
+ this.addEventListener("-change", this.#onChangeReactHandler, options);
65
68
  }
66
69
  disconnectedCallback() {
67
70
  this.#unsubscribeRangeHover();
@@ -72,136 +75,137 @@ export class DatePicker extends NectaryElement {
72
75
  setFormValue(this.#internals, this.value);
73
76
  }
74
77
  formResetCallback() {
75
- this.value = '';
76
- setFormValue(this.#internals, '');
78
+ this.value = "";
79
+ setFormValue(this.#internals, "");
77
80
  }
78
81
  formStateRestoreCallback(state) {
79
- if (this.#internals.form === null || getBooleanAttribute(this.#internals.form, 'data-form-state-restore') === false) {
82
+ if (this.#internals.form === null || getBooleanAttribute(this.#internals.form, "data-form-state-restore") === false) {
80
83
  return;
81
84
  }
82
85
  if (state !== null) {
83
- const value = typeof state === 'string' ? state : state.get(this.name);
84
- this.value = value?.toString() ?? '';
85
- setFormValue(this.#internals, value?.toString() ?? '');
86
+ const value = typeof state === "string" ? state : state.get(this.name);
87
+ this.value = value?.toString() ?? "";
88
+ setFormValue(this.#internals, value?.toString() ?? "");
86
89
  }
87
90
  }
88
91
  static get observedAttributes() {
89
- return ['value', 'min', 'max', 'locale', 'range', 'prev-year-aria-label', 'next-year-aria-label', 'prev-month-aria-label', 'next-month-aria-label'];
92
+ return [
93
+ "value",
94
+ "min",
95
+ "max",
96
+ "locale",
97
+ "range",
98
+ "prev-year-aria-label",
99
+ "next-year-aria-label",
100
+ "prev-month-aria-label",
101
+ "next-month-aria-label"
102
+ ];
90
103
  }
91
104
  attributeChangedCallback(name, prevValue, newVal) {
92
105
  switch (name) {
93
- case 'value':
94
- {
95
- this.#onValueChange();
96
- break;
97
- }
98
- case 'min':
99
- {
100
- this.#minDate = isoToDate(newVal);
101
- if (this.#uiDate !== null) {
102
- clampMinDate(this.#uiDate, this.#minDate);
103
- }
104
- this.#render();
105
- break;
106
- }
107
- case 'max':
108
- {
109
- this.#maxDate = isoToDate(newVal);
110
- if (this.#uiDate !== null) {
111
- clampMaxDate(this.#uiDate, this.#maxDate);
112
- }
113
- this.#render();
114
- break;
115
- }
116
- case 'locale':
117
- {
118
- const names = getDayNames(newVal);
119
- this.#$weekDayNames.forEach(($day, i) => {
120
- $day.textContent = names[i];
121
- });
122
- this.#monthNames = getMonthNames(newVal);
123
- this.#render();
124
- break;
125
- }
126
- case 'range':
127
- {
128
- const isRange = isAttrTrue(newVal);
129
- if (isRange) {
130
- this.#onValueChange();
131
- } else {
132
- this.#unsubscribeRangeHover();
133
- }
134
- break;
135
- }
136
- case 'prev-year-aria-label':
137
- {
138
- updateAttribute(this.#$prevYear, 'aria-label', newVal);
139
- break;
140
- }
141
- case 'next-year-aria-label':
142
- {
143
- updateAttribute(this.#$nextYear, 'aria-label', newVal);
144
- break;
106
+ case "value": {
107
+ this.#onValueChange();
108
+ break;
109
+ }
110
+ case "min": {
111
+ this.#minDate = isoToDate(newVal);
112
+ if (this.#uiDate !== null) {
113
+ clampMinDate(this.#uiDate, this.#minDate);
145
114
  }
146
- case 'prev-month-aria-label':
147
- {
148
- updateAttribute(this.#$prevMonth, 'aria-label', newVal);
149
- break;
115
+ this.#render();
116
+ break;
117
+ }
118
+ case "max": {
119
+ this.#maxDate = isoToDate(newVal);
120
+ if (this.#uiDate !== null) {
121
+ clampMaxDate(this.#uiDate, this.#maxDate);
150
122
  }
151
- case 'next-month-aria-label':
152
- {
153
- updateAttribute(this.#$nextMonth, 'aria-label', newVal);
154
- break;
123
+ this.#render();
124
+ break;
125
+ }
126
+ case "locale": {
127
+ const names = getDayNames(newVal);
128
+ this.#$weekDayNames.forEach(($day, i) => {
129
+ $day.textContent = names[i];
130
+ });
131
+ this.#monthNames = getMonthNames(newVal);
132
+ this.#render();
133
+ break;
134
+ }
135
+ case "range": {
136
+ const isRange = isAttrTrue(newVal);
137
+ if (isRange) {
138
+ this.#onValueChange();
139
+ } else {
140
+ this.#unsubscribeRangeHover();
155
141
  }
142
+ break;
143
+ }
144
+ case "prev-year-aria-label": {
145
+ updateAttribute(this.#$prevYear, "aria-label", newVal);
146
+ break;
147
+ }
148
+ case "next-year-aria-label": {
149
+ updateAttribute(this.#$nextYear, "aria-label", newVal);
150
+ break;
151
+ }
152
+ case "prev-month-aria-label": {
153
+ updateAttribute(this.#$prevMonth, "aria-label", newVal);
154
+ break;
155
+ }
156
+ case "next-month-aria-label": {
157
+ updateAttribute(this.#$nextMonth, "aria-label", newVal);
158
+ break;
159
+ }
156
160
  }
157
161
  }
158
162
  set name(value) {
159
- updateAttribute(this, 'name', value);
163
+ updateAttribute(this, "name", value);
160
164
  }
161
165
  get name() {
162
- return getAttribute(this, 'name', '');
166
+ return getAttribute(this, "name", "");
163
167
  }
164
168
  set locale(value) {
165
- updateAttribute(this, 'locale', value);
169
+ updateAttribute(this, "locale", value);
166
170
  }
167
171
  get locale() {
168
- return getAttribute(this, 'locale', '');
172
+ return getAttribute(this, "locale", "");
169
173
  }
170
174
  set value(value) {
171
- updateAttribute(this, 'value', value);
175
+ updateAttribute(this, "value", value);
172
176
  }
173
177
  get value() {
174
- return getAttribute(this, 'value', '');
178
+ return getAttribute(this, "value", "");
175
179
  }
176
180
  set min(value) {
177
- updateAttribute(this, 'min', value);
181
+ updateAttribute(this, "min", value);
178
182
  }
179
183
  get min() {
180
- return getAttribute(this, 'min', '');
184
+ return getAttribute(this, "min", "");
181
185
  }
182
186
  set max(value) {
183
- updateAttribute(this, 'max', value);
187
+ updateAttribute(this, "max", value);
184
188
  }
185
189
  get max() {
186
- return getAttribute(this, 'max', '');
190
+ return getAttribute(this, "max", "");
187
191
  }
188
192
  set range(isRanged) {
189
- updateBooleanAttribute(this, 'range', isRanged);
193
+ updateBooleanAttribute(this, "range", isRanged);
190
194
  }
191
195
  get range() {
192
- return getBooleanAttribute(this, 'range');
196
+ return getBooleanAttribute(this, "range");
193
197
  }
194
198
  set prevMonthAriaLabel(value) {
195
- updateAttribute(this, 'prev-month-aria-label', value);
199
+ updateAttribute(this, "prev-month-aria-label", value);
196
200
  }
197
201
  get prevMonthAriaLabel() {
198
- return getAttribute(this, 'prev-month-aria-label', '');
202
+ return getAttribute(this, "prev-month-aria-label", "");
199
203
  }
200
204
  set nextMonthAriaLabel(value) {
201
- updateAttribute(this, 'next-month-aria-label', value);
205
+ updateAttribute(this, "next-month-aria-label", value);
202
206
  }
203
207
  get nextMonthAriaLabel() {
204
- return getAttribute(this, 'next-month-aria-label', '');
208
+ return getAttribute(this, "next-month-aria-label", "");
205
209
  }
206
210
  get prevYearButtonRect() {
207
211
  return getRect(this.#$prevYear);
@@ -219,7 +223,7 @@ export class DatePicker extends NectaryElement {
219
223
  if (index < 0 || index > 30) {
220
224
  return null;
221
225
  }
222
- const indexOffset = this.#$days[0].findIndex(el => el.getAttribute('data-date') !== null);
226
+ const indexOffset = this.#$days[0].findIndex((el) => el.getAttribute("data-date") !== null);
223
227
  if (indexOffset < 0) {
224
228
  return null;
225
229
  }
@@ -231,29 +235,29 @@ export class DatePicker extends NectaryElement {
231
235
  }
232
236
  return getRect($el);
233
237
  }
234
- #onPrevMonthClick = e => {
238
+ #onPrevMonthClick = (e) => {
235
239
  e.stopPropagation();
236
240
  decMonth(this.#uiDate, this.#minDate);
237
241
  this.#render();
238
242
  };
239
- #onNextMonthClick = e => {
243
+ #onNextMonthClick = (e) => {
240
244
  e.stopPropagation();
241
245
  incMonth(this.#uiDate, this.#maxDate);
242
246
  this.#render();
243
247
  };
244
- #onPrevYearClick = e => {
248
+ #onPrevYearClick = (e) => {
245
249
  e.stopPropagation();
246
250
  decYear(this.#uiDate, this.#minDate);
247
251
  this.#render();
248
252
  };
249
- #onNextYearClick = e => {
253
+ #onNextYearClick = (e) => {
250
254
  e.stopPropagation();
251
255
  incYear(this.#uiDate, this.#maxDate);
252
256
  this.#render();
253
257
  };
254
- #onDateMouseEnter = e => {
258
+ #onDateMouseEnter = (e) => {
255
259
  if (this.#date1 !== null && this.#date2 === null) {
256
- const hoverDateIso = getTargetAttribute(e, 'data-date');
260
+ const hoverDateIso = getTargetAttribute(e, "data-date");
257
261
  if (hoverDateIso === null) {
258
262
  return;
259
263
  }
@@ -261,18 +265,18 @@ export class DatePicker extends NectaryElement {
261
265
  const todayDate = today();
262
266
  for (const week of this.#$days) {
263
267
  for (const $day of week) {
264
- if ($day.hasAttribute('disabled')) {
268
+ if ($day.hasAttribute("disabled")) {
265
269
  continue;
266
270
  }
267
- const dayDate = isoToDate($day.getAttribute('data-date'));
268
- setClass($day, 'range', !areDatesEqual(todayDate, dayDate) && (isDateBetween(dayDate, this.#date1, hoverDate) || isDateBetween(dayDate, hoverDate, this.#date1)));
271
+ const dayDate = isoToDate($day.getAttribute("data-date"));
272
+ setClass($day, "range", !areDatesEqual(todayDate, dayDate) && (isDateBetween(dayDate, this.#date1, hoverDate) || isDateBetween(dayDate, hoverDate, this.#date1)));
269
273
  }
270
274
  }
271
275
  }
272
276
  };
273
- #onDateClick = e => {
277
+ #onDateClick = (e) => {
274
278
  e.stopPropagation();
275
- const dateIso = getTargetAttribute(e, 'data-date');
279
+ const dateIso = getTargetAttribute(e, "data-date");
276
280
  if (dateIso === null || dateIso.length === 0) {
277
281
  return;
278
282
  }
@@ -285,9 +289,9 @@ export class DatePicker extends NectaryElement {
285
289
  this.#date2 = dateTuple[1];
286
290
  this.#unsubscribeRangeHover();
287
291
  this.#render();
288
- this.dispatchEvent(new CustomEvent('-change', {
289
- detail: value
290
- }));
292
+ this.dispatchEvent(
293
+ new CustomEvent("-change", { detail: value })
294
+ );
291
295
  return;
292
296
  }
293
297
  this.#date1 = isoToDate(dateIso);
@@ -296,9 +300,9 @@ export class DatePicker extends NectaryElement {
296
300
  this.#render();
297
301
  return;
298
302
  }
299
- this.dispatchEvent(new CustomEvent('-change', {
300
- detail: dateIso
301
- }));
303
+ this.dispatchEvent(
304
+ new CustomEvent("-change", { detail: dateIso })
305
+ );
302
306
  };
303
307
  #onValueChange() {
304
308
  const value = this.value;
@@ -350,10 +354,10 @@ export class DatePicker extends NectaryElement {
350
354
  }
351
355
  const todayDate = today();
352
356
  const month = getCalendarMonth(this.#uiDate);
353
- updateBooleanAttribute(this.#$prevMonth, 'disabled', canGoPrevMonth(this.#uiDate, this.#minDate) === false);
354
- updateBooleanAttribute(this.#$nextMonth, 'disabled', canGoNextMonth(this.#uiDate, this.#maxDate) === false);
355
- updateBooleanAttribute(this.#$prevYear, 'disabled', canGoPrevYear(this.#uiDate, this.#minDate) === false);
356
- updateBooleanAttribute(this.#$nextYear, 'disabled', canGoNextYear(this.#uiDate, this.#maxDate) === false);
357
+ updateBooleanAttribute(this.#$prevMonth, "disabled", canGoPrevMonth(this.#uiDate, this.#minDate) === false);
358
+ updateBooleanAttribute(this.#$nextMonth, "disabled", canGoNextMonth(this.#uiDate, this.#maxDate) === false);
359
+ updateBooleanAttribute(this.#$prevYear, "disabled", canGoPrevYear(this.#uiDate, this.#minDate) === false);
360
+ updateBooleanAttribute(this.#$nextYear, "disabled", canGoNextYear(this.#uiDate, this.#maxDate) === false);
357
361
  this.#$date.textContent = `${this.#monthNames[this.#uiDate.getUTCMonth()]} ${this.#uiDate.getUTCFullYear()}`;
358
362
  for (let wi = 0; wi < this.#$days.length; wi++) {
359
363
  const $week = this.#$days[wi];
@@ -362,50 +366,53 @@ export class DatePicker extends NectaryElement {
362
366
  const $day = $week[di];
363
367
  const week = month[wi];
364
368
  const day = week?.[di];
365
- $day.classList.remove('selected', 'range', 'today');
369
+ $day.classList.remove("selected", "range", "today");
366
370
  if (day == null) {
367
- $day.textContent = '';
368
- $day.removeAttribute('data-date');
369
- $day.setAttribute('disabled', '');
370
- $day.setAttribute('aria-hidden', 'true');
371
+ $day.textContent = "";
372
+ $day.removeAttribute("data-date");
373
+ $day.setAttribute("disabled", "");
374
+ $day.setAttribute("aria-hidden", "true");
371
375
  } else {
372
376
  const dayIso = dateToIso(day);
373
377
  $day.textContent = day.getUTCDate().toString();
374
- $day.setAttribute('data-date', dayIso);
378
+ $day.setAttribute("data-date", dayIso);
375
379
  if (isDateBetween(day, this.#minDate, this.#maxDate)) {
376
- $day.removeAttribute('disabled');
377
- $day.removeAttribute('aria-hidden');
380
+ $day.removeAttribute("disabled");
381
+ $day.removeAttribute("aria-hidden");
378
382
  } else {
379
- $day.setAttribute('disabled', '');
380
- $day.setAttribute('aria-hidden', 'true');
383
+ $day.setAttribute("disabled", "");
384
+ $day.setAttribute("aria-hidden", "true");
381
385
  }
382
386
  if (areDatesEqual(day, this.#date1) || areDatesEqual(day, this.#date2)) {
383
- $day.classList.add('selected');
387
+ $day.classList.add("selected");
384
388
  } else if (areDatesEqual(day, todayDate)) {
385
- $day.classList.add('today');
389
+ $day.classList.add("today");
386
390
  } else if (isDateBetween(day, this.#date1, this.#date2)) {
387
- $day.classList.add('range');
391
+ $day.classList.add("range");
388
392
  }
389
393
  isEmptyWeek = false;
390
394
  }
391
395
  }
392
- setClass(this.#$weeks[wi], 'empty', isEmptyWeek);
396
+ setClass(this.#$weeks[wi], "empty", isEmptyWeek);
393
397
  }
394
398
  }
395
399
  #subscribeRangeHover() {
396
400
  if (!this.#isHoverSubscribed) {
397
- this.#$month.addEventListener('mouseover', this.#onDateMouseEnter);
401
+ this.#$month.addEventListener("mouseover", this.#onDateMouseEnter);
398
402
  this.#isHoverSubscribed = true;
399
403
  }
400
404
  }
401
405
  #unsubscribeRangeHover() {
402
406
  if (this.#isHoverSubscribed) {
403
- this.#$month.removeEventListener('mouseover', this.#onDateMouseEnter);
407
+ this.#$month.removeEventListener("mouseover", this.#onDateMouseEnter);
404
408
  this.#isHoverSubscribed = false;
405
409
  }
406
410
  }
407
- #onChangeReactHandler = e => {
408
- getReactEventHandler(this, 'on-change')?.(e);
411
+ #onChangeReactHandler = (e) => {
412
+ getReactEventHandler(this, "on-change")?.(e);
409
413
  };
410
414
  }
411
- defineCustomElement('sinch-date-picker', DatePicker);
415
+ defineCustomElement("sinch-date-picker", DatePicker);
416
+ export {
417
+ DatePicker
418
+ };
@@ -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 TSinchDatePickerProps = {
3
3
  /** Identification for uncontrolled form submissions */
4
4
  name?: string;
@@ -72,3 +72,23 @@ export type TSinchDatePicker = {
72
72
  };
73
73
  export type TSinchDatePickerElement = NectaryComponentVanillaByType<TSinchDatePicker>;
74
74
  export type TSinchDatePickerReact = NectaryComponentReactByType<TSinchDatePicker>;
75
+ declare global {
76
+ interface NectaryComponentMap {
77
+ 'sinch-date-picker': TSinchDatePicker;
78
+ }
79
+ interface HTMLElementTagNameMap {
80
+ 'sinch-date-picker': NectaryComponentVanilla<'sinch-date-picker'>;
81
+ }
82
+ namespace JSX {
83
+ interface IntrinsicElements {
84
+ 'sinch-date-picker': NectaryComponentReact<'sinch-date-picker'>;
85
+ }
86
+ }
87
+ }
88
+ declare module 'react' {
89
+ namespace JSX {
90
+ interface IntrinsicElements extends globalThis.JSX.IntrinsicElements {
91
+ 'sinch-date-picker': NectaryComponentReact<'sinch-date-picker'>;
92
+ }
93
+ }
94
+ }
@@ -1 +1 @@
1
- export {};
1
+