@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/tooltip/index.js CHANGED
@@ -1,17 +1,20 @@
1
- import '../text';
2
- import '../pop';
3
- import { defineCustomElement, getAttribute, getLiteralAttribute, updateBooleanAttribute, updateAttribute, updateLiteralAttribute, NectaryElement, setClass, rectOverlap, getReactEventHandler, shouldReduceMotion } from '../utils';
4
- const templateHTML = '<style>:host{display:contents}#content-wrapper{padding-bottom:8px;filter:drop-shadow(var(--sinch-comp-tooltip-shadow))}:host([orientation=left]) #content-wrapper{padding-bottom:0;padding-right:8px}:host([orientation=right]) #content-wrapper{padding-bottom:0;padding-left:8px}:host([orientation^=bottom]) #content-wrapper{padding-bottom:0;padding-top:8px}#content{position:relative;display:block;max-width:300px;padding:2px 6px;box-sizing:border-box;background-color:var(--sinch-local-color-background);border-radius:var(--sinch-comp-tooltip-shape-radius);pointer-events:none;opacity:0;--sinch-local-color-background:var(--sinch-comp-tooltip-color-background);--sinch-global-color-text:var(--sinch-comp-tooltip-color-text)}#text{word-break:break-word;pointer-events:none;--sinch-comp-text-font:var(--sinch-comp-tooltip-font-body)}#tip{position:absolute;left:50%;top:100%;transform:translateX(-50%) rotate(0);transform-origin:top center;fill:var(--sinch-local-color-background);pointer-events:none}#tip.hidden{display:none}:host([orientation=left]) #tip{transform:translateX(-50%) rotate(270deg);top:50%;left:100%}:host([orientation=right]) #tip{transform:translateX(-50%) rotate(90deg);top:50%;left:0}:host([orientation^=bottom]) #tip{transform:translateX(-50%) rotate(180deg);top:0}:host([text-align=right]) #text{--sinch-comp-text-align:right}:host([text-align=center]) #text{--sinch-comp-text-align:center}:host([text-align=left]) #text{--sinch-comp-text-align:left}</style><sinch-pop id="pop"><slot id="target" slot="target"></slot><div id="content-wrapper" slot="content"><div id="content"><sinch-text id="text" type="s"></sinch-text><svg id="tip" width="8" height="4" aria-hidden="true"><path d="m4 4 4-4h-8l4 4Z"/></svg></div></div></sinch-pop>';
5
- import { TooltipState } from './tooltip-state';
6
- import { getPopOrientation, orientationValues, textAlignValues, typeValues } from './utils';
1
+ import "../text/index.js";
2
+ import "../pop/index.js";
3
+ import { shouldReduceMotion, updateAttribute, getAttribute, getLiteralAttribute, updateLiteralAttribute, updateBooleanAttribute, setClass } from "../utils/dom.js";
4
+ import { defineCustomElement, NectaryElement } from "../utils/element.js";
5
+ import { rectOverlap } from "../utils/rect.js";
6
+ import { getReactEventHandler } from "../utils/get-react-event-handler.js";
7
+ import { TooltipState } from "./tooltip-state.js";
8
+ import { getPopOrientation, orientationValues, textAlignValues, typeValues } from "./utils.js";
9
+ const templateHTML = '<style>\n :host {\n display: contents;\n }\n\n #content-wrapper {\n padding-bottom: 8px;\n filter: drop-shadow(var(--sinch-comp-tooltip-shadow));\n }\n\n :host([orientation="left"]) #content-wrapper {\n padding-bottom: 0;\n padding-right: 8px;\n }\n\n :host([orientation="right"]) #content-wrapper {\n padding-bottom: 0;\n padding-left: 8px;\n }\n\n :host([orientation^="bottom"]) #content-wrapper {\n padding-bottom: 0;\n padding-top: 8px;\n }\n\n #content {\n position: relative;\n display: block;\n max-width: 300px;\n padding: 2px 6px;\n box-sizing: border-box;\n background-color: var(--sinch-local-color-background);\n border-radius: var(--sinch-comp-tooltip-shape-radius);\n pointer-events: none;\n opacity: 0;\n\n --sinch-local-color-background: var(--sinch-comp-tooltip-color-background);\n --sinch-global-color-text: var(--sinch-comp-tooltip-color-text);\n }\n\n #text {\n word-break: break-word;\n pointer-events: none;\n\n --sinch-comp-text-font: var(--sinch-comp-tooltip-font-body);\n }\n\n #tip {\n position: absolute;\n left: 50%;\n top: 100%;\n transform: translateX(-50%) rotate(0);\n transform-origin: top center;\n fill: var(--sinch-local-color-background);\n pointer-events: none;\n }\n\n #tip.hidden {\n display: none;\n }\n\n :host([orientation="left"]) #tip {\n transform: translateX(-50%) rotate(270deg);\n top: 50%;\n left: 100%;\n }\n\n :host([orientation="right"]) #tip {\n transform: translateX(-50%) rotate(90deg);\n top: 50%;\n left: 0;\n }\n\n :host([orientation^="bottom"]) #tip {\n transform: translateX(-50%) rotate(180deg);\n top: 0;\n }\n\n :host([text-align="right"]) #text {\n --sinch-comp-text-align: right;\n }\n\n :host([text-align="center"]) #text {\n --sinch-comp-text-align: center;\n }\n\n :host([text-align="left"]) #text {\n --sinch-comp-text-align: left;\n }\n</style>\n\n<sinch-pop id="pop">\n <slot id="target" slot="target"></slot>\n <div id="content-wrapper" slot="content">\n <div id="content">\n <sinch-text id="text" type="s"></sinch-text>\n <svg id="tip" width="8" height="4" aria-hidden="true">\n <path d="m4 4 4-4h-8l4 4Z" />\n </svg>\n </div>\n </div>\n</sinch-pop>';
7
10
  const TIP_SIZE = 8;
