@payfit/unity-components 2.47.5 → 2.47.7

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 (446) hide show
  1. package/dist/esm/adapters/standardSchemaAdapter.js +18 -19
  2. package/dist/esm/adapters/zodAdapter.js +59 -73
  3. package/dist/esm/components/action-bar/ActionBar.js +46 -69
  4. package/dist/esm/components/action-bar/ActionBar.variants.js +18 -25
  5. package/dist/esm/components/action-bar/hooks/use-action-bar-state.js +31 -21
  6. package/dist/esm/components/action-bar/parts/ActionBarButton.js +29 -35
  7. package/dist/esm/components/action-bar/parts/ActionBarIconButton.js +29 -41
  8. package/dist/esm/components/action-bar/parts/ActionBarOverflowMenu.js +39 -45
  9. package/dist/esm/components/action-bar/parts/ActionBarPrefixArea.js +22 -33
  10. package/dist/esm/components/action-bar/parts/ActionBarRoot.js +44 -56
  11. package/dist/esm/components/action-bar/utils/action-bar-helpers.js +23 -28
  12. package/dist/esm/components/actionable/Actionable.js +66 -82
  13. package/dist/esm/components/alert/Alert.js +84 -99
  14. package/dist/esm/components/alert/parts/AlertActions.js +19 -21
  15. package/dist/esm/components/alert/parts/AlertContent.js +13 -10
  16. package/dist/esm/components/alert/parts/AlertTitle.js +15 -20
  17. package/dist/esm/components/anchor/Anchor.js +40 -48
  18. package/dist/esm/components/app-layout/AppLayout.js +62 -76
  19. package/dist/esm/components/app-menu/AppMenu.js +11 -14
  20. package/dist/esm/components/app-menu/parts/AppMenu.context.js +21 -22
  21. package/dist/esm/components/app-menu/parts/AppMenuFooter.js +189 -246
  22. package/dist/esm/components/app-menu/parts/AppMenuHeader.js +52 -49
  23. package/dist/esm/components/app-menu/parts/AppMenuNavContent.js +14 -22
  24. package/dist/esm/components/autocomplete/Autocomplete.js +136 -168
  25. package/dist/esm/components/autocomplete/parts/AutocompleteClearButton.js +23 -33
  26. package/dist/esm/components/autocomplete/parts/AutocompleteItem.js +28 -36
  27. package/dist/esm/components/autocomplete/parts/AutocompleteItemGroup.js +38 -32
  28. package/dist/esm/components/autocomplete/parts/AutocompletePanel.js +44 -46
  29. package/dist/esm/components/avatar/Avatar.context.js +24 -25
  30. package/dist/esm/components/avatar/Avatar.js +38 -46
  31. package/dist/esm/components/avatar/Avatar.variants.js +62 -62
  32. package/dist/esm/components/avatar/parts/AvatarFallback.js +77 -81
  33. package/dist/esm/components/avatar/parts/AvatarIcon.js +32 -40
  34. package/dist/esm/components/avatar/parts/AvatarImage.js +22 -18
  35. package/dist/esm/components/avatar/parts/AvatarPair.js +49 -47
  36. package/dist/esm/components/avatar/utils.js +4 -4
  37. package/dist/esm/components/badge/Badge.js +57 -92
  38. package/dist/esm/components/badge/parts/BadgeDot.js +42 -83
  39. package/dist/esm/components/bottom-sheet/BottomSheet.js +48 -69
  40. package/dist/esm/components/bottom-sheet/parts/BottomSheetContent.js +26 -26
  41. package/dist/esm/components/bottom-sheet/parts/BottomSheetDragIndicator.js +44 -65
  42. package/dist/esm/components/bottom-sheet/parts/BottomSheetFooter.js +20 -28
  43. package/dist/esm/components/bottom-sheet/parts/BottomSheetHeader.js +49 -45
  44. package/dist/esm/components/breadcrumbs/Breadcrumbs.context.js +22 -25
  45. package/dist/esm/components/breadcrumbs/Breadcrumbs.js +124 -159
  46. package/dist/esm/components/breadcrumbs/Breadcrumbs.variant.js +13 -19
  47. package/dist/esm/components/breadcrumbs/parts/Breadcrumb.js +35 -41
  48. package/dist/esm/components/breadcrumbs/parts/RawBreadcrumbLink.js +53 -62
  49. package/dist/esm/components/button/Button.js +90 -107
  50. package/dist/esm/components/button/Button.variants.js +172 -179
  51. package/dist/esm/components/card/Card.context.js +9 -13
  52. package/dist/esm/components/card/Card.js +63 -99
  53. package/dist/esm/components/card/parts/CardContent.js +11 -7
  54. package/dist/esm/components/card/parts/CardTitle.js +24 -31
  55. package/dist/esm/components/carousel/Carousel.context.js +8 -12
  56. package/dist/esm/components/carousel/Carousel.js +67 -106
  57. package/dist/esm/components/carousel/Carousel.options.js +69 -61
  58. package/dist/esm/components/carousel/hooks/useCarouselAccessibility.js +81 -85
  59. package/dist/esm/components/carousel/hooks/useCarouselState.js +54 -61
  60. package/dist/esm/components/carousel/parts/CarouselContent.js +52 -68
  61. package/dist/esm/components/carousel/parts/CarouselHeader.js +43 -58
  62. package/dist/esm/components/carousel/parts/CarouselNav.js +64 -79
  63. package/dist/esm/components/carousel/parts/CarouselSlide.js +26 -35
  64. package/dist/esm/components/checkbox/Checkbox.js +83 -105
  65. package/dist/esm/components/checkbox/Checkbox.variants.js +60 -80
  66. package/dist/esm/components/checkbox/CheckboxStandalone.js +33 -28
  67. package/dist/esm/components/checkbox/TanstackCheckbox.js +35 -51
  68. package/dist/esm/components/checkbox/parts/CheckboxIndicator.js +131 -161
  69. package/dist/esm/components/checkbox-field/CheckboxField.js +38 -65
  70. package/dist/esm/components/checkbox-field/TanstackCheckboxField.js +23 -39
  71. package/dist/esm/components/checkbox-group/CheckboxGroup.js +44 -73
  72. package/dist/esm/components/checkbox-group/TanstackCheckboxGroup.js +32 -37
  73. package/dist/esm/components/checkbox-group-field/CheckboxGroupField.js +35 -55
  74. package/dist/esm/components/checkbox-group-field/TanstackCheckGroupField.js +26 -39
  75. package/dist/esm/components/client-side-pagination/ClientSidePagination.js +130 -177
  76. package/dist/esm/components/client-side-pagination/hooks/use-pagination.js +20 -27
  77. package/dist/esm/components/client-side-pagination/parts/PaginationEllipsis.js +29 -29
  78. package/dist/esm/components/client-side-pagination/parts/PaginationJumpDialog.js +110 -143
  79. package/dist/esm/components/client-side-pagination/parts/PaginationNavButton.js +23 -31
  80. package/dist/esm/components/client-side-pagination/parts/RawPaginationLink.js +35 -48
  81. package/dist/esm/components/client-side-pagination/utils/pagination-window.js +37 -31
  82. package/dist/esm/components/code/Code.js +34 -38
  83. package/dist/esm/components/code/copyToClipboard.js +9 -9
  84. package/dist/esm/components/collapsible/Collapsible.js +21 -28
  85. package/dist/esm/components/collapsible/parts/CollapsibleContent.js +16 -18
  86. package/dist/esm/components/collapsible/parts/CollapsibleTitle.js +53 -53
  87. package/dist/esm/components/data-table/DataTable.js +101 -155
  88. package/dist/esm/components/data-table/parts/ColumnSortHeader.js +24 -36
  89. package/dist/esm/components/data-table/parts/DataTableBulkActions.js +95 -148
  90. package/dist/esm/components/data-table/parts/DataTableRoot.js +13 -13
  91. package/dist/esm/components/date-calendar/DateCalendar.js +121 -174
  92. package/dist/esm/components/date-calendar/DateCalendar.variants.js +32 -49
  93. package/dist/esm/components/date-calendar/hooks/useMonthsList.js +18 -25
  94. package/dist/esm/components/date-calendar/hooks/useYearsList.js +23 -32
  95. package/dist/esm/components/date-calendar/parts/DateSegmentSelect.js +62 -65
  96. package/dist/esm/components/date-picker/DatePicker.js +131 -174
  97. package/dist/esm/components/date-picker/TanstackDatePicker.js +39 -53
  98. package/dist/esm/components/date-picker/parts/DateInput.js +101 -135
  99. package/dist/esm/components/date-picker-field/DatePickerField.js +52 -71
  100. package/dist/esm/components/date-picker-field/TanstackDatePickerField.js +28 -41
  101. package/dist/esm/components/date-picker-field/test-utils.js +26 -51
  102. package/dist/esm/components/date-range-calendar/DateRangeCalendar.js +148 -211
  103. package/dist/esm/components/date-range-picker/DateRangePicker.js +132 -175
  104. package/dist/esm/components/date-range-picker/TanstackDateRangePicker.js +39 -53
  105. package/dist/esm/components/date-range-picker/parts/DateRangeInput.js +90 -101
  106. package/dist/esm/components/date-range-picker-field/TanstackDateRangePickerField.js +28 -41
  107. package/dist/esm/components/date-range-picker-field/test-utils.js +37 -65
  108. package/dist/esm/components/definition-list/DefinitionList.context.js +12 -16
  109. package/dist/esm/components/definition-list/DefinitionList.js +23 -22
  110. package/dist/esm/components/definition-list/parts/DefinitionItem.js +49 -50
  111. package/dist/esm/components/definition-tooltip/DefinitionTooltip.js +25 -28
  112. package/dist/esm/components/dialog/Dialog.js +79 -110
  113. package/dist/esm/components/dialog/parts/DialogActions/DialogButton.js +41 -61
  114. package/dist/esm/components/dialog/parts/DialogActions.js +10 -13
  115. package/dist/esm/components/dialog/parts/DialogContent.js +17 -22
  116. package/dist/esm/components/dialog/parts/DialogTitle.js +12 -9
  117. package/dist/esm/components/dialog/test-utils.js +46 -88
  118. package/dist/esm/components/empty-state/EmptyState.js +20 -25
  119. package/dist/esm/components/empty-state/EmptyState.variants.js +15 -22
  120. package/dist/esm/components/empty-state/parts/EmptyStateActions.js +12 -17
  121. package/dist/esm/components/empty-state/parts/EmptyStateContent.js +21 -21
  122. package/dist/esm/components/empty-state/parts/EmptyStateIcon.js +19 -14
  123. package/dist/esm/components/empty-state/presets/EmptyStateGetStarted.js +30 -26
  124. package/dist/esm/components/empty-state/presets/EmptyStateGoodJob.js +35 -55
  125. package/dist/esm/components/empty-state/presets/EmptyStateNoSearchResults.js +31 -27
  126. package/dist/esm/components/empty-state/presets/EmptyStateUpgradeRequired.js +30 -26
  127. package/dist/esm/components/empty-state/presets/EmptyStateUseDesktop.js +26 -25
  128. package/dist/esm/components/empty-state/presets/EmptyStateWaitingForData.js +30 -26
  129. package/dist/esm/components/error-state/ErrorState.js +155 -239
  130. package/dist/esm/components/error-state/initConfig.js +90 -148
  131. package/dist/esm/components/error-state/parts/Collapsible.js +68 -67
  132. package/dist/esm/components/fieldset/Fieldset.js +63 -72
  133. package/dist/esm/components/fieldset/parts/FieldGroup.js +13 -18
  134. package/dist/esm/components/filter/Filter.controls.js +49 -42
  135. package/dist/esm/components/filter/Filter.js +101 -146
  136. package/dist/esm/components/filter/hooks/useFilterIds.js +12 -12
  137. package/dist/esm/components/filter/hooks/useFilterState.js +16 -22
  138. package/dist/esm/components/filter/hooks/useFilterValue.js +31 -30
  139. package/dist/esm/components/filter/parts/FilterButton.js +40 -54
  140. package/dist/esm/components/filter/parts/FilterLabel.js +38 -56
  141. package/dist/esm/components/filter/parts/FilterPopover.js +68 -80
  142. package/dist/esm/components/filter/utils/value-formatters.js +9 -11
  143. package/dist/esm/components/filter-toolbar/FilterToolbar.js +124 -173
  144. package/dist/esm/components/filter-toolbar/hooks/use-filter-toolbar-state.js +128 -130
  145. package/dist/esm/components/filter-toolbar/parts/AddFilter.js +81 -109
  146. package/dist/esm/components/filter-toolbar/parts/AddFilterItem.js +20 -18
  147. package/dist/esm/components/filter-toolbar/utils/filter-adapters.js +17 -88
  148. package/dist/esm/components/filter-toolbar/utils/normalize-filter-value.js +12 -18
  149. package/dist/esm/components/flex/Flex.js +38 -57
  150. package/dist/esm/components/flex/Flex.variants.js +198 -199
  151. package/dist/esm/components/flex/FlexItem.js +21 -32
  152. package/dist/esm/components/floating-action-bar/FloatingActionBar.js +55 -68
  153. package/dist/esm/components/form/Form.context.js +15 -26
  154. package/dist/esm/components/form/Form.js +40 -57
  155. package/dist/esm/components/form/TanstackForm.js +22 -29
  156. package/dist/esm/components/form-field/FormField.context.js +44 -70
  157. package/dist/esm/components/form-field/FormField.js +50 -56
  158. package/dist/esm/components/form-field/TanstackFormField.context.js +11 -12
  159. package/dist/esm/components/form-field/TanstackFormField.js +44 -45
  160. package/dist/esm/components/form-field/parts/FormControl.js +41 -52
  161. package/dist/esm/components/form-field/parts/FormFeedbackText.js +24 -26
  162. package/dist/esm/components/form-field/parts/FormHelperText.js +21 -26
  163. package/dist/esm/components/form-field/parts/FormLabel.js +21 -30
  164. package/dist/esm/components/form-field/parts/RawFormContextualLink.js +32 -38
  165. package/dist/esm/components/form-field/parts/TanstackFormFeedbackText.js +28 -31
  166. package/dist/esm/components/form-field/parts/TanstackFormHelperText.js +22 -25
  167. package/dist/esm/components/form-field/parts/TanstackFormLabel.js +21 -26
  168. package/dist/esm/components/form-field/parts/TanstackRawFormContextualLink.js +33 -45
  169. package/dist/esm/components/form-field/utils/isFieldRequired.js +7 -7
  170. package/dist/esm/components/full-page-loader/FullPageLoader.js +26 -35
  171. package/dist/esm/components/funnel-layout/FunnelLayout.context.js +12 -26
  172. package/dist/esm/components/funnel-layout/FunnelLayout.js +75 -91
  173. package/dist/esm/components/funnel-layout/parts/FunnelBackButton.js +24 -34
  174. package/dist/esm/components/funnel-layout/parts/FunnelBody.js +15 -23
  175. package/dist/esm/components/funnel-layout/parts/FunnelPage.js +27 -35
  176. package/dist/esm/components/funnel-layout/parts/FunnelPageAction.js +32 -39
  177. package/dist/esm/components/funnel-layout/parts/FunnelPageActions.js +30 -41
  178. package/dist/esm/components/funnel-layout/parts/FunnelPageContent.js +15 -23
  179. package/dist/esm/components/funnel-layout/parts/FunnelPageFooter.js +20 -28
  180. package/dist/esm/components/funnel-layout/parts/FunnelPageHeader.js +53 -55
  181. package/dist/esm/components/funnel-layout/parts/FunnelProgressBar.js +39 -50
  182. package/dist/esm/components/funnel-layout/parts/FunnelSidebar.js +47 -54
  183. package/dist/esm/components/funnel-layout/parts/FunnelTopBar.js +88 -119
  184. package/dist/esm/components/grid/Grid.js +27 -38
  185. package/dist/esm/components/grid/Grid.variants.js +147 -164
  186. package/dist/esm/components/grid/GridItem.js +24 -43
  187. package/dist/esm/components/icon/Icon.js +112 -115
  188. package/dist/esm/components/icon-button/CircularIconButton.js +117 -119
  189. package/dist/esm/components/icon-button/IconButton.js +82 -93
  190. package/dist/esm/components/icon-button/IconButton.variants.js +167 -174
  191. package/dist/esm/components/inline-field/InlineField.context.js +8 -9
  192. package/dist/esm/components/inline-field/InlineField.js +48 -57
  193. package/dist/esm/components/inline-field/hooks/useInlineFieldMode.js +23 -26
  194. package/dist/esm/components/inline-field/parts/InlineFieldEditView.js +113 -149
  195. package/dist/esm/components/inline-field/parts/InlineFieldReadView.js +52 -57
  196. package/dist/esm/components/inline-field-group/InlineFieldGroup.context.js +5 -5
  197. package/dist/esm/components/inline-field-group/InlineFieldGroup.js +188 -216
  198. package/dist/esm/components/inline-field-group/hooks/useInlineFieldGroupMode.js +23 -26
  199. package/dist/esm/components/inline-field-group/parts/InlineFieldGroupActions.js +109 -156
  200. package/dist/esm/components/inline-field-group/parts/InlineFieldGroupEditView.js +51 -55
  201. package/dist/esm/components/inline-field-group/parts/InlineFieldGroupHeader.js +39 -38
  202. package/dist/esm/components/inline-field-group/parts/InlineFieldGroupReadView.js +18 -27
  203. package/dist/esm/components/input/Input.js +123 -150
  204. package/dist/esm/components/input/TanstackInput.js +33 -38
  205. package/dist/esm/components/label/Label.js +52 -66
  206. package/dist/esm/components/link/RawLink.js +109 -165
  207. package/dist/esm/components/link/utils.js +12 -15
  208. package/dist/esm/components/link-button/RawLinkButton.js +100 -127
  209. package/dist/esm/components/list-view/ListView.js +40 -45
  210. package/dist/esm/components/list-view/parts/ListViewItemLabel.js +17 -22
  211. package/dist/esm/components/list-view/parts/ListViewItemText.js +17 -22
  212. package/dist/esm/components/list-view/parts/ListViewSection.js +25 -23
  213. package/dist/esm/components/list-view/parts/RawListViewItem.js +68 -81
  214. package/dist/esm/components/menu/Menu.js +21 -30
  215. package/dist/esm/components/menu/parts/MenuContent.js +17 -29
  216. package/dist/esm/components/menu/parts/MenuHeader.js +13 -16
  217. package/dist/esm/components/menu/parts/MenuSection.js +32 -42
  218. package/dist/esm/components/menu/parts/MenuSeparator.js +8 -8
  219. package/dist/esm/components/menu/parts/MenuTrigger.js +12 -13
  220. package/dist/esm/components/menu/parts/RawMenuItem.js +29 -42
  221. package/dist/esm/components/multi-select/MultiSelect.js +249 -299
  222. package/dist/esm/components/multi-select/Multiselect.context.js +6 -6
  223. package/dist/esm/components/multi-select/TanstackMultiSelect.js +31 -41
  224. package/dist/esm/components/multi-select/parts/MultiSelectOptGroup.js +35 -43
  225. package/dist/esm/components/multi-select/parts/MultiSelectOption.js +60 -76
  226. package/dist/esm/components/multi-select/utils/selection-adapter.js +9 -15
  227. package/dist/esm/components/multi-select-field/MultiSelectField.js +56 -71
  228. package/dist/esm/components/multi-select-field/TanstackMultiSelectField.js +27 -48
  229. package/dist/esm/components/multi-select-field/test-utils.js +22 -45
  230. package/dist/esm/components/nav/Nav.js +21 -27
  231. package/dist/esm/components/nav/parts/NavGroup.js +103 -123
  232. package/dist/esm/components/nav/parts/RawNavItem.js +99 -118
  233. package/dist/esm/components/navigation-card/NavigationCard.context.js +10 -11
  234. package/dist/esm/components/navigation-card/NavigationCard.js +53 -63
  235. package/dist/esm/components/navigation-card/NavigationCard.variants.js +162 -162
  236. package/dist/esm/components/navigation-card/parts/NavigationCardDescription.js +17 -20
  237. package/dist/esm/components/navigation-card/parts/NavigationCardGroup.js +76 -93
  238. package/dist/esm/components/navigation-card/parts/NavigationCardLabel.js +18 -23
  239. package/dist/esm/components/number-field/NumberField.js +48 -69
  240. package/dist/esm/components/number-field/TanstackNumberField.js +30 -43
  241. package/dist/esm/components/number-input/NumberInput.js +161 -216
  242. package/dist/esm/components/number-input/TanstackNumberInput.js +33 -38
  243. package/dist/esm/components/page/Page.js +33 -48
  244. package/dist/esm/components/page/parts/PageHeader.js +41 -36
  245. package/dist/esm/components/page/parts/PageHeading.js +17 -19
  246. package/dist/esm/components/pagination/Pagination.js +78 -102
  247. package/dist/esm/components/pagination/PaginationContext.js +8 -14
  248. package/dist/esm/components/pagination/hooks/use-pagination-state.js +20 -26
  249. package/dist/esm/components/pagination/hooks/use-pagination-window.js +10 -13
  250. package/dist/esm/components/pagination/parts/PaginationContent.js +26 -37
  251. package/dist/esm/components/pagination/parts/PaginationEllipsis.js +33 -33
  252. package/dist/esm/components/pagination/parts/PaginationItem.js +17 -22
  253. package/dist/esm/components/pagination/parts/RawPaginationLink.js +50 -60
  254. package/dist/esm/components/pagination/parts/RawPaginationNext.js +53 -70
  255. package/dist/esm/components/pagination/parts/RawPaginationPrevious.js +52 -66
  256. package/dist/esm/components/pagination/utils/pagination-window.js +55 -40
  257. package/dist/esm/components/password-field/TanstackPasswordField.js +55 -82
  258. package/dist/esm/components/password-field/hooks/use-caps-lock.js +11 -11
  259. package/dist/esm/components/password-field/parts/PasswordFieldDetails.js +42 -41
  260. package/dist/esm/components/password-field/parts/PasswordInput.js +153 -188
  261. package/dist/esm/components/password-field/parts/ValidationRuleItem.js +38 -43
  262. package/dist/esm/components/payfit-brand/PayFitBrand.js +74 -84
  263. package/dist/esm/components/payfit-brand/PayFitPreprod.js +53 -57
  264. package/dist/esm/components/phone-number/PhoneNumberInput.js +214 -331
  265. package/dist/esm/components/phone-number/TanstackPhoneNumberInput.js +29 -32
  266. package/dist/esm/components/phone-number/parts/PhoneNumberItem.js +49 -65
  267. package/dist/esm/components/phone-number/unknownFlag.js +4 -0
  268. package/dist/esm/components/phone-number-field/TanstackPhoneNumberField.js +21 -32
  269. package/dist/esm/components/pill/Pill.js +48 -58
  270. package/dist/esm/components/popover/Popover.js +37 -41
  271. package/dist/esm/components/popover/parts/PopoverHeader.js +48 -60
  272. package/dist/esm/components/progress-bar/ProgressBar.js +66 -76
  273. package/dist/esm/components/promo-dialog/PromoDialog.js +135 -218
  274. package/dist/esm/components/promo-dialog/parts/PromoDialogActions.js +19 -29
  275. package/dist/esm/components/promo-dialog/parts/PromoDialogContent.js +14 -19
  276. package/dist/esm/components/promo-dialog/parts/PromoDialogHero.js +17 -24
  277. package/dist/esm/components/promo-dialog/parts/PromoDialogSubtitle.js +15 -21
  278. package/dist/esm/components/promo-dialog/parts/PromoDialogTitle.js +11 -16
  279. package/dist/esm/components/radio-button-group/RadioButtonGroup.js +18 -23
  280. package/dist/esm/components/radio-button-group/TanstackRadioButtonGroup.js +32 -42
  281. package/dist/esm/components/radio-button-group/parts/RadioButton.js +61 -66
  282. package/dist/esm/components/radio-button-group/parts/RadioButtonHelper.js +14 -19
  283. package/dist/esm/components/radio-button-group/parts/RadioIndicator.js +107 -129
  284. package/dist/esm/components/radio-button-group-field/RadioButtonGroupField.js +37 -52
  285. package/dist/esm/components/radio-button-group-field/TanstackRadioButtonGroupField.js +31 -37
  286. package/dist/esm/components/search/Search.js +120 -166
  287. package/dist/esm/components/segmented-button-group/SegmentedButtonGroup.js +20 -20
  288. package/dist/esm/components/segmented-button-group/SegmentedButtonGroups.context.js +11 -14
  289. package/dist/esm/components/segmented-button-group/parts/ToggleButton.js +105 -125
  290. package/dist/esm/components/select/Select.js +85 -130
  291. package/dist/esm/components/select/TanstackSelect.js +31 -40
  292. package/dist/esm/components/select/parts/SelectButton.js +79 -103
  293. package/dist/esm/components/select/parts/SelectOption.context.js +14 -21
  294. package/dist/esm/components/select/parts/SelectOption.js +53 -64
  295. package/dist/esm/components/select/parts/SelectOptionGroup.js +34 -27
  296. package/dist/esm/components/select/parts/SelectOptionHelper.js +22 -21
  297. package/dist/esm/components/select-field/SelectField.js +44 -66
  298. package/dist/esm/components/select-field/TanstackSelectField.js +29 -45
  299. package/dist/esm/components/select-field/test-utils.js +10 -25
  300. package/dist/esm/components/select-list/SelectList.js +70 -81
  301. package/dist/esm/components/select-list/constants.js +13 -28
  302. package/dist/esm/components/select-list/helpers.js +37 -43
  303. package/dist/esm/components/select-list/hooks/useControlledSelection.js +13 -15
  304. package/dist/esm/components/select-list/hooks/useSelectedFirstSorting.js +30 -30
  305. package/dist/esm/components/select-list/parts/SelectListEmptyState.js +24 -24
  306. package/dist/esm/components/select-list/parts/SelectListOptGroup.js +33 -30
  307. package/dist/esm/components/select-list/parts/SelectListOption.js +54 -70
  308. package/dist/esm/components/select-list/parts/SelectListSearchInput.js +43 -49
  309. package/dist/esm/components/select-list/parts/SelectedItemsSection.js +29 -35
  310. package/dist/esm/components/select-list/utils/partition.js +7 -8
  311. package/dist/esm/components/selectable-button-group/SelectableButtonGroup.context.js +5 -5
  312. package/dist/esm/components/selectable-button-group/SelectableButtonGroup.js +32 -38
  313. package/dist/esm/components/selectable-button-group/TanstackSelectableButtonGroup.js +27 -33
  314. package/dist/esm/components/selectable-button-group/parts/SelectableButton.js +81 -123
  315. package/dist/esm/components/selectable-button-group-field/SelectableButtonGroupField.js +41 -44
  316. package/dist/esm/components/selectable-button-group-field/TanstackSelectableButtonGroupField.js +29 -46
  317. package/dist/esm/components/selectable-card/internals/Content.js +8 -8
  318. package/dist/esm/components/selectable-card/internals/Description.js +11 -10
  319. package/dist/esm/components/selectable-card/internals/Illustration.js +8 -8
  320. package/dist/esm/components/selectable-card/internals/SelectedIndicator.js +9 -9
  321. package/dist/esm/components/selectable-card/selectable-card-checkbox-group/SelectableCardCheckboxGroup.js +13 -16
  322. package/dist/esm/components/selectable-card/selectable-card-checkbox-group/TanstackSelectableCardCheckboxGroup.js +28 -31
  323. package/dist/esm/components/selectable-card/selectable-card-checkbox-group/parts/SelectableCardCheckbox.js +37 -37
  324. package/dist/esm/components/selectable-card/selectable-card-radio-group/SelectableCardRadioGroup.js +18 -21
  325. package/dist/esm/components/selectable-card/selectable-card-radio-group/TanstackSelectableCardRadioGroup.js +28 -31
  326. package/dist/esm/components/selectable-card/selectable-card-radio-group/parts/SelectableCardRadio.js +40 -47
  327. package/dist/esm/components/selectable-card/selectableCard.variant.js +16 -22
  328. package/dist/esm/components/selectable-card-checkbox-group-field/SelectableCardCheckboxGroupField.js +38 -46
  329. package/dist/esm/components/selectable-card-checkbox-group-field/TanstackSelectableCardCheckboxGroupField.js +29 -37
  330. package/dist/esm/components/selectable-card-radio-group-field/SelectableCardRadioGroupField.js +37 -45
  331. package/dist/esm/components/selectable-card-radio-group-field/TanstackSelectableCardRadioGroupField.js +29 -37
  332. package/dist/esm/components/side-panel/SidePanel.js +53 -71
  333. package/dist/esm/components/side-panel/parts/SidePanelContent.js +25 -25
  334. package/dist/esm/components/side-panel/parts/SidePanelDragIndicator.js +44 -65
  335. package/dist/esm/components/side-panel/parts/SidePanelFooter.js +26 -29
  336. package/dist/esm/components/side-panel/parts/SidePanelHeader.js +41 -43
  337. package/dist/esm/components/skip-links/SkipLinks.js +69 -87
  338. package/dist/esm/components/spinner/Spinner.js +76 -106
  339. package/dist/esm/components/stepper/Stepper.context.js +15 -20
  340. package/dist/esm/components/stepper/Stepper.js +16 -18
  341. package/dist/esm/components/stepper/hooks/useStepper.js +20 -25
  342. package/dist/esm/components/stepper/parts/Step.js +47 -56
  343. package/dist/esm/components/table/Table.context.js +35 -41
  344. package/dist/esm/components/table/Table.js +155 -225
  345. package/dist/esm/components/table/hooks/useTableKeyboardNavigation.js +180 -208
  346. package/dist/esm/components/table/parts/TableBody.js +81 -104
  347. package/dist/esm/components/table/parts/TableCell.js +38 -62
  348. package/dist/esm/components/table/parts/TableColumnHeader.js +62 -78
  349. package/dist/esm/components/table/parts/TableEmptyState.js +131 -161
  350. package/dist/esm/components/table/parts/TableHeader.js +24 -37
  351. package/dist/esm/components/table/parts/TablePagination.js +119 -141
  352. package/dist/esm/components/table/parts/TableRow.js +36 -52
  353. package/dist/esm/components/tabs/Tabs.context.js +19 -20
  354. package/dist/esm/components/tabs/Tabs.js +26 -24
  355. package/dist/esm/components/tabs/Tabs.variant.js +35 -41
  356. package/dist/esm/components/tabs/parts/NavigationButton.js +37 -46
  357. package/dist/esm/components/tabs/parts/RawTab.js +22 -18
  358. package/dist/esm/components/tabs/parts/TabList.js +84 -83
  359. package/dist/esm/components/tabs/parts/TabPanel.js +13 -9
  360. package/dist/esm/components/task-menu/TaskMenu.context.js +44 -58
  361. package/dist/esm/components/task-menu/TaskMenu.js +21 -28
  362. package/dist/esm/components/task-menu/parts/Content.js +43 -48
  363. package/dist/esm/components/task-menu/parts/Header.js +39 -54
  364. package/dist/esm/components/task-menu/parts/RawSubTask.js +141 -166
  365. package/dist/esm/components/task-menu/parts/RawTask.js +115 -145
  366. package/dist/esm/components/task-menu/parts/TaskGroup.js +103 -140
  367. package/dist/esm/components/task-menu/parts/dot.js +19 -0
  368. package/dist/esm/components/task-menu/parts/task.variants.js +59 -64
  369. package/dist/esm/components/text/Text.js +56 -71
  370. package/dist/esm/components/text/Text.variants.js +106 -112
  371. package/dist/esm/components/text-area/TanstackTextArea.js +30 -35
  372. package/dist/esm/components/text-area/TextArea.js +121 -164
  373. package/dist/esm/components/text-field/TanstackTextField.js +39 -59
  374. package/dist/esm/components/text-field/TextField.js +53 -76
  375. package/dist/esm/components/timeline/Timeline.context.js +18 -21
  376. package/dist/esm/components/timeline/Timeline.js +33 -37
  377. package/dist/esm/components/timeline/Timeline.utils.js +8 -8
  378. package/dist/esm/components/timeline/Timeline.variants.js +93 -118
  379. package/dist/esm/components/timeline/parts/TimelineMarker.js +36 -26
  380. package/dist/esm/components/timeline/parts/TimelineStep.context.js +15 -19
  381. package/dist/esm/components/timeline/parts/TimelineStep.js +57 -52
  382. package/dist/esm/components/timeline/parts/TimelineStepContent.context.js +15 -20
  383. package/dist/esm/components/timeline/parts/TimelineStepContent.js +30 -17
  384. package/dist/esm/components/timeline/parts/TimelineStepDescription.js +12 -7
  385. package/dist/esm/components/timeline/parts/TimelineStepHeader.js +34 -36
  386. package/dist/esm/components/timeline/parts/check.js +23 -0
  387. package/dist/esm/components/toast/Toast.context.js +15 -20
  388. package/dist/esm/components/toast/ToastManager.js +13 -21
  389. package/dist/esm/components/toast/UnityToast.js +82 -95
  390. package/dist/esm/components/toast/parts/ToastAction.js +18 -13
  391. package/dist/esm/components/toast/parts/ToastContent.js +13 -9
  392. package/dist/esm/components/toast/parts/ToastTitle.js +13 -8
  393. package/dist/esm/components/toast/test-utils.js +63 -117
  394. package/dist/esm/components/toast/toast.js +27 -38
  395. package/dist/esm/components/toggle-switch/TanstackToggleSwitch.js +21 -24
  396. package/dist/esm/components/toggle-switch/ToggleSwitch.js +111 -112
  397. package/dist/esm/components/toggle-switch-field/TanstackToggleSwitchField.js +19 -33
  398. package/dist/esm/components/toggle-switch-field/ToggleSwitchField.js +33 -58
  399. package/dist/esm/components/toggle-switch-group/TanstackToggleSwitchGroup.js +18 -21
  400. package/dist/esm/components/toggle-switch-group/ToggleSwitchGroup.js +83 -108
  401. package/dist/esm/components/toggle-switch-group-field/TanstackToggleSwitchGroupField.js +30 -49
  402. package/dist/esm/components/toggle-switch-group-field/ToggleSwitchGroupField.js +41 -61
  403. package/dist/esm/components/tooltip/Tooltip.js +30 -31
  404. package/dist/esm/hooks/tanstack-form-context.js +5 -8
  405. package/dist/esm/hooks/tanstack-form-default-values.js +5 -5
  406. package/dist/esm/hooks/use-async-list.js +2 -0
  407. package/dist/esm/hooks/use-breakpoint-listener.js +16 -25
  408. package/dist/esm/hooks/use-container-query-level.js +30 -31
  409. package/dist/esm/hooks/use-form.js +35 -29
  410. package/dist/esm/hooks/use-has-scroll.js +76 -74
  411. package/dist/esm/hooks/use-id.js +18 -24
  412. package/dist/esm/hooks/use-media-query.js +15 -18
  413. package/dist/esm/hooks/use-resizable.js +49 -49
  414. package/dist/esm/hooks/use-responsive-value.js +22 -26
  415. package/dist/esm/hooks/use-scroll-direction.js +50 -52
  416. package/dist/esm/hooks/use-tanstack-form.js +60 -287
  417. package/dist/esm/index.js +240 -577
  418. package/dist/esm/integrations/tanstack-router/components/breadcrumbs/BreadcrumbLink.js +7 -7
  419. package/dist/esm/integrations/tanstack-router/components/form-contextual-link/FormContextualLink.js +7 -7
  420. package/dist/esm/integrations/tanstack-router/components/link/Link.js +7 -7
  421. package/dist/esm/integrations/tanstack-router/components/link-button/LinkButton.js +5 -5
  422. package/dist/esm/integrations/tanstack-router/components/list-view/ListView.js +20 -23
  423. package/dist/esm/integrations/tanstack-router/components/list-view/parts/ListViewItem.js +17 -30
  424. package/dist/esm/integrations/tanstack-router/components/menu-item/MenuItem.js +17 -15
  425. package/dist/esm/integrations/tanstack-router/components/nav-item/NavItem.js +21 -27
  426. package/dist/esm/integrations/tanstack-router/components/navigation-card/NavigationCard.js +19 -35
  427. package/dist/esm/integrations/tanstack-router/components/pagination/PaginationLink.js +18 -20
  428. package/dist/esm/integrations/tanstack-router/components/pagination/PaginationNext.js +17 -20
  429. package/dist/esm/integrations/tanstack-router/components/pagination/PaginationPrevious.js +18 -21
  430. package/dist/esm/integrations/tanstack-router/components/tabs/Tabs.js +52 -67
  431. package/dist/esm/integrations/tanstack-router/components/tabs/parts/Tab.js +16 -22
  432. package/dist/esm/integrations/tanstack-router/components/tabs/parts/TabPanel.js +14 -14
  433. package/dist/esm/integrations/tanstack-router/components/task-menu/SubTask.js +15 -12
  434. package/dist/esm/integrations/tanstack-router/components/task-menu/Task.js +15 -12
  435. package/dist/esm/integrations/tanstack-router.js +19 -40
  436. package/dist/esm/providers/router/RouterProvider.js +24 -20
  437. package/dist/esm/storybook-testing.js +7 -14
  438. package/dist/esm/utils/createSchemaAdapter.js +7 -12
  439. package/dist/esm/utils/field-revalidate-logic.js +41 -38
  440. package/dist/esm/utils/platform.js +4 -4
  441. package/dist/esm/utils/scroll-detection.js +31 -32
  442. package/dist/esm/utils/spacing.js +14 -14
  443. package/package.json +12 -12
  444. package/dist/esm/components/phone-number/unknownFlag.svg.js +0 -4
  445. package/dist/esm/components/task-menu/parts/dot.svg.js +0 -5
  446. package/dist/esm/components/timeline/parts/check.svg.js +0 -5
