@marigold/components 0.0.3 → 0.3.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.
Files changed (220) hide show
  1. package/CHANGELOG.md +174 -0
  2. package/dist/ActionGroup/ActionGroup.d.ts +8 -0
  3. package/dist/ActionGroup/ActionGroup.stories.d.ts +5 -0
  4. package/dist/ActionGroup/index.d.ts +1 -0
  5. package/dist/Alert/Alert.d.ts +22 -1
  6. package/dist/Alert/Alert.stories.d.ts +5 -0
  7. package/dist/Badge/Badge.d.ts +5 -0
  8. package/dist/Badge/Badge.stories.d.ts +5 -0
  9. package/dist/Box.d.ts +2 -0
  10. package/dist/Button/Button.d.ts +9 -6
  11. package/dist/Button/Button.stories.d.ts +5 -0
  12. package/dist/Card/Card.d.ts +14 -0
  13. package/dist/Card/Card.stories.d.ts +5 -0
  14. package/dist/Card/index.d.ts +1 -0
  15. package/dist/Checkbox/Checkbox.d.ts +15 -3
  16. package/dist/Checkbox/Checkbox.stories.d.ts +5 -0
  17. package/dist/Checkbox/CheckboxIcons.d.ts +9 -0
  18. package/dist/Column/Column.d.ts +3 -1
  19. package/dist/Column/Column.stories.d.ts +5 -0
  20. package/dist/Columns/Columns.d.ts +2 -2
  21. package/dist/Columns/Columns.stories.d.ts +5 -0
  22. package/dist/Container/Container.stories.d.ts +5 -0
  23. package/dist/Dialog/Dialog.d.ts +12 -2
  24. package/dist/Dialog/Dialog.stories.d.ts +5 -0
  25. package/dist/Dialog/ModalDialog.d.ts +8 -0
  26. package/dist/Divider/Divider.d.ts +5 -0
  27. package/dist/Divider/Divider.stories.d.ts +5 -0
  28. package/dist/Field/Field.d.ts +5 -1
  29. package/dist/Field/Field.stories.d.ts +5 -0
  30. package/dist/Image/Image.d.ts +5 -0
  31. package/dist/Image/Image.stories.d.ts +5 -0
  32. package/dist/Inline/Inline.d.ts +7 -0
  33. package/dist/Inline/Inline.stories.d.ts +5 -0
  34. package/dist/Inline/index.d.ts +1 -0
  35. package/dist/Input/Input.d.ts +5 -0
  36. package/dist/Input/Input.stories.d.ts +5 -0
  37. package/dist/Label/Label.d.ts +14 -2
  38. package/dist/Label/Label.stories.d.ts +5 -0
  39. package/dist/Link/Link.d.ts +10 -6
  40. package/dist/Link/Link.stories.d.ts +5 -0
  41. package/dist/Menu/Menu.d.ts +3 -0
  42. package/dist/Menu/Menu.stories.d.ts +5 -0
  43. package/dist/MenuItem/MenuItem.d.ts +5 -0
  44. package/dist/MenuItem/MenuItem.stories.d.ts +5 -0
  45. package/dist/Message/Message.d.ts +5 -0
  46. package/dist/Message/Message.stories.d.ts +5 -0
  47. package/dist/Provider/MarigoldProvider.d.ts +11 -0
  48. package/dist/Provider/index.d.ts +3 -0
  49. package/dist/Radio/Radio.d.ts +11 -4
  50. package/dist/Radio/Radio.stories.d.ts +5 -0
  51. package/dist/Radio/RadioIcon.d.ts +9 -0
  52. package/dist/Select/ListBox.d.ts +9 -0
  53. package/dist/Select/ListBoxSection.d.ts +9 -0
  54. package/dist/Select/Option.d.ts +9 -0
  55. package/dist/Select/Popover.d.ts +9 -0
  56. package/dist/Select/Select.d.ts +25 -4
  57. package/dist/Select/Select.stories.d.ts +5 -0
  58. package/dist/Slider/Slider.d.ts +5 -0
  59. package/dist/Slider/Slider.stories.d.ts +5 -0
  60. package/dist/Stack/Stack.d.ts +1 -3
  61. package/dist/Stack/Stack.stories.d.ts +5 -0
  62. package/dist/Text/Text.d.ts +17 -10
  63. package/dist/Text/Text.stories.d.ts +5 -0
  64. package/dist/Textarea/Textarea.d.ts +7 -1
  65. package/dist/Textarea/Textarea.stories.d.ts +5 -0
  66. package/dist/ValidationMessage/ValidationMessage.d.ts +5 -0
  67. package/dist/ValidationMessage/ValidationMessage.stories.d.ts +5 -0
  68. package/dist/VisuallyHidden/VisuallyHidden.d.ts +1 -0
  69. package/dist/VisuallyHidden/VisuallyHidden.stories.d.ts +5 -0
  70. package/dist/VisuallyHidden/index.d.ts +1 -0
  71. package/dist/components.cjs.development.js +1075 -562
  72. package/dist/components.cjs.development.js.map +1 -1
  73. package/dist/components.cjs.production.min.js +1 -1
  74. package/dist/components.cjs.production.min.js.map +1 -1
  75. package/dist/components.esm.js +1012 -542
  76. package/dist/components.esm.js.map +1 -1
  77. package/dist/index.d.ts +6 -2
  78. package/dist/theme.d.ts +23 -48
  79. package/package.json +21 -2
  80. package/src/ActionGroup/ActionGroup.stories.tsx +47 -0
  81. package/src/ActionGroup/ActionGroup.test.tsx +83 -0
  82. package/src/ActionGroup/ActionGroup.tsx +32 -0
  83. package/src/ActionGroup/index.ts +1 -0
  84. package/src/Alert/Alert.stories.tsx +32 -0
  85. package/src/Alert/Alert.test.tsx +5 -2
  86. package/src/Alert/Alert.tsx +27 -34
  87. package/src/Badge/Badge.stories.tsx +38 -0
  88. package/src/Badge/Badge.test.tsx +12 -16
  89. package/src/Badge/Badge.tsx +14 -3
  90. package/src/Box.ts +2 -0
  91. package/src/Button/Button.stories.tsx +57 -0
  92. package/src/Button/Button.test.tsx +76 -13
  93. package/src/Button/Button.tsx +61 -18
  94. package/src/Card/Card.stories.tsx +41 -0
  95. package/src/Card/Card.test.tsx +71 -0
  96. package/src/Card/Card.tsx +48 -0
  97. package/src/Card/index.ts +1 -0
  98. package/src/Checkbox/Checkbox.stories.tsx +78 -0
  99. package/src/Checkbox/Checkbox.test.tsx +138 -23
  100. package/src/Checkbox/Checkbox.tsx +81 -52
  101. package/src/Checkbox/CheckboxIcons.tsx +59 -0
  102. package/src/Column/Column.stories.tsx +33 -0
  103. package/src/Column/Column.test.tsx +8 -0
  104. package/src/Column/Column.tsx +12 -2
  105. package/src/Columns/Columns.stories.tsx +75 -0
  106. package/src/Columns/Columns.test.tsx +34 -23
  107. package/src/Columns/Columns.tsx +30 -30
  108. package/src/Container/Container.stories.tsx +14 -0
  109. package/src/Dialog/Dialog.stories.tsx +88 -0
  110. package/src/Dialog/Dialog.test.tsx +129 -18
  111. package/src/Dialog/Dialog.tsx +113 -15
  112. package/src/Dialog/ModalDialog.tsx +76 -0
  113. package/src/Divider/Divider.stories.tsx +30 -0
  114. package/src/Divider/Divider.test.tsx +13 -5
  115. package/src/Divider/Divider.tsx +12 -0
  116. package/src/Field/Field.stories.tsx +110 -0
  117. package/src/Field/Field.test.tsx +74 -33
  118. package/src/Field/Field.tsx +27 -20
  119. package/src/Image/Image.stories.tsx +34 -0
  120. package/src/Image/Image.test.tsx +4 -1
  121. package/src/Image/Image.tsx +13 -1
  122. package/src/Inline/Inline.stories.tsx +39 -0
  123. package/src/Inline/Inline.test.tsx +99 -0
  124. package/src/Inline/Inline.tsx +38 -0
  125. package/src/Inline/index.ts +1 -0
  126. package/src/Input/Input.stories.tsx +54 -0
  127. package/src/Input/Input.test.tsx +7 -3
  128. package/src/Input/Input.tsx +13 -1
  129. package/src/Label/Label.stories.tsx +41 -0
  130. package/src/Label/Label.test.tsx +40 -5
  131. package/src/Label/Label.tsx +54 -8
  132. package/src/Link/Link.stories.tsx +35 -0
  133. package/src/Link/Link.test.tsx +51 -21
  134. package/src/Link/Link.tsx +39 -13
  135. package/src/Menu/Menu.stories.tsx +62 -0
  136. package/src/Menu/Menu.test.tsx +11 -6
  137. package/src/Menu/Menu.tsx +22 -14
  138. package/src/MenuItem/MenuItem.stories.tsx +30 -0
  139. package/src/MenuItem/MenuItem.test.tsx +22 -13
  140. package/src/MenuItem/MenuItem.tsx +19 -10
  141. package/src/Message/Message.stories.tsx +30 -0
  142. package/src/Message/Message.test.tsx +4 -1
  143. package/src/Message/Message.tsx +18 -14
  144. package/src/Provider/MarigoldProvider.test.tsx +136 -0
  145. package/src/Provider/MarigoldProvider.tsx +47 -0
  146. package/src/Provider/index.ts +4 -0
  147. package/src/Radio/Radio.stories.tsx +78 -0
  148. package/src/Radio/Radio.test.tsx +129 -18
  149. package/src/Radio/Radio.tsx +62 -71
  150. package/src/Radio/RadioIcon.tsx +49 -0
  151. package/src/Select/ListBox.tsx +40 -0
  152. package/src/Select/ListBoxSection.tsx +40 -0
  153. package/src/Select/Option.tsx +48 -0
  154. package/src/Select/Popover.tsx +50 -0
  155. package/src/Select/Select.stories.tsx +81 -0
  156. package/src/Select/Select.test.tsx +317 -35
  157. package/src/Select/Select.tsx +162 -18
  158. package/src/Slider/Slider.stories.tsx +24 -0
  159. package/src/Slider/Slider.test.tsx +10 -6
  160. package/src/Slider/Slider.tsx +25 -13
  161. package/src/Stack/Stack.stories.tsx +57 -0
  162. package/src/Stack/Stack.test.tsx +93 -65
  163. package/src/Stack/Stack.tsx +27 -32
  164. package/src/Text/Text.stories.tsx +61 -0
  165. package/src/Text/Text.test.tsx +41 -36
  166. package/src/Text/Text.tsx +56 -31
  167. package/src/Textarea/Textarea.stories.tsx +64 -0
  168. package/src/Textarea/Textarea.test.tsx +11 -8
  169. package/src/Textarea/Textarea.tsx +41 -38
  170. package/src/ValidationMessage/ValidationMessage.stories.tsx +27 -0
  171. package/src/ValidationMessage/ValidationMessage.test.tsx +9 -4
  172. package/src/ValidationMessage/ValidationMessage.tsx +23 -12
  173. package/src/VisuallyHidden/VisuallyHidden.stories.tsx +19 -0
  174. package/src/VisuallyHidden/VisuallyHidden.test.tsx +10 -0
  175. package/src/VisuallyHidden/VisuallyHidden.tsx +1 -0
  176. package/src/VisuallyHidden/index.ts +1 -0
  177. package/src/index.ts +7 -2
  178. package/src/theme.ts +49 -48
  179. package/dist/Box/Box.d.ts +0 -45
  180. package/dist/Box/index.d.ts +0 -1
  181. package/dist/Heading/Heading.d.ts +0 -7
  182. package/dist/Heading/index.d.ts +0 -1
  183. package/dist/Hidden/Hidden.d.ts +0 -5
  184. package/dist/Hidden/index.d.ts +0 -1
  185. package/src/Alert/Alert.stories.mdx +0 -45
  186. package/src/Badge/Badge.stories.mdx +0 -43
  187. package/src/Box/Box.stories.mdx +0 -38
  188. package/src/Box/Box.test.tsx +0 -133
  189. package/src/Box/Box.tsx +0 -152
  190. package/src/Box/index.ts +0 -1
  191. package/src/Button/Button.stories.mdx +0 -176
  192. package/src/Checkbox/Checkbox.stories.mdx +0 -119
  193. package/src/Column/Column.stories.mdx +0 -74
  194. package/src/Columns/Columns.stories.mdx +0 -247
  195. package/src/Container/Container.stories.mdx +0 -36
  196. package/src/Dialog/Dialog.stories.mdx +0 -64
  197. package/src/Divider/Divider.stories.mdx +0 -43
  198. package/src/Field/Field.stories.mdx +0 -57
  199. package/src/Heading/Heading.stories.mdx +0 -91
  200. package/src/Heading/Heading.test.tsx +0 -77
  201. package/src/Heading/Heading.tsx +0 -19
  202. package/src/Heading/index.ts +0 -1
  203. package/src/Hidden/Hidden.stories.mdx +0 -64
  204. package/src/Hidden/Hidden.test.tsx +0 -24
  205. package/src/Hidden/Hidden.tsx +0 -16
  206. package/src/Hidden/index.ts +0 -1
  207. package/src/Image/Image.stories.mdx +0 -40
  208. package/src/Input/Input.stories.mdx +0 -45
  209. package/src/Label/Label.stories.mdx +0 -34
  210. package/src/Link/Link.stories.mdx +0 -38
  211. package/src/Menu/Menu.stories.mdx +0 -49
  212. package/src/MenuItem/MenuItem.stories.mdx +0 -32
  213. package/src/Message/Message.stories.mdx +0 -44
  214. package/src/Radio/Radio.stories.mdx +0 -100
  215. package/src/Select/Select.stories.mdx +0 -44
  216. package/src/Slider/Slider.stories.mdx +0 -58
  217. package/src/Stack/Stack.stories.mdx +0 -105
  218. package/src/Text/Text.stories.mdx +0 -60
  219. package/src/Textarea/Textarea.stories.mdx +0 -65
  220. package/src/ValidationMessage/ValidationMessage.stories.mdx +0 -36
