@westpac/ui 0.47.0 → 0.48.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (36) hide show
  1. package/CHANGELOG.md +18 -0
  2. package/dist/component-type.json +1 -1
  3. package/dist/components/accordion/accordion.component.js +4 -4
  4. package/dist/components/accordion/accordion.styles.d.ts +9 -0
  5. package/dist/components/accordion/accordion.styles.js +4 -1
  6. package/dist/components/accordion/components/accordion-item/accordion-item.component.d.ts +1 -1
  7. package/dist/components/accordion/components/accordion-item/accordion-item.component.js +7 -3
  8. package/dist/components/accordion/components/accordion-item/accordion-item.styles.d.ts +15 -0
  9. package/dist/components/accordion/components/accordion-item/accordion-item.styles.js +27 -5
  10. package/dist/components/accordion/components/accordion-item/accordion-item.types.d.ts +5 -0
  11. package/dist/components/alert/alert.styles.js +1 -1
  12. package/dist/components/field/field.component.js +1 -1
  13. package/dist/components/header/header.component.d.ts +1 -1
  14. package/dist/components/header/header.component.js +6 -2
  15. package/dist/components/header/header.types.d.ts +11 -1
  16. package/dist/components/modal/components/modal-backdrop/modal-backdrop.component.js +3 -2
  17. package/dist/components/modal/components/modal-backdrop/modal-backdrop.styles.js +1 -1
  18. package/dist/components/modal/modal.component.d.ts +1 -1
  19. package/dist/components/modal/modal.component.js +2 -1
  20. package/dist/components/modal/modal.types.d.ts +4 -0
  21. package/dist/css/westpac-ui.css +90 -40
  22. package/dist/css/westpac-ui.min.css +90 -40
  23. package/package.json +3 -3
  24. package/src/components/accordion/accordion.component.tsx +3 -3
  25. package/src/components/accordion/accordion.styles.ts +4 -1
  26. package/src/components/accordion/components/accordion-item/accordion-item.component.tsx +12 -2
  27. package/src/components/accordion/components/accordion-item/accordion-item.styles.ts +15 -6
  28. package/src/components/accordion/components/accordion-item/accordion-item.types.ts +6 -0
  29. package/src/components/alert/alert.styles.ts +1 -1
  30. package/src/components/field/field.component.tsx +5 -3
  31. package/src/components/header/header.component.tsx +4 -2
  32. package/src/components/header/header.types.ts +11 -1
  33. package/src/components/modal/components/modal-backdrop/modal-backdrop.component.tsx +2 -3
  34. package/src/components/modal/components/modal-backdrop/modal-backdrop.styles.ts +1 -1
  35. package/src/components/modal/modal.component.tsx +12 -2
  36. package/src/components/modal/modal.types.ts +4 -0
@@ -32,15 +32,15 @@ function Accordion({ className, rounded = true, look = 'soft', ...props }, ref)
32
32
  ref: domRef,
33
33
  className: styles({
34
34
  className,
35
- rounded
35
+ rounded,
36
+ lego: look === 'lego'
36
37
  })
37
- }, React.createElement("div", {
38
- className: "-ml-px -mt-px"
39
- }, [
38
+ }, React.createElement("div", null, [
40
39
  ...state.collection
41
40
  ].map((item)=>React.createElement(AccordionItemContent, {
42
41
  key: item.key,
43
42
  item: item,
43
+ rounded: rounded,
44
44
  state: state,
45
45
  look: look
46
46
  }))));
@@ -2,16 +2,25 @@ export declare const styles: import("tailwind-variants").TVReturnType<{
2
2
  rounded: {
3
3
  true: string;
4
4
  };
5
+ lego: {
6
+ true: string;
7
+ };
5
8
  }, undefined, "flex flex-col border border-border text-text", {
6
9
  responsiveVariants: string[];
7
10
  }, {
8
11
  rounded: {
9
12
  true: string;
10
13
  };
14
+ lego: {
15
+ true: string;
16
+ };
11
17
  }, undefined, import("tailwind-variants").TVReturnType<{
12
18
  rounded: {
13
19
  true: string;
14
20
  };
21
+ lego: {
22
+ true: string;
23
+ };
15
24
  }, undefined, "flex flex-col border border-border text-text", {
16
25
  responsiveVariants: string[];
17
26
  }, unknown, unknown, undefined>>;
