@payfit/unity-components 2.29.12 → 2.31.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,18 +1,19 @@
1
- import { jsxs as l, jsx as e } from "react/jsx-runtime";
1
+ import { jsxs as n, jsx as e } from "react/jsx-runtime";
2
2
  import { useState as v, useRef as C, isValidElement as I, cloneElement as O } from "react";
3
3
  import { uyMerge as g } from "@payfit/unity-themes";
4
4
  import { FormattedMessage as h, useIntl as V } from "react-intl";
5
- import { Actionable as x } from "../../actionable/Actionable.js";
5
+ import { Actionable as w } from "../../actionable/Actionable.js";
6
6
  import { Avatar as z } from "../../avatar/Avatar.js";
7
7
  import { AvatarFallback as F } from "../../avatar/parts/AvatarFallback.js";
8
8
  import { AvatarImage as H } from "../../avatar/parts/AvatarImage.js";
9
9
  import { Badge as j } from "../../badge/Badge.js";
10
- import { Icon as M } from "../../icon/Icon.js";
10
+ import { Icon as x } from "../../icon/Icon.js";
11
11
  import { Menu as k } from "../../menu/Menu.js";
12
12
  import { MenuContent as E } from "../../menu/parts/MenuContent.js";
13
13
  import { MenuHeader as S } from "../../menu/parts/MenuHeader.js";
14
- import { useAppMenuContext as B } from "./AppMenu.context.js";
15
- const w = (t) => /* @__PURE__ */ l(
14
+ import { MenuTrigger as B } from "../../menu/parts/MenuTrigger.js";
15
+ import { useAppMenuContext as R } from "./AppMenu.context.js";
16
+ const M = (t) => /* @__PURE__ */ n(
16
17
  z,
17
18
  {
18
19
  "aria-label": `${t.title} avatar`,
@@ -27,48 +28,48 @@ const w = (t) => /* @__PURE__ */ l(
27
28
  })
28
29
  ]
29
30
  }
