draft-components 3.5.0 → 4.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 (551) hide show
  1. package/css/draft-components-variables.css +418 -230
  2. package/css/draft-components.css +2547 -1594
  3. package/dist/components/alert/alert.css +58 -59
  4. package/dist/components/alert/alert.d.ts +6 -6
  5. package/dist/components/alert/alert.js +5 -4
  6. package/dist/components/alert/alert.js.map +1 -0
  7. package/dist/components/alert/index.js +1 -0
  8. package/dist/components/alert/index.js.map +1 -0
  9. package/dist/components/avatar/avatar.css +29 -29
  10. package/dist/components/avatar/avatar.d.ts +6 -6
  11. package/dist/components/avatar/avatar.js +6 -5
  12. package/dist/components/avatar/avatar.js.map +1 -0
  13. package/dist/components/avatar/index.js +1 -0
  14. package/dist/components/avatar/index.js.map +1 -0
  15. package/dist/components/badge/badge.css +8 -8
  16. package/dist/components/badge/badge.d.ts +5 -5
  17. package/dist/components/badge/badge.js +2 -0
  18. package/dist/components/badge/badge.js.map +1 -0
  19. package/dist/components/badge/index.js +1 -0
  20. package/dist/components/badge/index.js.map +1 -0
  21. package/dist/components/breadcrumbs/breadcrumbs-context.d.ts +1 -1
  22. package/dist/components/breadcrumbs/breadcrumbs-context.js +1 -0
  23. package/dist/components/breadcrumbs/breadcrumbs-context.js.map +1 -0
  24. package/dist/components/breadcrumbs/breadcrumbs-item.d.ts +7 -6
  25. package/dist/components/breadcrumbs/breadcrumbs-item.js +2 -0
  26. package/dist/components/breadcrumbs/breadcrumbs-item.js.map +1 -0
  27. package/dist/components/breadcrumbs/breadcrumbs.css +9 -9
  28. package/dist/components/breadcrumbs/breadcrumbs.d.ts +5 -4
  29. package/dist/components/breadcrumbs/breadcrumbs.js +2 -0
  30. package/dist/components/breadcrumbs/breadcrumbs.js.map +1 -0
  31. package/dist/components/breadcrumbs/index.js +1 -0
  32. package/dist/components/breadcrumbs/index.js.map +1 -0
  33. package/dist/components/button/button.css +634 -108
  34. package/dist/components/button/button.d.ts +7 -6
  35. package/dist/components/button/button.js +17 -13
  36. package/dist/components/button/button.js.map +1 -0
  37. package/dist/components/button/icon-button.d.ts +2 -2
  38. package/dist/components/button/icon-button.js +4 -4
  39. package/dist/components/button/icon-button.js.map +1 -0
  40. package/dist/components/button/index.js +1 -0
  41. package/dist/components/button/index.js.map +1 -0
  42. package/dist/components/button-group/button-group.d.ts +4 -3
  43. package/dist/components/button-group/button-group.js +2 -0
  44. package/dist/components/button-group/button-group.js.map +1 -0
  45. package/dist/components/button-group/index.js +1 -0
  46. package/dist/components/button-group/index.js.map +1 -0
  47. package/dist/components/caption/caption.css +6 -6
  48. package/dist/components/caption/caption.d.ts +6 -6
  49. package/dist/components/caption/caption.js +6 -4
  50. package/dist/components/caption/caption.js.map +1 -0
  51. package/dist/components/caption/index.js +1 -0
  52. package/dist/components/caption/index.js.map +1 -0
  53. package/dist/components/checkbox/checkbox.css +24 -28
  54. package/dist/components/checkbox/checkbox.d.ts +5 -5
  55. package/dist/components/checkbox/checkbox.js +11 -6
  56. package/dist/components/checkbox/checkbox.js.map +1 -0
  57. package/dist/components/checkbox/index.js +1 -0
  58. package/dist/components/checkbox/index.js.map +1 -0
  59. package/dist/components/color-picker/color-picker-button.d.ts +1 -1
  60. package/dist/components/color-picker/color-picker-button.js +9 -3
  61. package/dist/components/color-picker/color-picker-button.js.map +1 -0
  62. package/dist/components/color-picker/color-picker.css +13 -13
  63. package/dist/components/color-picker/color-picker.d.ts +10 -6
  64. package/dist/components/color-picker/color-picker.js +2 -0
  65. package/dist/components/color-picker/color-picker.js.map +1 -0
  66. package/dist/components/color-picker/index.js +1 -0
  67. package/dist/components/color-picker/index.js.map +1 -0
  68. package/dist/components/date-picker/calendar-day.d.ts +5 -4
  69. package/dist/components/date-picker/calendar-day.js +2 -0
  70. package/dist/components/date-picker/calendar-day.js.map +1 -0
  71. package/dist/components/date-picker/calendar-grid-head.d.ts +1 -1
  72. package/dist/components/date-picker/calendar-grid-head.js +2 -0
  73. package/dist/components/date-picker/calendar-grid-head.js.map +1 -0
  74. package/dist/components/date-picker/calendar-grid.d.ts +1 -1
  75. package/dist/components/date-picker/calendar-grid.js +22 -16
  76. package/dist/components/date-picker/calendar-grid.js.map +1 -0
  77. package/dist/components/date-picker/calendar-header.js +3 -2
  78. package/dist/components/date-picker/calendar-header.js.map +1 -0
  79. package/dist/components/date-picker/calendar.d.ts +10 -7
  80. package/dist/components/date-picker/calendar.js +1 -0
  81. package/dist/components/date-picker/calendar.js.map +1 -0
  82. package/dist/components/date-picker/date-helpers.js +1 -0
  83. package/dist/components/date-picker/date-helpers.js.map +1 -0
  84. package/dist/components/date-picker/date-picker.css +44 -40
  85. package/dist/components/date-picker/date-picker.d.ts +9 -8
  86. package/dist/components/date-picker/date-picker.js +4 -2
  87. package/dist/components/date-picker/date-picker.js.map +1 -0
  88. package/dist/components/date-picker/date-range-picker.d.ts +10 -9
  89. package/dist/components/date-picker/date-range-picker.js +5 -4
  90. package/dist/components/date-picker/date-range-picker.js.map +1 -0
  91. package/dist/components/date-picker/date-range.d.ts +1 -1
  92. package/dist/components/date-picker/date-range.js +1 -0
  93. package/dist/components/date-picker/date-range.js.map +1 -0
  94. package/dist/components/date-picker/index.js +1 -0
  95. package/dist/components/date-picker/index.js.map +1 -0
  96. package/dist/components/date-picker/parse-min-max-props.d.ts +1 -1
  97. package/dist/components/date-picker/parse-min-max-props.js +1 -0
  98. package/dist/components/date-picker/parse-min-max-props.js.map +1 -0
  99. package/dist/components/date-picker-popover/date-picker-popover.d.ts +18 -10
  100. package/dist/components/date-picker-popover/date-picker-popover.js +18 -5
  101. package/dist/components/date-picker-popover/date-picker-popover.js.map +1 -0
  102. package/dist/components/date-picker-popover/index.js +1 -0
  103. package/dist/components/date-picker-popover/index.js.map +1 -0
  104. package/dist/components/date-range-picker-popover/date-range-picker-popover-footer.d.ts +1 -1
  105. package/dist/components/date-range-picker-popover/date-range-picker-popover-footer.js +3 -1
  106. package/dist/components/date-range-picker-popover/date-range-picker-popover-footer.js.map +1 -0
  107. package/dist/components/date-range-picker-popover/date-range-picker-popover-presets.d.ts +1 -1
  108. package/dist/components/date-range-picker-popover/date-range-picker-popover-presets.js +2 -0
  109. package/dist/components/date-range-picker-popover/date-range-picker-popover-presets.js.map +1 -0
  110. package/dist/components/date-range-picker-popover/date-range-picker-popover.d.ts +17 -14
  111. package/dist/components/date-range-picker-popover/date-range-picker-popover.js +20 -14
  112. package/dist/components/date-range-picker-popover/date-range-picker-popover.js.map +1 -0
  113. package/dist/components/date-range-picker-popover/helpers.d.ts +1 -1
  114. package/dist/components/date-range-picker-popover/helpers.js +2 -0
  115. package/dist/components/date-range-picker-popover/helpers.js.map +1 -0
  116. package/dist/components/date-range-picker-popover/index.js +1 -0
  117. package/dist/components/date-range-picker-popover/index.js.map +1 -0
  118. package/dist/components/date-range-picker-popover/types.d.ts +1 -1
  119. package/dist/components/date-range-picker-popover/types.js +2 -1
  120. package/dist/components/date-range-picker-popover/types.js.map +1 -0
  121. package/dist/components/date-range-picker-popover/use-is-compact-view.js +7 -1
  122. package/dist/components/date-range-picker-popover/use-is-compact-view.js.map +1 -0
  123. package/dist/components/dialog/dialog-body.d.ts +9 -4
  124. package/dist/components/dialog/dialog-body.js +26 -3
  125. package/dist/components/dialog/dialog-body.js.map +1 -0
  126. package/dist/components/dialog/dialog-context.d.ts +4 -4
  127. package/dist/components/dialog/dialog-context.js +10 -7
  128. package/dist/components/dialog/dialog-context.js.map +1 -0
  129. package/dist/components/dialog/dialog-footer.d.ts +4 -6
  130. package/dist/components/dialog/dialog-footer.js +8 -4
  131. package/dist/components/dialog/dialog-footer.js.map +1 -0
  132. package/dist/components/dialog/dialog-header.d.ts +8 -8
  133. package/dist/components/dialog/dialog-header.js +12 -10
  134. package/dist/components/dialog/dialog-header.js.map +1 -0
  135. package/dist/components/dialog/dialog.css +321 -100
  136. package/dist/components/dialog/dialog.d.ts +13 -18
  137. package/dist/components/dialog/dialog.js +84 -30
  138. package/dist/components/dialog/dialog.js.map +1 -0
  139. package/dist/components/dialog/index.js +1 -0
  140. package/dist/components/dialog/index.js.map +1 -0
  141. package/dist/components/empty-state/empty-state.css +9 -5
  142. package/dist/components/empty-state/empty-state.d.ts +7 -6
  143. package/dist/components/empty-state/empty-state.js +7 -2
  144. package/dist/components/empty-state/empty-state.js.map +1 -0
  145. package/dist/components/empty-state/index.js +1 -0
  146. package/dist/components/empty-state/index.js.map +1 -0
  147. package/dist/components/file-picker/file-picker.css +19 -16
  148. package/dist/components/file-picker/file-picker.d.ts +7 -7
  149. package/dist/components/file-picker/file-picker.js +25 -9
  150. package/dist/components/file-picker/file-picker.js.map +1 -0
  151. package/dist/components/file-picker/index.js +1 -0
  152. package/dist/components/file-picker/index.js.map +1 -0
  153. package/dist/components/filter-buttons/filter-button.d.ts +6 -5
  154. package/dist/components/filter-buttons/filter-button.js +4 -3
  155. package/dist/components/filter-buttons/filter-button.js.map +1 -0
  156. package/dist/components/filter-buttons/filter-buttons.css +37 -12
  157. package/dist/components/filter-buttons/filter-buttons.d.ts +2 -2
  158. package/dist/components/filter-buttons/filter-buttons.js +3 -2
  159. package/dist/components/filter-buttons/filter-buttons.js.map +1 -0
  160. package/dist/components/filter-buttons/index.js +1 -0
  161. package/dist/components/filter-buttons/index.js.map +1 -0
  162. package/dist/components/filtered-search/filter-item.css +1 -1
  163. package/dist/components/filtered-search/filter-item.d.ts +1 -1
  164. package/dist/components/filtered-search/filter-item.js +3 -1
  165. package/dist/components/filtered-search/filter-item.js.map +1 -0
  166. package/dist/components/filtered-search/filter-operator-select.js +2 -1
  167. package/dist/components/filtered-search/filter-operator-select.js.map +1 -0
  168. package/dist/components/filtered-search/filter-token.css +7 -7
  169. package/dist/components/filtered-search/filter-token.d.ts +6 -3
  170. package/dist/components/filtered-search/filter-token.js +5 -4
  171. package/dist/components/filtered-search/filter-token.js.map +1 -0
  172. package/dist/components/filtered-search/filter-value-list.css +1 -1
  173. package/dist/components/filtered-search/filter-value-list.js +3 -1
  174. package/dist/components/filtered-search/filter-value-list.js.map +1 -0
  175. package/dist/components/filtered-search/filtered-search.css +56 -52
  176. package/dist/components/filtered-search/filtered-search.d.ts +6 -5
  177. package/dist/components/filtered-search/filtered-search.js +12 -9
  178. package/dist/components/filtered-search/filtered-search.js.map +1 -0
  179. package/dist/components/filtered-search/index.d.ts +1 -1
  180. package/dist/components/filtered-search/index.js +3 -1
  181. package/dist/components/filtered-search/index.js.map +1 -0
  182. package/dist/components/filtered-search/model/abstract-filter.js +1 -0
  183. package/dist/components/filtered-search/model/abstract-filter.js.map +1 -0
  184. package/dist/components/filtered-search/model/string-filter.d.ts +1 -1
  185. package/dist/components/filtered-search/model/string-filter.js +2 -0
  186. package/dist/components/filtered-search/model/string-filter.js.map +1 -0
  187. package/dist/components/filtered-search/model/string-set-filter.js +1 -0
  188. package/dist/components/filtered-search/model/string-set-filter.js.map +1 -0
  189. package/dist/components/filtered-search/model/validation-result.js +1 -0
  190. package/dist/components/filtered-search/model/validation-result.js.map +1 -0
  191. package/dist/components/filtered-search/string-filter-input.js +2 -1
  192. package/dist/components/filtered-search/string-filter-input.js.map +1 -0
  193. package/dist/components/filtered-search/string-filter-item.d.ts +1 -1
  194. package/dist/components/filtered-search/string-filter-item.js +7 -3
  195. package/dist/components/filtered-search/string-filter-item.js.map +1 -0
  196. package/dist/components/filtered-search/string-set-filter-item.d.ts +1 -1
  197. package/dist/components/filtered-search/string-set-filter-item.js +7 -3
  198. package/dist/components/filtered-search/string-set-filter-item.js.map +1 -0
  199. package/dist/components/filtered-search/types.d.ts +2 -2
  200. package/dist/components/filtered-search/types.js +3 -1
  201. package/dist/components/filtered-search/types.js.map +1 -0
  202. package/dist/components/filtered-search/use-combobox-ids.js +1 -0
  203. package/dist/components/filtered-search/use-combobox-ids.js.map +1 -0
  204. package/dist/components/filtered-search/use-translations.d.ts +1 -1
  205. package/dist/components/filtered-search/use-translations.js +1 -0
  206. package/dist/components/filtered-search/use-translations.js.map +1 -0
  207. package/dist/components/form-field/form-field.d.ts +7 -10
  208. package/dist/components/form-field/form-field.js +1 -0
  209. package/dist/components/form-field/form-field.js.map +1 -0
  210. package/dist/components/form-field/index.js +1 -0
  211. package/dist/components/form-field/index.js.map +1 -0
  212. package/dist/components/hero-icons/24/outline/arrow-down-icon.d.ts +2 -0
  213. package/dist/components/hero-icons/24/outline/arrow-down-icon.js +6 -0
  214. package/dist/components/hero-icons/24/outline/arrow-down-icon.js.map +1 -0
  215. package/dist/components/hero-icons/24/outline/arrow-up-icon.d.ts +2 -0
  216. package/dist/components/hero-icons/24/outline/arrow-up-icon.js +6 -0
  217. package/dist/components/hero-icons/24/outline/arrow-up-icon.js.map +1 -0
  218. package/dist/components/hero-icons/24/outline/arrows-up-down-icon.d.ts +2 -3
  219. package/dist/components/hero-icons/24/outline/arrows-up-down-icon.js +5 -4
  220. package/dist/components/hero-icons/24/outline/arrows-up-down-icon.js.map +1 -0
  221. package/dist/components/hero-icons/24/outline/chevron-left-icon.d.ts +2 -3
  222. package/dist/components/hero-icons/24/outline/chevron-left-icon.js +5 -4
  223. package/dist/components/hero-icons/24/outline/chevron-left-icon.js.map +1 -0
  224. package/dist/components/hero-icons/24/outline/chevron-right-icon.d.ts +2 -3
  225. package/dist/components/hero-icons/24/outline/chevron-right-icon.js +5 -4
  226. package/dist/components/hero-icons/24/outline/chevron-right-icon.js.map +1 -0
  227. package/dist/components/hero-icons/24/outline/eye-icon.d.ts +2 -3
  228. package/dist/components/hero-icons/24/outline/eye-icon.js +5 -4
  229. package/dist/components/hero-icons/24/outline/eye-icon.js.map +1 -0
  230. package/dist/components/hero-icons/24/outline/eye-slash-icon.d.ts +2 -3
  231. package/dist/components/hero-icons/24/outline/eye-slash-icon.js +5 -4
  232. package/dist/components/hero-icons/24/outline/eye-slash-icon.js.map +1 -0
  233. package/dist/components/hero-icons/24/outline/magnifying-glass-icon.d.ts +2 -3
  234. package/dist/components/hero-icons/24/outline/magnifying-glass-icon.js +5 -4
  235. package/dist/components/hero-icons/24/outline/magnifying-glass-icon.js.map +1 -0
  236. package/dist/components/hero-icons/24/outline/trash-icon.d.ts +2 -3
  237. package/dist/components/hero-icons/24/outline/trash-icon.js +5 -4
  238. package/dist/components/hero-icons/24/outline/trash-icon.js.map +1 -0
  239. package/dist/components/hero-icons/24/outline/x-mark-icon.d.ts +2 -3
  240. package/dist/components/hero-icons/24/outline/x-mark-icon.js +5 -4
  241. package/dist/components/hero-icons/24/outline/x-mark-icon.js.map +1 -0
  242. package/dist/components/hero-icons/24/solid/exclamation-triangle-icon.d.ts +2 -3
  243. package/dist/components/hero-icons/24/solid/exclamation-triangle-icon.js +5 -4
  244. package/dist/components/hero-icons/24/solid/exclamation-triangle-icon.js.map +1 -0
  245. package/dist/components/index.d.ts +0 -2
  246. package/dist/components/index.js +1 -2
  247. package/dist/components/index.js.map +1 -0
  248. package/dist/components/label/index.js +1 -0
  249. package/dist/components/label/index.js.map +1 -0
  250. package/dist/components/label/label.css +5 -5
  251. package/dist/components/label/label.d.ts +6 -3
  252. package/dist/components/label/label.js +6 -4
  253. package/dist/components/label/label.js.map +1 -0
  254. package/dist/components/menu/index.js +1 -0
  255. package/dist/components/menu/index.js.map +1 -0
  256. package/dist/components/menu/menu-item.d.ts +6 -6
  257. package/dist/components/menu/menu-item.js +9 -14
  258. package/dist/components/menu/menu-item.js.map +1 -0
  259. package/dist/components/menu/menu-separator.d.ts +2 -5
  260. package/dist/components/menu/menu-separator.js +3 -1
  261. package/dist/components/menu/menu-separator.js.map +1 -0
  262. package/dist/components/menu/menu.css +25 -26
  263. package/dist/components/menu/menu.d.ts +22 -26
  264. package/dist/components/menu/menu.js +121 -116
  265. package/dist/components/menu/menu.js.map +1 -0
  266. package/dist/components/nav-list/index.js +1 -0
  267. package/dist/components/nav-list/index.js.map +1 -0
  268. package/dist/components/nav-list/nav-list-item.d.ts +7 -6
  269. package/dist/components/nav-list/nav-list-item.js +2 -0
  270. package/dist/components/nav-list/nav-list-item.js.map +1 -0
  271. package/dist/components/nav-list/nav-list-title.d.ts +5 -5
  272. package/dist/components/nav-list/nav-list-title.js +2 -0
  273. package/dist/components/nav-list/nav-list-title.js.map +1 -0
  274. package/dist/components/nav-list/nav-list.css +12 -12
  275. package/dist/components/nav-list/nav-list.d.ts +8 -2
  276. package/dist/components/nav-list/nav-list.js +6 -0
  277. package/dist/components/nav-list/nav-list.js.map +1 -0
  278. package/dist/components/password-input/index.js +1 -0
  279. package/dist/components/password-input/index.js.map +1 -0
  280. package/dist/components/password-input/password-input.css +3 -33
  281. package/dist/components/password-input/password-input.d.ts +7 -6
  282. package/dist/components/password-input/password-input.js +9 -7
  283. package/dist/components/password-input/password-input.js.map +1 -0
  284. package/dist/components/popover/index.js +1 -0
  285. package/dist/components/popover/index.js.map +1 -0
  286. package/dist/components/popover/popover.css +43 -70
  287. package/dist/components/popover/popover.d.ts +28 -49
  288. package/dist/components/popover/popover.js +101 -82
  289. package/dist/components/popover/popover.js.map +1 -0
  290. package/dist/components/portal/index.js +1 -0
  291. package/dist/components/portal/index.js.map +1 -0
  292. package/dist/components/portal/portal-context.d.ts +1 -1
  293. package/dist/components/portal/portal-context.js +1 -0
  294. package/dist/components/portal/portal-context.js.map +1 -0
  295. package/dist/components/portal/portal.d.ts +1 -1
  296. package/dist/components/portal/portal.js +2 -0
  297. package/dist/components/portal/portal.js.map +1 -0
  298. package/dist/components/radio/index.js +1 -0
  299. package/dist/components/radio/index.js.map +1 -0
  300. package/dist/components/radio/radio.css +24 -28
  301. package/dist/components/radio/radio.d.ts +5 -5
  302. package/dist/components/radio/radio.js +11 -6
  303. package/dist/components/radio/radio.js.map +1 -0
  304. package/dist/components/search-select/context.d.ts +1 -1
  305. package/dist/components/search-select/context.js +1 -0
  306. package/dist/components/search-select/context.js.map +1 -0
  307. package/dist/components/search-select/icons.d.ts +3 -3
  308. package/dist/components/search-select/icons.js +2 -0
  309. package/dist/components/search-select/icons.js.map +1 -0
  310. package/dist/components/search-select/index.js +1 -0
  311. package/dist/components/search-select/index.js.map +1 -0
  312. package/dist/components/search-select/search-select.css +67 -43
  313. package/dist/components/search-select/search-select.d.ts +9 -10
  314. package/dist/components/search-select/search-select.js +20 -15
  315. package/dist/components/search-select/search-select.js.map +1 -0
  316. package/dist/components/segmented-control/index.js +1 -0
  317. package/dist/components/segmented-control/index.js.map +1 -0
  318. package/dist/components/segmented-control/segmented-button.d.ts +1 -1
  319. package/dist/components/segmented-control/segmented-button.js +2 -0
  320. package/dist/components/segmented-control/segmented-button.js.map +1 -0
  321. package/dist/components/segmented-control/segmented-control.css +46 -41
  322. package/dist/components/segmented-control/segmented-control.d.ts +5 -4
  323. package/dist/components/segmented-control/segmented-control.js +2 -0
  324. package/dist/components/segmented-control/segmented-control.js.map +1 -0
  325. package/dist/components/select/index.js +1 -0
  326. package/dist/components/select/index.js.map +1 -0
  327. package/dist/components/select/select.css +37 -32
  328. package/dist/components/select/select.d.ts +6 -31
  329. package/dist/components/select/select.js +5 -4
  330. package/dist/components/select/select.js.map +1 -0
  331. package/dist/components/selection-control/index.js +1 -0
  332. package/dist/components/selection-control/index.js.map +1 -0
  333. package/dist/components/selection-control/selection-control.d.ts +8 -13
  334. package/dist/components/selection-control/selection-control.js +5 -4
  335. package/dist/components/selection-control/selection-control.js.map +1 -0
  336. package/dist/components/slider/calc-position.js +1 -0
  337. package/dist/components/slider/calc-position.js.map +1 -0
  338. package/dist/components/slider/get-offset-relative-to-thumb.js +4 -3
  339. package/dist/components/slider/get-offset-relative-to-thumb.js.map +1 -0
  340. package/dist/components/slider/index.js +2 -0
  341. package/dist/components/slider/index.js.map +1 -0
  342. package/dist/components/slider/range-slider.d.ts +2 -2
  343. package/dist/components/slider/range-slider.js +2 -1
  344. package/dist/components/slider/range-slider.js.map +1 -0
  345. package/dist/components/slider/slider-thumb.d.ts +1 -1
  346. package/dist/components/slider/slider-thumb.js +3 -1
  347. package/dist/components/slider/slider-thumb.js.map +1 -0
  348. package/dist/components/slider/slider-tick-marks.d.ts +1 -1
  349. package/dist/components/slider/slider-tick-marks.js +2 -0
  350. package/dist/components/slider/slider-tick-marks.js.map +1 -0
  351. package/dist/components/slider/slider-track.d.ts +1 -1
  352. package/dist/components/slider/slider-track.js +7 -5
  353. package/dist/components/slider/slider-track.js.map +1 -0
  354. package/dist/components/slider/slider.css +88 -93
  355. package/dist/components/slider/slider.d.ts +2 -2
  356. package/dist/components/slider/slider.js +2 -1
  357. package/dist/components/slider/slider.js.map +1 -0
  358. package/dist/components/spinner/index.js +1 -0
  359. package/dist/components/spinner/index.js.map +1 -0
  360. package/dist/components/spinner/spinner.d.ts +6 -5
  361. package/dist/components/spinner/spinner.js +5 -4
  362. package/dist/components/spinner/spinner.js.map +1 -0
  363. package/dist/components/switch/index.js +1 -0
  364. package/dist/components/switch/index.js.map +1 -0
  365. package/dist/components/switch/switch.css +34 -47
  366. package/dist/components/switch/switch.d.ts +5 -5
  367. package/dist/components/switch/switch.js +12 -6
  368. package/dist/components/switch/switch.js.map +1 -0
  369. package/dist/components/table/index.js +1 -0
  370. package/dist/components/table/index.js.map +1 -0
  371. package/dist/components/table/table-body.d.ts +5 -5
  372. package/dist/components/table/table-body.js +5 -4
  373. package/dist/components/table/table-body.js.map +1 -0
  374. package/dist/components/table/table-cell.d.ts +5 -5
  375. package/dist/components/table/table-cell.js +5 -4
  376. package/dist/components/table/table-cell.js.map +1 -0
  377. package/dist/components/table/table-container.d.ts +6 -5
  378. package/dist/components/table/table-container.js +5 -4
  379. package/dist/components/table/table-container.js.map +1 -0
  380. package/dist/components/table/table-head-cell.d.ts +6 -5
  381. package/dist/components/table/table-head-cell.js +14 -9
  382. package/dist/components/table/table-head-cell.js.map +1 -0
  383. package/dist/components/table/table-head.d.ts +6 -5
  384. package/dist/components/table/table-head.js +5 -4
  385. package/dist/components/table/table-head.js.map +1 -0
  386. package/dist/components/table/table-row.d.ts +6 -5
  387. package/dist/components/table/table-row.js +5 -4
  388. package/dist/components/table/table-row.js.map +1 -0
  389. package/dist/components/table/table.css +48 -54
  390. package/dist/components/table/table.d.ts +21 -6
  391. package/dist/components/table/table.js +18 -5
  392. package/dist/components/table/table.js.map +1 -0
  393. package/dist/components/tabs/index.js +1 -0
  394. package/dist/components/tabs/index.js.map +1 -0
  395. package/dist/components/tabs/tab-list.d.ts +4 -2
  396. package/dist/components/tabs/tab-list.js +20 -13
  397. package/dist/components/tabs/tab-list.js.map +1 -0
  398. package/dist/components/tabs/tab-panel.d.ts +7 -4
  399. package/dist/components/tabs/tab-panel.js +3 -0
  400. package/dist/components/tabs/tab-panel.js.map +1 -0
  401. package/dist/components/tabs/tab.d.ts +6 -3
  402. package/dist/components/tabs/tab.js +5 -1
  403. package/dist/components/tabs/tab.js.map +1 -0
  404. package/dist/components/tabs/tabs-context.d.ts +2 -2
  405. package/dist/components/tabs/tabs-context.js +2 -0
  406. package/dist/components/tabs/tabs-context.js.map +1 -0
  407. package/dist/components/tabs/tabs.css +15 -11
  408. package/dist/components/tabs/tabs.d.ts +7 -4
  409. package/dist/components/tabs/tabs.js +3 -0
  410. package/dist/components/tabs/tabs.js.map +1 -0
  411. package/dist/components/tabs/types.js +1 -0
  412. package/dist/components/tabs/types.js.map +1 -0
  413. package/dist/components/tag/index.js +1 -0
  414. package/dist/components/tag/index.js.map +1 -0
  415. package/dist/components/tag/tag.css +222 -183
  416. package/dist/components/tag/tag.d.ts +8 -7
  417. package/dist/components/tag/tag.js +5 -4
  418. package/dist/components/tag/tag.js.map +1 -0
  419. package/dist/components/text-input/index.js +1 -0
  420. package/dist/components/text-input/index.js.map +1 -0
  421. package/dist/components/text-input/text-input.css +59 -53
  422. package/dist/components/text-input/text-input.d.ts +5 -5
  423. package/dist/components/text-input/text-input.js +5 -4
  424. package/dist/components/text-input/text-input.js.map +1 -0
  425. package/dist/components/textarea/index.js +1 -0
  426. package/dist/components/textarea/index.js.map +1 -0
  427. package/dist/components/textarea/textarea.css +36 -31
  428. package/dist/components/textarea/textarea.d.ts +5 -4
  429. package/dist/components/textarea/textarea.js +5 -4
  430. package/dist/components/textarea/textarea.js.map +1 -0
  431. package/dist/components/toast/index.js +1 -0
  432. package/dist/components/toast/index.js.map +1 -0
  433. package/dist/components/toast/toast-button.d.ts +5 -5
  434. package/dist/components/toast/toast-button.js +5 -4
  435. package/dist/components/toast/toast-button.js.map +1 -0
  436. package/dist/components/toast/toast.css +35 -35
  437. package/dist/components/toast/toast.d.ts +5 -4
  438. package/dist/components/toast/toast.js +2 -0
  439. package/dist/components/toast/toast.js.map +1 -0
  440. package/dist/components/toaster/index.js +1 -0
  441. package/dist/components/toaster/index.js.map +1 -0
  442. package/dist/components/toaster/toaster.css +11 -11
  443. package/dist/components/toaster/toaster.d.ts +1 -1
  444. package/dist/components/toaster/toaster.js +28 -17
  445. package/dist/components/toaster/toaster.js.map +1 -0
  446. package/dist/components/tooltip/index.js +1 -0
  447. package/dist/components/tooltip/index.js.map +1 -0
  448. package/dist/components/tooltip/tooltip.css +79 -12
  449. package/dist/components/tooltip/tooltip.d.ts +26 -24
  450. package/dist/components/tooltip/tooltip.js +82 -64
  451. package/dist/components/tooltip/tooltip.js.map +1 -0
  452. package/dist/hooks/index.d.ts +4 -5
  453. package/dist/hooks/index.js +5 -5
  454. package/dist/hooks/index.js.map +1 -0
  455. package/dist/hooks/use-close-on-click-outside.d.ts +10 -0
  456. package/dist/hooks/use-close-on-click-outside.js +57 -0
  457. package/dist/hooks/use-close-on-click-outside.js.map +1 -0
  458. package/dist/hooks/use-close-on-esc.d.ts +5 -0
  459. package/dist/hooks/use-close-on-esc.js +34 -0
  460. package/dist/hooks/use-close-on-esc.js.map +1 -0
  461. package/dist/hooks/use-focus-trap.d.ts +5 -14
  462. package/dist/hooks/use-focus-trap.js +27 -40
  463. package/dist/hooks/use-focus-trap.js.map +1 -0
  464. package/dist/hooks/use-lock-body-scroll.d.ts +3 -0
  465. package/dist/hooks/use-lock-body-scroll.js +41 -0
  466. package/dist/hooks/use-lock-body-scroll.js.map +1 -0
  467. package/dist/hooks/use-preserve-props-when-closed.js +1 -0
  468. package/dist/hooks/use-preserve-props-when-closed.js.map +1 -0
  469. package/dist/hooks/{use-callback-ref.d.ts → use-ref-callback.d.ts} +1 -1
  470. package/dist/hooks/use-ref-callback.js +9 -0
  471. package/dist/hooks/use-ref-callback.js.map +1 -0
  472. package/dist/index.d.ts +2 -2
  473. package/dist/index.js +3 -2
  474. package/dist/index.js.map +1 -0
  475. package/dist/lib/calc-element-position.d.ts +10 -0
  476. package/dist/lib/calc-element-position.js +28 -0
  477. package/dist/lib/calc-element-position.js.map +1 -0
  478. package/dist/lib/calc-position.d.ts +27 -0
  479. package/dist/lib/calc-position.js +143 -0
  480. package/dist/lib/calc-position.js.map +1 -0
  481. package/dist/lib/get-element-bounding-rect.d.ts +9 -0
  482. package/dist/lib/get-element-bounding-rect.js +17 -0
  483. package/dist/lib/get-element-bounding-rect.js.map +1 -0
  484. package/dist/lib/helpers.d.ts +3 -6
  485. package/dist/lib/helpers.js +14 -20
  486. package/dist/lib/helpers.js.map +1 -0
  487. package/dist/lib/index.d.ts +1 -1
  488. package/dist/lib/index.js +2 -1
  489. package/dist/lib/index.js.map +1 -0
  490. package/dist/lib/keyboard-key.d.ts +15 -0
  491. package/dist/lib/keyboard-key.js +16 -0
  492. package/dist/lib/keyboard-key.js.map +1 -0
  493. package/dist/lib/observe-element-change.d.ts +3 -0
  494. package/dist/lib/observe-element-change.js +14 -0
  495. package/dist/lib/observe-element-change.js.map +1 -0
  496. package/dist/lib/observe-element-move.d.ts +6 -0
  497. package/dist/lib/observe-element-move.js +43 -0
  498. package/dist/lib/observe-element-move.js.map +1 -0
  499. package/dist/lib/react-helpers.d.ts +1 -9
  500. package/dist/lib/react-helpers.js +2 -26
  501. package/dist/lib/react-helpers.js.map +1 -0
  502. package/dist/storybook-blocks/color-palette/color-palette.d.ts +11 -0
  503. package/dist/storybook-blocks/color-palette/color-palette.js +22 -0
  504. package/dist/storybook-blocks/color-palette/color-palette.js.map +1 -0
  505. package/dist/storybook-blocks/color-palette/index.d.ts +1 -0
  506. package/dist/storybook-blocks/color-palette/index.js +2 -0
  507. package/dist/storybook-blocks/color-palette/index.js.map +1 -0
  508. package/package.json +47 -49
  509. package/css/draft-components-utilities.css +0 -1710
  510. package/dist/components/hero-icons/24/outline/arrow-small-down-icon.d.ts +0 -3
  511. package/dist/components/hero-icons/24/outline/arrow-small-down-icon.js +0 -5
  512. package/dist/components/hero-icons/24/outline/arrow-small-up-icon.d.ts +0 -3
  513. package/dist/components/hero-icons/24/outline/arrow-small-up-icon.js +0 -5
  514. package/dist/components/popover/use-page-click.d.ts +0 -16
  515. package/dist/components/popover/use-page-click.js +0 -46
  516. package/dist/components/positioner/calc-position.d.ts +0 -32
  517. package/dist/components/positioner/calc-position.js +0 -112
  518. package/dist/components/positioner/index.d.ts +0 -1
  519. package/dist/components/positioner/index.js +0 -1
  520. package/dist/components/positioner/positioner.d.ts +0 -20
  521. package/dist/components/positioner/positioner.js +0 -59
  522. package/dist/components/positioner/types.d.ts +0 -14
  523. package/dist/components/positioner/types.js +0 -1
  524. package/dist/components/slide-over/index.d.ts +0 -4
  525. package/dist/components/slide-over/index.js +0 -3
  526. package/dist/components/slide-over/slide-over-body.css +0 -7
  527. package/dist/components/slide-over/slide-over-body.d.ts +0 -3
  528. package/dist/components/slide-over/slide-over-body.js +0 -5
  529. package/dist/components/slide-over/slide-over-context.d.ts +0 -14
  530. package/dist/components/slide-over/slide-over-context.js +0 -18
  531. package/dist/components/slide-over/slide-over-header.css +0 -29
  532. package/dist/components/slide-over/slide-over-header.d.ts +0 -11
  533. package/dist/components/slide-over/slide-over-header.js +0 -17
  534. package/dist/components/slide-over/slide-over.css +0 -85
  535. package/dist/components/slide-over/slide-over.d.ts +0 -25
  536. package/dist/components/slide-over/slide-over.js +0 -106
  537. package/dist/components/slide-over/types.d.ts +0 -1
  538. package/dist/components/slide-over/types.js +0 -1
  539. package/dist/hooks/use-callback-ref.js +0 -8
  540. package/dist/hooks/use-disable-body-scroll.d.ts +0 -5
  541. package/dist/hooks/use-disable-body-scroll.js +0 -32
  542. package/dist/hooks/use-esc-key-down.d.ts +0 -17
  543. package/dist/hooks/use-esc-key-down.js +0 -51
  544. package/dist/hooks/use-mount-transition.d.ts +0 -35
  545. package/dist/hooks/use-mount-transition.js +0 -39
  546. package/dist/hooks/use-prefers-reduced-motion.d.ts +0 -1
  547. package/dist/hooks/use-prefers-reduced-motion.js +0 -15
  548. package/dist/hooks/use-show-transition.d.ts +0 -16
  549. package/dist/hooks/use-show-transition.js +0 -69
  550. package/dist/lib/keyboard-keys.d.ts +0 -15
  551. package/dist/lib/keyboard-keys.js +0 -15