@@ -3,7 +3,10 @@ export const styles = tv({
3
3
  base: 'flex flex-col border border-border text-text',
4
4
  variants: {
5
5
  rounded: {
6
- true: 'overflow-hidden rounded'
6
+ true: 'rounded'
7
+ },
8
+ lego: {
9
+ true: 'border-0 border-b'
7
10
  }
8
11
  }
9
12
  }, {
@@ -1,2 +1,2 @@
1
1
  import { type AccordionItemProps } from './accordion-item.types.js';
2
- export declare function AccordionItem<T = HTMLElement>({ className, tag: Tag, look, ...props }: AccordionItemProps<T>): import("react/jsx-runtime").JSX.Element;
2
+ export declare function AccordionItem<T = HTMLElement>({ className, tag: Tag, look, rounded, ...props }: AccordionItemProps<T>): import("react/jsx-runtime").JSX.Element;
@@ -5,7 +5,7 @@ import { mergeProps, useFocusRing, useHover, useLocale } from 'react-aria';
5
5
  import { ArrowLeftIcon, ArrowRightIcon } from '../../../icon/index.js';
6
6
  import { styles as accordionItemStyles } from './accordion-item.styles.js';
7
7
  const loadAnimations = ()=>import('./accordion-item.utils.js').then((res)=>res.default);
8
- export function AccordionItem({ className, tag: Tag = 'div', look = 'soft', ...props }) {
8
+ export function AccordionItem({ className, tag: Tag = 'div', look = 'soft', rounded = true, ...props }) {
9
9
  const ref = useRef(null);
10
10
  const { state, item } = props;
11
11
  const { buttonProps, regionProps } = useAccordionItem(props, state, ref);
@@ -20,7 +20,8 @@ export function AccordionItem({ className, tag: Tag = 'div', look = 'soft', ...p
20
20
  isOpen,
21
21
  isDisabled,
22
22
  look,
23
- isFocusVisible
23
+ isFocusVisible,
24
+ rounded
24
25
  });
25
26
  return React.createElement(Tag, {
26
27
  className: styles.base({
@@ -63,6 +64,9 @@ export function AccordionItem({ className, tag: Tag = 'div', look = 'soft', ...p
63
64
  ]
64
65
  }
65
66
  }, React.createElement("div", {
66
- className: styles.content()
67
+ className: styles.content(),
68
+ onBlur: (e)=>{
69
+ e.stopPropagation();
70
+ }
67
71
  }, item.props.children))))));
68
72
  }
@@ -28,6 +28,11 @@ export declare const styles: import("tailwind-variants").TVReturnType<{
28
28
  itemHeader: string;
29
29
  };
30
30
  };
31
+ rounded: {
32
+ true: {
33
+ itemHeader: string;
34
+ };
35
+ };
31
36
  }, {
32
37
  base: string;
33
38
  itemHeader: string;
@@ -66,6 +71,11 @@ export declare const styles: import("tailwind-variants").TVReturnType<{
66
71
  itemHeader: string;
67
72
  };
68
73
  };
74
+ rounded: {
75
+ true: {
76
+ itemHeader: string;
77
+ };
78
+ };
69
79
  }, {
70
80
  base: string;
71
81
  itemHeader: string;
@@ -102,6 +112,11 @@ export declare const styles: import("tailwind-variants").TVReturnType<{
102
112
  itemHeader: string;
103
113
  };
104
114
  };
