@amboss/design-system 3.9.10 → 3.9.12

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 (32) hide show
  1. package/README.md +2 -334
  2. package/build/cjs/components/Form/PasswordInput/PasswordInput.js +1 -1
  3. package/build/cjs/components/Form/RadioButton/RadioButton.js +1 -1
  4. package/build/cjs/components/Form/SegmentedControl/SegmentedControl.js +1 -1
  5. package/build/cjs/components/Form/SegmentedControl/SegmentedControlOption.js +1 -1
  6. package/build/cjs/components/Form/ToggleButton/ToggleButton.js +1 -1
  7. package/build/cjs/components/Link/Link.d.ts +11 -2
  8. package/build/cjs/components/Link/Link.js +1 -1
  9. package/build/cjs/components/Patterns/Modal/Modal.js +3 -3
  10. package/build/cjs/components/RoundButton/RoundButton.js +1 -1
  11. package/build/cjs/web-tokens/_colors.json +20 -12
  12. package/build/cjs/web-tokens/assets/icons.json +1 -0
  13. package/build/cjs/web-tokens/assets/icons16.json +1 -0
  14. package/build/cjs/web-tokens/visualConfig.d.ts +6 -0
  15. package/build/cjs/web-tokens/visualConfig.js +1 -1
  16. package/build/esm/components/Form/PasswordInput/PasswordInput.js +1 -1
  17. package/build/esm/components/Form/RadioButton/RadioButton.js +1 -1
  18. package/build/esm/components/Form/SegmentedControl/SegmentedControl.js +1 -1
  19. package/build/esm/components/Form/SegmentedControl/SegmentedControlOption.js +1 -1
  20. package/build/esm/components/Form/ToggleButton/ToggleButton.js +1 -1
  21. package/build/esm/components/Link/Link.d.ts +11 -2
  22. package/build/esm/components/Link/Link.js +1 -1
  23. package/build/esm/components/Patterns/Modal/Modal.js +3 -3
  24. package/build/esm/components/RoundButton/RoundButton.js +1 -1
  25. package/build/esm/web-tokens/_colors.json +20 -12
  26. package/build/esm/web-tokens/assets/icons.json +1 -0
  27. package/build/esm/web-tokens/assets/icons16.json +1 -0
  28. package/build/esm/web-tokens/visualConfig.d.ts +6 -0
  29. package/build/esm/web-tokens/visualConfig.js +1 -1
  30. package/build/scss/_theming.scss +8 -6
  31. package/build/scss/_variables.scss +1 -0
  32. package/package.json +1 -1
package/README.md CHANGED
@@ -2,337 +2,5 @@
2
2
 
