@zimyo/ui 1.0.2 → 1.1.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 (309) hide show
  1. package/package.json +78 -83
  2. package/dist/components/index.d.ts +0 -60
  3. package/dist/components/ui/accordion.d.ts +0 -10
  4. package/dist/components/ui/accordion.js +0 -58
  5. package/dist/components/ui/alert-dialog.d.ts +0 -17
  6. package/dist/components/ui/alert-dialog.js +0 -108
  7. package/dist/components/ui/alert.d.ts +0 -13
  8. package/dist/components/ui/alert.js +0 -52
  9. package/dist/components/ui/aspect-ratio.d.ts +0 -6
  10. package/dist/components/ui/aspect-ratio.js +0 -12
  11. package/dist/components/ui/avatar.d.ts +0 -9
  12. package/dist/components/ui/avatar.js +0 -37
  13. package/dist/components/ui/badge.d.ts +0 -13
  14. package/dist/components/ui/badge.js +0 -36
  15. package/dist/components/ui/breadcrumb.d.ts +0 -14
  16. package/dist/components/ui/breadcrumb.js +0 -94
  17. package/dist/components/ui/button.d.ts +0 -14
  18. package/dist/components/ui/button.js +0 -48
  19. package/dist/components/ui/calendar.d.ts +0 -13
  20. package/dist/components/ui/calendar.js +0 -137
  21. package/dist/components/ui/card.d.ts +0 -12
  22. package/dist/components/ui/card.js +0 -76
  23. package/dist/components/ui/carousel.d.ts +0 -25
  24. package/dist/components/ui/carousel.js +0 -173
  25. package/dist/components/ui/chart.d.ts +0 -44
  26. package/dist/components/ui/chart.js +0 -203
  27. package/dist/components/ui/checkbox.d.ts +0 -7
  28. package/dist/components/ui/checkbox.js +0 -26
  29. package/dist/components/ui/collapsible.d.ts +0 -8
  30. package/dist/components/ui/collapsible.js +0 -24
  31. package/dist/components/ui/command.d.ts +0 -22
  32. package/dist/components/ui/command.js +0 -119
  33. package/dist/components/ui/context-menu.d.ts +0 -28
  34. package/dist/components/ui/context-menu.js +0 -171
  35. package/dist/components/ui/dialog.d.ts +0 -18
  36. package/dist/components/ui/dialog.js +0 -106
  37. package/dist/components/ui/drawer.d.ts +0 -16
  38. package/dist/components/ui/drawer.js +0 -99
  39. package/dist/components/ui/dropdown-menu.d.ts +0 -28
  40. package/dist/components/ui/dropdown-menu.js +0 -173
  41. package/dist/components/ui/form.d.ts +0 -27
  42. package/dist/components/ui/form.js +0 -129
  43. package/dist/components/ui/hover-card.d.ts +0 -9
  44. package/dist/components/ui/hover-card.js +0 -36
  45. package/dist/components/ui/input-otp.d.ts +0 -14
  46. package/dist/components/ui/input-otp.js +0 -66
  47. package/dist/components/ui/input.d.ts +0 -6
  48. package/dist/components/ui/input.js +0 -18
  49. package/dist/components/ui/label.d.ts +0 -7
  50. package/dist/components/ui/label.js +0 -17
  51. package/dist/components/ui/menubar.d.ts +0 -29
  52. package/dist/components/ui/menubar.js +0 -191
  53. package/dist/components/ui/navigation-menu.d.ts +0 -18
  54. package/dist/components/ui/navigation-menu.js +0 -108
  55. package/dist/components/ui/pagination.d.ts +0 -18
  56. package/dist/components/ui/pagination.js +0 -103
  57. package/dist/components/ui/popover.d.ts +0 -10
  58. package/dist/components/ui/popover.js +0 -41
  59. package/dist/components/ui/progress.d.ts +0 -7
  60. package/dist/components/ui/progress.js +0 -26
  61. package/dist/components/ui/radio-group.d.ts +0 -8
  62. package/dist/components/ui/radio-group.js +0 -36
  63. package/dist/components/ui/resizable.d.ts +0 -11
  64. package/dist/components/ui/resizable.js +0 -42
  65. package/dist/components/ui/scroll-area.d.ts +0 -8
  66. package/dist/components/ui/scroll-area.js +0 -41
  67. package/dist/components/ui/select.d.ts +0 -18
  68. package/dist/components/ui/select.js +0 -136
  69. package/dist/components/ui/separator.d.ts +0 -7
  70. package/dist/components/ui/separator.js +0 -21
  71. package/dist/components/ui/sheet.d.ts +0 -16
  72. package/dist/components/ui/sheet.js +0 -106
  73. package/dist/components/ui/sidebar.d.ts +0 -74
  74. package/dist/components/ui/sidebar.js +0 -511
  75. package/dist/components/ui/skeleton.d.ts +0 -5
  76. package/dist/components/ui/skeleton.js +0 -16
  77. package/dist/components/ui/slider.d.ts +0 -7
  78. package/dist/components/ui/slider.js +0 -41
  79. package/dist/components/ui/sonner.d.ts +0 -6
  80. package/dist/components/ui/sonner.js +0 -18
  81. package/dist/components/ui/switch.d.ts +0 -7
  82. package/dist/components/ui/switch.js +0 -22
  83. package/dist/components/ui/table.d.ts +0 -13
  84. package/dist/components/ui/table.js +0 -90
  85. package/dist/components/ui/tabs.d.ts +0 -10
  86. package/dist/components/ui/tabs.js +0 -47
  87. package/dist/components/ui/textarea.d.ts +0 -6
  88. package/dist/components/ui/textarea.js +0 -16
  89. package/dist/components/ui/toggle-group.d.ts +0 -11
  90. package/dist/components/ui/toggle-group.js +0 -57
  91. package/dist/components/ui/toggle.d.ts +0 -13
  92. package/dist/components/ui/toggle.js +0 -41
  93. package/dist/components/ui/tooltip.d.ts +0 -10
  94. package/dist/components/ui/tooltip.js +0 -50
  95. package/dist/index.d.ts +0 -63
  96. package/dist/index.js +0 -48
  97. package/dist/lib/utils.d.ts +0 -5
  98. package/dist/lib/utils.js +0 -8
  99. package/dist/node_modules/@date-fns/tz/date/index.js +0 -101
  100. package/dist/node_modules/@date-fns/tz/date/mini.js +0 -207
  101. package/dist/node_modules/@date-fns/tz/tzOffset/index.js +0 -43
  102. package/dist/node_modules/@radix-ui/primitive/dist/index.js +0 -11
  103. package/dist/node_modules/@radix-ui/react-compose-refs/dist/index.js +0 -39
  104. package/dist/node_modules/@radix-ui/react-context/dist/index.js +0 -79
  105. package/dist/node_modules/@radix-ui/react-dialog/dist/index.js +0 -321
  106. package/dist/node_modules/@radix-ui/react-dismissable-layer/dist/index.js +0 -211
  107. package/dist/node_modules/@radix-ui/react-focus-guards/dist/index.js +0 -29
  108. package/dist/node_modules/@radix-ui/react-focus-scope/dist/index.js +0 -207
  109. package/dist/node_modules/@radix-ui/react-id/dist/index.js +0 -15
  110. package/dist/node_modules/@radix-ui/react-portal/dist/index.js +0 -17
  111. package/dist/node_modules/@radix-ui/react-presence/dist/index.js +0 -130
  112. package/dist/node_modules/@radix-ui/react-primitive/dist/index.js +0 -43
  113. package/dist/node_modules/@radix-ui/react-slot/dist/index.js +0 -89
  114. package/dist/node_modules/@radix-ui/react-use-callback-ref/dist/index.js +0 -12
  115. package/dist/node_modules/@radix-ui/react-use-controllable-state/dist/index.js +0 -70
  116. package/dist/node_modules/@radix-ui/react-use-escape-keydown/dist/index.js +0 -18
  117. package/dist/node_modules/@radix-ui/react-use-layout-effect/dist/index.js +0 -7
  118. package/dist/node_modules/aria-hidden/dist/es2015/index.js +0 -137
  119. package/dist/node_modules/class-variance-authority/dist/index.js +0 -44
  120. package/dist/node_modules/clsx/dist/clsx.js +0 -3
  121. package/dist/node_modules/cmdk/dist/chunk-NZJY6EH4.js +0 -3
  122. package/dist/node_modules/cmdk/dist/index.js +0 -10
  123. package/dist/node_modules/date-fns/_lib/addLeadingZeros.js +0 -7
  124. package/dist/node_modules/date-fns/_lib/defaultOptions.js +0 -7
  125. package/dist/node_modules/date-fns/_lib/format/formatters.js +0 -775
  126. package/dist/node_modules/date-fns/_lib/format/lightFormatters.js +0 -94
  127. package/dist/node_modules/date-fns/_lib/format/longFormatters.js +0 -66
  128. package/dist/node_modules/date-fns/_lib/getTimezoneOffsetInMilliseconds.js +0 -31
  129. package/dist/node_modules/date-fns/_lib/normalizeDates.js +0 -11
  130. package/dist/node_modules/date-fns/_lib/normalizeInterval.js +0 -8
  131. package/dist/node_modules/date-fns/_lib/protectedTokens.js +0 -25
  132. package/dist/node_modules/date-fns/addDays.js +0 -41
  133. package/dist/node_modules/date-fns/addMonths.js +0 -75
  134. package/dist/node_modules/date-fns/addWeeks.js +0 -33
  135. package/dist/node_modules/date-fns/addYears.js +0 -33
  136. package/dist/node_modules/date-fns/constants.js +0 -46
  137. package/dist/node_modules/date-fns/constructFrom.js +0 -49
  138. package/dist/node_modules/date-fns/differenceInCalendarDays.js +0 -62
  139. package/dist/node_modules/date-fns/differenceInCalendarMonths.js +0 -42
  140. package/dist/node_modules/date-fns/eachMonthOfInterval.js +0 -65
  141. package/dist/node_modules/date-fns/endOfISOWeek.js +0 -35
  142. package/dist/node_modules/date-fns/endOfMonth.js +0 -37
  143. package/dist/node_modules/date-fns/endOfWeek.js +0 -53
  144. package/dist/node_modules/date-fns/endOfYear.js +0 -37
  145. package/dist/node_modules/date-fns/format.js +0 -423
  146. package/dist/node_modules/date-fns/getDayOfYear.js +0 -34
  147. package/dist/node_modules/date-fns/getDaysInMonth.js +0 -36
  148. package/dist/node_modules/date-fns/getISOWeek.js +0 -40
  149. package/dist/node_modules/date-fns/getISOWeekYear.js +0 -52
  150. package/dist/node_modules/date-fns/getMonth.js +0 -29
  151. package/dist/node_modules/date-fns/getWeek.js +0 -54
  152. package/dist/node_modules/date-fns/getWeekYear.js +0 -75
  153. package/dist/node_modules/date-fns/getYear.js +0 -29
  154. package/dist/node_modules/date-fns/isAfter.js +0 -25
  155. package/dist/node_modules/date-fns/isBefore.js +0 -25
  156. package/dist/node_modules/date-fns/isDate.js +0 -41
  157. package/dist/node_modules/date-fns/isSameDay.js +0 -46
  158. package/dist/node_modules/date-fns/isSameMonth.js +0 -43
  159. package/dist/node_modules/date-fns/isSameYear.js +0 -35
  160. package/dist/node_modules/date-fns/isValid.js +0 -39
  161. package/dist/node_modules/date-fns/locale/_lib/buildFormatLongFn.js +0 -10
  162. package/dist/node_modules/date-fns/locale/_lib/buildLocalizeFn.js +0 -64
  163. package/dist/node_modules/date-fns/locale/_lib/buildMatchFn.js +0 -59
  164. package/dist/node_modules/date-fns/locale/_lib/buildMatchPatternFn.js +0 -22
  165. package/dist/node_modules/date-fns/locale/en-US/_lib/formatDistance.js +0 -103
  166. package/dist/node_modules/date-fns/locale/en-US/_lib/formatLong.js +0 -41
  167. package/dist/node_modules/date-fns/locale/en-US/_lib/formatRelative.js +0 -13
  168. package/dist/node_modules/date-fns/locale/en-US/_lib/localize.js +0 -189
  169. package/dist/node_modules/date-fns/locale/en-US/_lib/match.js +0 -134
  170. package/dist/node_modules/date-fns/locale/en-US.js +0 -28
  171. package/dist/node_modules/date-fns/max.js +0 -49
  172. package/dist/node_modules/date-fns/min.js +0 -49
  173. package/dist/node_modules/date-fns/setMonth.js +0 -46
  174. package/dist/node_modules/date-fns/setYear.js +0 -40
  175. package/dist/node_modules/date-fns/startOfDay.js +0 -35
  176. package/dist/node_modules/date-fns/startOfISOWeek.js +0 -35
  177. package/dist/node_modules/date-fns/startOfISOWeekYear.js +0 -42
  178. package/dist/node_modules/date-fns/startOfMonth.js +0 -37
  179. package/dist/node_modules/date-fns/startOfWeek.js +0 -53
  180. package/dist/node_modules/date-fns/startOfWeekYear.js +0 -64
  181. package/dist/node_modules/date-fns/startOfYear.js +0 -36
  182. package/dist/node_modules/date-fns/toDate.js +0 -46
  183. package/dist/node_modules/embla-carousel/esm/embla-carousel.esm.js +0 -1669
  184. package/dist/node_modules/embla-carousel-react/esm/embla-carousel-react.esm.js +0 -37
  185. package/dist/node_modules/embla-carousel-reactive-utils/esm/embla-carousel-reactive-utils.esm.js +0 -38
  186. package/dist/node_modules/get-nonce/dist/es2015/index.js +0 -8
  187. package/dist/node_modules/input-otp/dist/index.js +0 -24
  188. package/dist/node_modules/react-day-picker/dist/esm/DayPicker.js +0 -285
  189. package/dist/node_modules/react-day-picker/dist/esm/UI.js +0 -122
  190. package/dist/node_modules/react-day-picker/dist/esm/classes/CalendarDay.js +0 -30
  191. package/dist/node_modules/react-day-picker/dist/esm/classes/CalendarMonth.js +0 -14
  192. package/dist/node_modules/react-day-picker/dist/esm/classes/CalendarWeek.js +0 -13
  193. package/dist/node_modules/react-day-picker/dist/esm/classes/DateLib.js +0 -522
  194. package/dist/node_modules/react-day-picker/dist/esm/components/Button.js +0 -13
  195. package/dist/node_modules/react-day-picker/dist/esm/components/CaptionLabel.js +0 -13
  196. package/dist/node_modules/react-day-picker/dist/esm/components/Chevron.js +0 -18
  197. package/dist/node_modules/react-day-picker/dist/esm/components/Day.js +0 -18
  198. package/dist/node_modules/react-day-picker/dist/esm/components/DayButton.js +0 -19
  199. package/dist/node_modules/react-day-picker/dist/esm/components/Dropdown.js +0 -21
  200. package/dist/node_modules/react-day-picker/dist/esm/components/DropdownNav.js +0 -13
  201. package/dist/node_modules/react-day-picker/dist/esm/components/Footer.js +0 -13
  202. package/dist/node_modules/react-day-picker/dist/esm/components/Month.js +0 -15
  203. package/dist/node_modules/react-day-picker/dist/esm/components/MonthCaption.js +0 -14
  204. package/dist/node_modules/react-day-picker/dist/esm/components/MonthGrid.js +0 -13
  205. package/dist/node_modules/react-day-picker/dist/esm/components/Months.js +0 -13
  206. package/dist/node_modules/react-day-picker/dist/esm/components/MonthsDropdown.js +0 -15
  207. package/dist/node_modules/react-day-picker/dist/esm/components/Nav.js +0 -31
  208. package/dist/node_modules/react-day-picker/dist/esm/components/NextMonthButton.js +0 -15
  209. package/dist/node_modules/react-day-picker/dist/esm/components/Option.js +0 -13
  210. package/dist/node_modules/react-day-picker/dist/esm/components/PreviousMonthButton.js +0 -15
  211. package/dist/node_modules/react-day-picker/dist/esm/components/Root.js +0 -14
  212. package/dist/node_modules/react-day-picker/dist/esm/components/Select.js +0 -13
  213. package/dist/node_modules/react-day-picker/dist/esm/components/Week.js +0 -14
  214. package/dist/node_modules/react-day-picker/dist/esm/components/WeekNumber.js +0 -14
  215. package/dist/node_modules/react-day-picker/dist/esm/components/WeekNumberHeader.js +0 -13
  216. package/dist/node_modules/react-day-picker/dist/esm/components/Weekday.js +0 -13
  217. package/dist/node_modules/react-day-picker/dist/esm/components/Weekdays.js +0 -14
  218. package/dist/node_modules/react-day-picker/dist/esm/components/Weeks.js +0 -13
  219. package/dist/node_modules/react-day-picker/dist/esm/components/YearsDropdown.js +0 -15
  220. package/dist/node_modules/react-day-picker/dist/esm/components/custom-components.js +0 -26
  221. package/dist/node_modules/react-day-picker/dist/esm/formatters/formatCaption.js +0 -25
  222. package/dist/node_modules/react-day-picker/dist/esm/formatters/formatDay.js +0 -19
  223. package/dist/node_modules/react-day-picker/dist/esm/formatters/formatMonthDropdown.js +0 -18
  224. package/dist/node_modules/react-day-picker/dist/esm/formatters/formatWeekNumber.js +0 -21
  225. package/dist/node_modules/react-day-picker/dist/esm/formatters/formatWeekNumberHeader.js +0 -13
  226. package/dist/node_modules/react-day-picker/dist/esm/formatters/formatWeekdayName.js +0 -19
  227. package/dist/node_modules/react-day-picker/dist/esm/formatters/formatYearDropdown.js +0 -23
  228. package/dist/node_modules/react-day-picker/dist/esm/formatters/index.js +0 -7
  229. package/dist/node_modules/react-day-picker/dist/esm/helpers/calculateFocusTarget.js +0 -73
  230. package/dist/node_modules/react-day-picker/dist/esm/helpers/createGetModifiers.js +0 -95
  231. package/dist/node_modules/react-day-picker/dist/esm/helpers/endOfBroadcastWeek.js +0 -22
  232. package/dist/node_modules/react-day-picker/dist/esm/helpers/getBroadcastWeeksInMonth.js +0 -28
  233. package/dist/node_modules/react-day-picker/dist/esm/helpers/getClassNamesForModifiers.js +0 -33
  234. package/dist/node_modules/react-day-picker/dist/esm/helpers/getComponents.js +0 -20
  235. package/dist/node_modules/react-day-picker/dist/esm/helpers/getDataAttributes.js +0 -27
  236. package/dist/node_modules/react-day-picker/dist/esm/helpers/getDates.js +0 -51
  237. package/dist/node_modules/react-day-picker/dist/esm/helpers/getDays.js +0 -19
  238. package/dist/node_modules/react-day-picker/dist/esm/helpers/getDefaultClassNames.js +0 -33
  239. package/dist/node_modules/react-day-picker/dist/esm/helpers/getDisplayMonths.js +0 -24
  240. package/dist/node_modules/react-day-picker/dist/esm/helpers/getFocusableDate.js +0 -46
  241. package/dist/node_modules/react-day-picker/dist/esm/helpers/getFormatters.js +0 -24
  242. package/dist/node_modules/react-day-picker/dist/esm/helpers/getInitialMonth.js +0 -28
  243. package/dist/node_modules/react-day-picker/dist/esm/helpers/getMonthOptions.js +0 -33
  244. package/dist/node_modules/react-day-picker/dist/esm/helpers/getMonths.js +0 -69
  245. package/dist/node_modules/react-day-picker/dist/esm/helpers/getNavMonth.js +0 -51
  246. package/dist/node_modules/react-day-picker/dist/esm/helpers/getNextFocus.js +0 -39
  247. package/dist/node_modules/react-day-picker/dist/esm/helpers/getNextMonth.js +0 -36
  248. package/dist/node_modules/react-day-picker/dist/esm/helpers/getPreviousMonth.js +0 -37
  249. package/dist/node_modules/react-day-picker/dist/esm/helpers/getStyleForModifiers.js +0 -27
  250. package/dist/node_modules/react-day-picker/dist/esm/helpers/getWeekdays.js +0 -24
  251. package/dist/node_modules/react-day-picker/dist/esm/helpers/getWeeks.js +0 -14
  252. package/dist/node_modules/react-day-picker/dist/esm/helpers/getYearOptions.js +0 -38
  253. package/dist/node_modules/react-day-picker/dist/esm/helpers/startOfBroadcastWeek.js +0 -27
  254. package/dist/node_modules/react-day-picker/dist/esm/helpers/useControlledValue.js +0 -31
  255. package/dist/node_modules/react-day-picker/dist/esm/labels/index.js +0 -11
  256. package/dist/node_modules/react-day-picker/dist/esm/labels/labelDayButton.js +0 -32
  257. package/dist/node_modules/react-day-picker/dist/esm/labels/labelGrid.js +0 -24
  258. package/dist/node_modules/react-day-picker/dist/esm/labels/labelGridcell.js +0 -22
  259. package/dist/node_modules/react-day-picker/dist/esm/labels/labelMonthDropdown.js +0 -14
  260. package/dist/node_modules/react-day-picker/dist/esm/labels/labelNav.js +0 -13
  261. package/dist/node_modules/react-day-picker/dist/esm/labels/labelNext.js +0 -15
  262. package/dist/node_modules/react-day-picker/dist/esm/labels/labelPrevious.js +0 -15
  263. package/dist/node_modules/react-day-picker/dist/esm/labels/labelWeekNumber.js +0 -15
  264. package/dist/node_modules/react-day-picker/dist/esm/labels/labelWeekNumberHeader.js +0 -14
  265. package/dist/node_modules/react-day-picker/dist/esm/labels/labelWeekday.js +0 -18
  266. package/dist/node_modules/react-day-picker/dist/esm/labels/labelYearDropdown.js +0 -14
  267. package/dist/node_modules/react-day-picker/dist/esm/selection/useMulti.js +0 -57
  268. package/dist/node_modules/react-day-picker/dist/esm/selection/useRange.js +0 -45
  269. package/dist/node_modules/react-day-picker/dist/esm/selection/useSingle.js +0 -44
  270. package/dist/node_modules/react-day-picker/dist/esm/useAnimation.js +0 -175
  271. package/dist/node_modules/react-day-picker/dist/esm/useCalendar.js +0 -85
  272. package/dist/node_modules/react-day-picker/dist/esm/useDayPicker.js +0 -25
  273. package/dist/node_modules/react-day-picker/dist/esm/useFocus.js +0 -50
  274. package/dist/node_modules/react-day-picker/dist/esm/useSelection.js +0 -31
  275. package/dist/node_modules/react-day-picker/dist/esm/utils/addToRange.js +0 -92
  276. package/dist/node_modules/react-day-picker/dist/esm/utils/dateMatchModifiers.js +0 -62
  277. package/dist/node_modules/react-day-picker/dist/esm/utils/rangeContainsDayOfWeek.js +0 -30
  278. package/dist/node_modules/react-day-picker/dist/esm/utils/rangeContainsModifiers.js +0 -74
  279. package/dist/node_modules/react-day-picker/dist/esm/utils/rangeIncludesDate.js +0 -35
  280. package/dist/node_modules/react-day-picker/dist/esm/utils/rangeOverlaps.js +0 -21
  281. package/dist/node_modules/react-day-picker/dist/esm/utils/typeguards.js +0 -66
  282. package/dist/node_modules/react-hook-form/dist/index.esm.js +0 -507
  283. package/dist/node_modules/react-remove-scroll/dist/es2015/Combination.js +0 -9
  284. package/dist/node_modules/react-remove-scroll/dist/es2015/SideEffect.js +0 -160
  285. package/dist/node_modules/react-remove-scroll/dist/es2015/UI.js +0 -38
  286. package/dist/node_modules/react-remove-scroll/dist/es2015/aggresiveCapture.js +0 -21
  287. package/dist/node_modules/react-remove-scroll/dist/es2015/handleScroll.js +0 -110
  288. package/dist/node_modules/react-remove-scroll/dist/es2015/medium.js +0 -5
  289. package/dist/node_modules/react-remove-scroll/dist/es2015/sidecar.js +0 -7
  290. package/dist/node_modules/react-remove-scroll-bar/dist/es2015/component.js +0 -56
  291. package/dist/node_modules/react-remove-scroll-bar/dist/es2015/constants.js +0 -10
  292. package/dist/node_modules/react-remove-scroll-bar/dist/es2015/utils.js +0 -31
  293. package/dist/node_modules/react-resizable-panels/dist/react-resizable-panels.js +0 -2407
  294. package/dist/node_modules/react-style-singleton/dist/es2015/component.js +0 -19
  295. package/dist/node_modules/react-style-singleton/dist/es2015/hook.js +0 -25
  296. package/dist/node_modules/react-style-singleton/dist/es2015/singleton.js +0 -51
  297. package/dist/node_modules/sonner/dist/index.js +0 -1125
  298. package/dist/node_modules/tailwind-merge/dist/bundle-mjs.js +0 -2956
  299. package/dist/node_modules/tslib/tslib.es6.js +0 -56
  300. package/dist/node_modules/use-callback-ref/dist/es2015/assignRef.js +0 -24
  301. package/dist/node_modules/use-callback-ref/dist/es2015/useMergeRef.js +0 -48
  302. package/dist/node_modules/use-callback-ref/dist/es2015/useRef.js +0 -42
  303. package/dist/node_modules/use-sidecar/dist/es2015/exports.js +0 -21
  304. package/dist/node_modules/use-sidecar/dist/es2015/medium.js +0 -77
  305. package/dist/node_modules/vaul/dist/index.js +0 -1627
  306. package/dist/providers/ThemeProvider.d.ts +0 -12
  307. package/dist/providers/ThemeProvider.js +0 -27
  308. package/dist/providers/index.d.ts +0 -3
  309. package/dist/styles.css +0 -1