@@ -1,18 +1,19 @@
1
1
  import { jsx as _jsx } from "react/jsx-runtime";
2
- import { forwardRef, useState } from 'react';
2
+ import { useState } from 'react';
3
3
  import { classNames } from '../../lib/react-helpers.js';
4
4
  import { TextInput } from '../text-input/index.js';
5
5
  import { Tooltip } from '../tooltip/index.js';
6
6
  import { EyeIcon } from '../hero-icons/24/outline/eye-icon.js';
7
7
  import { EyeSlashIcon } from '../hero-icons/24/outline/eye-slash-icon.js';
8
8
  import { Spinner } from '../spinner/index.js';
9
+ import { Button } from '../button/index.js';
9
10
  const getDefaultTooltipText = (visible) => (visible
10
11
  ? 'Hide password'
11
12
  : 'Show password');
12
13
  const renderToggleButtonDefaultIcon = (visible) => (visible
13
- ? _jsx(EyeIcon, { width: "1.25em", height: "1.25em" })
14
- : _jsx(EyeSlashIcon, { width: "1.25em", height: "1.25em" }));
15
- export const PasswordInput = forwardRef(function PasswordInput({ className, loading = false, defaultVisible = false, getTooltipText = getDefaultTooltipText, renderToggleButtonIcon = renderToggleButtonDefaultIcon, onClickToggleButton, ...props }, ref) {
14
+ ? _jsx(EyeSlashIcon, { width: "1.25em", height: "1.25em" })
15
+ : _jsx(EyeIcon, { width: "1.25em", height: "1.25em" }));
16
+ export function PasswordInput({ className, loading = false, defaultVisible = false, getTooltipText = getDefaultTooltipText, renderToggleButtonIcon = renderToggleButtonDefaultIcon, onClickToggleButton, ...props }) {
16
17
  const [visible, setVisible] = useState(defaultVisible);
17
18
  const handleClickToggleButton = (event) => {
18
19
  setVisible(!visible);
@@ -20,7 +21,8 @@ export const PasswordInput = forwardRef(function PasswordInput({ className, load
20
21
  onClickToggleButton(event);
21
22
  }
22
23
  };
23
- return (_jsx(TextInput, { ...props, ref: ref, className: classNames('dc-password-input', className), type: visible ? 'text' : 'password', readOnly: loading ?? props.readOnly, slotRight: () => (_jsx(Tooltip, { content: getTooltipText(visible), children: _jsx("button", { className: "dc-password-input__toggle-button", type: "button", disabled: loading, onClick: handleClickToggleButton, children: loading
24
+ return (_jsx(TextInput, { ...props, className: classNames('dc-password-input', className), type: visible ? 'text' : 'password', readOnly: loading ?? props.readOnly, slotRight: () => (_jsx(Tooltip, { title: getTooltipText(visible), children: (props) => (_jsx(Button, { ...props, className: "dc-password-input__toggle-button", buttonStyle: "plain", onClick: handleClickToggleButton, children: loading
24
25
  ? _jsx(Spinner, { width: "1.15em" })
25
- : renderToggleButtonIcon(visible) }) })) }));
26
- });
26
+ : renderToggleButtonIcon(visible) })) })) }));
27
+ }
28
+ //# sourceMappingURL=password-input.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"password-input.js","sourceRoot":"","sources":["../../../src/components/password-input/password-input.tsx"],"names":[],"mappings":";AAAA,OAAO,EAA0C,QAAQ,EAAE,MAAM,OAAO,CAAC;AACzE,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AACxD,OAAO,EAAE,SAAS,EAAuB,MAAM,wBAAwB,CAAC;AACxE,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC9C,OAAO,EAAE,OAAO,EAAE,MAAM,sCAAsC,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,4CAA4C,CAAC;AAC1E,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC9C,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAY5C,MAAM,qBAAqB,GAAG,CAAC,OAAgB,EAAE,EAAE,CAAC,CAAC,OAAO;IAC1D,CAAC,CAAC,eAAe;IACjB,CAAC,CAAC,eAAe,CAAC,CAAC;AAErB,MAAM,6BAA6B,GAAG,CAAC,OAAgB,EAAE,EAAE,CAAC,CAAC,OAAO;IAClE,CAAC,CAAC,KAAC,YAAY,IAAC,KAAK,EAAC,QAAQ,EAAC,MAAM,EAAC,QAAQ,GAAG;IACjD,CAAC,CAAC,KAAC,OAAO,IAAC,KAAK,EAAC,QAAQ,EAAC,MAAM,EAAC,QAAQ,GAAG,CAAC,CAAC;AAEhD,MAAM,UAAU,aAAa,CAAC,EAC5B,SAAS,EACT,OAAO,GAAG,KAAK,EACf,cAAc,GAAG,KAAK,EACtB,cAAc,GAAG,qBAAqB,EACtC,sBAAsB,GAAG,6BAA6B,EACtD,mBAAmB,EACnB,GAAG,KAAK,EACW;IACnB,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAC,cAAc,CAAC,CAAC;IAEvD,MAAM,uBAAuB,GAAyC,CAAC,KAAK,EAAE,EAAE;QAC9E,UAAU,CAAC,CAAC,OAAO,CAAC,CAAC;QACrB,IAAI,OAAO,mBAAmB,KAAK,UAAU,EAAE,CAAC;YAC9C,mBAAmB,CAAC,KAAK,CAAC,CAAC;QAC7B,CAAC;IACH,CAAC,CAAC;IAEF,OAAO,CACL,KAAC,SAAS,OACJ,KAAK,EACT,SAAS,EAAE,UAAU,CAAC,mBAAmB,EAAE,SAAS,CAAC,EACrD,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,UAAU,EACnC,QAAQ,EAAE,OAAO,IAAI,KAAK,CAAC,QAAQ,EACnC,SAAS,EAAE,GAAG,EAAE,CAAC,CACf,KAAC,OAAO,IAAC,KAAK,EAAE,cAAc,CAAC,OAAO,CAAC,YACpC,CAAC,KAAK,EAAE,EAAE,CAAC,CACV,KAAC,MAAM,OACD,KAAK,EACT,SAAS,EAAC,kCAAkC,EAC5C,WAAW,EAAC,OAAO,EACnB,OAAO,EAAE,uBAAuB,YAE/B,OAAO;oBACN,CAAC,CAAC,KAAC,OAAO,IAAC,KAAK,EAAC,QAAQ,GAAG;oBAC5B,CAAC,CAAC,sBAAsB,CAAC,OAAO,CAAC,GAC5B,CACV,GACO,CACX,GACD,CACH,CAAC;AACJ,CAAC"}
@@ -1 +1,2 @@
1
1
  export * from './popover.js';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/popover/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAC"}
@@ -1,98 +1,71 @@
1
1
  .dc-popover {
2
- --dc-popover-text-color: var(--dc-primary-text-color);
3
- --dc-popover-transition-duration: 100ms;
4
- --dc-popover-bg: white;
5
- --dc-popover-shadow:
6
- 0 0 0 1px rgb(var(--dc-black-rgb) / 7.5%),
2
+ --font: var(--dc-text-sm);
3
+ --padding: 12px 16px;
4
+ --color: var(--dc-text-color-primary);
5
+ --background: var(--dc-white);
6
+ --radius: 8px;
7
+ --shadow: 0 0 0 1px rgb(var(--dc-black-rgb) / 7.5%),
7
8
  0 -1px 0 0 rgb(var(--dc-black-rgb) / 5%),
8
9
  var(--dc-shadow-lg);
9
10
 
11
+ position: absolute;
10
12
  top: 0;
11
13
  left: 0;
12
14
  z-index: var(--dc-overlay-z-index);
13
15
  box-sizing: border-box;
14
- padding: 1px;
16
+ width: -moz-max-content;
17
+ width: max-content;
18
+ padding: var(--padding);
19
+ overflow: auto;
20
+ font: var(--font);
21
+ color: var(--color);
15
22
  color-scheme: light;
23
+ scrollbar-width: thin;
24
+ background: var(--background);
25
+ border-radius: var(--radius);
26
+ box-shadow: var(--shadow);
16
27
  }
17
28
 
18
- .dc-popover-modal {
19
- box-sizing: border-box;
20
- max-width: 448px;
21
- padding: 12px 16px;
22
- font: var(--dc-text-sm);
23
- color: var(--dc-popover-text-color);
24
- background: var(--dc-popover-bg);
25
- border-radius: 8px;
26
- box-shadow: var(--dc-popover-shadow);
27
- }
28
-
29
- .dc-popover_closed .dc-popover-modal {
30
- opacity: 0;
31
- transition: var(--dc-popover-transition-duration) ease;
32
- transition-property: opacity, transform;
33
- transform: scale(0.95);
34
- }
35
-
36
- .dc-popover_opened .dc-popover-modal {
37
- opacity: 1;
38
- transform: scale(1);
39
- }
40
-
41
- .dc-popover[data-position="top-start"] .dc-popover-modal {
42
- transform-origin: bottom left;
43
- }
44
-
45
- .dc-popover[data-position="top-center"] .dc-popover-modal {
46
- transform-origin: bottom center;
47
- }
29
+ @keyframes dc-popover-enter {
30
+ from {
31
+ opacity: 0;
32
+ }
48
33
 
49
- .dc-popover[data-position="top-right"] .dc-popover-modal {
50
- transform-origin: bottom left;
34
+ to {
35
+ opacity: 1;
36
+ }
51
37
  }
52
38
 
53
- .dc-popover[data-position="right-start"] .dc-popover-modal {
54
- transform-origin: left top;
39
+ .dc-popover[data-animation="enter"] {
40
+ animation: dc-popover-enter 50ms ease forwards;
55
41
  }
56
42
 
57
- .dc-popover[data-position="right-center"] .dc-popover-modal {
58
- transform-origin: left center;
59
- }
60
-
61
- .dc-popover[data-position="right-right"] .dc-popover-modal {
62
- transform-origin: left bottom;
63
- }
64
-
65
- .dc-popover[data-position="bottom-start"] .dc-popover-modal {
66
- transform-origin: top left;
67
- }
43
+ @keyframes dc-popover-leave {
44
+ from {
45
+ opacity: 1;
46
+ }
68
47
 
69
- .dc-popover[data-position="bottom-center"] .dc-popover-modal {
70
- transform-origin: top center;
48
+ to {
49
+ opacity: 0;
50
+ }
71
51
  }
72
52
 
73
- .dc-popover[data-position="bottom-right"] .dc-popover-modal {
74
- transform-origin: top left;
53
+ .dc-popover[data-animation="leave"] {
54
+ animation: dc-popover-leave 50ms ease forwards;
75
55
  }
76
56
 
77
- .dc-popover[data-position="left-start"] .dc-popover-modal {
78
- transform-origin: right top;
79
- }
80
-
81
- .dc-popover[data-position="left-center"] .dc-popover-modal {
82
- transform-origin: right center;
83
- }
84
-
85
- .dc-popover[data-position="left-right"] .dc-popover-modal {
86
- transform-origin: right bottom;
57
+ @media (prefers-reduced-motion) {
58
+ .dc-popover[data-animation="enter"]
59
+ .dc-popover[data-animation="leave"] {
60
+ animation-duration: 0ms !important;
61
+ }
87
62
  }
88
63
 
89
64
  .dark .dc-popover,
90
65
  .dark.dc-popover {
91
- --dc-popover-border-color: var(--dc-gray-700);
92
- --dc-popover-bg: var(--dc-gray-800);
93
- --dc-popover-shadow:
94
- 0 0 0 1px var(--dc-gray-700),
95
- var(--dc-shadow-lg);
66
+ --border-color: var(--dc-neutral-700);
67
+ --background: var(--dc-neutral-800);
68
+ --shadow: 0 0 0 1px var(--dc-neutral-700), var(--dc-shadow-lg);
96
69
 
97
70
  color-scheme: dark;
98
71
  }
@@ -1,51 +1,30 @@
1
- import { ComponentPropsWithoutRef, ReactNode, RefCallback } from 'react';
2
- import { type PositionerProps } from '../positioner/index.js';
3
- export type PopoverRef = {
4
- open(): void;
5
- close(): void;
6
- toggle(): void;
7
- };
8
- export type PopoverAnchorRenderFn = (props: {
9
- ref: RefCallback<HTMLElement>;
10
- }, context: {
11
- isOpen: boolean;
12
- openPopover: () => void;
13
- closePopover: () => void;
14
- togglePopover: () => void;
15
- }) => ReactNode;
16
- type PopoverHTMLProps = ComponentPropsWithoutRef<'div'>;
17
- export type PopoverPlacement = PositionerProps['placement'];
18
- export type PopoverAlignment = PositionerProps['alignment'];
19
- export type PopoverOpenCallback = () => void;
20
- export type PopoverCloseCallback = () => void;
21
- export type PopoverProps = {
22
- defaultIsOpen?: boolean;
23
- isOpen?: boolean;
1
+ import { type ElementPlacement } from '../../lib/calc-element-position.js';
2
+ import { type ComponentProps, type JSX, type RefCallback, type RefObject } from 'react';
3
+ export { type ElementPlacement as PopoverPlacement };
4
+ export type PopoverCloseHandler = () => void;
5
+ export type PopoverUnmountHandler = () => void;
6
+ export type PopoverRenderAnchor = (props: {
7
+ ref: RefCallback<HTMLElement | null>;
8
+ }) => JSX.Element;
9
+ type PopoverHTMLProps = ComponentProps<'div'>;
10
+ type PopoverCommonProps = {
11
+ placement?: ElementPlacement;
12
+ anchorPadding?: number;
13
+ viewportPadding?: number;
14
+ openAnimationDuration?: number;
15
+ closeAnimationDuration?: number;
24
16
  shouldTrapFocus?: boolean;
25
- shouldFocusAnchorAfterEscPress?: boolean;
26
- transitionDurationMs?: number;
27
- anchorGap?: number;
28
- viewportGap?: number;
29
- placement?: PopoverPlacement;
30
- alignment?: PopoverAlignment;
31
- anchor: ReactNode | PopoverAnchorRenderFn;
32
- children: ReactNode;
33
- onOpen?: PopoverOpenCallback;
34
- onClose?: PopoverCloseCallback;
35
- } & PopoverHTMLProps;
36
- export declare const Popover: import("react").ForwardRefExoticComponent<{
37
- defaultIsOpen?: boolean;
17
+ shouldLockBodyScroll?: boolean;
18
+ shouldCloseOnEsc?: boolean;
19
+ shouldCloseOnClickOutside?: boolean;
38
20
  isOpen?: boolean;
39
- shouldTrapFocus?: boolean;
40
- shouldFocusAnchorAfterEscPress?: boolean;
41
- transitionDurationMs?: number;
42
- anchorGap?: number;
43
- viewportGap?: number;
44
- placement?: PopoverPlacement;
45
- alignment?: PopoverAlignment;
46
- anchor: ReactNode | PopoverAnchorRenderFn;
47
- children: ReactNode;
48
- onOpen?: PopoverOpenCallback;
49
- onClose?: PopoverCloseCallback;
50
- } & Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & import("react").RefAttributes<PopoverRef>>;
51
- export {};
21
+ onClose?: PopoverCloseHandler;
22
+ onUnmount?: PopoverUnmountHandler;
23
+ };
24
+ type PopoverBaseProps = PopoverCommonProps & ({
25
+ anchorRef: RefObject<HTMLElement | null>;
26
+ } | {
27
+ renderAnchor: PopoverRenderAnchor;
28
+ });
29
+ export type PopoverProps = PopoverBaseProps & Omit<PopoverHTMLProps, keyof PopoverBaseProps>;
30
+ export declare function Popover({ className, role, 'aria-modal': ariaModal, placement, anchorPadding, viewportPadding, shouldTrapFocus, shouldLockBodyScroll, shouldCloseOnEsc, shouldCloseOnClickOutside, children, isOpen, onClose, onUnmount, ...props }: PopoverProps): import("react/jsx-runtime").JSX.Element;
@@ -1,91 +1,110 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { cloneElement, forwardRef, useCallback, useImperativeHandle, useRef, useState, } from 'react';
3
- import { classNames, focusElement, isReactElementWithRef, mergeRefs } from '../../lib/react-helpers.js';
4
- import { useMountTransition } from '../../hooks/use-mount-transition.js';
5
- import { useEscKeyDown } from '../../hooks/use-esc-key-down.js';
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { classNames, tryToFocusElement } from '../../lib/react-helpers.js';
3
+ import { observeElementMove } from '../../lib/observe-element-move.js';
4
+ import { calcElementPosition } from '../../lib/calc-element-position.js';
5
+ import { deleteKeys } from '../../lib/helpers.js';
6
+ import { useRefCallback } from '../../hooks/use-ref-callback.js';
6
7
  import { useFocusTrap } from '../../hooks/use-focus-trap.js';
7
- import { usePageClick } from './use-page-click.js';
8
- import { Positioner, } from '../positioner/index.js';
9
- export const Popover = forwardRef(function Popover({ shouldTrapFocus = true, shouldFocusAnchorAfterEscPress = true, transitionDurationMs = 100, placement = 'bottom', alignment = 'start', anchorGap, viewportGap, anchor, className, children, onOpen, onClose, ...props }, ref) {
10
- const [defaultIsOpen, setDefaultIsOpen] = useState(props.defaultIsOpen ?? false);
11
- const anchorRef = useRef(null);
12
- const contentRef = useRef(null);
13
- const isOpen = props.isOpen ?? defaultIsOpen;
14
- const { isMounted, className: transitionClass } = useMountTransition({
15
- durationMs: transitionDurationMs,
16
- isShown: isOpen,
17
- enterFrom: 'dc-popover_closed',
18
- enterTo: 'dc-popover_opened',
19
- });
20
- const openPopover = useCallback(() => {
21
- setDefaultIsOpen(true);
22
- onOpen?.();
23
- }, [onOpen]);
24
- const closePopover = useCallback(() => {
25
- setDefaultIsOpen(false);
26
- onClose?.();
27
- }, [onClose]);
28
- const togglePopover = useCallback(() => {
29
- if (isOpen) {
30
- closePopover();
8
+ import { useLockBodyScroll } from '../../hooks/use-lock-body-scroll.js';
9
+ import { useCloseOnEsc } from '../../hooks/use-close-on-esc.js';
10
+ import { useCloseOnClickOutside } from '../../hooks/use-close-on-click-outside.js';
11
+ import { useEffect, useRef, useState } from 'react';
12
+ import { Portal } from '../portal/portal.js';
13
+ export {};
14
+ export function Popover({ className, role = 'dialog', 'aria-modal': ariaModal = true, placement = 'bottom-start', anchorPadding = 4, viewportPadding = 4, shouldTrapFocus = true, shouldLockBodyScroll = true, shouldCloseOnEsc = true, shouldCloseOnClickOutside = true, children = null, isOpen = false, onClose, onUnmount, ...props }) {
15
+ const [isMounted, setIsMounted] = useState(isOpen);
16
+ const defaultAnchorRef = useRef(null);
17
+ const popoverRef = useRef(null);
18
+ const isAnchorRefProvided = 'anchorRef' in props;
19
+ let anchorRef;
20
+ if (isAnchorRefProvided) {
21
+ anchorRef = props.anchorRef;
22
+ }
23
+ else {
24
+ anchorRef = defaultAnchorRef;
25
+ }
26
+ const close = useRefCallback(() => {
27
+ if (typeof onClose === 'function') {
28
+ onClose();
31
29
  }
32
- else {
33
- openPopover();
30
+ });
31
+ const unmount = useRefCallback(() => {
32
+ setIsMounted(false);
33
+ if (typeof onUnmount === 'function') {
34
+ onUnmount();
34
35
  }
35
- }, [isOpen, closePopover, openPopover]);
36
- useImperativeHandle(ref, () => ({
37
- open: openPopover,
38
- close: closePopover,
39
- toggle: togglePopover,
40
- }), [openPopover, closePopover, togglePopover]);
41
- usePageClick((event) => {
42
- const target = event.target;
36
+ });
37
+ useEffect(() => {
43
38
  const anchor = anchorRef.current;
44
- const content = contentRef.current;
45
- if (target instanceof Node
46
- && !anchor?.contains(target)
47
- && !content?.contains(target)) {
48
- closePopover();
49
- }
50
- }, { isEnabled: isOpen });
51
- useEscKeyDown(() => {
52
- closePopover();
53
- if (shouldFocusAnchorAfterEscPress && anchorRef.current) {
54
- focusElement(anchorRef.current);
39
+ const popover = popoverRef.current;
40
+ if (!anchor || !popover) {
41
+ return;
55
42
  }
56
- }, { isEnabled: isOpen });
57
- useFocusTrap(contentRef, { isEnabled: shouldTrapFocus && isOpen });
58
- const renderAnchor = ({ setRef }) => {
59
- if (typeof anchor === 'function') {
60
- return anchor({
61
- ref: mergeRefs(setRef, anchorRef),
62
- }, {
63
- isOpen: isOpen || isMounted,
64
- openPopover,
65
- closePopover,
66
- togglePopover,
43
+ if (isOpen) {
44
+ setIsMounted((isMounted) => {
45
+ if (isMounted) {
46
+ return isMounted;
47
+ }
48
+ popover.dataset.animation = 'enter';
49
+ return !isMounted;
67
50
  });
51
+ const positionPopover = () => {
52
+ popover.style.removeProperty('max-width');
53
+ popover.style.removeProperty('max-height');
54
+ const result = calcElementPosition(anchor, popover, {
55
+ placement,
56
+ anchorPadding,
57
+ viewportPadding,
58
+ });
59
+ popover.style.setProperty('top', `${result.y}px`);
60
+ popover.style.setProperty('left', `${result.x}px`);
61
+ popover.style.setProperty('max-width', `${result.maxWidth}px`);
62
+ popover.style.setProperty('max-height', `${result.maxHeight}px`);
63
+ };
64
+ positionPopover();
65
+ return observeElementMove(anchor, positionPopover);
68
66
  }
69
- if (isReactElementWithRef(anchor)) {
70
- return cloneElement(anchor, {
71
- ref: mergeRefs(setRef, anchorRef, anchor.ref),
72
- onClick: (event) => {
73
- togglePopover();
74
- anchor.props.onClick?.(event);
75
- },
76
- });
67
+ else {
68
+ popover.dataset.animation = 'leave';
69
+ popover.addEventListener('animationend', unmount);
70
+ return () => {
71
+ popover.removeEventListener('animationend', unmount);
72
+ };
77
73
  }
78
- return anchor;
79
- };
80
- const renderContent = ({ setRef: portalRef, style: portalStyle, }) => {
81
- if (isOpen || isMounted) {
82
- delete props.defaultIsOpen;
83
- delete props.isOpen;
84
- return (_jsx("div", { ref: portalRef, style: {
85
- '--dc-popover-transition-duration': `${transitionDurationMs}ms`,
86
- ...portalStyle,
87
- }, className: classNames('dc-popover', transitionClass), children: _jsx("div", { ...props, ref: contentRef, className: classNames('dc-popover-modal', className), children: children }) }));
74
+ }, [
75
+ anchorRef,
76
+ isOpen,
77
+ placement,
78
+ anchorPadding,
79
+ viewportPadding,
80
+ unmount,
81
+ ]);
82
+ useFocusTrap(popoverRef, {
83
+ disabled: !shouldTrapFocus || !isMounted,
84
+ });
85
+ useLockBodyScroll({
86
+ disabled: !shouldLockBodyScroll || !isMounted,
87
+ });
88
+ useCloseOnEsc(close, {
89
+ disabled: !shouldCloseOnEsc || !isMounted,
90
+ });
91
+ useCloseOnClickOutside(close, {
92
+ ref: popoverRef,
93
+ disabled: !shouldCloseOnClickOutside || !isMounted,
94
+ shouldIgnoreClick: (node) => anchorRef.current ? anchorRef.current.contains(node) : false,
95
+ });
96
+ useEffect(() => {
97
+ if (isOpen) {
98
+ const prevFocusedElement = document.activeElement;
99
+ return () => {
100
+ tryToFocusElement(prevFocusedElement);
101
+ };
88
102
  }
89
- };
90
- return (_jsx(Positioner, { position: "absolute", placement: placement, alignment: alignment, anchorGap: anchorGap, viewportGap: viewportGap, renderAnchor: renderAnchor, renderContent: renderContent }));
91
- });
103
+ }, [isOpen]);
104
+ return (_jsxs(_Fragment, { children: [!isAnchorRefProvided && props.renderAnchor({
105
+ ref: (el) => {
106
+ defaultAnchorRef.current = el;
107
+ },
108
+ }), (isOpen || isMounted) && (_jsx(Portal, { children: _jsx("div", { className: classNames('dc-popover', className), ref: popoverRef, role: role, "aria-modal": ariaModal, ...isAnchorRefProvided ? deleteKeys(props, 'anchorRef') : deleteKeys(props, 'renderAnchor'), children: children }) }))] }));
109
+ }
110
+ //# sourceMappingURL=popover.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"popover.js","sourceRoot":"","sources":["../../../src/components/popover/popover.tsx"],"names":[],"mappings":"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"}
@@ -1 +1,2 @@
1
1
  export * from './portal.js';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/portal/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC"}
@@ -1,4 +1,4 @@
1
- import { ReactNode } from 'react';
1
+ import { type ReactNode } from 'react';
2
2
  export declare function usePortalRoot(): HTMLElement;
3
3
  export declare function PortalRootProvider(props: {
4
4
  children?: ReactNode;
@@ -19,3 +19,4 @@ export function PortalRootProvider(props) {
19
19
  const { getPortalRoot, children } = props;
20
20
  return (_jsx(PortalContext.Provider, { value: getPortalRoot, children: children }));
21
21
  }
22
+ //# sourceMappingURL=portal-context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"portal-context.js","sourceRoot":"","sources":["../../../src/components/portal/portal-context.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAkB,aAAa,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAElE,IAAI,IAAI,GAAuB,IAAI,CAAC;AACpC,MAAM,aAAa,GAAG,GAAgB,EAAE;IACtC,IAAI,IAAI,IAAI,IAAI,EAAE,CAAC;QACjB,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACrC,IAAI,CAAC,EAAE,GAAG,aAAa,CAAC;QACxB,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,aAAa,CAAC;QACpC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAEF,MAAM,aAAa,GAAG,aAAa,CAAC,aAAa,CAAC,CAAC;AAEnD,MAAM,UAAU,aAAa;IAC3B,MAAM,OAAO,GAAG,UAAU,CAAC,aAAa,CAAC,CAAC;IAC1C,OAAO,OAAO,EAAE,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,KAGlC;IACC,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,GAAG,KAAK,CAAC;IAC1C,OAAO,CACL,KAAC,aAAa,CAAC,QAAQ,IAAC,KAAK,EAAE,aAAa,YACzC,QAAQ,GACc,CAC1B,CAAC;AACJ,CAAC"}
@@ -1,4 +1,4 @@
1
- import { ReactNode } from 'react';
1
+ import { type ReactNode } from 'react';
2
2
  export type PortalProps = {
3
3
  children: ReactNode;
4
4
  };
@@ -1,6 +1,8 @@
1
+ import {} from 'react';
1
2
  import { createPortal } from 'react-dom';
2
3
  import { usePortalRoot } from './portal-context.js';
3
4
  export function Portal({ children }) {
4
5
  const container = usePortalRoot();
5
6
  return createPortal(children, container);
6
7
  }
8
+ //# sourceMappingURL=portal.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"portal.js","sourceRoot":"","sources":["../../../src/components/portal/portal.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAkB,MAAM,OAAO,CAAC;AACvC,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAMpD,MAAM,UAAU,MAAM,CAAC,EAAE,QAAQ,EAAe;IAC9C,MAAM,SAAS,GAAG,aAAa,EAAE,CAAC;IAClC,OAAO,YAAY,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;AAC3C,CAAC"}
@@ -1 +1,2 @@
1
1
  export * from './radio.js';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/radio/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC"}
@@ -1,17 +1,17 @@
1
1
  .dc-radio {
2
- --dc-radio-size: 20px;
3
- --dc-radio-color-bg: var(--dc-control-bg);
4
- --dc-radio-color-bg-checked: var(--dc-control-primary-color);
5
- --dc-radio-color-border: var(--dc-control-border-color);
6
- --dc-radio-color-border-checked: var(--dc-control-primary-color);
7
- --dc-radio-color-icon: var(--dc-control-on-primary-color);
8
- --dc-radio-color-focus-ring: var(--dc-focus-ring-color);
2
+ --size: 20px;
3
+ --background: var(--dc-white);
4
+ --background-checked: var(--dc-blue-500);
5
+ --border-color: var(--dc-neutral-300);
6
+ --border-color-checked: rgb(var(--dc-black-rgb) / 10%);
7
+ --icon-color: var(--dc-white);
8
+ --focus-ring-color: var(--dc-focus-ring-color);
9
9
 
10
10
  position: relative;
11
11
  display: inline-block;
12
12
  flex-shrink: 0;
13
- width: var(--dc-radio-size);
14
- height: var(--dc-radio-size);
13
+ width: var(--size);
14
+ height: var(--size);
15
15
  text-align: left;
16
16
  color-scheme: light;
17
17
  }
@@ -23,9 +23,9 @@
23
23
  padding: 0;
24
24
  margin: -1px;
25
25
  overflow: hidden;
26
- clip: rect(0, 0, 0, 0);
27
26
  white-space: nowrap;
28
27
  border: 0;
28
+ clip: rect(0, 0, 0, 0);
29
29
  }
30
30
 
31
31
  .dc-radio__check {
@@ -34,11 +34,11 @@
34
34
  left: 0;
35
35
  box-sizing: border-box;
36
36
  display: inline-block;
37
- width: var(--dc-radio-size);
38
- height: var(--dc-radio-size);
37
+ width: var(--size);
38
+ height: var(--size);
39
39
  vertical-align: middle;
40
- background: var(--dc-radio-color-bg);
41
- border: 1px solid var(--dc-radio-color-border);
40
+ background: var(--background);
41
+ border: 1px solid var(--border-color);
42
42
  border-radius: 50%;
43
43
  transition: opacity 0.2s;
44
44
  }
@@ -47,12 +47,12 @@
47
47
  display: none;
48
48
  width: 100%;
49
49
  height: 100%;
50
- color: var(--dc-radio-color-icon);
50
+ color: var(--icon-color);
51
51
  }
52
52
 
53
53
  .dc-radio__input:checked + .dc-radio__check {
54
- background: var(--dc-radio-color-bg-checked);
55
- border-color: var(--dc-radio-color-border-checked);
54
+ background: var(--background-checked);
55
+ border-color: var(--border-color-checked);
56
56
  }
57
57
 
58
58
  .dc-radio__input:checked + .dc-radio__check .dc-radio__icon {
@@ -68,20 +68,16 @@
68
68
  outline: none;
69
69
  }
70
70
 
71
- .dc-radio__input:focus + .dc-radio__check::after {
72
- position: absolute;
73
- inset: -3px;
74
- pointer-events: none;
75
- content: "";
76
- border-radius: 50%;
77
- box-shadow: 0 0 0 3px var(--dc-radio-color-focus-ring);
78
- }
79
-
80
- .dc-radio__input:focus:not(:focus-visible) + .dc-radio__check::after {
81
- content: none;
71
+ .dc-radio__input:focus-visible + .dc-radio__check {
72
+ outline: 2px solid var(--focus-ring-color);
73
+ outline-offset: 2px;
82
74
  }
83
75
 
84
76
  .dark .dc-radio,
85
77
  .dark.dc-radio {
78
+ --background: var(--dc-neutral-800);
79
+ --border-color: var(--dc-neutral-600);
80
+ --border-color-checked: rgb(var(--dc-white-rgb) / 10%);
81
+
86
82
  color-scheme: dark;
87
83
  }