@@ -1 +1 @@
1
- {"version":3,"file":"components.esm.js","sources":["../src/Box/Box.tsx","../src/Alert/Alert.tsx","../src/Badge/Badge.tsx","../src/Button/Button.tsx","../src/Label/Label.tsx","../src/Checkbox/Checkbox.tsx","../src/Column/Column.tsx","../src/Columns/Columns.tsx","../src/Dialog/Dialog.tsx","../src/Divider/Divider.tsx","../src/Input/Input.tsx","../src/ValidationMessage/ValidationMessage.tsx","../src/Field/Field.tsx","../src/Heading/Heading.tsx","../src/Hidden/Hidden.tsx","../src/Image/Image.tsx","../src/Link/Link.tsx","../src/Menu/Menu.tsx","../src/MenuItem/MenuItem.tsx","../src/Message/Message.tsx","../src/Radio/Radio.tsx","../src/Slider/Slider.tsx","../src/Select/Select.tsx","../src/Stack/Stack.tsx","../src/Text/Text.tsx","../src/Textarea/Textarea.tsx","../src/Container/Container.tsx"],"sourcesContent":["import { createElement, forwardRef } from 'react';\nimport { ResponsiveStyleValue, useStyles } from '@marigold/system';\nimport { ComponentWithAs } from '@marigold/types';\n\nexport type BoxProps = {\n className?: string;\n variant?: string | string[];\n\n display?: ResponsiveStyleValue<string>;\n\n height?: ResponsiveStyleValue<number | string>;\n width?: ResponsiveStyleValue<number | string>;\n minWidth?: ResponsiveStyleValue<number | string>;\n maxWidth?: ResponsiveStyleValue<number | string>;\n\n position?: ResponsiveStyleValue<string>;\n top?: ResponsiveStyleValue<number | string>;\n bottom?: ResponsiveStyleValue<number | string>;\n right?: ResponsiveStyleValue<number | string>;\n left?: ResponsiveStyleValue<number | string>;\n zIndex?: ResponsiveStyleValue<number | string>;\n\n p?: ResponsiveStyleValue<number | string>;\n px?: ResponsiveStyleValue<number | string>;\n py?: ResponsiveStyleValue<number | string>;\n pt?: ResponsiveStyleValue<number | string>;\n pb?: ResponsiveStyleValue<number | string>;\n pl?: ResponsiveStyleValue<number | string>;\n pr?: ResponsiveStyleValue<number | string>;\n\n m?: ResponsiveStyleValue<number | string>;\n mx?: ResponsiveStyleValue<number | string>;\n my?: ResponsiveStyleValue<number | string>;\n mt?: ResponsiveStyleValue<number | string>;\n mb?: ResponsiveStyleValue<number | string>;\n ml?: ResponsiveStyleValue<number | string>;\n mr?: ResponsiveStyleValue<number | string>;\n\n flexDirection?: ResponsiveStyleValue<string>;\n flexWrap?: ResponsiveStyleValue<string>;\n flexShrink?: ResponsiveStyleValue<number | string>;\n flexGrow?: ResponsiveStyleValue<number | string>;\n alignItems?: ResponsiveStyleValue<string>;\n justifyContent?: ResponsiveStyleValue<string>;\n\n bg?: ResponsiveStyleValue<number | string>;\n border?: ResponsiveStyleValue<number | string>;\n borderRadius?: ResponsiveStyleValue<number | string>;\n boxShadow?: ResponsiveStyleValue<number | string>;\n opacity?: ResponsiveStyleValue<number | string>;\n overflow?: ResponsiveStyleValue<string>;\n\n transition?: ResponsiveStyleValue<number | string>;\n};\n\nexport const Box: ComponentWithAs<BoxProps, 'div'> = forwardRef(\n (\n {\n variant,\n as = 'div',\n children,\n className,\n display,\n height,\n width,\n minWidth,\n maxWidth,\n position,\n top,\n bottom,\n right,\n left,\n zIndex,\n p,\n px,\n py,\n pt,\n pb,\n pl,\n pr,\n m,\n mx,\n my,\n mt,\n mb,\n ml,\n mr,\n flexDirection,\n flexWrap,\n flexShrink,\n flexGrow,\n alignItems,\n justifyContent,\n bg,\n border,\n borderRadius,\n boxShadow,\n opacity,\n overflow,\n transition,\n ...props\n },\n ref\n ) => {\n const cn = useStyles({\n element: as,\n variant,\n className,\n css: {\n display,\n height,\n width,\n minWidth,\n maxWidth,\n position,\n top,\n bottom,\n right,\n left,\n zIndex,\n p,\n px,\n py,\n pt,\n pb,\n pl,\n pr,\n m,\n mx,\n my,\n mt,\n mb,\n ml,\n mr,\n flexDirection,\n flexWrap,\n flexShrink,\n flexGrow,\n alignItems,\n justifyContent,\n bg,\n border,\n borderRadius,\n boxShadow,\n opacity,\n overflow,\n transition,\n },\n });\n return createElement(as, { ...props, ref, className: cn }, children);\n }\n);\n","import React from 'react';\nimport { ComponentProps } from '@marigold/types';\nimport { Exclamation, Check, Notification } from '@marigold/icons';\nimport { useStyles } from '@marigold/system';\nimport { Box } from '../Box';\n\nexport type AlertProps = {\n variant?: string;\n} & ComponentProps<'div'>;\n\nexport const Alert: React.FC<AlertProps> = ({\n variant = 'success',\n children,\n className,\n ...props\n}) => {\n const classNames = useStyles({\n css: {\n display: 'flex',\n alignItems: 'center',\n },\n variant: `alerts.${variant}`,\n className,\n });\n\n var bgColor = 'success';\n if (variant === 'warning') {\n bgColor = 'warning';\n } else if (variant === 'error') {\n bgColor = 'error';\n }\n const iconClassName = useStyles({ css: { bg: bgColor, m: '10px' } });\n\n var icon = <Check size={12} color=\"#ffffff\" className={iconClassName} />;\n if (variant === 'warning') {\n icon = <Notification size={12} color=\"#ffffff\" className={iconClassName} />;\n } else if (variant === 'error') {\n icon = <Exclamation size={12} color=\"#ffffff\" className={iconClassName} />;\n }\n\n return (\n <Box {...props} className={classNames}>\n <Box\n display=\"inline-block\"\n alignItems=\"center\"\n width=\"32px\"\n height=\"32px\"\n className={useStyles({\n css: {\n bg: bgColor,\n },\n })}\n >\n {icon}\n </Box>\n <Box mx=\"16px\">{children}</Box>\n </Box>\n );\n};\n","import React from 'react';\nimport { ComponentProps } from '@marigold/types';\nimport { Box } from '../Box';\nimport { useStyles } from '@marigold/system';\n\nexport type BadgeProps = {\n variant?: string;\n bgColor?: string;\n borderColor?: string;\n} & ComponentProps<'div'>;\n\nexport const Badge: React.FC<BadgeProps> = ({\n variant = 'default',\n bgColor = 'transparent',\n borderColor = 'transparent',\n children,\n ...props\n}) => (\n <Box\n className={useStyles({ css: { bg: bgColor, borderColor: borderColor } })}\n variant={`badge.${variant}`}\n {...props}\n >\n {children}\n </Box>\n);\n","import React from 'react';\nimport { ComponentPropsWithRef } from '@marigold/types';\nimport { Box } from '../Box';\n\nexport type ButtonProps = {\n variant?: string;\n} & ComponentPropsWithRef<'button'>;\n\nexport const Button: React.FC<ButtonProps> = ({\n variant = 'primary.large',\n children,\n ...props\n}) => {\n return (\n <Box as=\"button\" {...props} variant={`button.${variant}`}>\n <Box as=\"span\" display=\"inline-flex\" alignItems=\"center\">\n {children}\n </Box>\n </Box>\n );\n};\n","import React from 'react';\nimport { ComponentProps } from '@marigold/types';\nimport { Box } from '../Box';\n\nexport type LabelProps = {\n htmlFor: string;\n variant?: string;\n} & ComponentProps<'label'>;\n\nexport const Label: React.FC<LabelProps> = ({\n variant = 'default',\n children,\n ...props\n}) => (\n <Box {...props} as=\"label\" variant={`label.${variant}`}>\n {children}\n </Box>\n);\n","import React from 'react';\nimport { Required, SquareUnchecked, SquareChecked } from '@marigold/icons';\nimport { useStyles } from '@marigold/system';\nimport { ComponentProps } from '@marigold/types';\n\nimport { Box } from '../Box';\nimport { Label } from '../Label';\n\nexport type CheckboxProps = {\n id: string;\n variant?: string;\n label?: string;\n} & Omit<ComponentProps<'input'>, 'type' | 'id'>;\n\nexport const Checkbox: React.FC<CheckboxProps> = ({\n id,\n variant = 'default',\n label,\n required,\n className,\n ...props\n}) => {\n const checkboxStyles = useStyles({\n css: {\n position: 'absolute',\n opacity: 0,\n zIndex: -1,\n width: 1,\n height: 1,\n overflow: 'hidden',\n },\n });\n\n const checkboxIconStyles = useStyles({\n variant: `checkbox.${variant}`,\n css: {\n mr: 2,\n verticalAlign: 'middle',\n ':hover': { cursor: 'pointer' },\n 'input:disabled ~ &': {\n color: 'muted',\n cursor: 'not-allowed',\n },\n },\n className,\n });\n\n const checkbox = (\n <Box display=\"inline-block\">\n <input type=\"checkbox\" className={checkboxStyles} {...props} />\n {props.checked ? (\n <SquareChecked aria-hidden=\"true\" className={checkboxIconStyles} />\n ) : (\n <SquareUnchecked aria-hidden=\"true\" className={checkboxIconStyles} />\n )}\n </Box>\n );\n\n return (\n <>\n {label ? (\n <Label htmlFor={id}>\n {checkbox}\n {label}\n {required ? <Required size={16} /> : ''}\n </Label>\n ) : (\n <>{checkbox}</>\n )}\n </>\n );\n};\n","import React from 'react';\nimport { Box } from '../Box';\n\nexport type ColumnProps = {\n className?: string;\n width?: 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12;\n};\n\nexport const Column: React.FC<ColumnProps> = ({\n width = 12,\n children,\n ...props\n}) => (\n <Box {...props} width={`${(width / 12) * 100}%`}>\n {children}\n </Box>\n);\n","import React, { Children } from 'react';\nimport { useStyles } from '@marigold/system';\nimport { Box } from '../Box';\nimport flattenChildren from 'react-keyed-flatten-children';\n\ntype ColumnsProps = {\n className?: string;\n space?: number;\n horizontalAlign?: 'left' | 'right' | 'center';\n verticalAlign?: 'top' | 'bottom' | 'center';\n title?: string; // Should only be used for testing.\n};\n\nexport const Columns: React.FC<ColumnsProps> = ({\n space = 0,\n horizontalAlign = 'left',\n verticalAlign = 'top',\n className,\n children,\n ...props\n}) => {\n let columnItems = flattenChildren(children);\n let childClassNames = useStyles({ css: { p: `${space / 2}px` } });\n\n // horizontal Alignment\n let justify = 'flex-start';\n if (horizontalAlign === 'right') {\n justify = 'flex-end';\n } else if (horizontalAlign === 'center') {\n justify = 'center';\n }\n\n // vertical Alignment\n let alignItems = 'flex-start';\n if (verticalAlign === 'bottom') {\n alignItems = 'flex-end';\n } else if (verticalAlign === 'center') {\n alignItems = 'center';\n }\n\n return (\n <Box p={`${space}px`} display=\"flex\" className={className}>\n <Box\n width={`calc(100% + ${space}px)`}\n m={`${-space / 2}px`}\n display=\"flex\"\n flexWrap=\"wrap\"\n alignItems={alignItems}\n justifyContent={justify}\n {...props}\n >\n {Children.map(\n (columnItems as unknown) as React.ReactElement,\n (child: React.ReactElement) => {\n return React.cloneElement(\n child,\n {\n className: childClassNames,\n },\n <Box className={child && child.props.className}>\n {child.props.children}\n </Box>\n );\n }\n )}\n </Box>\n </Box>\n );\n};\n","import React from 'react';\nimport { ComponentProps } from '@marigold/types';\n\nimport { Close } from '@marigold/icons';\nimport { Button } from '../Button';\nimport { Box } from '../Box';\n\nexport type DialogProps = {\n onClose?: ComponentProps<typeof Button>['onClick'];\n} & ComponentProps<'div'>;\n\nexport const Dialog: React.FC<DialogProps> = ({\n onClose,\n children,\n className,\n ...props\n}) => {\n return (\n <Box display=\"flex\" width=\"100%\">\n <Box {...props} variant=\"dialog.wrapper\" className={className}>\n <Box display=\"flex\">\n <Box variant=\"dialog.body\">{children}</Box>\n <Box variant=\"dialog.onClose\">\n <Button variant=\"text.root\" onClick={onClose}>\n <Close size={16} />\n </Button>\n </Box>\n </Box>\n </Box>\n </Box>\n );\n};\n","import React from 'react';\nimport { Box } from '../Box';\n\nexport type DividerProps = {\n className?: string;\n variant?: string;\n title?: string; // Should only be used for testing.\n};\n\nexport const Divider: React.FC<DividerProps> = ({\n variant = 'regular',\n ...props\n}) => <Box {...props} as=\"hr\" variant={`divider.${variant}`} />;\n","import React from 'react';\nimport { ComponentProps } from '@marigold/types';\nimport { Box } from '../Box';\n\nexport type InputProps = {\n variant?: string;\n} & ComponentProps<'input'>;\n\nexport const Input: React.FC<InputProps> = ({\n variant = 'default',\n type = 'text',\n ...props\n}) => <Box {...props} as=\"input\" type={type} variant={`input.${variant}`} />;\n","import React from 'react';\nimport { useStyles } from '@marigold/system';\nimport { ComponentProps } from '@marigold/types';\n\nexport type ValidationMessageProps = {\n variant?: string;\n} & ComponentProps<'span'>;\n\nexport const ValidationMessage: React.FC<ValidationMessageProps> = ({\n variant = 'error',\n children,\n className,\n ...props\n}) => {\n const classNames = useStyles({\n variant: `validation.${variant}`,\n css: {\n display: 'flex',\n alignItems: 'center',\n },\n className,\n });\n\n return (\n <span className={classNames} {...props}>\n {children}\n </span>\n );\n};\n","import React from 'react';\nimport { useStyles } from '@marigold/system';\nimport { Exclamation, Required } from '@marigold/icons';\nimport { ComponentProps } from '@marigold/types';\n\nimport { Input } from '../Input';\nimport { Label } from '../Label';\nimport { ValidationMessage } from '../ValidationMessage';\n\nexport type FieldProps = {\n variant?: string;\n htmlFor: string;\n label: string;\n error?: string;\n} & ComponentProps<'input'>;\n\nexport const Field: React.FC<FieldProps> = ({\n variant = 'default',\n type = 'text',\n className = '',\n htmlFor,\n label,\n error,\n ...props\n}) => {\n const labelClassName = useStyles({\n variant: `field.${variant}`,\n className,\n });\n const errorClassName = useStyles({ css: { color: 'red60' } });\n\n return (\n <div>\n <Label className={labelClassName} htmlFor={htmlFor}>\n {label}\n {error ? <Required size={16} className={errorClassName} /> : ''}\n </Label>\n <Input {...props} type={type} id={htmlFor} />\n {error ? (\n <ValidationMessage>\n <Exclamation size={16} />\n {error}\n </ValidationMessage>\n ) : (\n ''\n )}\n </div>\n );\n};\n","import React from 'react';\nimport { ComponentProps } from '@marigold/types';\nimport { Box } from '../Box';\n\nexport type HeadingProps = {\n as?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n variant?: string;\n} & ComponentProps<'h1'>;\n\nexport const Heading: React.FC<HeadingProps> = ({\n as = 'h2',\n variant = 'h2',\n children,\n ...props\n}) => (\n <Box {...props} as={as} variant={`text.${variant}`}>\n {children}\n </Box>\n);\n","import React from 'react';\nimport { Box } from '../Box';\n\nexport type HiddenProps = {\n show?: boolean;\n};\n\nexport const Hidden: React.FC<HiddenProps> = ({\n show = false,\n children,\n ...props\n}) => (\n <Box {...props} as=\"span\" display={show ? 'display' : 'none'}>\n {children}\n </Box>\n);\n","import React from 'react';\nimport { ComponentProps } from '@marigold/types';\nimport { Box } from '../Box';\n\nexport type ImageProps = {\n variant?: string;\n children?: never;\n} & ComponentProps<'img'>;\n\nexport const Image: React.FC<ImageProps> = ({\n variant = 'fullWidth',\n ...props\n}) => <Box {...props} as=\"img\" variant={`images.${variant}`} />;\n","import React from 'react';\nimport { ComponentProps } from '@marigold/types';\nimport { Box } from '../Box';\n\nexport type LinkProps = {\n variant?: string;\n} & ComponentProps<'a'>;\n\nexport const Link: React.FC<LinkProps> = ({\n variant = 'normal',\n children,\n ...props\n}) => (\n <Box {...props} as=\"a\" variant={`link.${variant}`}>\n {children}\n </Box>\n);\n","import React from 'react';\nimport { useStyles } from '@marigold/system';\nimport { ComponentProps } from '@marigold/types';\n\nimport { Button } from '../Button';\nimport { Box } from '../Box';\n\nexport type MenuProps = {\n variant?: string;\n label?: string;\n onClick: ComponentProps<typeof Button>['onClick'];\n show?: boolean;\n className?: string;\n title?: string; // For testing\n};\n\nexport const Menu: React.FC<MenuProps> = ({\n variant = 'menu',\n label = 'Menu',\n onClick,\n show = false,\n children,\n ...props\n}) => {\n const itemStyles = useStyles({\n css: {\n position: 'absolute',\n minWidth: '120px',\n display: 'block',\n textAlign: 'left',\n borderRadius: '2px',\n },\n });\n\n return (\n <Box variant={`content.${variant}`} {...props}>\n <Button onClick={onClick} variant=\"menu\">\n {label}\n </Button>\n {show ? <div className={itemStyles}>{children}</div> : null}\n </Box>\n );\n};\n","import React from 'react';\nimport { useStyles } from '@marigold/system';\nimport { ComponentProps } from '@marigold/types';\nimport { Link } from '../Link';\n\nexport type MenuItemProps = {\n variant?: string;\n} & ComponentProps<typeof Link>;\n\nexport const MenuItem: React.FC<MenuItemProps> = ({\n variant = 'menuItem',\n className,\n children,\n ...props\n}) => {\n const classNames = useStyles({\n variant: `menu.${variant}`,\n className,\n });\n\n return (\n <Link {...props} variant=\"menu\" className={classNames}>\n {children}\n </Link>\n );\n};\n","import React from 'react';\nimport { Exclamation, Info, Notification } from '@marigold/icons';\nimport { useStyles } from '@marigold/system';\nimport { ComponentProps } from '@marigold/types';\nimport { Box } from '../Box';\nimport { Heading } from '../Heading';\n\nexport type MessageProps = {\n messageTitle: string;\n variant?: string;\n} & ComponentProps<'div'>;\n\nexport const Message: React.FC<MessageProps> = ({\n messageTitle,\n variant = 'info',\n className,\n children,\n ...props\n}) => {\n var icon = <Info />;\n if (variant === 'warning') {\n icon = <Notification />;\n }\n if (variant === 'error') {\n icon = <Exclamation />;\n }\n\n return (\n <Box\n display=\"inline-block\"\n variant={`messages.${variant}`}\n className={className}\n {...props}\n >\n <Box display=\"flex\" alignItems=\"center\" variant=\"messages.title\">\n {icon}\n <Heading\n variant=\"h4\"\n className={useStyles({\n css: {\n display: 'inline',\n },\n })}\n >\n {messageTitle}\n </Heading>\n </Box>\n <Box className={useStyles({ css: { color: 'black' } })}>{children}</Box>\n </Box>\n );\n};\n","import React from 'react';\nimport { CircleUnchecked, CircleChecked, Required } from '@marigold/icons';\nimport { useStyles } from '@marigold/system';\nimport { ComponentProps } from '@marigold/types';\nimport { Box } from '../Box';\nimport { Label } from '../Label';\n\n// Radio Icon\n// ---------------\ntype RadioIconProps = {\n className?: string;\n variant?: string;\n checked?: boolean;\n children?: never;\n};\n\nconst RadioIcon: React.FC<RadioIconProps> = ({\n className,\n variant,\n checked,\n}) => {\n const radioIconStyle = useStyles({\n variant: `form.${variant}`,\n css: {\n ariaHidden: 'true',\n mr: 2,\n verticalAlign: 'middle',\n ':hover': { cursor: 'pointer' },\n 'input:disabled ~ &': {\n color: 'muted',\n cursor: 'not-allowed',\n },\n },\n className,\n });\n\n if (checked) {\n return <CircleChecked className={radioIconStyle} />;\n }\n return <CircleUnchecked className={radioIconStyle} />;\n};\n\n// Radio Input\n// ---------------\ntype RadioInputProps = {\n variant?: string;\n} & ComponentProps<'input'>;\n\nconst RadioInput: React.FC<RadioInputProps> = ({\n className,\n variant = 'radio',\n ...props\n}) => {\n const radioStyle = useStyles({\n css: {\n position: 'absolute',\n opacity: 0,\n zIndex: -1,\n width: 1,\n height: 1,\n overflow: 'hidden',\n },\n });\n\n return (\n <Box display=\"inline-block\">\n <input type=\"radio\" className={radioStyle} {...props} />\n <RadioIcon\n checked={props.checked}\n className={className}\n variant={variant}\n />\n </Box>\n );\n};\n\n// Radio\n// ---------------\nexport type RadioProps = {\n id: string;\n label?: string;\n required?: boolean;\n} & RadioInputProps;\n\nexport const Radio: React.FC<RadioProps> = ({ label, required, ...props }) => {\n if (label) {\n return (\n <Label htmlFor={props.id}>\n <RadioInput {...props} />\n {label}\n {required && <Required size={16} />}\n </Label>\n );\n }\n\n return <RadioInput {...props} />;\n};\n","import React from 'react';\nimport { useStyles } from '@marigold/system';\nimport { ComponentProps } from '@marigold/types';\n\nexport type SliderProps = {\n variant?: string;\n} & ComponentProps<'input'>;\n\nexport const Slider: React.FC<SliderProps> = ({\n variant = 'slider',\n className,\n ...props\n}) => {\n const classNames = useStyles({\n variant: `form.${variant}`,\n css: {\n verticalAlign: 'middle',\n },\n className,\n });\n\n return <input type=\"range\" className={classNames} {...props} />;\n};\n","import React from 'react';\nimport { ArrowDown } from '@marigold/icons';\nimport { useStyles } from '@marigold/system';\nimport { ComponentProps } from '@marigold/types';\nimport { Box } from '../Box';\n\nexport type SelectProps = { variant?: string } & ComponentProps<'select'>;\n\nexport const Select: React.FC<SelectProps> = ({\n variant = 'default',\n children,\n ...props\n}) => {\n const iconStyles = useStyles({\n css: {\n alignSelf: 'center',\n pointerEvents: 'none',\n ml: '-28px',\n },\n });\n\n return (\n <Box display=\"flex\">\n <Box as=\"select\" variant={`select.${variant}`} {...props}>\n {children}\n </Box>\n <ArrowDown className={iconStyles} />\n </Box>\n );\n};\n","import React, { Children } from 'react';\nimport { ResponsiveStyleValue } from '@marigold/system';\nimport { Box } from '../Box';\nimport flattenChildren from 'react-keyed-flatten-children';\n\nexport type StackProps = {\n className?: string;\n space?: ResponsiveStyleValue<number | string>;\n align?: 'left' | 'right' | 'center';\n title?: string; // For Testing\n};\n\nexport const Stack: React.FC<StackProps> = ({\n space = 0,\n align = 'left',\n children,\n ...props\n}) => {\n let stackItems = flattenChildren(children);\n let display = 'flex';\n let flexDirection = 'column';\n let alignItems = align === 'right' ? 'flex-end' : 'center';\n if (align === 'left') {\n display = 'block';\n flexDirection = 'row';\n alignItems = 'flex-start';\n }\n\n return (\n <Box p={space} display={display} flexDirection={flexDirection} {...props}>\n {Children.map(stackItems, (child, index) => (\n <Box\n display={display}\n flexDirection={flexDirection}\n alignItems={alignItems}\n pt={space}\n mt={index === 0 ? -space! : 0}\n >\n {child}\n </Box>\n ))}\n </Box>\n );\n};\n","import React from 'react';\nimport { useStyles } from '@marigold/system';\nimport { ComponentPropsWithRef } from '@marigold/types';\nimport { Box, BoxProps } from '../Box';\n\nexport type TextProps = {\n className?: string;\n as?: 'p' | 'span' | 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n variant?: string;\n textColor?: string;\n} & ComponentPropsWithRef<'span'> &\n BoxProps;\n\nexport const Text: React.FC<TextProps> = ({\n as = 'span',\n variant = 'body',\n textColor = 'inherit',\n className,\n children,\n ...props\n}) => {\n const classNames = useStyles({\n variant: `text.${variant}`,\n css: {\n color: textColor,\n },\n className,\n });\n\n return (\n <Box as={as} className={classNames} {...props}>\n {children}\n </Box>\n );\n};\n","import React from 'react';\nimport { useStyles } from '@marigold/system';\nimport { Exclamation, Required } from '@marigold/icons';\nimport { ComponentProps } from '@marigold/types';\n\nimport { ValidationMessage } from '../ValidationMessage';\nimport { Label } from '../Label';\nimport { Box } from '../Box';\n\nexport type TextareaProps = {\n variant?: string;\n label?: string;\n htmlFor?: string;\n errorMessage?: string;\n required?: boolean;\n} & ComponentProps<'textarea'>;\n\nexport const Textarea: React.FC<TextareaProps> = ({\n variant = 'default',\n htmlFor = 'textarea',\n label,\n errorMessage,\n required = false,\n className = '',\n children,\n ...props\n}) => {\n const errorClassName = useStyles({ css: { color: 'error' } });\n const textareaClassNames = useStyles({\n css: { outlineColor: errorMessage && 'error' },\n className,\n });\n\n return (\n <Box>\n {label && (\n <Label htmlFor={htmlFor}>\n {label}\n {(errorMessage || required) && (\n <Required size={16} className={errorClassName} />\n )}\n </Label>\n )}\n <Box\n as=\"textarea\"\n {...props}\n display=\"block\"\n variant={`textarea.${variant}`}\n className={textareaClassNames}\n />\n {errorMessage && (\n <ValidationMessage>\n <Exclamation size={16} />\n {errorMessage}\n </ValidationMessage>\n )}\n </Box>\n );\n};\n","import React from 'react';\nimport { Box } from '../Box';\n\nexport type ContainerProps = {\n className?: string;\n title?: string; // Used for testing.\n};\n\nexport const Container: React.FC<ContainerProps> = ({ children, ...props }) => (\n <Box {...props} width=\"100%\">\n {children}\n </Box>\n);\n"],"names":["Box","forwardRef","ref","variant","as","children","className","display","height","width","minWidth","maxWidth","position","top","bottom","right","left","zIndex","p","px","py","pt","pb","pl","pr","m","mx","my","mt","mb","ml","mr","flexDirection","flexWrap","flexShrink","flexGrow","alignItems","justifyContent","bg","border","borderRadius","boxShadow","opacity","overflow","transition","props","cn","useStyles","element","css","createElement","Alert","classNames","bgColor","iconClassName","icon","React","Check","size","color","Notification","Exclamation","Badge","borderColor","Button","Label","Checkbox","id","label","required","checkboxStyles","checkboxIconStyles","verticalAlign","cursor","checkbox","type","checked","SquareChecked","SquareUnchecked","htmlFor","Required","Column","Columns","space","horizontalAlign","columnItems","flattenChildren","childClassNames","justify","Children","map","child","cloneElement","Dialog","onClose","onClick","Close","Divider","Input","ValidationMessage","Field","error","labelClassName","errorClassName","Heading","Hidden","show","Image","Link","Menu","itemStyles","textAlign","MenuItem","Message","messageTitle","Info","RadioIcon","radioIconStyle","ariaHidden","CircleChecked","CircleUnchecked","RadioInput","radioStyle","Radio","Slider","Select","iconStyles","alignSelf","pointerEvents","ArrowDown","Stack","align","stackItems","index","Text","textColor","Textarea","errorMessage","textareaClassNames","outlineColor","Container"],"mappings":"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"}
1
+ {"version":3,"file":"components.esm.js","sources":["../src/Inline/Inline.tsx","../src/Stack/Stack.tsx","../src/ActionGroup/ActionGroup.tsx","../src/Alert/Alert.tsx","../src/Badge/Badge.tsx","../src/Button/Button.tsx","../src/Card/Card.tsx","../src/Checkbox/CheckboxIcons.tsx","../src/Label/Label.tsx","../src/ValidationMessage/ValidationMessage.tsx","../src/Checkbox/Checkbox.tsx","../src/Column/Column.tsx","../src/Columns/Columns.tsx","../src/Text/Text.tsx","../src/Dialog/ModalDialog.tsx","../src/Dialog/Dialog.tsx","../src/Divider/Divider.tsx","../src/Input/Input.tsx","../src/Field/Field.tsx","../src/Image/Image.tsx","../src/Link/Link.tsx","../src/Menu/Menu.tsx","../src/MenuItem/MenuItem.tsx","../src/Message/Message.tsx","../src/Provider/MarigoldProvider.tsx","../src/Radio/RadioIcon.tsx","../src/Radio/Radio.tsx","../src/Slider/Slider.tsx","../src/Select/Option.tsx","../src/Select/ListBoxSection.tsx","../src/Select/ListBox.tsx","../src/Select/Popover.tsx","../src/Select/Select.tsx","../src/Textarea/Textarea.tsx","../src/Container/Container.tsx"],"sourcesContent":["import React, { Children } from 'react';\nimport flattenChildren from 'react-keyed-flatten-children';\n\nimport { ResponsiveStyleValue } from '@marigold/system';\n\nimport { Box } from '../Box';\n\nexport type InlineProps = {\n space?: ResponsiveStyleValue<string>;\n align?: 'top' | 'center' | 'bottom';\n};\n\nconst ALIGNMENT = {\n top: 'flex-start',\n center: 'center',\n bottom: 'flex-end',\n};\n\nexport const Inline: React.FC<InlineProps> = ({\n space = 'none',\n align = 'center',\n children,\n ...props\n}) => (\n <Box\n display=\"inline-flex\"\n css={{ '> * + *': { pl: space } }}\n alignItems={ALIGNMENT[align]}\n {...props}\n >\n {Children.map(\n flattenChildren(children) as unknown as React.ReactElement,\n (child: React.ReactElement) => (\n <Box>{React.cloneElement(child, {}, child.props.children)}</Box>\n )\n )}\n </Box>\n);\n","import React, { Children } from 'react';\nimport flattenChildren from 'react-keyed-flatten-children';\n\nimport { ResponsiveStyleValue } from '@marigold/system';\n\nimport { Box } from '../Box';\n\nexport type StackProps = {\n space?: ResponsiveStyleValue<string>;\n align?: 'left' | 'right' | 'center';\n};\n\nconst ALIGNMENT = {\n left: 'flex-start',\n center: 'center',\n right: 'flex-end',\n};\n\nexport const Stack: React.FC<StackProps> = ({\n space = 'none',\n align = 'left',\n children,\n ...props\n}) => (\n <Box\n {...props}\n display=\"flex\"\n flexDirection=\"column\"\n alignItems={ALIGNMENT[align]}\n css={{ '> * + *': { pt: space } }}\n >\n {Children.map(\n flattenChildren(children) as unknown as React.ReactElement,\n (child: React.ReactElement) => (\n <Box>{React.cloneElement(child, {}, child.props.children)}</Box>\n )\n )}\n </Box>\n);\n","import React from 'react';\n\nimport { ResponsiveStyleValue } from '@marigold/system';\nimport { ComponentProps } from '@marigold/types';\n\nimport { Inline } from '../Inline';\nimport { Stack } from '../Stack';\n\n// Props\n// ---------------\nexport type ActionGroupProps = {\n space?: ResponsiveStyleValue<string>;\n verticalAlignment?: boolean;\n} & ComponentProps<'div'>;\n\n// Component\n// ---------------\nexport const ActionGroup: React.FC<ActionGroupProps> = ({\n space = 'none',\n verticalAlignment = false,\n children,\n ...props\n}) =>\n verticalAlignment ? (\n <Stack space={space} {...props}>\n {children}\n </Stack>\n ) : (\n <Inline space={space} {...props}>\n {children}\n </Inline>\n );\n","import React from 'react';\nimport { Exclamation, Check, Notification } from '@marigold/icons';\nimport { type ComponentProps } from '@marigold/types';\n\nimport { Box } from '../Box';\n\nconst ICON_MAP = {\n success: Check,\n warning: Notification,\n error: Exclamation,\n} as const;\n\nexport type AlertVariants = keyof typeof ICON_MAP;\n\n// Theme Extension\n// ---------------\nexport interface AlertThemeExtension<Value> {\n alert?: {\n [key in AlertVariants]?: Value;\n };\n}\n\n// Props\n// ---------------\nexport type AlertProps = {\n variant?: AlertVariants;\n} & ComponentProps<'div'>;\n\n// Component\n// ---------------\nexport const Alert: React.FC<AlertProps> = ({\n variant = 'success',\n children,\n ...props\n}) => {\n const Icon = ICON_MAP[variant];\n\n return (\n <Box {...props} display=\"flex\" variant={`alert.${variant}`}>\n <Box\n display=\"inline-block\"\n alignItems=\"center\"\n width=\"32px\"\n height=\"32px\"\n bg={variant}\n >\n <Box as={Icon} size={12} color=\"#fff\" bg={variant} m={10} />\n </Box>\n <Box mx=\"16px\">{children}</Box>\n </Box>\n );\n};\n","import React from 'react';\nimport { ComponentProps } from '@marigold/types';\nimport { Box } from '../Box';\n\n// Theme Extension\n// ---------------\nexport interface BadgeThemeExtension<Value> {\n badge?: {\n [key: string]: Value;\n };\n}\n\n// Props\n// ---------------\nexport type BadgeProps = {\n variant?: string;\n bgColor?: string;\n borderColor?: string;\n} & ComponentProps<'div'>;\n\n// Component\n// ---------------\nexport const Badge: React.FC<BadgeProps> = ({\n variant = '',\n bgColor = 'transparent',\n borderColor = 'transparent',\n children,\n ...props\n}) => (\n <Box\n css={{ bg: bgColor, borderColor: borderColor }}\n variant={`badge.${variant}`}\n {...props}\n >\n {children}\n </Box>\n);\n","import React, { forwardRef, RefObject } from 'react';\nimport { useButton } from '@react-aria/button';\nimport {\n PolymorphicComponentWithRef,\n PolymorphicPropsWithRef,\n} from '@marigold/types';\n\nimport { Box, BoxOwnProps } from '../Box';\n\n// Theme Extension\n// ---------------\nexport interface ButtonThemeExtension<Value> {\n button?: {\n [key: string]: Value;\n };\n}\n\n// Props\n// ---------------\nexport type ButtonProps = PolymorphicPropsWithRef<BoxOwnProps, 'button'>;\n\n// Component\n// ---------------\nexport const Button: PolymorphicComponentWithRef<BoxOwnProps, 'button'> =\n forwardRef(\n (\n {\n as = 'button',\n variant = 'primary',\n size = 'large',\n space = 'none',\n disabled,\n children,\n className,\n ...props\n },\n ref\n ) => {\n const { buttonProps } = useButton(\n {\n ...props,\n elementType: typeof as === 'string' ? as : 'span',\n isDisabled: disabled,\n },\n ref as RefObject<HTMLSpanElement>\n );\n\n return (\n <Box\n {...buttonProps}\n {...props}\n as={as}\n display=\"inline-flex\"\n alignItems=\"center\"\n variant={[`button.${variant}`, `button.${size}`]}\n className={className}\n ref={ref}\n css={{ columnGap: space }}\n >\n {children}\n </Box>\n );\n }\n );\n","import React from 'react';\nimport { ResponsiveStyleValue } from '@marigold/system';\nimport { ComponentProps } from '@marigold/types';\n\nimport { Box } from '../Box';\n\n// Theme Extension\n// ---------------\nexport interface CardThemeExtension<Value> {\n card?: {\n [key: string]: Value;\n };\n}\n\n// Props\n// ---------------\nexport type CardProps = {\n title?: string;\n width?: ResponsiveStyleValue<string>;\n variant?: string;\n} & ComponentProps<'div'>;\n\n// Component\n// ---------------\nexport const Card: React.FC<CardProps> = ({\n variant = '',\n title,\n width,\n className,\n children,\n ...props\n}) => {\n return (\n <Box\n {...props}\n variant={`card.${variant}`}\n maxWidth={width}\n className={className}\n >\n {title && (\n <Box as=\"h2\" variant=\"text.h2\" pb=\"small\">\n {title}\n </Box>\n )}\n {children}\n </Box>\n );\n};\n","import React from 'react';\nimport { conditional, State, SVG } from '@marigold/system';\n\nimport { Box } from '../Box';\n\n// Checkbox Icon\n// ---------------\nexport type CheckboxIconProps = {\n variant?: string;\n checked?: boolean;\n disabled?: boolean;\n error?: boolean;\n children?: never;\n};\n\nexport const CheckboxIcon: React.FC<CheckboxIconProps> = ({\n variant = '',\n checked = false,\n disabled = false,\n error = false,\n}) => {\n const conditionalStates: State = disabled\n ? {\n disabled: disabled,\n }\n : {\n checked: checked,\n error: error,\n };\n\n return (\n <SVG\n width=\"16\"\n height=\"32\"\n viewBox=\"0 0 16 32\"\n fill=\"none\"\n aria-hidden=\"true\"\n >\n <Box\n as=\"rect\"\n x=\"0.5\"\n y=\"8.5\"\n width=\"15px\"\n height=\"15px\"\n rx=\"1.5\"\n variant={conditional(`checkbox.${variant}`, conditionalStates)}\n />\n {checked && (\n <Box\n __baseCSS={{ fill: 'gray00' }}\n as=\"path\"\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M13.9571 12.8338L12.4085 11.2852L6.08699 17.6007L3.59887 15.1126L2.04163 16.6588L6.08682 20.704L13.9571 12.8338Z\"\n />\n )}\n </SVG>\n );\n};\n","import React from 'react';\n\nimport { ComponentProps } from '@marigold/types';\nimport { Required } from '@marigold/icons';\nimport { ResponsiveStyleValue } from '@marigold/system';\n\nimport { Box } from '../Box';\n\n// Theme Extension\n// ---------------\nexport interface LabelThemeExtension<Value> {\n label?: {\n [key: string]: Value;\n };\n}\n\n// LabelBase\n// ---------------\nexport type LabelBaseProps = {\n htmlFor?: string;\n variant?: string;\n required?: boolean;\n color?: ResponsiveStyleValue<string>;\n} & ComponentProps<'label'>;\n\nexport const LabelBase: React.FC<LabelProps> = ({\n variant = 'above',\n required,\n color = 'text',\n children,\n ...props\n}) => {\n return (\n <Box\n {...props}\n as=\"label\"\n __baseCSS={{ color: color }}\n variant={`label.${variant}`}\n >\n {children}\n </Box>\n );\n};\n\n// Label\n// ---------------\nexport type LabelProps = {\n required?: boolean;\n} & LabelBaseProps;\n\nexport const Label: React.FC<LabelProps> = ({\n required,\n children,\n ...props\n}) => {\n return required ? (\n <Box as=\"span\" display=\"inline-flex\" alignItems=\"center\">\n <LabelBase {...props}>{children}</LabelBase>\n {required && <Box as={Required} size={16} css={{ color: 'error' }} />}\n </Box>\n ) : (\n <LabelBase {...props}>{children}</LabelBase>\n );\n};\n","import React from 'react';\nimport { ComponentProps } from '@marigold/types';\n\nimport { Box } from '../Box';\n\n// Theme Extension\n// ---------------\nexport interface ValidationMessageThemeExtension<Value> {\n validation?: {\n [key: string]: Value;\n };\n}\n\n// Props\n// ---------------\nexport type ValidationMessageProps = {\n variant?: string;\n} & ComponentProps<'span'>;\n\n// Component\n// ---------------\nexport const ValidationMessage: React.FC<ValidationMessageProps> = ({\n variant = 'error',\n children,\n className,\n ...props\n}) => {\n return (\n <Box\n as=\"span\"\n display=\"flex\"\n alignItems=\"center\"\n variant={`validation.${variant}`}\n className={className}\n {...props}\n >\n {children}\n </Box>\n );\n};\n","import React from 'react';\nimport { useFocusRing } from '@react-aria/focus';\nimport { VisuallyHidden } from '@react-aria/visually-hidden';\nimport { useCheckbox } from '@react-aria/checkbox';\nimport { useToggleState } from '@react-stately/toggle';\nimport { ToggleProps } from '@react-types/checkbox';\n\nimport { ComponentProps } from '@marigold/types';\nimport { Exclamation } from '@marigold/icons';\n\nimport { CheckboxIcon, CheckboxIconProps } from './CheckboxIcons';\nimport { Box } from '../Box';\nimport { Label } from '../Label';\nimport { ValidationMessage } from '../ValidationMessage';\n\n// Theme Extension\n// ---------------\nexport interface CheckboxThemeExtension<Value> {\n checkbox?: {\n [key: string]: Value;\n };\n}\n\n// Checkbox Input\n// ---------------\ntype CheckboxInputProps = CheckboxIconProps &\n ToggleProps &\n ComponentProps<'input'>;\n\nconst CheckboxInput: React.FC<CheckboxInputProps> = ({ error, ...props }) => {\n const state = useToggleState(props);\n const ref = React.useRef<HTMLInputElement>(null);\n const { inputProps } = useCheckbox(props, state, ref);\n const { focusProps } = useFocusRing();\n\n return (\n <Box pr=\"xsmall\">\n <VisuallyHidden>\n <Box\n as=\"input\"\n type=\"checkbox\"\n disabled={props.disabled}\n {...inputProps}\n {...focusProps}\n ref={ref}\n {...props}\n />\n </VisuallyHidden>\n <CheckboxIcon\n checked={props.checked}\n variant={props.variant}\n disabled={props.disabled}\n error={error}\n />\n </Box>\n );\n};\n\n// Checkbox\n// ---------------\nexport type CheckboxProps = {\n id: string;\n label: string;\n required?: boolean;\n labelVariant?: string;\n error?: boolean;\n errorMessage?: string;\n} & CheckboxInputProps;\n\nexport const Checkbox: React.FC<CheckboxProps> = ({\n label,\n required,\n labelVariant = 'inline',\n error,\n errorMessage,\n ...props\n}) => {\n return (\n <>\n <Box\n as={Label}\n __baseCSS={{\n ':hover': { cursor: props.disabled ? 'not-allowed' : 'pointer' },\n }}\n htmlFor={props.id}\n required={required}\n variant={`label.${labelVariant}`}\n color={props.disabled ? 'disabled' : 'text'}\n >\n <Box as={CheckboxInput} error={error} {...props} />\n {label}\n </Box>\n {error && errorMessage && (\n <ValidationMessage>\n <Exclamation size={16} />\n {errorMessage}\n </ValidationMessage>\n )}\n </>\n );\n};\n","import React from 'react';\nimport { Box } from '../Box';\n\ntype WidthValues = 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12;\n\nexport type ColumnProps = {\n className?: string;\n width?: WidthValues | WidthValues[];\n};\n\nconst transform = (width: WidthValues | WidthValues[]) => {\n if (Array.isArray(width)) {\n return width.map(v => `${(v / 12) * 100}%`);\n }\n\n return `${(width / 12) * 100}%`;\n};\n\nexport const Column: React.FC<ColumnProps> = ({\n width = 12,\n children,\n ...props\n}) => (\n <Box {...props} width={transform(width)}>\n {children}\n </Box>\n);\n","import React, { Children } from 'react';\nimport { Box } from '../Box';\nimport flattenChildren from 'react-keyed-flatten-children';\nimport { ResponsiveStyleValue, useTheme } from '@marigold/system';\n\ntype ColumnsProps = {\n className?: string;\n space?: ResponsiveStyleValue<string>;\n horizontalAlign?: 'left' | 'right' | 'center';\n verticalAlign?: 'top' | 'bottom' | 'center';\n};\n\nconst useAlignment = (direction: string) => {\n switch (direction) {\n case 'right':\n return 'flex-end';\n case 'bottom':\n return 'flex-end';\n case 'center':\n return 'center';\n }\n return 'flex-start';\n};\n\nexport const Columns: React.FC<ColumnsProps> = ({\n space = 'none',\n horizontalAlign = 'left',\n verticalAlign = 'top',\n className,\n children,\n ...props\n}) => {\n const justifyContent = useAlignment(horizontalAlign);\n const alignItems = useAlignment(verticalAlign);\n\n /**\n * transform space string to space value from theme\n */\n const { css } = useTheme();\n const spaceObject = css({ space }) as Object;\n const spaceValue = Object.values(spaceObject)[0];\n\n return (\n <Box p={space} display=\"flex\" className={className}>\n <Box\n width={`calc(100% + ${spaceValue}px)`}\n m={`${-spaceValue / 2}px`}\n display=\"flex\"\n flexWrap=\"wrap\"\n alignItems={alignItems}\n justifyContent={justifyContent}\n {...props}\n >\n {Children.map(\n flattenChildren(children) as unknown as React.ReactElement,\n (child: React.ReactElement) => {\n return React.cloneElement(\n child,\n {},\n <Box css={{ p: `${spaceValue / 2}px` }}>\n {child.props.children}\n </Box>\n );\n }\n )}\n </Box>\n </Box>\n );\n};\n","import React, { forwardRef } from 'react';\nimport { ResponsiveStyleValue } from '@marigold/system';\nimport {\n PolymorphicComponentWithRef,\n PolymorphicPropsWithRef,\n} from '@marigold/types';\n\nimport { Box, BoxOwnProps } from '../Box';\n\n// Theme Extension\n// ---------------\nexport interface TextThemeExtension<Value> {\n text?: {\n [key: string]: Value;\n };\n}\n\n// Props\n// ---------------\nexport type TextOwnProps = {\n align?: ResponsiveStyleValue<string>;\n color?: ResponsiveStyleValue<string>;\n cursor?: ResponsiveStyleValue<string>;\n outline?: ResponsiveStyleValue<string>;\n userSelect?: ResponsiveStyleValue<string>;\n} & BoxOwnProps;\n\nexport type TextProps = PolymorphicPropsWithRef<TextOwnProps, 'span'>;\n\n// Component\n// ---------------\nexport const Text: PolymorphicComponentWithRef<TextOwnProps, 'span'> =\n forwardRef(\n (\n {\n as = 'span',\n variant = 'body',\n children,\n className,\n align,\n color,\n cursor,\n outline,\n userSelect,\n ...props\n },\n ref\n ) => (\n <Box\n {...props}\n as={as}\n variant={`text.${variant}`}\n css={{ textAlign: align, color, cursor, outline, userSelect }}\n className={className}\n ref={ref}\n >\n {children}\n </Box>\n )\n );\n","import React, { RefObject } from 'react';\nimport {\n useOverlay,\n usePreventScroll,\n useModal,\n OverlayProps,\n} from '@react-aria/overlays';\nimport { useDialog } from '@react-aria/dialog';\nimport { FocusScope } from '@react-aria/focus';\nimport { AriaDialogProps } from '@react-types/dialog';\n\nimport { Box } from '../Box';\n\n// Props\n// ---------------\nexport type ModalDialogProps = {\n variant?: string;\n backdropVariant?: string;\n} & OverlayProps &\n AriaDialogProps;\n\n// Component\n// ---------------\nexport const ModalDialog: React.FC<ModalDialogProps> = ({\n variant,\n backdropVariant = 'backdrop',\n children,\n ...props\n}) => {\n const { isDismissable, isOpen, onClose, ...restProps } = props;\n\n // Handle interacting outside the dialog and pressing\n // the Escape key to close the modal.\n const ref = React.useRef<HTMLElement>() as RefObject<HTMLElement>;\n const { overlayProps, underlayProps } = useOverlay(\n { isDismissable, isOpen, onClose },\n ref\n );\n\n // Prevent scrolling while the modal is open, and hide content\n // outside the modal from screen readers.\n usePreventScroll();\n\n const { modalProps } = useModal();\n const { dialogProps } = useDialog(props, ref);\n\n return (\n <Box\n __baseCSS={{\n display: 'grid',\n placeItems: 'center',\n position: 'fixed',\n zIndex: 100,\n top: 0,\n left: 0,\n bottom: 0,\n right: 0,\n }}\n variant={`dialog.${backdropVariant}`}\n {...underlayProps}\n >\n <FocusScope contain restoreFocus autoFocus>\n <Box\n {...overlayProps}\n {...dialogProps}\n {...modalProps}\n ref={ref}\n variant={variant ? `dialog.${variant}` : `dialog`}\n {...restProps}\n >\n {children}\n </Box>\n </FocusScope>\n </Box>\n );\n};\n","import React, { RefObject } from 'react';\nimport { ComponentProps } from '@marigold/types';\nimport { useOverlayTriggerState } from '@react-stately/overlays';\nimport { OverlayContainer } from '@react-aria/overlays';\nimport { useButton } from '@react-aria/button';\nimport { Close } from '@marigold/icons';\n\nimport { Box } from '../Box';\nimport { Button } from '../Button';\nimport { Text } from '../Text';\n\nimport { ModalDialog, ModalDialogProps } from './ModalDialog';\n\n// Props\n// ---------------\nexport type DialogProps = {\n backdropVariant?: string;\n close: ComponentProps<typeof Button>['onClick'];\n isOpen: boolean;\n title?: string;\n variant?: string;\n} & ModalDialogProps &\n ComponentProps<'div'>;\n\n// Component\n// ---------------\nexport const Dialog: React.FC<DialogProps> = ({\n backdropVariant,\n children,\n className,\n close,\n isOpen,\n title,\n variant,\n ...props\n}) => {\n const closeButtonRef = React.useRef<HTMLElement>() as RefObject<HTMLElement>;\n\n // useButton ensures that focus management is handled correctly,\n // across all browsers. Focus is restored to the button once the\n // dialog closes.\n const { buttonProps: closeButtonProps } = useButton(\n {\n onPress: () => close(),\n },\n closeButtonRef\n );\n\n return (\n <OverlayContainer>\n <ModalDialog\n variant={variant}\n backdropVariant={backdropVariant}\n isOpen={isOpen}\n onClose={close}\n isDismissable\n {...props}\n >\n <Box\n __baseCSS={{\n display: 'flex',\n justifyContent: 'space-between',\n borderRadius: 'small',\n pl: 'large',\n pb: 'large',\n }}\n className={className}\n >\n <Box pt=\"medium\">\n {title && (\n <Text as=\"h4\" variant=\"headline4\">\n {title}\n </Text>\n )}\n {children}\n </Box>\n <Box\n __baseCSS={{\n display: 'flex',\n justifyContent: 'flex-end',\n alignItems: 'start',\n paddingTop: 'xsmall',\n paddingX: 'xsmall',\n }}\n >\n <Box\n as={Button}\n __baseCSS={{\n color: 'text',\n bg: 'transparent',\n lineHeight: 'xsmall',\n px: 'xxsmall',\n ':hover': {\n color: 'text',\n bg: 'transparent',\n cursor: 'pointer',\n },\n ':focus': {\n outline: 0,\n },\n }}\n {...closeButtonProps}\n ref={closeButtonRef}\n >\n <Close size={16} />\n </Box>\n </Box>\n </Box>\n </ModalDialog>\n </OverlayContainer>\n );\n};\n\n// get the overlayTriggerState and openButton props for using the dialog component\nexport const useDialogButtonProps = () => {\n const state = useOverlayTriggerState({});\n const openButtonRef = React.useRef<HTMLElement>() as RefObject<HTMLElement>;\n const { buttonProps: openButtonProps } = useButton(\n {\n onPress: () => state.open(),\n },\n openButtonRef\n );\n\n return {\n state,\n openButtonProps,\n openButtonRef,\n };\n};\n","import React from 'react';\nimport { Box } from '../Box';\n\n// Theme Extension\n// ---------------\nexport interface DividerThemeExtension<Value> {\n divider?: {\n [key: string]: Value;\n };\n}\n\n// Props\n// ---------------\nexport type DividerProps = {\n className?: string;\n variant?: string;\n title?: string; // Should only be used for testing.\n};\n\n// Component\n// ---------------\nexport const Divider: React.FC<DividerProps> = ({\n variant = 'regular',\n ...props\n}) => <Box {...props} as=\"hr\" variant={`divider.${variant}`} />;\n","import React from 'react';\nimport { ComponentProps } from '@marigold/types';\nimport { Box } from '../Box';\n\n// Theme Extension\n// ---------------\nexport interface InputThemeExtension<Value> {\n input?: {\n [key: string]: Value;\n };\n}\n\n// Props\n// ---------------\nexport type InputProps = {\n variant?: string;\n} & ComponentProps<'input'>;\n\n// Component\n// ---------------\nexport const Input: React.FC<InputProps> = ({\n variant = '',\n type = 'text',\n ...props\n}) => <Box {...props} as=\"input\" type={type} variant={`input.${variant}`} />;\n","import React from 'react';\nimport { Exclamation } from '@marigold/icons';\nimport { ComponentProps } from '@marigold/types';\n\nimport { Input } from '../Input';\nimport { Label } from '../Label';\nimport { ValidationMessage } from '../ValidationMessage';\n\n// Props\n// ---------------\nexport type FieldProps = {\n variant?: string;\n labelVariant?: string;\n htmlFor: string;\n label: string;\n required?: boolean;\n error?: boolean;\n errorMessage?: string;\n disabled?: boolean;\n} & ComponentProps<'input'>;\n\n// Component\n// ---------------\nexport const Field: React.FC<FieldProps> = ({\n type = 'text',\n variant = '',\n labelVariant = 'above',\n htmlFor,\n label,\n required,\n error,\n errorMessage,\n disabled,\n ...props\n}) => {\n return (\n <>\n <Label variant={labelVariant} htmlFor={htmlFor} required={required}>\n {label}\n </Label>\n <Input\n {...props}\n type={type}\n id={htmlFor}\n disabled={disabled}\n variant={variant}\n />\n {error && errorMessage && (\n <ValidationMessage>\n <Exclamation size={16} />\n {errorMessage}\n </ValidationMessage>\n )}\n </>\n );\n};\n","import React from 'react';\nimport { ComponentProps } from '@marigold/types';\nimport { Box } from '../Box';\n\n// Theme Extension\n// ---------------\nexport interface ImageThemeExtension<Value> {\n image?: {\n [key: string]: Value;\n };\n}\n\n// Props\n// ---------------\nexport type ImageProps = {\n variant?: string;\n children?: never;\n} & ComponentProps<'img'>;\n\n// Component\n// ---------------\nexport const Image: React.FC<ImageProps> = ({\n variant = 'fullWidth',\n ...props\n}) => <Box {...props} as=\"img\" variant={`image.${variant}`} />;\n","import React, { useRef } from 'react';\nimport { useLink } from '@react-aria/link';\nimport { PolymorphicComponent, PolymorphicProps } from '@marigold/types';\n\nimport { Text, TextOwnProps } from '../Text';\n\n// Theme Extension\n// ---------------\nexport interface LinkThemeExtension<Value> {\n link?: Value;\n}\n\n// Props\n// ---------------\nexport type LinkOwnProps = { disabled?: boolean } & TextOwnProps;\nexport type LinkProps = PolymorphicProps<LinkOwnProps, 'a'>;\n\n// Component\n// ---------------\nexport const Link = (({\n as = 'a',\n variant = 'link',\n children,\n disabled,\n ...props\n}: LinkProps) => {\n const ref = useRef<any>();\n const { linkProps } = useLink(\n {\n // We typecast here because the element could very well be a `span`\n ...(props as PolymorphicProps<LinkOwnProps, any>),\n elementType: typeof as === 'string' ? as : 'span',\n isDisabled: disabled,\n },\n ref\n );\n\n return (\n <Text {...props} {...linkProps} as={as} variant={variant} ref={ref}>\n {children}\n </Text>\n );\n}) as PolymorphicComponent<LinkOwnProps, 'a'>;\n","import React from 'react';\nimport { ComponentProps } from '@marigold/types';\n\nimport { Button } from '../Button';\nimport { Box } from '../Box';\n\n// Theme Extension\n// ---------------\nexport interface MenuThemeExtension<Value> {\n menu?: Value;\n}\n\n// Props\n// ---------------\nexport type MenuProps = {\n variant?: string;\n label?: string;\n onClick: ComponentProps<typeof Button>['onClick'];\n show?: boolean;\n className?: string;\n title?: string; // For testing\n};\n\n// Component\n// ---------------\nexport const Menu: React.FC<MenuProps> = ({\n variant = 'default',\n label = 'Menu',\n onClick,\n show = false,\n children,\n ...props\n}) => {\n return (\n <Box variant={`menu.${variant}`} {...props}>\n <Button onClick={onClick} variant=\"menu\">\n {label}\n </Button>\n {show ? (\n <Box\n display=\"block\"\n position=\"absolute\"\n minWidth=\"120px\"\n borderRadius=\"2px\"\n >\n {children}\n </Box>\n ) : null}\n </Box>\n );\n};\n","import React from 'react';\nimport { ComponentProps } from '@marigold/types';\nimport { Link } from '../Link';\nimport { Box } from '../Box';\n\n// Theme Extension\n// ---------------\nexport interface MenuItemThemeExtension<Value> {\n menuItem?: {\n [key: string]: Value;\n };\n}\n\n// Props\n// ---------------\nexport type MenuItemProps = {\n variant?: string;\n} & ComponentProps<typeof Link>;\n\n// Component\n// ---------------\nexport const MenuItem: React.FC<MenuItemProps> = ({\n variant = 'default',\n className,\n children,\n ...props\n}) => {\n return (\n <Box variant={`menuItem.${variant}`} className={className}>\n <Link variant=\"menuItemLink\" {...props}>\n {children}\n </Link>\n </Box>\n );\n};\n","import React from 'react';\nimport { Exclamation, Info, Notification } from '@marigold/icons';\nimport { ComponentProps } from '@marigold/types';\nimport { Box } from '../Box';\nimport { Text } from '../Text';\n\n// Theme Extension\n// ---------------\nexport interface MessageThemeExtension<Value> {\n message?: {\n [key: string]: Value;\n };\n}\n\n// Props\n// ---------------\nexport type MessageProps = {\n messageTitle: string;\n variant?: string;\n} & ComponentProps<'div'>;\n\n// Component\n// ---------------\nexport const Message: React.FC<MessageProps> = ({\n messageTitle,\n variant = 'info',\n className,\n children,\n ...props\n}) => {\n var icon = <Info />;\n if (variant === 'warning') {\n icon = <Notification />;\n }\n if (variant === 'error') {\n icon = <Exclamation />;\n }\n\n return (\n <Box\n display=\"inline-block\"\n variant={`message.${variant}`}\n className={className}\n {...props}\n >\n <Box display=\"flex\" alignItems=\"center\" variant=\"message.title\">\n {icon}\n <Text as=\"h4\" variant=\"headline4\">\n {messageTitle}\n </Text>\n </Box>\n <Box css={{ color: 'black' }}>{children}</Box>\n </Box>\n );\n};\n","import React from 'react';\nimport { OverlayProvider } from '@react-aria/overlays';\nimport {\n Theme,\n Global,\n ThemeProvider,\n ThemeProviderProps,\n useTheme,\n __defaultTheme,\n} from '@marigold/system';\n\n// Theme Extension\n// ---------------\nexport interface RootThemeExtension<Value> {\n root?: {\n body?: Value;\n html?: Value;\n };\n}\n\n// Props\n// ---------------\nexport interface MarigoldProviderProps<T extends Theme>\n extends ThemeProviderProps<T> {}\n\n// Provider\n// ---------------\nexport function MarigoldProvider<T extends Theme>({\n theme,\n children,\n}: MarigoldProviderProps<T>) {\n const outer = useTheme();\n const isTopLevel = outer.theme === __defaultTheme;\n\n return (\n <ThemeProvider theme={theme}>\n {isTopLevel ? (\n <>\n <Global />\n <OverlayProvider>{children}</OverlayProvider>\n </>\n ) : (\n children\n )}\n </ThemeProvider>\n );\n}\n","import React from 'react';\nimport { conditional, State, SVG } from '@marigold/system';\n\nimport { Box } from '../Box';\n\n// Radio Icon\n// ---------------\nexport type RadioIconProps = {\n variant?: string;\n checked?: boolean;\n disabled?: boolean;\n error?: boolean;\n children?: never;\n};\n\nexport const RadioIcon: React.FC<RadioIconProps> = ({\n variant = '',\n checked = false,\n disabled = false,\n error = false,\n}) => {\n const conditionalStates: State = disabled\n ? {\n disabled: disabled,\n }\n : {\n checked: checked,\n error: error,\n };\n\n return (\n <SVG\n width=\"16\"\n height=\"32\"\n viewBox=\"0 0 16 32\"\n fill=\"none\"\n aria-hidden=\"true\"\n >\n <Box\n variant={conditional(`radio.${variant}`, conditionalStates)}\n as=\"circle\"\n cx=\"8\"\n cy=\"16\"\n r=\"7.5\"\n />\n {checked && <circle fill=\"white\" cx=\"8\" cy=\"16\" r=\"3\" />}\n </SVG>\n );\n};\n","import React from 'react';\nimport { ComponentProps } from '@marigold/types';\nimport { Exclamation } from '@marigold/icons';\nimport { useFocusRing } from '@react-aria/focus';\nimport { VisuallyHidden } from '@react-aria/visually-hidden';\n\nimport { RadioIcon, RadioIconProps } from './RadioIcon';\nimport { Box } from '../Box';\nimport { Label } from '../Label';\nimport { ValidationMessage } from '../ValidationMessage';\n\n// Theme Extension\n// ---------------\nexport interface RadioThemeExtension<Value> {\n radio?: {\n [key: string]: Value;\n };\n}\n\n// Radio Input\n// ---------------\ntype RadioInputProps = RadioIconProps & ComponentProps<'input'>;\n\nconst RadioInput: React.FC<RadioInputProps> = ({ error, ...props }) => {\n const { focusProps } = useFocusRing();\n\n return (\n <Box pr=\"xsmall\">\n <VisuallyHidden>\n <input\n type=\"radio\"\n disabled={props.disabled}\n {...focusProps}\n {...props}\n />\n </VisuallyHidden>\n <RadioIcon\n variant={props.variant}\n disabled={props.disabled}\n checked={props.checked}\n error={error}\n />\n </Box>\n );\n};\n\n// Radio\n// ---------------\nexport type RadioProps = {\n id: string;\n label: string;\n required?: boolean;\n labelVariant?: string;\n error?: boolean;\n errorMessage?: string;\n} & RadioInputProps;\n\nexport const Radio: React.FC<RadioProps> = ({\n label,\n required,\n labelVariant = 'inline',\n error,\n errorMessage,\n ...props\n}) => (\n <>\n <Box\n as={Label}\n htmlFor={props.id}\n required={required}\n variant={`label.${labelVariant}`}\n css={\n props.disabled\n ? { color: 'disabled', ':hover': { cursor: 'not-allowed' } }\n : { color: 'text', ':hover': { cursor: 'pointer' } }\n }\n >\n <Box as={RadioInput} error={error} {...props} />\n {label}\n </Box>\n {error && errorMessage && (\n <ValidationMessage>\n <Exclamation size={16} />\n {errorMessage}\n </ValidationMessage>\n )}\n </>\n);\n","import React from 'react';\nimport { ComponentProps } from '@marigold/types';\n\nimport { Box } from '../Box';\n\n// Theme Extension\n// ---------------\nexport interface SliderThemeExtension<Value> {\n slider?: {\n [key: string]: Value;\n };\n}\n\n// Props\n// ---------------\nexport type SliderProps = {\n variant?: string;\n} & ComponentProps<'input'>;\n\n// Component\n// ---------------\nexport const Slider: React.FC<SliderProps> = ({\n variant = '',\n className,\n ...props\n}) => (\n <Box\n as=\"input\"\n type=\"range\"\n css={{ verticalAlign: 'middle' }}\n variant={`slider.${variant}`}\n className={className}\n {...props}\n />\n);\n","import React, { useEffect, useRef, useState } from 'react';\nimport type { ListState } from '@react-stately/list';\nimport type { Node } from '@react-types/shared';\nimport { useOption } from '@react-aria/listbox';\n\nimport { Box } from '../Box';\n\ninterface OptionProps {\n item: Node<unknown>;\n state: ListState<unknown>;\n}\n\nexport const Option = ({ item, state }: OptionProps) => {\n const ref = useRef<HTMLLIElement>(null);\n const [disabled, setDisabled] = useState(false);\n const { optionProps, isSelected } = useOption(\n {\n key: item.key,\n },\n state,\n ref\n );\n\n useEffect(() => {\n for (const key of state.disabledKeys.values()) {\n if (key === item.key) {\n setDisabled(true);\n }\n }\n }, [state.disabledKeys, item.key]);\n\n return (\n <Box\n as=\"li\"\n {...optionProps}\n ref={ref}\n variant={\n isSelected\n ? 'select.option.selected'\n : disabled\n ? 'select.option.disabled'\n : 'select.option'\n }\n >\n {item.rendered}\n </Box>\n );\n};\n","import React from 'react';\nimport { useListBoxSection } from '@react-aria/listbox';\nimport type { ListState } from '@react-stately/list';\nimport type { Node } from '@react-types/shared';\n\nimport { Box } from '../Box';\nimport { Option } from './Option';\n\ninterface SectionProps {\n section: Node<unknown>;\n state: ListState<unknown>;\n}\n\nexport const ListBoxSection = ({ section, state }: SectionProps) => {\n const { itemProps, headingProps, groupProps } = useListBoxSection({\n heading: section.rendered,\n 'aria-label': section['aria-label'],\n });\n\n return (\n <Box\n as=\"li\"\n {...itemProps}\n css={{\n cursor: 'not-allowed',\n }}\n >\n {section.rendered && (\n <Box as=\"span\" {...headingProps} variant={'select.section'}>\n {section.rendered}\n </Box>\n )}\n <Box as=\"ul\" {...groupProps}>\n {[...section.childNodes].map(node => (\n <Option key={node.key} item={node} state={state} />\n ))}\n </Box>\n </Box>\n );\n};\n","import React, { useRef } from 'react';\nimport { useListBox } from '@react-aria/listbox';\nimport type { AriaListBoxOptions } from '@react-aria/listbox';\nimport type { ListState } from '@react-stately/list';\n\nimport { Box } from '../Box';\nimport { Option } from './Option';\nimport { ListBoxSection } from './ListBoxSection';\n\ninterface ListBoxProps extends AriaListBoxOptions<unknown> {\n state: ListState<unknown>;\n error?: boolean;\n}\n\nexport const ListBox = (props: ListBoxProps) => {\n const ref = useRef<HTMLUListElement>(null);\n const { state, error } = props;\n const { listBoxProps } = useListBox(props, state, ref);\n\n return (\n <Box\n as=\"ul\"\n p=\"none\"\n css={{\n listStyle: 'none',\n }}\n {...listBoxProps}\n variant={error ? 'select.listbox.error' : 'select.listbox'}\n ref={ref}\n >\n {[...state.collection].map(item =>\n item.type === 'section' ? (\n <ListBoxSection key={item.key} section={item} state={state} />\n ) : (\n <Option key={item.key} item={item} state={state} />\n )\n )}\n </Box>\n );\n};\n","import React, { forwardRef, RefObject } from 'react';\nimport { FocusScope } from '@react-aria/focus';\nimport {\n DismissButton,\n OverlayContainer,\n useModal,\n useOverlay,\n} from '@react-aria/overlays';\nimport { mergeProps } from '@react-aria/utils';\n\nimport { Box } from '../Box';\n\ninterface PopoverProps {\n isOpen?: boolean;\n onClose?: () => void;\n ref?: React.Ref<HTMLDivElement>;\n className?: string;\n}\n\nexport const Popover: React.FC<PopoverProps> = forwardRef(\n ({ children, className, isOpen, onClose, ...otherProps }, ref) => {\n // Handle events that should cause the popup to close,\n const { overlayProps } = useOverlay(\n {\n isOpen,\n onClose,\n shouldCloseOnBlur: true,\n isDismissable: true,\n },\n ref as RefObject<HTMLElement>\n );\n // Hide content outside the modal from screen readers.\n const { modalProps } = useModal();\n\n return (\n <OverlayContainer>\n <FocusScope restoreFocus>\n <Box\n {...mergeProps(overlayProps, otherProps, modalProps)}\n className={className}\n ref={ref}\n >\n {children}\n <DismissButton onDismiss={onClose} />\n </Box>\n </FocusScope>\n </OverlayContainer>\n );\n }\n);\n","import React, { Ref, RefObject, useRef } from 'react';\nimport { useSelectState } from '@react-stately/select';\nimport { useButton } from '@react-aria/button';\nimport { mergeProps } from '@react-aria/utils';\nimport { useFocusRing } from '@react-aria/focus';\nimport { HiddenSelect, useSelect } from '@react-aria/select';\nimport type { AriaSelectProps } from '@react-types/select';\nimport { useOverlayTriggerState } from '@react-stately/overlays';\nimport { useOverlayTrigger, useOverlayPosition } from '@react-aria/overlays';\nimport { SingleSelection } from '@react-types/shared';\n\nimport { ComponentProps } from '@marigold/types';\nimport { ArrowDown, ArrowUp, Exclamation, Required } from '@marigold/icons';\nimport { ResponsiveStyleValue } from '@marigold/system';\n\nimport { Box } from '../Box';\nimport { Label } from '../Label';\nimport { ValidationMessage } from '../ValidationMessage';\nimport { ListBox } from './ListBox';\nimport { Popover } from './Popover';\n\n// Theme Extension\n// ---------------\nexport interface SelectThemeExtension<Value> {\n select?: {\n __default: Value;\n disabled?: Value;\n listbox?: {\n __default: Value;\n error?: Value;\n };\n section?: Value;\n option?: Value;\n };\n}\n\n// Props\n// ---------------\nexport type SelectProps = {\n labelVariant?: string;\n placeholder?: string;\n disabled?: boolean;\n required?: boolean;\n width?: ResponsiveStyleValue<number | string>;\n error?: boolean;\n errorMessage?: string;\n} & ComponentProps<'select'> &\n AriaSelectProps<object> &\n SingleSelection;\n\n// Component\n// ---------------\nexport const Select = ({\n labelVariant = 'above',\n placeholder = 'Select an option',\n disabled,\n required,\n error,\n errorMessage,\n width,\n className,\n ...props\n}: SelectProps) => {\n const state = useSelectState(props);\n const overlayTriggerState = useOverlayTriggerState({});\n const triggerRef = useRef<HTMLElement>() as RefObject<HTMLElement>;\n const overlayRef = useRef<HTMLDivElement>();\n\n // Get props for the overlay\n const { overlayProps } = useOverlayTrigger(\n { type: 'listbox' },\n overlayTriggerState,\n triggerRef\n );\n // Get popover positioning props relative to the trigger\n const { overlayProps: positionProps } = useOverlayPosition({\n targetRef: triggerRef,\n overlayRef: overlayRef as RefObject<HTMLElement>,\n placement: 'bottom',\n shouldFlip: false,\n isOpen: state.isOpen,\n onClose: state.close,\n });\n // Get props for child elements from useSelect\n const { labelProps, triggerProps, valueProps, menuProps } = useSelect(\n props,\n state,\n triggerRef\n );\n // Get props for the button based on the trigger props from useSelect\n const { buttonProps } = useButton(triggerProps, triggerRef);\n\n const { focusProps } = useFocusRing();\n\n return (\n <Box position=\"relative\" display=\"inline-block\" width={width && width}>\n {props.label && (\n <Box>\n <Label {...labelProps} htmlFor={labelProps.id} variant={labelVariant}>\n {required ? (\n <Box as=\"span\" display=\"inline-flex\" alignItems=\"center\">\n {props.label}\n <Box as={Required} size={16} css={{ color: 'error' }} />\n </Box>\n ) : (\n props.label\n )}\n </Label>\n </Box>\n )}\n <HiddenSelect\n state={state}\n triggerRef={triggerRef}\n label={props.label}\n name={props.name}\n isDisabled={disabled}\n />\n <Box\n as=\"button\"\n {...mergeProps(buttonProps, focusProps)}\n ref={triggerRef as RefObject<HTMLButtonElement>}\n variant={\n error && state.isOpen && !disabled\n ? 'button.select.errorOpened'\n : error\n ? 'button.select.error'\n : state.isOpen && !disabled\n ? 'button.select.open'\n : 'button.select'\n }\n disabled={disabled}\n className={className}\n >\n <Box\n as=\"span\"\n {...valueProps}\n variant={disabled ? 'select.disabled' : 'select'}\n >\n {state.selectedItem ? state.selectedItem.rendered : placeholder}\n </Box>\n {state.isOpen && !disabled ? (\n <Box as={ArrowUp} size={16} css={{ fill: 'text' }} />\n ) : (\n <Box\n as={ArrowDown}\n size={16}\n css={{ fill: disabled ? 'disabled' : 'text' }}\n />\n )}\n </Box>\n {state.isOpen && !disabled && (\n <Box\n as={Popover}\n {...overlayProps}\n {...positionProps}\n css={{\n width: triggerRef.current && triggerRef.current.offsetWidth + 'px',\n }}\n ref={overlayRef as Ref<HTMLDivElement>}\n isOpen={state.isOpen}\n onClose={state.close}\n >\n <ListBox error={error} {...menuProps} state={state} />\n </Box>\n )}\n {error && errorMessage && (\n <Box as=\"span\" display=\"inline-flex\" alignItems=\"center\">\n <Box as={Exclamation} size={16} css={{ color: 'error' }} />\n <ValidationMessage>{errorMessage}</ValidationMessage>\n </Box>\n )}\n </Box>\n );\n};\n","import React from 'react';\nimport { Exclamation } from '@marigold/icons';\nimport { ComponentProps } from '@marigold/types';\n\nimport { ValidationMessage } from '../ValidationMessage';\nimport { Label } from '../Label';\nimport { Box } from '../Box';\n\n// Theme Extension\n// ---------------\nexport interface TextareaThemeExtension<Value> {\n textarea?: {\n [key: string]: Value;\n };\n}\n\n// Props\n// ---------------\nexport type TextareaProps = {\n variant?: string;\n label?: string;\n htmlFor?: string;\n required?: boolean;\n error?: boolean;\n errorMessage?: string;\n} & ComponentProps<'textarea'>;\n\n// Component\n// ---------------\nexport const Textarea: React.FC<TextareaProps> = ({\n variant = '',\n htmlFor = 'textarea',\n label,\n error,\n errorMessage,\n required,\n className = '',\n children,\n ...props\n}) => (\n <Box>\n {label && (\n <Label htmlFor={htmlFor} required={required}>\n {label}\n </Label>\n )}\n <Box\n as=\"textarea\"\n {...props}\n display=\"block\"\n variant={`textarea.${variant}`}\n css={{ outlineColor: error && 'error' }}\n className={className}\n />\n {error && errorMessage && (\n <ValidationMessage>\n <Exclamation size={16} />\n {errorMessage}\n </ValidationMessage>\n )}\n </Box>\n);\n","import React from 'react';\nimport { Box } from '../Box';\n\nexport type ContainerProps = {\n className?: string;\n title?: string; // Used for testing.\n};\n\nexport const Container: React.FC<ContainerProps> = ({ children, ...props }) => (\n <Box {...props} width=\"100%\">\n {children}\n </Box>\n);\n"],"names":["ALIGNMENT","top","center","bottom","Inline","space","align","children","props","React","Box","display","css","pl","alignItems","Children","map","flattenChildren","child","cloneElement","left","right","Stack","flexDirection","pt","ActionGroup","verticalAlignment","ICON_MAP","success","Check","warning","Notification","error","Exclamation","Alert","variant","Icon","width","height","bg","as","size","color","m","mx","Badge","bgColor","borderColor","Button","forwardRef","ref","disabled","className","useButton","elementType","isDisabled","buttonProps","columnGap","Card","title","maxWidth","pb","CheckboxIcon","checked","conditionalStates","SVG","viewBox","fill","x","y","rx","conditional","__baseCSS","fillRule","clipRule","d","LabelBase","required","Label","Required","ValidationMessage","CheckboxInput","state","useToggleState","useRef","useCheckbox","inputProps","useFocusRing","focusProps","pr","VisuallyHidden","type","Checkbox","label","labelVariant","errorMessage","cursor","htmlFor","id","transform","Array","isArray","v","Column","useAlignment","direction","Columns","horizontalAlign","verticalAlign","justifyContent","useTheme","spaceObject","spaceValue","Object","values","p","flexWrap","Text","outline","userSelect","textAlign","ModalDialog","backdropVariant","isDismissable","isOpen","onClose","restProps","useOverlay","overlayProps","underlayProps","usePreventScroll","useModal","modalProps","useDialog","dialogProps","placeItems","position","zIndex","FocusScope","contain","restoreFocus","autoFocus","Dialog","close","closeButtonRef","onPress","closeButtonProps","OverlayContainer","borderRadius","paddingTop","paddingX","lineHeight","px","Close","useDialogButtonProps","useOverlayTriggerState","openButtonRef","open","openButtonProps","Divider","Input","Field","Image","Link","useLink","linkProps","Menu","onClick","show","minWidth","MenuItem","Message","messageTitle","icon","Info","MarigoldProvider","theme","outer","isTopLevel","__defaultTheme","ThemeProvider","Global","OverlayProvider","RadioIcon","cx","cy","r","RadioInput","Radio","Slider","Option","item","useState","setDisabled","useOption","key","optionProps","isSelected","useEffect","disabledKeys","rendered","ListBoxSection","section","useListBoxSection","heading","itemProps","headingProps","groupProps","childNodes","node","ListBox","useListBox","listBoxProps","listStyle","collection","Popover","otherProps","shouldCloseOnBlur","mergeProps","DismissButton","onDismiss","Select","placeholder","useSelectState","overlayTriggerState","triggerRef","overlayRef","useOverlayTrigger","useOverlayPosition","targetRef","placement","shouldFlip","positionProps","useSelect","labelProps","triggerProps","valueProps","menuProps","HiddenSelect","name","selectedItem","ArrowUp","ArrowDown","current","offsetWidth","Textarea","outlineColor","Container"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAYA,IAAMA,SAAS,GAAG;AAChBC,EAAAA,GAAG,EAAE,YADW;AAEhBC,EAAAA,MAAM,EAAE,QAFQ;AAGhBC,EAAAA,MAAM,EAAE;AAHQ,CAAlB;IAMaC,MAAM,GAA0B,SAAhCA,MAAgC;AAAA,wBAC3CC,KAD2C;AAAA,MAC3CA,KAD2C,2BACnC,MADmC;AAAA,wBAE3CC,KAF2C;AAAA,MAE3CA,KAF2C,2BAEnC,QAFmC;AAAA,MAG3CC,QAH2C,QAG3CA,QAH2C;AAAA,MAIxCC,KAJwC;;AAAA,SAM3CC,mBAAA,CAACC,GAAD;AACEC,IAAAA,OAAO,EAAC;AACRC,IAAAA,GAAG,EAAE;AAAE,iBAAW;AAAEC,QAAAA,EAAE,EAAER;AAAN;AAAb;AACLS,IAAAA,UAAU,EAAEd,SAAS,CAACM,KAAD;KACjBE,MAJN,EAMGO,QAAQ,CAACC,GAAT,CACCC,eAAe,CAACV,QAAD,CADhB,EAEC,UAACW,KAAD;AAAA,WACET,mBAAA,CAACC,GAAD,MAAA,EAAMD,KAAK,CAACU,YAAN,CAAmBD,KAAnB,EAA0B,EAA1B,EAA8BA,KAAK,CAACV,KAAN,CAAYD,QAA1C,CAAN,CADF;AAAA,GAFD,CANH,CAN2C;AAAA;;;AClB7C,AAYA,IAAMP,WAAS,GAAG;AAChBoB,EAAAA,IAAI,EAAE,YADU;AAEhBlB,EAAAA,MAAM,EAAE,QAFQ;AAGhBmB,EAAAA,KAAK,EAAE;AAHS,CAAlB;AAMA,IAAaC,KAAK,GAAyB,SAA9BA,KAA8B;AAAA,wBACzCjB,KADyC;AAAA,MACzCA,KADyC,2BACjC,MADiC;AAAA,wBAEzCC,KAFyC;AAAA,MAEzCA,KAFyC,2BAEjC,MAFiC;AAAA,MAGzCC,QAHyC,QAGzCA,QAHyC;AAAA,MAItCC,KAJsC;;AAAA,SAMzCC,mBAAA,CAACC,GAAD,oBACMF;AACJG,IAAAA,OAAO,EAAC;AACRY,IAAAA,aAAa,EAAC;AACdT,IAAAA,UAAU,EAAEd,WAAS,CAACM,KAAD;AACrBM,IAAAA,GAAG,EAAE;AAAE,iBAAW;AAAEY,QAAAA,EAAE,EAAEnB;AAAN;AAAb;IALP,EAOGU,QAAQ,CAACC,GAAT,CACCC,eAAe,CAACV,QAAD,CADhB,EAEC,UAACW,KAAD;AAAA,WACET,mBAAA,CAACC,GAAD,MAAA,EAAMD,KAAK,CAACU,YAAN,CAAmBD,KAAnB,EAA0B,EAA1B,EAA8BA,KAAK,CAACV,KAAN,CAAYD,QAA1C,CAAN,CADF;AAAA,GAFD,CAPH,CANyC;AAAA,CAApC;;;AClBP,AAgBA;;AACA,IAAakB,WAAW,GAA+B,SAA1CA,WAA0C;AAAA,wBACrDpB,KADqD;AAAA,MACrDA,KADqD,2BAC7C,MAD6C;AAAA,mCAErDqB,iBAFqD;AAAA,MAErDA,iBAFqD,sCAEjC,KAFiC;AAAA,MAGrDnB,QAHqD,QAGrDA,QAHqD;AAAA,MAIlDC,KAJkD;;AAAA,SAMrDkB,iBAAiB,GACfjB,mBAAA,CAACa,KAAD;AAAOjB,IAAAA,KAAK,EAAEA;KAAWG,MAAzB,EACGD,QADH,CADe,GAKfE,mBAAA,CAACL,MAAD;AAAQC,IAAAA,KAAK,EAAEA;KAAWG,MAA1B,EACGD,QADH,CAXmD;AAAA,CAAhD;;;ACjBP,AAMA,IAAMoB,QAAQ,GAAG;AACfC,EAAAA,OAAO,EAAEC,KADM;AAEfC,EAAAA,OAAO,EAAEC,YAFM;AAGfC,EAAAA,KAAK,EAAEC;AAHQ,CAAjB;AAuBA;;AACA,IAAaC,KAAK,GAAyB,SAA9BA,KAA8B;0BACzCC;MAAAA,oCAAU;MACV5B,gBAAAA;MACGC;;AAEH,MAAM4B,IAAI,GAAGT,QAAQ,CAACQ,OAAD,CAArB;AAEA,SACE1B,mBAAA,CAACC,GAAD,oBAASF;AAAOG,IAAAA,OAAO,EAAC;AAAOwB,IAAAA,OAAO,aAAWA;IAAjD,EACE1B,mBAAA,CAACC,GAAD;AACEC,IAAAA,OAAO,EAAC;AACRG,IAAAA,UAAU,EAAC;AACXuB,IAAAA,KAAK,EAAC;AACNC,IAAAA,MAAM,EAAC;AACPC,IAAAA,EAAE,EAAEJ;GALN,EAOE1B,mBAAA,CAACC,GAAD;AAAK8B,IAAAA,EAAE,EAAEJ;AAAMK,IAAAA,IAAI,EAAE;AAAIC,IAAAA,KAAK,EAAC;AAAOH,IAAAA,EAAE,EAAEJ;AAASQ,IAAAA,CAAC,EAAE;GAAtD,CAPF,CADF,EAUElC,mBAAA,CAACC,GAAD;AAAKkC,IAAAA,EAAE,EAAC;GAAR,EAAgBrC,QAAhB,CAVF,CADF;AAcD,CArBM;;;AC9BP,AAqBA;;AACA,IAAasC,KAAK,GAAyB,SAA9BA,KAA8B;AAAA,0BACzCV,OADyC;AAAA,MACzCA,OADyC,6BAC/B,EAD+B;AAAA,0BAEzCW,OAFyC;AAAA,MAEzCA,OAFyC,6BAE/B,aAF+B;AAAA,8BAGzCC,WAHyC;AAAA,MAGzCA,WAHyC,iCAG3B,aAH2B;AAAA,MAIzCxC,QAJyC,QAIzCA,QAJyC;AAAA,MAKtCC,KALsC;;AAAA,SAOzCC,mBAAA,CAACC,GAAD;AACEE,IAAAA,GAAG,EAAE;AAAE2B,MAAAA,EAAE,EAAEO,OAAN;AAAeC,MAAAA,WAAW,EAAEA;AAA5B;AACLZ,IAAAA,OAAO,aAAWA;KACd3B,MAHN,EAKGD,QALH,CAPyC;AAAA,CAApC;;;ACtBP,AAsBA;;AACA,IAAayC,MAAM,gBACjBC,UAAU,CACR,gBAWEC,GAXF;qBAEIV;MAAAA,0BAAK;0BACLL;MAAAA,oCAAU;uBACVM;MAAAA,8BAAO;wBACPpC;MAAAA,gCAAQ;MACR8C,gBAAAA;MACA5C,gBAAAA;MACA6C,iBAAAA;MACG5C;;AAIL,mBAAwB6C,SAAS,cAE1B7C,KAF0B;AAG7B8C,IAAAA,WAAW,EAAE,OAAOd,EAAP,KAAc,QAAd,GAAyBA,EAAzB,GAA8B,MAHd;AAI7Be,IAAAA,UAAU,EAAEJ;AAJiB,MAM/BD,GAN+B,CAAjC;AAAA,MAAQM,WAAR,cAAQA,WAAR;;AASA,SACE/C,mBAAA,CAACC,GAAD,oBACM8C,aACAhD;AACJgC,IAAAA,EAAE,EAAEA;AACJ7B,IAAAA,OAAO,EAAC;AACRG,IAAAA,UAAU,EAAC;AACXqB,IAAAA,OAAO,EAAE,aAAWA,OAAX,cAAgCM,IAAhC;AACTW,IAAAA,SAAS,EAAEA;AACXF,IAAAA,GAAG,EAAEA;AACLtC,IAAAA,GAAG,EAAE;AAAE6C,MAAAA,SAAS,EAAEpD;AAAb;IATP,EAWGE,QAXH,CADF;AAeD,CAtCO,CADL;;;ACvBP,AAuBA;;AACA,IAAamD,IAAI,GAAwB,SAA5BA,IAA4B;0BACvCvB;MAAAA,oCAAU;MACVwB,aAAAA;MACAtB,aAAAA;MACAe,iBAAAA;MACA7C,gBAAAA;MACGC;;AAEH,SACEC,mBAAA,CAACC,GAAD,oBACMF;AACJ2B,IAAAA,OAAO,YAAUA;AACjByB,IAAAA,QAAQ,EAAEvB;AACVe,IAAAA,SAAS,EAAEA;IAJb,EAMGO,KAAK,IACJlD,mBAAA,CAACC,GAAD;AAAK8B,IAAAA,EAAE,EAAC;AAAKL,IAAAA,OAAO,EAAC;AAAU0B,IAAAA,EAAE,EAAC;GAAlC,EACGF,KADH,CAPJ,EAWGpD,QAXH,CADF;AAeD,CAvBM;;ACTA,IAAMuD,YAAY,GAAgC,SAA5CA,YAA4C;0BACvD3B;MAAAA,oCAAU;0BACV4B;MAAAA,oCAAU;2BACVZ;MAAAA,sCAAW;wBACXnB;MAAAA,gCAAQ;AAER,MAAMgC,iBAAiB,GAAUb,QAAQ,GACrC;AACEA,IAAAA,QAAQ,EAAEA;AADZ,GADqC,GAIrC;AACEY,IAAAA,OAAO,EAAEA,OADX;AAEE/B,IAAAA,KAAK,EAAEA;AAFT,GAJJ;AASA,SACEvB,mBAAA,CAACwD,GAAD;AACE5B,IAAAA,KAAK,EAAC;AACNC,IAAAA,MAAM,EAAC;AACP4B,IAAAA,OAAO,EAAC;AACRC,IAAAA,IAAI,EAAC;mBACO;GALd,EAOE1D,mBAAA,CAACC,GAAD;AACE8B,IAAAA,EAAE,EAAC;AACH4B,IAAAA,CAAC,EAAC;AACFC,IAAAA,CAAC,EAAC;AACFhC,IAAAA,KAAK,EAAC;AACNC,IAAAA,MAAM,EAAC;AACPgC,IAAAA,EAAE,EAAC;AACHnC,IAAAA,OAAO,EAAEoC,WAAW,eAAapC,OAAb,EAAwB6B,iBAAxB;GAPtB,CAPF,EAgBGD,OAAO,IACNtD,mBAAA,CAACC,GAAD;AACE8D,IAAAA,SAAS,EAAE;AAAEL,MAAAA,IAAI,EAAE;AAAR;AACX3B,IAAAA,EAAE,EAAC;AACHiC,IAAAA,QAAQ,EAAC;AACTC,IAAAA,QAAQ,EAAC;AACTC,IAAAA,CAAC,EAAC;GALJ,CAjBJ,CADF;AA4BD,CA3CM;;;;ACfP,IAyBaC,SAAS,GAAyB,SAAlCA,SAAkC;0BAC7CzC;MAAAA,oCAAU;MACV0C,kBACAnC;MAAAA,gCAAQ;MACRnC,gBAAAA;MACGC;;AAEH,SACEC,mBAAA,CAACC,GAAD,oBACMF;AACJgC,IAAAA,EAAE,EAAC;AACHgC,IAAAA,SAAS,EAAE;AAAE9B,MAAAA,KAAK,EAAEA;AAAT;AACXP,IAAAA,OAAO,aAAWA;IAJpB,EAMG5B,QANH,CADF;AAUD,CAjBM;AAyBP,IAAauE,KAAK,GAAyB,SAA9BA,KAA8B;MACzCD,iBAAAA;MACAtE,iBAAAA;MACGC;;AAEH,SAAOqE,QAAQ,GACbpE,mBAAA,CAACC,GAAD;AAAK8B,IAAAA,EAAE,EAAC;AAAO7B,IAAAA,OAAO,EAAC;AAAcG,IAAAA,UAAU,EAAC;GAAhD,EACEL,mBAAA,CAACmE,SAAD,oBAAepE,MAAf,EAAuBD,QAAvB,CADF,EAEGsE,QAAQ,IAAIpE,mBAAA,CAACC,GAAD;AAAK8B,IAAAA,EAAE,EAAEuC;AAAUtC,IAAAA,IAAI,EAAE;AAAI7B,IAAAA,GAAG,EAAE;AAAE8B,MAAAA,KAAK,EAAE;AAAT;GAAlC,CAFf,CADa,GAMbjC,mBAAA,CAACmE,SAAD,oBAAepE,MAAf,EAAuBD,QAAvB,CANF;AAQD,CAbM;;;AClDP,AAoBA;;AACA,IAAayE,iBAAiB,GAAqC,SAAtDA,iBAAsD;0BACjE7C;MAAAA,oCAAU;MACV5B,gBAAAA;MACA6C,iBAAAA;MACG5C;;AAEH,SACEC,mBAAA,CAACC,GAAD;AACE8B,IAAAA,EAAE,EAAC;AACH7B,IAAAA,OAAO,EAAC;AACRG,IAAAA,UAAU,EAAC;AACXqB,IAAAA,OAAO,kBAAgBA;AACvBiB,IAAAA,SAAS,EAAEA;KACP5C,MANN,EAQGD,QARH,CADF;AAYD,CAlBM;;;;ACrBP;AA6BA,IAAM0E,aAAa,GAAiC,SAA9CA,aAA8C;MAAGjD,aAAAA;MAAUxB;;AAC/D,MAAM0E,KAAK,GAAGC,cAAc,CAAC3E,KAAD,CAA5B;AACA,MAAM0C,GAAG,GAAGzC,KAAK,CAAC2E,MAAN,CAA+B,IAA/B,CAAZ;;AACA,qBAAuBC,WAAW,CAAC7E,KAAD,EAAQ0E,KAAR,EAAehC,GAAf,CAAlC;AAAA,MAAQoC,UAAR,gBAAQA,UAAR;;AACA,sBAAuBC,YAAY,EAAnC;AAAA,MAAQC,UAAR,iBAAQA,UAAR;;AAEA,SACE/E,mBAAA,CAACC,GAAD;AAAK+E,IAAAA,EAAE,EAAC;GAAR,EACEhF,mBAAA,CAACiF,cAAD,MAAA,EACEjF,mBAAA,CAACC,GAAD;AACE8B,IAAAA,EAAE,EAAC;AACHmD,IAAAA,IAAI,EAAC;AACLxC,IAAAA,QAAQ,EAAE3C,KAAK,CAAC2C;KACZmC,YACAE;AACJtC,IAAAA,GAAG,EAAEA;KACD1C,MAPN,CADF,CADF,EAYEC,mBAAA,CAACqD,YAAD;AACEC,IAAAA,OAAO,EAAEvD,KAAK,CAACuD;AACf5B,IAAAA,OAAO,EAAE3B,KAAK,CAAC2B;AACfgB,IAAAA,QAAQ,EAAE3C,KAAK,CAAC2C;AAChBnB,IAAAA,KAAK,EAAEA;GAJT,CAZF,CADF;AAqBD,CA3BD;;AAwCA,IAAa4D,QAAQ,GAA4B,SAApCA,QAAoC;MAC/CC,cAAAA;MACAhB,iBAAAA;iCACAiB;MAAAA,+CAAe;MACf9D,cAAAA;MACA+D,qBAAAA;MACGvF;;AAEH,SACEC,mBAAA,eAAA,MAAA,EACEA,mBAAA,CAACC,GAAD;AACE8B,IAAAA,EAAE,EAAEsC;AACJN,IAAAA,SAAS,EAAE;AACT,gBAAU;AAAEwB,QAAAA,MAAM,EAAExF,KAAK,CAAC2C,QAAN,GAAiB,aAAjB,GAAiC;AAA3C;AADD;AAGX8C,IAAAA,OAAO,EAAEzF,KAAK,CAAC0F;AACfrB,IAAAA,QAAQ,EAAEA;AACV1C,IAAAA,OAAO,aAAW2D;AAClBpD,IAAAA,KAAK,EAAElC,KAAK,CAAC2C,QAAN,GAAiB,UAAjB,GAA8B;GARvC,EAUE1C,mBAAA,CAACC,GAAD;AAAK8B,IAAAA,EAAE,EAAEyC;AAAejD,IAAAA,KAAK,EAAEA;KAAWxB,MAA1C,CAVF,EAWGqF,KAXH,CADF,EAcG7D,KAAK,IAAI+D,YAAT,IACCtF,mBAAA,CAACuE,iBAAD,MAAA,EACEvE,mBAAA,CAACwB,WAAD;AAAaQ,IAAAA,IAAI,EAAE;GAAnB,CADF,EAEGsD,YAFH,CAfJ,CADF;AAuBD,CA/BM;;;ACrEP;AAUA,IAAMI,SAAS,GAAG,SAAZA,SAAY,CAAC9D,KAAD;AAChB,MAAI+D,KAAK,CAACC,OAAN,CAAchE,KAAd,CAAJ,EAA0B;AACxB,WAAOA,KAAK,CAACrB,GAAN,CAAU,UAAAsF,CAAC;AAAA,aAAQA,CAAC,GAAG,EAAL,GAAW,GAAlB;AAAA,KAAX,CAAP;AACD;;AAED,SAAWjE,KAAK,GAAG,EAAT,GAAe,GAAzB;AACD,CAND;;AAQA,IAAakE,MAAM,GAA0B,SAAhCA,MAAgC;AAAA,wBAC3ClE,KAD2C;AAAA,MAC3CA,KAD2C,2BACnC,EADmC;AAAA,MAE3C9B,QAF2C,QAE3CA,QAF2C;AAAA,MAGxCC,KAHwC;;AAAA,SAK3CC,mBAAA,CAACC,GAAD,oBAASF;AAAO6B,IAAAA,KAAK,EAAE8D,SAAS,CAAC9D,KAAD;IAAhC,EACG9B,QADH,CAL2C;AAAA,CAAtC;;;AClBP;AAYA,IAAMiG,YAAY,GAAG,SAAfA,YAAe,CAACC,SAAD;AACnB,UAAQA,SAAR;AACE,SAAK,OAAL;AACE,aAAO,UAAP;;AACF,SAAK,QAAL;AACE,aAAO,UAAP;;AACF,SAAK,QAAL;AACE,aAAO,QAAP;AANJ;;AAQA,SAAO,YAAP;AACD,CAVD;;AAYA,IAAaC,OAAO,GAA2B,SAAlCA,OAAkC;wBAC7CrG;MAAAA,gCAAQ;kCACRsG;MAAAA,oDAAkB;gCAClBC;MAAAA,gDAAgB;MAChBxD,iBAAAA;MACA7C,gBAAAA;MACGC;;AAEH,MAAMqG,cAAc,GAAGL,YAAY,CAACG,eAAD,CAAnC;AACA,MAAM7F,UAAU,GAAG0F,YAAY,CAACI,aAAD,CAA/B;AAEA;;;;AAGA,kBAAgBE,QAAQ,EAAxB;AAAA,MAAQlG,GAAR,aAAQA,GAAR;;AACA,MAAMmG,WAAW,GAAGnG,GAAG,CAAC;AAAEP,IAAAA,KAAK,EAALA;AAAF,GAAD,CAAvB;AACA,MAAM2G,UAAU,GAAGC,MAAM,CAACC,MAAP,CAAcH,WAAd,EAA2B,CAA3B,CAAnB;AAEA,SACEtG,mBAAA,CAACC,GAAD;AAAKyG,IAAAA,CAAC,EAAE9G;AAAOM,IAAAA,OAAO,EAAC;AAAOyC,IAAAA,SAAS,EAAEA;GAAzC,EACE3C,mBAAA,CAACC,GAAD;AACE2B,IAAAA,KAAK,mBAAiB2E,UAAjB;AACLrE,IAAAA,CAAC,EAAK,CAACqE,UAAD,GAAc,CAAnB;AACDrG,IAAAA,OAAO,EAAC;AACRyG,IAAAA,QAAQ,EAAC;AACTtG,IAAAA,UAAU,EAAEA;AACZ+F,IAAAA,cAAc,EAAEA;KACZrG,MAPN,EASGO,QAAQ,CAACC,GAAT,CACCC,eAAe,CAACV,QAAD,CADhB,EAEC,UAACW,KAAD;AACE,WAAOT,KAAK,CAACU,YAAN,CACLD,KADK,EAEL,EAFK,EAGLT,mBAAA,CAACC,GAAD;AAAKE,MAAAA,GAAG,EAAE;AAAEuG,QAAAA,CAAC,EAAKH,UAAU,GAAG,CAAlB;AAAH;KAAV,EACG9F,KAAK,CAACV,KAAN,CAAYD,QADf,CAHK,CAAP;AAOD,GAVF,CATH,CADF,CADF;AA0BD,CA5CM;;;ACxBP,AA8BA;;AACA,IAAa8G,IAAI,gBACfpE,UAAU,CACR,gBAaEC,GAbF;AAAA,qBAEIV,EAFJ;AAAA,MAEIA,EAFJ,wBAES,MAFT;AAAA,0BAGIL,OAHJ;AAAA,MAGIA,OAHJ,6BAGc,MAHd;AAAA,MAII5B,QAJJ,QAIIA,QAJJ;AAAA,MAKI6C,SALJ,QAKIA,SALJ;AAAA,MAMI9C,KANJ,QAMIA,KANJ;AAAA,MAOIoC,KAPJ,QAOIA,KAPJ;AAAA,MAQIsD,MARJ,QAQIA,MARJ;AAAA,MASIsB,OATJ,QASIA,OATJ;AAAA,MAUIC,UAVJ,QAUIA,UAVJ;AAAA,MAWO/G,KAXP;;AAAA,SAeEC,mBAAA,CAACC,GAAD,oBACMF;AACJgC,IAAAA,EAAE,EAAEA;AACJL,IAAAA,OAAO,YAAUA;AACjBvB,IAAAA,GAAG,EAAE;AAAE4G,MAAAA,SAAS,EAAElH,KAAb;AAAoBoC,MAAAA,KAAK,EAALA,KAApB;AAA2BsD,MAAAA,MAAM,EAANA,MAA3B;AAAmCsB,MAAAA,OAAO,EAAPA,OAAnC;AAA4CC,MAAAA,UAAU,EAAVA;AAA5C;AACLnE,IAAAA,SAAS,EAAEA;AACXF,IAAAA,GAAG,EAAEA;IANP,EAQG3C,QARH,CAfF;AAAA,CADQ,CADL;;;;AC/BP,AAsBA;;AACA,AAAO,IAAMkH,WAAW,GAA+B,SAA1CA,WAA0C;MACrDtF,eAAAA;kCACAuF;MAAAA,oDAAkB;MAClBnH,gBAAAA;MACGC;;AAEH,MAAQmH,aAAR,GAAyDnH,KAAzD,CAAQmH,aAAR;AAAA,MAAuBC,MAAvB,GAAyDpH,KAAzD,CAAuBoH,MAAvB;AAAA,MAA+BC,OAA/B,GAAyDrH,KAAzD,CAA+BqH,OAA/B;AAAA,MAA2CC,SAA3C,iCAAyDtH,KAAzD;AAGA;;;AACA,MAAM0C,GAAG,GAAGzC,KAAK,CAAC2E,MAAN,EAAZ;;AACA,oBAAwC2C,UAAU,CAChD;AAAEJ,IAAAA,aAAa,EAAbA,aAAF;AAAiBC,IAAAA,MAAM,EAANA,MAAjB;AAAyBC,IAAAA,OAAO,EAAPA;AAAzB,GADgD,EAEhD3E,GAFgD,CAAlD;AAAA,MAAQ8E,YAAR,eAAQA,YAAR;AAAA,MAAsBC,aAAtB,eAAsBA,aAAtB;AAMA;;;AACAC,EAAAA,gBAAgB;;AAEhB,kBAAuBC,QAAQ,EAA/B;AAAA,MAAQC,UAAR,aAAQA,UAAR;;AACA,mBAAwBC,SAAS,CAAC7H,KAAD,EAAQ0C,GAAR,CAAjC;AAAA,MAAQoF,WAAR,cAAQA,WAAR;;AAEA,SACE7H,mBAAA,CAACC,GAAD;AACE8D,IAAAA,SAAS,EAAE;AACT7D,MAAAA,OAAO,EAAE,MADA;AAET4H,MAAAA,UAAU,EAAE,QAFH;AAGTC,MAAAA,QAAQ,EAAE,OAHD;AAITC,MAAAA,MAAM,EAAE,GAJC;AAKTxI,MAAAA,GAAG,EAAE,CALI;AAMTmB,MAAAA,IAAI,EAAE,CANG;AAOTjB,MAAAA,MAAM,EAAE,CAPC;AAQTkB,MAAAA,KAAK,EAAE;AARE;AAUXc,IAAAA,OAAO,cAAYuF;KACfO,cAZN,EAcExH,mBAAA,CAACiI,UAAD;AAAYC,IAAAA,OAAO;AAACC,IAAAA,YAAY;AAACC,IAAAA,SAAS;GAA1C,EACEpI,mBAAA,CAACC,GAAD,oBACMsH,cACAM,aACAF;AACJlF,IAAAA,GAAG,EAAEA;AACLf,IAAAA,OAAO,EAAEA,OAAO,eAAaA,OAAb;KACZ2F,UANN,EAQGvH,QARH,CADF,CAdF,CADF;AA6BD,CApDM;;;ACvBP,AAyBA;;AACA,IAAauI,MAAM,GAA0B,SAAhCA,MAAgC;MAC3CpB,uBAAAA;MACAnH,gBAAAA;MACA6C,iBAAAA;MACA2F,aAAAA;MACAnB,cAAAA;MACAjE,aAAAA;MACAxB,eAAAA;MACG3B;;AAEH,MAAMwI,cAAc,GAAGvI,KAAK,CAAC2E,MAAN,EAAvB;AAGA;AACA;;AACA,mBAA0C/B,SAAS,CACjD;AACE4F,IAAAA,OAAO,EAAE;AAAA,aAAMF,KAAK,EAAX;AAAA;AADX,GADiD,EAIjDC,cAJiD,CAAnD;AAAA,MAAqBE,gBAArB,cAAQ1F,WAAR;;AAOA,SACE/C,mBAAA,CAAC0I,gBAAD,MAAA,EACE1I,mBAAA,CAACgH,WAAD;AACEtF,IAAAA,OAAO,EAAEA;AACTuF,IAAAA,eAAe,EAAEA;AACjBE,IAAAA,MAAM,EAAEA;AACRC,IAAAA,OAAO,EAAEkB;AACTpB,IAAAA,aAAa;KACTnH,MANN,EAQEC,mBAAA,CAACC,GAAD;AACE8D,IAAAA,SAAS,EAAE;AACT7D,MAAAA,OAAO,EAAE,MADA;AAETkG,MAAAA,cAAc,EAAE,eAFP;AAGTuC,MAAAA,YAAY,EAAE,OAHL;AAITvI,MAAAA,EAAE,EAAE,OAJK;AAKTgD,MAAAA,EAAE,EAAE;AALK;AAOXT,IAAAA,SAAS,EAAEA;GARb,EAUE3C,mBAAA,CAACC,GAAD;AAAKc,IAAAA,EAAE,EAAC;GAAR,EACGmC,KAAK,IACJlD,mBAAA,CAAC4G,IAAD;AAAM7E,IAAAA,EAAE,EAAC;AAAKL,IAAAA,OAAO,EAAC;GAAtB,EACGwB,KADH,CAFJ,EAMGpD,QANH,CAVF,EAkBEE,mBAAA,CAACC,GAAD;AACE8D,IAAAA,SAAS,EAAE;AACT7D,MAAAA,OAAO,EAAE,MADA;AAETkG,MAAAA,cAAc,EAAE,UAFP;AAGT/F,MAAAA,UAAU,EAAE,OAHH;AAITuI,MAAAA,UAAU,EAAE,QAJH;AAKTC,MAAAA,QAAQ,EAAE;AALD;GADb,EASE7I,mBAAA,CAACC,GAAD;AACE8B,IAAAA,EAAE,EAAEQ;AACJwB,IAAAA,SAAS,EAAE;AACT9B,MAAAA,KAAK,EAAE,MADE;AAETH,MAAAA,EAAE,EAAE,aAFK;AAGTgH,MAAAA,UAAU,EAAE,QAHH;AAITC,MAAAA,EAAE,EAAE,SAJK;AAKT,gBAAU;AACR9G,QAAAA,KAAK,EAAE,MADC;AAERH,QAAAA,EAAE,EAAE,aAFI;AAGRyD,QAAAA,MAAM,EAAE;AAHA,OALD;AAUT,gBAAU;AACRsB,QAAAA,OAAO,EAAE;AADD;AAVD;KAcP4B;AACJhG,IAAAA,GAAG,EAAE8F;IAjBP,EAmBEvI,mBAAA,CAACgJ,KAAD;AAAOhH,IAAAA,IAAI,EAAE;GAAb,CAnBF,CATF,CAlBF,CARF,CADF,CADF;AA+DD,CArFM;;AAwFP,IAAaiH,oBAAoB,GAAG,SAAvBA,oBAAuB;AAClC,MAAMxE,KAAK,GAAGyE,sBAAsB,CAAC,EAAD,CAApC;AACA,MAAMC,aAAa,GAAGnJ,KAAK,CAAC2E,MAAN,EAAtB;;AACA,oBAAyC/B,SAAS,CAChD;AACE4F,IAAAA,OAAO,EAAE;AAAA,aAAM/D,KAAK,CAAC2E,IAAN,EAAN;AAAA;AADX,GADgD,EAIhDD,aAJgD,CAAlD;AAAA,MAAqBE,eAArB,eAAQtG,WAAR;;AAOA,SAAO;AACL0B,IAAAA,KAAK,EAALA,KADK;AAEL4E,IAAAA,eAAe,EAAfA,eAFK;AAGLF,IAAAA,aAAa,EAAbA;AAHK,GAAP;AAKD,CAfM;;;AClHP,AAoBA;;AACA,IAAaG,OAAO,GAA2B,SAAlCA,OAAkC;AAAA,0BAC7C5H,OAD6C;AAAA,MAC7CA,OAD6C,6BACnC,SADmC;AAAA,MAE1C3B,KAF0C;;AAAA,SAGzCC,mBAAA,CAACC,GAAD,oBAASF;AAAOgC,IAAAA,EAAE,EAAC;AAAKL,IAAAA,OAAO,eAAaA;IAA5C,CAHyC;AAAA,CAAxC;;;ACrBP,AAmBA;;AACA,IAAa6H,KAAK,GAAyB,SAA9BA,KAA8B;AAAA,0BACzC7H,OADyC;AAAA,MACzCA,OADyC,6BAC/B,EAD+B;AAAA,uBAEzCwD,IAFyC;AAAA,MAEzCA,IAFyC,0BAElC,MAFkC;AAAA,MAGtCnF,KAHsC;;AAAA,SAIrCC,mBAAA,CAACC,GAAD,oBAASF;AAAOgC,IAAAA,EAAE,EAAC;AAAQmD,IAAAA,IAAI,EAAEA;AAAMxD,IAAAA,OAAO,aAAWA;IAAzD,CAJqC;AAAA,CAApC;;;ACpBP,AAsBA;;AACA,IAAa8H,KAAK,GAAyB,SAA9BA,KAA8B;uBACzCtE;MAAAA,8BAAO;0BACPxD;MAAAA,oCAAU;+BACV2D;MAAAA,8CAAe;MACfG,eAAAA;MACAJ,aAAAA;MACAhB,gBAAAA;MACA7C,aAAAA;MACA+D,oBAAAA;MACA5C,gBAAAA;MACG3C;;AAEH,SACEC,mBAAA,eAAA,MAAA,EACEA,mBAAA,CAACqE,KAAD;AAAO3C,IAAAA,OAAO,EAAE2D;AAAcG,IAAAA,OAAO,EAAEA;AAASpB,IAAAA,QAAQ,EAAEA;GAA1D,EACGgB,KADH,CADF,EAIEpF,mBAAA,CAACuJ,KAAD,oBACMxJ;AACJmF,IAAAA,IAAI,EAAEA;AACNO,IAAAA,EAAE,EAAED;AACJ9C,IAAAA,QAAQ,EAAEA;AACVhB,IAAAA,OAAO,EAAEA;IALX,CAJF,EAWGH,KAAK,IAAI+D,YAAT,IACCtF,mBAAA,CAACuE,iBAAD,MAAA,EACEvE,mBAAA,CAACwB,WAAD;AAAaQ,IAAAA,IAAI,EAAE;GAAnB,CADF,EAEGsD,YAFH,CAZJ,CADF;AAoBD,CAhCM;;;ACvBP,AAoBA;;AACA,IAAamE,KAAK,GAAyB,SAA9BA,KAA8B;AAAA,0BACzC/H,OADyC;AAAA,MACzCA,OADyC,6BAC/B,WAD+B;AAAA,MAEtC3B,KAFsC;;AAAA,SAGrCC,mBAAA,CAACC,GAAD,oBAASF;AAAOgC,IAAAA,EAAE,EAAC;AAAML,IAAAA,OAAO,aAAWA;IAA3C,CAHqC;AAAA,CAApC;;;ACrBP,AAkBA;;AACA,IAAagI,IAAI,GAAI,SAARA,IAAQ;qBACnB3H;MAAAA,0BAAK;0BACLL;MAAAA,oCAAU;MACV5B,gBAAAA;MACA4C,gBAAAA;MACG3C;;AAEH,MAAM0C,GAAG,GAAGkC,MAAM,EAAlB;;AACA,iBAAsBgF,OAAO,cAGrB5J,KAHqB;AAIzB8C,IAAAA,WAAW,EAAE,OAAOd,EAAP,KAAc,QAAd,GAAyBA,EAAzB,GAA8B,MAJlB;AAKzBe,IAAAA,UAAU,EAAEJ;AALa,MAO3BD,GAP2B,CAA7B;AAAA,MAAQmH,SAAR,YAAQA,SAAR;;AAUA,SACE5J,mBAAA,CAAC4G,IAAD,oBAAU7G,OAAW6J;AAAW7H,IAAAA,EAAE,EAAEA;AAAIL,IAAAA,OAAO,EAAEA;AAASe,IAAAA,GAAG,EAAEA;IAA/D,EACG3C,QADH,CADF;AAKD,CAvBM;;;ACnBP,AAwBA;;AACA,IAAa+J,IAAI,GAAwB,SAA5BA,IAA4B;0BACvCnI;MAAAA,oCAAU;wBACV0D;MAAAA,gCAAQ;MACR0E,eAAAA;uBACAC;MAAAA,8BAAO;MACPjK,gBAAAA;MACGC;;AAEH,SACEC,mBAAA,CAACC,GAAD;AAAKyB,IAAAA,OAAO,YAAUA;KAAe3B,MAArC,EACEC,mBAAA,CAACuC,MAAD;AAAQuH,IAAAA,OAAO,EAAEA;AAASpI,IAAAA,OAAO,EAAC;GAAlC,EACG0D,KADH,CADF,EAIG2E,IAAI,GACH/J,mBAAA,CAACC,GAAD;AACEC,IAAAA,OAAO,EAAC;AACR6H,IAAAA,QAAQ,EAAC;AACTiC,IAAAA,QAAQ,EAAC;AACTrB,IAAAA,YAAY,EAAC;GAJf,EAMG7I,QANH,CADG,GASD,IAbN,CADF;AAiBD,CAzBM;;;ACzBP,AAoBA;;AACA,IAAamK,QAAQ,GAA4B,SAApCA,QAAoC;0BAC/CvI;MAAAA,oCAAU;MACViB,iBAAAA;MACA7C,gBAAAA;MACGC;;AAEH,SACEC,mBAAA,CAACC,GAAD;AAAKyB,IAAAA,OAAO,gBAAcA;AAAWiB,IAAAA,SAAS,EAAEA;GAAhD,EACE3C,mBAAA,CAAC0J,IAAD;AAAMhI,IAAAA,OAAO,EAAC;KAAmB3B,MAAjC,EACGD,QADH,CADF,CADF;AAOD,CAbM;;;ACrBP,AAsBA;;AACA,IAAaoK,OAAO,GAA2B,SAAlCA,OAAkC;MAC7CC,oBAAAA;0BACAzI;MAAAA,oCAAU;MACViB,iBAAAA;MACA7C,gBAAAA;MACGC;;AAEH,MAAIqK,IAAI,GAAGpK,mBAAA,CAACqK,IAAD,MAAA,CAAX;;AACA,MAAI3I,OAAO,KAAK,SAAhB,EAA2B;AACzB0I,IAAAA,IAAI,GAAGpK,mBAAA,CAACsB,YAAD,MAAA,CAAP;AACD;;AACD,MAAII,OAAO,KAAK,OAAhB,EAAyB;AACvB0I,IAAAA,IAAI,GAAGpK,mBAAA,CAACwB,WAAD,MAAA,CAAP;AACD;;AAED,SACExB,mBAAA,CAACC,GAAD;AACEC,IAAAA,OAAO,EAAC;AACRwB,IAAAA,OAAO,eAAaA;AACpBiB,IAAAA,SAAS,EAAEA;KACP5C,MAJN,EAMEC,mBAAA,CAACC,GAAD;AAAKC,IAAAA,OAAO,EAAC;AAAOG,IAAAA,UAAU,EAAC;AAASqB,IAAAA,OAAO,EAAC;GAAhD,EACG0I,IADH,EAEEpK,mBAAA,CAAC4G,IAAD;AAAM7E,IAAAA,EAAE,EAAC;AAAKL,IAAAA,OAAO,EAAC;GAAtB,EACGyI,YADH,CAFF,CANF,EAYEnK,mBAAA,CAACC,GAAD;AAAKE,IAAAA,GAAG,EAAE;AAAE8B,MAAAA,KAAK,EAAE;AAAT;GAAV,EAA+BnC,QAA/B,CAZF,CADF;AAgBD,CA/BM;;ACGP;;AACA,SAAgBwK;MACdC,aAAAA;MACAzK,gBAAAA;AAEA,MAAM0K,KAAK,GAAGnE,QAAQ,EAAtB;AACA,MAAMoE,UAAU,GAAGD,KAAK,CAACD,KAAN,KAAgBG,cAAnC;AAEA,SACE1K,mBAAA,CAAC2K,aAAD;AAAeJ,IAAAA,KAAK,EAAEA;GAAtB,EACGE,UAAU,GACTzK,mBAAA,eAAA,MAAA,EACEA,mBAAA,CAAC4K,MAAD,MAAA,CADF,EAEE5K,mBAAA,CAAC6K,eAAD,MAAA,EAAkB/K,QAAlB,CAFF,CADS,GAMTA,QAPJ,CADF;AAYD;;AC/BM,IAAMgL,SAAS,GAA6B,SAAtCA,SAAsC;0BACjDpJ;MAAAA,oCAAU;0BACV4B;MAAAA,oCAAU;2BACVZ;MAAAA,sCAAW;wBACXnB;MAAAA,gCAAQ;AAER,MAAMgC,iBAAiB,GAAUb,QAAQ,GACrC;AACEA,IAAAA,QAAQ,EAAEA;AADZ,GADqC,GAIrC;AACEY,IAAAA,OAAO,EAAEA,OADX;AAEE/B,IAAAA,KAAK,EAAEA;AAFT,GAJJ;AASA,SACEvB,mBAAA,CAACwD,GAAD;AACE5B,IAAAA,KAAK,EAAC;AACNC,IAAAA,MAAM,EAAC;AACP4B,IAAAA,OAAO,EAAC;AACRC,IAAAA,IAAI,EAAC;mBACO;GALd,EAOE1D,mBAAA,CAACC,GAAD;AACEyB,IAAAA,OAAO,EAAEoC,WAAW,YAAUpC,OAAV,EAAqB6B,iBAArB;AACpBxB,IAAAA,EAAE,EAAC;AACHgJ,IAAAA,EAAE,EAAC;AACHC,IAAAA,EAAE,EAAC;AACHC,IAAAA,CAAC,EAAC;GALJ,CAPF,EAcG3H,OAAO,IAAItD,mBAAA,SAAA;AAAQ0D,IAAAA,IAAI,EAAC;AAAQqH,IAAAA,EAAE,EAAC;AAAIC,IAAAA,EAAE,EAAC;AAAKC,IAAAA,CAAC,EAAC;GAAtC,CAdd,CADF;AAkBD,CAjCM;;;;ACfP;AAuBA,IAAMC,UAAU,GAA8B,SAAxCA,UAAwC;MAAG3J,aAAAA;MAAUxB;;AACzD,sBAAuB+E,YAAY,EAAnC;AAAA,MAAQC,UAAR,iBAAQA,UAAR;;AAEA,SACE/E,mBAAA,CAACC,GAAD;AAAK+E,IAAAA,EAAE,EAAC;GAAR,EACEhF,mBAAA,CAACiF,cAAD,MAAA,EACEjF,mBAAA,QAAA;AACEkF,IAAAA,IAAI,EAAC;AACLxC,IAAAA,QAAQ,EAAE3C,KAAK,CAAC2C;KACZqC,YACAhF,MAJN,CADF,CADF,EASEC,mBAAA,CAAC8K,SAAD;AACEpJ,IAAAA,OAAO,EAAE3B,KAAK,CAAC2B;AACfgB,IAAAA,QAAQ,EAAE3C,KAAK,CAAC2C;AAChBY,IAAAA,OAAO,EAAEvD,KAAK,CAACuD;AACf/B,IAAAA,KAAK,EAAEA;GAJT,CATF,CADF;AAkBD,CArBD;;AAkCA,IAAa4J,KAAK,GAAyB,SAA9BA,KAA8B;AAAA,MACzC/F,KADyC,SACzCA,KADyC;AAAA,MAEzChB,QAFyC,SAEzCA,QAFyC;AAAA,iCAGzCiB,YAHyC;AAAA,MAGzCA,YAHyC,mCAG1B,QAH0B;AAAA,MAIzC9D,KAJyC,SAIzCA,KAJyC;AAAA,MAKzC+D,YALyC,SAKzCA,YALyC;AAAA,MAMtCvF,KANsC;;AAAA,SAQzCC,mBAAA,eAAA,MAAA,EACEA,mBAAA,CAACC,GAAD;AACE8B,IAAAA,EAAE,EAAEsC;AACJmB,IAAAA,OAAO,EAAEzF,KAAK,CAAC0F;AACfrB,IAAAA,QAAQ,EAAEA;AACV1C,IAAAA,OAAO,aAAW2D;AAClBlF,IAAAA,GAAG,EACDJ,KAAK,CAAC2C,QAAN,GACI;AAAET,MAAAA,KAAK,EAAE,UAAT;AAAqB,gBAAU;AAAEsD,QAAAA,MAAM,EAAE;AAAV;AAA/B,KADJ,GAEI;AAAEtD,MAAAA,KAAK,EAAE,MAAT;AAAiB,gBAAU;AAAEsD,QAAAA,MAAM,EAAE;AAAV;AAA3B;GARR,EAWEvF,mBAAA,CAACC,GAAD;AAAK8B,IAAAA,EAAE,EAAEmJ;AAAY3J,IAAAA,KAAK,EAAEA;KAAWxB,MAAvC,CAXF,EAYGqF,KAZH,CADF,EAeG7D,KAAK,IAAI+D,YAAT,IACCtF,mBAAA,CAACuE,iBAAD,MAAA,EACEvE,mBAAA,CAACwB,WAAD;AAAaQ,IAAAA,IAAI,EAAE;GAAnB,CADF,EAEGsD,YAFH,CAhBJ,CARyC;AAAA,CAApC;;;ACzDP,AAoBA;;AACA,IAAa8F,MAAM,GAA0B,SAAhCA,MAAgC;AAAA,0BAC3C1J,OAD2C;AAAA,MAC3CA,OAD2C,6BACjC,EADiC;AAAA,MAE3CiB,SAF2C,QAE3CA,SAF2C;AAAA,MAGxC5C,KAHwC;;AAAA,SAK3CC,mBAAA,CAACC,GAAD;AACE8B,IAAAA,EAAE,EAAC;AACHmD,IAAAA,IAAI,EAAC;AACL/E,IAAAA,GAAG,EAAE;AAAEgG,MAAAA,aAAa,EAAE;AAAjB;AACLzE,IAAAA,OAAO,cAAYA;AACnBiB,IAAAA,SAAS,EAAEA;KACP5C,MANN,CAL2C;AAAA,CAAtC;;ACTA,IAAMsL,MAAM,GAAG,SAATA,MAAS;MAAGC,YAAAA;MAAM7G,aAAAA;AAC7B,MAAMhC,GAAG,GAAGkC,MAAM,CAAgB,IAAhB,CAAlB;;AACA,kBAAgC4G,QAAQ,CAAC,KAAD,CAAxC;AAAA,MAAO7I,QAAP;AAAA,MAAiB8I,WAAjB;;AACA,mBAAoCC,SAAS,CAC3C;AACEC,IAAAA,GAAG,EAAEJ,IAAI,CAACI;AADZ,GAD2C,EAI3CjH,KAJ2C,EAK3ChC,GAL2C,CAA7C;AAAA,MAAQkJ,WAAR,cAAQA,WAAR;AAAA,MAAqBC,UAArB,cAAqBA,UAArB;;AAQAC,EAAAA,SAAS,CAAC;AACR,yDAAkBpH,KAAK,CAACqH,YAAN,CAAmBrF,MAAnB,EAAlB,wCAA+C;AAAA,UAApCiF,GAAoC;;AAC7C,UAAIA,GAAG,KAAKJ,IAAI,CAACI,GAAjB,EAAsB;AACpBF,QAAAA,WAAW,CAAC,IAAD,CAAX;AACD;AACF;AACF,GANQ,EAMN,CAAC/G,KAAK,CAACqH,YAAP,EAAqBR,IAAI,CAACI,GAA1B,CANM,CAAT;AAQA,SACE1L,mBAAA,CAACC,GAAD;AACE8B,IAAAA,EAAE,EAAC;KACC4J;AACJlJ,IAAAA,GAAG,EAAEA;AACLf,IAAAA,OAAO,EACLkK,UAAU,GACN,wBADM,GAENlJ,QAAQ,GACR,wBADQ,GAER;IATR,EAYG4I,IAAI,CAACS,QAZR,CADF;AAgBD,CAnCM;;ACCA,IAAMC,cAAc,GAAG,SAAjBA,cAAiB;MAAGC,eAAAA;MAASxH,aAAAA;;AACxC,2BAAgDyH,iBAAiB,CAAC;AAChEC,IAAAA,OAAO,EAAEF,OAAO,CAACF,QAD+C;AAEhE,kBAAcE,OAAO,CAAC,YAAD;AAF2C,GAAD,CAAjE;AAAA,MAAQG,SAAR,sBAAQA,SAAR;AAAA,MAAmBC,YAAnB,sBAAmBA,YAAnB;AAAA,MAAiCC,UAAjC,sBAAiCA,UAAjC;;AAKA,SACEtM,mBAAA,CAACC,GAAD;AACE8B,IAAAA,EAAE,EAAC;KACCqK;AACJjM,IAAAA,GAAG,EAAE;AACHoF,MAAAA,MAAM,EAAE;AADL;IAHP,EAOG0G,OAAO,CAACF,QAAR,IACC/L,mBAAA,CAACC,GAAD;AAAK8B,IAAAA,EAAE,EAAC;KAAWsK;AAAc3K,IAAAA,OAAO,EAAE;IAA1C,EACGuK,OAAO,CAACF,QADX,CARJ,EAYE/L,mBAAA,CAACC,GAAD;AAAK8B,IAAAA,EAAE,EAAC;KAASuK,WAAjB,EACG,UAAIL,OAAO,CAACM,UAAZ,EAAwBhM,GAAxB,CAA4B,UAAAiM,IAAI;AAAA,WAC/BxM,mBAAA,CAACqL,MAAD;AAAQK,MAAAA,GAAG,EAAEc,IAAI,CAACd;AAAKJ,MAAAA,IAAI,EAAEkB;AAAM/H,MAAAA,KAAK,EAAEA;KAA1C,CAD+B;AAAA,GAAhC,CADH,CAZF,CADF;AAoBD,CA1BM;;ACCA,IAAMgI,OAAO,GAAG,SAAVA,OAAU,CAAC1M,KAAD;AACrB,MAAM0C,GAAG,GAAGkC,MAAM,CAAmB,IAAnB,CAAlB;AACA,MAAQF,KAAR,GAAyB1E,KAAzB,CAAQ0E,KAAR;AAAA,MAAelD,KAAf,GAAyBxB,KAAzB,CAAewB,KAAf;;AACA,oBAAyBmL,UAAU,CAAC3M,KAAD,EAAQ0E,KAAR,EAAehC,GAAf,CAAnC;AAAA,MAAQkK,YAAR,eAAQA,YAAR;;AAEA,SACE3M,mBAAA,CAACC,GAAD;AACE8B,IAAAA,EAAE,EAAC;AACH2E,IAAAA,CAAC,EAAC;AACFvG,IAAAA,GAAG,EAAE;AACHyM,MAAAA,SAAS,EAAE;AADR;KAGDD;AACJjL,IAAAA,OAAO,EAAEH,KAAK,GAAG,sBAAH,GAA4B;AAC1CkB,IAAAA,GAAG,EAAEA;IARP,EAUG,UAAIgC,KAAK,CAACoI,UAAV,EAAsBtM,GAAtB,CAA0B,UAAA+K,IAAI;AAAA,WAC7BA,IAAI,CAACpG,IAAL,KAAc,SAAd,GACElF,mBAAA,CAACgM,cAAD;AAAgBN,MAAAA,GAAG,EAAEJ,IAAI,CAACI;AAAKO,MAAAA,OAAO,EAAEX;AAAM7G,MAAAA,KAAK,EAAEA;KAArD,CADF,GAGEzE,mBAAA,CAACqL,MAAD;AAAQK,MAAAA,GAAG,EAAEJ,IAAI,CAACI;AAAKJ,MAAAA,IAAI,EAAEA;AAAM7G,MAAAA,KAAK,EAAEA;KAA1C,CAJ2B;AAAA,GAA9B,CAVH,CADF;AAoBD,CAzBM;;;ACdP,AAmBO,IAAMqI,OAAO,gBAA2BtK,UAAU,CACvD,gBAA0DC,GAA1D;MAAG3C,gBAAAA;MAAU6C,iBAAAA;MAAWwE,cAAAA;MAAQC,eAAAA;MAAY2F;;AAC1C;AACA,oBAAyBzF,UAAU,CACjC;AACEH,IAAAA,MAAM,EAANA,MADF;AAEEC,IAAAA,OAAO,EAAPA,OAFF;AAGE4F,IAAAA,iBAAiB,EAAE,IAHrB;AAIE9F,IAAAA,aAAa,EAAE;AAJjB,GADiC,EAOjCzE,GAPiC,CAAnC;AAAA,MAAQ8E,YAAR,eAAQA,YAAR;;;AAUA,kBAAuBG,QAAQ,EAA/B;AAAA,MAAQC,UAAR,aAAQA,UAAR;;AAEA,SACE3H,mBAAA,CAAC0I,gBAAD,MAAA,EACE1I,mBAAA,CAACiI,UAAD;AAAYE,IAAAA,YAAY;GAAxB,EACEnI,mBAAA,CAACC,GAAD,oBACMgN,UAAU,CAAC1F,YAAD,EAAewF,UAAf,EAA2BpF,UAA3B;AACdhF,IAAAA,SAAS,EAAEA;AACXF,IAAAA,GAAG,EAAEA;IAHP,EAKG3C,QALH,EAMEE,mBAAA,CAACkN,aAAD;AAAeC,IAAAA,SAAS,EAAE/F;GAA1B,CANF,CADF,CADF,CADF;AAcD,CA7BsD,CAAlD;;;ACnBP,AAmDA;;AACA,IAAagG,MAAM,GAAG,SAATA,MAAS;+BACpB/H;MAAAA,8CAAe;8BACfgI;MAAAA,4CAAc;MACd3K,gBAAAA;MACA0B,gBAAAA;MACA7C,aAAAA;MACA+D,oBAAAA;MACA1D,aAAAA;MACAe,iBAAAA;MACG5C;;AAEH,MAAM0E,KAAK,GAAG6I,cAAc,CAACvN,KAAD,CAA5B;AACA,MAAMwN,mBAAmB,GAAGrE,sBAAsB,CAAC,EAAD,CAAlD;AACA,MAAMsE,UAAU,GAAG7I,MAAM,EAAzB;AACA,MAAM8I,UAAU,GAAG9I,MAAM,EAAzB;;AAGA,2BAAyB+I,iBAAiB,CACxC;AAAExI,IAAAA,IAAI,EAAE;AAAR,GADwC,EAExCqI,mBAFwC,EAGxCC,UAHwC,CAA1C;AAAA,MAAQjG,YAAR,sBAAQA,YAAR;;;AAMA,4BAAwCoG,kBAAkB,CAAC;AACzDC,IAAAA,SAAS,EAAEJ,UAD8C;AAEzDC,IAAAA,UAAU,EAAEA,UAF6C;AAGzDI,IAAAA,SAAS,EAAE,QAH8C;AAIzDC,IAAAA,UAAU,EAAE,KAJ6C;AAKzD3G,IAAAA,MAAM,EAAE1C,KAAK,CAAC0C,MAL2C;AAMzDC,IAAAA,OAAO,EAAE3C,KAAK,CAAC6D;AAN0C,GAAD,CAA1D;AAAA,MAAsByF,aAAtB,uBAAQxG,YAAR;;;AASA,mBAA4DyG,SAAS,CACnEjO,KADmE,EAEnE0E,KAFmE,EAGnE+I,UAHmE,CAArE;AAAA,MAAQS,UAAR,cAAQA,UAAR;AAAA,MAAoBC,YAApB,cAAoBA,YAApB;AAAA,MAAkCC,UAAlC,cAAkCA,UAAlC;AAAA,MAA8CC,SAA9C,cAA8CA,SAA9C;;;AAMA,mBAAwBxL,SAAS,CAACsL,YAAD,EAAeV,UAAf,CAAjC;AAAA,MAAQzK,WAAR,cAAQA,WAAR;;AAEA,sBAAuB+B,YAAY,EAAnC;AAAA,MAAQC,UAAR,iBAAQA,UAAR;;AAEA,SACE/E,mBAAA,CAACC,GAAD;AAAK8H,IAAAA,QAAQ,EAAC;AAAW7H,IAAAA,OAAO,EAAC;AAAe0B,IAAAA,KAAK,EAAEA,KAAK,IAAIA;GAAhE,EACG7B,KAAK,CAACqF,KAAN,IACCpF,mBAAA,CAACC,GAAD,MAAA,EACED,mBAAA,CAACqE,KAAD,oBAAW4J;AAAYzI,IAAAA,OAAO,EAAEyI,UAAU,CAACxI;AAAI/D,IAAAA,OAAO,EAAE2D;IAAxD,EACGjB,QAAQ,GACPpE,mBAAA,CAACC,GAAD;AAAK8B,IAAAA,EAAE,EAAC;AAAO7B,IAAAA,OAAO,EAAC;AAAcG,IAAAA,UAAU,EAAC;GAAhD,EACGN,KAAK,CAACqF,KADT,EAEEpF,mBAAA,CAACC,GAAD;AAAK8B,IAAAA,EAAE,EAAEuC;AAAUtC,IAAAA,IAAI,EAAE;AAAI7B,IAAAA,GAAG,EAAE;AAAE8B,MAAAA,KAAK,EAAE;AAAT;GAAlC,CAFF,CADO,GAMPlC,KAAK,CAACqF,KAPV,CADF,CAFJ,EAeEpF,mBAAA,CAACqO,YAAD;AACE5J,IAAAA,KAAK,EAAEA;AACP+I,IAAAA,UAAU,EAAEA;AACZpI,IAAAA,KAAK,EAAErF,KAAK,CAACqF;AACbkJ,IAAAA,IAAI,EAAEvO,KAAK,CAACuO;AACZxL,IAAAA,UAAU,EAAEJ;GALd,CAfF,EAsBE1C,mBAAA,CAACC,GAAD;AACE8B,IAAAA,EAAE,EAAC;KACCkL,UAAU,CAAClK,WAAD,EAAcgC,UAAd;AACdtC,IAAAA,GAAG,EAAE+K;AACL9L,IAAAA,OAAO,EACLH,KAAK,IAAIkD,KAAK,CAAC0C,MAAf,IAAyB,CAACzE,QAA1B,GACI,2BADJ,GAEInB,KAAK,GACL,qBADK,GAELkD,KAAK,CAAC0C,MAAN,IAAgB,CAACzE,QAAjB,GACA,oBADA,GAEA;AAENA,IAAAA,QAAQ,EAAEA;AACVC,IAAAA,SAAS,EAAEA;IAdb,EAgBE3C,mBAAA,CAACC,GAAD;AACE8B,IAAAA,EAAE,EAAC;KACCoM;AACJzM,IAAAA,OAAO,EAAEgB,QAAQ,GAAG,iBAAH,GAAuB;IAH1C,EAKG+B,KAAK,CAAC8J,YAAN,GAAqB9J,KAAK,CAAC8J,YAAN,CAAmBxC,QAAxC,GAAmDsB,WALtD,CAhBF,EAuBG5I,KAAK,CAAC0C,MAAN,IAAgB,CAACzE,QAAjB,GACC1C,mBAAA,CAACC,GAAD;AAAK8B,IAAAA,EAAE,EAAEyM;AAASxM,IAAAA,IAAI,EAAE;AAAI7B,IAAAA,GAAG,EAAE;AAAEuD,MAAAA,IAAI,EAAE;AAAR;GAAjC,CADD,GAGC1D,mBAAA,CAACC,GAAD;AACE8B,IAAAA,EAAE,EAAE0M;AACJzM,IAAAA,IAAI,EAAE;AACN7B,IAAAA,GAAG,EAAE;AAAEuD,MAAAA,IAAI,EAAEhB,QAAQ,GAAG,UAAH,GAAgB;AAAhC;GAHP,CA1BJ,CAtBF,EAuDG+B,KAAK,CAAC0C,MAAN,IAAgB,CAACzE,QAAjB,IACC1C,mBAAA,CAACC,GAAD;AACE8B,IAAAA,EAAE,EAAE+K;KACAvF,cACAwG;AACJ5N,IAAAA,GAAG,EAAE;AACHyB,MAAAA,KAAK,EAAE4L,UAAU,CAACkB,OAAX,IAAsBlB,UAAU,CAACkB,OAAX,CAAmBC,WAAnB,GAAiC;AAD3D;AAGLlM,IAAAA,GAAG,EAAEgL;AACLtG,IAAAA,MAAM,EAAE1C,KAAK,CAAC0C;AACdC,IAAAA,OAAO,EAAE3C,KAAK,CAAC6D;IATjB,EAWEtI,mBAAA,CAACyM,OAAD;AAASlL,IAAAA,KAAK,EAAEA;KAAW6M;AAAW3J,IAAAA,KAAK,EAAEA;IAA7C,CAXF,CAxDJ,EAsEGlD,KAAK,IAAI+D,YAAT,IACCtF,mBAAA,CAACC,GAAD;AAAK8B,IAAAA,EAAE,EAAC;AAAO7B,IAAAA,OAAO,EAAC;AAAcG,IAAAA,UAAU,EAAC;GAAhD,EACEL,mBAAA,CAACC,GAAD;AAAK8B,IAAAA,EAAE,EAAEP;AAAaQ,IAAAA,IAAI,EAAE;AAAI7B,IAAAA,GAAG,EAAE;AAAE8B,MAAAA,KAAK,EAAE;AAAT;GAArC,CADF,EAEEjC,mBAAA,CAACuE,iBAAD,MAAA,EAAoBe,YAApB,CAFF,CAvEJ,CADF;AA+ED,CAzHM;;;ACpDP,AA4BA;;AACA,IAAasJ,QAAQ,GAA4B,SAApCA,QAAoC;AAAA,0BAC/ClN,OAD+C;AAAA,MAC/CA,OAD+C,6BACrC,EADqC;AAAA,0BAE/C8D,OAF+C;AAAA,MAE/CA,OAF+C,6BAErC,UAFqC;AAAA,MAG/CJ,KAH+C,QAG/CA,KAH+C;AAAA,MAI/C7D,KAJ+C,QAI/CA,KAJ+C;AAAA,MAK/C+D,YAL+C,QAK/CA,YAL+C;AAAA,MAM/ClB,QAN+C,QAM/CA,QAN+C;AAAA,4BAO/CzB,SAP+C;AAAA,MAO/CA,SAP+C,+BAOnC,EAPmC;AAAA,MAQ/C7C,AACGC,KAT4C;;AAAA,SAW/CC,mBAAA,CAACC,GAAD,MAAA,EACGmF,KAAK,IACJpF,mBAAA,CAACqE,KAAD;AAAOmB,IAAAA,OAAO,EAAEA;AAASpB,IAAAA,QAAQ,EAAEA;GAAnC,EACGgB,KADH,CAFJ,EAMEpF,mBAAA,CAACC,GAAD;AACE8B,IAAAA,EAAE,EAAC;KACChC;AACJG,IAAAA,OAAO,EAAC;AACRwB,IAAAA,OAAO,gBAAcA;AACrBvB,IAAAA,GAAG,EAAE;AAAE0O,MAAAA,YAAY,EAAEtN,KAAK,IAAI;AAAzB;AACLoB,IAAAA,SAAS,EAAEA;IANb,CANF,EAcGpB,KAAK,IAAI+D,YAAT,IACCtF,mBAAA,CAACuE,iBAAD,MAAA,EACEvE,mBAAA,CAACwB,WAAD;AAAaQ,IAAAA,IAAI,EAAE;GAAnB,CADF,EAEGsD,YAFH,CAfJ,CAX+C;AAAA,CAA1C;;;AC7BP,IAQawJ,SAAS,GAA6B,SAAtCA,SAAsC;AAAA,MAAGhP,QAAH,QAAGA,QAAH;AAAA,MAAgBC,KAAhB;;AAAA,SACjDC,mBAAA,CAACC,GAAD,oBAASF;AAAO6B,IAAAA,KAAK,EAAC;IAAtB,EACG9B,QADH,CADiD;AAAA,CAA5C;;;;"}
package/dist/index.d.ts CHANGED
@@ -1,22 +1,25 @@
1
1
  export * from './theme';
2
+ export * from './ActionGroup';
2
3
  export * from './Alert';
3
4
  export * from './Badge';
4
5
  export * from './Box';
5
6
  export * from './Button';
7
+ export * from './Card';
6
8
  export * from './Checkbox';
7
9
  export * from './Column';
8
10
  export * from './Columns';
9
11
  export * from './Dialog';
10
12
  export * from './Divider';
11
13
  export * from './Field';
12
- export * from './Heading';
13
- export * from './Hidden';
14
+ export * from './VisuallyHidden';
14
15
  export * from './Image';
16
+ export * from './Inline';
15
17
  export * from './Label';
16
18
  export * from './Link';
17
19
  export * from './Menu';
18
20
  export * from './MenuItem';
19
21
  export * from './Message';
22
+ export * from './Provider';
20
23
  export * from './Radio';
21
24
  export * from './Slider';
22
25
  export * from './Select';
@@ -26,3 +29,4 @@ export * from './Textarea';
26
29
  export * from './Input';
27
30
  export * from './Container';
28
31
  export * from './ValidationMessage';
32
+ export { Item, Section } from '@react-stately/collections';
package/dist/theme.d.ts CHANGED
@@ -1,48 +1,23 @@
1
- export declare type CSSObject = object;
2
- export declare type BaseTheme = {
3
- breakpoints: string[];
4
- space: {
5
- none: number;
6
- xxsmall: number;
7
- xsmall: number;
8
- small: number;
9
- medium: number;
10
- large: number;
11
- xlarge: number;
12
- xxlarge: number;
13
- };
14
- fonts: {
15
- body: string;
16
- heading: string;
17
- };
18
- fontSizes: {
19
- xxsmall: string;
20
- xsmall: string;
21
- small: string;
22
- medium: string;
23
- large: string;
24
- xlarge: string;
25
- };
26
- fontWeights: {
27
- body: number;
28
- heading: number;
29
- bold: number;
30
- };
31
- lineHeights: {
32
- body: number;
33
- heading: number;
34
- };
35
- colors: {
36
- text: string;
37
- background: string;
38
- primary: string;
39
- secondary: string;
40
- disabled: string;
41
- error: string;
42
- warning: string;
43
- info: string;
44
- success: string;
45
- [key: string]: string;
46
- };
47
- [key: string]: CSSObject;
48
- };
1
+ import { CSSObject, Theme as Scales } from '@marigold/system';
2
+ import { RootThemeExtension } from './Provider';
3
+ import { AlertThemeExtension } from './Alert';
4
+ import { BadgeThemeExtension } from './Badge';
5
+ import { ButtonThemeExtension } from './Button';
6
+ import { CardThemeExtension } from './Card';
7
+ import { CheckboxThemeExtension } from './Checkbox';
8
+ import { DividerThemeExtension } from './Divider';
9
+ import { ImageThemeExtension } from './Image';
10
+ import { InputThemeExtension } from './Input';
11
+ import { LabelThemeExtension } from './Label';
12
+ import { LinkThemeExtension } from './Link';
13
+ import { MenuThemeExtension } from './Menu';
14
+ import { MenuItemThemeExtension } from './MenuItem';
15
+ import { MessageThemeExtension } from './Message';
16
+ import { RadioThemeExtension } from './Radio';
17
+ import { SelectThemeExtension } from './Select';
18
+ import { SliderThemeExtension } from './Slider';
19
+ import { TextThemeExtension } from './Text';
20
+ import { TextareaThemeExtension } from './Textarea';
21
+ import { ValidationMessageThemeExtension } from './ValidationMessage';
22
+ export interface Theme extends Scales, RootThemeExtension<CSSObject>, AlertThemeExtension<CSSObject>, BadgeThemeExtension<CSSObject>, ButtonThemeExtension<CSSObject>, CardThemeExtension<CSSObject>, CheckboxThemeExtension<CSSObject>, DividerThemeExtension<CSSObject>, ImageThemeExtension<CSSObject>, InputThemeExtension<CSSObject>, LabelThemeExtension<CSSObject>, LinkThemeExtension<CSSObject>, MenuThemeExtension<CSSObject>, MenuItemThemeExtension<CSSObject>, MessageThemeExtension<CSSObject>, RadioThemeExtension<CSSObject>, SelectThemeExtension<CSSObject>, SliderThemeExtension<CSSObject>, TextThemeExtension<CSSObject>, TextareaThemeExtension<CSSObject>, ValidationMessageThemeExtension<CSSObject> {
23
+ }
package/package.json CHANGED
@@ -1,13 +1,31 @@
1
1
  {
2
2
  "name": "@marigold/components",
3
- "version": "0.0.3",
3
+ "version": "0.3.1",
4
4
  "description": "Components for the Marigold Design System",
5
5
  "main": "dist/index.js",
6
6
  "module": "dist/components.esm.js",
7
7
  "typings": "dist/index.d.ts",
8
8
  "license": "MIT",
9
9
  "dependencies": {
10
+ "@marigold/icons": "workspace:*",
10
11
  "@marigold/system": "workspace:*",
12
+ "@react-aria/button": "^3.3.3",
13
+ "@react-aria/checkbox": "^3.2.3",
14
+ "@react-aria/dialog": "^3.1.4",
15
+ "@react-aria/focus": "^3.4.1",
16
+ "@react-aria/link": "^3.1.4",
17
+ "@react-aria/listbox": "^3.3.1",
18
+ "@react-aria/overlays": "^3.7.2",
19
+ "@react-aria/select": "^3.4.1",
20
+ "@react-aria/ssr": "^3.1.0",
21
+ "@react-aria/utils": "^3.8.2",
22
+ "@react-aria/visually-hidden": "^3.2.3",
23
+ "@react-stately/collections": "^3.3.3",
24
+ "@react-stately/list": "^3.3.0",
25
+ "@react-stately/overlays": "^3.1.3",
26
+ "@react-stately/select": "^3.1.3",
27
+ "@react-types/dialog": "^3.3.1",
28
+ "@react-types/shared": "^3.8.0",
11
29
  "react-keyed-flatten-children": "1.3.0"
12
30
  },
13
31
  "peerDependencies": {
@@ -15,7 +33,8 @@
15
33
  "react-dom": "^16.x || ^17.0.0"
16
34
  },
17
35
  "devDependencies": {
18
- "@marigold/types": "workspace:*"
36
+ "@marigold/types": "workspace:*",
37
+ "@testing-library/user-event": "13.5.0"
19
38
  },
20
39
  "scripts": {
21
40
  "build": "tsdx build --tsconfig tsconfig.build.json --transpileOnly",
@@ -0,0 +1,47 @@
1
+ import React from 'react';
2
+ import type { Meta, ComponentStory } from '@storybook/react';
3
+
4
+ import { Button } from '../Button';
5
+ import { ActionGroup } from './ActionGroup';
6
+
7
+ export default {
8
+ component: ActionGroup,
9
+ title: 'Components/ActionGroup',
10
+ argTypes: {
11
+ space: {
12
+ control: {
13
+ type: 'select',
14
+ },
15
+ options: [
16
+ 'none',
17
+ 'xxsmall',
18
+ 'xsmall',
19
+ 'small',
20
+ 'medium',
21
+ 'large',
22
+ 'xlarge',
23
+ 'xxlarge',
24
+ ],
25
+ defaultValue: 'none',
26
+ description: 'spacing around the group',
27
+ },
28
+ verticalAlignment: {
29
+ control: {
30
+ type: 'boolean',
31
+ },
32
+ defaultValue: false,
33
+ description: 'switch alignment',
34
+ },
35
+ },
36
+ } as Meta;
37
+
38
+ export const Basic: ComponentStory<typeof ActionGroup> = args => (
39
+ <ActionGroup {...args}>
40
+ <Button variant="text" size="small">
41
+ Cancel
42
+ </Button>
43
+ <Button variant="primary" size="small">
44
+ Confirm
45
+ </Button>
46
+ </ActionGroup>
47
+ );
@@ -0,0 +1,83 @@
1
+ import React from 'react';
2
+ import { render, screen } from '@testing-library/react';
3
+ import { ThemeProvider } from '@marigold/system';
4
+ import { ActionGroup } from './ActionGroup';
5
+ import { Button } from '../Button';
6
+
7
+ const theme = {
8
+ space: {
9
+ none: 0,
10
+ small: 2,
11
+ },
12
+ };
13
+
14
+ const getLeftPadding = (element: HTMLElement) =>
15
+ getComputedStyle(element).getPropertyValue('padding-left');
16
+
17
+ const getTopPadding = (element: HTMLElement) =>
18
+ getComputedStyle(element).getPropertyValue('padding-top');
19
+
20
+ test('default space is "none"', () => {
21
+ render(
22
+ <ThemeProvider theme={theme}>
23
+ <ActionGroup title="actionGroup">
24
+ <Button title="Button1">Button1</Button>
25
+ <Button title="Button2">Button2</Button>
26
+ </ActionGroup>
27
+ </ThemeProvider>
28
+ );
29
+ const first = screen.getByTitle(/Button1/).parentElement!;
30
+ const second = screen.getByTitle(/Button2/).parentElement!;
31
+
32
+ expect(getLeftPadding(first)).toEqual('');
33
+ expect(second).toHaveStyle(`padding-left: 0px`);
34
+ });
35
+
36
+ test('supports space prop', () => {
37
+ render(
38
+ <ThemeProvider theme={theme}>
39
+ <ActionGroup title="actionGroup" space="8px">
40
+ <Button title="Button1">Button1</Button>
41
+ <Button title="Button2">Button2</Button>
42
+ </ActionGroup>
43
+ </ThemeProvider>
44
+ );
45
+ const first = screen.getByTitle(/Button1/).parentElement!;
46
+ const second = screen.getByTitle(/Button2/).parentElement;
47
+
48
+ expect(getLeftPadding(first)).toEqual('');
49
+ expect(second).toHaveStyle(`padding-left: 8px`);
50
+ });
51
+
52
+ test('accepts and uses spacing from theme', () => {
53
+ render(
54
+ <ThemeProvider theme={theme}>
55
+ <ActionGroup title="actionGroup" space="small">
56
+ <Button title="Button1">Button1</Button>
57
+ <Button title="Button2">Button2</Button>
58
+ </ActionGroup>
59
+ </ThemeProvider>
60
+ );
61
+ const first = screen.getByTitle(/Button1/).parentElement!;
62
+ const second = screen.getByTitle(/Button2/).parentElement;
63
+
64
+ expect(getLeftPadding(first)).toEqual('');
65
+ expect(second).toHaveStyle(`padding-left: 2px`);
66
+ });
67
+
68
+ test('supports verticalAlignment prop', () => {
69
+ render(
70
+ <ThemeProvider theme={theme}>
71
+ <ActionGroup title="actionGroup" space="small" verticalAlignment>
72
+ <Button title="Button1">Button1</Button>
73
+ <Button title="Button2">Button2</Button>
74
+ </ActionGroup>
75
+ </ThemeProvider>
76
+ );
77
+
78
+ const button1 = screen.getByText(/Button1/);
79
+ const button2 = screen.getByText(/Button2/);
80
+
81
+ expect(getTopPadding(button1.parentElement!)).toEqual('');
82
+ expect(button2.parentElement).toHaveStyle(`padding-top: 2px`);
83
+ });