@nectary/components 4.12.1 → 5.0.0

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