3
3
  [![Latest version](https://img.shields.io/npm/v/@amboss/design-system?color=green&label=design-system)](https://www.npmjs.com/package/@amboss/design-system) ![Dependencies](https://img.shields.io/librariesio/release/npm/@amboss/design-system) ![React Version](https://img.shields.io/npm/dependency-version/@amboss/design-system/react?color=red)
4
4
 
5
- 📄 [Browse the design system (Storyboard documentation)](https://design-system.miamed.de/)
6
-
7
- ## Quick start
8
-
9
- **Development**
10
- Ensure that you are using `npm` >= 7.0.0 before running `npm install`
11
-
12
- To start the project run `npm run start`
13
-
14
- To generate a new component run `npm run component myComponentName`
15
-
16
- **Building the package**
17
-
18
- To build the package run `npm run build`
19
-
20
- **Building storybook**
21
-
22
- To build storybook run `npm run build-storybook`
23
-
24
- **Publishing**
25
-
26
- - Add `minor`, `major` or `patch` label to your PR to specify release type.
27
- - Add `skip-release` label to skip the release
28
- - If you want your commit to skip ci, add "[skip ci]" to your commit message.
29
-
30
- **Generating mobile tokens**
31
-
32
- 1. Install Node.js and npm by following the [official installation guide](https://docs.npmjs.com/downloading-and-installing-node-js-and-npm)
33
- 2. Install dependencies:
34
- `npm install`
35
- 3. Generate the tokens:
36
- ```
37
- npm run tokens:ios
38
- npm run tokens:android
39
- ```
40
-
41
- **Generating mobile icons**
42
-
43
- 1. Install Node.js and npm by following the [official installation guide](https://docs.npmjs.com/downloading-and-installing-node-js-and-npm)
44
- 2. Install dependencies:
45
- `npm install`
46
- 3. Generate the tokens:
47
- ```
48
- npm run icons:ios
49
- npm run icons:android
50
- ```
51
-
52
- ### Codebase Overview
53
-
54
- **1. [Tech stack](#tech-stack)**<br/>
55
- **2. [Linting](#linting)**<br/>
56
- **3. [Folder structure](#folder-structure)**<br/>
57
- **4. [Build](#build)**<br/>
58
- **5. [Tokens, styles and theming](#tokens-styles-and-theming)**<br/>
59
- **6. [Assets](#assets)**<br/>
60
- **7. [Media queries](#media-queries)**<br/>
61
-
62
- ## Tech stack
63
-
64
- - Code: **typescript**
65
- - Styles: **emotion.js**
66
- - Framework: **react**
67
- - Bundler: **vite**
68
- - Environment: **storybook**
69
- - Tokens: **[style-dictionary](https://github.com/amzn/style-dictionary)**
70
- - Testing: **jest + react testing library**
71
-
72
- ## Linting
73
-
74
- As for linting and formatting, you can configure your editor to automatically lint and format your code on save. For this purpose, we're using [Prettier](https://prettier.io/) and [ESLint](https://eslint.org/). If you need to do it manually, you can run:
75
-
76
- ```sh
77
- npm run lint
78
- ```
79
-
80
- > This command is also run as a **pre-push hook** and in the pipeline.
81
-
82
- ## Folder structure
83
-
84
- ```
85
- |-- .storybook
86
-     |-- components
87
-         |-- ColorGrid.tsx
88
-         |-- SizeGrid.tsx
89
-     |-- main.js
90
-     |-- preview.js
91
- |-- assets
92
-     |-- fonts
93
-         |-- Lato.woff
94
- |-- build (autogenerated)
95
- |-- build-icons (autogenerated)
96
- |-- android
97
- |-- ic_activity_16.xml
98
- |-- ic_activity_24.xml
99
- |-- ios
100
- |-- activity.imageset
101
- |-- activity.pdf
102
- |-- activity16.pdf
103
- |-- Contents.json
104
- |-- build-tokens (autogenerated)
105
- |-- android
106
- |-- design_system_color.xml
107
- |-- ios
108
- |-- DesignSystemColorTokens.swift
109
- |-- scss
110
- |-- _theming.scss
111
- |-- _variables.scss
112
- |-- assets
113
- |-- icons.json
114
- |-- icons16.json
115
-     |-- _colors.json
116
-     |-- _sizes.json
117
- |-- visualConfig.ts
118
- |-- docs
119
-     |-- Design-principles.mdx
120
- |-- static
121
-     |-- image-for-storybook.png
122
- |-- tokens
123
- |-- global
124
-     |-- themes
125
-         |-- dark.json
126
-         |-- light.json
127
-     |-- assets.json
128
-     |-- colors.json
129
- |-- web
130
- |-- component
131
- |-- dark.json
132
- |-- light.json
133
- |-- android
134
- |-- opacity.json
135
- |-- ios
136
- |-- opacity.json
137
- |-- src
138
-     |-- index.ts
139
-     |-- components
140
-         |-- Button
141
-             |-- Button.tsx
142
-             |-- Button.stories.tsx
143
-             |-- Button.test.tsx
144
-     |-- shared
145
- -- mediaQueries.ts
146
-     |-- types
147
-         |-- index.ts
148
- ```
149
-
150
- ## Build
151
-
152
- There are 3 stages of a build.
153
-
154
- 1. Generate variables, theme values and assets from tokens
155
- 2. Build all exported components with swc (preset-react, preset-typescript)
156
- 3. Bundle all built components with vite
157
-
158
- ### Generate variables, theme values and assets from tokens
159
-
160
- In order to structure our tokens we use **[style-dictionary](https://github.com/amzn/style-dictionary)**.
161
- This tool is used for creation a content of `./build-tokens` folder where we keep all the scss variables and mixins.
162
-
163
- New variables and mixins gets generated automaticaly:
164
-
165
- - in watch mode while `npm run start` is running
166
- - after npm install
167
- - before build
168
-
169
- You can generate tokens manually using `npm run tokens:web` and `npm run tokens:watch`
170
-
171
- We use tokens to control the most atomic values in styles and themes.
172
-
173
- How does it work?
174
-
175
- We have a set of .json files that are located in `./tokens` folder, and we have a `style-dictionary` as a tool for converting .json in to various formats.
176
-
177
- For example:
178
-
179
- We have a file - `./tokens/global/light|dark.json` that gets converted into part of `./build-tokens/visualConfig.ts`.
180
-
181
- `visualConfig.ts` is used later as a source for emotion.js theme.
182
-
183
- The configuration for `style-dictionary` is inside `./style-dictionary/{platformName}/{platformName}.sd.config.json`. In this config we use some custom transforms, filters and formatters, all of them defined in corresponding files of platform folders.
184
-
185
- **custom/format/emotion-visual-config** - a formatter that generates visualConfig.ts that contains all variables and themed values.
186
-
187
- **custom/filter/emotion-build-tokens** - a filter for all token categories that should go to visutal config.
188
-
189
- **custom/format/json** - a formatter for generation .json files per category. This formatter also add `isUsed` flag to according token.
190
-
191
- **custom/format/sub-theme-types** - a formatter that generates type definitions for sub-themes.
192
-
193
- **custom/assets/svg** - a transformer that adds a path name to dictionary of svg icons.
194
-
195
- [More about tokens, themes and styles.](#tokens-styles-and-theming)
196
-
197
- ### Bundle all exported components
198
-
199
- Before publishing the design system for NPM, we run `npm run build`. This runs the script at ``bundles everything that is exported from`.ts`and`.tsx` files within the source.
200
-
201
- For this, we use `tsup`, which runs `esbuild` under the hood. We also use a lenient browserslist config to ensure compatibility with older browsers.
202
-
203
- For styles, we use emotion.js.
204
-
205
- What in the bundle?
206
-
207
- - JS code that is compiled from `.tsx` files (includes common components and emotion.js styled components)
208
- - SVG icons that are inlined
209
-
210
- fonts that are base64-ed currently taken off the build
211
-
212
- ## Tokens, styles and theming
213
-
214
- Currently, we have 4 types of tokens:
215
-
216
- - Atomic values, like colors, sizes, shadows.
217
- - Font assets, that are basically base64 of font files. (not used in production)
218
- - Theme values, that are referencing atomic different atomic values
219
- - Svg icon assets, that are inlined to a `.json` file
220
-
221
- As we use Emotion.js all tokenized values are accessible via theme provider. <br />
222
-
223
- Basically during the build phase we generate big objects of variables and themed values for each theme (currently light and dark). <br />
224
-
225
- We call this object `ambossVisualConfiguration`.
226
-
227
- Particular themes from `ambossVisualConfiguration` has to be imported and passed to the theme provider at the consumer side.<br />
228
-
229
- <br />
230
-
231
- Atomic values are straight forward and simply converted to `variables`.
232
-
233
- After build all atomic values are passed to `theme.variables` by emotion.
234
-
235
- Example:
236
-
237
- ```ts
238
- const StyledContainer - styled.div(
239
- ({ theme }) => ({
240
- marginTop: theme.variables.size.spacing.s
241
- })
242
- );
243
- ```
244
-
245
- Theme tokens are little more complex. We generate separate VisualConfig for each theme, but together with that we generate type definition that describe any of the themes. This enables developers not care about current theme and how many themes are there.
246
-
247
- After build all themes values are passed to `theme.values` by emotion.
248
-
249
- Example:
250
-
251
- ```ts
252
- const StyledContainer - styled.div(
253
- ({ theme }) => ({
254
- backgroundColor: theme.values.color.background.primary.default
255
- })
256
- );
257
- ```
258
-
259
- Sub-themes are following the same concept as themes. Developer can fully rely on `theme.values` object. As long as component in runtime is wrapped in `SubThemeProvider` and its tokens listed in "tokens/themes/sub-themes/...", all values will be set correctly and automatically.
260
-
261
- > Note that not all tokens are enabled in sub-themes. Make sure to add missing ones to "tokens/themes/sub-themes/...".
262
-
263
- > Components that have a "Sub-themed" badge are already in.
264
-
265
- ## Assets
266
-
267
- - assets are defined in `tokens/assets.json`
268
- - with the help from style-dictionary we create a `json` file with tokens (`/build-tokens/assets/`)
269
- - those `json` files supposed to be imported in the ts module (see `Icons.tsx`)
270
- - in order to secure `d.ts` filed in the build we "manually" copy asset `json`s on the `postbuild` phase (see `package.json`)
271
-
272
- ## Media queries
273
-
274
- There is an API for media-query related props: an array of 3 elements [small, medium, large], for respective screen sizes.
275
-
276
- For example `<Box space=["xs", "xl", "xxl"] />` will set `xs` for small screens, `xl` for medium screens and `xxl` for large.
277
-
278
- Basically, if you see a type of `MQ<Whatever>` you can provide an array of 3 `Whatever`s.
279
-
280
- In order to add a media query support to your components:
281
-
282
- ```ts
283
- import React from "react";
284
-
285
- import styled from "@emotion/styled";
286
- import { useResponsiveStyles } from "../../shared/mediaQueries";
287
-
288
- type TextAlignment = "left" | "center" | "right";
289
-
290
- type BoxProps = {
291
- alignText: TextAlignment | MQ<TextAlignment>;
292
- };
293
-
294
- export const Box = styled.div<BoxProps>(({ alignText = "left" }) =>
295
- useResponsiveStyles({
296
- textAlign: [alignText, { left: "left", right: "right", center: "center" }],
297
- })
298
- );
299
- ```
300
-
301
- ## Shadow-DOM
302
-
303
- In order to use emotion-enabled DS components in the shadow-dom, you need to take some steps to 'link' the styles in the light-dom (these are added by emotion using CSSStyleSheet.insertRule() which is why <style data-emotion> appears empty in the DOM).
304
-
305
- emotion-js/emotion#1366
306
- https://emotion.sh/docs/cache-provider
307
- https://stackblitz.com/edit/emotion-shadow-dom-example?file=ShadowDomContainer.js
308
- https://developer.mozilla.org/en-US/docs/Web/API/CSSStyleSheet/insertRule
309
-
310
- ```js
311
- import {
312
- ThemeProvider,
313
- light,
314
- Card,
315
- H1,
316
- CacheProvider,
317
- createCache,
318
- } from "@amboss/design-system";
319
- class SuchShadow extends HTMLElement {
320
- connectedCallback() {
321
- const root = document.createElement("div");
322
- this.attachShadow({ mode: "open" });
323
- this.emotionCache = createCache({ container: this.shadowRoot });
324
- render(
325
- <ThemeProvider theme={light}>
326
- <CacheProvider value={this.emotionCache}>
327
- <Card>
328
- <H1>I love you shadow unicorn!!!</H1>
329
- </Card>
330
- </CacheProvider>
331
- </ThemeProvider>,
332
- root
333
- );
334
- }
335
- }
336
-
337
- customElements.define("shadow-element", SuchShadow);
338
- ```
5
+ 🧑‍💻 [How to Contribute](https://design-system.miamed.de/?path=/docs/introduction-contribution-guide-overview--docs)
6
+ 📄 [Browse the design system (Storyboard documentation)](https://design-system.miamed.de/)
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get PasswordInput(){return PasswordInput},get PasswordInputRaw(){return PasswordInputRaw}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Icon=require("../../Icon/Icon"),_FormField=require("../FormField/FormField"),_useFormFieldMessageId=require("../FormField/useFormFieldMessageId"),handleBorderColor=(theme,hasError,readOnly)=>hasError?theme.values.color.border.error.default:readOnly?theme.values.color.border.primary.disabled:theme.values.color.border.primary.default,handleIconBorderColor=(theme,hasError)=>hasError?theme.values.color.icon.error.default:"transparent",handleIconLeftBorderColor=(theme,hasError)=>hasError?theme.values.color.border.error.default:theme.values.color.border.primary.default,StyledContainer=(0,_styled.default)("div",{target:"e1mxlpm80",label:"StyledContainer"})(()=>({width:"100%",display:"flex",alignItems:"center",flexDirection:"row",position:"relative"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/PasswordInput/PasswordInput.tsx","sources":["src/components/Form/PasswordInput/PasswordInput.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport type { RefObject, InputHTMLAttributes } from \"react\";\nimport React, { useState, forwardRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject, Theme } from \"@emotion/react\";\nimport { Icon } from \"../../Icon/Icon\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport { useFormFieldMessageId } from \"../FormField/useFormFieldMessageId\";\n\nexport type PasswordInputProps = {\n  iconAriaLabel: string;\n} & InputProps;\n\ntype InputProps = {\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Set to true to disabled input\n   */\n  onIconClick?: (e: React.MouseEvent) => void;\n} & FormFieldProps &\n  Omit<InputHTMLAttributes<HTMLInputElement>, \"type\">;\n\ntype IconProps = {\n  hasError?: boolean;\n  disabled?: boolean;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  tabIndex?: number;\n};\n\nconst handleBorderColor = (\n  theme: Theme,\n  hasError: boolean,\n  readOnly: boolean\n) => {\n  if (hasError) return theme.values.color.border.error.default;\n  if (readOnly) return theme.values.color.border.primary.disabled;\n\n  return theme.values.color.border.primary.default;\n};\n\nconst handleIconBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.icon.error.default;\n  return \"transparent\";\n};\n\nconst handleIconLeftBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.border.error.default;\n  return theme.values.color.border.primary.default;\n};\n\nconst StyledContainer = styled.div(\n  () =>\n    ({\n      width: \"100%\",\n      display: \"flex\",\n      alignItems: \"center\",\n      flexDirection: \"row\",\n      position: \"relative\",\n    } as CSSObject)\n);\n\nconst StyledIconBtn = styled.button<IconProps>(({ theme, hasError }) => ({\n  \"&[type='button']\": {\n    appearance: \"none\",\n    MozAppearance: \"none\",\n    WebkitAppearance: \"none\",\n  },\n  position: \"absolute\",\n  top: 0,\n  right: 0,\n  border: \"1px solid\",\n  borderColor: handleIconBorderColor(theme, hasError),\n  borderLeftColor: handleIconLeftBorderColor(theme, hasError),\n  padding: `calc(${theme.variables.size.spacing.s} - 1px) ${theme.variables.size.spacing.s}`,\n  borderRadius: theme.variables.size.borderRadius.xs,\n  borderBottomLeftRadius: \"0\",\n  borderTopLeftRadius: \"0\",\n  color: theme.values.color.text.secondary.default,\n  backgroundColor: \"inherit\",\n  cursor: \"pointer\",\n  \"&:hover\": {\n    backgroundColor: theme.values.color.background.transparent.hover,\n    borderColor: theme.values.color.border.primary.default,\n  },\n  \"&:active\": {\n    color: theme.values.color.text.primary.default,\n    backgroundColor: theme.values.color.background.transparent.active,\n    borderColor: theme.values.color.border.primary.active,\n  },\n  \"&:disabled\": {\n    backgroundColor: theme.values.color.background.transparent.default,\n    borderLeftColor: theme.values.color.border.primary.disabled,\n    pointerEvents: \"none\",\n  },\n  ...(hasError && {\n    boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n  }),\n  \"& svg\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledPasswordInput = styled.input<InputProps>(\n  ({ theme, hasError, readOnly }) => ({\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.m,\n    lineHeight: theme.variables.size.lineHeight.xl,\n    borderRadius: theme.variables.size.borderRadius.xs,\n    borderWidth: \"1px\",\n    borderStyle: \"solid\",\n    width: \"100%\",\n    padding: `calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,\n    paddingRight: theme.variables.size.spacing.xxl,\n    boxSizing: \"border-box\",\n    color: theme.values.color.text.secondary.default,\n    borderColor: handleBorderColor(theme, hasError, readOnly),\n    backgroundColor: theme.values.color.background.primary.default,\n    \"&.error\": {\n      borderColor: theme.values.color.border.error.default,\n    },\n    \"&.has-icon\": {\n      paddingRight:\n        theme.variables.size.spacing.xs + theme.variables.size.dimension.icon.m,\n    },\n    \"&::placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n      opacity: theme.variables.opacity.visible,\n    },\n    \"&:-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    \"&::-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    ...(hasError && {\n      boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n    }),\n  })\n);\n\nexport const PasswordInputRaw = forwardRef(\n  (\n    {\n      placeholder,\n      hasError = false,\n      onIconClick,\n      iconAriaLabel,\n      readOnly,\n      disabled,\n      ...rest\n    }: PasswordInputProps,\n    ref: RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const [inputType, setInputType] = useState(\"password\");\n    const currentType = inputType === \"password\" ? \"text\" : \"password\";\n    const eyeIcon = inputType === \"password\" ? \"eye-off\" : \"eye\";\n\n    return (\n      <StyledContainer>\n        <StyledPasswordInput\n          {...rest}\n          type={inputType}\n          placeholder={!readOnly && placeholder}\n          ref={ref}\n          hasError={hasError}\n          readOnly={readOnly}\n          disabled={disabled}\n          aria-invalid={hasError}\n        />\n        <StyledIconBtn\n          onClick={(e: React.MouseEvent) => {\n            if (disabled) {\n              e.preventDefault();\n            }\n            if (onIconClick) {\n              onIconClick(e);\n            }\n            setInputType(currentType);\n          }}\n          hasError={hasError}\n          disabled={readOnly || disabled}\n          aria-label={iconAriaLabel}\n          type=\"button\"\n        >\n          <Icon\n            name={eyeIcon}\n            size=\"s\"\n            color={readOnly ? \"quaternary\" : \"tertiary\"}\n          />\n        </StyledIconBtn>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const PasswordInput = React.forwardRef(\n  (\n    {\n      placeholder = \"••••••••\",\n      hasError = false,\n      onIconClick,\n      autoComplete = \"on\",\n      iconAriaLabel,\n      disabled,\n      label,\n      labelHint,\n      hideLabel,\n      hint,\n      errorMessages,\n      \"aria-describedby\": ariaDescribedBy,\n      \"data-e2e-test-id\": dataE2eTestId,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const { id, ariaDescribedByProp } = useFormFieldMessageId({\n      ariaDescribedBy,\n      errorMessages,\n      hint,\n    });\n\n    return (\n      <FormField\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"PasswordInput\"\n        disabled={disabled}\n        label={label}\n        labelHint={labelHint}\n        hideLabel={hideLabel}\n        hint={hint}\n        errorMessages={errorMessages}\n        messageId={id}\n      >\n        <PasswordInputRaw\n          {...rest}\n          ref={ref}\n          placeholder={placeholder}\n          hasError={hasError}\n          disabled={disabled}\n          onIconClick={onIconClick}\n          autoComplete={autoComplete}\n          iconAriaLabel={iconAriaLabel}\n          {...ariaDescribedByProp}\n        />\n      </FormField>\n    );\n  }\n);\n"],"names":[],"mappings":"AAuDwB"} */"),StyledIconBtn=(0,_styled.default)("button",{target:"e1mxlpm81",label:"StyledIconBtn"})(({theme,hasError})=>({"&[type='button']":{appearance:"none",MozAppearance:"none",WebkitAppearance:"none"},position:"absolute",top:0,right:0,border:"1px solid",borderColor:handleIconBorderColor(theme,hasError),borderLeftColor:handleIconLeftBorderColor(theme,hasError),padding:`calc(${theme.variables.size.spacing.s} - 1px) ${theme.variables.size.spacing.s}`,borderRadius:theme.variables.size.borderRadius.xs,borderBottomLeftRadius:"0",borderTopLeftRadius:"0",color:theme.values.color.text.secondary.default,backgroundColor:"inherit",cursor:"pointer","&:hover":{backgroundColor:theme.values.color.background.transparent.hover,borderColor:theme.values.color.border.primary.default},"&:active":{color:theme.values.color.text.primary.default,backgroundColor:theme.values.color.background.transparent.active,borderColor:theme.values.color.border.primary.active},"&:disabled":{backgroundColor:theme.values.color.background.transparent.default,borderLeftColor:theme.values.color.border.primary.disabled,pointerEvents:"none"},...hasError&&{boxShadow:`0 0 0 1px inset ${theme.values.color.border.error.default}`},"& svg":{pointerEvents:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/PasswordInput/PasswordInput.tsx","sources":["src/components/Form/PasswordInput/PasswordInput.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport type { RefObject, InputHTMLAttributes } from \"react\";\nimport React, { useState, forwardRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject, Theme } from \"@emotion/react\";\nimport { Icon } from \"../../Icon/Icon\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport { useFormFieldMessageId } from \"../FormField/useFormFieldMessageId\";\n\nexport type PasswordInputProps = {\n  iconAriaLabel: string;\n} & InputProps;\n\ntype InputProps = {\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Set to true to disabled input\n   */\n  onIconClick?: (e: React.MouseEvent) => void;\n} & FormFieldProps &\n  Omit<InputHTMLAttributes<HTMLInputElement>, \"type\">;\n\ntype IconProps = {\n  hasError?: boolean;\n  disabled?: boolean;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  tabIndex?: number;\n};\n\nconst handleBorderColor = (\n  theme: Theme,\n  hasError: boolean,\n  readOnly: boolean\n) => {\n  if (hasError) return theme.values.color.border.error.default;\n  if (readOnly) return theme.values.color.border.primary.disabled;\n\n  return theme.values.color.border.primary.default;\n};\n\nconst handleIconBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.icon.error.default;\n  return \"transparent\";\n};\n\nconst handleIconLeftBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.border.error.default;\n  return theme.values.color.border.primary.default;\n};\n\nconst StyledContainer = styled.div(\n  () =>\n    ({\n      width: \"100%\",\n      display: \"flex\",\n      alignItems: \"center\",\n      flexDirection: \"row\",\n      position: \"relative\",\n    } as CSSObject)\n);\n\nconst StyledIconBtn = styled.button<IconProps>(({ theme, hasError }) => ({\n  \"&[type='button']\": {\n    appearance: \"none\",\n    MozAppearance: \"none\",\n    WebkitAppearance: \"none\",\n  },\n  position: \"absolute\",\n  top: 0,\n  right: 0,\n  border: \"1px solid\",\n  borderColor: handleIconBorderColor(theme, hasError),\n  borderLeftColor: handleIconLeftBorderColor(theme, hasError),\n  padding: `calc(${theme.variables.size.spacing.s} - 1px) ${theme.variables.size.spacing.s}`,\n  borderRadius: theme.variables.size.borderRadius.xs,\n  borderBottomLeftRadius: \"0\",\n  borderTopLeftRadius: \"0\",\n  color: theme.values.color.text.secondary.default,\n  backgroundColor: \"inherit\",\n  cursor: \"pointer\",\n  \"&:hover\": {\n    backgroundColor: theme.values.color.background.transparent.hover,\n    borderColor: theme.values.color.border.primary.default,\n  },\n  \"&:active\": {\n    color: theme.values.color.text.primary.default,\n    backgroundColor: theme.values.color.background.transparent.active,\n    borderColor: theme.values.color.border.primary.active,\n  },\n  \"&:disabled\": {\n    backgroundColor: theme.values.color.background.transparent.default,\n    borderLeftColor: theme.values.color.border.primary.disabled,\n    pointerEvents: \"none\",\n  },\n  ...(hasError && {\n    boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n  }),\n  \"& svg\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledPasswordInput = styled.input<InputProps>(\n  ({ theme, hasError, readOnly }) => ({\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.m,\n    lineHeight: theme.variables.size.lineHeight.xl,\n    borderRadius: theme.variables.size.borderRadius.xs,\n    borderWidth: \"1px\",\n    borderStyle: \"solid\",\n    width: \"100%\",\n    padding: `calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,\n    paddingRight: theme.variables.size.spacing.xxl,\n    boxSizing: \"border-box\",\n    color: theme.values.color.text.secondary.default,\n    borderColor: handleBorderColor(theme, hasError, readOnly),\n    backgroundColor: theme.values.color.background.primary.default,\n    \"&.error\": {\n      borderColor: theme.values.color.border.error.default,\n    },\n    \"&.has-icon\": {\n      paddingRight:\n        theme.variables.size.spacing.xs + theme.variables.size.dimension.icon.m,\n    },\n    \"&::placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n      opacity: theme.variables.opacity.visible,\n    },\n    \"&:-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    \"&::-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    ...(hasError && {\n      boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n    }),\n  })\n);\n\nexport const PasswordInputRaw = forwardRef(\n  (\n    {\n      placeholder,\n      hasError = false,\n      onIconClick,\n      iconAriaLabel,\n      readOnly,\n      disabled,\n      ...rest\n    }: PasswordInputProps,\n    ref: RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const [inputType, setInputType] = useState(\"password\");\n    const currentType = inputType === \"password\" ? \"text\" : \"password\";\n    const eyeIcon = inputType === \"password\" ? \"eye-off\" : \"eye\";\n\n    return (\n      <StyledContainer>\n        <StyledPasswordInput\n          {...rest}\n          type={inputType}\n          placeholder={!readOnly && placeholder}\n          ref={ref}\n          hasError={hasError}\n          readOnly={readOnly}\n          disabled={disabled}\n          aria-invalid={hasError}\n        />\n        <StyledIconBtn\n          onClick={(e: React.MouseEvent) => {\n            if (disabled) {\n              e.preventDefault();\n            }\n            if (onIconClick) {\n              onIconClick(e);\n            }\n            setInputType(currentType);\n          }}\n          hasError={hasError}\n          disabled={readOnly || disabled}\n          aria-label={iconAriaLabel}\n          type=\"button\"\n        >\n          <Icon\n            name={eyeIcon}\n            size=\"s\"\n            color={readOnly ? \"quaternary\" : \"tertiary\"}\n          />\n        </StyledIconBtn>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const PasswordInput = React.forwardRef(\n  (\n    {\n      placeholder = \"••••••••\",\n      hasError = false,\n      onIconClick,\n      autoComplete = \"on\",\n      iconAriaLabel,\n      disabled,\n      label,\n      labelHint,\n      hideLabel,\n      hint,\n      errorMessages,\n      \"aria-describedby\": ariaDescribedBy,\n      \"data-e2e-test-id\": dataE2eTestId,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const { id, ariaDescribedByProp } = useFormFieldMessageId({\n      ariaDescribedBy,\n      errorMessages,\n      hint,\n    });\n\n    return (\n      <FormField\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"PasswordInput\"\n        disabled={disabled}\n        label={label}\n        labelHint={labelHint}\n        hideLabel={hideLabel}\n        hint={hint}\n        errorMessages={errorMessages}\n        messageId={id}\n      >\n        <PasswordInputRaw\n          {...rest}\n          ref={ref}\n          placeholder={placeholder}\n          hasError={hasError}\n          disabled={disabled}\n          onIconClick={onIconClick}\n          autoComplete={autoComplete}\n          iconAriaLabel={iconAriaLabel}\n          {...ariaDescribedByProp}\n        />\n      </FormField>\n    );\n  }\n);\n"],"names":[],"mappings":"AAkEsB"} */"),StyledPasswordInput=(0,_styled.default)("input",{target:"e1mxlpm82",label:"StyledPasswordInput"})(({theme,hasError,readOnly})=>({fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.m,lineHeight:theme.variables.size.lineHeight.xl,borderRadius:theme.variables.size.borderRadius.xs,borderWidth:"1px",borderStyle:"solid",width:"100%",padding:`calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,paddingRight:theme.variables.size.spacing.xxl,boxSizing:"border-box",color:theme.values.color.text.secondary.default,borderColor:handleBorderColor(theme,hasError,readOnly),backgroundColor:theme.values.color.background.primary.default,"&.error":{borderColor:theme.values.color.border.error.default},"&.has-icon":{paddingRight:theme.variables.size.spacing.xs+theme.variables.size.dimension.icon.m},"&::placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default,opacity:theme.variables.opacity.visible},"&:-ms-input-placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default},"&::-ms-input-placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default},...hasError&&{boxShadow:`0 0 0 1px inset ${theme.values.color.border.error.default}`}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/PasswordInput/PasswordInput.tsx","sources":["src/components/Form/PasswordInput/PasswordInput.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport type { RefObject, InputHTMLAttributes } from \"react\";\nimport React, { useState, forwardRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject, Theme } from \"@emotion/react\";\nimport { Icon } from \"../../Icon/Icon\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport { useFormFieldMessageId } from \"../FormField/useFormFieldMessageId\";\n\nexport type PasswordInputProps = {\n  iconAriaLabel: string;\n} & InputProps;\n\ntype InputProps = {\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Set to true to disabled input\n   */\n  onIconClick?: (e: React.MouseEvent) => void;\n} & FormFieldProps &\n  Omit<InputHTMLAttributes<HTMLInputElement>, \"type\">;\n\ntype IconProps = {\n  hasError?: boolean;\n  disabled?: boolean;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  tabIndex?: number;\n};\n\nconst handleBorderColor = (\n  theme: Theme,\n  hasError: boolean,\n  readOnly: boolean\n) => {\n  if (hasError) return theme.values.color.border.error.default;\n  if (readOnly) return theme.values.color.border.primary.disabled;\n\n  return theme.values.color.border.primary.default;\n};\n\nconst handleIconBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.icon.error.default;\n  return \"transparent\";\n};\n\nconst handleIconLeftBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.border.error.default;\n  return theme.values.color.border.primary.default;\n};\n\nconst StyledContainer = styled.div(\n  () =>\n    ({\n      width: \"100%\",\n      display: \"flex\",\n      alignItems: \"center\",\n      flexDirection: \"row\",\n      position: \"relative\",\n    } as CSSObject)\n);\n\nconst StyledIconBtn = styled.button<IconProps>(({ theme, hasError }) => ({\n  \"&[type='button']\": {\n    appearance: \"none\",\n    MozAppearance: \"none\",\n    WebkitAppearance: \"none\",\n  },\n  position: \"absolute\",\n  top: 0,\n  right: 0,\n  border: \"1px solid\",\n  borderColor: handleIconBorderColor(theme, hasError),\n  borderLeftColor: handleIconLeftBorderColor(theme, hasError),\n  padding: `calc(${theme.variables.size.spacing.s} - 1px) ${theme.variables.size.spacing.s}`,\n  borderRadius: theme.variables.size.borderRadius.xs,\n  borderBottomLeftRadius: \"0\",\n  borderTopLeftRadius: \"0\",\n  color: theme.values.color.text.secondary.default,\n  backgroundColor: \"inherit\",\n  cursor: \"pointer\",\n  \"&:hover\": {\n    backgroundColor: theme.values.color.background.transparent.hover,\n    borderColor: theme.values.color.border.primary.default,\n  },\n  \"&:active\": {\n    color: theme.values.color.text.primary.default,\n    backgroundColor: theme.values.color.background.transparent.active,\n    borderColor: theme.values.color.border.primary.active,\n  },\n  \"&:disabled\": {\n    backgroundColor: theme.values.color.background.transparent.default,\n    borderLeftColor: theme.values.color.border.primary.disabled,\n    pointerEvents: \"none\",\n  },\n  ...(hasError && {\n    boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n  }),\n  \"& svg\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledPasswordInput = styled.input<InputProps>(\n  ({ theme, hasError, readOnly }) => ({\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.m,\n    lineHeight: theme.variables.size.lineHeight.xl,\n    borderRadius: theme.variables.size.borderRadius.xs,\n    borderWidth: \"1px\",\n    borderStyle: \"solid\",\n    width: \"100%\",\n    padding: `calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,\n    paddingRight: theme.variables.size.spacing.xxl,\n    boxSizing: \"border-box\",\n    color: theme.values.color.text.secondary.default,\n    borderColor: handleBorderColor(theme, hasError, readOnly),\n    backgroundColor: theme.values.color.background.primary.default,\n    \"&.error\": {\n      borderColor: theme.values.color.border.error.default,\n    },\n    \"&.has-icon\": {\n      paddingRight:\n        theme.variables.size.spacing.xs + theme.variables.size.dimension.icon.m,\n    },\n    \"&::placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n      opacity: theme.variables.opacity.visible,\n    },\n    \"&:-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    \"&::-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    ...(hasError && {\n      boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n    }),\n  })\n);\n\nexport const PasswordInputRaw = forwardRef(\n  (\n    {\n      placeholder,\n      hasError = false,\n      onIconClick,\n      iconAriaLabel,\n      readOnly,\n      disabled,\n      ...rest\n    }: PasswordInputProps,\n    ref: RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const [inputType, setInputType] = useState(\"password\");\n    const currentType = inputType === \"password\" ? \"text\" : \"password\";\n    const eyeIcon = inputType === \"password\" ? \"eye-off\" : \"eye\";\n\n    return (\n      <StyledContainer>\n        <StyledPasswordInput\n          {...rest}\n          type={inputType}\n          placeholder={!readOnly && placeholder}\n          ref={ref}\n          hasError={hasError}\n          readOnly={readOnly}\n          disabled={disabled}\n          aria-invalid={hasError}\n        />\n        <StyledIconBtn\n          onClick={(e: React.MouseEvent) => {\n            if (disabled) {\n              e.preventDefault();\n            }\n            if (onIconClick) {\n              onIconClick(e);\n            }\n            setInputType(currentType);\n          }}\n          hasError={hasError}\n          disabled={readOnly || disabled}\n          aria-label={iconAriaLabel}\n          type=\"button\"\n        >\n          <Icon\n            name={eyeIcon}\n            size=\"s\"\n            color={readOnly ? \"quaternary\" : \"tertiary\"}\n          />\n        </StyledIconBtn>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const PasswordInput = React.forwardRef(\n  (\n    {\n      placeholder = \"••••••••\",\n      hasError = false,\n      onIconClick,\n      autoComplete = \"on\",\n      iconAriaLabel,\n      disabled,\n      label,\n      labelHint,\n      hideLabel,\n      hint,\n      errorMessages,\n      \"aria-describedby\": ariaDescribedBy,\n      \"data-e2e-test-id\": dataE2eTestId,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const { id, ariaDescribedByProp } = useFormFieldMessageId({\n      ariaDescribedBy,\n      errorMessages,\n      hint,\n    });\n\n    return (\n      <FormField\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"PasswordInput\"\n        disabled={disabled}\n        label={label}\n        labelHint={labelHint}\n        hideLabel={hideLabel}\n        hint={hint}\n        errorMessages={errorMessages}\n        messageId={id}\n      >\n        <PasswordInputRaw\n          {...rest}\n          ref={ref}\n          placeholder={placeholder}\n          hasError={hasError}\n          disabled={disabled}\n          onIconClick={onIconClick}\n          autoComplete={autoComplete}\n          iconAriaLabel={iconAriaLabel}\n          {...ariaDescribedByProp}\n        />\n      </FormField>\n    );\n  }\n);\n"],"names":[],"mappings":"AA2G4B"} */"),PasswordInputRaw=(0,_react.forwardRef)(({placeholder,hasError=!1,onIconClick,iconAriaLabel,readOnly,disabled,...rest},ref)=>{let[inputType,setInputType]=(0,_react.useState)("password"),currentType="password"===inputType?"text":"password";return _react.default.createElement(StyledContainer,null,_react.default.createElement(StyledPasswordInput,{...rest,type:inputType,placeholder:!readOnly&&placeholder,ref:ref,hasError:hasError,readOnly:readOnly,disabled:disabled,"aria-invalid":hasError}),_react.default.createElement(StyledIconBtn,{onClick:e=>{disabled&&e.preventDefault(),onIconClick&&onIconClick(e),setInputType(currentType)},hasError:hasError,disabled:readOnly||disabled,"aria-label":iconAriaLabel,type:"button"},_react.default.createElement(_Icon.Icon,{name:"password"===inputType?"eye-off":"eye",size:"s",color:readOnly?"quaternary":"tertiary"})))}),PasswordInput=_react.default.forwardRef(({placeholder="••••••••",hasError=!1,onIconClick,autoComplete="on",iconAriaLabel,disabled,label,labelHint,hideLabel,hint,errorMessages,"aria-describedby":ariaDescribedBy,"data-e2e-test-id":dataE2eTestId,...rest},ref)=>{let{id,ariaDescribedByProp}=(0,_useFormFieldMessageId.useFormFieldMessageId)({ariaDescribedBy,errorMessages,hint});return _react.default.createElement(_FormField.FormField,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"PasswordInput",disabled:disabled,label:label,labelHint:labelHint,hideLabel:hideLabel,hint:hint,errorMessages:errorMessages,messageId:id},_react.default.createElement(PasswordInputRaw,{...rest,ref:ref,placeholder:placeholder,hasError:hasError,disabled:disabled,onIconClick:onIconClick,autoComplete:autoComplete,iconAriaLabel:iconAriaLabel,...ariaDescribedByProp}))});
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get PasswordInput(){return PasswordInput},get PasswordInputRaw(){return PasswordInputRaw}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Icon=require("../../Icon/Icon"),_FormField=require("../FormField/FormField"),_useFormFieldMessageId=require("../FormField/useFormFieldMessageId"),handleBorderColor=(theme,hasError,readOnly)=>hasError?theme.values.color.border.error.default:readOnly?theme.values.color.border.primary.disabled:theme.values.color.border.primary.default,handleIconBorderColor=(theme,hasError)=>hasError?theme.values.color.icon.error.default:"transparent",handleIconLeftBorderColor=(theme,hasError)=>hasError?theme.values.color.border.error.default:theme.values.color.border.primary.default,StyledContainer=(0,_styled.default)("div",{target:"e1ro5src0",label:"StyledContainer"})(()=>({width:"100%",display:"flex",alignItems:"center",flexDirection:"row",position:"relative"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/PasswordInput/PasswordInput.tsx","sources":["src/components/Form/PasswordInput/PasswordInput.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport type { RefObject, InputHTMLAttributes } from \"react\";\nimport React, { useState, forwardRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject, Theme } from \"@emotion/react\";\nimport { Icon } from \"../../Icon/Icon\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport { useFormFieldMessageId } from \"../FormField/useFormFieldMessageId\";\n\nexport type PasswordInputProps = {\n  iconAriaLabel: string;\n} & InputProps;\n\ntype InputProps = {\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Set to true to disabled input\n   */\n  onIconClick?: (e: React.MouseEvent) => void;\n} & FormFieldProps &\n  Omit<InputHTMLAttributes<HTMLInputElement>, \"type\">;\n\ntype IconProps = {\n  hasError?: boolean;\n  disabled?: boolean;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  tabIndex?: number;\n};\n\nconst handleBorderColor = (\n  theme: Theme,\n  hasError: boolean,\n  readOnly: boolean\n) => {\n  if (hasError) return theme.values.color.border.error.default;\n  if (readOnly) return theme.values.color.border.primary.disabled;\n\n  return theme.values.color.border.primary.default;\n};\n\nconst handleIconBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.icon.error.default;\n  return \"transparent\";\n};\n\nconst handleIconLeftBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.border.error.default;\n  return theme.values.color.border.primary.default;\n};\n\nconst StyledContainer = styled.div(\n  () =>\n    ({\n      width: \"100%\",\n      display: \"flex\",\n      alignItems: \"center\",\n      flexDirection: \"row\",\n      position: \"relative\",\n    } as CSSObject)\n);\n\nconst StyledIconBtn = styled.button<IconProps>(({ theme, hasError }) => ({\n  \"&[type='button']\": {\n    appearance: \"none\",\n    MozAppearance: \"none\",\n    WebkitAppearance: \"none\",\n  },\n  position: \"absolute\",\n  top: 0,\n  right: 0,\n  border: \"1px solid\",\n  borderColor: handleIconBorderColor(theme, hasError),\n  borderLeftColor: handleIconLeftBorderColor(theme, hasError),\n  padding: `calc(${theme.variables.size.spacing.s} - 1px) ${theme.variables.size.spacing.s}`,\n  borderRadius: theme.variables.size.borderRadius.xs,\n  borderBottomLeftRadius: \"0\",\n  borderTopLeftRadius: \"0\",\n  color: theme.values.color.text.secondary.default,\n  backgroundColor: \"inherit\",\n  cursor: \"pointer\",\n  \"&:hover\": {\n    backgroundColor: theme.values.color.background.transparent.hover,\n    borderColor: theme.values.color.border.primary.hover,\n  },\n  \"&:active\": {\n    color: theme.values.color.text.primary.default,\n    backgroundColor: theme.values.color.background.transparent.active,\n    borderColor: theme.values.color.border.primary.active,\n  },\n  \"&:disabled\": {\n    backgroundColor: theme.values.color.background.transparent.default,\n    borderLeftColor: theme.values.color.border.primary.disabled,\n    pointerEvents: \"none\",\n  },\n  ...(hasError && {\n    boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n  }),\n  \"& svg\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledPasswordInput = styled.input<InputProps>(\n  ({ theme, hasError, readOnly }) => ({\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.m,\n    lineHeight: theme.variables.size.lineHeight.xl,\n    borderRadius: theme.variables.size.borderRadius.xs,\n    borderWidth: \"1px\",\n    borderStyle: \"solid\",\n    width: \"100%\",\n    padding: `calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,\n    paddingRight: theme.variables.size.spacing.xxl,\n    boxSizing: \"border-box\",\n    color: theme.values.color.text.secondary.default,\n    borderColor: handleBorderColor(theme, hasError, readOnly),\n    backgroundColor: theme.values.color.background.primary.default,\n    \"&.error\": {\n      borderColor: theme.values.color.border.error.default,\n    },\n    \"&.has-icon\": {\n      paddingRight:\n        theme.variables.size.spacing.xs + theme.variables.size.dimension.icon.m,\n    },\n    \"&::placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n      opacity: theme.variables.opacity.visible,\n    },\n    \"&:-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    \"&::-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    ...(hasError && {\n      boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n    }),\n  })\n);\n\nexport const PasswordInputRaw = forwardRef(\n  (\n    {\n      placeholder,\n      hasError = false,\n      onIconClick,\n      iconAriaLabel,\n      readOnly,\n      disabled,\n      ...rest\n    }: PasswordInputProps,\n    ref: RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const [inputType, setInputType] = useState(\"password\");\n    const currentType = inputType === \"password\" ? \"text\" : \"password\";\n    const eyeIcon = inputType === \"password\" ? \"eye-off\" : \"eye\";\n\n    return (\n      <StyledContainer>\n        <StyledPasswordInput\n          {...rest}\n          type={inputType}\n          placeholder={!readOnly && placeholder}\n          ref={ref}\n          hasError={hasError}\n          readOnly={readOnly}\n          disabled={disabled}\n          aria-invalid={hasError}\n        />\n        <StyledIconBtn\n          onClick={(e: React.MouseEvent) => {\n            if (disabled) {\n              e.preventDefault();\n            }\n            if (onIconClick) {\n              onIconClick(e);\n            }\n            setInputType(currentType);\n          }}\n          hasError={hasError}\n          disabled={readOnly || disabled}\n          aria-label={iconAriaLabel}\n          type=\"button\"\n        >\n          <Icon\n            name={eyeIcon}\n            size=\"s\"\n            color={readOnly ? \"quaternary\" : \"tertiary\"}\n          />\n        </StyledIconBtn>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const PasswordInput = React.forwardRef(\n  (\n    {\n      placeholder = \"••••••••\",\n      hasError = false,\n      onIconClick,\n      autoComplete = \"on\",\n      iconAriaLabel,\n      disabled,\n      label,\n      labelHint,\n      hideLabel,\n      hint,\n      errorMessages,\n      \"aria-describedby\": ariaDescribedBy,\n      \"data-e2e-test-id\": dataE2eTestId,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const { id, ariaDescribedByProp } = useFormFieldMessageId({\n      ariaDescribedBy,\n      errorMessages,\n      hint,\n    });\n\n    return (\n      <FormField\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"PasswordInput\"\n        disabled={disabled}\n        label={label}\n        labelHint={labelHint}\n        hideLabel={hideLabel}\n        hint={hint}\n        errorMessages={errorMessages}\n        messageId={id}\n      >\n        <PasswordInputRaw\n          {...rest}\n          ref={ref}\n          placeholder={placeholder}\n          hasError={hasError}\n          disabled={disabled}\n          onIconClick={onIconClick}\n          autoComplete={autoComplete}\n          iconAriaLabel={iconAriaLabel}\n          {...ariaDescribedByProp}\n        />\n      </FormField>\n    );\n  }\n);\n"],"names":[],"mappings":"AAuDwB"} */"),StyledIconBtn=(0,_styled.default)("button",{target:"e1ro5src1",label:"StyledIconBtn"})(({theme,hasError})=>({"&[type='button']":{appearance:"none",MozAppearance:"none",WebkitAppearance:"none"},position:"absolute",top:0,right:0,border:"1px solid",borderColor:handleIconBorderColor(theme,hasError),borderLeftColor:handleIconLeftBorderColor(theme,hasError),padding:`calc(${theme.variables.size.spacing.s} - 1px) ${theme.variables.size.spacing.s}`,borderRadius:theme.variables.size.borderRadius.xs,borderBottomLeftRadius:"0",borderTopLeftRadius:"0",color:theme.values.color.text.secondary.default,backgroundColor:"inherit",cursor:"pointer","&:hover":{backgroundColor:theme.values.color.background.transparent.hover,borderColor:theme.values.color.border.primary.hover},"&:active":{color:theme.values.color.text.primary.default,backgroundColor:theme.values.color.background.transparent.active,borderColor:theme.values.color.border.primary.active},"&:disabled":{backgroundColor:theme.values.color.background.transparent.default,borderLeftColor:theme.values.color.border.primary.disabled,pointerEvents:"none"},...hasError&&{boxShadow:`0 0 0 1px inset ${theme.values.color.border.error.default}`},"& svg":{pointerEvents:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/PasswordInput/PasswordInput.tsx","sources":["src/components/Form/PasswordInput/PasswordInput.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport type { RefObject, InputHTMLAttributes } from \"react\";\nimport React, { useState, forwardRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject, Theme } from \"@emotion/react\";\nimport { Icon } from \"../../Icon/Icon\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport { useFormFieldMessageId } from \"../FormField/useFormFieldMessageId\";\n\nexport type PasswordInputProps = {\n  iconAriaLabel: string;\n} & InputProps;\n\ntype InputProps = {\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Set to true to disabled input\n   */\n  onIconClick?: (e: React.MouseEvent) => void;\n} & FormFieldProps &\n  Omit<InputHTMLAttributes<HTMLInputElement>, \"type\">;\n\ntype IconProps = {\n  hasError?: boolean;\n  disabled?: boolean;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  tabIndex?: number;\n};\n\nconst handleBorderColor = (\n  theme: Theme,\n  hasError: boolean,\n  readOnly: boolean\n) => {\n  if (hasError) return theme.values.color.border.error.default;\n  if (readOnly) return theme.values.color.border.primary.disabled;\n\n  return theme.values.color.border.primary.default;\n};\n\nconst handleIconBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.icon.error.default;\n  return \"transparent\";\n};\n\nconst handleIconLeftBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.border.error.default;\n  return theme.values.color.border.primary.default;\n};\n\nconst StyledContainer = styled.div(\n  () =>\n    ({\n      width: \"100%\",\n      display: \"flex\",\n      alignItems: \"center\",\n      flexDirection: \"row\",\n      position: \"relative\",\n    } as CSSObject)\n);\n\nconst StyledIconBtn = styled.button<IconProps>(({ theme, hasError }) => ({\n  \"&[type='button']\": {\n    appearance: \"none\",\n    MozAppearance: \"none\",\n    WebkitAppearance: \"none\",\n  },\n  position: \"absolute\",\n  top: 0,\n  right: 0,\n  border: \"1px solid\",\n  borderColor: handleIconBorderColor(theme, hasError),\n  borderLeftColor: handleIconLeftBorderColor(theme, hasError),\n  padding: `calc(${theme.variables.size.spacing.s} - 1px) ${theme.variables.size.spacing.s}`,\n  borderRadius: theme.variables.size.borderRadius.xs,\n  borderBottomLeftRadius: \"0\",\n  borderTopLeftRadius: \"0\",\n  color: theme.values.color.text.secondary.default,\n  backgroundColor: \"inherit\",\n  cursor: \"pointer\",\n  \"&:hover\": {\n    backgroundColor: theme.values.color.background.transparent.hover,\n    borderColor: theme.values.color.border.primary.hover,\n  },\n  \"&:active\": {\n    color: theme.values.color.text.primary.default,\n    backgroundColor: theme.values.color.background.transparent.active,\n    borderColor: theme.values.color.border.primary.active,\n  },\n  \"&:disabled\": {\n    backgroundColor: theme.values.color.background.transparent.default,\n    borderLeftColor: theme.values.color.border.primary.disabled,\n    pointerEvents: \"none\",\n  },\n  ...(hasError && {\n    boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n  }),\n  \"& svg\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledPasswordInput = styled.input<InputProps>(\n  ({ theme, hasError, readOnly }) => ({\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.m,\n    lineHeight: theme.variables.size.lineHeight.xl,\n    borderRadius: theme.variables.size.borderRadius.xs,\n    borderWidth: \"1px\",\n    borderStyle: \"solid\",\n    width: \"100%\",\n    padding: `calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,\n    paddingRight: theme.variables.size.spacing.xxl,\n    boxSizing: \"border-box\",\n    color: theme.values.color.text.secondary.default,\n    borderColor: handleBorderColor(theme, hasError, readOnly),\n    backgroundColor: theme.values.color.background.primary.default,\n    \"&.error\": {\n      borderColor: theme.values.color.border.error.default,\n    },\n    \"&.has-icon\": {\n      paddingRight:\n        theme.variables.size.spacing.xs + theme.variables.size.dimension.icon.m,\n    },\n    \"&::placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n      opacity: theme.variables.opacity.visible,\n    },\n    \"&:-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    \"&::-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    ...(hasError && {\n      boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n    }),\n  })\n);\n\nexport const PasswordInputRaw = forwardRef(\n  (\n    {\n      placeholder,\n      hasError = false,\n      onIconClick,\n      iconAriaLabel,\n      readOnly,\n      disabled,\n      ...rest\n    }: PasswordInputProps,\n    ref: RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const [inputType, setInputType] = useState(\"password\");\n    const currentType = inputType === \"password\" ? \"text\" : \"password\";\n    const eyeIcon = inputType === \"password\" ? \"eye-off\" : \"eye\";\n\n    return (\n      <StyledContainer>\n        <StyledPasswordInput\n          {...rest}\n          type={inputType}\n          placeholder={!readOnly && placeholder}\n          ref={ref}\n          hasError={hasError}\n          readOnly={readOnly}\n          disabled={disabled}\n          aria-invalid={hasError}\n        />\n        <StyledIconBtn\n          onClick={(e: React.MouseEvent) => {\n            if (disabled) {\n              e.preventDefault();\n            }\n            if (onIconClick) {\n              onIconClick(e);\n            }\n            setInputType(currentType);\n          }}\n          hasError={hasError}\n          disabled={readOnly || disabled}\n          aria-label={iconAriaLabel}\n          type=\"button\"\n        >\n          <Icon\n            name={eyeIcon}\n            size=\"s\"\n            color={readOnly ? \"quaternary\" : \"tertiary\"}\n          />\n        </StyledIconBtn>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const PasswordInput = React.forwardRef(\n  (\n    {\n      placeholder = \"••••••••\",\n      hasError = false,\n      onIconClick,\n      autoComplete = \"on\",\n      iconAriaLabel,\n      disabled,\n      label,\n      labelHint,\n      hideLabel,\n      hint,\n      errorMessages,\n      \"aria-describedby\": ariaDescribedBy,\n      \"data-e2e-test-id\": dataE2eTestId,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const { id, ariaDescribedByProp } = useFormFieldMessageId({\n      ariaDescribedBy,\n      errorMessages,\n      hint,\n    });\n\n    return (\n      <FormField\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"PasswordInput\"\n        disabled={disabled}\n        label={label}\n        labelHint={labelHint}\n        hideLabel={hideLabel}\n        hint={hint}\n        errorMessages={errorMessages}\n        messageId={id}\n      >\n        <PasswordInputRaw\n          {...rest}\n          ref={ref}\n          placeholder={placeholder}\n          hasError={hasError}\n          disabled={disabled}\n          onIconClick={onIconClick}\n          autoComplete={autoComplete}\n          iconAriaLabel={iconAriaLabel}\n          {...ariaDescribedByProp}\n        />\n      </FormField>\n    );\n  }\n);\n"],"names":[],"mappings":"AAkEsB"} */"),StyledPasswordInput=(0,_styled.default)("input",{target:"e1ro5src2",label:"StyledPasswordInput"})(({theme,hasError,readOnly})=>({fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.m,lineHeight:theme.variables.size.lineHeight.xl,borderRadius:theme.variables.size.borderRadius.xs,borderWidth:"1px",borderStyle:"solid",width:"100%",padding:`calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,paddingRight:theme.variables.size.spacing.xxl,boxSizing:"border-box",color:theme.values.color.text.secondary.default,borderColor:handleBorderColor(theme,hasError,readOnly),backgroundColor:theme.values.color.background.primary.default,"&.error":{borderColor:theme.values.color.border.error.default},"&.has-icon":{paddingRight:theme.variables.size.spacing.xs+theme.variables.size.dimension.icon.m},"&::placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default,opacity:theme.variables.opacity.visible},"&:-ms-input-placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default},"&::-ms-input-placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default},...hasError&&{boxShadow:`0 0 0 1px inset ${theme.values.color.border.error.default}`}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/PasswordInput/PasswordInput.tsx","sources":["src/components/Form/PasswordInput/PasswordInput.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport type { RefObject, InputHTMLAttributes } from \"react\";\nimport React, { useState, forwardRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject, Theme } from \"@emotion/react\";\nimport { Icon } from \"../../Icon/Icon\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\nimport { useFormFieldMessageId } from \"../FormField/useFormFieldMessageId\";\n\nexport type PasswordInputProps = {\n  iconAriaLabel: string;\n} & InputProps;\n\ntype InputProps = {\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Set to true to disabled input\n   */\n  onIconClick?: (e: React.MouseEvent) => void;\n} & FormFieldProps &\n  Omit<InputHTMLAttributes<HTMLInputElement>, \"type\">;\n\ntype IconProps = {\n  hasError?: boolean;\n  disabled?: boolean;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  tabIndex?: number;\n};\n\nconst handleBorderColor = (\n  theme: Theme,\n  hasError: boolean,\n  readOnly: boolean\n) => {\n  if (hasError) return theme.values.color.border.error.default;\n  if (readOnly) return theme.values.color.border.primary.disabled;\n\n  return theme.values.color.border.primary.default;\n};\n\nconst handleIconBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.icon.error.default;\n  return \"transparent\";\n};\n\nconst handleIconLeftBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.border.error.default;\n  return theme.values.color.border.primary.default;\n};\n\nconst StyledContainer = styled.div(\n  () =>\n    ({\n      width: \"100%\",\n      display: \"flex\",\n      alignItems: \"center\",\n      flexDirection: \"row\",\n      position: \"relative\",\n    } as CSSObject)\n);\n\nconst StyledIconBtn = styled.button<IconProps>(({ theme, hasError }) => ({\n  \"&[type='button']\": {\n    appearance: \"none\",\n    MozAppearance: \"none\",\n    WebkitAppearance: \"none\",\n  },\n  position: \"absolute\",\n  top: 0,\n  right: 0,\n  border: \"1px solid\",\n  borderColor: handleIconBorderColor(theme, hasError),\n  borderLeftColor: handleIconLeftBorderColor(theme, hasError),\n  padding: `calc(${theme.variables.size.spacing.s} - 1px) ${theme.variables.size.spacing.s}`,\n  borderRadius: theme.variables.size.borderRadius.xs,\n  borderBottomLeftRadius: \"0\",\n  borderTopLeftRadius: \"0\",\n  color: theme.values.color.text.secondary.default,\n  backgroundColor: \"inherit\",\n  cursor: \"pointer\",\n  \"&:hover\": {\n    backgroundColor: theme.values.color.background.transparent.hover,\n    borderColor: theme.values.color.border.primary.hover,\n  },\n  \"&:active\": {\n    color: theme.values.color.text.primary.default,\n    backgroundColor: theme.values.color.background.transparent.active,\n    borderColor: theme.values.color.border.primary.active,\n  },\n  \"&:disabled\": {\n    backgroundColor: theme.values.color.background.transparent.default,\n    borderLeftColor: theme.values.color.border.primary.disabled,\n    pointerEvents: \"none\",\n  },\n  ...(hasError && {\n    boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n  }),\n  \"& svg\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledPasswordInput = styled.input<InputProps>(\n  ({ theme, hasError, readOnly }) => ({\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.m,\n    lineHeight: theme.variables.size.lineHeight.xl,\n    borderRadius: theme.variables.size.borderRadius.xs,\n    borderWidth: \"1px\",\n    borderStyle: \"solid\",\n    width: \"100%\",\n    padding: `calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,\n    paddingRight: theme.variables.size.spacing.xxl,\n    boxSizing: \"border-box\",\n    color: theme.values.color.text.secondary.default,\n    borderColor: handleBorderColor(theme, hasError, readOnly),\n    backgroundColor: theme.values.color.background.primary.default,\n    \"&.error\": {\n      borderColor: theme.values.color.border.error.default,\n    },\n    \"&.has-icon\": {\n      paddingRight:\n        theme.variables.size.spacing.xs + theme.variables.size.dimension.icon.m,\n    },\n    \"&::placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n      opacity: theme.variables.opacity.visible,\n    },\n    \"&:-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    \"&::-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    ...(hasError && {\n      boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n    }),\n  })\n);\n\nexport const PasswordInputRaw = forwardRef(\n  (\n    {\n      placeholder,\n      hasError = false,\n      onIconClick,\n      iconAriaLabel,\n      readOnly,\n      disabled,\n      ...rest\n    }: PasswordInputProps,\n    ref: RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const [inputType, setInputType] = useState(\"password\");\n    const currentType = inputType === \"password\" ? \"text\" : \"password\";\n    const eyeIcon = inputType === \"password\" ? \"eye-off\" : \"eye\";\n\n    return (\n      <StyledContainer>\n        <StyledPasswordInput\n          {...rest}\n          type={inputType}\n          placeholder={!readOnly && placeholder}\n          ref={ref}\n          hasError={hasError}\n          readOnly={readOnly}\n          disabled={disabled}\n          aria-invalid={hasError}\n        />\n        <StyledIconBtn\n          onClick={(e: React.MouseEvent) => {\n            if (disabled) {\n              e.preventDefault();\n            }\n            if (onIconClick) {\n              onIconClick(e);\n            }\n            setInputType(currentType);\n          }}\n          hasError={hasError}\n          disabled={readOnly || disabled}\n          aria-label={iconAriaLabel}\n          type=\"button\"\n        >\n          <Icon\n            name={eyeIcon}\n            size=\"s\"\n            color={readOnly ? \"quaternary\" : \"tertiary\"}\n          />\n        </StyledIconBtn>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const PasswordInput = React.forwardRef(\n  (\n    {\n      placeholder = \"••••••••\",\n      hasError = false,\n      onIconClick,\n      autoComplete = \"on\",\n      iconAriaLabel,\n      disabled,\n      label,\n      labelHint,\n      hideLabel,\n      hint,\n      errorMessages,\n      \"aria-describedby\": ariaDescribedBy,\n      \"data-e2e-test-id\": dataE2eTestId,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const { id, ariaDescribedByProp } = useFormFieldMessageId({\n      ariaDescribedBy,\n      errorMessages,\n      hint,\n    });\n\n    return (\n      <FormField\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"PasswordInput\"\n        disabled={disabled}\n        label={label}\n        labelHint={labelHint}\n        hideLabel={hideLabel}\n        hint={hint}\n        errorMessages={errorMessages}\n        messageId={id}\n      >\n        <PasswordInputRaw\n          {...rest}\n          ref={ref}\n          placeholder={placeholder}\n          hasError={hasError}\n          disabled={disabled}\n          onIconClick={onIconClick}\n          autoComplete={autoComplete}\n          iconAriaLabel={iconAriaLabel}\n          {...ariaDescribedByProp}\n        />\n      </FormField>\n    );\n  }\n);\n"],"names":[],"mappings":"AA2G4B"} */"),PasswordInputRaw=(0,_react.forwardRef)(({placeholder,hasError=!1,onIconClick,iconAriaLabel,readOnly,disabled,...rest},ref)=>{let[inputType,setInputType]=(0,_react.useState)("password"),currentType="password"===inputType?"text":"password";return _react.default.createElement(StyledContainer,null,_react.default.createElement(StyledPasswordInput,{...rest,type:inputType,placeholder:!readOnly&&placeholder,ref:ref,hasError:hasError,readOnly:readOnly,disabled:disabled,"aria-invalid":hasError}),_react.default.createElement(StyledIconBtn,{onClick:e=>{disabled&&e.preventDefault(),onIconClick&&onIconClick(e),setInputType(currentType)},hasError:hasError,disabled:readOnly||disabled,"aria-label":iconAriaLabel,type:"button"},_react.default.createElement(_Icon.Icon,{name:"password"===inputType?"eye-off":"eye",size:"s",color:readOnly?"quaternary":"tertiary"})))}),PasswordInput=_react.default.forwardRef(({placeholder="••••••••",hasError=!1,onIconClick,autoComplete="on",iconAriaLabel,disabled,label,labelHint,hideLabel,hint,errorMessages,"aria-describedby":ariaDescribedBy,"data-e2e-test-id":dataE2eTestId,...rest},ref)=>{let{id,ariaDescribedByProp}=(0,_useFormFieldMessageId.useFormFieldMessageId)({ariaDescribedBy,errorMessages,hint});return _react.default.createElement(_FormField.FormField,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"PasswordInput",disabled:disabled,label:label,labelHint:labelHint,hideLabel:hideLabel,hint:hint,errorMessages:errorMessages,messageId:id},_react.default.createElement(PasswordInputRaw,{...rest,ref:ref,placeholder:placeholder,hasError:hasError,disabled:disabled,onIconClick:onIconClick,autoComplete:autoComplete,iconAriaLabel:iconAriaLabel,...ariaDescribedByProp}))});
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"RadioButton",{enumerable:!0,get:function(){return RadioButton}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_FormField=require("../FormField/FormField"),_Icon=require("../../Icon/Icon"),_Inline=require("../../Inline/Inline"),StyledContainer=(0,_styled.default)("div",{target:"e1dke7do0",label:"StyledContainer"})(()=>({userSelect:"none",display:"block",position:"relative",width:"100%",boxSizing:"border-box"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9SYWRpb0J1dHRvbi9SYWRpb0J1dHRvbi50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0Zvcm0vUmFkaW9CdXR0b24vUmFkaW9CdXR0b24udHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cblxuaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHR5cGUgeyBDU1NPYmplY3QgfSBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB0eXBlIHsgRm9ybUZpZWxkUHJvcHMgfSBmcm9tIFwiLi4vRm9ybUZpZWxkL0Zvcm1GaWVsZFwiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB0eXBlIHsgSWNvbk5hbWUgfSBmcm9tIFwiLi4vLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uLy4uL0lubGluZS9JbmxpbmVcIjtcblxuZXhwb3J0IHR5cGUgUmFkaW9CdXR0b25Qcm9wcyA9IHtcbiAgbmFtZTogc3RyaW5nO1xuICB2YWx1ZT86IHN0cmluZztcbiAgY2hlY2tlZD86IGJvb2xlYW4gfCB1bmRlZmluZWQ7XG4gIGljb24/OiBJY29uTmFtZTtcbiAgbGFiZWw/OiBzdHJpbmc7XG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbiAgb25DaGFuZ2U/OiAoZTogUmVhY3QuQ2hhbmdlRXZlbnQ8SFRNTElucHV0RWxlbWVudD4pID0+IHZvaWQ7XG4gIG9uQ2xpY2s/OiAoZTogUmVhY3QuRm9ybUV2ZW50PEhUTUxJbnB1dEVsZW1lbnQ+KSA9PiB2b2lkO1xuICBvbkJsdXI/OiAoZTogUmVhY3QuRm9ybUV2ZW50PEhUTUxJbnB1dEVsZW1lbnQ+KSA9PiB2b2lkO1xuICBvbkZvY3VzPzogKGU6IFJlYWN0LkZvcm1FdmVudDxIVE1MSW5wdXRFbGVtZW50PikgPT4gdm9pZDtcbn0gJiBPbWl0PEZvcm1GaWVsZFByb3BzLCBcImxhYmVsSGludFwiPjtcblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdihcbiAgKCkgPT5cbiAgICAoe1xuICAgICAgdXNlclNlbGVjdDogXCJub25lXCIsXG4gICAgICBkaXNwbGF5OiBcImJsb2NrXCIsXG4gICAgICBwb3NpdGlvbjogXCJyZWxhdGl2ZVwiLFxuICAgICAgd2lkdGg6IFwiMTAwJVwiLFxuICAgICAgYm94U2l6aW5nOiBcImJvcmRlci1ib3hcIixcbiAgICB9IGFzIENTU09iamVjdClcbik7XG5cbmNvbnN0IFN0eWxlZFJlYWxJbnB1dCA9IHN0eWxlZC5pbnB1dCgoeyB0aGVtZSB9KSA9PiAoe1xuICBvcGFjaXR5OiB0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5oaWRkZW4sXG4gIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gIGhlaWdodDogMCxcbiAgd2lkdGg6IDAsXG4gIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG59KSk7XG5cbmNvbnN0IFN0eWxlZEZha2VJbnB1dCA9IHN0eWxlZC5kaXY8UGFydGlhbDxSYWRpb0J1dHRvblByb3BzPj4oKHsgdGhlbWUgfSkgPT4gKHtcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgdGV4dFRyYW5zZm9ybTogXCJub25lXCIsXG4gIHRleHREZWNvcmF0aW9uOiBcIm5vbmVcIixcbiAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gIGZvbnRGYW1pbHk6IHRoZW1lLnZhcmlhYmxlcy5mb250RmFtaWx5LmxhdG8sXG4gIGZvbnRTaXplOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5mb250LnMsXG4gIGZvbnRXZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy53ZWlnaHQuYm9sZCxcbiAgbGluZUhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUubGluZUhlaWdodC54cyxcbiAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubH1gLFxuXG4gIFwiaW5wdXQ6IGZvY3VzLXZpc2libGUgKyAmXCI6IHtcbiAgICBvdXRsaW5lV2lkdGg6IFwiMnB4XCIsXG4gICAgb3V0bGluZVN0eWxlOiBcInNvbGlkXCIsXG4gICAgb3V0bGluZUNvbG9yOiBcIkhpZ2hsaWdodFwiLFxuICB9LFxuXG4gIFwiQG1lZGlhICgtd2Via2l0LW1pbi1kZXZpY2UtcGl4ZWwtcmF0aW86MClcIjoge1xuICAgIFwiaW5wdXQ6IGZvY3VzLXZpc2libGUgKyAmXCI6IHtcbiAgICAgIG91dGxpbmVDb2xvcjogXCItd2Via2l0LWZvY3VzLXJpbmctY29sb3JcIixcbiAgICAgIG91dGxpbmVTdHlsZTogXCJhdXRvXCIsXG4gICAgfSxcbiAgfSxcblxuICBcImlucHV0Om5vdCg6Y2hlY2tlZCkgKyAmXCI6IHtcbiAgICBib3JkZXI6IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LnNlY29uZGFyeS5kZWZhdWx0LFxuXG4gICAgXCImOmhvdmVyXCI6IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQuc2Vjb25kYXJ5LmRlZmF1bHQsXG4gICAgfSxcbiAgfSxcbiAgXCJpbnB1dDpjaGVja2VkICsgJiBcIjoge1xuICAgIGJvcmRlcjogYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuYWNjZW50U3VidGxlLmRlZmF1bHR9YCxcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLmFjY2VudFN1YnRsZS5kZWZhdWx0LFxuICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGV4dC5hY2NlbnQuZGVmYXVsdCxcbiAgfSxcbn0pKTtcblxuLyoqIEBkZXByZWNhdGVkIFVzZSBSYWRpbyBvciBTZWdtZW50ZWRDb250cm9sIGNvbXBvbmVudCBpbnN0ZWFkICovXG5leHBvcnQgZnVuY3Rpb24gUmFkaW9CdXR0b24oe1xuICBuYW1lLFxuICB2YWx1ZSA9IFwiXCIsXG4gIGNoZWNrZWQgPSB1bmRlZmluZWQsXG4gIGxhYmVsID0gXCJcIixcbiAgaWNvbixcbiAgZGlzYWJsZWQgPSBmYWxzZSxcbiAgb25DaGFuZ2UsXG4gIG9uQ2xpY2ssXG4gIG9uQmx1cixcbiAgb25Gb2N1cyxcbiAgLi4ucmVzdFxufTogUmFkaW9CdXR0b25Qcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPEZvcm1GaWVsZCBkYXRhLWRzLWlkPVwiUmFkaW9CdXR0b25cIiB7Li4ucmVzdH0gZGlzYWJsZWQ9e2Rpc2FibGVkfT5cbiAgICAgIDxTdHlsZWRDb250YWluZXI+XG4gICAgICAgIDxTdHlsZWRSZWFsSW5wdXRcbiAgICAgICAgICB0eXBlPVwicmFkaW9cIlxuICAgICAgICAgIG5hbWU9e25hbWV9XG4gICAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICAgIGNoZWNrZWQ9e2NoZWNrZWR9XG4gICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgICAgIG9uQmx1cj17b25CbHVyfVxuICAgICAgICAgIG9uRm9jdXM9e29uRm9jdXN9XG4gICAgICAgIC8+XG4gICAgICAgIDxTdHlsZWRGYWtlSW5wdXQ+XG4gICAgICAgICAgPElubGluZSB2QWxpZ25JdGVtcz1cImNlbnRlclwiIGFsaWduSXRlbXM9XCJzcGFjZUJldHdlZW5cIiBub1dyYXA+XG4gICAgICAgICAgICB7bGFiZWx9XG4gICAgICAgICAgICB7aWNvbiAmJiA8SWNvbiBuYW1lPXtpY29ufSAvPn1cbiAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgPC9TdHlsZWRGYWtlSW5wdXQ+XG4gICAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgICA8L0Zvcm1GaWVsZD5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3QndCIn0= */"),StyledRealInput=(0,_styled.default)("input",{target:"e1dke7do1",label:"StyledRealInput"})(({theme})=>({opacity:theme.variables.opacity.hidden,cursor:"pointer",height:0,width:0,position:"absolute"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9SYWRpb0J1dHRvbi9SYWRpb0J1dHRvbi50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0Zvcm0vUmFkaW9CdXR0b24vUmFkaW9CdXR0b24udHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cblxuaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHR5cGUgeyBDU1NPYmplY3QgfSBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB0eXBlIHsgRm9ybUZpZWxkUHJvcHMgfSBmcm9tIFwiLi4vRm9ybUZpZWxkL0Zvcm1GaWVsZFwiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB0eXBlIHsgSWNvbk5hbWUgfSBmcm9tIFwiLi4vLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uLy4uL0lubGluZS9JbmxpbmVcIjtcblxuZXhwb3J0IHR5cGUgUmFkaW9CdXR0b25Qcm9wcyA9IHtcbiAgbmFtZTogc3RyaW5nO1xuICB2YWx1ZT86IHN0cmluZztcbiAgY2hlY2tlZD86IGJvb2xlYW4gfCB1bmRlZmluZWQ7XG4gIGljb24/OiBJY29uTmFtZTtcbiAgbGFiZWw/OiBzdHJpbmc7XG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbiAgb25DaGFuZ2U/OiAoZTogUmVhY3QuQ2hhbmdlRXZlbnQ8SFRNTElucHV0RWxlbWVudD4pID0+IHZvaWQ7XG4gIG9uQ2xpY2s/OiAoZTogUmVhY3QuRm9ybUV2ZW50PEhUTUxJbnB1dEVsZW1lbnQ+KSA9PiB2b2lkO1xuICBvbkJsdXI/OiAoZTogUmVhY3QuRm9ybUV2ZW50PEhUTUxJbnB1dEVsZW1lbnQ+KSA9PiB2b2lkO1xuICBvbkZvY3VzPzogKGU6IFJlYWN0LkZvcm1FdmVudDxIVE1MSW5wdXRFbGVtZW50PikgPT4gdm9pZDtcbn0gJiBPbWl0PEZvcm1GaWVsZFByb3BzLCBcImxhYmVsSGludFwiPjtcblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdihcbiAgKCkgPT5cbiAgICAoe1xuICAgICAgdXNlclNlbGVjdDogXCJub25lXCIsXG4gICAgICBkaXNwbGF5OiBcImJsb2NrXCIsXG4gICAgICBwb3NpdGlvbjogXCJyZWxhdGl2ZVwiLFxuICAgICAgd2lkdGg6IFwiMTAwJVwiLFxuICAgICAgYm94U2l6aW5nOiBcImJvcmRlci1ib3hcIixcbiAgICB9IGFzIENTU09iamVjdClcbik7XG5cbmNvbnN0IFN0eWxlZFJlYWxJbnB1dCA9IHN0eWxlZC5pbnB1dCgoeyB0aGVtZSB9KSA9PiAoe1xuICBvcGFjaXR5OiB0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5oaWRkZW4sXG4gIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gIGhlaWdodDogMCxcbiAgd2lkdGg6IDAsXG4gIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG59KSk7XG5cbmNvbnN0IFN0eWxlZEZha2VJbnB1dCA9IHN0eWxlZC5kaXY8UGFydGlhbDxSYWRpb0J1dHRvblByb3BzPj4oKHsgdGhlbWUgfSkgPT4gKHtcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgdGV4dFRyYW5zZm9ybTogXCJub25lXCIsXG4gIHRleHREZWNvcmF0aW9uOiBcIm5vbmVcIixcbiAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gIGZvbnRGYW1pbHk6IHRoZW1lLnZhcmlhYmxlcy5mb250RmFtaWx5LmxhdG8sXG4gIGZvbnRTaXplOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5mb250LnMsXG4gIGZvbnRXZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy53ZWlnaHQuYm9sZCxcbiAgbGluZUhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUubGluZUhlaWdodC54cyxcbiAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubH1gLFxuXG4gIFwiaW5wdXQ6IGZvY3VzLXZpc2libGUgKyAmXCI6IHtcbiAgICBvdXRsaW5lV2lkdGg6IFwiMnB4XCIsXG4gICAgb3V0bGluZVN0eWxlOiBcInNvbGlkXCIsXG4gICAgb3V0bGluZUNvbG9yOiBcIkhpZ2hsaWdodFwiLFxuICB9LFxuXG4gIFwiQG1lZGlhICgtd2Via2l0LW1pbi1kZXZpY2UtcGl4ZWwtcmF0aW86MClcIjoge1xuICAgIFwiaW5wdXQ6IGZvY3VzLXZpc2libGUgKyAmXCI6IHtcbiAgICAgIG91dGxpbmVDb2xvcjogXCItd2Via2l0LWZvY3VzLXJpbmctY29sb3JcIixcbiAgICAgIG91dGxpbmVTdHlsZTogXCJhdXRvXCIsXG4gICAgfSxcbiAgfSxcblxuICBcImlucHV0Om5vdCg6Y2hlY2tlZCkgKyAmXCI6IHtcbiAgICBib3JkZXI6IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LnNlY29uZGFyeS5kZWZhdWx0LFxuXG4gICAgXCImOmhvdmVyXCI6IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQuc2Vjb25kYXJ5LmRlZmF1bHQsXG4gICAgfSxcbiAgfSxcbiAgXCJpbnB1dDpjaGVja2VkICsgJiBcIjoge1xuICAgIGJvcmRlcjogYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuYWNjZW50U3VidGxlLmRlZmF1bHR9YCxcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLmFjY2VudFN1YnRsZS5kZWZhdWx0LFxuICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGV4dC5hY2NlbnQuZGVmYXVsdCxcbiAgfSxcbn0pKTtcblxuLyoqIEBkZXByZWNhdGVkIFVzZSBSYWRpbyBvciBTZWdtZW50ZWRDb250cm9sIGNvbXBvbmVudCBpbnN0ZWFkICovXG5leHBvcnQgZnVuY3Rpb24gUmFkaW9CdXR0b24oe1xuICBuYW1lLFxuICB2YWx1ZSA9IFwiXCIsXG4gIGNoZWNrZWQgPSB1bmRlZmluZWQsXG4gIGxhYmVsID0gXCJcIixcbiAgaWNvbixcbiAgZGlzYWJsZWQgPSBmYWxzZSxcbiAgb25DaGFuZ2UsXG4gIG9uQ2xpY2ssXG4gIG9uQmx1cixcbiAgb25Gb2N1cyxcbiAgLi4ucmVzdFxufTogUmFkaW9CdXR0b25Qcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPEZvcm1GaWVsZCBkYXRhLWRzLWlkPVwiUmFkaW9CdXR0b25cIiB7Li4ucmVzdH0gZGlzYWJsZWQ9e2Rpc2FibGVkfT5cbiAgICAgIDxTdHlsZWRDb250YWluZXI+XG4gICAgICAgIDxTdHlsZWRSZWFsSW5wdXRcbiAgICAgICAgICB0eXBlPVwicmFkaW9cIlxuICAgICAgICAgIG5hbWU9e25hbWV9XG4gICAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICAgIGNoZWNrZWQ9e2NoZWNrZWR9XG4gICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgICAgIG9uQmx1cj17b25CbHVyfVxuICAgICAgICAgIG9uRm9jdXM9e29uRm9jdXN9XG4gICAgICAgIC8+XG4gICAgICAgIDxTdHlsZWRGYWtlSW5wdXQ+XG4gICAgICAgICAgPElubGluZSB2QWxpZ25JdGVtcz1cImNlbnRlclwiIGFsaWduSXRlbXM9XCJzcGFjZUJldHdlZW5cIiBub1dyYXA+XG4gICAgICAgICAgICB7bGFiZWx9XG4gICAgICAgICAgICB7aWNvbiAmJiA8SWNvbiBuYW1lPXtpY29ufSAvPn1cbiAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgPC9TdHlsZWRGYWtlSW5wdXQ+XG4gICAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgICA8L0Zvcm1GaWVsZD5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQ3dCIn0= */"),StyledFakeInput=(0,_styled.default)("div",{target:"e1dke7do2",label:"StyledFakeInput"})(({theme})=>({cursor:"pointer",textTransform:"none",textDecoration:"none",borderRadius:theme.variables.size.borderRadius.xs,fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.s,fontWeight:theme.variables.weight.bold,lineHeight:theme.variables.size.lineHeight.xs,padding:`${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,"input: focus-visible + &":{outlineWidth:"2px",outlineStyle:"solid",outlineColor:"Highlight"},"@media (-webkit-min-device-pixel-ratio:0)":{"input: focus-visible + &":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"auto"}},"input:not(:checked) + &":{border:`1px solid ${theme.values.color.border.secondary.default}`,backgroundColor:theme.values.color.background.primary.default,color:theme.values.color.text.secondary.default,"&:hover":{backgroundColor:theme.values.color.background.secondary.default}},"input:checked + & ":{border:`1px solid ${theme.values.color.border.accentSubtle.default}`,backgroundColor:theme.values.color.background.accentSubtle.default,color:theme.values.color.text.accent.default}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9SYWRpb0J1dHRvbi9SYWRpb0J1dHRvbi50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0Zvcm0vUmFkaW9CdXR0b24vUmFkaW9CdXR0b24udHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cblxuaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHR5cGUgeyBDU1NPYmplY3QgfSBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB0eXBlIHsgRm9ybUZpZWxkUHJvcHMgfSBmcm9tIFwiLi4vRm9ybUZpZWxkL0Zvcm1GaWVsZFwiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB0eXBlIHsgSWNvbk5hbWUgfSBmcm9tIFwiLi4vLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uLy4uL0lubGluZS9JbmxpbmVcIjtcblxuZXhwb3J0IHR5cGUgUmFkaW9CdXR0b25Qcm9wcyA9IHtcbiAgbmFtZTogc3RyaW5nO1xuICB2YWx1ZT86IHN0cmluZztcbiAgY2hlY2tlZD86IGJvb2xlYW4gfCB1bmRlZmluZWQ7XG4gIGljb24/OiBJY29uTmFtZTtcbiAgbGFiZWw/OiBzdHJpbmc7XG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbiAgb25DaGFuZ2U/OiAoZTogUmVhY3QuQ2hhbmdlRXZlbnQ8SFRNTElucHV0RWxlbWVudD4pID0+IHZvaWQ7XG4gIG9uQ2xpY2s/OiAoZTogUmVhY3QuRm9ybUV2ZW50PEhUTUxJbnB1dEVsZW1lbnQ+KSA9PiB2b2lkO1xuICBvbkJsdXI/OiAoZTogUmVhY3QuRm9ybUV2ZW50PEhUTUxJbnB1dEVsZW1lbnQ+KSA9PiB2b2lkO1xuICBvbkZvY3VzPzogKGU6IFJlYWN0LkZvcm1FdmVudDxIVE1MSW5wdXRFbGVtZW50PikgPT4gdm9pZDtcbn0gJiBPbWl0PEZvcm1GaWVsZFByb3BzLCBcImxhYmVsSGludFwiPjtcblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdihcbiAgKCkgPT5cbiAgICAoe1xuICAgICAgdXNlclNlbGVjdDogXCJub25lXCIsXG4gICAgICBkaXNwbGF5OiBcImJsb2NrXCIsXG4gICAgICBwb3NpdGlvbjogXCJyZWxhdGl2ZVwiLFxuICAgICAgd2lkdGg6IFwiMTAwJVwiLFxuICAgICAgYm94U2l6aW5nOiBcImJvcmRlci1ib3hcIixcbiAgICB9IGFzIENTU09iamVjdClcbik7XG5cbmNvbnN0IFN0eWxlZFJlYWxJbnB1dCA9IHN0eWxlZC5pbnB1dCgoeyB0aGVtZSB9KSA9PiAoe1xuICBvcGFjaXR5OiB0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5oaWRkZW4sXG4gIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gIGhlaWdodDogMCxcbiAgd2lkdGg6IDAsXG4gIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG59KSk7XG5cbmNvbnN0IFN0eWxlZEZha2VJbnB1dCA9IHN0eWxlZC5kaXY8UGFydGlhbDxSYWRpb0J1dHRvblByb3BzPj4oKHsgdGhlbWUgfSkgPT4gKHtcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgdGV4dFRyYW5zZm9ybTogXCJub25lXCIsXG4gIHRleHREZWNvcmF0aW9uOiBcIm5vbmVcIixcbiAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gIGZvbnRGYW1pbHk6IHRoZW1lLnZhcmlhYmxlcy5mb250RmFtaWx5LmxhdG8sXG4gIGZvbnRTaXplOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5mb250LnMsXG4gIGZvbnRXZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy53ZWlnaHQuYm9sZCxcbiAgbGluZUhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUubGluZUhlaWdodC54cyxcbiAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubH1gLFxuXG4gIFwiaW5wdXQ6IGZvY3VzLXZpc2libGUgKyAmXCI6IHtcbiAgICBvdXRsaW5lV2lkdGg6IFwiMnB4XCIsXG4gICAgb3V0bGluZVN0eWxlOiBcInNvbGlkXCIsXG4gICAgb3V0bGluZUNvbG9yOiBcIkhpZ2hsaWdodFwiLFxuICB9LFxuXG4gIFwiQG1lZGlhICgtd2Via2l0LW1pbi1kZXZpY2UtcGl4ZWwtcmF0aW86MClcIjoge1xuICAgIFwiaW5wdXQ6IGZvY3VzLXZpc2libGUgKyAmXCI6IHtcbiAgICAgIG91dGxpbmVDb2xvcjogXCItd2Via2l0LWZvY3VzLXJpbmctY29sb3JcIixcbiAgICAgIG91dGxpbmVTdHlsZTogXCJhdXRvXCIsXG4gICAgfSxcbiAgfSxcblxuICBcImlucHV0Om5vdCg6Y2hlY2tlZCkgKyAmXCI6IHtcbiAgICBib3JkZXI6IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LnNlY29uZGFyeS5kZWZhdWx0LFxuXG4gICAgXCImOmhvdmVyXCI6IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQuc2Vjb25kYXJ5LmRlZmF1bHQsXG4gICAgfSxcbiAgfSxcbiAgXCJpbnB1dDpjaGVja2VkICsgJiBcIjoge1xuICAgIGJvcmRlcjogYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuYWNjZW50U3VidGxlLmRlZmF1bHR9YCxcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLmFjY2VudFN1YnRsZS5kZWZhdWx0LFxuICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGV4dC5hY2NlbnQuZGVmYXVsdCxcbiAgfSxcbn0pKTtcblxuLyoqIEBkZXByZWNhdGVkIFVzZSBSYWRpbyBvciBTZWdtZW50ZWRDb250cm9sIGNvbXBvbmVudCBpbnN0ZWFkICovXG5leHBvcnQgZnVuY3Rpb24gUmFkaW9CdXR0b24oe1xuICBuYW1lLFxuICB2YWx1ZSA9IFwiXCIsXG4gIGNoZWNrZWQgPSB1bmRlZmluZWQsXG4gIGxhYmVsID0gXCJcIixcbiAgaWNvbixcbiAgZGlzYWJsZWQgPSBmYWxzZSxcbiAgb25DaGFuZ2UsXG4gIG9uQ2xpY2ssXG4gIG9uQmx1cixcbiAgb25Gb2N1cyxcbiAgLi4ucmVzdFxufTogUmFkaW9CdXR0b25Qcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPEZvcm1GaWVsZCBkYXRhLWRzLWlkPVwiUmFkaW9CdXR0b25cIiB7Li4ucmVzdH0gZGlzYWJsZWQ9e2Rpc2FibGVkfT5cbiAgICAgIDxTdHlsZWRDb250YWluZXI+XG4gICAgICAgIDxTdHlsZWRSZWFsSW5wdXRcbiAgICAgICAgICB0eXBlPVwicmFkaW9cIlxuICAgICAgICAgIG5hbWU9e25hbWV9XG4gICAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICAgIGNoZWNrZWQ9e2NoZWNrZWR9XG4gICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgICAgIG9uQmx1cj17b25CbHVyfVxuICAgICAgICAgIG9uRm9jdXM9e29uRm9jdXN9XG4gICAgICAgIC8+XG4gICAgICAgIDxTdHlsZWRGYWtlSW5wdXQ+XG4gICAgICAgICAgPElubGluZSB2QWxpZ25JdGVtcz1cImNlbnRlclwiIGFsaWduSXRlbXM9XCJzcGFjZUJldHdlZW5cIiBub1dyYXA+XG4gICAgICAgICAgICB7bGFiZWx9XG4gICAgICAgICAgICB7aWNvbiAmJiA8SWNvbiBuYW1lPXtpY29ufSAvPn1cbiAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgPC9TdHlsZWRGYWtlSW5wdXQ+XG4gICAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgICA8L0Zvcm1GaWVsZD5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyQ3dCIn0= */");function RadioButton({name,value="",checked,label="",icon,disabled=!1,onChange,onClick,onBlur,onFocus,...rest}){return _react.default.createElement(_FormField.FormField,{"data-ds-id":"RadioButton",...rest,disabled:disabled},_react.default.createElement(StyledContainer,null,_react.default.createElement(StyledRealInput,{type:"radio",name:name,value:value,checked:checked,disabled:disabled,onChange:onChange,onClick:onClick,onBlur:onBlur,onFocus:onFocus}),_react.default.createElement(StyledFakeInput,null,_react.default.createElement(_Inline.Inline,{vAlignItems:"center",alignItems:"spaceBetween",noWrap:!0},label,icon&&_react.default.createElement(_Icon.Icon,{name:icon})))))}
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"RadioButton",{enumerable:!0,get:function(){return RadioButton}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_FormField=require("../FormField/FormField"),_Icon=require("../../Icon/Icon"),_Inline=require("../../Inline/Inline"),StyledContainer=(0,_styled.default)("div",{target:"eafnzqf0",label:"StyledContainer"})(()=>({userSelect:"none",display:"block",position:"relative",width:"100%",boxSizing:"border-box"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9SYWRpb0J1dHRvbi9SYWRpb0J1dHRvbi50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0Zvcm0vUmFkaW9CdXR0b24vUmFkaW9CdXR0b24udHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cblxuaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHR5cGUgeyBDU1NPYmplY3QgfSBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB0eXBlIHsgRm9ybUZpZWxkUHJvcHMgfSBmcm9tIFwiLi4vRm9ybUZpZWxkL0Zvcm1GaWVsZFwiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB0eXBlIHsgSWNvbk5hbWUgfSBmcm9tIFwiLi4vLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uLy4uL0lubGluZS9JbmxpbmVcIjtcblxuZXhwb3J0IHR5cGUgUmFkaW9CdXR0b25Qcm9wcyA9IHtcbiAgbmFtZTogc3RyaW5nO1xuICB2YWx1ZT86IHN0cmluZztcbiAgY2hlY2tlZD86IGJvb2xlYW4gfCB1bmRlZmluZWQ7XG4gIGljb24/OiBJY29uTmFtZTtcbiAgbGFiZWw/OiBzdHJpbmc7XG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbiAgb25DaGFuZ2U/OiAoZTogUmVhY3QuQ2hhbmdlRXZlbnQ8SFRNTElucHV0RWxlbWVudD4pID0+IHZvaWQ7XG4gIG9uQ2xpY2s/OiAoZTogUmVhY3QuRm9ybUV2ZW50PEhUTUxJbnB1dEVsZW1lbnQ+KSA9PiB2b2lkO1xuICBvbkJsdXI/OiAoZTogUmVhY3QuRm9ybUV2ZW50PEhUTUxJbnB1dEVsZW1lbnQ+KSA9PiB2b2lkO1xuICBvbkZvY3VzPzogKGU6IFJlYWN0LkZvcm1FdmVudDxIVE1MSW5wdXRFbGVtZW50PikgPT4gdm9pZDtcbn0gJiBPbWl0PEZvcm1GaWVsZFByb3BzLCBcImxhYmVsSGludFwiPjtcblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdihcbiAgKCkgPT5cbiAgICAoe1xuICAgICAgdXNlclNlbGVjdDogXCJub25lXCIsXG4gICAgICBkaXNwbGF5OiBcImJsb2NrXCIsXG4gICAgICBwb3NpdGlvbjogXCJyZWxhdGl2ZVwiLFxuICAgICAgd2lkdGg6IFwiMTAwJVwiLFxuICAgICAgYm94U2l6aW5nOiBcImJvcmRlci1ib3hcIixcbiAgICB9IGFzIENTU09iamVjdClcbik7XG5cbmNvbnN0IFN0eWxlZFJlYWxJbnB1dCA9IHN0eWxlZC5pbnB1dCgoeyB0aGVtZSB9KSA9PiAoe1xuICBvcGFjaXR5OiB0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5oaWRkZW4sXG4gIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gIGhlaWdodDogMCxcbiAgd2lkdGg6IDAsXG4gIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG59KSk7XG5cbmNvbnN0IFN0eWxlZEZha2VJbnB1dCA9IHN0eWxlZC5kaXY8UGFydGlhbDxSYWRpb0J1dHRvblByb3BzPj4oKHsgdGhlbWUgfSkgPT4gKHtcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgdGV4dFRyYW5zZm9ybTogXCJub25lXCIsXG4gIHRleHREZWNvcmF0aW9uOiBcIm5vbmVcIixcbiAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gIGZvbnRGYW1pbHk6IHRoZW1lLnZhcmlhYmxlcy5mb250RmFtaWx5LmxhdG8sXG4gIGZvbnRTaXplOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5mb250LnMsXG4gIGZvbnRXZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy53ZWlnaHQuYm9sZCxcbiAgbGluZUhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUubGluZUhlaWdodC54cyxcbiAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubH1gLFxuXG4gIFwiaW5wdXQ6IGZvY3VzLXZpc2libGUgKyAmXCI6IHtcbiAgICBvdXRsaW5lV2lkdGg6IFwiMnB4XCIsXG4gICAgb3V0bGluZVN0eWxlOiBcInNvbGlkXCIsXG4gICAgb3V0bGluZUNvbG9yOiBcIkhpZ2hsaWdodFwiLFxuICB9LFxuXG4gIFwiQG1lZGlhICgtd2Via2l0LW1pbi1kZXZpY2UtcGl4ZWwtcmF0aW86MClcIjoge1xuICAgIFwiaW5wdXQ6IGZvY3VzLXZpc2libGUgKyAmXCI6IHtcbiAgICAgIG91dGxpbmVDb2xvcjogXCItd2Via2l0LWZvY3VzLXJpbmctY29sb3JcIixcbiAgICAgIG91dGxpbmVTdHlsZTogXCJhdXRvXCIsXG4gICAgfSxcbiAgfSxcblxuICBcImlucHV0Om5vdCg6Y2hlY2tlZCkgKyAmXCI6IHtcbiAgICBib3JkZXI6IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LnNlY29uZGFyeS5kZWZhdWx0LFxuXG4gICAgXCImOmhvdmVyXCI6IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQuc2Vjb25kYXJ5LmRlZmF1bHQsXG4gICAgfSxcbiAgfSxcbiAgXCJpbnB1dDpjaGVja2VkICsgJiBcIjoge1xuICAgIGJvcmRlcjogYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuYWNjZW50LmRlZmF1bHR9YCxcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLmFjY2VudFN1YnRsZS5kZWZhdWx0LFxuICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGV4dC5hY2NlbnQuZGVmYXVsdCxcbiAgfSxcbn0pKTtcblxuLyoqIEBkZXByZWNhdGVkIFVzZSBSYWRpbyBvciBTZWdtZW50ZWRDb250cm9sIGNvbXBvbmVudCBpbnN0ZWFkICovXG5leHBvcnQgZnVuY3Rpb24gUmFkaW9CdXR0b24oe1xuICBuYW1lLFxuICB2YWx1ZSA9IFwiXCIsXG4gIGNoZWNrZWQgPSB1bmRlZmluZWQsXG4gIGxhYmVsID0gXCJcIixcbiAgaWNvbixcbiAgZGlzYWJsZWQgPSBmYWxzZSxcbiAgb25DaGFuZ2UsXG4gIG9uQ2xpY2ssXG4gIG9uQmx1cixcbiAgb25Gb2N1cyxcbiAgLi4ucmVzdFxufTogUmFkaW9CdXR0b25Qcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPEZvcm1GaWVsZCBkYXRhLWRzLWlkPVwiUmFkaW9CdXR0b25cIiB7Li4ucmVzdH0gZGlzYWJsZWQ9e2Rpc2FibGVkfT5cbiAgICAgIDxTdHlsZWRDb250YWluZXI+XG4gICAgICAgIDxTdHlsZWRSZWFsSW5wdXRcbiAgICAgICAgICB0eXBlPVwicmFkaW9cIlxuICAgICAgICAgIG5hbWU9e25hbWV9XG4gICAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICAgIGNoZWNrZWQ9e2NoZWNrZWR9XG4gICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgICAgIG9uQmx1cj17b25CbHVyfVxuICAgICAgICAgIG9uRm9jdXM9e29uRm9jdXN9XG4gICAgICAgIC8+XG4gICAgICAgIDxTdHlsZWRGYWtlSW5wdXQ+XG4gICAgICAgICAgPElubGluZSB2QWxpZ25JdGVtcz1cImNlbnRlclwiIGFsaWduSXRlbXM9XCJzcGFjZUJldHdlZW5cIiBub1dyYXA+XG4gICAgICAgICAgICB7bGFiZWx9XG4gICAgICAgICAgICB7aWNvbiAmJiA8SWNvbiBuYW1lPXtpY29ufSAvPn1cbiAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgPC9TdHlsZWRGYWtlSW5wdXQ+XG4gICAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgICA8L0Zvcm1GaWVsZD5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3QndCIn0= */"),StyledRealInput=(0,_styled.default)("input",{target:"eafnzqf1",label:"StyledRealInput"})(({theme})=>({opacity:theme.variables.opacity.hidden,cursor:"pointer",height:0,width:0,position:"absolute"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9SYWRpb0J1dHRvbi9SYWRpb0J1dHRvbi50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0Zvcm0vUmFkaW9CdXR0b24vUmFkaW9CdXR0b24udHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cblxuaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHR5cGUgeyBDU1NPYmplY3QgfSBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB0eXBlIHsgRm9ybUZpZWxkUHJvcHMgfSBmcm9tIFwiLi4vRm9ybUZpZWxkL0Zvcm1GaWVsZFwiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB0eXBlIHsgSWNvbk5hbWUgfSBmcm9tIFwiLi4vLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uLy4uL0lubGluZS9JbmxpbmVcIjtcblxuZXhwb3J0IHR5cGUgUmFkaW9CdXR0b25Qcm9wcyA9IHtcbiAgbmFtZTogc3RyaW5nO1xuICB2YWx1ZT86IHN0cmluZztcbiAgY2hlY2tlZD86IGJvb2xlYW4gfCB1bmRlZmluZWQ7XG4gIGljb24/OiBJY29uTmFtZTtcbiAgbGFiZWw/OiBzdHJpbmc7XG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbiAgb25DaGFuZ2U/OiAoZTogUmVhY3QuQ2hhbmdlRXZlbnQ8SFRNTElucHV0RWxlbWVudD4pID0+IHZvaWQ7XG4gIG9uQ2xpY2s/OiAoZTogUmVhY3QuRm9ybUV2ZW50PEhUTUxJbnB1dEVsZW1lbnQ+KSA9PiB2b2lkO1xuICBvbkJsdXI/OiAoZTogUmVhY3QuRm9ybUV2ZW50PEhUTUxJbnB1dEVsZW1lbnQ+KSA9PiB2b2lkO1xuICBvbkZvY3VzPzogKGU6IFJlYWN0LkZvcm1FdmVudDxIVE1MSW5wdXRFbGVtZW50PikgPT4gdm9pZDtcbn0gJiBPbWl0PEZvcm1GaWVsZFByb3BzLCBcImxhYmVsSGludFwiPjtcblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdihcbiAgKCkgPT5cbiAgICAoe1xuICAgICAgdXNlclNlbGVjdDogXCJub25lXCIsXG4gICAgICBkaXNwbGF5OiBcImJsb2NrXCIsXG4gICAgICBwb3NpdGlvbjogXCJyZWxhdGl2ZVwiLFxuICAgICAgd2lkdGg6IFwiMTAwJVwiLFxuICAgICAgYm94U2l6aW5nOiBcImJvcmRlci1ib3hcIixcbiAgICB9IGFzIENTU09iamVjdClcbik7XG5cbmNvbnN0IFN0eWxlZFJlYWxJbnB1dCA9IHN0eWxlZC5pbnB1dCgoeyB0aGVtZSB9KSA9PiAoe1xuICBvcGFjaXR5OiB0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5oaWRkZW4sXG4gIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gIGhlaWdodDogMCxcbiAgd2lkdGg6IDAsXG4gIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG59KSk7XG5cbmNvbnN0IFN0eWxlZEZha2VJbnB1dCA9IHN0eWxlZC5kaXY8UGFydGlhbDxSYWRpb0J1dHRvblByb3BzPj4oKHsgdGhlbWUgfSkgPT4gKHtcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgdGV4dFRyYW5zZm9ybTogXCJub25lXCIsXG4gIHRleHREZWNvcmF0aW9uOiBcIm5vbmVcIixcbiAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gIGZvbnRGYW1pbHk6IHRoZW1lLnZhcmlhYmxlcy5mb250RmFtaWx5LmxhdG8sXG4gIGZvbnRTaXplOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5mb250LnMsXG4gIGZvbnRXZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy53ZWlnaHQuYm9sZCxcbiAgbGluZUhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUubGluZUhlaWdodC54cyxcbiAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubH1gLFxuXG4gIFwiaW5wdXQ6IGZvY3VzLXZpc2libGUgKyAmXCI6IHtcbiAgICBvdXRsaW5lV2lkdGg6IFwiMnB4XCIsXG4gICAgb3V0bGluZVN0eWxlOiBcInNvbGlkXCIsXG4gICAgb3V0bGluZUNvbG9yOiBcIkhpZ2hsaWdodFwiLFxuICB9LFxuXG4gIFwiQG1lZGlhICgtd2Via2l0LW1pbi1kZXZpY2UtcGl4ZWwtcmF0aW86MClcIjoge1xuICAgIFwiaW5wdXQ6IGZvY3VzLXZpc2libGUgKyAmXCI6IHtcbiAgICAgIG91dGxpbmVDb2xvcjogXCItd2Via2l0LWZvY3VzLXJpbmctY29sb3JcIixcbiAgICAgIG91dGxpbmVTdHlsZTogXCJhdXRvXCIsXG4gICAgfSxcbiAgfSxcblxuICBcImlucHV0Om5vdCg6Y2hlY2tlZCkgKyAmXCI6IHtcbiAgICBib3JkZXI6IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LnNlY29uZGFyeS5kZWZhdWx0LFxuXG4gICAgXCImOmhvdmVyXCI6IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQuc2Vjb25kYXJ5LmRlZmF1bHQsXG4gICAgfSxcbiAgfSxcbiAgXCJpbnB1dDpjaGVja2VkICsgJiBcIjoge1xuICAgIGJvcmRlcjogYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuYWNjZW50LmRlZmF1bHR9YCxcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLmFjY2VudFN1YnRsZS5kZWZhdWx0LFxuICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGV4dC5hY2NlbnQuZGVmYXVsdCxcbiAgfSxcbn0pKTtcblxuLyoqIEBkZXByZWNhdGVkIFVzZSBSYWRpbyBvciBTZWdtZW50ZWRDb250cm9sIGNvbXBvbmVudCBpbnN0ZWFkICovXG5leHBvcnQgZnVuY3Rpb24gUmFkaW9CdXR0b24oe1xuICBuYW1lLFxuICB2YWx1ZSA9IFwiXCIsXG4gIGNoZWNrZWQgPSB1bmRlZmluZWQsXG4gIGxhYmVsID0gXCJcIixcbiAgaWNvbixcbiAgZGlzYWJsZWQgPSBmYWxzZSxcbiAgb25DaGFuZ2UsXG4gIG9uQ2xpY2ssXG4gIG9uQmx1cixcbiAgb25Gb2N1cyxcbiAgLi4ucmVzdFxufTogUmFkaW9CdXR0b25Qcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPEZvcm1GaWVsZCBkYXRhLWRzLWlkPVwiUmFkaW9CdXR0b25cIiB7Li4ucmVzdH0gZGlzYWJsZWQ9e2Rpc2FibGVkfT5cbiAgICAgIDxTdHlsZWRDb250YWluZXI+XG4gICAgICAgIDxTdHlsZWRSZWFsSW5wdXRcbiAgICAgICAgICB0eXBlPVwicmFkaW9cIlxuICAgICAgICAgIG5hbWU9e25hbWV9XG4gICAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICAgIGNoZWNrZWQ9e2NoZWNrZWR9XG4gICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgICAgIG9uQmx1cj17b25CbHVyfVxuICAgICAgICAgIG9uRm9jdXM9e29uRm9jdXN9XG4gICAgICAgIC8+XG4gICAgICAgIDxTdHlsZWRGYWtlSW5wdXQ+XG4gICAgICAgICAgPElubGluZSB2QWxpZ25JdGVtcz1cImNlbnRlclwiIGFsaWduSXRlbXM9XCJzcGFjZUJldHdlZW5cIiBub1dyYXA+XG4gICAgICAgICAgICB7bGFiZWx9XG4gICAgICAgICAgICB7aWNvbiAmJiA8SWNvbiBuYW1lPXtpY29ufSAvPn1cbiAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgPC9TdHlsZWRGYWtlSW5wdXQ+XG4gICAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgICA8L0Zvcm1GaWVsZD5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQ3dCIn0= */"),StyledFakeInput=(0,_styled.default)("div",{target:"eafnzqf2",label:"StyledFakeInput"})(({theme})=>({cursor:"pointer",textTransform:"none",textDecoration:"none",borderRadius:theme.variables.size.borderRadius.xs,fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.s,fontWeight:theme.variables.weight.bold,lineHeight:theme.variables.size.lineHeight.xs,padding:`${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,"input: focus-visible + &":{outlineWidth:"2px",outlineStyle:"solid",outlineColor:"Highlight"},"@media (-webkit-min-device-pixel-ratio:0)":{"input: focus-visible + &":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"auto"}},"input:not(:checked) + &":{border:`1px solid ${theme.values.color.border.secondary.default}`,backgroundColor:theme.values.color.background.primary.default,color:theme.values.color.text.secondary.default,"&:hover":{backgroundColor:theme.values.color.background.secondary.default}},"input:checked + & ":{border:`1px solid ${theme.values.color.border.accent.default}`,backgroundColor:theme.values.color.background.accentSubtle.default,color:theme.values.color.text.accent.default}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9SYWRpb0J1dHRvbi9SYWRpb0J1dHRvbi50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0Zvcm0vUmFkaW9CdXR0b24vUmFkaW9CdXR0b24udHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cblxuaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHR5cGUgeyBDU1NPYmplY3QgfSBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB0eXBlIHsgRm9ybUZpZWxkUHJvcHMgfSBmcm9tIFwiLi4vRm9ybUZpZWxkL0Zvcm1GaWVsZFwiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB0eXBlIHsgSWNvbk5hbWUgfSBmcm9tIFwiLi4vLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uLy4uL0lubGluZS9JbmxpbmVcIjtcblxuZXhwb3J0IHR5cGUgUmFkaW9CdXR0b25Qcm9wcyA9IHtcbiAgbmFtZTogc3RyaW5nO1xuICB2YWx1ZT86IHN0cmluZztcbiAgY2hlY2tlZD86IGJvb2xlYW4gfCB1bmRlZmluZWQ7XG4gIGljb24/OiBJY29uTmFtZTtcbiAgbGFiZWw/OiBzdHJpbmc7XG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbiAgb25DaGFuZ2U/OiAoZTogUmVhY3QuQ2hhbmdlRXZlbnQ8SFRNTElucHV0RWxlbWVudD4pID0+IHZvaWQ7XG4gIG9uQ2xpY2s/OiAoZTogUmVhY3QuRm9ybUV2ZW50PEhUTUxJbnB1dEVsZW1lbnQ+KSA9PiB2b2lkO1xuICBvbkJsdXI/OiAoZTogUmVhY3QuRm9ybUV2ZW50PEhUTUxJbnB1dEVsZW1lbnQ+KSA9PiB2b2lkO1xuICBvbkZvY3VzPzogKGU6IFJlYWN0LkZvcm1FdmVudDxIVE1MSW5wdXRFbGVtZW50PikgPT4gdm9pZDtcbn0gJiBPbWl0PEZvcm1GaWVsZFByb3BzLCBcImxhYmVsSGludFwiPjtcblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdihcbiAgKCkgPT5cbiAgICAoe1xuICAgICAgdXNlclNlbGVjdDogXCJub25lXCIsXG4gICAgICBkaXNwbGF5OiBcImJsb2NrXCIsXG4gICAgICBwb3NpdGlvbjogXCJyZWxhdGl2ZVwiLFxuICAgICAgd2lkdGg6IFwiMTAwJVwiLFxuICAgICAgYm94U2l6aW5nOiBcImJvcmRlci1ib3hcIixcbiAgICB9IGFzIENTU09iamVjdClcbik7XG5cbmNvbnN0IFN0eWxlZFJlYWxJbnB1dCA9IHN0eWxlZC5pbnB1dCgoeyB0aGVtZSB9KSA9PiAoe1xuICBvcGFjaXR5OiB0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5oaWRkZW4sXG4gIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gIGhlaWdodDogMCxcbiAgd2lkdGg6IDAsXG4gIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG59KSk7XG5cbmNvbnN0IFN0eWxlZEZha2VJbnB1dCA9IHN0eWxlZC5kaXY8UGFydGlhbDxSYWRpb0J1dHRvblByb3BzPj4oKHsgdGhlbWUgfSkgPT4gKHtcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgdGV4dFRyYW5zZm9ybTogXCJub25lXCIsXG4gIHRleHREZWNvcmF0aW9uOiBcIm5vbmVcIixcbiAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gIGZvbnRGYW1pbHk6IHRoZW1lLnZhcmlhYmxlcy5mb250RmFtaWx5LmxhdG8sXG4gIGZvbnRTaXplOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5mb250LnMsXG4gIGZvbnRXZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy53ZWlnaHQuYm9sZCxcbiAgbGluZUhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUubGluZUhlaWdodC54cyxcbiAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubH1gLFxuXG4gIFwiaW5wdXQ6IGZvY3VzLXZpc2libGUgKyAmXCI6IHtcbiAgICBvdXRsaW5lV2lkdGg6IFwiMnB4XCIsXG4gICAgb3V0bGluZVN0eWxlOiBcInNvbGlkXCIsXG4gICAgb3V0bGluZUNvbG9yOiBcIkhpZ2hsaWdodFwiLFxuICB9LFxuXG4gIFwiQG1lZGlhICgtd2Via2l0LW1pbi1kZXZpY2UtcGl4ZWwtcmF0aW86MClcIjoge1xuICAgIFwiaW5wdXQ6IGZvY3VzLXZpc2libGUgKyAmXCI6IHtcbiAgICAgIG91dGxpbmVDb2xvcjogXCItd2Via2l0LWZvY3VzLXJpbmctY29sb3JcIixcbiAgICAgIG91dGxpbmVTdHlsZTogXCJhdXRvXCIsXG4gICAgfSxcbiAgfSxcblxuICBcImlucHV0Om5vdCg6Y2hlY2tlZCkgKyAmXCI6IHtcbiAgICBib3JkZXI6IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuYm9yZGVyLnNlY29uZGFyeS5kZWZhdWx0fWAsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LnNlY29uZGFyeS5kZWZhdWx0LFxuXG4gICAgXCImOmhvdmVyXCI6IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQuc2Vjb25kYXJ5LmRlZmF1bHQsXG4gICAgfSxcbiAgfSxcbiAgXCJpbnB1dDpjaGVja2VkICsgJiBcIjoge1xuICAgIGJvcmRlcjogYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuYWNjZW50LmRlZmF1bHR9YCxcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLmFjY2VudFN1YnRsZS5kZWZhdWx0LFxuICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGV4dC5hY2NlbnQuZGVmYXVsdCxcbiAgfSxcbn0pKTtcblxuLyoqIEBkZXByZWNhdGVkIFVzZSBSYWRpbyBvciBTZWdtZW50ZWRDb250cm9sIGNvbXBvbmVudCBpbnN0ZWFkICovXG5leHBvcnQgZnVuY3Rpb24gUmFkaW9CdXR0b24oe1xuICBuYW1lLFxuICB2YWx1ZSA9IFwiXCIsXG4gIGNoZWNrZWQgPSB1bmRlZmluZWQsXG4gIGxhYmVsID0gXCJcIixcbiAgaWNvbixcbiAgZGlzYWJsZWQgPSBmYWxzZSxcbiAgb25DaGFuZ2UsXG4gIG9uQ2xpY2ssXG4gIG9uQmx1cixcbiAgb25Gb2N1cyxcbiAgLi4ucmVzdFxufTogUmFkaW9CdXR0b25Qcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPEZvcm1GaWVsZCBkYXRhLWRzLWlkPVwiUmFkaW9CdXR0b25cIiB7Li4ucmVzdH0gZGlzYWJsZWQ9e2Rpc2FibGVkfT5cbiAgICAgIDxTdHlsZWRDb250YWluZXI+XG4gICAgICAgIDxTdHlsZWRSZWFsSW5wdXRcbiAgICAgICAgICB0eXBlPVwicmFkaW9cIlxuICAgICAgICAgIG5hbWU9e25hbWV9XG4gICAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICAgIGNoZWNrZWQ9e2NoZWNrZWR9XG4gICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgICAgIG9uQmx1cj17b25CbHVyfVxuICAgICAgICAgIG9uRm9jdXM9e29uRm9jdXN9XG4gICAgICAgIC8+XG4gICAgICAgIDxTdHlsZWRGYWtlSW5wdXQ+XG4gICAgICAgICAgPElubGluZSB2QWxpZ25JdGVtcz1cImNlbnRlclwiIGFsaWduSXRlbXM9XCJzcGFjZUJldHdlZW5cIiBub1dyYXA+XG4gICAgICAgICAgICB7bGFiZWx9XG4gICAgICAgICAgICB7aWNvbiAmJiA8SWNvbiBuYW1lPXtpY29ufSAvPn1cbiAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgPC9TdHlsZWRGYWtlSW5wdXQ+XG4gICAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgICA8L0Zvcm1GaWVsZD5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyQ3dCIn0= */");function RadioButton({name,value="",checked,label="",icon,disabled=!1,onChange,onClick,onBlur,onFocus,...rest}){return _react.default.createElement(_FormField.FormField,{"data-ds-id":"RadioButton",...rest,disabled:disabled},_react.default.createElement(StyledContainer,null,_react.default.createElement(StyledRealInput,{type:"radio",name:name,value:value,checked:checked,disabled:disabled,onChange:onChange,onClick:onClick,onBlur:onBlur,onFocus:onFocus}),_react.default.createElement(StyledFakeInput,null,_react.default.createElement(_Inline.Inline,{vAlignItems:"center",alignItems:"spaceBetween",noWrap:!0},label,icon&&_react.default.createElement(_Icon.Icon,{name:icon})))))}