8
- const SHOW_DELAY_SLOW = 1000;
11
+ const SHOW_DELAY_SLOW = 1e3;
9
12
  const SHOW_DELAY_FAST = 250;
10
13
  const HIDE_DELAY = 0;
11
14
  const ANIMATION_DURATION = 100;
12
- const template = document.createElement('template');
15
+ const template = document.createElement("template");
13
16
  template.innerHTML = templateHTML;
14
- export class Tooltip extends NectaryElement {
17
+ class Tooltip extends NectaryElement {
15
18
  #$pop;
16
19
  #$tooltipText;
17
20
  #$content;
@@ -27,12 +30,12 @@ export class Tooltip extends NectaryElement {
27
30
  super();
28
31
  const shadowRoot = this.attachShadow();
29
32
  shadowRoot.appendChild(template.content.cloneNode(true));
30
- this.#$pop = shadowRoot.querySelector('#pop');
31
- this.#$tooltipText = shadowRoot.querySelector('#text');
32
- this.#$content = shadowRoot.querySelector('#content');
33
- this.#$contentWrapper = shadowRoot.querySelector('#content-wrapper');
34
- this.#$tip = shadowRoot.querySelector('#tip');
35
- this.#$target = shadowRoot.querySelector('#target');
33
+ this.#$pop = shadowRoot.querySelector("#pop");
34
+ this.#$tooltipText = shadowRoot.querySelector("#text");
35
+ this.#$content = shadowRoot.querySelector("#content");
36
+ this.#$contentWrapper = shadowRoot.querySelector("#content-wrapper");
37
+ this.#$tip = shadowRoot.querySelector("#tip");
38
+ this.#$target = shadowRoot.querySelector("#target");
36
39
  this.#shouldReduceMotion = shouldReduceMotion();
37
40
  this.#tooltipState = new TooltipState({
38
41
  showDelay: SHOW_DELAY_SLOW,
@@ -50,11 +53,11 @@ export class Tooltip extends NectaryElement {
50
53
  const options = {
51
54
  signal: this.#controller.signal
52
55
  };
53
- this.setAttribute('role', 'tooltip');
54
- this.#$pop.addEventListener('-close', this.#onPopClose, options);
55
- this.addEventListener('-show', this.#onShowReactHandler, options);
56
- this.addEventListener('-hide', this.#onHideReactHandler, options);
57
- updateAttribute(this.#$pop, 'orientation', getPopOrientation(this.orientation));
56
+ this.setAttribute("role", "tooltip");
57
+ this.#$pop.addEventListener("-close", this.#onPopClose, options);
58
+ this.addEventListener("-show", this.#onShowReactHandler, options);
59
+ this.addEventListener("-hide", this.#onHideReactHandler, options);
60
+ updateAttribute(this.#$pop, "orientation", getPopOrientation(this.orientation));
58
61
  this.#updateText();
59
62
  }
60
63
  disconnectedCallback() {
@@ -64,67 +67,69 @@ export class Tooltip extends NectaryElement {
64
67
  this.#controller = null;
65
68
  }
66
69
  static get observedAttributes() {
67
- return ['text', 'orientation', 'text-align', 'type', 'aria-label', 'aria-description'];
70
+ return [
71
+ "text",
72
+ "orientation",
73
+ "text-align",
74
+ "type",
75
+ "aria-label",
76
+ "aria-description"
77
+ ];
68
78
  }
69
79
  attributeChangedCallback(name, _, newVal) {
70
80
  switch (name) {
71
- case 'text':
72
- {
73
- this.#updateText();
74
- break;
75
- }
76
- case 'orientation':
77
- {
78
- updateAttribute(this.#$pop, 'orientation', getPopOrientation(this.orientation));
79
- if (this.#isOpen()) {
80
- this.#resetTipOrientation();
81
- this.#updateTipOrientation();
82
- }
83
- break;
84
- }
85
- case 'text-align':
86
- {
87
- updateAttribute(this.#$pop, 'text-align', newVal);
88
- break;
89
- }
90
- case 'type':
91
- {
92
- this.#tooltipState.updateOptions({
93
- showDelay: newVal === 'fast' ? SHOW_DELAY_FAST : SHOW_DELAY_SLOW
94
- });
95
- break;
96
- }
97
- case 'aria-label':
98
- case 'aria-description':
99
- {
100
- updateAttribute(this.#$pop, name, newVal);
101
- break;
81
+ case "text": {
82
+ this.#updateText();
83
+ break;
84
+ }
85
+ case "orientation": {
86
+ updateAttribute(this.#$pop, "orientation", getPopOrientation(this.orientation));
87
+ if (this.#isOpen()) {
88
+ this.#resetTipOrientation();
89
+ this.#updateTipOrientation();
102
90
  }
91
+ break;
92
+ }
93
+ case "text-align": {
94
+ updateAttribute(this.#$pop, "text-align", newVal);
95
+ break;
96
+ }
97
+ case "type": {
98
+ this.#tooltipState.updateOptions({
99
+ showDelay: newVal === "fast" ? SHOW_DELAY_FAST : SHOW_DELAY_SLOW
100
+ });
101
+ break;
102
+ }
103
+ case "aria-label":
104
+ case "aria-description": {
105
+ updateAttribute(this.#$pop, name, newVal);
106
+ break;
107
+ }
103
108
  }
104
109
  }
105
110
  get text() {
106
- return getAttribute(this, 'text', '');
111
+ return getAttribute(this, "text", "");
107
112
  }
108
113
  set text(value) {
109
- updateAttribute(this, 'text', value);
114
+ updateAttribute(this, "text", value);
110
115
  }
111
116
  get orientation() {
112
- return getLiteralAttribute(this, orientationValues, 'orientation', 'top');
117
+ return getLiteralAttribute(this, orientationValues, "orientation", "top");
113
118
  }
114
119
  set orientation(value) {
115
- updateLiteralAttribute(this, orientationValues, 'orientation', value);
120
+ updateLiteralAttribute(this, orientationValues, "orientation", value);
116
121
  }
117
- get 'text-align'() {
118
- return getLiteralAttribute(this, textAlignValues, 'text-align', 'left');
122
+ get "text-align"() {
123
+ return getLiteralAttribute(this, textAlignValues, "text-align", "left");
119
124
  }
120
- set 'text-align'(value) {
121
- updateLiteralAttribute(this, textAlignValues, 'text-align', value);
125
+ set "text-align"(value) {
126
+ updateLiteralAttribute(this, textAlignValues, "text-align", value);
122
127
  }
123
128
  get type() {
124
- return getLiteralAttribute(this, typeValues, 'type', 'slow');
129
+ return getLiteralAttribute(this, typeValues, "type", "slow");
125
130
  }
126
131
  set type(value) {
127
- updateLiteralAttribute(this, typeValues, 'type', value);
132
+ updateLiteralAttribute(this, typeValues, "type", value);
128
133
  }
129
134
  get footprintRect() {
130
135
  return this.#$pop.footprintRect;
@@ -132,16 +137,18 @@ export class Tooltip extends NectaryElement {
132
137
  get tooltipRect() {
133
138
  return this.#$pop.popoverRect;
134
139
  }
140
+ // Begin hide animation if shown, skipping HIDE_DELAY wait
135
141
  #onMouseDown = () => {
136
142
  this.#tooltipState.destroy();
137
143
  };
144
+ // Underlying pop asks for a close
138
145
  #onPopClose = () => {
139
146
  this.#tooltipState.destroy();
140
147
  };
141
148
  #onMouseEnter = () => {
142
149
  this.#tooltipState.show();
143
150
  };
144
- #onMouseLeave = e => {
151
+ #onMouseLeave = (e) => {
145
152
  if (!this.#isOpen() || e.relatedTarget !== this.#$contentWrapper && e.relatedTarget !== this.#$target) {
146
153
  this.#tooltipState.hide();
147
154
  }
@@ -149,13 +156,15 @@ export class Tooltip extends NectaryElement {
149
156
  #onScroll = () => {
150
157
  this.#tooltipState.destroy();
151
158
  };
159
+ // Tooltip begins to wait for SHOW_DELAY on mouseenter
152
160
  #onStateShowStart = () => {
153
161
  this.#subscribeScroll();
154
162
  this.#subscribeMouseLeaveEvents();
155
163
  };
164
+ // SHOW_DELAY ended, tooltip can be shown with animation
156
165
  #onStateShowEnd = () => {
157
166
  this.#dispatchShowEvent();
158
- updateBooleanAttribute(this.#$pop, 'open', true);
167
+ updateBooleanAttribute(this.#$pop, "open", true);
159
168
  requestAnimationFrame(this.#updateTipOrientation);
160
169
  if (this.#animation !== null) {
161
170
  this.#animation.updatePlaybackRate(1);
@@ -166,27 +175,29 @@ export class Tooltip extends NectaryElement {
166
175
  }, {
167
176
  duration: this.#shouldReduceMotion ? 0 : ANIMATION_DURATION,
168
177
  iterations: 1,
169
- fill: 'forwards'
178
+ fill: "forwards"
170
179
  });
171
180
  }
172
181
  };
182
+ // HIDE_DELAY ended, begin tooltip hide animation
173
183
  #onStateHideStart = () => {
174
184
  this.#animation.updatePlaybackRate(-1);
175
185
  this.#animation.play();
176
186
  };
187
+ // Hide animation ended, tooltip can be hidden
177
188
  #onStateHideEnd = () => {
178
189
  if (this.#isOpen()) {
179
190
  this.#animation.finish();
180
191
  this.#dispatchHideEvent();
181
- updateBooleanAttribute(this.#$pop, 'open', false);
192
+ updateBooleanAttribute(this.#$pop, "open", false);
182
193
  }
183
194
  this.#resetTipOrientation();
184
195
  this.#unsubscribeMouseLeaveEvents();
185
196
  this.#unsubscribeScroll();
186
197
  };
187
198
  #resetTipOrientation() {
188
- this.#$tip.style.top = '';
189
- this.#$tip.style.left = '';
199
+ this.#$tip.style.top = "";
200
+ this.#$tip.style.left = "";
190
201
  }
191
202
  #updateTipOrientation = () => {
192
203
  const orient = this.orientation;
@@ -194,20 +205,20 @@ export class Tooltip extends NectaryElement {
194
205
  const contentRect = this.#$content.getBoundingClientRect();
195
206
  const diffX = targetRect.x - contentRect.x;
196
207
  const diffY = targetRect.y - contentRect.y;
197
- if (orient === 'left' || orient === 'right') {
208
+ if (orient === "left" || orient === "right") {
198
209
  const yPos = Math.max(TIP_SIZE, Math.min(diffY + targetRect.height / 2, contentRect.height - TIP_SIZE));
199
210
  this.#$tip.style.top = `${yPos}px`;
200
211
  } else {
201
212
  let xPos = Math.max(TIP_SIZE, Math.min(diffX + targetRect.width / 2, contentRect.width - TIP_SIZE));
202
- if (orient === 'bottom-left' || orient === 'top-left') {
213
+ if (orient === "bottom-left" || orient === "top-left") {
203
214
  xPos = Math.max(xPos, contentRect.width * 0.75);
204
215
  }
205
- if (orient === 'bottom-right' || orient === 'top-right') {
216
+ if (orient === "bottom-right" || orient === "top-right") {
206
217
  xPos = Math.min(xPos, contentRect.width * 0.25);
207
218
  }
208
219
  this.#$tip.style.left = `${xPos}px`;
209
220
  }
210
- setClass(this.#$tip, 'hidden', rectOverlap(targetRect, contentRect));
221
+ setClass(this.#$tip, "hidden", rectOverlap(targetRect, contentRect));
211
222
  };
212
223
  #updateText() {
213
224
  if (!this.isDomConnected) {
@@ -227,50 +238,51 @@ export class Tooltip extends NectaryElement {
227
238
  if (!this.isDomConnected || this.#isSubscribed) {
228
239
  return;
229
240
  }
230
- this.#$target.addEventListener('mouseenter', this.#onMouseEnter, {
241
+ this.#$target.addEventListener("mouseenter", this.#onMouseEnter, {
231
242
  signal: this.#controller.signal
232
243
  });
233
244
  this.#isSubscribed = true;
234
245
  }
235
246
  #unsubscribeMouseEnterEvent() {
236
- this.#$target.removeEventListener('mouseenter', this.#onMouseEnter);
247
+ this.#$target.removeEventListener("mouseenter", this.#onMouseEnter);
237
248
  this.#isSubscribed = false;
238
249
  }
239
250
  #subscribeMouseLeaveEvents() {
240
- const options = {
241
- signal: this.#controller.signal
242
- };
243
- this.#$target.addEventListener('mousedown', this.#onMouseDown, options);
244
- this.#$target.addEventListener('mouseleave', this.#onMouseLeave, options);
245
- this.#$contentWrapper.addEventListener('mouseenter', this.#onMouseEnter, options);
246
- this.#$contentWrapper.addEventListener('mouseleave', this.#onMouseLeave, options);
251
+ const options = { signal: this.#controller.signal };
252
+ this.#$target.addEventListener("mousedown", this.#onMouseDown, options);
253
+ this.#$target.addEventListener("mouseleave", this.#onMouseLeave, options);
254
+ this.#$contentWrapper.addEventListener("mouseenter", this.#onMouseEnter, options);
255
+ this.#$contentWrapper.addEventListener("mouseleave", this.#onMouseLeave, options);
247
256
  }
248
257
  #unsubscribeMouseLeaveEvents() {
249
- this.#$target.removeEventListener('mousedown', this.#onMouseDown);
250
- this.#$target.removeEventListener('mouseleave', this.#onMouseLeave);
251
- this.#$contentWrapper.removeEventListener('mouseenter', this.#onMouseEnter);
252
- this.#$contentWrapper.removeEventListener('mouseleave', this.#onMouseLeave);
258
+ this.#$target.removeEventListener("mousedown", this.#onMouseDown);
259
+ this.#$target.removeEventListener("mouseleave", this.#onMouseLeave);
260
+ this.#$contentWrapper.removeEventListener("mouseenter", this.#onMouseEnter);
261
+ this.#$contentWrapper.removeEventListener("mouseleave", this.#onMouseLeave);
253
262
  }
254
263
  #subscribeScroll() {
255
- window.addEventListener('wheel', this.#onScroll, true);
264
+ window.addEventListener("wheel", this.#onScroll, true);
256
265
  }
257
266
  #unsubscribeScroll() {
258
- window.removeEventListener('wheel', this.#onScroll, true);
267
+ window.removeEventListener("wheel", this.#onScroll, true);
259
268
  }
260
269
  #isOpen() {
261
- return this.#$pop.hasAttribute('open');
270
+ return this.#$pop.hasAttribute("open");
262
271
  }
263
272
  #dispatchShowEvent() {
264
- this.dispatchEvent(new CustomEvent('-show'));
273
+ this.dispatchEvent(new CustomEvent("-show"));
265
274
  }
266
275
  #dispatchHideEvent() {
267
- this.dispatchEvent(new CustomEvent('-hide'));
276
+ this.dispatchEvent(new CustomEvent("-hide"));
268
277
  }
269
278
  #onShowReactHandler = () => {
270
- getReactEventHandler(this, 'on-show')?.();
279
+ getReactEventHandler(this, "on-show")?.();
271
280
  };
272
281
  #onHideReactHandler = () => {
273
- getReactEventHandler(this, 'on-hide')?.();
282
+ getReactEventHandler(this, "on-hide")?.();
274
283
  };
275
284
  }
276
- defineCustomElement('sinch-tooltip', Tooltip);
285
+ defineCustomElement("sinch-tooltip", Tooltip);
286
+ export {
287
+ Tooltip
288
+ };
@@ -1,6 +1,6 @@
1
- export class TooltipState {
1
+ class TooltipState {
2
2
  #timerId = null;
3
- #state = 'hide';
3
+ #state = "hide";
4
4
  #options;
5
5
  constructor(options) {
6
6
  this.#options = options;
@@ -13,77 +13,66 @@ export class TooltipState {
13
13
  }
14
14
  show() {
15
15
  switch (this.#state) {
16
- case 'hide':
17
- {
18
- this.#switchToHideToShow();
19
- break;
20
- }
21
- case 'show-to-hide':
22
- {
23
- this.#switchToState('show');
24
- break;
25
- }
16
+ case "hide": {
17
+ this.#switchToHideToShow();
18
+ break;
19
+ }
20
+ case "show-to-hide": {
21
+ this.#switchToState("show");
22
+ break;
23
+ }
26
24
  }
27
25
  }
28
26
  hide() {
29
27
  switch (this.#state) {
30
- case 'hide-to-show':
31
- {
32
- this.#onHideAnimationEnd();
33
- break;
34
- }
35
- case 'show':
36
- {
37
- this.#switchToShowToHide();
38
- break;
39
- }
28
+ case "hide-to-show": {
29
+ this.#onHideAnimationEnd();
30
+ break;
31
+ }
32
+ case "show": {
33
+ this.#switchToShowToHide();
34
+ break;
35
+ }
40
36
  }
41
37
  }
42
38
  interrupt() {
43
39
  switch (this.#state) {
44
- case 'hide-to-show':
45
- {
46
- this.#onHideAnimationEnd();
47
- break;
48
- }
49
- case 'show':
50
- {
51
- this.#switchToShowToHide(true, false);
52
- break;
53
- }
54
- case 'show-to-hide':
55
- {
56
- this.#switchToShowToHide(true, false);
57
- break;
58
- }
40
+ case "hide-to-show": {
41
+ this.#onHideAnimationEnd();
42
+ break;
43
+ }
44
+ case "show": {
45
+ this.#switchToShowToHide(true, false);
46
+ break;
47
+ }
48
+ case "show-to-hide": {
49
+ this.#switchToShowToHide(true, false);
50
+ break;
51
+ }
59
52
  }
60
53
  }
61
54
  destroy() {
62
55
  switch (this.#state) {
63
- case 'hide-to-show':
64
- {
65
- this.#onHideAnimationEnd();
66
- break;
67
- }
68
- case 'show':
69
- {
70
- this.#switchToShowToHide(true, true);
71
- break;
72
- }
73
- case 'show-to-hide':
74
- {
75
- this.#switchToShowToHide(true, true);
76
- break;
77
- }
78
- case 'hide':
79
- {
80
- this.#onHideAnimationEnd();
81
- break;
82
- }
56
+ case "hide-to-show": {
57
+ this.#onHideAnimationEnd();
58
+ break;
59
+ }
60
+ case "show": {
61
+ this.#switchToShowToHide(true, true);
62
+ break;
63
+ }
64
+ case "show-to-hide": {
65
+ this.#switchToShowToHide(true, true);
66
+ break;
67
+ }
68
+ case "hide": {
69
+ this.#onHideAnimationEnd();
70
+ break;
71
+ }
83
72
  }
84
73
  }
85
74
  #switchToHideToShow() {
86
- this.#switchToState('hide-to-show');
75
+ this.#switchToState("hide-to-show");
87
76
  this.#options.onShowStart();
88
77
  if (this.#options.showDelay === 0) {
89
78
  this.#onSwitchToShow();
@@ -92,7 +81,7 @@ export class TooltipState {
92
81
  }
93
82
  }
94
83
  #switchToShowToHide(skipDelay, skipHideAnimation) {
95
- this.#switchToState('show-to-hide');
84
+ this.#switchToState("show-to-hide");
96
85
  if (skipDelay === true || this.#options.hideDelay === 0) {
97
86
  this.#onShowToHideEnd(skipHideAnimation);
98
87
  } else {
@@ -100,11 +89,11 @@ export class TooltipState {
100
89
  }
101
90
  }
102
91
  #onSwitchToShow = () => {
103
- this.#switchToState('show');
92
+ this.#switchToState("show");
104
93
  this.#options.onShowEnd();
105
94
  };
106
- #onShowToHideEnd = skipHideAnimation => {
107
- this.#switchToState('hide');
95
+ #onShowToHideEnd = (skipHideAnimation) => {
96
+ this.#switchToState("hide");
108
97
  this.#options.onHideStart();
109
98
  if (skipHideAnimation === true || this.#options.hideAnimationDuration === 0) {
110
99
  this.#onHideAnimationEnd();
@@ -113,7 +102,7 @@ export class TooltipState {
113
102
  }
114
103
  };
115
104
  #onHideAnimationEnd = () => {
116
- this.#switchToState('hide');
105
+ this.#switchToState("hide");
117
106
  this.#options.onHideEnd();
118
107
  };
119
108
  #switchToState(nextState) {
@@ -123,4 +112,7 @@ export class TooltipState {
123
112
  this.#timerId = null;
124
113
  }
125
114
  }
126
- }
115
+ }
116
+ export {
117
+ TooltipState
118
+ };
@@ -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 TSinchTooltipOrientation = 'top' | 'bottom' | 'left' | 'right' | 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right';
3
3
  export type TSinchTooltipTextAlign = 'center' | 'right' | 'left';
4
4
  export type TSinchTooltipType = 'slow' | 'fast';
@@ -37,3 +37,23 @@ export type TSinchTooltip = {
37
37
  };
38
38
  export type TSinchTooltipElement = NectaryComponentVanillaByType<TSinchTooltip>;
39
39
  export type TSinchTooltipReact = NectaryComponentReactByType<TSinchTooltip>;
40
+ declare global {
41
+ interface NectaryComponentMap {
42
+ 'sinch-tooltip': TSinchTooltip;
43
+ }
44
+ interface HTMLElementTagNameMap {
45
+ 'sinch-tooltip': NectaryComponentVanilla<'sinch-tooltip'>;
46
+ }
47
+ namespace JSX {
48
+ interface IntrinsicElements {
49
+ 'sinch-tooltip': NectaryComponentReact<'sinch-tooltip'>;
50
+ }
51
+ }
52
+ }
53
+ declare module 'react' {
54
+ namespace JSX {
55
+ interface IntrinsicElements extends globalThis.JSX.IntrinsicElements {
56
+ 'sinch-tooltip': NectaryComponentReact<'sinch-tooltip'>;
57
+ }
58
+ }
59
+ }
package/tooltip/types.js CHANGED
@@ -1 +1 @@
1
- export {};
1
+
package/tooltip/utils.js CHANGED
@@ -1,18 +1,37 @@
1
- export const typeValues = ['fast', 'slow'];
2
- export const orientationValues = ['top', 'bottom', 'left', 'right', 'top-left', 'top-right', 'bottom-left', 'bottom-right'];
3
- export const textAlignValues = ['right', 'center', 'left'];
4
- export const getPopOrientation = orientation => {
5
- if (orientation === 'top') {
6
- return 'top-center';
1
+ const typeValues = ["fast", "slow"];
2
+ const orientationValues = [
3
+ "top",
4
+ "bottom",
5
+ "left",
6
+ "right",
7
+ "top-left",
8
+ "top-right",
9
+ "bottom-left",
10
+ "bottom-right"
11
+ ];
12
+ const textAlignValues = [
13
+ "right",
14
+ "center",
15
+ "left"
16
+ ];
17
+ const getPopOrientation = (orientation) => {
18
+ if (orientation === "top") {
19
+ return "top-center";
7
20
  }
8
- if (orientation === 'bottom') {
9
- return 'bottom-center';
21
+ if (orientation === "bottom") {
22
+ return "bottom-center";
10
23
  }
11
- if (orientation === 'left') {
12
- return 'center-left';
24
+ if (orientation === "left") {
25
+ return "center-left";
13
26
  }
14
- if (orientation === 'right') {
15
- return 'center-right';
27
+ if (orientation === "right") {
28
+ return "center-right";
16
29
  }
17
30
  return orientation;
18
- };
31
+ };
32
+ export {
33
+ getPopOrientation,
34
+ orientationValues,
35
+ textAlignValues,
36
+ typeValues
37
+ };
package/types.d.ts CHANGED
@@ -1,31 +1,14 @@
1
- import type { HTMLAttributes, CSSProperties } from 'react'
2
- import type { ReactifyEvents, WebComponentReactBaseProp, SafeSelect, CamelCaseify, RemoveReadonly, SetAttributes, ExtendEventListeners } from './utils/adapters'
3
-
1
+ import type { ReactifyEvents, WebComponentReactBaseProp, SafeSelect, CamelCaseify, RemoveReadonly, SetAttributes, ExtendEventListeners } from './utils/adapters';
2
+ import type { CSSProperties } from 'react';
4
3
  export type TRect = {
5
- x: number,
6
- y: number,
7
- width: number,
8
- height: number,
9
- }
10
-
11
- export type NectaryComponentVanillaByType<T extends NectaryComponentMap[keyof NectaryComponentMap]> =
12
- Omit<HTMLElement, 'addEventListener' | 'removeEventListener'> &
13
- ExtendEventListeners<Required<SafeSelect<T, 'events'>>> &
14
- SetAttributes<Required<RemoveReadonly<SafeSelect<T, 'props'>>>> &
15
- Required<CamelCaseify<SafeSelect<T, 'props'>>> &
16
- Required<SafeSelect<T, 'methods'>>
17
-
18
- export type NectaryComponentReactByType<T extends NectaryComponentMap[keyof NectaryComponentMap]> =
19
- WebComponentReactBaseProp<NectaryComponentVanillaByType<T>> &
20
- ReactifyEvents<SafeSelect<T, 'events'>> &
21
- RemoveReadonly<SafeSelect<T, 'props'>> &
22
- {
4
+ x: number;
5
+ y: number;
6
+ width: number;
7
+ height: number;
8
+ };
9
+ export type NectaryComponentVanillaByType<T extends NectaryComponentMap[keyof NectaryComponentMap]> = Omit<HTMLElement, 'addEventListener' | 'removeEventListener'> & ExtendEventListeners<Required<SafeSelect<T, 'events'>>> & SetAttributes<Required<RemoveReadonly<SafeSelect<T, 'props'>>>> & Required<CamelCaseify<SafeSelect<T, 'props'>>> & Required<SafeSelect<T, 'methods'>>;
10
+ export type NectaryComponentReactByType<T extends NectaryComponentMap[keyof NectaryComponentMap]> = WebComponentReactBaseProp<NectaryComponentVanillaByType<T>> & ReactifyEvents<SafeSelect<T, 'events'>> & RemoveReadonly<SafeSelect<T, 'props'>> & {
23
11
  style?: Partial<SafeSelect<T, 'style'>> & CSSProperties;
24
- }
25
-
26
-
27
- export type NectaryComponentVanilla<K extends keyof NectaryComponentMap> =
28
- NectaryComponentVanillaByType<NectaryComponentMap[K]>
29
-
30
- export type NectaryComponentReact<K extends keyof NectaryComponentMap> =
31
- NectaryComponentReactByType<NectaryComponentMap[K]>
12
+ };
13
+ export type NectaryComponentVanilla<K extends keyof NectaryComponentMap> = NectaryComponentVanillaByType<NectaryComponentMap[K]>;
14
+ export type NectaryComponentReact<K extends keyof NectaryComponentMap> = NectaryComponentReactByType<NectaryComponentMap[K]>;
package/utils/adapters.js CHANGED
@@ -1 +1 @@
1
- export {};
1
+