@@ -1,220 +1,137 @@
1
- import { jsx as t, jsxs as c } from "react/jsx-runtime";
2
- import { useRef as P, Children as m, isValidElement as l, useLayoutEffect as b } from "react";
3
- import { uyTv as N } from "@payfit/unity-themes";
4
- import { DialogContext as C, Dialog as A } from "react-aria-components/Dialog";
5
- import { ModalOverlay as E, Modal as I } from "react-aria-components/Modal";
6
- import { useId as j } from "react-aria/useId";
7
- import { useIntl as z } from "react-intl";
8
- import { useHasScroll as M } from "../../hooks/use-has-scroll.js";
9
- import { DialogButton as H } from "../dialog/parts/DialogActions/DialogButton.js";
10
- import { CircularIconButton as T } from "../icon-button/CircularIconButton.js";
11
- import { PromoDialogActions as v } from "./parts/PromoDialogActions.js";
12
- import { PromoDialogHero as W } from "./parts/PromoDialogHero.js";
13
- import { PromoDialogTitle as _ } from "./parts/PromoDialogTitle.js";
14
- const k = N({
15
- slots: {
16
- overlay: [
17
- "uy:@container",
18
- "uy:fixed uy:inset-0 uy:z-30 uy:overflow-y-auto",
19
- "uy:min-h-full",
20
- "uy:flex uy:items-end uy:md:items-center uy:md:justify-center uy:md:text-center",
21
- "uy:bg-utility-backdrop",
22
- // enter/leave animation
23
- "uy:data-[entering]:animate-fade-in uy:data-[exiting]:animate-fade-out",
24
- "uy:motion-reduce:data-[entering]:animate-none uy:motion-reduce:data-[exiting]:animate-none"
25
- ],
26
- wrapper: [
27
- "uy:w-full uy:relative uy:isolate",
28
- "uy:m-0",
29
- "uy:rounded-t-300 uy:md:rounded-300",
30
- "uy:bg-surface-neutral",
31
- "uy:text-left uy:align-middle uy:shadow-400",
32
- // Mobile: enter/leave animation
33
- "uy:data-[entering]:animate-slide-up-fade-in uy:data-[exiting]:animate-slide-down-fade-out",
34
- "uy:md:[animation-delay:100ms]",
35
- // Desktop: enter/leave animation
36
- "uy:md:data-[entering]:animate-zoom-in uy:md:data-[exiting]:animate-zoom-out",
37
- "uy:motion-reduce:data-[entering]:animate-none uy:motion-reduce:data-[exiting]:animate-none",
38
- // Mobile: scrollable with max height
39
- "uy:max-h-[95dvh] uy:overflow-y-auto",
40
- // Desktop: max height (adapts to content), no overflow on wrapper
41
- "uy:md:h-[82dvh] uy:md:max-h-65 uy:lg:max-h-85 uy:md:overflow-hidden",
42
- "uy:md:w-10/12 uy:md:max-w-[1000px] uy:p-300 uy:pb-0 uy:md:p-200"
43
- ],
44
- content: [
45
- "uy:group/promo-dialog uy:outline-none uy:relative",
46
- // Mobile: auto height (wrapper scrolls)
47
- "uy:h-auto",
48
- // Desktop: full height (content scrolls internally)
49
- "uy:md:h-full"
50
- ],
51
- dismissIcon: [
52
- // Mobile: sticky button that takes some padding at the top
53
- "uy:sticky uy:top-0 uy:right-0 uy:flex uy:justify-end",
54
- // Desktop: close button is positioned absolutely at the top-right corner
55
- "uy:md:absolute uy:md:right-100 uy:md:top-100 uy:md:z-20"
56
- ],
57
- // Layout slots
58
- layoutWrapper: [
59
- "uy:flex uy:flex-col uy:md:flex-row",
60
- // Mobile: auto height (wrapper scrolls)
61
- "uy:h-auto",
62
- // Desktop: full height for flex layout
63
- "uy:md:h-full uy:gap-300 uy:md:gap-0"
64
- ],
65
- contentColumn: [
66
- "uy:group/content-column",
67
- "uy:flex uy:flex-col",
68
- // Mobile: auto height
69
- "uy:h-auto",
70
- // Desktop: takes 2/3 of width, fixed max height, enables scrolling
71
- "uy:md:basis-2/3 uy:md:h-full uy:md:max-h-85 uy:md:overflow-y-auto uy:md:pt-600 uy:md:[scrollbar-gutter:stable]"
72
- ],
73
- scrollableContent: [
74
- "uy:md:pl-[clamp(var(--uy-spacing-400),11%,var(--uy-spacing-800))] uy:md:pr-1000 uy:[scrollbar-width:thin] uy:md:scroll-mt-1000",
75
- // Mobile: flex-1 to fill space (wrapper scrolls)
76
- "uy:flex-1",
77
- // desktop: centered layout
78
- "uy:md:flex uy:md:flex-col uy:md:justify-center"
79
- ],
80
- actionsWrapper: [
81
- "uy:py-300 uy:md:py-0 uy:sticky uy:-bottom-px uy:bg-surface-neutral",
82
- // Apply shadow when parent group has scroll
83
- "uy:group-data-[has-scroll=true]/content-column:shadow-[0_-1px_6px_0_var(--uy-color-utility-shadow-floating)]"
84
- ]
85
- }
86
- }), B = (r) => {
87
- const n = m.toArray(r).find(
88
- (e) => l(e) && e.type === v
89
- );
90
- return l(
91
- n
92
- ) ? m.toArray(n.props.children).some(
93
- (e) => l(
94
- e
95
- ) && e.type === H && e.props.variant === "danger"
96
- ) : !1;
1
+ import { CircularIconButton as e } from "../icon-button/CircularIconButton.js";
2
+ import { DialogButton as t } from "../dialog/parts/DialogActions/DialogButton.js";
3
+ import { useHasScroll as n } from "../../hooks/use-has-scroll.js";
4
+ import { PromoDialogActions as r } from "./parts/PromoDialogActions.js";
5
+ import { PromoDialogHero as i } from "./parts/PromoDialogHero.js";
6
+ import { PromoDialogTitle as a } from "./parts/PromoDialogTitle.js";
7
+ import { Children as o, isValidElement as s, useLayoutEffect as c, useRef as l } from "react";
8
+ import { uyTv as u } from "@payfit/unity-themes";
9
+ import { jsx as d, jsxs as f } from "react/jsx-runtime";
10
+ import { useIntl as p } from "react-intl";
11
+ import { useId as m } from "react-aria/useId";
12
+ import { Dialog as h, DialogContext as g } from "react-aria-components/Dialog";
13
+ import { Modal as _, ModalOverlay as v } from "react-aria-components/Modal";
14
+ //#region src/components/promo-dialog/PromoDialog.tsx
15
+ var y = u({ slots: {
16
+ overlay: [
17
+ "uy:@container",
18
+ "uy:fixed uy:inset-0 uy:z-30 uy:overflow-y-auto",
19
+ "uy:min-h-full",
20
+ "uy:flex uy:items-end uy:md:items-center uy:md:justify-center uy:md:text-center",
21
+ "uy:bg-utility-backdrop",
22
+ "uy:data-[entering]:animate-fade-in uy:data-[exiting]:animate-fade-out",
23
+ "uy:motion-reduce:data-[entering]:animate-none uy:motion-reduce:data-[exiting]:animate-none"
24
+ ],
25
+ wrapper: [
26
+ "uy:w-full uy:relative uy:isolate",
27
+ "uy:m-0",
28
+ "uy:rounded-t-300 uy:md:rounded-300",
29
+ "uy:bg-surface-neutral",
30
+ "uy:text-left uy:align-middle uy:shadow-400",
31
+ "uy:data-[entering]:animate-slide-up-fade-in uy:data-[exiting]:animate-slide-down-fade-out",
32
+ "uy:md:[animation-delay:100ms]",
33
+ "uy:md:data-[entering]:animate-zoom-in uy:md:data-[exiting]:animate-zoom-out",
34
+ "uy:motion-reduce:data-[entering]:animate-none uy:motion-reduce:data-[exiting]:animate-none",
35
+ "uy:max-h-[95dvh] uy:overflow-y-auto",
36
+ "uy:md:h-[82dvh] uy:md:max-h-65 uy:lg:max-h-85 uy:md:overflow-hidden",
37
+ "uy:md:w-10/12 uy:md:max-w-[1000px] uy:p-300 uy:pb-0 uy:md:p-200"
38
+ ],
39
+ content: [
40
+ "uy:group/promo-dialog uy:outline-none uy:relative",
41
+ "uy:h-auto",
42
+ "uy:md:h-full"
43
+ ],
44
+ dismissIcon: ["uy:sticky uy:top-0 uy:right-0 uy:flex uy:justify-end", "uy:md:absolute uy:md:right-100 uy:md:top-100 uy:md:z-20"],
45
+ layoutWrapper: [
46
+ "uy:flex uy:flex-col uy:md:flex-row",
47
+ "uy:h-auto",
48
+ "uy:md:h-full uy:gap-300 uy:md:gap-0"
49
+ ],
50
+ contentColumn: [
51
+ "uy:group/content-column",
52
+ "uy:flex uy:flex-col",
53
+ "uy:h-auto",
54
+ "uy:md:basis-2/3 uy:md:h-full uy:md:max-h-85 uy:md:overflow-y-auto uy:md:pt-600 uy:md:[scrollbar-gutter:stable]"
55
+ ],
56
+ scrollableContent: [
57
+ "uy:md:pl-[clamp(var(--uy-spacing-400),11%,var(--uy-spacing-800))] uy:md:pr-1000 uy:[scrollbar-width:thin] uy:md:scroll-mt-1000",
58
+ "uy:flex-1",
59
+ "uy:md:flex uy:md:flex-col uy:md:justify-center"
60
+ ],
61
+ actionsWrapper: ["uy:py-300 uy:md:py-0 uy:sticky uy:-bottom-px uy:bg-surface-neutral", "uy:group-data-[has-scroll=true]/content-column:shadow-[0_-1px_6px_0_var(--uy-color-utility-shadow-floating)]"]
62
+ } }), b = (e) => {
63
+ let n = o.toArray(e).find((e) => s(e) && e.type === r);
64
+ return s(n) ? o.toArray(n.props.children).some((e) => s(e) && e.type === t && e.props.variant === "danger") : !1;
97
65
  };
98
- function q({
99
- children: r,
100
- isOpen: n,
101
- onOpenChange: e,
102
- isDismissable: p = !0,
103
- ...y
104
- }) {
105
- const f = z(), d = j(), g = P(null), { hasAnyScroll: i } = M(g, {
106
- strategy: "both",
107
- watchMutations: !0
108
- }), s = m.toArray(r), u = s.find(
109
- (o) => l(o) && o.type === W
110
- ), h = s.find(
111
- (o) => l(o) && o.type === v
112
- ), w = s.filter(
113
- (o) => o !== u && o !== h
114
- );
115
- b(() => {
116
- u || console.error(
117
- "PromoDialog: PromoDialogHero is required. Please add <PromoDialogHero> as a child of your PromoDialog component."
118
- );
119
- }, [u]), b(() => {
120
- const D = m.toArray(r).some(
121
- (x) => l(x) && x.type === _
122
- );
123
- !y["aria-label"] && !D && console.error(
124
- "PromoDialog: Either an aria-label or a PromoDialogTitle is required for accessibility. Provide one to ensure screen reader users can identify the dialog."
125
- );
126
- }, [r, y]);
127
- const a = k();
128
- return /* @__PURE__ */ t(
129
- E,
130
- {
131
- isDismissable: p,
132
- isOpen: n,
133
- onOpenChange: e,
134
- className: a.overlay(),
135
- children: /* @__PURE__ */ t(
136
- I,
137
- {
138
- className: a.wrapper(),
139
- "data-unity-promo-dialog": !0,
140
- "data-dd-privacy": "allow",
141
- children: /* @__PURE__ */ t(C.Provider, { value: { "aria-describedby": d }, children: /* @__PURE__ */ c(
142
- A,
143
- {
144
- role: B(r) ? "alertdialog" : "dialog",
145
- "aria-modal": "true",
146
- className: a.content(),
147
- "aria-label": y["aria-label"],
148
- "aria-describedby": d,
149
- "data-unity-slot": "promo-dialog",
150
- children: [
151
- p && /* @__PURE__ */ t("div", { className: a.dismissIcon(), children: /* @__PURE__ */ t(
152
- T,
153
- {
154
- asElement: "button",
155
- icon: "CloseOutlined",
156
- color: "content.neutral.low",
157
- size: "large",
158
- title: f.formatMessage({
159
- id: "unity:component:common:close:label"
160
- }),
161
- slot: "close",
162
- className: "uy:relative uy:-top-100 uy:-right-100 uy:md:static"
163
- }
164
- ) }),
165
- /* @__PURE__ */ c(
166
- "div",
167
- {
168
- className: a.layoutWrapper(),
169
- "data-slot": "promo-dialog.layout-wrapper",
170
- children: [
171
- u,
172
- /* @__PURE__ */ c(
173
- "div",
174
- {
175
- ref: g,
176
- className: a.contentColumn(),
177
- "data-slot": "promo-dialog.content-column",
178
- "data-has-scroll": i,
179
- role: i ? "region" : void 0,
180
- "aria-label": i ? f.formatMessage({
181
- id: "unity:component:common:scrollable-content:label"
182
- }) : void 0,
183
- tabIndex: i ? 0 : void 0,
184
- children: [
185
- /* @__PURE__ */ t(
186
- "div",
187
- {
188
- id: d,
189
- className: a.scrollableContent(),
190
- "data-slot": "promo-dialog.scrollable-content",
191
- children: w
192
- }
193
- ),
194
- /* @__PURE__ */ t(
195
- "div",
196
- {
197
- className: a.actionsWrapper(),
198
- "data-slot": "promo-dialog.actions-wrapper",
199
- children: h
200
- }
201
- )
202
- ]
203
- }
204
- )
205
- ]
206
- }
207
- )
208
- ]
209
- }
210
- ) })
211
- }
212
- )
213
- }
214
- );
66
+ function x({ children: t, isOpen: u, onOpenChange: x, isDismissable: S = !0, ...C }) {
67
+ let w = p(), T = m(), E = l(null), { hasAnyScroll: D } = n(E, {
68
+ strategy: "both",
69
+ watchMutations: !0
70
+ }), O = o.toArray(t), k = O.find((e) => s(e) && e.type === i), A = O.find((e) => s(e) && e.type === r), j = O.filter((e) => e !== k && e !== A);
71
+ c(() => {
72
+ k || console.error("PromoDialog: PromoDialogHero is required. Please add <PromoDialogHero> as a child of your PromoDialog component.");
73
+ }, [k]), c(() => {
74
+ let e = o.toArray(t).some((e) => s(e) && e.type === a);
75
+ !C["aria-label"] && !e && console.error("PromoDialog: Either an aria-label or a PromoDialogTitle is required for accessibility. Provide one to ensure screen reader users can identify the dialog.");
76
+ }, [t, C]);
77
+ let M = y();
78
+ return /* @__PURE__ */ d(v, {
79
+ isDismissable: S,
80
+ isOpen: u,
81
+ onOpenChange: x,
82
+ className: M.overlay(),
83
+ children: /* @__PURE__ */ d(_, {
84
+ className: M.wrapper(),
85
+ "data-unity-promo-dialog": !0,
86
+ "data-dd-privacy": "allow",
87
+ children: /* @__PURE__ */ d(g.Provider, {
88
+ value: { "aria-describedby": T },
89
+ children: /* @__PURE__ */ f(h, {
90
+ role: b(t) ? "alertdialog" : "dialog",
91
+ "aria-modal": "true",
92
+ className: M.content(),
93
+ "aria-label": C["aria-label"],
94
+ "aria-describedby": T,
95
+ "data-unity-slot": "promo-dialog",
96
+ children: [S && /* @__PURE__ */ d("div", {
97
+ className: M.dismissIcon(),
98
+ children: /* @__PURE__ */ d(e, {
99
+ asElement: "button",
100
+ icon: "CloseOutlined",
101
+ color: "content.neutral.low",
102
+ size: "large",
103
+ title: w.formatMessage({ id: "unity:component:common:close:label" }),
104
+ slot: "close",
105
+ className: "uy:relative uy:-top-100 uy:-right-100 uy:md:static"
106
+ })
107
+ }), /* @__PURE__ */ f("div", {
108
+ className: M.layoutWrapper(),
109
+ "data-slot": "promo-dialog.layout-wrapper",
110
+ children: [k, /* @__PURE__ */ f("div", {
111
+ ref: E,
112
+ className: M.contentColumn(),
113
+ "data-slot": "promo-dialog.content-column",
114
+ "data-has-scroll": D,
115
+ role: D ? "region" : void 0,
116
+ "aria-label": D ? w.formatMessage({ id: "unity:component:common:scrollable-content:label" }) : void 0,
117
+ tabIndex: D ? 0 : void 0,
118
+ children: [/* @__PURE__ */ d("div", {
119
+ id: T,
120
+ className: M.scrollableContent(),
121
+ "data-slot": "promo-dialog.scrollable-content",
122
+ children: j
123
+ }), /* @__PURE__ */ d("div", {
124
+ className: M.actionsWrapper(),
125
+ "data-slot": "promo-dialog.actions-wrapper",
126
+ children: A
127
+ })]
128
+ })]
129
+ })]
130
+ })
131
+ })
132
+ })
133
+ });
215
134
  }
216
- q.displayName = "PromoDialog";
217
- export {
218
- q as PromoDialog,
219
- k as promoDialog
220
- };
135
+ x.displayName = "PromoDialog";
136
+ //#endregion
137
+ export { x as PromoDialog, y as promoDialog };
@@ -1,29 +1,19 @@
1
- import { jsx as a } from "react/jsx-runtime";
2
- import { uyTv as i } from "@payfit/unity-themes";
3
- import { useIntl as r } from "react-intl";
4
- const s = i({
5
- base: [
6
- "uy:md:pt-250 uy:md:pb-100 uy:md:px-200 uy:flex uy:flex-col-reverse uy:md:flex-row uy:md:justify-end uy:md:items-start",
7
- "uy:gap-150 uy:md:gap-100",
8
- "uy:self-stretch"
9
- ]
10
- }), e = ({ children: o }) => {
11
- const t = r();
12
- return /* @__PURE__ */ a(
13
- "div",
14
- {
15
- role: "group",
16
- "aria-label": t.formatMessage({
17
- id: "unity:component:dialog:actions:label"
18
- }),
19
- className: s(),
20
- "data-unity-slot": "promo-dialog.actions",
21
- "data-dd-privacy": "allow",
22
- children: o
23
- }
24
- );
25
- };
26
- e.displayName = "PromoDialogActions";
27
- export {
28
- e as PromoDialogActions
29
- };
1
+ import { uyTv as e } from "@payfit/unity-themes";
2
+ import { jsx as t } from "react/jsx-runtime";
3
+ import { useIntl as n } from "react-intl";
4
+ //#region src/components/promo-dialog/parts/PromoDialogActions.tsx
5
+ var r = e({ base: [
6
+ "uy:md:pt-250 uy:md:pb-100 uy:md:px-200 uy:flex uy:flex-col-reverse uy:md:flex-row uy:md:justify-end uy:md:items-start",
7
+ "uy:gap-150 uy:md:gap-100",
8
+ "uy:self-stretch"
9
+ ] }), i = ({ children: e }) => /* @__PURE__ */ t("div", {
10
+ role: "group",
11
+ "aria-label": n().formatMessage({ id: "unity:component:dialog:actions:label" }),
12
+ className: r(),
13
+ "data-unity-slot": "promo-dialog.actions",
14
+ "data-dd-privacy": "allow",
15
+ children: e
16
+ });
17
+ i.displayName = "PromoDialogActions";
18
+ //#endregion
19
+ export { i as PromoDialogActions };
@@ -1,20 +1,15 @@
1
+ import { uyTv as e } from "@payfit/unity-themes";
1
2
  import { jsx as t } from "react/jsx-runtime";
2
- import { uyTv as n } from "@payfit/unity-themes";
3
- const a = n({
4
- base: [
5
- "uy:flex uy:flex-col uy:gap-200",
6
- "uy:text-content-neutral",
7
- "uy:typography-body"
8
- ]
9
- }), e = ({ children: o }) => /* @__PURE__ */ t(
10
- "div",
11
- {
12
- className: a(),
13
- "data-unity-slot": "promo-dialog.content",
14
- children: o
15
- }
16
- );
17
- e.displayName = "PromoDialogContent";
18
- export {
19
- e as PromoDialogContent
20
- };
3
+ //#region src/components/promo-dialog/parts/PromoDialogContent.tsx
4
+ var n = e({ base: [
5
+ "uy:flex uy:flex-col uy:gap-200",
6
+ "uy:text-content-neutral",
7
+ "uy:typography-body"
8
+ ] }), r = ({ children: e }) => /* @__PURE__ */ t("div", {
9
+ className: n(),
10
+ "data-unity-slot": "promo-dialog.content",
11
+ children: e
12
+ });
13
+ r.displayName = "PromoDialogContent";
14
+ //#endregion
15
+ export { r as PromoDialogContent };
@@ -1,25 +1,18 @@
1
- import { jsx as a } from "react/jsx-runtime";
2
1
  import { uyTv as e } from "@payfit/unity-themes";
3
- const t = e({
4
- base: [
5
- "uy:rounded-150 uy:bg-surface-neutral-lowest",
6
- "uy:flex uy:items-center uy:justify-center",
7
- // Mobile: auto height for vertical stack
8
- "uy:h-auto",
9
- // Desktop: takes 1/3 of width, stretches to row height
10
- "uy:md:basis-[40%] uy:lg:basis-[37.2%] uy:md:shrink-0"
11
- ]
12
- }), u = ({ children: o, className: r }) => /* @__PURE__ */ a(
13
- "div",
14
- {
15
- className: t({ className: r }),
16
- "data-unity-slot": "promo-dialog.hero",
17
- "data-dd-privacy": "allow",
18
- "aria-hidden": "true",
19
- children: o
20
- }
21
- );
22
- u.displayName = "PromoDialogHero";
23
- export {
24
- u as PromoDialogHero
25
- };
2
+ import { jsx as t } from "react/jsx-runtime";
3
+ //#region src/components/promo-dialog/parts/PromoDialogHero.tsx
4
+ var n = e({ base: [
5
+ "uy:rounded-150 uy:bg-surface-neutral-lowest",
6
+ "uy:flex uy:items-center uy:justify-center",
7
+ "uy:h-auto",
8
+ "uy:md:basis-[40%] uy:lg:basis-[37.2%] uy:md:shrink-0"
9
+ ] }), r = ({ children: e, className: r }) => /* @__PURE__ */ t("div", {
10
+ className: n({ className: r }),
11
+ "data-unity-slot": "promo-dialog.hero",
12
+ "data-dd-privacy": "allow",
13
+ "aria-hidden": "true",
14
+ children: e
15
+ });
16
+ r.displayName = "PromoDialogHero";
17
+ //#endregion
18
+ export { r as PromoDialogHero };
@@ -1,21 +1,15 @@
1
- import { jsx as a } from "react/jsx-runtime";
2
- import { Text as l } from "../../text/Text.js";
3
- const r = ({
4
- children: o,
5
- ...t
6
- }) => /* @__PURE__ */ a(
7
- l,
8
- {
9
- ...t,
10
- variant: "body",
11
- asElement: "h4",
12
- color: "content.neutral.lowest",
13
- "data-unity-slot": "promo-dialog.subtitle",
14
- className: "uy:typography-body-small uy:md:typography-body uy:mb-100",
15
- children: o
16
- }
17
- );
18
- r.displayName = "PromoDialogSubtitle";
19
- export {
20
- r as PromoDialogSubtitle
21
- };
1
+ import { Text as e } from "../../text/Text.js";
2
+ import { jsx as t } from "react/jsx-runtime";
3
+ //#region src/components/promo-dialog/parts/PromoDialogSubtitle.tsx
4
+ var n = ({ children: n, ...r }) => /* @__PURE__ */ t(e, {
5
+ ...r,
6
+ variant: "body",
7
+ asElement: "h4",
8
+ color: "content.neutral.lowest",
9
+ "data-unity-slot": "promo-dialog.subtitle",
10
+ className: "uy:typography-body-small uy:md:typography-body uy:mb-100",
11
+ children: n
12
+ });
13
+ n.displayName = "PromoDialogSubtitle";
14
+ //#endregion
15
+ export { n as PromoDialogSubtitle };
@@ -1,18 +1,13 @@
1
+ import { uyTv as e } from "@payfit/unity-themes";
1
2
  import { jsx as t } from "react/jsx-runtime";
2
- import { uyTv as a } from "@payfit/unity-themes";
3
- import { Heading as m } from "react-aria-components/Heading";
4
- const r = a({
5
- base: ["uy:typography-h2 uy:md:typography-h1", "uy:mb-150 uy:md:mb-250"]
6
- }), i = ({ children: o }) => /* @__PURE__ */ t(
7
- m,
8
- {
9
- slot: "title",
10
- className: r(),
11
- "data-dd-privacy": "allow",
12
- children: o
13
- }
14
- );
3
+ import { Heading as n } from "react-aria-components/Heading";
4
+ //#region src/components/promo-dialog/parts/PromoDialogTitle.tsx
5
+ var r = e({ base: ["uy:typography-h2 uy:md:typography-h1", "uy:mb-150 uy:md:mb-250"] }), i = ({ children: e }) => /* @__PURE__ */ t(n, {
6
+ slot: "title",
7
+ className: r(),
8
+ "data-dd-privacy": "allow",
9
+ children: e
10
+ });
15
11
  i.displayName = "PromoDialogTitle";
16
- export {
17
- i as PromoDialogTitle
18
- };
12
+ //#endregion
13
+ export { i as PromoDialogTitle };
@@ -1,23 +1,18 @@
1
- import { jsx as f } from "react/jsx-runtime";
2
- import { forwardRef as i } from "react";
3
- import { RadioGroup as d } from "react-aria-components/RadioGroup";
4
- const l = i(
5
- ({ children: o, isReadOnly: r, isDisabled: t, value: a, onChange: p, onBlur: u, ...m }, e) => /* @__PURE__ */ f(
6
- d,
7
- {
8
- ...m,
9
- isReadOnly: r,
10
- isDisabled: t,
11
- value: a,
12
- onBlur: u,
13
- onChange: p,
14
- className: "uy:flex uy:flex-col uy:gap-150",
15
- ref: e,
16
- children: o
17
- }
18
- )
19
- );
20
- l.displayName = "RadioButtonGroup";
21
- export {
22
- l as RadioButtonGroup
23
- };
1
+ import { forwardRef as e } from "react";
2
+ import { jsx as t } from "react/jsx-runtime";
3
+ import { RadioGroup as n } from "react-aria-components/RadioGroup";
4
+ //#region src/components/radio-button-group/RadioButtonGroup.tsx
5
+ var r = e(({ children: e, isReadOnly: r, isDisabled: i, value: a, onChange: o, onBlur: s, ...c }, l) => /* @__PURE__ */ t(n, {
6
+ ...c,
7
+ isReadOnly: r,
8
+ isDisabled: i,
9
+ value: a,
10
+ onBlur: s,
11
+ onChange: o,
12
+ className: "uy:flex uy:flex-col uy:gap-150",
13
+ ref: l,
14
+ children: e
15
+ }));
16
+ r.displayName = "RadioButtonGroup";
17
+ //#endregion
18
+ export { r as RadioButtonGroup };