115
+ rounded: {
116
+ true: {
117
+ itemHeader: string;
118
+ };
119
+ };
105
120
  }, {
106
121
  base: string;
107
122
  itemHeader: string;
@@ -1,8 +1,8 @@
1
1
  import { tv } from 'tailwind-variants';
2
2
  export const styles = tv({
3
3
  slots: {
4
- base: 'relative',
5
- itemHeader: 'typography-body-9 flex w-full flex-1 items-center justify-between px-3 py-2',
4
+ base: 'group',
5
+ itemHeader: 'typography-body-9 flex w-full flex-1 items-center justify-between px-3 py-2 group-first:border-t-0',
6
6
  headerTitleWrapper: 'flex-1 pr-2 text-left',
7
7
  indicator: 'size-3 rotate-90',
8
8
  content: 'hidden'
@@ -13,12 +13,12 @@ export const styles = tv({
13
13
  itemHeader: 'border-t border-border bg-light'
14
14
  },
15
15
  lego: {
16
- itemHeader: 'border-l-[0.375rem] border-border bg-light shadow-[inset_0_1px_0_var(--tw-shadow-color)] !shadow-border transition-colors'
16
+ itemHeader: 'mb-[-1px] border-l-[0.375rem] border-r border-border bg-light shadow-[inset_0px_1px_0_0_var(--tw-shadow-color),inset_0_-1px_0_0_var(--tw-shadow-color)] !shadow-border transition-colors'
17
17
  }
18
18
  },
19
19
  isOpen: {
20
20
  true: {
21
- content: 'block border-t border-border p-3'
21
+ content: 'block border-border p-3'
22
22
  },
23
23
  false: {
24
24
  base: '',
@@ -36,6 +36,11 @@ export const styles = tv({
36
36
  false: {
37
37
  itemHeader: 'outline-none'
38
38
  }
39
+ },
40
+ rounded: {
41
+ true: {
42
+ itemHeader: 'group-first:rounded-t-sm group-last:rounded-b-sm'
43
+ }
39
44
  }
40
45
  },
41
46
  compoundSlots: [
@@ -58,8 +63,25 @@ export const styles = tv({
58
63
  slots: [
59
64
  'content'
60
65
  ],
66
+ look: 'soft',
67
+ isOpen: true,
68
+ className: 'border-t'
69
+ },
70
+ {
71
+ slots: [
72
+ 'itemHeader'
73
+ ],
74
+ isOpen: true,
75
+ rounded: true,
76
+ className: 'group-last:rounded-none'
77
+ },
78
+ {
79
+ slots: [
80
+ 'content'
81
+ ],
82
+ isOpen: true,
61
83
  look: 'lego',
62
- className: 'border-l-[0.375rem] border-l-border'
84
+ className: 'mt-[1px] border-l-[0.375rem] border-r'
63
85
  }
64
86
  ]
65
87
  }, {
@@ -1,6 +1,7 @@
1
1
  import { HTMLAttributes, ReactNode } from 'react';
2
2
  import { Node, TreeState } from 'react-stately';
3
3
  import { type VariantProps } from 'tailwind-variants';
4
+ import { AccordionProps } from '../../accordion.types.js';
4
5
  import { styles } from './accordion-item.styles.js';
5
6
  type Variants = VariantProps<typeof styles>;
6
7
  export type AccordionItemProps<T = HTMLElement> = {
@@ -16,6 +17,10 @@ export type AccordionItemProps<T = HTMLElement> = {
16
17
  * Look of the item
17
18
  */
18
19
  look?: Variants['look'];
20
+ /**
21
+ * Whether accordion is rounded
22
+ */
23
+ rounded?: AccordionProps['rounded'];
19
24
  /**
20
25
  * Tree state
21
26
  */
@@ -1,7 +1,7 @@
1
1
  import { tv } from 'tailwind-variants';
2
2
  export const styles = tv({
3
3
  slots: {
4
- base: 'typography-body-10 relative mb-4 xsl:flex',
4
+ base: 'typography-body-10 relative mb-5 xsl:flex',
5
5
  icon: 'float-left flex-none',
6
6
  body: 'relative flex-1 overflow-hidden xsl:top-[0.125rem] [&_a]:underline',
7
7
  heading: 'typography-body-9 mb-1 font-bold',
@@ -26,7 +26,7 @@ export function Field({ className, label, tag: Tag = 'div', children, hintMessag
26
26
  className
27
27
  }),
28
28
  ...props
29
- }, React.createElement(Label, {
29
+ }, label && React.createElement(Label, {
30
30
  size: labelSize,
31
31
  ...labelProps
32
32
  }, label), hintMessage && React.createElement(Hint, descriptionProps, hintMessage), errorMessage && React.createElement(ErrorMessage, {
@@ -1,2 +1,2 @@
1
1
  import { type HeaderProps } from './header.types.js';
2
- export declare function Header({ brand, className, children, fixed, isScrolled, leftIcon, leftOnClick, leftAssistiveText, logoAssistiveText, logoLink, logoCenter, logoOnClick, skipLinkContent, skipToContentId, ...props }: HeaderProps): import("react/jsx-runtime").JSX.Element;
2
+ export declare function Header({ anchorTarget, brand, className, children, fixed, fixedMaxWidth, isScrolled, leftIcon, leftOnClick, leftAssistiveText, logoAssistiveText, logoLink, logoCenter, logoOnClick, skipLinkContent, skipToContentId, ...props }: HeaderProps): import("react/jsx-runtime").JSX.Element;
@@ -31,7 +31,7 @@ const logoMap = {
31
31
  largeLogo: (props)=>React.createElement(RAMSMultibrandLargeLogo, props)
32
32
  }
33
33
  };
34
- export function Header({ brand, className, children, fixed = false, isScrolled, leftIcon, leftOnClick, leftAssistiveText, logoAssistiveText, logoLink = '#', logoCenter = false, logoOnClick, skipLinkContent = 'Skip to main content', skipToContentId, ...props }) {
34
+ export function Header({ anchorTarget, brand, className, children, fixed = false, fixedMaxWidth, isScrolled, leftIcon, leftOnClick, leftAssistiveText, logoAssistiveText, logoLink = '#', logoCenter = false, logoOnClick, skipLinkContent = 'Skip to main content', skipToContentId, ...props }) {
35
35
  const [scrolled, setScrolled] = useState(false);
36
36
  const handleScroll = throttle(()=>{
37
37
  let hasScrolled = false;
@@ -65,7 +65,10 @@ export function Header({ brand, className, children, fixed = false, isScrolled,
65
65
  }),
66
66
  ...props
67
67
  }, React.createElement("div", {
68
- className: styles.inner()
68
+ className: styles.inner(),
69
+ style: {
70
+ maxWidth: fixed ? fixedMaxWidth : undefined
71
+ }
69
72
  }, skipToContentId && React.createElement(SkipLink, {
70
73
  href: skipToContentId
71
74
  }, skipLinkContent), leftIcon && React.createElement("div", {
@@ -80,6 +83,7 @@ export function Header({ brand, className, children, fixed = false, isScrolled,
80
83
  iconColor: "text"
81
84
  })), React.createElement("a", {
82
85
  href: logoLink,
86
+ target: anchorTarget,
83
87
  className: styles.logoLink(),
84
88
  onClick: logoOnClick
85
89
  }, React.createElement(SmallLogo, {
@@ -1,6 +1,11 @@
1
- import { HTMLAttributes } from 'react';
1
+ import { Property } from 'csstype';
2
+ import { HTMLAttributeAnchorTarget, HTMLAttributes } from 'react';
2
3
  import { BrandKey } from '../../tailwind/index.js';
3
4
  export type HeaderProps = {
5
+ /**
6
+ * Target for the logo link
7
+ */
8
+ anchorTarget?: HTMLAttributeAnchorTarget;
4
9
  /**
5
10
  * Icon for brand
6
11
  */
@@ -9,6 +14,11 @@ export type HeaderProps = {
9
14
  * Enable fixed header
10
15
  */
11
16
  fixed?: boolean;
17
+ /**
18
+ * Set max width for fixed header for certain layouts
19
+ * NOTE: Using max-w in classname will work for non-fixed headers
20
+ */
21
+ fixedMaxWidth?: Property.MaxWidth;
12
22
  /**
13
23
  * Used with fixed to show drop shadow when something on screen is scrolled that should trigger drop shadow but doesn't
14
24
  */
@@ -6,7 +6,6 @@ export function ModalBackdrop({ zIndex = 100, portalContainer, size, ...props })
6
6
  const { children, state, className } = props;
7
7
  const ref = useRef(null);
8
8
  const styles = backdropStyles({
9
- className,
10
9
  fullscreen: size === 'full',
11
10
  fluid: size === 'fluid'
12
11
  });
@@ -22,10 +21,12 @@ export function ModalBackdrop({ zIndex = 100, portalContainer, size, ...props })
22
21
  return React.createElement(Overlay, {
23
22
  portalContainer: portalContainer || brandContainer
24
23
  }, React.createElement("div", {
24
+ className: styles.base({
25
+ className
26
+ }),
25
27
  style: {
26
28
  zIndex
27
29
  },
28
- className: styles.base(),
29
30
  ...underlayProps
30
31
  }, React.createElement("div", {
31
32
  ...modalProps,
@@ -1,7 +1,7 @@
1
1
  import { tv } from 'tailwind-variants';
2
2
  export const styles = tv({
3
3
  slots: {
4
- base: 'fixed inset-0 z-50 flex animate-fadeIn items-center justify-center overflow-y-auto bg-black/50 p-2',
4
+ base: 'fixed inset-0 flex animate-fadeIn items-center justify-center overflow-y-auto bg-black/50 p-2',
5
5
  modal: 'relative top-3 z-10 h-fit w-full animate-fadeInDown'
6
6
  },
7
7
  variants: {
@@ -1,2 +1,2 @@
1
1
  import { type ModalProps } from './modal.types.js';
2
- export declare function Modal({ children, title, role, body, size, className, fullscreen, ...props }: ModalProps): import("react/jsx-runtime").JSX.Element;
2
+ export declare function Modal({ children, backdropStyle, title, role, body, size, className, fullscreen, ...props }: ModalProps): import("react/jsx-runtime").JSX.Element;
@@ -1,9 +1,10 @@
1
1
  'use client';
2
2
  import React from 'react';
3
3
  import { ModalBackdrop, ModalDialog } from './components/index.js';
4
- export function Modal({ children, title, role, body, size, className, fullscreen, ...props }) {
4
+ export function Modal({ children, backdropStyle, title, role, body, size, className, fullscreen, ...props }) {
5
5
  return React.createElement(ModalBackdrop, {
6
6
  size: size,
7
+ className: backdropStyle,
7
8
  ...props
8
9
  }, React.createElement(ModalDialog, {
9
10
  fullscreen: fullscreen,
@@ -1,5 +1,9 @@
1
1
  import { type ModalBackdropProps, ModalDialogProps } from './components/index.js';
2
2
  export type ModalProps = {
3
+ /**
4
+ * Provide inset styles for the backdrop for centering in certain containers
5
+ */
6
+ backdropStyle?: string;
3
7
  /**
4
8
  * Whether the modal is fullscreen
5
9
  */
@@ -3356,9 +3356,6 @@ body {
3356
3356
  .z-10 {
3357
3357
  z-index: 10;
3358
3358
  }
3359
- .z-50 {
3360
- z-index: 50;
3361
- }
3362
3359
  .z-\[999\] {
3363
3360
  z-index: 999;
3364
3361
  }
@@ -3620,6 +3617,9 @@ body {
3620
3617
  .mt-\[0\.875rem\] {
3621
3618
  margin-top: 0.875rem;
3622
3619
  }
3620
+ .mt-\[1px\] {
3621
+ margin-top: 1px;
3622
+ }
3623
3623
  .mt-\[200px\] {
3624
3624
  margin-top: 200px;
3625
3625
  }
@@ -4655,10 +4655,6 @@ body {
4655
4655
  --tw-border-opacity: 1;
4656
4656
  border-bottom-color: rgb(255 255 255 / var(--tw-border-opacity, 1));
4657
4657
  }
4658
- .border-l-border {
4659
- --tw-border-opacity: 1;
4660
- border-left-color: rgba(var(--colors-border), var(--tw-border-opacity, 1));
4661
- }
4662
4658
  .border-l-hero {
4663
4659
  --tw-border-opacity: 1;
4664
4660
  border-left-color: rgba(var(--colors-hero), var(--tw-border-opacity, 1));
@@ -6287,9 +6283,9 @@ body {
6287
6283
  --tw-shadow-colored: 0 5px 10px var(--tw-shadow-color);
6288
6284
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
6289
6285
  }
6290
- .shadow-\[inset_0_1px_0_var\(--tw-shadow-color\)\] {
6291
- --tw-shadow: inset 0 1px 0 var(--tw-shadow-color);
6292
- --tw-shadow-colored: inset 0 1px 0 var(--tw-shadow-color);
6286
+ .shadow-\[inset_0px_1px_0_0_var\(--tw-shadow-color\)\2c inset_0_-1px_0_0_var\(--tw-shadow-color\)\] {
6287
+ --tw-shadow: inset 0px 1px 0 0 var(--tw-shadow-color),inset 0 -1px 0 0 var(--tw-shadow-color);
6288
+ --tw-shadow-colored: inset 0px 1px 0 0 var(--tw-shadow-color), inset 0 -1px 0 0 var(--tw-shadow-color);
6293
6289
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
6294
6290
  }
6295
6291
  .shadow-lg {
@@ -8190,10 +8186,17 @@ body {
8190
8186
  border-top-left-radius: 0.1875rem;
8191
8187
  border-bottom-left-radius: 0.1875rem;
8192
8188
  }
8189
+ .group:first-child .group-first\:rounded-t-sm {
8190
+ border-top-left-radius: 0.125rem;
8191
+ border-top-right-radius: 0.125rem;
8192
+ }
8193
8193
  .group\/add-on-before:first-child .group-first\/add-on-before\:\!border-x {
8194
8194
  border-left-width: 1px !important;
8195
8195
  border-right-width: 1px !important;
8196
8196
  }
8197
+ .group:first-child .group-first\:border-t-0 {
8198
+ border-top-width: 0px;
8199
+ }
8197
8200
  .group\/panel:first-child .group-first\/panel\:px-4 {
8198
8201
  padding-left: 1.5rem;
8199
8202
  padding-right: 1.5rem;
@@ -8201,6 +8204,9 @@ body {
8201
8204
  .group\/panel:first-child .group-first\/panel\:pt-4 {
8202
8205
  padding-top: 1.5rem;
8203
8206
  }
8207
+ .group:last-child .group-last\:rounded-none {
8208
+ border-radius: 0px;
8209
+ }
8204
8210
  .group\/add-on-after:last-child .group-last\/add-on-after\:\!rounded-r {
8205
8211
  border-top-right-radius: 0.1875rem !important;
8206
8212
  border-bottom-right-radius: 0.1875rem !important;
@@ -8213,6 +8219,10 @@ body {
8213
8219
  border-top-right-radius: 0.1875rem;
8214
8220
  border-bottom-right-radius: 0.1875rem;
8215
8221
  }
8222
+ .group:last-child .group-last\:rounded-b-sm {
8223
+ border-bottom-right-radius: 0.125rem;
8224
+ border-bottom-left-radius: 0.125rem;
8225
+ }
8216
8226
  .group\/add-on-after:last-child .group-last\/add-on-after\:\!border-x {
8217
8227
  border-left-width: 1px !important;
8218
8228
  border-right-width: 1px !important;
@@ -9014,9 +9024,6 @@ body {
9014
9024
  .xsl\:self-center {
9015
9025
  align-self: center;
9016
9026
  }
9017
- .xsl\:overflow-hidden {
9018
- overflow: hidden;
9019
- }
9020
9027
  .xsl\:truncate {
9021
9028
  overflow: hidden;
9022
9029
  text-overflow: ellipsis;
@@ -9111,6 +9118,9 @@ body {
9111
9118
  .xsl\:border-l-\[6px\] {
9112
9119
  border-left-width: 6px;
9113
9120
  }
9121
+ .xsl\:border-r {
9122
+ border-right-width: 1px;
9123
+ }
9114
9124
  .xsl\:border-r-0 {
9115
9125
  border-right-width: 0px;
9116
9126
  }
@@ -9543,9 +9553,9 @@ body {
9543
9553
  --tw-shadow-colored: inset 0 0 0 2px var(--tw-shadow-color);
9544
9554
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
9545
9555
  }
9546
- .xsl\:shadow-\[inset_0_1px_0_var\(--tw-shadow-color\)\] {
9547
- --tw-shadow: inset 0 1px 0 var(--tw-shadow-color);
9548
- --tw-shadow-colored: inset 0 1px 0 var(--tw-shadow-color);
9556
+ .xsl\:shadow-\[inset_0px_1px_0_0_var\(--tw-shadow-color\)\2c inset_0_-1px_0_0_var\(--tw-shadow-color\)\] {
9557
+ --tw-shadow: inset 0px 1px 0 0 var(--tw-shadow-color),inset 0 -1px 0 0 var(--tw-shadow-color);
9558
+ --tw-shadow-colored: inset 0px 1px 0 0 var(--tw-shadow-color), inset 0 -1px 0 0 var(--tw-shadow-color);
9549
9559
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
9550
9560
  }
9551
9561
  .xsl\:shadow-md {
@@ -9838,6 +9848,14 @@ body {
9838
9848
  --tw-bg-opacity: 1;
9839
9849
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
9840
9850
  }
9851
+ .group:first-child .xsl\:group-first\:rounded-t-sm {
9852
+ border-top-left-radius: 0.125rem;
9853
+ border-top-right-radius: 0.125rem;
9854
+ }
9855
+ .group:last-child .xsl\:group-last\:rounded-b-sm {
9856
+ border-bottom-right-radius: 0.125rem;
9857
+ border-bottom-left-radius: 0.125rem;
9858
+ }
9841
9859
  @media (hover: hover) and (pointer: fine) {
9842
9860
  .group\/dualaction:hover .xsl\:group-hover\/dualaction\:text-primary {
9843
9861
  --tw-text-opacity: 1;
@@ -10549,9 +10567,6 @@ body {
10549
10567
  .sm\:self-center {
10550
10568
  align-self: center;
10551
10569
  }
10552
- .sm\:overflow-hidden {
10553
- overflow: hidden;
10554
- }
10555
10570
  .sm\:truncate {
10556
10571
  overflow: hidden;
10557
10572
  text-overflow: ellipsis;
@@ -10646,6 +10661,9 @@ body {
10646
10661
  .sm\:border-l-\[6px\] {
10647
10662
  border-left-width: 6px;
10648
10663
  }
10664
+ .sm\:border-r {
10665
+ border-right-width: 1px;
10666
+ }
10649
10667
  .sm\:border-r-0 {
10650
10668
  border-right-width: 0px;
10651
10669
  }
@@ -11101,9 +11119,9 @@ body {
11101
11119
  --tw-shadow-colored: inset 0 0 0 2px var(--tw-shadow-color);
11102
11120
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
11103
11121
  }
11104
- .sm\:shadow-\[inset_0_1px_0_var\(--tw-shadow-color\)\] {
11105
- --tw-shadow: inset 0 1px 0 var(--tw-shadow-color);
11106
- --tw-shadow-colored: inset 0 1px 0 var(--tw-shadow-color);
11122
+ .sm\:shadow-\[inset_0px_1px_0_0_var\(--tw-shadow-color\)\2c inset_0_-1px_0_0_var\(--tw-shadow-color\)\] {
11123
+ --tw-shadow: inset 0px 1px 0 0 var(--tw-shadow-color),inset 0 -1px 0 0 var(--tw-shadow-color);
11124
+ --tw-shadow-colored: inset 0px 1px 0 0 var(--tw-shadow-color), inset 0 -1px 0 0 var(--tw-shadow-color);
11107
11125
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
11108
11126
  }
11109
11127
  .sm\:shadow-md {
@@ -11396,6 +11414,14 @@ body {
11396
11414
  --tw-bg-opacity: 1;
11397
11415
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
11398
11416
  }
11417
+ .group:first-child .sm\:group-first\:rounded-t-sm {
11418
+ border-top-left-radius: 0.125rem;
11419
+ border-top-right-radius: 0.125rem;
11420
+ }
11421
+ .group:last-child .sm\:group-last\:rounded-b-sm {
11422
+ border-bottom-right-radius: 0.125rem;
11423
+ border-bottom-left-radius: 0.125rem;
11424
+ }
11399
11425
  @media (hover: hover) and (pointer: fine) {
11400
11426
  .group\/checkbox-option:hover .sm\:group-hover\/checkbox-option\:translate-x-1 {
11401
11427
  --tw-translate-x: 0.375rem;
@@ -12178,9 +12204,6 @@ body {
12178
12204
  .md\:self-center {
12179
12205
  align-self: center;
12180
12206
  }
12181
- .md\:overflow-hidden {
12182
- overflow: hidden;
12183
- }
12184
12207
  .md\:truncate {
12185
12208
  overflow: hidden;
12186
12209
  text-overflow: ellipsis;
@@ -12278,6 +12301,9 @@ body {
12278
12301
  .md\:border-l-\[6px\] {
12279
12302
  border-left-width: 6px;
12280
12303
  }
12304
+ .md\:border-r {
12305
+ border-right-width: 1px;
12306
+ }
12281
12307
  .md\:border-r-0 {
12282
12308
  border-right-width: 0px;
12283
12309
  }
@@ -12741,9 +12767,9 @@ body {
12741
12767
  --tw-shadow-colored: inset 0 0 0 2px var(--tw-shadow-color);
12742
12768
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
12743
12769
  }
12744
- .md\:shadow-\[inset_0_1px_0_var\(--tw-shadow-color\)\] {
12745
- --tw-shadow: inset 0 1px 0 var(--tw-shadow-color);
12746
- --tw-shadow-colored: inset 0 1px 0 var(--tw-shadow-color);
12770
+ .md\:shadow-\[inset_0px_1px_0_0_var\(--tw-shadow-color\)\2c inset_0_-1px_0_0_var\(--tw-shadow-color\)\] {
12771
+ --tw-shadow: inset 0px 1px 0 0 var(--tw-shadow-color),inset 0 -1px 0 0 var(--tw-shadow-color);
12772
+ --tw-shadow-colored: inset 0px 1px 0 0 var(--tw-shadow-color), inset 0 -1px 0 0 var(--tw-shadow-color);
12747
12773
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
12748
12774
  }
12749
12775
  .md\:shadow-md {
@@ -13036,6 +13062,14 @@ body {
13036
13062
  --tw-bg-opacity: 1;
13037
13063
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
13038
13064
  }
13065
+ .group:first-child .md\:group-first\:rounded-t-sm {
13066
+ border-top-left-radius: 0.125rem;
13067
+ border-top-right-radius: 0.125rem;
13068
+ }
13069
+ .group:last-child .md\:group-last\:rounded-b-sm {
13070
+ border-bottom-right-radius: 0.125rem;
13071
+ border-bottom-left-radius: 0.125rem;
13072
+ }
13039
13073
  @media (hover: hover) and (pointer: fine) {
13040
13074
  .group\/dualaction:hover .md\:group-hover\/dualaction\:text-primary {
13041
13075
  --tw-text-opacity: 1;
@@ -13800,9 +13834,6 @@ body {
13800
13834
  .lg\:self-center {
13801
13835
  align-self: center;
13802
13836
  }
13803
- .lg\:overflow-hidden {
13804
- overflow: hidden;
13805
- }
13806
13837
  .lg\:truncate {
13807
13838
  overflow: hidden;
13808
13839
  text-overflow: ellipsis;
@@ -13897,6 +13928,9 @@ body {
13897
13928
  .lg\:border-l-\[6px\] {
13898
13929
  border-left-width: 6px;
13899
13930
  }
13931
+ .lg\:border-r {
13932
+ border-right-width: 1px;
13933
+ }
13900
13934
  .lg\:border-r-0 {
13901
13935
  border-right-width: 0px;
13902
13936
  }
@@ -14341,9 +14375,9 @@ body {
14341
14375
  --tw-shadow-colored: inset 0 0 0 2px var(--tw-shadow-color);
14342
14376
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
14343
14377
  }
14344
- .lg\:shadow-\[inset_0_1px_0_var\(--tw-shadow-color\)\] {
14345
- --tw-shadow: inset 0 1px 0 var(--tw-shadow-color);
14346
- --tw-shadow-colored: inset 0 1px 0 var(--tw-shadow-color);
14378
+ .lg\:shadow-\[inset_0px_1px_0_0_var\(--tw-shadow-color\)\2c inset_0_-1px_0_0_var\(--tw-shadow-color\)\] {
14379
+ --tw-shadow: inset 0px 1px 0 0 var(--tw-shadow-color),inset 0 -1px 0 0 var(--tw-shadow-color);
14380
+ --tw-shadow-colored: inset 0px 1px 0 0 var(--tw-shadow-color), inset 0 -1px 0 0 var(--tw-shadow-color);
14347
14381
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
14348
14382
  }
14349
14383
  .lg\:shadow-md {
@@ -14636,6 +14670,14 @@ body {
14636
14670
  --tw-bg-opacity: 1;
14637
14671
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
14638
14672
  }
14673
+ .group:first-child .lg\:group-first\:rounded-t-sm {
14674
+ border-top-left-radius: 0.125rem;
14675
+ border-top-right-radius: 0.125rem;
14676
+ }
14677
+ .group:last-child .lg\:group-last\:rounded-b-sm {
14678
+ border-bottom-right-radius: 0.125rem;
14679
+ border-bottom-left-radius: 0.125rem;
14680
+ }
14639
14681
  @media (hover: hover) and (pointer: fine) {
14640
14682
  .group\/dualaction:hover .lg\:group-hover\/dualaction\:text-primary {
14641
14683
  --tw-text-opacity: 1;
@@ -15346,9 +15388,6 @@ body {
15346
15388
  .xl\:self-center {
15347
15389
  align-self: center;
15348
15390
  }
15349
- .xl\:overflow-hidden {
15350
- overflow: hidden;
15351
- }
15352
15391
  .xl\:truncate {
15353
15392
  overflow: hidden;
15354
15393
  text-overflow: ellipsis;
@@ -15443,6 +15482,9 @@ body {
15443
15482
  .xl\:border-l-\[6px\] {
15444
15483
  border-left-width: 6px;
15445
15484
  }
15485
+ .xl\:border-r {
15486
+ border-right-width: 1px;
15487
+ }
15446
15488
  .xl\:border-r-0 {
15447
15489
  border-right-width: 0px;
15448
15490
  }
@@ -15869,9 +15911,9 @@ body {
15869
15911
  --tw-shadow-colored: inset 0 0 0 2px var(--tw-shadow-color);
15870
15912
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
15871
15913
  }
15872
- .xl\:shadow-\[inset_0_1px_0_var\(--tw-shadow-color\)\] {
15873
- --tw-shadow: inset 0 1px 0 var(--tw-shadow-color);
15874
- --tw-shadow-colored: inset 0 1px 0 var(--tw-shadow-color);
15914
+ .xl\:shadow-\[inset_0px_1px_0_0_var\(--tw-shadow-color\)\2c inset_0_-1px_0_0_var\(--tw-shadow-color\)\] {
15915
+ --tw-shadow: inset 0px 1px 0 0 var(--tw-shadow-color),inset 0 -1px 0 0 var(--tw-shadow-color);
15916
+ --tw-shadow-colored: inset 0px 1px 0 0 var(--tw-shadow-color), inset 0 -1px 0 0 var(--tw-shadow-color);
15875
15917
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
15876
15918
  }
15877
15919
  .xl\:shadow-md {
@@ -16164,6 +16206,14 @@ body {
16164
16206
  --tw-bg-opacity: 1;
16165
16207
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
16166
16208
  }
16209
+ .group:first-child .xl\:group-first\:rounded-t-sm {
16210
+ border-top-left-radius: 0.125rem;
16211
+ border-top-right-radius: 0.125rem;
16212
+ }
16213
+ .group:last-child .xl\:group-last\:rounded-b-sm {
16214
+ border-bottom-right-radius: 0.125rem;
16215
+ border-bottom-left-radius: 0.125rem;
16216
+ }
16167
16217
  @media (hover: hover) and (pointer: fine) {
16168
16218
  .group\/dualaction:hover .xl\:group-hover\/dualaction\:text-primary {
16169
16219
  --tw-text-opacity: 1;