30
- ), R = ({
31
+ ), q = ({
31
32
  avatar: t,
32
- avatarPair: a,
33
- title: n,
34
- uploadAvatarCallback: y,
33
+ avatarPair: r,
34
+ title: u,
35
+ uploadAvatarCallback: d,
35
36
  uploadAvatarLabel: s,
36
- uploadAvatarDescription: r
37
+ uploadAvatarDescription: i
37
38
  }) => {
38
- const [o, u] = v(!0), c = V(), i = () => {
39
- a && u((f) => !f);
40
- }, d = g(
39
+ const [o, l] = v(!0), c = V(), a = () => {
40
+ r && l((m) => !m);
41
+ }, y = g(
41
42
  "uy:group/avatar uy:cursor-pointer uy:relative uy:leading-[0] uy:rounded-75 uy:focus-visible:outline-none uy:focus-visible:ring-2 uy:focus-visible:ring-utility-focus-ring uy:focus-visible:ring-offset-2"
42
43
  );
43
- return /* @__PURE__ */ l(
44
- x,
44
+ return /* @__PURE__ */ n(
45
+ w,
45
46
  {
46
47
  "aria-describedby": "profile-picture-change-desc",
47
48
  "aria-label": s || c.formatMessage({
48
49
  id: "unity:component:app-menu:footer:profile-button:avatar:change",
49
50
  defaultMessage: "Change profile picture"
50
51
  }),
51
- className: d,
52
- onHoverStart: i,
53
- onHoverEnd: i,
54
- onFocus: i,
55
- onBlur: i,
52
+ className: y,
53
+ onHoverStart: a,
54
+ onHoverEnd: a,
55
+ onFocus: a,
56
+ onBlur: a,
56
57
  onPress: () => {
57
- y?.();
58
+ d?.();
58
59
  },
59
60
  children: [
60
61
  /* @__PURE__ */ e(
61
- w,
62
+ M,
62
63
  {
63
64
  avatar: t,
64
- avatarPair: a,
65
- title: n,
65
+ avatarPair: r,
66
+ title: u,
66
67
  isPairAvatarVisible: o
67
68
  }
68
69
  ),
69
- /* @__PURE__ */ l("div", { className: "uy:flex uy:pointer-events-none uy:opacity-0 uy:group-hover/avatar:opacity-90 uy:group-hover/avatar:pointer-events-auto uy:group-focus-visible/avatar:opacity-90 uy:group-focus-visible/avatar:pointer-events-auto uy:bg-utility-backdrop uy:rounded-75 uy:absolute uy:top-0 uy:left-0 uy:w-full uy:h-full uy:transition-all uy:duration-200 uy:items-center uy:justify-center", children: [
70
+ /* @__PURE__ */ n("div", { className: "uy:flex uy:pointer-events-none uy:opacity-0 uy:group-hover/avatar:opacity-90 uy:group-hover/avatar:pointer-events-auto uy:group-focus-visible/avatar:opacity-90 uy:group-focus-visible/avatar:pointer-events-auto uy:bg-utility-backdrop uy:rounded-75 uy:absolute uy:top-0 uy:left-0 uy:w-full uy:h-full uy:transition-all uy:duration-200 uy:items-center uy:justify-center", children: [
70
71
  /* @__PURE__ */ e(
71
- M,
72
+ x,
72
73
  {
73
74
  alt: "Camera",
74
75
  color: "content.inverted",
@@ -76,7 +77,7 @@ const w = (t) => /* @__PURE__ */ l(
76
77
  src: "CameraOutlined"
77
78
  }
78
79
  ),
79
- /* @__PURE__ */ e("span", { className: "uy:sr-only", id: "profile-picture-change-desc", children: r || /* @__PURE__ */ e(
80
+ /* @__PURE__ */ e("span", { className: "uy:sr-only", id: "profile-picture-change-desc", children: i || /* @__PURE__ */ e(
80
81
  h,
81
82
  {
82
83
  id: "unity:component:app-menu:footer:profile-button:avatar:change-description",
@@ -89,36 +90,36 @@ const w = (t) => /* @__PURE__ */ l(
89
90
  );
90
91
  }, b = ({
91
92
  asMenuHeader: t = !1,
92
- avatar: a,
93
- avatarPair: n,
94
- badgeLabel: y,
93
+ avatar: r,
94
+ avatarPair: u,
95
+ badgeLabel: d,
95
96
  description: s,
96
- menuTriggerDescription: r,
97
+ menuTriggerDescription: i,
97
98
  title: o,
98
- uploadAvatarCallback: u,
99
+ uploadAvatarCallback: l,
99
100
  uploadAvatarLabel: c,
100
- uploadAvatarDescription: i
101
- }) => /* @__PURE__ */ l("div", { className: "uy:min-w-[240px] uy:w-full uy:flex uy:items-center", children: [
102
- /* @__PURE__ */ e("div", { className: "uy:mr-150 uy:flex uy:items-center", children: u ? /* @__PURE__ */ e(
103
- R,
101
+ uploadAvatarDescription: a
102
+ }) => /* @__PURE__ */ n("div", { className: "uy:min-w-[240px] uy:w-full uy:flex uy:items-center", children: [
103
+ /* @__PURE__ */ e("div", { className: "uy:mr-150 uy:flex uy:items-center", children: l ? /* @__PURE__ */ e(
104
+ q,
104
105
  {
105
- avatar: a,
106
- avatarPair: n,
106
+ avatar: r,
107
+ avatarPair: u,
107
108
  title: o,
108
109
  uploadAvatarLabel: c,
109
- uploadAvatarDescription: i,
110
- uploadAvatarCallback: u
110
+ uploadAvatarDescription: a,
111
+ uploadAvatarCallback: l
111
112
  }
112
113
  ) : /* @__PURE__ */ e(
113
- w,
114
+ M,
114
115
  {
115
- avatar: a,
116
- avatarPair: n,
116
+ avatar: r,
117
+ avatarPair: u,
117
118
  title: o,
118
119
  isPairAvatarVisible: !0
119
120
  }
120
121
  ) }),
121
- /* @__PURE__ */ l("div", { className: "uy:flex uy:flex-col uy:text-left uy:leading-[1.25] uy:min-w-[50%] uy:flex-grow", children: [
122
+ /* @__PURE__ */ n("div", { className: "uy:flex uy:flex-col uy:text-left uy:leading-[1.25] uy:min-w-[50%] uy:flex-grow", children: [
122
123
  /* @__PURE__ */ e(
123
124
  "span",
124
125
  {
@@ -136,7 +137,7 @@ const w = (t) => /* @__PURE__ */ l(
136
137
  children: s
137
138
  }
138
139
  ),
139
- !t && /* @__PURE__ */ e("span", { id: "profile-button-description", className: "uy:sr-only", children: r || /* @__PURE__ */ e(
140
+ !t && /* @__PURE__ */ e("span", { id: "profile-button-description", className: "uy:sr-only", children: i || /* @__PURE__ */ e(
140
141
  h,
141
142
  {
142
143
  id: "unity:component:app-menu:footer:profile-button:description",
@@ -144,8 +145,8 @@ const w = (t) => /* @__PURE__ */ l(
144
145
  }
145
146
  ) })
146
147
  ] }),
147
- /* @__PURE__ */ e("div", { className: "uy:p-100", children: t ? /* @__PURE__ */ e(j, { className: "uy:capitalize", variant: "neutral", children: y }) : /* @__PURE__ */ e(
148
- M,
148
+ /* @__PURE__ */ e("div", { className: "uy:p-100", children: t ? /* @__PURE__ */ e(j, { className: "uy:capitalize", variant: "neutral", children: d }) : /* @__PURE__ */ e(
149
+ x,
149
150
  {
150
151
  src: "CaretUpDownOutlined",
151
152
  alt: "open",
@@ -153,27 +154,27 @@ const w = (t) => /* @__PURE__ */ l(
153
154
  color: "content.neutral.low"
154
155
  }
155
156
  ) })
156
- ] }), L = ({
157
+ ] }), te = ({
157
158
  avatar: t,
158
- avatarPair: a,
159
- badgeLabel: n,
160
- children: y,
159
+ avatarPair: r,
160
+ badgeLabel: u,
161
+ children: d,
161
162
  computeSlot: s,
162
- description: r,
163
+ description: i,
163
164
  title: o,
164
- menuTriggerDescription: u,
165
+ menuTriggerDescription: l,
165
166
  uploadAvatarCallback: c,
166
- uploadAvatarLabel: i,
167
- uploadAvatarDescription: d,
168
- updateNotificationSlot: f
167
+ uploadAvatarLabel: a,
168
+ uploadAvatarDescription: y,
169
+ updateNotificationSlot: m
169
170
  }) => {
170
- const { isMobileMenuOpen: N } = B(), [P, p] = v(!1), m = C(null), A = g(
171
+ const { isMobileMenuOpen: N } = R(), [P, f] = v(!1), p = C(null), A = g(
171
172
  "uy:fixed uy:bottom-0 uy:left-0 uy:right-0 uy:z-10 uy:bg-canvas",
172
173
  "uy:p-150",
173
174
  "uy:md:static uy:md:mt-auto uy:md:p-0 uy:md:bg-[transparent]",
174
175
  "uy:data-[mobile-open=false]:hidden uy:md:data-[mobile-open=false]:block uy:data-[mobile-open=true]:block"
175
176
  );
176
- return /* @__PURE__ */ l(
177
+ return /* @__PURE__ */ n(
177
178
  "aside",
178
179
  {
179
180
  className: A,
@@ -181,55 +182,66 @@ const w = (t) => /* @__PURE__ */ l(
181
182
  id: "app-menu-profile-button",
182
183
  children: [
183
184
  s,
184
- f,
185
- /* @__PURE__ */ e(
186
- x,
185
+ m,
186
+ /* @__PURE__ */ n(
187
+ k,
187
188
  {
188
- ref: m,
189
- className: "uy:transition-colors uy:rounded-75 uy:px-150 uy:py-100 uy:w-full uy:not-aria-disabled:hover:bg-surface-neutral-low-hover uy:not-aria-disabled:active:bg-surface-neutral-low-active uy:not-aria-disabled:data-[pressed=true]:bg-surface-neutral-low-active uy:not-aria-disabled:focus-visible:outline-none uy:not-aria-disabled:focus-visible:ring-2 uy:not-aria-disabled:focus-visible:ring-utility-focus-ring uy:not-aria-disabled:focus-visible:ring-offset-2",
190
- "aria-labelledby": "profile-button-label",
191
- "aria-describedby": "profile-button-description",
192
- onPress: () => {
193
- p(!0);
194
- },
195
- children: /* @__PURE__ */ e(
196
- b,
197
- {
198
- avatar: t,
199
- avatarPair: a,
200
- badgeLabel: n,
201
- description: r,
202
- menuTriggerDescription: u,
203
- title: o,
204
- uploadAvatarCallback: c,
205
- uploadAvatarLabel: i,
206
- uploadAvatarDescription: d
207
- }
208
- )
189
+ isOpen: P,
190
+ onOpenChange: f,
191
+ placement: "top left",
192
+ triggerRef: p,
193
+ children: [
194
+ /* @__PURE__ */ e(B, { asChild: !0, children: /* @__PURE__ */ e(
195
+ w,
196
+ {
197
+ ref: p,
198
+ className: "uy:transition-colors uy:rounded-75 uy:px-150 uy:py-100 uy:w-full uy:theme-legacy:not-aria-disabled:hover:bg-surface-neutral-low-hover uy:theme-rebrand:not-aria-disabled:hover:bg-surface-neutral-lowest-hover uy:theme-legacy:not-aria-disabled:active:bg-surface-neutral-low-active uy:theme-rebrand:not-aria-disabled:active:bg-surface-neutral-lowest-active uy:theme-legacy:not-aria-disabled:data-[pressed=true]:bg-surface-neutral-low-pressed uy:theme-rebrand:not-aria-disabled:data-[pressed=true]:bg-surface-neutral-lowest-pressed uy:not-aria-disabled:focus-visible:outline-none uy:not-aria-disabled:focus-visible:ring-2 uy:not-aria-disabled:focus-visible:ring-utility-focus-ring uy:not-aria-disabled:focus-visible:ring-offset-2",
199
+ "aria-labelledby": "profile-button-label",
200
+ "aria-describedby": "profile-button-description",
201
+ onPress: () => {
202
+ f(!0);
203
+ },
204
+ children: /* @__PURE__ */ e(
205
+ b,
206
+ {
207
+ avatar: t,
208
+ avatarPair: r,
209
+ badgeLabel: u,
210
+ description: i,
211
+ menuTriggerDescription: l,
212
+ title: o,
213
+ uploadAvatarCallback: c,
214
+ uploadAvatarLabel: a,
215
+ uploadAvatarDescription: y
216
+ }
217
+ )
218
+ }
219
+ ) }),
220
+ /* @__PURE__ */ n(E, { width: 312, children: [
221
+ /* @__PURE__ */ e(S, { className: "uy:rounded-75", children: /* @__PURE__ */ e(
222
+ b,
223
+ {
224
+ asMenuHeader: !0,
225
+ avatar: t,
226
+ avatarPair: r,
227
+ badgeLabel: u,
228
+ description: i,
229
+ menuTriggerDescription: l,
230
+ title: o,
231
+ uploadAvatarCallback: c,
232
+ uploadAvatarLabel: a,
233
+ uploadAvatarDescription: y
234
+ }
235
+ ) }),
236
+ d
237
+ ] })
238
+ ]
209
239
  }
210
- ),
211
- /* @__PURE__ */ e(k, { isOpen: P, onOpenChange: p, children: /* @__PURE__ */ l(E, { width: 312, placement: "top left", triggerRef: m, children: [
212
- /* @__PURE__ */ e(S, { className: "uy:rounded-75", children: /* @__PURE__ */ e(
213
- b,
214
- {
215
- asMenuHeader: !0,
216
- avatar: t,
217
- avatarPair: a,
218
- badgeLabel: n,
219
- description: r,
220
- menuTriggerDescription: u,
221
- title: o,
222
- uploadAvatarCallback: c,
223
- uploadAvatarLabel: i,
224
- uploadAvatarDescription: d
225
- }
226
- ) }),
227
- y
228
- ] }) })
240
+ )
229
241
  ]
230
242
  }
231
243
  );
232
244
  };
233
245
  export {
234
- L as AppMenuFooter
246
+ te as AppMenuFooter
235
247
  };
@@ -1,41 +1,51 @@
1
- import { jsxs as r, jsx as n } from "react/jsx-runtime";
1
+ import { jsxs as o, jsx as e } from "react/jsx-runtime";
2
2
  import { Link as m } from "react-aria-components/Link";
3
- import { useIntl as s } from "react-intl";
4
- import { IconButton as c } from "../../icon-button/IconButton.js";
5
- import { PayFitBrand as y } from "../../payfit-brand/PayFitBrand.js";
6
- import { PayFitBrandPreprod as f } from "../../payfit-brand/PayFitPreprod.js";
7
- import { useAppMenuContext as h } from "./AppMenu.context.js";
8
- const O = ({
9
- environment: o,
10
- brandLabel: a,
3
+ import { useIntl as c } from "react-intl";
4
+ import { useBreakpointListener as y, isMobileBreakpoint as f } from "../../../hooks/use-breakpoint-listener.js";
5
+ import { Button as h } from "../../button/Button.js";
6
+ import { PayFitBrand as b } from "../../payfit-brand/PayFitBrand.js";
7
+ import { PayFitBrandPreprod as g } from "../../payfit-brand/PayFitPreprod.js";
8
+ import { useAppMenuContext as x } from "./AppMenu.context.js";
9
+ const j = ({
10
+ environment: r,
11
+ brandLabel: i,
11
12
  notificationsComponent: t,
12
- searchComponent: i,
13
- renderLink: l = ({ children: e }) => /* @__PURE__ */ n(m, { href: "/", children: e })
13
+ searchComponent: l,
14
+ renderLink: s = ({ children: n }) => /* @__PURE__ */ e(m, { href: "/", children: n })
14
15
  }) => {
15
- const { isMobileMenuOpen: e, toggleMobileMenu: u } = h(), d = s(), p = o === "prod" ? /* @__PURE__ */ n(y, { label: a, width: 104 }) : /* @__PURE__ */ n(f, { label: a, env: o });
16
- return /* @__PURE__ */ r("header", { className: "uy:flex uy:flex-col uy:gap-y-200 uy:pl-25 uy:pr-25", children: [
17
- /* @__PURE__ */ n("div", { className: "uy:block uy:md:hidden", children: /* @__PURE__ */ n(
18
- c,
19
- {
20
- variant: "ghost",
21
- color: "neutral",
22
- icon: e ? "CloseOutlined" : "ListOutlined",
23
- label: d.formatMessage({
24
- id: e ? "unity:component:app-menu:header:menu-close" : "unity:component:app-menu:header:menu-open",
25
- defaultMessage: e ? "Close navigation" : "Open navigation"
26
- }),
27
- onClick: u,
28
- "aria-expanded": e,
29
- "aria-controls": "app-menu-nav-container app-menu-profile-button"
30
- }
31
- ) }),
32
- /* @__PURE__ */ r("div", { className: "uy:hidden uy:justify-between uy:items-center uy:md:flex", children: [
33
- l({ children: p }),
34
- t
16
+ const { isMobileMenuOpen: n, toggleMobileMenu: p } = x(), d = c(), u = y(), a = f(u);
17
+ return /* @__PURE__ */ o("header", { className: "uy:flex uy:flex-col uy:gap-y-200 uy:pl-25 uy:pr-25", children: [
18
+ /* @__PURE__ */ o("div", { className: "uy:flex uy:items-center", children: [
19
+ /* @__PURE__ */ e("div", { className: "uy:flex-1", children: s({ children: r === "prod" ? /* @__PURE__ */ e(
20
+ b,
21
+ {
22
+ label: i,
23
+ width: a ? 36 : 104,
24
+ showOnlyMonogram: a
25
+ }
26
+ ) : /* @__PURE__ */ e(g, { label: i, env: r }) }) }),
27
+ /* @__PURE__ */ o("div", { className: "uy:flex uy:gap-150", children: [
28
+ t,
29
+ /* @__PURE__ */ e("div", { className: "uy:block uy:md:hidden", children: /* @__PURE__ */ e(
30
+ h,
31
+ {
32
+ variant: "ghost",
33
+ color: "neutral",
34
+ prefixIcon: n ? "CloseOutlined" : "ListOutlined",
35
+ onPress: p,
36
+ "aria-expanded": n,
37
+ "aria-controls": "app-menu-nav-container app-menu-profile-button",
38
+ children: d.formatMessage({
39
+ id: n ? "unity:component:app-menu:header:menu-close" : "unity:component:app-menu:header:menu-open",
40
+ defaultMessage: n ? "Close navigation" : "Open navigation"
41
+ })
42
+ }
43
+ ) })
44
+ ] })
35
45
  ] }),
36
- /* @__PURE__ */ n("div", { className: "uy:hidden uy:md:flex", children: i })
46
+ /* @__PURE__ */ e("div", { className: "uy:hidden uy:md:flex", children: l })
37
47
  ] });
38
48
  };
39
49
  export {
40
- O as AppMenuHeader
50
+ j as AppMenuHeader
41
51
  };
@@ -58,7 +58,7 @@ function G({
58
58
  triggerAriaLabel: o
59
59
  }) {
60
60
  return /* @__PURE__ */ b(R, { className: n, children: [
61
- /* @__PURE__ */ b(T, { children: [
61
+ /* @__PURE__ */ b(T, { placement: "bottom start", children: [
62
62
  /* @__PURE__ */ a(K, { asChild: !0, children: /* @__PURE__ */ a(
63
63
  $,
64
64
  {
@@ -75,7 +75,7 @@ function G({
75
75
  )
76
76
  }
77
77
  ) }),
78
- /* @__PURE__ */ a(H, { width: 248, placement: "bottom start", children: r.map((e) => /* @__PURE__ */ a(
78
+ /* @__PURE__ */ a(H, { width: 248, children: r.map((e) => /* @__PURE__ */ a(
79
79
  L,
80
80
  {
81
81
  ...e.menuItemProps,
@@ -1,6 +1,10 @@
1
1
  import { MenuTriggerProps } from 'react-aria-components/Menu';
2
- type MenuProps = Omit<MenuTriggerProps, 'className' | 'style'>;
3
- export declare function Menu({ defaultOpen, children, ...rest }: MenuProps): import("react/jsx-runtime").JSX.Element;
2
+ import { PopoverProps } from 'react-aria-components/Popover';
3
+ type MenuProps = Omit<MenuTriggerProps, 'className' | 'style'> & {
4
+ placement?: PopoverProps['placement'];
5
+ triggerRef?: PopoverProps['triggerRef'];
6
+ };
7
+ export declare function Menu({ defaultOpen, children, triggerRef, placement, ...rest }: MenuProps): import("react/jsx-runtime").JSX.Element;
4
8
  export declare namespace Menu {
5
9
  var displayName: string;
6
10
  }
@@ -1,7 +1,29 @@
1
- import { jsx as o } from "react/jsx-runtime";
2
- import { MenuTrigger as i } from "react-aria-components/Menu";
3
- function m({ defaultOpen: r, children: e, ...n }) {
4
- return /* @__PURE__ */ o(i, { defaultOpen: r, ...n, children: e });
1
+ import { jsxs as d, jsx as i } from "react/jsx-runtime";
2
+ import y from "react";
3
+ import { MenuTrigger as l, Popover as s } from "react-aria-components/Menu";
4
+ function m({
5
+ defaultOpen: u,
6
+ children: o,
7
+ triggerRef: t,
8
+ placement: n,
9
+ ...a
10
+ }) {
11
+ const [r, e] = y.Children.toArray(o);
12
+ if (!r || !e)
13
+ throw new Error("Menu must have a trigger and a menu content");
14
+ return /* @__PURE__ */ d(l, { defaultOpen: u, ...a, children: [
15
+ r,
16
+ /* @__PURE__ */ i(
17
+ s,
18
+ {
19
+ triggerRef: t,
20
+ placement: n,
21
+ className: "uy:flex uy:flex-col uy:justify-end uy:items-start uy:p-100 uy:rounded-100 uy:border uy:border-solid uy:border-border-neutral uy:bg-surface-neutral uy:shadow-300",
22
+ "data-dd-privacy": "allow",
23
+ children: e
24
+ }
25
+ )
26
+ ] });
5
27
  }
6
28
  m.displayName = "Menu";
7
29
  export {
@@ -1,8 +1,14 @@
1
1
  import { PropsWithChildren } from 'react';
2
2
  import { PopoverProps } from 'react-aria-components/Popover';
3
3
  interface MenuContent {
4
+ /**
5
+ * @deprecated move it to the root Menu component
6
+ */
4
7
  placement?: PopoverProps['placement'];
5
8
  width?: number;
9
+ /**
10
+ * @deprecated move it to the root Menu component
11
+ */
6
12
  triggerRef?: PopoverProps['triggerRef'];
7
13
  }
8
14
  export declare function MenuContent({ children, placement, width, triggerRef, }: PropsWithChildren<MenuContent>): import("react/jsx-runtime").JSX.Element;
@@ -1,24 +1,31 @@
1
1
  import { jsx as e } from "react/jsx-runtime";
2
- import { Popover as a, Menu as y } from "react-aria-components/Menu";
3
- function d({
4
- children: r,
5
- placement: o,
6
- width: u,
7
- triggerRef: t
2
+ import { uyTv as u } from "@payfit/unity-themes";
3
+ import { Menu as o } from "react-aria-components/Menu";
4
+ const m = u({
5
+ base: [
6
+ "uy:outline-none",
7
+ "uy:w-(--uy-menu-content-width) uy:min-w-(--uy-menu-content-min-width)"
8
+ ]
9
+ });
10
+ function i({
11
+ children: t,
12
+ placement: r,
13
+ width: n,
14
+ triggerRef: c
8
15
  }) {
9
- const n = u ? `uy:w-[${u}px] uy:min-w-[${u}px]` : "";
10
16
  return /* @__PURE__ */ e(
11
- a,
17
+ o,
12
18
  {
13
- triggerRef: t,
14
- placement: o,
15
- className: "uy:flex uy:flex-col uy:justify-end uy:items-start uy:p-100 uy:rounded-100 uy:border uy:border-solid uy:border-border-neutral uy:bg-surface-neutral uy:shadow-300",
16
- "data-dd-privacy": "allow",
17
- children: /* @__PURE__ */ e(y, { autoFocus: "first", className: `${u ? "" : "uy:min-w-[320px]"} ${n}`, children: r })
19
+ className: m(),
20
+ style: {
21
+ "--uy-menu-content-width": n ? `${n}px` : "auto",
22
+ "--uy-menu-content-min-width": n ? "" : "calc(var(--uy-spacing) * 40)"
23
+ },
24
+ children: t
18
25
  }
19
26
  );
20
27
  }
21
- d.displayName = "MenuContent";
28
+ i.displayName = "MenuContent";
22
29
  export {
23
- d as MenuContent
30
+ i as MenuContent
24
31
  };
@@ -1,29 +1,37 @@
1
- import { jsxs as s, jsx as y } from "react/jsx-runtime";
2
- import { uyMerge as i } from "@payfit/unity-themes";
3
- import { MenuItem as l } from "react-aria-components/Menu";
1
+ import { jsxs as i, jsx as n } from "react/jsx-runtime";
2
+ import { uyTv as l } from "@payfit/unity-themes";
3
+ import { MenuItem as d } from "react-aria-components/Menu";
4
+ const y = l({
5
+ base: [
6
+ "uy:cursor-pointer",
7
+ "uy:flex uy:p-100 uy:items-start uy:gap-100 uy:rounded-25 uy:typography-body uy:text-content-neutral",
8
+ "uy:not-aria-disabled:data-[hovered=true]:bg-surface-neutral-hover",
9
+ "uy:not-aria-disabled:data-[pressed=true]:bg-surface-neutral-pressed",
10
+ "uy:active:bg-surface-neutral-active",
11
+ "uy:focus-visible:outline-none uy:data-[focus-visible=true]:outline-2 uy:data-[focus-visible=true]:outline-offset-2 uy:data-[focus-visible=true]:outline-utility-focus-ring",
12
+ "uy:aria-disabled:text-content-neutral-disabled uy:aria-disabled:cursor-not-allowed"
13
+ ]
14
+ });
4
15
  function c({
5
16
  prefix: e,
6
- children: u,
7
- href: t,
8
- onAction: r,
9
- className: a,
10
- isDisabled: n,
11
- ...o
17
+ children: t,
18
+ href: u,
19
+ onAction: a,
20
+ className: r,
21
+ isDisabled: o,
22
+ ...s
12
23
  }) {
13
- return /* @__PURE__ */ s(
14
- l,
24
+ return /* @__PURE__ */ i(
25
+ d,
15
26
  {
16
- href: t,
17
- isDisabled: n,
18
- onAction: r,
19
- className: i(
20
- "uy:cursor-pointer uy:flex uy:p-100 uy:items-start uy:gap-100 uy:rounded-25 uy:typography-body uy:text-content-neutral uy:hover:bg-surface-neutral-hover uy:data-[pressed]:bg-surface-neutral-pressed uy:focus-visible:outline-utility-focus-ring uy:active:bg-surface-neutral-active",
21
- a
22
- ),
23
- ...o,
27
+ href: u,
28
+ isDisabled: o,
29
+ onAction: a,
30
+ className: y({ className: r }),
31
+ ...s,
24
32
  children: [
25
- /* @__PURE__ */ y("div", { className: "uy:text-content-neutral-low", children: e || null }),
26
- u
33
+ /* @__PURE__ */ n("div", { className: "uy:text-content-neutral-low", children: e || null }),
34
+ t
27
35
  ]
28
36
  }
29
37
  );
@@ -1,5 +1,5 @@
1
- import { jsxs as s, jsx as t } from "react/jsx-runtime";
2
- import o, { useState as j, useCallback as B, useMemo as D } from "react";
1
+ import { jsxs as r, jsx as t } from "react/jsx-runtime";
2
+ import s, { useState as j, useCallback as B, useMemo as D } from "react";
3
3
  import { uyTv as S } from "@payfit/unity-themes";
4
4
  import { Button as _ } from "react-aria-components/Button";
5
5
  import $ from "../../../hooks/use-id.js";
@@ -8,6 +8,7 @@ import { navItemBase as z } from "./RawNavItem.js";
8
8
  const H = S({
9
9
  extend: z,
10
10
  slots: {
11
+ base: "uy:theme-rebrand:border-1 uy:theme-rebrand:border-solid",
11
12
  caret: "uy:transition-transform uy:duration-150 uy:delay-25 uy:ease-linear motion-reduce:transition-none",
12
13
  contentWrapper: "uy:transition-[max-height] uy:duration-200 uy:ease-linear motion-reduce:transition-none",
13
14
  content: "uy:list-none uy:flex uy:flex-col uy:gap-50 uy:transition-opacity uy:duration-150 uy:delay-25 uy:ease-linear"
@@ -15,6 +16,14 @@ const H = S({
15
16
  variants: {
16
17
  expanded: {
17
18
  true: {
19
+ base: [
20
+ "uy:theme-legacy:bg-surface-neutral-low-active",
21
+ "uy:theme-rebrand:bg-surface-neutral uy:theme-rebrand:border-border-neutral uy:theme-rebrand:shadow-100"
22
+ ],
23
+ prefix: [
24
+ "uy:theme-legacy:text-content-neutral",
25
+ "uy:theme-rebrand:text-content-primary"
26
+ ],
18
27
  caret: "uy:rotate-180",
19
28
  contentWrapper: "uy:max-h-[1000px] uy:overflow-visible",
20
29
  label: "uy:typography-body-strong",
@@ -24,30 +33,31 @@ const H = S({
24
33
  caret: "uy:rotate-0",
25
34
  contentWrapper: "uy:max-h-0 uy:overflow-hidden",
26
35
  content: "uy:opacity-0 uy:invisible uy:pointer-events-none",
27
- label: "uy:typography-body"
36
+ label: "uy:typography-body",
37
+ base: "uy:theme-rebrand:border-transparent"
28
38
  }
29
39
  }
30
40
  }
31
41
  });
32
42
  function M({
33
- children: d,
34
- label: p,
35
- prefix: l,
36
- suffix: y,
37
- defaultExpanded: f = !1,
38
- isExpanded: r,
43
+ children: m,
44
+ label: y,
45
+ prefix: o,
46
+ suffix: p,
47
+ defaultExpanded: b = !1,
48
+ isExpanded: l,
39
49
  onToggle: i,
40
- ...N
50
+ ...f
41
51
  }) {
42
- const u = $(), [x, b] = j(f), n = r !== void 0, a = n ? r : x, C = B(() => {
43
- n || b((e) => !e), i?.(!a);
44
- }, [n, a, i]), h = o.Children.map(d, (e) => o.isValidElement(e) ? o.cloneElement(e, { isDisabled: !a, level: 1 }) : e), c = `${u}-toggle`, m = `${u}-content`, {
52
+ const u = $(), [x, h] = j(b), n = l !== void 0, a = n ? l : x, N = B(() => {
53
+ n || h((e) => !e), i?.(!a);
54
+ }, [n, a, i]), C = s.Children.map(m, (e) => s.isValidElement(e) ? s.cloneElement(e, { isDisabled: !a, level: 1 }) : e), c = `${u}-toggle`, d = `${u}-content`, {
45
55
  baseClassName: v,
46
56
  prefixClassName: g,
47
- labelClassName: I,
48
- suffixClassName: W,
49
- contentClassName: E,
50
- contentWrapperClassName: w,
57
+ labelClassName: w,
58
+ suffixClassName: I,
59
+ contentClassName: W,
60
+ contentWrapperClassName: E,
51
61
  caretClassName: G
52
62
  } = D(() => {
53
63
  const e = H({ level: 0, expanded: a });
@@ -61,21 +71,21 @@ function M({
61
71
  caretClassName: e.caret()
62
72
  };
63
73
  }, [a]);
64
- return /* @__PURE__ */ s("li", { className: "uy:flex uy:flex-col uy:gap-50", children: [
65
- /* @__PURE__ */ s(
74
+ return /* @__PURE__ */ r("li", { className: "uy:flex uy:flex-col uy:gap-50", children: [
75
+ /* @__PURE__ */ r(
66
76
  _,
67
77
  {
68
78
  id: c,
69
79
  className: v,
70
- onPress: C,
80
+ onPress: N,
71
81
  "aria-expanded": a,
72
- "aria-controls": m,
73
- ...N,
82
+ "aria-controls": d,
83
+ ...f,
74
84
  children: [
75
- l && /* @__PURE__ */ t("span", { className: g, children: l({ isExpanded: a }) }),
76
- /* @__PURE__ */ t("span", { className: I, children: p }),
77
- /* @__PURE__ */ s("span", { className: W, role: "presentation", children: [
78
- y,
85
+ o && /* @__PURE__ */ t("span", { className: g, children: o({ isExpanded: a }) }),
86
+ /* @__PURE__ */ t("span", { className: w, children: y }),
87
+ /* @__PURE__ */ r("span", { className: I, role: "presentation", children: [
88
+ p,
79
89
  /* @__PURE__ */ t(
80
90
  k,
81
91
  {
@@ -93,16 +103,16 @@ function M({
93
103
  /* @__PURE__ */ t(
94
104
  "div",
95
105
  {
96
- className: w,
106
+ className: E,
97
107
  style: { maxHeight: a ? 1e3 : 0 },
98
108
  children: /* @__PURE__ */ t(
99
109
  "ul",
100
110
  {
101
- id: m,
102
- className: E,
111
+ id: d,
112
+ className: W,
103
113
  "aria-labelledby": c,
104
114
  "aria-hidden": !a,
105
- children: h
115
+ children: C
106
116
  }
107
117
  )
108
118
  }
@@ -57,8 +57,8 @@ export declare const navItemBase: import('tailwind-variants').TVReturnType<{
57
57
  declare const navItem: import('tailwind-variants').TVReturnType<{
58
58
  isActive: {
59
59
  true: {
60
- base: string;
61
- prefix: string;
60
+ base: string[];
61
+ prefix: string[];
62
62
  label: string;
63
63
  };
64
64
  false: {
@@ -160,8 +160,8 @@ export type NavItemProps = Pick<VariantProps<typeof navItem>, 'level'> & PropsWi
160
160
  export declare const RawNavItem: import('react').ForwardRefExoticComponent<Pick<VariantProps<import('tailwind-variants').TVReturnType<{
161
161
  isActive: {
162
162
  true: {
163
- base: string;
164
- prefix: string;
163
+ base: string[];
164
+ prefix: string[];
165
165
  label: string;
166
166
  };
167
167
  false: {
@@ -1,17 +1,21 @@
1
- import { jsx as u, jsxs as h } from "react/jsx-runtime";
1
+ import { jsx as u, jsxs as N } from "react/jsx-runtime";
2
2
  import { forwardRef as C, useMemo as I } from "react";
3
- import { uyTv as i, uyMerge as j } from "@payfit/unity-themes";
3
+ import { uyTv as y, uyMerge as j } from "@payfit/unity-themes";
4
4
  import { Button as R } from "react-aria-components/Button";
5
5
  import { Link as A } from "react-aria-components/Link";
6
6
  import { useRouter as k } from "../../../providers/router/RouterProvider.js";
7
- const B = i({
7
+ const B = y({
8
8
  slots: {
9
9
  base: [
10
- "uy:group uy:cursor-pointer uy:grid uy:w-full uy:grid-cols-[auto_1fr_auto] uy:items-center uy:py-100 uy:px-150 uy:gap-100 uy:rounded-75 uy:outline-0 uy:transition-all",
11
- "uy:hover:bg-surface-neutral-low-hover uy:active:bg-surface-neutral-low-active uy:data-[pressed]:bg-surface-neutral-low-pressed",
10
+ "uy:group uy:cursor-pointer uy:grid uy:w-full uy:grid-cols-[auto_1fr_auto] uy:items-center uy:py-100 uy:px-150 uy:gap-100 uy:theme-legacy:rounded-75 uy:theme-rebrand:rounded-100 uy:outline-0 uy:transition-all uy:min-h-5.5 uy:md:min-h-auto",
11
+ "uy:bg-transparent uy:theme-rebrand:border-1 uy:theme-rebrand:border-solid uy:theme-rebrand:border-transparent",
12
+ "uy:theme-legacy:data-[hovered]:bg-surface-neutral-low-hover",
13
+ "uy:theme-rebrand:data-[hovered]:bg-surface-neutral-lowest-hover uy:theme-rebrand:data-[hovered]:border-border-neutral-lowest-hover",
14
+ "uy:theme-legacy:active:bg-surface-neutral-low-active uy:theme-legacy:data-[pressed]:bg-surface-neutral-low-pressed",
15
+ "uy:theme-rebrand:active:bg-surface-neutral-lowest-active uy:theme-rebrand:active:border-border-neutral-lowest-pressed uy:theme-rebrand:data-[pressed]:bg-surface-neutral-lowest-pressed uy:theme-rebrand:data-[pressed]:border-border-neutral-lowest-pressed",
12
16
  "uy:focus:outline-0 uy:data-[focus-visible]:outline-none uy:data-[focus-visible]:ring-2 uy:data-[focus-visible]:ring-utility-focus-ring uy:data-[focus-visible]:ring-offset-2"
13
17
  ],
14
- prefix: "uy:p-25 uy:empty:hidden uy:text-content-neutral-low",
18
+ prefix: "uy:theme-legacy:p-25 uy:theme-rebrand:px-25 uy:empty:hidden uy:text-content-neutral-low",
15
19
  suffix: "uy:flex uy:gap-100 uy:items-center uy:text-content-neutral-low uy:justify-self-end uy:text-right uy:empty:hidden",
16
20
  label: [
17
21
  "uy:flex-1 uy:basis-full uy:text-left uy:truncate uy:overflow-hidden uy:whitespace-break-spaces uy:typography-body uy:text-content-neutral"
@@ -30,13 +34,19 @@ const B = i({
30
34
  false: ""
31
35
  }
32
36
  }
33
- }), M = i({
37
+ }), M = y({
34
38
  extend: B,
35
39
  variants: {
36
40
  isActive: {
37
41
  true: {
38
- base: "uy:bg-surface-neutral-low-active",
39
- prefix: "uy:text-content-neutral",
42
+ base: [
43
+ "uy:theme-legacy:bg-surface-neutral-low-active uy:theme-rebrand:data-[level=1]:bg-surface-neutral-lowest-active",
44
+ "uy:theme-rebrand:data-[level=0]:bg-surface-neutral uy:theme-rebrand:data-[level=0]:border-1 uy:theme-rebrand:data-[level=0]:border-solid uy:theme-rebrand:data-[level=0]:border-border-neutral uy:theme-rebrand:data-[level=0]:shadow-100"
45
+ ],
46
+ prefix: [
47
+ "uy:theme-legacy:text-content-neutral",
48
+ "uy:theme-rebrand:text-content-primary"
49
+ ],
40
50
  label: "uy:typography-body-strong"
41
51
  },
42
52
  false: {
@@ -48,53 +58,54 @@ const B = i({
48
58
  }
49
59
  }), _ = C(
50
60
  ({
51
- children: y,
52
- level: r = 0,
61
+ children: d,
62
+ level: s = 0,
53
63
  prefix: l,
54
64
  suffix: n,
55
- onPress: c,
65
+ onPress: i,
56
66
  href: t,
57
- isCurrent: f,
58
- isDisabled: s = !1,
59
- isExact: p = !1,
60
- ...m
61
- }, d) => {
62
- const o = k(), b = t ? A : R, e = o && t ? o.isActive(t, p) : f, {
63
- rawNavItemClassName: v,
64
- labelClassName: x,
67
+ isCurrent: c,
68
+ isDisabled: r = !1,
69
+ isExact: m = !1,
70
+ ...b
71
+ }, p) => {
72
+ const o = k(), f = t ? A : R, e = o && t ? o.isActive(t, m) : c, {
73
+ rawNavItemClassName: h,
74
+ labelClassName: v,
65
75
  prefixClassName: g,
66
- suffixClassName: N
76
+ suffixClassName: x
67
77
  } = I(() => {
68
- const a = M({ level: r, isActive: e, isDisabled: s });
78
+ const a = M({ level: s, isActive: e, isDisabled: r });
69
79
  return {
70
80
  rawNavItemClassName: j(a.base(), a.label()),
71
81
  prefixClassName: a.prefix(),
72
82
  suffixClassName: a.suffix(),
73
83
  labelClassName: a.label()
74
84
  };
75
- }, [e, s, r]), w = Object.assign(
85
+ }, [e, r, s]), w = Object.assign(
76
86
  {},
77
87
  e !== void 0 && {
78
88
  "data-current": e,
79
89
  "aria-current": e ? "page" : void 0
80
90
  },
81
- !t && { tabIndex: s ? -1 : void 0 }
91
+ !t && { tabIndex: r ? -1 : void 0 }
82
92
  );
83
- return /* @__PURE__ */ u("li", { children: /* @__PURE__ */ h(
84
- b,
93
+ return /* @__PURE__ */ u("li", { children: /* @__PURE__ */ N(
94
+ f,
85
95
  {
86
96
  ...w,
87
- ...m,
88
- ref: d,
89
- className: v,
97
+ ...b,
98
+ ref: p,
99
+ className: h,
90
100
  href: t,
91
- onPress: c,
92
- isDisabled: s,
93
- "data-level": r,
101
+ onPress: i,
102
+ isDisabled: r,
103
+ "data-level": s,
104
+ "data-selected": e,
94
105
  children: [
95
106
  l && /* @__PURE__ */ u("span", { className: g, children: l({ isCurrent: e ?? !1 }) }),
96
- /* @__PURE__ */ u("span", { className: x, children: y }),
97
- n && /* @__PURE__ */ u("span", { className: N, children: n })
107
+ /* @__PURE__ */ u("span", { className: v, children: d }),
108
+ n && /* @__PURE__ */ u("span", { className: x, children: n })
98
109
  ]
99
110
  }
100
111
  ) });
@@ -3,8 +3,8 @@ import { SwitchProps as AriaSwitchProps } from 'react-aria-components/Switch';
3
3
  export declare const toggleSwitch: import('tailwind-variants').TVReturnType<{
4
4
  isDisabled: {
5
5
  false: {
6
- indicator: string;
7
- knob: string;
6
+ indicator: string[];
7
+ knob: string[];
8
8
  };
9
9
  true: {
10
10
  indicator: string;
@@ -22,8 +22,8 @@ export declare const toggleSwitch: import('tailwind-variants').TVReturnType<{
22
22
  }, undefined, {
23
23
  isDisabled: {
24
24
  false: {
25
- indicator: string;
26
- knob: string;
25
+ indicator: string[];
26
+ knob: string[];
27
27
  };
28
28
  true: {
29
29
  indicator: string;
@@ -41,8 +41,8 @@ export declare const toggleSwitch: import('tailwind-variants').TVReturnType<{
41
41
  }, import('tailwind-variants').TVReturnType<{
42
42
  isDisabled: {
43
43
  false: {
44
- indicator: string;
45
- knob: string;
44
+ indicator: string[];
45
+ knob: string[];
46
46
  };
47
47
  true: {
48
48
  indicator: string;
@@ -1,7 +1,7 @@
1
1
  import { jsx as e, jsxs as a } from "react/jsx-runtime";
2
2
  import { forwardRef as h } from "react";
3
3
  import { uyTv as v } from "@payfit/unity-themes";
4
- import { Switch as b } from "react-aria-components/Switch";
4
+ import { Switch as m } from "react-aria-components/Switch";
5
5
  import { useBreakpointListener as w } from "../../hooks/use-breakpoint-listener.js";
6
6
  const x = v({
7
7
  slots: {
@@ -35,8 +35,19 @@ const x = v({
35
35
  variants: {
36
36
  isDisabled: {
37
37
  false: {
38
- indicator: 'uy:group-data-[selected="true"]:bg-surface-form-active uy:group-data-[selected="true"]:border-border-form-active uy:group-data-[selected="true"]:group-data-[pressed]:bg-surface-form-active uy:group-data-[selected="true"]:group-data-[pressed]:border-border-form-active',
39
- knob: 'uy:group-data-[selected="true"]:border-border-inverted-enabled uy:group-data-[selected="true"]:group-data-[pressed]:bg-surface-form-pressed uy:group-data-[selected="true"]:group-data-[pressed]:border-border-inverted-pressed'
38
+ indicator: [
39
+ 'uy:theme-legacy:group-data-[selected="true"]:bg-surface-form-active uy:theme-legacy:group-data-[selected="true"]:border-border-form-active',
40
+ 'uy:theme-rebrand:group-data-[selected="true"]:bg-surface-form-active uy:theme-rebrand:group-data-[selected="true"]:border-surface-form-active',
41
+ 'uy:theme-legacy:group-data-[selected="true"]:group-data-[pressed]:bg-surface-form-active',
42
+ 'uy:theme-legacy:group-data-[selected="true"]:group-data-[pressed]:border-border-form-active',
43
+ 'uy:theme-rebrand:group-data-[selected="true"]:group-data-[pressed]:bg-surface-primary-active',
44
+ 'uy:theme-rebrand:group-data-[selected="true"]:group-data-[pressed]:border-border-primary-active'
45
+ ],
46
+ knob: [
47
+ "uy:theme-legacy:group-data-[selected=true]:border-border-inverted-enabled uy:theme-rebrand:group-data-[selected=true]:border-transparent",
48
+ "uy:group-data-[selected=true]:group-data-[pressed]:bg-surface-form-pressed",
49
+ "uy:group-data-[selected=true]:group-data-[pressed]:border-border-inverted-pressed"
50
+ ]
40
51
  },
41
52
  true: {
42
53
  indicator: "",
@@ -46,39 +57,39 @@ const x = v({
46
57
  }
47
58
  }), N = h(
48
59
  ({
49
- label: o,
60
+ label: u,
50
61
  helperText: r,
51
- isLabelSrOnly: s = !1,
62
+ isLabelSrOnly: o = !1,
52
63
  isDisabled: d,
53
- ...m
54
- }, u) => {
64
+ ...b
65
+ }, s) => {
55
66
  const {
56
67
  container: t,
57
68
  indicator: i,
58
69
  knob: l,
59
70
  textWrapper: y,
60
71
  label: c,
61
- hintText: n,
62
- mobileContainer: f
63
- } = x({ isDisabled: d }), g = w() === "xs", p = { ...m, role: "switch" };
64
- return g ? /* @__PURE__ */ e(
65
- b,
72
+ hintText: p,
73
+ mobileContainer: g
74
+ } = x({ isDisabled: d }), f = w() === "xs", n = { ...b, role: "switch" };
75
+ return f ? /* @__PURE__ */ e(
76
+ m,
66
77
  {
67
- ...p,
68
- ref: u,
78
+ ...n,
79
+ ref: s,
69
80
  className: t(),
70
81
  isDisabled: d,
71
- children: /* @__PURE__ */ a("div", { className: f(), children: [
82
+ children: /* @__PURE__ */ a("div", { className: g(), children: [
72
83
  /* @__PURE__ */ a(
73
84
  "div",
74
85
  {
75
86
  className: y({
76
- className: s ? "uy:sr-only" : ""
87
+ className: o ? "uy:sr-only" : ""
77
88
  }),
78
89
  "data-dd-privacy": "allow",
79
90
  children: [
80
- /* @__PURE__ */ e("span", { className: c(), children: o }),
81
- r && /* @__PURE__ */ e("span", { className: n(), children: r })
91
+ /* @__PURE__ */ e("span", { className: c(), children: u }),
92
+ r && /* @__PURE__ */ e("span", { className: p(), children: r })
82
93
  ]
83
94
  }
84
95
  ),
@@ -86,10 +97,10 @@ const x = v({
86
97
  ] })
87
98
  }
88
99
  ) : /* @__PURE__ */ a(
89
- b,
100
+ m,
90
101
  {
91
- ...p,
92
- ref: u,
102
+ ...n,
103
+ ref: s,
93
104
  className: t(),
94
105
  isDisabled: d,
95
106
  children: [
@@ -98,12 +109,12 @@ const x = v({
98
109
  "div",
99
110
  {
100
111
  className: y({
101
- className: s ? "uy:sr-only" : ""
112
+ className: o ? "uy:sr-only" : ""
102
113
  }),
103
114
  "data-dd-privacy": "allow",
104
115
  children: [
105
- /* @__PURE__ */ e("span", { className: c(), children: o }),
106
- r && /* @__PURE__ */ e("span", { className: n(), children: r })
116
+ /* @__PURE__ */ e("span", { className: c(), children: u }),
117
+ r && /* @__PURE__ */ e("span", { className: p(), children: r })
107
118
  ]
108
119
  }
109
120
  )
package/i18n/en-GB.json CHANGED
@@ -15,8 +15,8 @@
15
15
  "unity:component:action-bar:key-shortcuts-text": "Use {keyShortcuts} to focus the action bar",
16
16
  "unity:component:action-bar:clear-selection-button": "Clear selection",
17
17
  "unity:component:action-bar:group:label": "Selection information",
18
- "unity:component:app-menu:header:menu-open": "Open navigation",
19
- "unity:component:app-menu:header:menu-close": "Close navigation",
18
+ "unity:component:app-menu:header:menu-open": "Menu",
19
+ "unity:component:app-menu:header:menu-close": "Close",
20
20
  "unity:component:app-menu:footer:profile-button:description": "Press this button to open the profile menu.",
21
21
  "unity:component:app-menu:footer:profile-button:avatar:change": "Change profile picture",
22
22
  "unity:component:app-menu:footer:profile-button:avatar:change-description": "Press enter to change profile picture",
package/i18n/es-ES.json CHANGED
@@ -15,8 +15,8 @@
15
15
  "unity:component:action-bar:key-shortcuts-text": "Use {keyShortcuts} para enfocar la barra de acciones",
16
16
  "unity:component:action-bar:clear-selection-button": "Borrar selección",
17
17
  "unity:component:action-bar:group:label": "Información de selección",
18
- "unity:component:app-menu:header:menu-open": "Abrir navegación",
19
- "unity:component:app-menu:header:menu-close": "Cerrar navegación",
18
+ "unity:component:app-menu:header:menu-open": "Menú",
19
+ "unity:component:app-menu:header:menu-close": "Cerrar",
20
20
  "unity:component:app-menu:footer:profile-button:description": "Presione este botón para abrir el menú de perfil.",
21
21
  "unity:component:app-menu:footer:profile-button:avatar:change": "Cambiar foto de perfil",
22
22
  "unity:component:app-menu:footer:profile-button:avatar:change-description": "Presione enter para cambiar la foto de perfil",
package/i18n/fr-FR.json CHANGED
@@ -15,8 +15,8 @@
15
15
  "unity:component:action-bar:key-shortcuts-text": "Appuyez sur {keyShortcuts} pour accéder à la barre d'actions",
16
16
  "unity:component:action-bar:clear-selection-button": "Effacer la sélection",
17
17
  "unity:component:action-bar:group:label": "Informations de sélection",
18
- "unity:component:app-menu:header:menu-open": "Ouvrir la navigation",
19
- "unity:component:app-menu:header:menu-close": "Fermer la navigation",
18
+ "unity:component:app-menu:header:menu-open": "Menu",
19
+ "unity:component:app-menu:header:menu-close": "Fermer",
20
20
  "unity:component:app-menu:footer:profile-button:description": "Appuyez sur ce bouton pour ouvrir le menu du profil.",
21
21
  "unity:component:app-menu:footer:profile-button:avatar:change": "Changer la photo de profil",
22
22
  "unity:component:app-menu:footer:profile-button:avatar:change-description": "Appuyez sur Entrée pour modifier la photo de profil",
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@payfit/unity-components",
3
- "version": "2.29.12",
3
+ "version": "2.31.1",
4
4
  "module": "./dist/esm/index.js",
5
5
  "type": "module",
6
6
  "sideEffects": false,
@@ -42,7 +42,7 @@
42
42
  "@hookform/devtools": "4.4.0",
43
43
  "@hookform/resolvers": "5.2.1",
44
44
  "@internationalized/date": "3.12.1",
45
- "@payfit/unity-illustrations": "2.29.12",
45
+ "@payfit/unity-illustrations": "2.31.1",
46
46
  "@radix-ui/react-avatar": "1.1.11",
47
47
  "@radix-ui/react-slot": "1.2.4",
48
48
  "@react-aria/interactions": "3.28.0",
@@ -74,8 +74,8 @@
74
74
  },
75
75
  "peerDependencies": {
76
76
  "@hookform/devtools": "^4",
77
- "@payfit/unity-icons": "2.29.12",
78
- "@payfit/unity-themes": "2.29.12",
77
+ "@payfit/unity-icons": "2.31.1",
78
+ "@payfit/unity-themes": "2.31.1",
79
79
  "@storybook/react-vite": "^10.3.2",
80
80
  "@tanstack/react-query": "^5",
81
81
  "@tanstack/react-router": "^1.131",
@@ -89,9 +89,9 @@
89
89
  "@figma/code-connect": "1.4.3",
90
90
  "@hookform/devtools": "4.4.0",
91
91
  "@internationalized/date": "3.12.1",
92
- "@payfit/unity-icons": "2.29.12",
93
- "@payfit/unity-illustrations": "2.29.12",
94
- "@payfit/unity-themes": "2.29.12",
92
+ "@payfit/unity-icons": "2.31.1",
93
+ "@payfit/unity-illustrations": "2.31.1",
94
+ "@payfit/unity-themes": "2.31.1",
95
95
  "@storybook/addon-a11y": "10.3.5",
96
96
  "@storybook/addon-designs": "11.1.3",
97
97
  "@storybook/addon-docs": "10.3.5",