@@ -1,1125 +0,0 @@
1
- import React__default from 'react';
2
- import ReactDOM__default from 'react-dom';
3
-
4
- function __insertCSS(code) {
5
- if (typeof document == 'undefined') return
6
- let head = document.head || document.getElementsByTagName('head')[0];
7
- let style = document.createElement('style');
8
- style.type = 'text/css';
9
- head.appendChild(style)
10
- ;style.styleSheet ? (style.styleSheet.cssText = code) : style.appendChild(document.createTextNode(code));
11
- }
12
-
13
- const getAsset = (type)=>{
14
- switch(type){
15
- case 'success':
16
- return SuccessIcon;
17
- case 'info':
18
- return InfoIcon;
19
- case 'warning':
20
- return WarningIcon;
21
- case 'error':
22
- return ErrorIcon;
23
- default:
24
- return null;
25
- }
26
- };
27
- const bars = Array(12).fill(0);
28
- const Loader = ({ visible, className })=>{
29
- return /*#__PURE__*/ React__default.createElement("div", {
30
- className: [
31
- 'sonner-loading-wrapper',
32
- className
33
- ].filter(Boolean).join(' '),
34
- "data-visible": visible
35
- }, /*#__PURE__*/ React__default.createElement("div", {
36
- className: "sonner-spinner"
37
- }, bars.map((_, i)=>/*#__PURE__*/ React__default.createElement("div", {
38
- className: "sonner-loading-bar",
39
- key: `spinner-bar-${i}`
40
- }))));
41
- };
42
- const SuccessIcon = /*#__PURE__*/ React__default.createElement("svg", {
43
- xmlns: "http://www.w3.org/2000/svg",
44
- viewBox: "0 0 20 20",
45
- fill: "currentColor",
46
- height: "20",
47
- width: "20"
48
- }, /*#__PURE__*/ React__default.createElement("path", {
49
- fillRule: "evenodd",
50
- d: "M10 18a8 8 0 100-16 8 8 0 000 16zm3.857-9.809a.75.75 0 00-1.214-.882l-3.483 4.79-1.88-1.88a.75.75 0 10-1.06 1.061l2.5 2.5a.75.75 0 001.137-.089l4-5.5z",
51
- clipRule: "evenodd"
52
- }));
53
- const WarningIcon = /*#__PURE__*/ React__default.createElement("svg", {
54
- xmlns: "http://www.w3.org/2000/svg",
55
- viewBox: "0 0 24 24",
56
- fill: "currentColor",
57
- height: "20",
58
- width: "20"
59
- }, /*#__PURE__*/ React__default.createElement("path", {
60
- fillRule: "evenodd",
61
- d: "M9.401 3.003c1.155-2 4.043-2 5.197 0l7.355 12.748c1.154 2-.29 4.5-2.599 4.5H4.645c-2.309 0-3.752-2.5-2.598-4.5L9.4 3.003zM12 8.25a.75.75 0 01.75.75v3.75a.75.75 0 01-1.5 0V9a.75.75 0 01.75-.75zm0 8.25a.75.75 0 100-1.5.75.75 0 000 1.5z",
62
- clipRule: "evenodd"
63
- }));
64
- const InfoIcon = /*#__PURE__*/ React__default.createElement("svg", {
65
- xmlns: "http://www.w3.org/2000/svg",
66
- viewBox: "0 0 20 20",
67
- fill: "currentColor",
68
- height: "20",
69
- width: "20"
70
- }, /*#__PURE__*/ React__default.createElement("path", {
71
- fillRule: "evenodd",
72
- d: "M18 10a8 8 0 11-16 0 8 8 0 0116 0zm-7-4a1 1 0 11-2 0 1 1 0 012 0zM9 9a.75.75 0 000 1.5h.253a.25.25 0 01.244.304l-.459 2.066A1.75 1.75 0 0010.747 15H11a.75.75 0 000-1.5h-.253a.25.25 0 01-.244-.304l.459-2.066A1.75 1.75 0 009.253 9H9z",
73
- clipRule: "evenodd"
74
- }));
75
- const ErrorIcon = /*#__PURE__*/ React__default.createElement("svg", {
76
- xmlns: "http://www.w3.org/2000/svg",
77
- viewBox: "0 0 20 20",
78
- fill: "currentColor",
79
- height: "20",
80
- width: "20"
81
- }, /*#__PURE__*/ React__default.createElement("path", {
82
- fillRule: "evenodd",
83
- d: "M18 10a8 8 0 11-16 0 8 8 0 0116 0zm-8-5a.75.75 0 01.75.75v4.5a.75.75 0 01-1.5 0v-4.5A.75.75 0 0110 5zm0 10a1 1 0 100-2 1 1 0 000 2z",
84
- clipRule: "evenodd"
85
- }));
86
- const CloseIcon = /*#__PURE__*/ React__default.createElement("svg", {
87
- xmlns: "http://www.w3.org/2000/svg",
88
- width: "12",
89
- height: "12",
90
- viewBox: "0 0 24 24",
91
- fill: "none",
92
- stroke: "currentColor",
93
- strokeWidth: "1.5",
94
- strokeLinecap: "round",
95
- strokeLinejoin: "round"
96
- }, /*#__PURE__*/ React__default.createElement("line", {
97
- x1: "18",
98
- y1: "6",
99
- x2: "6",
100
- y2: "18"
101
- }), /*#__PURE__*/ React__default.createElement("line", {
102
- x1: "6",
103
- y1: "6",
104
- x2: "18",
105
- y2: "18"
106
- }));
107
-
108
- const useIsDocumentHidden = ()=>{
109
- const [isDocumentHidden, setIsDocumentHidden] = React__default.useState(document.hidden);
110
- React__default.useEffect(()=>{
111
- const callback = ()=>{
112
- setIsDocumentHidden(document.hidden);
113
- };
114
- document.addEventListener('visibilitychange', callback);
115
- return ()=>window.removeEventListener('visibilitychange', callback);
116
- }, []);
117
- return isDocumentHidden;
118
- };
119
-
120
- let toastsCounter = 1;
121
- class Observer {
122
- constructor(){
123
- // We use arrow functions to maintain the correct `this` reference
124
- this.subscribe = (subscriber)=>{
125
- this.subscribers.push(subscriber);
126
- return ()=>{
127
- const index = this.subscribers.indexOf(subscriber);
128
- this.subscribers.splice(index, 1);
129
- };
130
- };
131
- this.publish = (data)=>{
132
- this.subscribers.forEach((subscriber)=>subscriber(data));
133
- };
134
- this.addToast = (data)=>{
135
- this.publish(data);
136
- this.toasts = [
137
- ...this.toasts,
138
- data
139
- ];
140
- };
141
- this.create = (data)=>{
142
- var _data_id;
143
- const { message, ...rest } = data;
144
- const id = typeof (data == null ? void 0 : data.id) === 'number' || ((_data_id = data.id) == null ? void 0 : _data_id.length) > 0 ? data.id : toastsCounter++;
145
- const alreadyExists = this.toasts.find((toast)=>{
146
- return toast.id === id;
147
- });
148
- const dismissible = data.dismissible === undefined ? true : data.dismissible;
149
- if (this.dismissedToasts.has(id)) {
150
- this.dismissedToasts.delete(id);
151
- }
152
- if (alreadyExists) {
153
- this.toasts = this.toasts.map((toast)=>{
154
- if (toast.id === id) {
155
- this.publish({
156
- ...toast,
157
- ...data,
158
- id,
159
- title: message
160
- });
161
- return {
162
- ...toast,
163
- ...data,
164
- id,
165
- dismissible,
166
- title: message
167
- };
168
- }
169
- return toast;
170
- });
171
- } else {
172
- this.addToast({
173
- title: message,
174
- ...rest,
175
- dismissible,
176
- id
177
- });
178
- }
179
- return id;
180
- };
181
- this.dismiss = (id)=>{
182
- if (id) {
183
- this.dismissedToasts.add(id);
184
- requestAnimationFrame(()=>this.subscribers.forEach((subscriber)=>subscriber({
185
- id,
186
- dismiss: true
187
- })));
188
- } else {
189
- this.toasts.forEach((toast)=>{
190
- this.subscribers.forEach((subscriber)=>subscriber({
191
- id: toast.id,
192
- dismiss: true
193
- }));
194
- });
195
- }
196
- return id;
197
- };
198
- this.message = (message, data)=>{
199
- return this.create({
200
- ...data,
201
- message
202
- });
203
- };
204
- this.error = (message, data)=>{
205
- return this.create({
206
- ...data,
207
- message,
208
- type: 'error'
209
- });
210
- };
211
- this.success = (message, data)=>{
212
- return this.create({
213
- ...data,
214
- type: 'success',
215
- message
216
- });
217
- };
218
- this.info = (message, data)=>{
219
- return this.create({
220
- ...data,
221
- type: 'info',
222
- message
223
- });
224
- };
225
- this.warning = (message, data)=>{
226
- return this.create({
227
- ...data,
228
- type: 'warning',
229
- message
230
- });
231
- };
232
- this.loading = (message, data)=>{
233
- return this.create({
234
- ...data,
235
- type: 'loading',
236
- message
237
- });
238
- };
239
- this.promise = (promise, data)=>{
240
- if (!data) {
241
- // Nothing to show
242
- return;
243
- }
244
- let id = undefined;
245
- if (data.loading !== undefined) {
246
- id = this.create({
247
- ...data,
248
- promise,
249
- type: 'loading',
250
- message: data.loading,
251
- description: typeof data.description !== 'function' ? data.description : undefined
252
- });
253
- }
254
- const p = Promise.resolve(promise instanceof Function ? promise() : promise);
255
- let shouldDismiss = id !== undefined;
256
- let result;
257
- const originalPromise = p.then(async (response)=>{
258
- result = [
259
- 'resolve',
260
- response
261
- ];
262
- const isReactElementResponse = React__default.isValidElement(response);
263
- if (isReactElementResponse) {
264
- shouldDismiss = false;
265
- this.create({
266
- id,
267
- type: 'default',
268
- message: response
269
- });
270
- } else if (isHttpResponse(response) && !response.ok) {
271
- shouldDismiss = false;
272
- const promiseData = typeof data.error === 'function' ? await data.error(`HTTP error! status: ${response.status}`) : data.error;
273
- const description = typeof data.description === 'function' ? await data.description(`HTTP error! status: ${response.status}`) : data.description;
274
- const isExtendedResult = typeof promiseData === 'object' && !React__default.isValidElement(promiseData);
275
- const toastSettings = isExtendedResult ? promiseData : {
276
- message: promiseData
277
- };
278
- this.create({
279
- id,
280
- type: 'error',
281
- description,
282
- ...toastSettings
283
- });
284
- } else if (response instanceof Error) {
285
- shouldDismiss = false;
286
- const promiseData = typeof data.error === 'function' ? await data.error(response) : data.error;
287
- const description = typeof data.description === 'function' ? await data.description(response) : data.description;
288
- const isExtendedResult = typeof promiseData === 'object' && !React__default.isValidElement(promiseData);
289
- const toastSettings = isExtendedResult ? promiseData : {
290
- message: promiseData
291
- };
292
- this.create({
293
- id,
294
- type: 'error',
295
- description,
296
- ...toastSettings
297
- });
298
- } else if (data.success !== undefined) {
299
- shouldDismiss = false;
300
- const promiseData = typeof data.success === 'function' ? await data.success(response) : data.success;
301
- const description = typeof data.description === 'function' ? await data.description(response) : data.description;
302
- const isExtendedResult = typeof promiseData === 'object' && !React__default.isValidElement(promiseData);
303
- const toastSettings = isExtendedResult ? promiseData : {
304
- message: promiseData
305
- };
306
- this.create({
307
- id,
308
- type: 'success',
309
- description,
310
- ...toastSettings
311
- });
312
- }
313
- }).catch(async (error)=>{
314
- result = [
315
- 'reject',
316
- error
317
- ];
318
- if (data.error !== undefined) {
319
- shouldDismiss = false;
320
- const promiseData = typeof data.error === 'function' ? await data.error(error) : data.error;
321
- const description = typeof data.description === 'function' ? await data.description(error) : data.description;
322
- const isExtendedResult = typeof promiseData === 'object' && !React__default.isValidElement(promiseData);
323
- const toastSettings = isExtendedResult ? promiseData : {
324
- message: promiseData
325
- };
326
- this.create({
327
- id,
328
- type: 'error',
329
- description,
330
- ...toastSettings
331
- });
332
- }
333
- }).finally(()=>{
334
- if (shouldDismiss) {
335
- // Toast is still in load state (and will be indefinitely — dismiss it)
336
- this.dismiss(id);
337
- id = undefined;
338
- }
339
- data.finally == null ? void 0 : data.finally.call(data);
340
- });
341
- const unwrap = ()=>new Promise((resolve, reject)=>originalPromise.then(()=>result[0] === 'reject' ? reject(result[1]) : resolve(result[1])).catch(reject));
342
- if (typeof id !== 'string' && typeof id !== 'number') {
343
- // cannot Object.assign on undefined
344
- return {
345
- unwrap
346
- };
347
- } else {
348
- return Object.assign(id, {
349
- unwrap
350
- });
351
- }
352
- };
353
- this.custom = (jsx, data)=>{
354
- const id = (data == null ? void 0 : data.id) || toastsCounter++;
355
- this.create({
356
- jsx: jsx(id),
357
- id,
358
- ...data
359
- });
360
- return id;
361
- };
362
- this.getActiveToasts = ()=>{
363
- return this.toasts.filter((toast)=>!this.dismissedToasts.has(toast.id));
364
- };
365
- this.subscribers = [];
366
- this.toasts = [];
367
- this.dismissedToasts = new Set();
368
- }
369
- }
370
- const ToastState = new Observer();
371
- // bind this to the toast function
372
- const toastFunction = (message, data)=>{
373
- const id = (data == null ? void 0 : data.id) || toastsCounter++;
374
- ToastState.addToast({
375
- title: message,
376
- ...data,
377
- id
378
- });
379
- return id;
380
- };
381
- const isHttpResponse = (data)=>{
382
- return data && typeof data === 'object' && 'ok' in data && typeof data.ok === 'boolean' && 'status' in data && typeof data.status === 'number';
383
- };
384
- const basicToast = toastFunction;
385
- const getHistory = ()=>ToastState.toasts;
386
- const getToasts = ()=>ToastState.getActiveToasts();
387
- // We use `Object.assign` to maintain the correct types as we would lose them otherwise
388
- Object.assign(basicToast, {
389
- success: ToastState.success,
390
- info: ToastState.info,
391
- warning: ToastState.warning,
392
- error: ToastState.error,
393
- custom: ToastState.custom,
394
- message: ToastState.message,
395
- promise: ToastState.promise,
396
- dismiss: ToastState.dismiss,
397
- loading: ToastState.loading
398
- }, {
399
- getHistory,
400
- getToasts
401
- });
402
-
403
- __insertCSS("[data-sonner-toaster][dir=ltr],html[dir=ltr]{--toast-icon-margin-start:-3px;--toast-icon-margin-end:4px;--toast-svg-margin-start:-1px;--toast-svg-margin-end:0px;--toast-button-margin-start:auto;--toast-button-margin-end:0;--toast-close-button-start:0;--toast-close-button-end:unset;--toast-close-button-transform:translate(-35%, -35%)}[data-sonner-toaster][dir=rtl],html[dir=rtl]{--toast-icon-margin-start:4px;--toast-icon-margin-end:-3px;--toast-svg-margin-start:0px;--toast-svg-margin-end:-1px;--toast-button-margin-start:0;--toast-button-margin-end:auto;--toast-close-button-start:unset;--toast-close-button-end:0;--toast-close-button-transform:translate(35%, -35%)}[data-sonner-toaster]{position:fixed;width:var(--width);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;--gray1:hsl(0, 0%, 99%);--gray2:hsl(0, 0%, 97.3%);--gray3:hsl(0, 0%, 95.1%);--gray4:hsl(0, 0%, 93%);--gray5:hsl(0, 0%, 90.9%);--gray6:hsl(0, 0%, 88.7%);--gray7:hsl(0, 0%, 85.8%);--gray8:hsl(0, 0%, 78%);--gray9:hsl(0, 0%, 56.1%);--gray10:hsl(0, 0%, 52.3%);--gray11:hsl(0, 0%, 43.5%);--gray12:hsl(0, 0%, 9%);--border-radius:8px;box-sizing:border-box;padding:0;margin:0;list-style:none;outline:0;z-index:999999999;transition:transform .4s ease}@media (hover:none) and (pointer:coarse){[data-sonner-toaster][data-lifted=true]{transform:none}}[data-sonner-toaster][data-x-position=right]{right:var(--offset-right)}[data-sonner-toaster][data-x-position=left]{left:var(--offset-left)}[data-sonner-toaster][data-x-position=center]{left:50%;transform:translateX(-50%)}[data-sonner-toaster][data-y-position=top]{top:var(--offset-top)}[data-sonner-toaster][data-y-position=bottom]{bottom:var(--offset-bottom)}[data-sonner-toast]{--y:translateY(100%);--lift-amount:calc(var(--lift) * var(--gap));z-index:var(--z-index);position:absolute;opacity:0;transform:var(--y);touch-action:none;transition:transform .4s,opacity .4s,height .4s,box-shadow .2s;box-sizing:border-box;outline:0;overflow-wrap:anywhere}[data-sonner-toast][data-styled=true]{padding:16px;background:var(--normal-bg);border:1px solid var(--normal-border);color:var(--normal-text);border-radius:var(--border-radius);box-shadow:0 4px 12px rgba(0,0,0,.1);width:var(--width);font-size:13px;display:flex;align-items:center;gap:6px}[data-sonner-toast]:focus-visible{box-shadow:0 4px 12px rgba(0,0,0,.1),0 0 0 2px rgba(0,0,0,.2)}[data-sonner-toast][data-y-position=top]{top:0;--y:translateY(-100%);--lift:1;--lift-amount:calc(1 * var(--gap))}[data-sonner-toast][data-y-position=bottom]{bottom:0;--y:translateY(100%);--lift:-1;--lift-amount:calc(var(--lift) * var(--gap))}[data-sonner-toast][data-styled=true] [data-description]{font-weight:400;line-height:1.4;color:#3f3f3f}[data-rich-colors=true][data-sonner-toast][data-styled=true] [data-description]{color:inherit}[data-sonner-toaster][data-sonner-theme=dark] [data-description]{color:#e8e8e8}[data-sonner-toast][data-styled=true] [data-title]{font-weight:500;line-height:1.5;color:inherit}[data-sonner-toast][data-styled=true] [data-icon]{display:flex;height:16px;width:16px;position:relative;justify-content:flex-start;align-items:center;flex-shrink:0;margin-left:var(--toast-icon-margin-start);margin-right:var(--toast-icon-margin-end)}[data-sonner-toast][data-promise=true] [data-icon]>svg{opacity:0;transform:scale(.8);transform-origin:center;animation:sonner-fade-in .3s ease forwards}[data-sonner-toast][data-styled=true] [data-icon]>*{flex-shrink:0}[data-sonner-toast][data-styled=true] [data-icon] svg{margin-left:var(--toast-svg-margin-start);margin-right:var(--toast-svg-margin-end)}[data-sonner-toast][data-styled=true] [data-content]{display:flex;flex-direction:column;gap:2px}[data-sonner-toast][data-styled=true] [data-button]{border-radius:4px;padding-left:8px;padding-right:8px;height:24px;font-size:12px;color:var(--normal-bg);background:var(--normal-text);margin-left:var(--toast-button-margin-start);margin-right:var(--toast-button-margin-end);border:none;font-weight:500;cursor:pointer;outline:0;display:flex;align-items:center;flex-shrink:0;transition:opacity .4s,box-shadow .2s}[data-sonner-toast][data-styled=true] [data-button]:focus-visible{box-shadow:0 0 0 2px rgba(0,0,0,.4)}[data-sonner-toast][data-styled=true] [data-button]:first-of-type{margin-left:var(--toast-button-margin-start);margin-right:var(--toast-button-margin-end)}[data-sonner-toast][data-styled=true] [data-cancel]{color:var(--normal-text);background:rgba(0,0,0,.08)}[data-sonner-toaster][data-sonner-theme=dark] [data-sonner-toast][data-styled=true] [data-cancel]{background:rgba(255,255,255,.3)}[data-sonner-toast][data-styled=true] [data-close-button]{position:absolute;left:var(--toast-close-button-start);right:var(--toast-close-button-end);top:0;height:20px;width:20px;display:flex;justify-content:center;align-items:center;padding:0;color:var(--gray12);background:var(--normal-bg);border:1px solid var(--gray4);transform:var(--toast-close-button-transform);border-radius:50%;cursor:pointer;z-index:1;transition:opacity .1s,background .2s,border-color .2s}[data-sonner-toast][data-styled=true] [data-close-button]:focus-visible{box-shadow:0 4px 12px rgba(0,0,0,.1),0 0 0 2px rgba(0,0,0,.2)}[data-sonner-toast][data-styled=true] [data-disabled=true]{cursor:not-allowed}[data-sonner-toast][data-styled=true]:hover [data-close-button]:hover{background:var(--gray2);border-color:var(--gray5)}[data-sonner-toast][data-swiping=true]::before{content:'';position:absolute;left:-100%;right:-100%;height:100%;z-index:-1}[data-sonner-toast][data-y-position=top][data-swiping=true]::before{bottom:50%;transform:scaleY(3) translateY(50%)}[data-sonner-toast][data-y-position=bottom][data-swiping=true]::before{top:50%;transform:scaleY(3) translateY(-50%)}[data-sonner-toast][data-swiping=false][data-removed=true]::before{content:'';position:absolute;inset:0;transform:scaleY(2)}[data-sonner-toast][data-expanded=true]::after{content:'';position:absolute;left:0;height:calc(var(--gap) + 1px);bottom:100%;width:100%}[data-sonner-toast][data-mounted=true]{--y:translateY(0);opacity:1}[data-sonner-toast][data-expanded=false][data-front=false]{--scale:var(--toasts-before) * 0.05 + 1;--y:translateY(calc(var(--lift-amount) * var(--toasts-before))) scale(calc(-1 * var(--scale)));height:var(--front-toast-height)}[data-sonner-toast]>*{transition:opacity .4s}[data-sonner-toast][data-x-position=right]{right:0}[data-sonner-toast][data-x-position=left]{left:0}[data-sonner-toast][data-expanded=false][data-front=false][data-styled=true]>*{opacity:0}[data-sonner-toast][data-visible=false]{opacity:0;pointer-events:none}[data-sonner-toast][data-mounted=true][data-expanded=true]{--y:translateY(calc(var(--lift) * var(--offset)));height:var(--initial-height)}[data-sonner-toast][data-removed=true][data-front=true][data-swipe-out=false]{--y:translateY(calc(var(--lift) * -100%));opacity:0}[data-sonner-toast][data-removed=true][data-front=false][data-swipe-out=false][data-expanded=true]{--y:translateY(calc(var(--lift) * var(--offset) + var(--lift) * -100%));opacity:0}[data-sonner-toast][data-removed=true][data-front=false][data-swipe-out=false][data-expanded=false]{--y:translateY(40%);opacity:0;transition:transform .5s,opacity .2s}[data-sonner-toast][data-removed=true][data-front=false]::before{height:calc(var(--initial-height) + 20%)}[data-sonner-toast][data-swiping=true]{transform:var(--y) translateY(var(--swipe-amount-y,0)) translateX(var(--swipe-amount-x,0));transition:none}[data-sonner-toast][data-swiped=true]{user-select:none}[data-sonner-toast][data-swipe-out=true][data-y-position=bottom],[data-sonner-toast][data-swipe-out=true][data-y-position=top]{animation-duration:.2s;animation-timing-function:ease-out;animation-fill-mode:forwards}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=left]{animation-name:swipe-out-left}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=right]{animation-name:swipe-out-right}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=up]{animation-name:swipe-out-up}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=down]{animation-name:swipe-out-down}@keyframes swipe-out-left{from{transform:var(--y) translateX(var(--swipe-amount-x));opacity:1}to{transform:var(--y) translateX(calc(var(--swipe-amount-x) - 100%));opacity:0}}@keyframes swipe-out-right{from{transform:var(--y) translateX(var(--swipe-amount-x));opacity:1}to{transform:var(--y) translateX(calc(var(--swipe-amount-x) + 100%));opacity:0}}@keyframes swipe-out-up{from{transform:var(--y) translateY(var(--swipe-amount-y));opacity:1}to{transform:var(--y) translateY(calc(var(--swipe-amount-y) - 100%));opacity:0}}@keyframes swipe-out-down{from{transform:var(--y) translateY(var(--swipe-amount-y));opacity:1}to{transform:var(--y) translateY(calc(var(--swipe-amount-y) + 100%));opacity:0}}@media (max-width:600px){[data-sonner-toaster]{position:fixed;right:var(--mobile-offset-right);left:var(--mobile-offset-left);width:100%}[data-sonner-toaster][dir=rtl]{left:calc(var(--mobile-offset-left) * -1)}[data-sonner-toaster] [data-sonner-toast]{left:0;right:0;width:calc(100% - var(--mobile-offset-left) * 2)}[data-sonner-toaster][data-x-position=left]{left:var(--mobile-offset-left)}[data-sonner-toaster][data-y-position=bottom]{bottom:var(--mobile-offset-bottom)}[data-sonner-toaster][data-y-position=top]{top:var(--mobile-offset-top)}[data-sonner-toaster][data-x-position=center]{left:var(--mobile-offset-left);right:var(--mobile-offset-right);transform:none}}[data-sonner-toaster][data-sonner-theme=light]{--normal-bg:#fff;--normal-border:var(--gray4);--normal-text:var(--gray12);--success-bg:hsl(143, 85%, 96%);--success-border:hsl(145, 92%, 87%);--success-text:hsl(140, 100%, 27%);--info-bg:hsl(208, 100%, 97%);--info-border:hsl(221, 91%, 93%);--info-text:hsl(210, 92%, 45%);--warning-bg:hsl(49, 100%, 97%);--warning-border:hsl(49, 91%, 84%);--warning-text:hsl(31, 92%, 45%);--error-bg:hsl(359, 100%, 97%);--error-border:hsl(359, 100%, 94%);--error-text:hsl(360, 100%, 45%)}[data-sonner-toaster][data-sonner-theme=light] [data-sonner-toast][data-invert=true]{--normal-bg:#000;--normal-border:hsl(0, 0%, 20%);--normal-text:var(--gray1)}[data-sonner-toaster][data-sonner-theme=dark] [data-sonner-toast][data-invert=true]{--normal-bg:#fff;--normal-border:var(--gray3);--normal-text:var(--gray12)}[data-sonner-toaster][data-sonner-theme=dark]{--normal-bg:#000;--normal-bg-hover:hsl(0, 0%, 12%);--normal-border:hsl(0, 0%, 20%);--normal-border-hover:hsl(0, 0%, 25%);--normal-text:var(--gray1);--success-bg:hsl(150, 100%, 6%);--success-border:hsl(147, 100%, 12%);--success-text:hsl(150, 86%, 65%);--info-bg:hsl(215, 100%, 6%);--info-border:hsl(223, 43%, 17%);--info-text:hsl(216, 87%, 65%);--warning-bg:hsl(64, 100%, 6%);--warning-border:hsl(60, 100%, 9%);--warning-text:hsl(46, 87%, 65%);--error-bg:hsl(358, 76%, 10%);--error-border:hsl(357, 89%, 16%);--error-text:hsl(358, 100%, 81%)}[data-sonner-toaster][data-sonner-theme=dark] [data-sonner-toast] [data-close-button]{background:var(--normal-bg);border-color:var(--normal-border);color:var(--normal-text)}[data-sonner-toaster][data-sonner-theme=dark] [data-sonner-toast] [data-close-button]:hover{background:var(--normal-bg-hover);border-color:var(--normal-border-hover)}[data-rich-colors=true][data-sonner-toast][data-type=success]{background:var(--success-bg);border-color:var(--success-border);color:var(--success-text)}[data-rich-colors=true][data-sonner-toast][data-type=success] [data-close-button]{background:var(--success-bg);border-color:var(--success-border);color:var(--success-text)}[data-rich-colors=true][data-sonner-toast][data-type=info]{background:var(--info-bg);border-color:var(--info-border);color:var(--info-text)}[data-rich-colors=true][data-sonner-toast][data-type=info] [data-close-button]{background:var(--info-bg);border-color:var(--info-border);color:var(--info-text)}[data-rich-colors=true][data-sonner-toast][data-type=warning]{background:var(--warning-bg);border-color:var(--warning-border);color:var(--warning-text)}[data-rich-colors=true][data-sonner-toast][data-type=warning] [data-close-button]{background:var(--warning-bg);border-color:var(--warning-border);color:var(--warning-text)}[data-rich-colors=true][data-sonner-toast][data-type=error]{background:var(--error-bg);border-color:var(--error-border);color:var(--error-text)}[data-rich-colors=true][data-sonner-toast][data-type=error] [data-close-button]{background:var(--error-bg);border-color:var(--error-border);color:var(--error-text)}.sonner-loading-wrapper{--size:16px;height:var(--size);width:var(--size);position:absolute;inset:0;z-index:10}.sonner-loading-wrapper[data-visible=false]{transform-origin:center;animation:sonner-fade-out .2s ease forwards}.sonner-spinner{position:relative;top:50%;left:50%;height:var(--size);width:var(--size)}.sonner-loading-bar{animation:sonner-spin 1.2s linear infinite;background:var(--gray11);border-radius:6px;height:8%;left:-10%;position:absolute;top:-3.9%;width:24%}.sonner-loading-bar:first-child{animation-delay:-1.2s;transform:rotate(.0001deg) translate(146%)}.sonner-loading-bar:nth-child(2){animation-delay:-1.1s;transform:rotate(30deg) translate(146%)}.sonner-loading-bar:nth-child(3){animation-delay:-1s;transform:rotate(60deg) translate(146%)}.sonner-loading-bar:nth-child(4){animation-delay:-.9s;transform:rotate(90deg) translate(146%)}.sonner-loading-bar:nth-child(5){animation-delay:-.8s;transform:rotate(120deg) translate(146%)}.sonner-loading-bar:nth-child(6){animation-delay:-.7s;transform:rotate(150deg) translate(146%)}.sonner-loading-bar:nth-child(7){animation-delay:-.6s;transform:rotate(180deg) translate(146%)}.sonner-loading-bar:nth-child(8){animation-delay:-.5s;transform:rotate(210deg) translate(146%)}.sonner-loading-bar:nth-child(9){animation-delay:-.4s;transform:rotate(240deg) translate(146%)}.sonner-loading-bar:nth-child(10){animation-delay:-.3s;transform:rotate(270deg) translate(146%)}.sonner-loading-bar:nth-child(11){animation-delay:-.2s;transform:rotate(300deg) translate(146%)}.sonner-loading-bar:nth-child(12){animation-delay:-.1s;transform:rotate(330deg) translate(146%)}@keyframes sonner-fade-in{0%{opacity:0;transform:scale(.8)}100%{opacity:1;transform:scale(1)}}@keyframes sonner-fade-out{0%{opacity:1;transform:scale(1)}100%{opacity:0;transform:scale(.8)}}@keyframes sonner-spin{0%{opacity:1}100%{opacity:.15}}@media (prefers-reduced-motion){.sonner-loading-bar,[data-sonner-toast],[data-sonner-toast]>*{transition:none!important;animation:none!important}}.sonner-loader{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);transform-origin:center;transition:opacity .2s,transform .2s}.sonner-loader[data-visible=false]{opacity:0;transform:scale(.8) translate(-50%,-50%)}");
404
-
405
- function isAction(action) {
406
- return action.label !== undefined;
407
- }
408
-
409
- // Visible toasts amount
410
- const VISIBLE_TOASTS_AMOUNT = 3;
411
- // Viewport padding
412
- const VIEWPORT_OFFSET = '24px';
413
- // Mobile viewport padding
414
- const MOBILE_VIEWPORT_OFFSET = '16px';
415
- // Default lifetime of a toasts (in ms)
416
- const TOAST_LIFETIME = 4000;
417
- // Default toast width
418
- const TOAST_WIDTH = 356;
419
- // Default gap between toasts
420
- const GAP = 14;
421
- // Threshold to dismiss a toast
422
- const SWIPE_THRESHOLD = 45;
423
- // Equal to exit animation duration
424
- const TIME_BEFORE_UNMOUNT = 200;
425
- function cn(...classes) {
426
- return classes.filter(Boolean).join(' ');
427
- }
428
- function getDefaultSwipeDirections(position) {
429
- const [y, x] = position.split('-');
430
- const directions = [];
431
- if (y) {
432
- directions.push(y);
433
- }
434
- if (x) {
435
- directions.push(x);
436
- }
437
- return directions;
438
- }
439
- const Toast = (props)=>{
440
- var _toast_classNames, _toast_classNames1, _toast_classNames2, _toast_classNames3, _toast_classNames4, _toast_classNames5, _toast_classNames6, _toast_classNames7, _toast_classNames8;
441
- const { invert: ToasterInvert, toast, unstyled, interacting, setHeights, visibleToasts, heights, index, toasts, expanded, removeToast, defaultRichColors, closeButton: closeButtonFromToaster, style, cancelButtonStyle, actionButtonStyle, className = '', descriptionClassName = '', duration: durationFromToaster, position, gap, expandByDefault, classNames, icons, closeButtonAriaLabel = 'Close toast' } = props;
442
- const [swipeDirection, setSwipeDirection] = React__default.useState(null);
443
- const [swipeOutDirection, setSwipeOutDirection] = React__default.useState(null);
444
- const [mounted, setMounted] = React__default.useState(false);
445
- const [removed, setRemoved] = React__default.useState(false);
446
- const [swiping, setSwiping] = React__default.useState(false);
447
- const [swipeOut, setSwipeOut] = React__default.useState(false);
448
- const [isSwiped, setIsSwiped] = React__default.useState(false);
449
- const [offsetBeforeRemove, setOffsetBeforeRemove] = React__default.useState(0);
450
- const [initialHeight, setInitialHeight] = React__default.useState(0);
451
- const remainingTime = React__default.useRef(toast.duration || durationFromToaster || TOAST_LIFETIME);
452
- const dragStartTime = React__default.useRef(null);
453
- const toastRef = React__default.useRef(null);
454
- const isFront = index === 0;
455
- const isVisible = index + 1 <= visibleToasts;
456
- const toastType = toast.type;
457
- const dismissible = toast.dismissible !== false;
458
- const toastClassname = toast.className || '';
459
- const toastDescriptionClassname = toast.descriptionClassName || '';
460
- // Height index is used to calculate the offset as it gets updated before the toast array, which means we can calculate the new layout faster.
461
- const heightIndex = React__default.useMemo(()=>heights.findIndex((height)=>height.toastId === toast.id) || 0, [
462
- heights,
463
- toast.id
464
- ]);
465
- const closeButton = React__default.useMemo(()=>{
466
- var _toast_closeButton;
467
- return (_toast_closeButton = toast.closeButton) != null ? _toast_closeButton : closeButtonFromToaster;
468
- }, [
469
- toast.closeButton,
470
- closeButtonFromToaster
471
- ]);
472
- const duration = React__default.useMemo(()=>toast.duration || durationFromToaster || TOAST_LIFETIME, [
473
- toast.duration,
474
- durationFromToaster
475
- ]);
476
- const closeTimerStartTimeRef = React__default.useRef(0);
477
- const offset = React__default.useRef(0);
478
- const lastCloseTimerStartTimeRef = React__default.useRef(0);
479
- const pointerStartRef = React__default.useRef(null);
480
- const [y, x] = position.split('-');
481
- const toastsHeightBefore = React__default.useMemo(()=>{
482
- return heights.reduce((prev, curr, reducerIndex)=>{
483
- // Calculate offset up until current toast
484
- if (reducerIndex >= heightIndex) {
485
- return prev;
486
- }
487
- return prev + curr.height;
488
- }, 0);
489
- }, [
490
- heights,
491
- heightIndex
492
- ]);
493
- const isDocumentHidden = useIsDocumentHidden();
494
- const invert = toast.invert || ToasterInvert;
495
- const disabled = toastType === 'loading';
496
- offset.current = React__default.useMemo(()=>heightIndex * gap + toastsHeightBefore, [
497
- heightIndex,
498
- toastsHeightBefore
499
- ]);
500
- React__default.useEffect(()=>{
501
- remainingTime.current = duration;
502
- }, [
503
- duration
504
- ]);
505
- React__default.useEffect(()=>{
506
- // Trigger enter animation without using CSS animation
507
- setMounted(true);
508
- }, []);
509
- React__default.useEffect(()=>{
510
- const toastNode = toastRef.current;
511
- if (toastNode) {
512
- const height = toastNode.getBoundingClientRect().height;
513
- // Add toast height to heights array after the toast is mounted
514
- setInitialHeight(height);
515
- setHeights((h)=>[
516
- {
517
- toastId: toast.id,
518
- height,
519
- position: toast.position
520
- },
521
- ...h
522
- ]);
523
- return ()=>setHeights((h)=>h.filter((height)=>height.toastId !== toast.id));
524
- }
525
- }, [
526
- setHeights,
527
- toast.id
528
- ]);
529
- React__default.useLayoutEffect(()=>{
530
- // Keep height up to date with the content in case it updates
531
- if (!mounted) return;
532
- const toastNode = toastRef.current;
533
- const originalHeight = toastNode.style.height;
534
- toastNode.style.height = 'auto';
535
- const newHeight = toastNode.getBoundingClientRect().height;
536
- toastNode.style.height = originalHeight;
537
- setInitialHeight(newHeight);
538
- setHeights((heights)=>{
539
- const alreadyExists = heights.find((height)=>height.toastId === toast.id);
540
- if (!alreadyExists) {
541
- return [
542
- {
543
- toastId: toast.id,
544
- height: newHeight,
545
- position: toast.position
546
- },
547
- ...heights
548
- ];
549
- } else {
550
- return heights.map((height)=>height.toastId === toast.id ? {
551
- ...height,
552
- height: newHeight
553
- } : height);
554
- }
555
- });
556
- }, [
557
- mounted,
558
- toast.title,
559
- toast.description,
560
- setHeights,
561
- toast.id,
562
- toast.jsx,
563
- toast.action,
564
- toast.cancel
565
- ]);
566
- const deleteToast = React__default.useCallback(()=>{
567
- // Save the offset for the exit swipe animation
568
- setRemoved(true);
569
- setOffsetBeforeRemove(offset.current);
570
- setHeights((h)=>h.filter((height)=>height.toastId !== toast.id));
571
- setTimeout(()=>{
572
- removeToast(toast);
573
- }, TIME_BEFORE_UNMOUNT);
574
- }, [
575
- toast,
576
- removeToast,
577
- setHeights,
578
- offset
579
- ]);
580
- React__default.useEffect(()=>{
581
- if (toast.promise && toastType === 'loading' || toast.duration === Infinity || toast.type === 'loading') return;
582
- let timeoutId;
583
- // Pause the timer on each hover
584
- const pauseTimer = ()=>{
585
- if (lastCloseTimerStartTimeRef.current < closeTimerStartTimeRef.current) {
586
- // Get the elapsed time since the timer started
587
- const elapsedTime = new Date().getTime() - closeTimerStartTimeRef.current;
588
- remainingTime.current = remainingTime.current - elapsedTime;
589
- }
590
- lastCloseTimerStartTimeRef.current = new Date().getTime();
591
- };
592
- const startTimer = ()=>{
593
- // setTimeout(, Infinity) behaves as if the delay is 0.
594
- // As a result, the toast would be closed immediately, giving the appearance that it was never rendered.
595
- // See: https://github.com/denysdovhan/wtfjs?tab=readme-ov-file#an-infinite-timeout
596
- if (remainingTime.current === Infinity) return;
597
- closeTimerStartTimeRef.current = new Date().getTime();
598
- // Let the toast know it has started
599
- timeoutId = setTimeout(()=>{
600
- toast.onAutoClose == null ? void 0 : toast.onAutoClose.call(toast, toast);
601
- deleteToast();
602
- }, remainingTime.current);
603
- };
604
- if (expanded || interacting || isDocumentHidden) {
605
- pauseTimer();
606
- } else {
607
- startTimer();
608
- }
609
- return ()=>clearTimeout(timeoutId);
610
- }, [
611
- expanded,
612
- interacting,
613
- toast,
614
- toastType,
615
- isDocumentHidden,
616
- deleteToast
617
- ]);
618
- React__default.useEffect(()=>{
619
- if (toast.delete) {
620
- deleteToast();
621
- toast.onDismiss == null ? void 0 : toast.onDismiss.call(toast, toast);
622
- }
623
- }, [
624
- deleteToast,
625
- toast.delete
626
- ]);
627
- function getLoadingIcon() {
628
- var _toast_classNames;
629
- if (icons == null ? void 0 : icons.loading) {
630
- var _toast_classNames1;
631
- return /*#__PURE__*/ React__default.createElement("div", {
632
- className: cn(classNames == null ? void 0 : classNames.loader, toast == null ? void 0 : (_toast_classNames1 = toast.classNames) == null ? void 0 : _toast_classNames1.loader, 'sonner-loader'),
633
- "data-visible": toastType === 'loading'
634
- }, icons.loading);
635
- }
636
- return /*#__PURE__*/ React__default.createElement(Loader, {
637
- className: cn(classNames == null ? void 0 : classNames.loader, toast == null ? void 0 : (_toast_classNames = toast.classNames) == null ? void 0 : _toast_classNames.loader),
638
- visible: toastType === 'loading'
639
- });
640
- }
641
- const icon = toast.icon || (icons == null ? void 0 : icons[toastType]) || getAsset(toastType);
642
- var _toast_richColors, _icons_close;
643
- return /*#__PURE__*/ React__default.createElement("li", {
644
- tabIndex: 0,
645
- ref: toastRef,
646
- className: cn(className, toastClassname, classNames == null ? void 0 : classNames.toast, toast == null ? void 0 : (_toast_classNames = toast.classNames) == null ? void 0 : _toast_classNames.toast, classNames == null ? void 0 : classNames.default, classNames == null ? void 0 : classNames[toastType], toast == null ? void 0 : (_toast_classNames1 = toast.classNames) == null ? void 0 : _toast_classNames1[toastType]),
647
- "data-sonner-toast": "",
648
- "data-rich-colors": (_toast_richColors = toast.richColors) != null ? _toast_richColors : defaultRichColors,
649
- "data-styled": !Boolean(toast.jsx || toast.unstyled || unstyled),
650
- "data-mounted": mounted,
651
- "data-promise": Boolean(toast.promise),
652
- "data-swiped": isSwiped,
653
- "data-removed": removed,
654
- "data-visible": isVisible,
655
- "data-y-position": y,
656
- "data-x-position": x,
657
- "data-index": index,
658
- "data-front": isFront,
659
- "data-swiping": swiping,
660
- "data-dismissible": dismissible,
661
- "data-type": toastType,
662
- "data-invert": invert,
663
- "data-swipe-out": swipeOut,
664
- "data-swipe-direction": swipeOutDirection,
665
- "data-expanded": Boolean(expanded || expandByDefault && mounted),
666
- style: {
667
- '--index': index,
668
- '--toasts-before': index,
669
- '--z-index': toasts.length - index,
670
- '--offset': `${removed ? offsetBeforeRemove : offset.current}px`,
671
- '--initial-height': expandByDefault ? 'auto' : `${initialHeight}px`,
672
- ...style,
673
- ...toast.style
674
- },
675
- onDragEnd: ()=>{
676
- setSwiping(false);
677
- setSwipeDirection(null);
678
- pointerStartRef.current = null;
679
- },
680
- onPointerDown: (event)=>{
681
- if (disabled || !dismissible) return;
682
- dragStartTime.current = new Date();
683
- setOffsetBeforeRemove(offset.current);
684
- // Ensure we maintain correct pointer capture even when going outside of the toast (e.g. when swiping)
685
- event.target.setPointerCapture(event.pointerId);
686
- if (event.target.tagName === 'BUTTON') return;
687
- setSwiping(true);
688
- pointerStartRef.current = {
689
- x: event.clientX,
690
- y: event.clientY
691
- };
692
- },
693
- onPointerUp: ()=>{
694
- var _toastRef_current, _toastRef_current1, _dragStartTime_current;
695
- if (swipeOut || !dismissible) return;
696
- pointerStartRef.current = null;
697
- const swipeAmountX = Number(((_toastRef_current = toastRef.current) == null ? void 0 : _toastRef_current.style.getPropertyValue('--swipe-amount-x').replace('px', '')) || 0);
698
- const swipeAmountY = Number(((_toastRef_current1 = toastRef.current) == null ? void 0 : _toastRef_current1.style.getPropertyValue('--swipe-amount-y').replace('px', '')) || 0);
699
- const timeTaken = new Date().getTime() - ((_dragStartTime_current = dragStartTime.current) == null ? void 0 : _dragStartTime_current.getTime());
700
- const swipeAmount = swipeDirection === 'x' ? swipeAmountX : swipeAmountY;
701
- const velocity = Math.abs(swipeAmount) / timeTaken;
702
- if (Math.abs(swipeAmount) >= SWIPE_THRESHOLD || velocity > 0.11) {
703
- setOffsetBeforeRemove(offset.current);
704
- toast.onDismiss == null ? void 0 : toast.onDismiss.call(toast, toast);
705
- if (swipeDirection === 'x') {
706
- setSwipeOutDirection(swipeAmountX > 0 ? 'right' : 'left');
707
- } else {
708
- setSwipeOutDirection(swipeAmountY > 0 ? 'down' : 'up');
709
- }
710
- deleteToast();
711
- setSwipeOut(true);
712
- return;
713
- } else {
714
- var _toastRef_current2, _toastRef_current3;
715
- (_toastRef_current2 = toastRef.current) == null ? void 0 : _toastRef_current2.style.setProperty('--swipe-amount-x', `0px`);
716
- (_toastRef_current3 = toastRef.current) == null ? void 0 : _toastRef_current3.style.setProperty('--swipe-amount-y', `0px`);
717
- }
718
- setIsSwiped(false);
719
- setSwiping(false);
720
- setSwipeDirection(null);
721
- },
722
- onPointerMove: (event)=>{
723
- var _window_getSelection, // Apply transform using both x and y values
724
- _toastRef_current, _toastRef_current1;
725
- if (!pointerStartRef.current || !dismissible) return;
726
- const isHighlighted = ((_window_getSelection = window.getSelection()) == null ? void 0 : _window_getSelection.toString().length) > 0;
727
- if (isHighlighted) return;
728
- const yDelta = event.clientY - pointerStartRef.current.y;
729
- const xDelta = event.clientX - pointerStartRef.current.x;
730
- var _props_swipeDirections;
731
- const swipeDirections = (_props_swipeDirections = props.swipeDirections) != null ? _props_swipeDirections : getDefaultSwipeDirections(position);
732
- // Determine swipe direction if not already locked
733
- if (!swipeDirection && (Math.abs(xDelta) > 1 || Math.abs(yDelta) > 1)) {
734
- setSwipeDirection(Math.abs(xDelta) > Math.abs(yDelta) ? 'x' : 'y');
735
- }
736
- let swipeAmount = {
737
- x: 0,
738
- y: 0
739
- };
740
- const getDampening = (delta)=>{
741
- const factor = Math.abs(delta) / 20;
742
- return 1 / (1.5 + factor);
743
- };
744
- // Only apply swipe in the locked direction
745
- if (swipeDirection === 'y') {
746
- // Handle vertical swipes
747
- if (swipeDirections.includes('top') || swipeDirections.includes('bottom')) {
748
- if (swipeDirections.includes('top') && yDelta < 0 || swipeDirections.includes('bottom') && yDelta > 0) {
749
- swipeAmount.y = yDelta;
750
- } else {
751
- // Smoothly transition to dampened movement
752
- const dampenedDelta = yDelta * getDampening(yDelta);
753
- // Ensure we don't jump when transitioning to dampened movement
754
- swipeAmount.y = Math.abs(dampenedDelta) < Math.abs(yDelta) ? dampenedDelta : yDelta;
755
- }
756
- }
757
- } else if (swipeDirection === 'x') {
758
- // Handle horizontal swipes
759
- if (swipeDirections.includes('left') || swipeDirections.includes('right')) {
760
- if (swipeDirections.includes('left') && xDelta < 0 || swipeDirections.includes('right') && xDelta > 0) {
761
- swipeAmount.x = xDelta;
762
- } else {
763
- // Smoothly transition to dampened movement
764
- const dampenedDelta = xDelta * getDampening(xDelta);
765
- // Ensure we don't jump when transitioning to dampened movement
766
- swipeAmount.x = Math.abs(dampenedDelta) < Math.abs(xDelta) ? dampenedDelta : xDelta;
767
- }
768
- }
769
- }
770
- if (Math.abs(swipeAmount.x) > 0 || Math.abs(swipeAmount.y) > 0) {
771
- setIsSwiped(true);
772
- }
773
- (_toastRef_current = toastRef.current) == null ? void 0 : _toastRef_current.style.setProperty('--swipe-amount-x', `${swipeAmount.x}px`);
774
- (_toastRef_current1 = toastRef.current) == null ? void 0 : _toastRef_current1.style.setProperty('--swipe-amount-y', `${swipeAmount.y}px`);
775
- }
776
- }, closeButton && !toast.jsx && toastType !== 'loading' ? /*#__PURE__*/ React__default.createElement("button", {
777
- "aria-label": closeButtonAriaLabel,
778
- "data-disabled": disabled,
779
- "data-close-button": true,
780
- onClick: disabled || !dismissible ? ()=>{} : ()=>{
781
- deleteToast();
782
- toast.onDismiss == null ? void 0 : toast.onDismiss.call(toast, toast);
783
- },
784
- className: cn(classNames == null ? void 0 : classNames.closeButton, toast == null ? void 0 : (_toast_classNames2 = toast.classNames) == null ? void 0 : _toast_classNames2.closeButton)
785
- }, (_icons_close = icons == null ? void 0 : icons.close) != null ? _icons_close : CloseIcon) : null, (toastType || toast.icon || toast.promise) && toast.icon !== null && ((icons == null ? void 0 : icons[toastType]) !== null || toast.icon) ? /*#__PURE__*/ React__default.createElement("div", {
786
- "data-icon": "",
787
- className: cn(classNames == null ? void 0 : classNames.icon, toast == null ? void 0 : (_toast_classNames3 = toast.classNames) == null ? void 0 : _toast_classNames3.icon)
788
- }, toast.promise || toast.type === 'loading' && !toast.icon ? toast.icon || getLoadingIcon() : null, toast.type !== 'loading' ? icon : null) : null, /*#__PURE__*/ React__default.createElement("div", {
789
- "data-content": "",
790
- className: cn(classNames == null ? void 0 : classNames.content, toast == null ? void 0 : (_toast_classNames4 = toast.classNames) == null ? void 0 : _toast_classNames4.content)
791
- }, /*#__PURE__*/ React__default.createElement("div", {
792
- "data-title": "",
793
- className: cn(classNames == null ? void 0 : classNames.title, toast == null ? void 0 : (_toast_classNames5 = toast.classNames) == null ? void 0 : _toast_classNames5.title)
794
- }, toast.jsx ? toast.jsx : typeof toast.title === 'function' ? toast.title() : toast.title), toast.description ? /*#__PURE__*/ React__default.createElement("div", {
795
- "data-description": "",
796
- className: cn(descriptionClassName, toastDescriptionClassname, classNames == null ? void 0 : classNames.description, toast == null ? void 0 : (_toast_classNames6 = toast.classNames) == null ? void 0 : _toast_classNames6.description)
797
- }, typeof toast.description === 'function' ? toast.description() : toast.description) : null), /*#__PURE__*/ React__default.isValidElement(toast.cancel) ? toast.cancel : toast.cancel && isAction(toast.cancel) ? /*#__PURE__*/ React__default.createElement("button", {
798
- "data-button": true,
799
- "data-cancel": true,
800
- style: toast.cancelButtonStyle || cancelButtonStyle,
801
- onClick: (event)=>{
802
- // We need to check twice because typescript
803
- if (!isAction(toast.cancel)) return;
804
- if (!dismissible) return;
805
- toast.cancel.onClick == null ? void 0 : toast.cancel.onClick.call(toast.cancel, event);
806
- deleteToast();
807
- },
808
- className: cn(classNames == null ? void 0 : classNames.cancelButton, toast == null ? void 0 : (_toast_classNames7 = toast.classNames) == null ? void 0 : _toast_classNames7.cancelButton)
809
- }, toast.cancel.label) : null, /*#__PURE__*/ React__default.isValidElement(toast.action) ? toast.action : toast.action && isAction(toast.action) ? /*#__PURE__*/ React__default.createElement("button", {
810
- "data-button": true,
811
- "data-action": true,
812
- style: toast.actionButtonStyle || actionButtonStyle,
813
- onClick: (event)=>{
814
- // We need to check twice because typescript
815
- if (!isAction(toast.action)) return;
816
- toast.action.onClick == null ? void 0 : toast.action.onClick.call(toast.action, event);
817
- if (event.defaultPrevented) return;
818
- deleteToast();
819
- },
820
- className: cn(classNames == null ? void 0 : classNames.actionButton, toast == null ? void 0 : (_toast_classNames8 = toast.classNames) == null ? void 0 : _toast_classNames8.actionButton)
821
- }, toast.action.label) : null);
822
- };
823
- function getDocumentDirection() {
824
- if (typeof window === 'undefined') return 'ltr';
825
- if (typeof document === 'undefined') return 'ltr'; // For Fresh purpose
826
- const dirAttribute = document.documentElement.getAttribute('dir');
827
- if (dirAttribute === 'auto' || !dirAttribute) {
828
- return window.getComputedStyle(document.documentElement).direction;
829
- }
830
- return dirAttribute;
831
- }
832
- function assignOffset(defaultOffset, mobileOffset) {
833
- const styles = {};
834
- [
835
- defaultOffset,
836
- mobileOffset
837
- ].forEach((offset, index)=>{
838
- const isMobile = index === 1;
839
- const prefix = isMobile ? '--mobile-offset' : '--offset';
840
- const defaultValue = isMobile ? MOBILE_VIEWPORT_OFFSET : VIEWPORT_OFFSET;
841
- function assignAll(offset) {
842
- [
843
- 'top',
844
- 'right',
845
- 'bottom',
846
- 'left'
847
- ].forEach((key)=>{
848
- styles[`${prefix}-${key}`] = typeof offset === 'number' ? `${offset}px` : offset;
849
- });
850
- }
851
- if (typeof offset === 'number' || typeof offset === 'string') {
852
- assignAll(offset);
853
- } else if (typeof offset === 'object') {
854
- [
855
- 'top',
856
- 'right',
857
- 'bottom',
858
- 'left'
859
- ].forEach((key)=>{
860
- if (offset[key] === undefined) {
861
- styles[`${prefix}-${key}`] = defaultValue;
862
- } else {
863
- styles[`${prefix}-${key}`] = typeof offset[key] === 'number' ? `${offset[key]}px` : offset[key];
864
- }
865
- });
866
- } else {
867
- assignAll(defaultValue);
868
- }
869
- });
870
- return styles;
871
- }
872
- const Toaster = /*#__PURE__*/ React__default.forwardRef(function Toaster(props, ref) {
873
- const { invert, position = 'bottom-right', hotkey = [
874
- 'altKey',
875
- 'KeyT'
876
- ], expand, closeButton, className, offset, mobileOffset, theme = 'light', richColors, duration, style, visibleToasts = VISIBLE_TOASTS_AMOUNT, toastOptions, dir = getDocumentDirection(), gap = GAP, icons, containerAriaLabel = 'Notifications' } = props;
877
- const [toasts, setToasts] = React__default.useState([]);
878
- const possiblePositions = React__default.useMemo(()=>{
879
- return Array.from(new Set([
880
- position
881
- ].concat(toasts.filter((toast)=>toast.position).map((toast)=>toast.position))));
882
- }, [
883
- toasts,
884
- position
885
- ]);
886
- const [heights, setHeights] = React__default.useState([]);
887
- const [expanded, setExpanded] = React__default.useState(false);
888
- const [interacting, setInteracting] = React__default.useState(false);
889
- const [actualTheme, setActualTheme] = React__default.useState(theme !== 'system' ? theme : typeof window !== 'undefined' ? window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light' : 'light');
890
- const listRef = React__default.useRef(null);
891
- const hotkeyLabel = hotkey.join('+').replace(/Key/g, '').replace(/Digit/g, '');
892
- const lastFocusedElementRef = React__default.useRef(null);
893
- const isFocusWithinRef = React__default.useRef(false);
894
- const removeToast = React__default.useCallback((toastToRemove)=>{
895
- setToasts((toasts)=>{
896
- var _toasts_find;
897
- if (!((_toasts_find = toasts.find((toast)=>toast.id === toastToRemove.id)) == null ? void 0 : _toasts_find.delete)) {
898
- ToastState.dismiss(toastToRemove.id);
899
- }
900
- return toasts.filter(({ id })=>id !== toastToRemove.id);
901
- });
902
- }, []);
903
- React__default.useEffect(()=>{
904
- return ToastState.subscribe((toast)=>{
905
- if (toast.dismiss) {
906
- // Prevent batching of other state updates
907
- requestAnimationFrame(()=>{
908
- setToasts((toasts)=>toasts.map((t)=>t.id === toast.id ? {
909
- ...t,
910
- delete: true
911
- } : t));
912
- });
913
- return;
914
- }
915
- // Prevent batching, temp solution.
916
- setTimeout(()=>{
917
- ReactDOM__default.flushSync(()=>{
918
- setToasts((toasts)=>{
919
- const indexOfExistingToast = toasts.findIndex((t)=>t.id === toast.id);
920
- // Update the toast if it already exists
921
- if (indexOfExistingToast !== -1) {
922
- return [
923
- ...toasts.slice(0, indexOfExistingToast),
924
- {
925
- ...toasts[indexOfExistingToast],
926
- ...toast
927
- },
928
- ...toasts.slice(indexOfExistingToast + 1)
929
- ];
930
- }
931
- return [
932
- toast,
933
- ...toasts
934
- ];
935
- });
936
- });
937
- });
938
- });
939
- }, [
940
- toasts
941
- ]);
942
- React__default.useEffect(()=>{
943
- if (theme !== 'system') {
944
- setActualTheme(theme);
945
- return;
946
- }
947
- if (theme === 'system') {
948
- // check if current preference is dark
949
- if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {
950
- // it's currently dark
951
- setActualTheme('dark');
952
- } else {
953
- // it's not dark
954
- setActualTheme('light');
955
- }
956
- }
957
- if (typeof window === 'undefined') return;
958
- const darkMediaQuery = window.matchMedia('(prefers-color-scheme: dark)');
959
- try {
960
- // Chrome & Firefox
961
- darkMediaQuery.addEventListener('change', ({ matches })=>{
962
- if (matches) {
963
- setActualTheme('dark');
964
- } else {
965
- setActualTheme('light');
966
- }
967
- });
968
- } catch (error) {
969
- // Safari < 14
970
- darkMediaQuery.addListener(({ matches })=>{
971
- try {
972
- if (matches) {
973
- setActualTheme('dark');
974
- } else {
975
- setActualTheme('light');
976
- }
977
- } catch (e) {
978
- console.error(e);
979
- }
980
- });
981
- }
982
- }, [
983
- theme
984
- ]);
985
- React__default.useEffect(()=>{
986
- // Ensure expanded is always false when no toasts are present / only one left
987
- if (toasts.length <= 1) {
988
- setExpanded(false);
989
- }
990
- }, [
991
- toasts
992
- ]);
993
- React__default.useEffect(()=>{
994
- const handleKeyDown = (event)=>{
995
- var _listRef_current;
996
- const isHotkeyPressed = hotkey.every((key)=>event[key] || event.code === key);
997
- if (isHotkeyPressed) {
998
- var _listRef_current1;
999
- setExpanded(true);
1000
- (_listRef_current1 = listRef.current) == null ? void 0 : _listRef_current1.focus();
1001
- }
1002
- if (event.code === 'Escape' && (document.activeElement === listRef.current || ((_listRef_current = listRef.current) == null ? void 0 : _listRef_current.contains(document.activeElement)))) {
1003
- setExpanded(false);
1004
- }
1005
- };
1006
- document.addEventListener('keydown', handleKeyDown);
1007
- return ()=>document.removeEventListener('keydown', handleKeyDown);
1008
- }, [
1009
- hotkey
1010
- ]);
1011
- React__default.useEffect(()=>{
1012
- if (listRef.current) {
1013
- return ()=>{
1014
- if (lastFocusedElementRef.current) {
1015
- lastFocusedElementRef.current.focus({
1016
- preventScroll: true
1017
- });
1018
- lastFocusedElementRef.current = null;
1019
- isFocusWithinRef.current = false;
1020
- }
1021
- };
1022
- }
1023
- }, [
1024
- listRef.current
1025
- ]);
1026
- return(// Remove item from normal navigation flow, only available via hotkey
1027
- /*#__PURE__*/ React__default.createElement("section", {
1028
- ref: ref,
1029
- "aria-label": `${containerAriaLabel} ${hotkeyLabel}`,
1030
- tabIndex: -1,
1031
- "aria-live": "polite",
1032
- "aria-relevant": "additions text",
1033
- "aria-atomic": "false",
1034
- suppressHydrationWarning: true
1035
- }, possiblePositions.map((position, index)=>{
1036
- var _heights_;
1037
- const [y, x] = position.split('-');
1038
- if (!toasts.length) return null;
1039
- return /*#__PURE__*/ React__default.createElement("ol", {
1040
- key: position,
1041
- dir: dir === 'auto' ? getDocumentDirection() : dir,
1042
- tabIndex: -1,
1043
- ref: listRef,
1044
- className: className,
1045
- "data-sonner-toaster": true,
1046
- "data-sonner-theme": actualTheme,
1047
- "data-y-position": y,
1048
- "data-x-position": x,
1049
- style: {
1050
- '--front-toast-height': `${((_heights_ = heights[0]) == null ? void 0 : _heights_.height) || 0}px`,
1051
- '--width': `${TOAST_WIDTH}px`,
1052
- '--gap': `${gap}px`,
1053
- ...style,
1054
- ...assignOffset(offset, mobileOffset)
1055
- },
1056
- onBlur: (event)=>{
1057
- if (isFocusWithinRef.current && !event.currentTarget.contains(event.relatedTarget)) {
1058
- isFocusWithinRef.current = false;
1059
- if (lastFocusedElementRef.current) {
1060
- lastFocusedElementRef.current.focus({
1061
- preventScroll: true
1062
- });
1063
- lastFocusedElementRef.current = null;
1064
- }
1065
- }
1066
- },
1067
- onFocus: (event)=>{
1068
- const isNotDismissible = event.target instanceof HTMLElement && event.target.dataset.dismissible === 'false';
1069
- if (isNotDismissible) return;
1070
- if (!isFocusWithinRef.current) {
1071
- isFocusWithinRef.current = true;
1072
- lastFocusedElementRef.current = event.relatedTarget;
1073
- }
1074
- },
1075
- onMouseEnter: ()=>setExpanded(true),
1076
- onMouseMove: ()=>setExpanded(true),
1077
- onMouseLeave: ()=>{
1078
- // Avoid setting expanded to false when interacting with a toast, e.g. swiping
1079
- if (!interacting) {
1080
- setExpanded(false);
1081
- }
1082
- },
1083
- onDragEnd: ()=>setExpanded(false),
1084
- onPointerDown: (event)=>{
1085
- const isNotDismissible = event.target instanceof HTMLElement && event.target.dataset.dismissible === 'false';
1086
- if (isNotDismissible) return;
1087
- setInteracting(true);
1088
- },
1089
- onPointerUp: ()=>setInteracting(false)
1090
- }, toasts.filter((toast)=>!toast.position && index === 0 || toast.position === position).map((toast, index)=>{
1091
- var _toastOptions_duration, _toastOptions_closeButton;
1092
- return /*#__PURE__*/ React__default.createElement(Toast, {
1093
- key: toast.id,
1094
- icons: icons,
1095
- index: index,
1096
- toast: toast,
1097
- defaultRichColors: richColors,
1098
- duration: (_toastOptions_duration = toastOptions == null ? void 0 : toastOptions.duration) != null ? _toastOptions_duration : duration,
1099
- className: toastOptions == null ? void 0 : toastOptions.className,
1100
- descriptionClassName: toastOptions == null ? void 0 : toastOptions.descriptionClassName,
1101
- invert: invert,
1102
- visibleToasts: visibleToasts,
1103
- closeButton: (_toastOptions_closeButton = toastOptions == null ? void 0 : toastOptions.closeButton) != null ? _toastOptions_closeButton : closeButton,
1104
- interacting: interacting,
1105
- position: position,
1106
- style: toastOptions == null ? void 0 : toastOptions.style,
1107
- unstyled: toastOptions == null ? void 0 : toastOptions.unstyled,
1108
- classNames: toastOptions == null ? void 0 : toastOptions.classNames,
1109
- cancelButtonStyle: toastOptions == null ? void 0 : toastOptions.cancelButtonStyle,
1110
- actionButtonStyle: toastOptions == null ? void 0 : toastOptions.actionButtonStyle,
1111
- closeButtonAriaLabel: toastOptions == null ? void 0 : toastOptions.closeButtonAriaLabel,
1112
- removeToast: removeToast,
1113
- toasts: toasts.filter((t)=>t.position == toast.position),
1114
- heights: heights.filter((h)=>h.position == toast.position),
1115
- setHeights: setHeights,
1116
- expandByDefault: expand,
1117
- gap: gap,
1118
- expanded: expanded,
1119
- swipeDirections: props.swipeDirections
1120
- });
1121
- }));
1122
- })));
1123
- });
1124
-
1125
- export { Toaster };