@amboss/design-system 3.9.9 → 3.9.11

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 (38) hide show
  1. package/README.md +2 -334
  2. package/build/cjs/components/CatalogCard/CatalogCard.js +1 -1
  3. package/build/cjs/components/Column/Columns.d.ts +5 -7
  4. package/build/cjs/components/Column/Columns.js +1 -1
  5. package/build/cjs/components/Form/PasswordInput/PasswordInput.js +1 -1
  6. package/build/cjs/components/Form/RadioButton/RadioButton.js +1 -1
  7. package/build/cjs/components/Form/SegmentedControl/SegmentedControl.js +1 -1
  8. package/build/cjs/components/Form/SegmentedControl/SegmentedControlOption.js +1 -1
  9. package/build/cjs/components/Form/ToggleButton/ToggleButton.js +1 -1
  10. package/build/cjs/components/Patterns/Modal/Modal.js +3 -3
  11. package/build/cjs/components/RoundButton/RoundButton.js +1 -1
  12. package/build/cjs/components/Toggletip/BasePopover.d.ts +3 -13
  13. package/build/cjs/components/Toggletip/BasePopover.js +1 -1
  14. package/build/cjs/components/Typography/Header/Header.d.ts +1 -1
  15. package/build/cjs/components/Typography/Header/Header.js +1 -1
  16. package/build/cjs/web-tokens/_colors.json +20 -12
  17. package/build/cjs/web-tokens/visualConfig.d.ts +6 -0
  18. package/build/cjs/web-tokens/visualConfig.js +1 -1
  19. package/build/esm/components/CatalogCard/CatalogCard.js +1 -1
  20. package/build/esm/components/Column/Columns.d.ts +5 -7
  21. package/build/esm/components/Column/Columns.js +1 -1
  22. package/build/esm/components/Form/PasswordInput/PasswordInput.js +1 -1
  23. package/build/esm/components/Form/RadioButton/RadioButton.js +1 -1
  24. package/build/esm/components/Form/SegmentedControl/SegmentedControl.js +1 -1
  25. package/build/esm/components/Form/SegmentedControl/SegmentedControlOption.js +1 -1
  26. package/build/esm/components/Form/ToggleButton/ToggleButton.js +1 -1
  27. package/build/esm/components/Patterns/Modal/Modal.js +3 -3
  28. package/build/esm/components/RoundButton/RoundButton.js +1 -1
  29. package/build/esm/components/Toggletip/BasePopover.d.ts +3 -13
  30. package/build/esm/components/Toggletip/BasePopover.js +1 -1
  31. package/build/esm/components/Typography/Header/Header.d.ts +1 -1
  32. package/build/esm/components/Typography/Header/Header.js +1 -1
  33. package/build/esm/web-tokens/_colors.json +20 -12
  34. package/build/esm/web-tokens/visualConfig.d.ts +6 -0
  35. package/build/esm/web-tokens/visualConfig.js +1 -1
  36. package/build/scss/_theming.scss +8 -6
  37. package/build/scss/_variables.scss +1 -0
  38. package/package.json +8 -14
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}),Object.defineProperty(exports,"CatalogCard",{enumerable:!0,get:function(){return CatalogCard}});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")),_Container=require("../Container/Container"),_DropdownMenu=require("../DropdownMenu/DropdownMenu"),_Box=require("../Box/Box"),_Columns=require("../Column/Columns"),_Inline=require("../Inline/Inline"),_Stack=require("../Stack/Stack"),_TextClamped=require("../Typography/TextClamped/TextClamped"),_breakpointsjson=/*#__PURE__*/_interop_require_default._(require("../../web-tokens/_breakpoints.json")),StyledDropdownMenuContainer=(0,_styled.default)("div",{target:"e1qd7sd30",label:"StyledDropdownMenuContainer"})(({isMobile,theme})=>({marginRight:`-${theme.variables.size.spacing.xs}`,marginTop:`-${theme.variables.size.spacing.xs}`,pointerEvents:"auto",visibility:isMobile?"visible":"collapse"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/CatalogCard/CatalogCard.tsx","sources":["src/components/CatalogCard/CatalogCard.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Container, type ContainerProps } from \"../Container/Container\";\nimport { DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\nconst StyledDropdownMenuContainer = styled.div<{ isMobile: boolean }>(\n  ({ isMobile, theme }) => ({\n    marginRight: `-${theme.variables.size.spacing.xs}`,\n    marginTop: `-${theme.variables.size.spacing.xs}`,\n    pointerEvents: \"auto\",\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  })\n);\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  \"&:focus-within\": {\n    outlineWidth: 2,\n    outlineStyle: \"solid\",\n    outlineColor: \"Highlight\",\n    outlineOffset: -1,\n    borderRadius: theme.variables.size.borderRadius.s,\n\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"&:focus-within\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"solid\",\n      borderRadius: theme.variables.size.borderRadius.s,\n\n      [`${StyledDropdownMenuContainer}`]: {\n        visibility: \"visible\",\n      },\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      boxShadow: theme.values.elevation[2],\n    },\n  },\n}));\n\nconst StyledContainer = styled.div<{ isMobile: boolean }>(({ isMobile }) => ({\n  display: \"flex\",\n  minHeight: \"102px\",\n  cursor: \"pointer\",\n  position: \"relative\",\n  height: \"100%\",\n  alignItems: \"end\",\n\n  [`${StyledDropdownMenuContainer}`]: {\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  },\n\n  \"> div\": {\n    width: \"100%\",\n  },\n\n  \"&:hover\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n}));\n\nconst StyledButton = styled.button({\n  position: \"absolute\",\n  top: 0,\n  left: 0,\n  width: \"1px\",\n  height: \"1px\",\n  opacity: 0,\n  border: \"none\",\n});\n\nconst StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\ntype DropdownMenuOption = {\n  label: string;\n  onSelect: (ev: React.MouseEvent) => void;\n};\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  dropdownMenuOptions?: DropdownMenuOption[];\n  portalContainer?: PortalProps[\"portalContainer\"];\n  onClick?: VoidFunction;\n  onDropdownClick?: (ev: MouseEvent | KeyboardEvent) => void;\n  topLeftElement?: React.ReactNode;\n};\n\nexport function CatalogCard({\n  title,\n  subtitle,\n  dropdownMenuOptions = [],\n  onClick,\n  onDropdownClick,\n  topLeftElement,\n  portalContainer,\n  borderRadius = \"s\",\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.medium.value;\n  const canShowDropdownMenu = dropdownMenuOptions?.length > 0;\n\n  const leftColumnSize = canShowDropdownMenu ? 10 : 12;\n  const rightColumnSize = canShowDropdownMenu ? 2 : \"auto\";\n\n  return (\n    <StyledWrapper>\n      <StyledButton onClick={onClick} aria-label={title} />\n      <Container\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id={dataDsId}\n        borderRadius={borderRadius}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size={leftColumnSize}>\n                {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n                <div onClick={onClick}>\n                  <Stack vAlignItems=\"spaceBetween\" space=\"s\">\n                    {topLeftElement}\n                    <Stack space=\"xxs\" vAlignItems=\"bottom\">\n                      <StyledTitle>\n                        <TextClamped size=\"m\" weight=\"bold\" lines={2}>\n                          {title}\n                        </TextClamped>\n                      </StyledTitle>\n                      {subtitle && (\n                        <TextClamped size=\"s\" color=\"tertiary\">\n                          {subtitle}\n                        </TextClamped>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              <Column size={rightColumnSize}>\n                <Inline alignItems=\"right\">\n                  {canShowDropdownMenu && (\n                    <Box space=\"xxs\" bSpace=\"zero\">\n                      <StyledDropdownMenuContainer isMobile={isMobile}>\n                        <DropdownMenu\n                          iconName=\"more-horizontal\"\n                          menuItems={dropdownMenuOptions}\n                          onMenuOpen={onDropdownClick}\n                          portalContainer={portalContainer}\n                          size=\"s\"\n                        />\n                      </StyledDropdownMenuContainer>\n                    </Box>\n                  )}\n                </Inline>\n              </Column>\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AAYoC"} */"),StyledWrapper=(0,_styled.default)("div",{target:"e1qd7sd31",label:"StyledWrapper"})(({theme})=>({position:"relative",height:"100%","> div":{height:"100%"},"&:focus-within":{outlineWidth:2,outlineStyle:"solid",outlineColor:"Highlight",outlineOffset:-1,borderRadius:theme.variables.size.borderRadius.s,[`${StyledDropdownMenuContainer}`]:{visibility:"visible"}},"@media (-webkit-min-device-pixel-ratio:0)":{"&:focus-within":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"solid",borderRadius:theme.variables.size.borderRadius.s,[`${StyledDropdownMenuContainer}`]:{visibility:"visible"}}},"&:hover":{"> div":{boxShadow:theme.values.elevation[2]}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/CatalogCard/CatalogCard.tsx","sources":["src/components/CatalogCard/CatalogCard.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Container, type ContainerProps } from \"../Container/Container\";\nimport { DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\nconst StyledDropdownMenuContainer = styled.div<{ isMobile: boolean }>(\n  ({ isMobile, theme }) => ({\n    marginRight: `-${theme.variables.size.spacing.xs}`,\n    marginTop: `-${theme.variables.size.spacing.xs}`,\n    pointerEvents: \"auto\",\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  })\n);\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  \"&:focus-within\": {\n    outlineWidth: 2,\n    outlineStyle: \"solid\",\n    outlineColor: \"Highlight\",\n    outlineOffset: -1,\n    borderRadius: theme.variables.size.borderRadius.s,\n\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"&:focus-within\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"solid\",\n      borderRadius: theme.variables.size.borderRadius.s,\n\n      [`${StyledDropdownMenuContainer}`]: {\n        visibility: \"visible\",\n      },\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      boxShadow: theme.values.elevation[2],\n    },\n  },\n}));\n\nconst StyledContainer = styled.div<{ isMobile: boolean }>(({ isMobile }) => ({\n  display: \"flex\",\n  minHeight: \"102px\",\n  cursor: \"pointer\",\n  position: \"relative\",\n  height: \"100%\",\n  alignItems: \"end\",\n\n  [`${StyledDropdownMenuContainer}`]: {\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  },\n\n  \"> div\": {\n    width: \"100%\",\n  },\n\n  \"&:hover\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n}));\n\nconst StyledButton = styled.button({\n  position: \"absolute\",\n  top: 0,\n  left: 0,\n  width: \"1px\",\n  height: \"1px\",\n  opacity: 0,\n  border: \"none\",\n});\n\nconst StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\ntype DropdownMenuOption = {\n  label: string;\n  onSelect: (ev: React.MouseEvent) => void;\n};\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  dropdownMenuOptions?: DropdownMenuOption[];\n  portalContainer?: PortalProps[\"portalContainer\"];\n  onClick?: VoidFunction;\n  onDropdownClick?: (ev: MouseEvent | KeyboardEvent) => void;\n  topLeftElement?: React.ReactNode;\n};\n\nexport function CatalogCard({\n  title,\n  subtitle,\n  dropdownMenuOptions = [],\n  onClick,\n  onDropdownClick,\n  topLeftElement,\n  portalContainer,\n  borderRadius = \"s\",\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.medium.value;\n  const canShowDropdownMenu = dropdownMenuOptions?.length > 0;\n\n  const leftColumnSize = canShowDropdownMenu ? 10 : 12;\n  const rightColumnSize = canShowDropdownMenu ? 2 : \"auto\";\n\n  return (\n    <StyledWrapper>\n      <StyledButton onClick={onClick} aria-label={title} />\n      <Container\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id={dataDsId}\n        borderRadius={borderRadius}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size={leftColumnSize}>\n                {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n                <div onClick={onClick}>\n                  <Stack vAlignItems=\"spaceBetween\" space=\"s\">\n                    {topLeftElement}\n                    <Stack space=\"xxs\" vAlignItems=\"bottom\">\n                      <StyledTitle>\n                        <TextClamped size=\"m\" weight=\"bold\" lines={2}>\n                          {title}\n                        </TextClamped>\n                      </StyledTitle>\n                      {subtitle && (\n                        <TextClamped size=\"s\" color=\"tertiary\">\n                          {subtitle}\n                        </TextClamped>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              <Column size={rightColumnSize}>\n                <Inline alignItems=\"right\">\n                  {canShowDropdownMenu && (\n                    <Box space=\"xxs\" bSpace=\"zero\">\n                      <StyledDropdownMenuContainer isMobile={isMobile}>\n                        <DropdownMenu\n                          iconName=\"more-horizontal\"\n                          menuItems={dropdownMenuOptions}\n                          onMenuOpen={onDropdownClick}\n                          portalContainer={portalContainer}\n                          size=\"s\"\n                        />\n                      </StyledDropdownMenuContainer>\n                    </Box>\n                  )}\n                </Inline>\n              </Column>\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AAqBsB"} */"),StyledContainer=(0,_styled.default)("div",{target:"e1qd7sd32",label:"StyledContainer"})(({isMobile})=>({display:"flex",minHeight:"102px",cursor:"pointer",position:"relative",height:"100%",alignItems:"end",[`${StyledDropdownMenuContainer}`]:{visibility:isMobile?"visible":"collapse"},"> div":{width:"100%"},"&:hover":{[`${StyledDropdownMenuContainer}`]:{visibility:"visible"}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/CatalogCard/CatalogCard.tsx","sources":["src/components/CatalogCard/CatalogCard.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Container, type ContainerProps } from \"../Container/Container\";\nimport { DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\nconst StyledDropdownMenuContainer = styled.div<{ isMobile: boolean }>(\n  ({ isMobile, theme }) => ({\n    marginRight: `-${theme.variables.size.spacing.xs}`,\n    marginTop: `-${theme.variables.size.spacing.xs}`,\n    pointerEvents: \"auto\",\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  })\n);\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  \"&:focus-within\": {\n    outlineWidth: 2,\n    outlineStyle: \"solid\",\n    outlineColor: \"Highlight\",\n    outlineOffset: -1,\n    borderRadius: theme.variables.size.borderRadius.s,\n\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"&:focus-within\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"solid\",\n      borderRadius: theme.variables.size.borderRadius.s,\n\n      [`${StyledDropdownMenuContainer}`]: {\n        visibility: \"visible\",\n      },\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      boxShadow: theme.values.elevation[2],\n    },\n  },\n}));\n\nconst StyledContainer = styled.div<{ isMobile: boolean }>(({ isMobile }) => ({\n  display: \"flex\",\n  minHeight: \"102px\",\n  cursor: \"pointer\",\n  position: \"relative\",\n  height: \"100%\",\n  alignItems: \"end\",\n\n  [`${StyledDropdownMenuContainer}`]: {\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  },\n\n  \"> div\": {\n    width: \"100%\",\n  },\n\n  \"&:hover\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n}));\n\nconst StyledButton = styled.button({\n  position: \"absolute\",\n  top: 0,\n  left: 0,\n  width: \"1px\",\n  height: \"1px\",\n  opacity: 0,\n  border: \"none\",\n});\n\nconst StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\ntype DropdownMenuOption = {\n  label: string;\n  onSelect: (ev: React.MouseEvent) => void;\n};\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  dropdownMenuOptions?: DropdownMenuOption[];\n  portalContainer?: PortalProps[\"portalContainer\"];\n  onClick?: VoidFunction;\n  onDropdownClick?: (ev: MouseEvent | KeyboardEvent) => void;\n  topLeftElement?: React.ReactNode;\n};\n\nexport function CatalogCard({\n  title,\n  subtitle,\n  dropdownMenuOptions = [],\n  onClick,\n  onDropdownClick,\n  topLeftElement,\n  portalContainer,\n  borderRadius = \"s\",\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.medium.value;\n  const canShowDropdownMenu = dropdownMenuOptions?.length > 0;\n\n  const leftColumnSize = canShowDropdownMenu ? 10 : 12;\n  const rightColumnSize = canShowDropdownMenu ? 2 : \"auto\";\n\n  return (\n    <StyledWrapper>\n      <StyledButton onClick={onClick} aria-label={title} />\n      <Container\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id={dataDsId}\n        borderRadius={borderRadius}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size={leftColumnSize}>\n                {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n                <div onClick={onClick}>\n                  <Stack vAlignItems=\"spaceBetween\" space=\"s\">\n                    {topLeftElement}\n                    <Stack space=\"xxs\" vAlignItems=\"bottom\">\n                      <StyledTitle>\n                        <TextClamped size=\"m\" weight=\"bold\" lines={2}>\n                          {title}\n                        </TextClamped>\n                      </StyledTitle>\n                      {subtitle && (\n                        <TextClamped size=\"s\" color=\"tertiary\">\n                          {subtitle}\n                        </TextClamped>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              <Column size={rightColumnSize}>\n                <Inline alignItems=\"right\">\n                  {canShowDropdownMenu && (\n                    <Box space=\"xxs\" bSpace=\"zero\">\n                      <StyledDropdownMenuContainer isMobile={isMobile}>\n                        <DropdownMenu\n                          iconName=\"more-horizontal\"\n                          menuItems={dropdownMenuOptions}\n                          onMenuOpen={onDropdownClick}\n                          portalContainer={portalContainer}\n                          size=\"s\"\n                        />\n                      </StyledDropdownMenuContainer>\n                    </Box>\n                  )}\n                </Inline>\n              </Column>\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AA4DwB"} */"),StyledButton=(0,_styled.default)("button",{target:"e1qd7sd33",label:"StyledButton"})({position:"absolute",top:0,left:0,width:"1px",height:"1px",opacity:0,border:"none"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/CatalogCard/CatalogCard.tsx","sources":["src/components/CatalogCard/CatalogCard.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Container, type ContainerProps } from \"../Container/Container\";\nimport { DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\nconst StyledDropdownMenuContainer = styled.div<{ isMobile: boolean }>(\n  ({ isMobile, theme }) => ({\n    marginRight: `-${theme.variables.size.spacing.xs}`,\n    marginTop: `-${theme.variables.size.spacing.xs}`,\n    pointerEvents: \"auto\",\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  })\n);\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  \"&:focus-within\": {\n    outlineWidth: 2,\n    outlineStyle: \"solid\",\n    outlineColor: \"Highlight\",\n    outlineOffset: -1,\n    borderRadius: theme.variables.size.borderRadius.s,\n\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"&:focus-within\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"solid\",\n      borderRadius: theme.variables.size.borderRadius.s,\n\n      [`${StyledDropdownMenuContainer}`]: {\n        visibility: \"visible\",\n      },\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      boxShadow: theme.values.elevation[2],\n    },\n  },\n}));\n\nconst StyledContainer = styled.div<{ isMobile: boolean }>(({ isMobile }) => ({\n  display: \"flex\",\n  minHeight: \"102px\",\n  cursor: \"pointer\",\n  position: \"relative\",\n  height: \"100%\",\n  alignItems: \"end\",\n\n  [`${StyledDropdownMenuContainer}`]: {\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  },\n\n  \"> div\": {\n    width: \"100%\",\n  },\n\n  \"&:hover\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n}));\n\nconst StyledButton = styled.button({\n  position: \"absolute\",\n  top: 0,\n  left: 0,\n  width: \"1px\",\n  height: \"1px\",\n  opacity: 0,\n  border: \"none\",\n});\n\nconst StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\ntype DropdownMenuOption = {\n  label: string;\n  onSelect: (ev: React.MouseEvent) => void;\n};\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  dropdownMenuOptions?: DropdownMenuOption[];\n  portalContainer?: PortalProps[\"portalContainer\"];\n  onClick?: VoidFunction;\n  onDropdownClick?: (ev: MouseEvent | KeyboardEvent) => void;\n  topLeftElement?: React.ReactNode;\n};\n\nexport function CatalogCard({\n  title,\n  subtitle,\n  dropdownMenuOptions = [],\n  onClick,\n  onDropdownClick,\n  topLeftElement,\n  portalContainer,\n  borderRadius = \"s\",\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.medium.value;\n  const canShowDropdownMenu = dropdownMenuOptions?.length > 0;\n\n  const leftColumnSize = canShowDropdownMenu ? 10 : 12;\n  const rightColumnSize = canShowDropdownMenu ? 2 : \"auto\";\n\n  return (\n    <StyledWrapper>\n      <StyledButton onClick={onClick} aria-label={title} />\n      <Container\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id={dataDsId}\n        borderRadius={borderRadius}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size={leftColumnSize}>\n                {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n                <div onClick={onClick}>\n                  <Stack vAlignItems=\"spaceBetween\" space=\"s\">\n                    {topLeftElement}\n                    <Stack space=\"xxs\" vAlignItems=\"bottom\">\n                      <StyledTitle>\n                        <TextClamped size=\"m\" weight=\"bold\" lines={2}>\n                          {title}\n                        </TextClamped>\n                      </StyledTitle>\n                      {subtitle && (\n                        <TextClamped size=\"s\" color=\"tertiary\">\n                          {subtitle}\n                        </TextClamped>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              <Column size={rightColumnSize}>\n                <Inline alignItems=\"right\">\n                  {canShowDropdownMenu && (\n                    <Box space=\"xxs\" bSpace=\"zero\">\n                      <StyledDropdownMenuContainer isMobile={isMobile}>\n                        <DropdownMenu\n                          iconName=\"more-horizontal\"\n                          menuItems={dropdownMenuOptions}\n                          onMenuOpen={onDropdownClick}\n                          portalContainer={portalContainer}\n                          size=\"s\"\n                        />\n                      </StyledDropdownMenuContainer>\n                    </Box>\n                  )}\n                </Inline>\n              </Column>\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AAmFqB"} */"),StyledTitle=(0,_styled.default)("div",{target:"e1qd7sd34",label:"StyledTitle"})(({theme})=>({display:"flex",flexDirection:"column",height:theme.variables.size.spacing.xxl,justifyContent:"flex-end"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/CatalogCard/CatalogCard.tsx","sources":["src/components/CatalogCard/CatalogCard.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Container, type ContainerProps } from \"../Container/Container\";\nimport { DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\nconst StyledDropdownMenuContainer = styled.div<{ isMobile: boolean }>(\n  ({ isMobile, theme }) => ({\n    marginRight: `-${theme.variables.size.spacing.xs}`,\n    marginTop: `-${theme.variables.size.spacing.xs}`,\n    pointerEvents: \"auto\",\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  })\n);\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  \"&:focus-within\": {\n    outlineWidth: 2,\n    outlineStyle: \"solid\",\n    outlineColor: \"Highlight\",\n    outlineOffset: -1,\n    borderRadius: theme.variables.size.borderRadius.s,\n\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"&:focus-within\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"solid\",\n      borderRadius: theme.variables.size.borderRadius.s,\n\n      [`${StyledDropdownMenuContainer}`]: {\n        visibility: \"visible\",\n      },\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      boxShadow: theme.values.elevation[2],\n    },\n  },\n}));\n\nconst StyledContainer = styled.div<{ isMobile: boolean }>(({ isMobile }) => ({\n  display: \"flex\",\n  minHeight: \"102px\",\n  cursor: \"pointer\",\n  position: \"relative\",\n  height: \"100%\",\n  alignItems: \"end\",\n\n  [`${StyledDropdownMenuContainer}`]: {\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  },\n\n  \"> div\": {\n    width: \"100%\",\n  },\n\n  \"&:hover\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n}));\n\nconst StyledButton = styled.button({\n  position: \"absolute\",\n  top: 0,\n  left: 0,\n  width: \"1px\",\n  height: \"1px\",\n  opacity: 0,\n  border: \"none\",\n});\n\nconst StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\ntype DropdownMenuOption = {\n  label: string;\n  onSelect: (ev: React.MouseEvent) => void;\n};\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  dropdownMenuOptions?: DropdownMenuOption[];\n  portalContainer?: PortalProps[\"portalContainer\"];\n  onClick?: VoidFunction;\n  onDropdownClick?: (ev: MouseEvent | KeyboardEvent) => void;\n  topLeftElement?: React.ReactNode;\n};\n\nexport function CatalogCard({\n  title,\n  subtitle,\n  dropdownMenuOptions = [],\n  onClick,\n  onDropdownClick,\n  topLeftElement,\n  portalContainer,\n  borderRadius = \"s\",\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.medium.value;\n  const canShowDropdownMenu = dropdownMenuOptions?.length > 0;\n\n  const leftColumnSize = canShowDropdownMenu ? 10 : 12;\n  const rightColumnSize = canShowDropdownMenu ? 2 : \"auto\";\n\n  return (\n    <StyledWrapper>\n      <StyledButton onClick={onClick} aria-label={title} />\n      <Container\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id={dataDsId}\n        borderRadius={borderRadius}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size={leftColumnSize}>\n                {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n                <div onClick={onClick}>\n                  <Stack vAlignItems=\"spaceBetween\" space=\"s\">\n                    {topLeftElement}\n                    <Stack space=\"xxs\" vAlignItems=\"bottom\">\n                      <StyledTitle>\n                        <TextClamped size=\"m\" weight=\"bold\" lines={2}>\n                          {title}\n                        </TextClamped>\n                      </StyledTitle>\n                      {subtitle && (\n                        <TextClamped size=\"s\" color=\"tertiary\">\n                          {subtitle}\n                        </TextClamped>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              <Column size={rightColumnSize}>\n                <Inline alignItems=\"right\">\n                  {canShowDropdownMenu && (\n                    <Box space=\"xxs\" bSpace=\"zero\">\n                      <StyledDropdownMenuContainer isMobile={isMobile}>\n                        <DropdownMenu\n                          iconName=\"more-horizontal\"\n                          menuItems={dropdownMenuOptions}\n                          onMenuOpen={onDropdownClick}\n                          portalContainer={portalContainer}\n                          size=\"s\"\n                        />\n                      </StyledDropdownMenuContainer>\n                    </Box>\n                  )}\n                </Inline>\n              </Column>\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AA6FoB"} */");function CatalogCard({title,subtitle,dropdownMenuOptions=[],onClick,onDropdownClick,topLeftElement,portalContainer,borderRadius="s","data-e2e-test-id":dataE2eTestId="CatalogCard","data-ds-id":dataDsId="CatalogCard"}){let isMobile=!!window&&window.innerWidth<=_breakpointsjson.default.medium.value,canShowDropdownMenu=dropdownMenuOptions?.length>0;return _react.default.createElement(StyledWrapper,null,_react.default.createElement(StyledButton,{onClick:onClick,"aria-label":title}),_react.default.createElement(_Container.Container,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId,borderRadius:borderRadius},_react.default.createElement(StyledContainer,{isMobile:isMobile},_react.default.createElement(_Box.Box,{space:"m"},_react.default.createElement(_Columns.Columns,null,_react.default.createElement(_Columns.Column,{size:canShowDropdownMenu?10:12},_react.default.createElement("div",{onClick:onClick},_react.default.createElement(_Stack.Stack,{vAlignItems:"spaceBetween",space:"s"},topLeftElement,_react.default.createElement(_Stack.Stack,{space:"xxs",vAlignItems:"bottom"},_react.default.createElement(StyledTitle,null,_react.default.createElement(_TextClamped.TextClamped,{size:"m",weight:"bold",lines:2},title)),subtitle&&_react.default.createElement(_TextClamped.TextClamped,{size:"s",color:"tertiary"},subtitle))))),_react.default.createElement(_Columns.Column,{size:canShowDropdownMenu?2:"auto"},_react.default.createElement(_Inline.Inline,{alignItems:"right"},canShowDropdownMenu&&_react.default.createElement(_Box.Box,{space:"xxs",bSpace:"zero"},_react.default.createElement(StyledDropdownMenuContainer,{isMobile:isMobile},_react.default.createElement(_DropdownMenu.DropdownMenu,{iconName:"more-horizontal",menuItems:dropdownMenuOptions,onMenuOpen:onDropdownClick,portalContainer:portalContainer,size:"s"}))))))))))}
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"CatalogCard",{enumerable:!0,get:function(){return CatalogCard}});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")),_Container=require("../Container/Container"),_DropdownMenu=require("../DropdownMenu/DropdownMenu"),_Box=require("../Box/Box"),_Columns=require("../Column/Columns"),_Inline=require("../Inline/Inline"),_Stack=require("../Stack/Stack"),_TextClamped=require("../Typography/TextClamped/TextClamped"),_breakpointsjson=/*#__PURE__*/_interop_require_default._(require("../../web-tokens/_breakpoints.json")),StyledDropdownMenuContainer=(0,_styled.default)("div",{target:"ecnjjdi0",label:"StyledDropdownMenuContainer"})(({isMobile,theme})=>({marginRight:`-${theme.variables.size.spacing.xs}`,marginTop:`-${theme.variables.size.spacing.xs}`,pointerEvents:"auto",visibility:isMobile?"visible":"collapse"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/CatalogCard/CatalogCard.tsx","sources":["src/components/CatalogCard/CatalogCard.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Container, type ContainerProps } from \"../Container/Container\";\nimport { DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\nconst StyledDropdownMenuContainer = styled.div<{ isMobile: boolean }>(\n  ({ isMobile, theme }) => ({\n    marginRight: `-${theme.variables.size.spacing.xs}`,\n    marginTop: `-${theme.variables.size.spacing.xs}`,\n    pointerEvents: \"auto\",\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  })\n);\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  // <Container/>\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  \"&:focus-within\": {\n    \"> div\": {\n      outlineWidth: 2,\n      outlineStyle: \"solid\",\n      outlineColor: \"Highlight\",\n      outlineOffset: -1,\n      borderRadius: theme.variables.size.borderRadius.s,\n    },\n\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"&:focus-within > div\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"solid\",\n      borderRadius: theme.variables.size.borderRadius.s,\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      boxShadow: theme.values.elevation[2],\n    },\n  },\n}));\n\nconst StyledContainer = styled.div<{ isMobile: boolean }>(({ isMobile }) => ({\n  display: \"flex\",\n  minHeight: \"102px\",\n  cursor: \"pointer\",\n  position: \"relative\",\n  height: \"100%\",\n  alignItems: \"end\",\n\n  [`${StyledDropdownMenuContainer}`]: {\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  },\n\n  \"> div\": {\n    width: \"100%\",\n  },\n\n  \"&:hover\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n}));\n\nconst StyledButton = styled.button({\n  position: \"absolute\",\n  top: 0,\n  left: 0,\n  width: \"1px\",\n  height: \"1px\",\n  opacity: 0,\n  border: \"none\",\n});\n\nconst StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\ntype DropdownMenuOption = {\n  label: string;\n  onSelect: (ev: React.MouseEvent) => void;\n};\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  dropdownMenuOptions?: DropdownMenuOption[];\n  portalContainer?: PortalProps[\"portalContainer\"];\n  onClick?: VoidFunction;\n  onDropdownClick?: (ev: MouseEvent | KeyboardEvent) => void;\n  topLeftElement?: React.ReactNode;\n};\n\nexport function CatalogCard({\n  title,\n  subtitle,\n  dropdownMenuOptions = [],\n  onClick,\n  onDropdownClick,\n  topLeftElement,\n  portalContainer,\n  borderRadius = \"s\",\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.medium.value;\n  const canShowDropdownMenu = dropdownMenuOptions?.length > 0;\n\n  const leftColumnSize = canShowDropdownMenu ? 10 : 12;\n  const rightColumnSize = canShowDropdownMenu ? 2 : \"auto\";\n\n  return (\n    <StyledWrapper>\n      <StyledButton onClick={onClick} aria-label={title} />\n      <Container\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id={dataDsId}\n        borderRadius={borderRadius}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size={leftColumnSize}>\n                {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n                <div onClick={onClick}>\n                  <Stack vAlignItems=\"spaceBetween\" space=\"s\">\n                    {topLeftElement}\n                    <Stack space=\"xxs\" vAlignItems=\"bottom\">\n                      <StyledTitle>\n                        <TextClamped size=\"m\" weight=\"bold\" lines={2}>\n                          {title}\n                        </TextClamped>\n                      </StyledTitle>\n                      {subtitle && (\n                        <TextClamped size=\"s\" color=\"tertiary\">\n                          {subtitle}\n                        </TextClamped>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              <Column size={rightColumnSize}>\n                <Inline alignItems=\"right\">\n                  {canShowDropdownMenu && (\n                    <Box space=\"xxs\" bSpace=\"zero\">\n                      <StyledDropdownMenuContainer isMobile={isMobile}>\n                        <DropdownMenu\n                          iconName=\"more-horizontal\"\n                          menuItems={dropdownMenuOptions}\n                          onMenuOpen={onDropdownClick}\n                          portalContainer={portalContainer}\n                          size=\"s\"\n                        />\n                      </StyledDropdownMenuContainer>\n                    </Box>\n                  )}\n                </Inline>\n              </Column>\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AAYoC"} */"),StyledWrapper=(0,_styled.default)("div",{target:"ecnjjdi1",label:"StyledWrapper"})(({theme})=>({position:"relative",height:"100%","> div":{height:"100%"},"&:focus-within":{"> div":{outlineWidth:2,outlineStyle:"solid",outlineColor:"Highlight",outlineOffset:-1,borderRadius:theme.variables.size.borderRadius.s},[`${StyledDropdownMenuContainer}`]:{visibility:"visible"}},"@media (-webkit-min-device-pixel-ratio:0)":{"&:focus-within > div":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"solid",borderRadius:theme.variables.size.borderRadius.s}},"&:hover":{"> div":{boxShadow:theme.values.elevation[2]}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/CatalogCard/CatalogCard.tsx","sources":["src/components/CatalogCard/CatalogCard.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Container, type ContainerProps } from \"../Container/Container\";\nimport { DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\nconst StyledDropdownMenuContainer = styled.div<{ isMobile: boolean }>(\n  ({ isMobile, theme }) => ({\n    marginRight: `-${theme.variables.size.spacing.xs}`,\n    marginTop: `-${theme.variables.size.spacing.xs}`,\n    pointerEvents: \"auto\",\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  })\n);\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  // <Container/>\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  \"&:focus-within\": {\n    \"> div\": {\n      outlineWidth: 2,\n      outlineStyle: \"solid\",\n      outlineColor: \"Highlight\",\n      outlineOffset: -1,\n      borderRadius: theme.variables.size.borderRadius.s,\n    },\n\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"&:focus-within > div\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"solid\",\n      borderRadius: theme.variables.size.borderRadius.s,\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      boxShadow: theme.values.elevation[2],\n    },\n  },\n}));\n\nconst StyledContainer = styled.div<{ isMobile: boolean }>(({ isMobile }) => ({\n  display: \"flex\",\n  minHeight: \"102px\",\n  cursor: \"pointer\",\n  position: \"relative\",\n  height: \"100%\",\n  alignItems: \"end\",\n\n  [`${StyledDropdownMenuContainer}`]: {\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  },\n\n  \"> div\": {\n    width: \"100%\",\n  },\n\n  \"&:hover\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n}));\n\nconst StyledButton = styled.button({\n  position: \"absolute\",\n  top: 0,\n  left: 0,\n  width: \"1px\",\n  height: \"1px\",\n  opacity: 0,\n  border: \"none\",\n});\n\nconst StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\ntype DropdownMenuOption = {\n  label: string;\n  onSelect: (ev: React.MouseEvent) => void;\n};\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  dropdownMenuOptions?: DropdownMenuOption[];\n  portalContainer?: PortalProps[\"portalContainer\"];\n  onClick?: VoidFunction;\n  onDropdownClick?: (ev: MouseEvent | KeyboardEvent) => void;\n  topLeftElement?: React.ReactNode;\n};\n\nexport function CatalogCard({\n  title,\n  subtitle,\n  dropdownMenuOptions = [],\n  onClick,\n  onDropdownClick,\n  topLeftElement,\n  portalContainer,\n  borderRadius = \"s\",\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.medium.value;\n  const canShowDropdownMenu = dropdownMenuOptions?.length > 0;\n\n  const leftColumnSize = canShowDropdownMenu ? 10 : 12;\n  const rightColumnSize = canShowDropdownMenu ? 2 : \"auto\";\n\n  return (\n    <StyledWrapper>\n      <StyledButton onClick={onClick} aria-label={title} />\n      <Container\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id={dataDsId}\n        borderRadius={borderRadius}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size={leftColumnSize}>\n                {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n                <div onClick={onClick}>\n                  <Stack vAlignItems=\"spaceBetween\" space=\"s\">\n                    {topLeftElement}\n                    <Stack space=\"xxs\" vAlignItems=\"bottom\">\n                      <StyledTitle>\n                        <TextClamped size=\"m\" weight=\"bold\" lines={2}>\n                          {title}\n                        </TextClamped>\n                      </StyledTitle>\n                      {subtitle && (\n                        <TextClamped size=\"s\" color=\"tertiary\">\n                          {subtitle}\n                        </TextClamped>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              <Column size={rightColumnSize}>\n                <Inline alignItems=\"right\">\n                  {canShowDropdownMenu && (\n                    <Box space=\"xxs\" bSpace=\"zero\">\n                      <StyledDropdownMenuContainer isMobile={isMobile}>\n                        <DropdownMenu\n                          iconName=\"more-horizontal\"\n                          menuItems={dropdownMenuOptions}\n                          onMenuOpen={onDropdownClick}\n                          portalContainer={portalContainer}\n                          size=\"s\"\n                        />\n                      </StyledDropdownMenuContainer>\n                    </Box>\n                  )}\n                </Inline>\n              </Column>\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AAqBsB"} */"),StyledContainer=(0,_styled.default)("div",{target:"ecnjjdi2",label:"StyledContainer"})(({isMobile})=>({display:"flex",minHeight:"102px",cursor:"pointer",position:"relative",height:"100%",alignItems:"end",[`${StyledDropdownMenuContainer}`]:{visibility:isMobile?"visible":"collapse"},"> div":{width:"100%"},"&:hover":{[`${StyledDropdownMenuContainer}`]:{visibility:"visible"}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/CatalogCard/CatalogCard.tsx","sources":["src/components/CatalogCard/CatalogCard.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Container, type ContainerProps } from \"../Container/Container\";\nimport { DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\nconst StyledDropdownMenuContainer = styled.div<{ isMobile: boolean }>(\n  ({ isMobile, theme }) => ({\n    marginRight: `-${theme.variables.size.spacing.xs}`,\n    marginTop: `-${theme.variables.size.spacing.xs}`,\n    pointerEvents: \"auto\",\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  })\n);\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  // <Container/>\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  \"&:focus-within\": {\n    \"> div\": {\n      outlineWidth: 2,\n      outlineStyle: \"solid\",\n      outlineColor: \"Highlight\",\n      outlineOffset: -1,\n      borderRadius: theme.variables.size.borderRadius.s,\n    },\n\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"&:focus-within > div\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"solid\",\n      borderRadius: theme.variables.size.borderRadius.s,\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      boxShadow: theme.values.elevation[2],\n    },\n  },\n}));\n\nconst StyledContainer = styled.div<{ isMobile: boolean }>(({ isMobile }) => ({\n  display: \"flex\",\n  minHeight: \"102px\",\n  cursor: \"pointer\",\n  position: \"relative\",\n  height: \"100%\",\n  alignItems: \"end\",\n\n  [`${StyledDropdownMenuContainer}`]: {\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  },\n\n  \"> div\": {\n    width: \"100%\",\n  },\n\n  \"&:hover\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n}));\n\nconst StyledButton = styled.button({\n  position: \"absolute\",\n  top: 0,\n  left: 0,\n  width: \"1px\",\n  height: \"1px\",\n  opacity: 0,\n  border: \"none\",\n});\n\nconst StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\ntype DropdownMenuOption = {\n  label: string;\n  onSelect: (ev: React.MouseEvent) => void;\n};\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  dropdownMenuOptions?: DropdownMenuOption[];\n  portalContainer?: PortalProps[\"portalContainer\"];\n  onClick?: VoidFunction;\n  onDropdownClick?: (ev: MouseEvent | KeyboardEvent) => void;\n  topLeftElement?: React.ReactNode;\n};\n\nexport function CatalogCard({\n  title,\n  subtitle,\n  dropdownMenuOptions = [],\n  onClick,\n  onDropdownClick,\n  topLeftElement,\n  portalContainer,\n  borderRadius = \"s\",\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.medium.value;\n  const canShowDropdownMenu = dropdownMenuOptions?.length > 0;\n\n  const leftColumnSize = canShowDropdownMenu ? 10 : 12;\n  const rightColumnSize = canShowDropdownMenu ? 2 : \"auto\";\n\n  return (\n    <StyledWrapper>\n      <StyledButton onClick={onClick} aria-label={title} />\n      <Container\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id={dataDsId}\n        borderRadius={borderRadius}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size={leftColumnSize}>\n                {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n                <div onClick={onClick}>\n                  <Stack vAlignItems=\"spaceBetween\" space=\"s\">\n                    {topLeftElement}\n                    <Stack space=\"xxs\" vAlignItems=\"bottom\">\n                      <StyledTitle>\n                        <TextClamped size=\"m\" weight=\"bold\" lines={2}>\n                          {title}\n                        </TextClamped>\n                      </StyledTitle>\n                      {subtitle && (\n                        <TextClamped size=\"s\" color=\"tertiary\">\n                          {subtitle}\n                        </TextClamped>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              <Column size={rightColumnSize}>\n                <Inline alignItems=\"right\">\n                  {canShowDropdownMenu && (\n                    <Box space=\"xxs\" bSpace=\"zero\">\n                      <StyledDropdownMenuContainer isMobile={isMobile}>\n                        <DropdownMenu\n                          iconName=\"more-horizontal\"\n                          menuItems={dropdownMenuOptions}\n                          onMenuOpen={onDropdownClick}\n                          portalContainer={portalContainer}\n                          size=\"s\"\n                        />\n                      </StyledDropdownMenuContainer>\n                    </Box>\n                  )}\n                </Inline>\n              </Column>\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AA2DwB"} */"),StyledButton=(0,_styled.default)("button",{target:"ecnjjdi3",label:"StyledButton"})({position:"absolute",top:0,left:0,width:"1px",height:"1px",opacity:0,border:"none"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/CatalogCard/CatalogCard.tsx","sources":["src/components/CatalogCard/CatalogCard.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Container, type ContainerProps } from \"../Container/Container\";\nimport { DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\nconst StyledDropdownMenuContainer = styled.div<{ isMobile: boolean }>(\n  ({ isMobile, theme }) => ({\n    marginRight: `-${theme.variables.size.spacing.xs}`,\n    marginTop: `-${theme.variables.size.spacing.xs}`,\n    pointerEvents: \"auto\",\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  })\n);\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  // <Container/>\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  \"&:focus-within\": {\n    \"> div\": {\n      outlineWidth: 2,\n      outlineStyle: \"solid\",\n      outlineColor: \"Highlight\",\n      outlineOffset: -1,\n      borderRadius: theme.variables.size.borderRadius.s,\n    },\n\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"&:focus-within > div\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"solid\",\n      borderRadius: theme.variables.size.borderRadius.s,\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      boxShadow: theme.values.elevation[2],\n    },\n  },\n}));\n\nconst StyledContainer = styled.div<{ isMobile: boolean }>(({ isMobile }) => ({\n  display: \"flex\",\n  minHeight: \"102px\",\n  cursor: \"pointer\",\n  position: \"relative\",\n  height: \"100%\",\n  alignItems: \"end\",\n\n  [`${StyledDropdownMenuContainer}`]: {\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  },\n\n  \"> div\": {\n    width: \"100%\",\n  },\n\n  \"&:hover\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n}));\n\nconst StyledButton = styled.button({\n  position: \"absolute\",\n  top: 0,\n  left: 0,\n  width: \"1px\",\n  height: \"1px\",\n  opacity: 0,\n  border: \"none\",\n});\n\nconst StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\ntype DropdownMenuOption = {\n  label: string;\n  onSelect: (ev: React.MouseEvent) => void;\n};\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  dropdownMenuOptions?: DropdownMenuOption[];\n  portalContainer?: PortalProps[\"portalContainer\"];\n  onClick?: VoidFunction;\n  onDropdownClick?: (ev: MouseEvent | KeyboardEvent) => void;\n  topLeftElement?: React.ReactNode;\n};\n\nexport function CatalogCard({\n  title,\n  subtitle,\n  dropdownMenuOptions = [],\n  onClick,\n  onDropdownClick,\n  topLeftElement,\n  portalContainer,\n  borderRadius = \"s\",\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.medium.value;\n  const canShowDropdownMenu = dropdownMenuOptions?.length > 0;\n\n  const leftColumnSize = canShowDropdownMenu ? 10 : 12;\n  const rightColumnSize = canShowDropdownMenu ? 2 : \"auto\";\n\n  return (\n    <StyledWrapper>\n      <StyledButton onClick={onClick} aria-label={title} />\n      <Container\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id={dataDsId}\n        borderRadius={borderRadius}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size={leftColumnSize}>\n                {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n                <div onClick={onClick}>\n                  <Stack vAlignItems=\"spaceBetween\" space=\"s\">\n                    {topLeftElement}\n                    <Stack space=\"xxs\" vAlignItems=\"bottom\">\n                      <StyledTitle>\n                        <TextClamped size=\"m\" weight=\"bold\" lines={2}>\n                          {title}\n                        </TextClamped>\n                      </StyledTitle>\n                      {subtitle && (\n                        <TextClamped size=\"s\" color=\"tertiary\">\n                          {subtitle}\n                        </TextClamped>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              <Column size={rightColumnSize}>\n                <Inline alignItems=\"right\">\n                  {canShowDropdownMenu && (\n                    <Box space=\"xxs\" bSpace=\"zero\">\n                      <StyledDropdownMenuContainer isMobile={isMobile}>\n                        <DropdownMenu\n                          iconName=\"more-horizontal\"\n                          menuItems={dropdownMenuOptions}\n                          onMenuOpen={onDropdownClick}\n                          portalContainer={portalContainer}\n                          size=\"s\"\n                        />\n                      </StyledDropdownMenuContainer>\n                    </Box>\n                  )}\n                </Inline>\n              </Column>\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AAkFqB"} */"),StyledTitle=(0,_styled.default)("div",{target:"ecnjjdi4",label:"StyledTitle"})(({theme})=>({display:"flex",flexDirection:"column",height:theme.variables.size.spacing.xxl,justifyContent:"flex-end"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/CatalogCard/CatalogCard.tsx","sources":["src/components/CatalogCard/CatalogCard.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Container, type ContainerProps } from \"../Container/Container\";\nimport { DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\nconst StyledDropdownMenuContainer = styled.div<{ isMobile: boolean }>(\n  ({ isMobile, theme }) => ({\n    marginRight: `-${theme.variables.size.spacing.xs}`,\n    marginTop: `-${theme.variables.size.spacing.xs}`,\n    pointerEvents: \"auto\",\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  })\n);\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  // <Container/>\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  \"&:focus-within\": {\n    \"> div\": {\n      outlineWidth: 2,\n      outlineStyle: \"solid\",\n      outlineColor: \"Highlight\",\n      outlineOffset: -1,\n      borderRadius: theme.variables.size.borderRadius.s,\n    },\n\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"&:focus-within > div\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"solid\",\n      borderRadius: theme.variables.size.borderRadius.s,\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      boxShadow: theme.values.elevation[2],\n    },\n  },\n}));\n\nconst StyledContainer = styled.div<{ isMobile: boolean }>(({ isMobile }) => ({\n  display: \"flex\",\n  minHeight: \"102px\",\n  cursor: \"pointer\",\n  position: \"relative\",\n  height: \"100%\",\n  alignItems: \"end\",\n\n  [`${StyledDropdownMenuContainer}`]: {\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  },\n\n  \"> div\": {\n    width: \"100%\",\n  },\n\n  \"&:hover\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n}));\n\nconst StyledButton = styled.button({\n  position: \"absolute\",\n  top: 0,\n  left: 0,\n  width: \"1px\",\n  height: \"1px\",\n  opacity: 0,\n  border: \"none\",\n});\n\nconst StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\ntype DropdownMenuOption = {\n  label: string;\n  onSelect: (ev: React.MouseEvent) => void;\n};\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  dropdownMenuOptions?: DropdownMenuOption[];\n  portalContainer?: PortalProps[\"portalContainer\"];\n  onClick?: VoidFunction;\n  onDropdownClick?: (ev: MouseEvent | KeyboardEvent) => void;\n  topLeftElement?: React.ReactNode;\n};\n\nexport function CatalogCard({\n  title,\n  subtitle,\n  dropdownMenuOptions = [],\n  onClick,\n  onDropdownClick,\n  topLeftElement,\n  portalContainer,\n  borderRadius = \"s\",\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.medium.value;\n  const canShowDropdownMenu = dropdownMenuOptions?.length > 0;\n\n  const leftColumnSize = canShowDropdownMenu ? 10 : 12;\n  const rightColumnSize = canShowDropdownMenu ? 2 : \"auto\";\n\n  return (\n    <StyledWrapper>\n      <StyledButton onClick={onClick} aria-label={title} />\n      <Container\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id={dataDsId}\n        borderRadius={borderRadius}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size={leftColumnSize}>\n                {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n                <div onClick={onClick}>\n                  <Stack vAlignItems=\"spaceBetween\" space=\"s\">\n                    {topLeftElement}\n                    <Stack space=\"xxs\" vAlignItems=\"bottom\">\n                      <StyledTitle>\n                        <TextClamped size=\"m\" weight=\"bold\" lines={2}>\n                          {title}\n                        </TextClamped>\n                      </StyledTitle>\n                      {subtitle && (\n                        <TextClamped size=\"s\" color=\"tertiary\">\n                          {subtitle}\n                        </TextClamped>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              <Column size={rightColumnSize}>\n                <Inline alignItems=\"right\">\n                  {canShowDropdownMenu && (\n                    <Box space=\"xxs\" bSpace=\"zero\">\n                      <StyledDropdownMenuContainer isMobile={isMobile}>\n                        <DropdownMenu\n                          iconName=\"more-horizontal\"\n                          menuItems={dropdownMenuOptions}\n                          onMenuOpen={onDropdownClick}\n                          portalContainer={portalContainer}\n                          size=\"s\"\n                        />\n                      </StyledDropdownMenuContainer>\n                    </Box>\n                  )}\n                </Inline>\n              </Column>\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AA4FoB"} */");function CatalogCard({title,subtitle,dropdownMenuOptions=[],onClick,onDropdownClick,topLeftElement,portalContainer,borderRadius="s","data-e2e-test-id":dataE2eTestId="CatalogCard","data-ds-id":dataDsId="CatalogCard"}){let isMobile=!!window&&window.innerWidth<=_breakpointsjson.default.medium.value,canShowDropdownMenu=dropdownMenuOptions?.length>0;return _react.default.createElement(StyledWrapper,null,_react.default.createElement(StyledButton,{onClick:onClick,"aria-label":title}),_react.default.createElement(_Container.Container,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId,borderRadius:borderRadius},_react.default.createElement(StyledContainer,{isMobile:isMobile},_react.default.createElement(_Box.Box,{space:"m"},_react.default.createElement(_Columns.Columns,null,_react.default.createElement(_Columns.Column,{size:canShowDropdownMenu?10:12},_react.default.createElement("div",{onClick:onClick},_react.default.createElement(_Stack.Stack,{vAlignItems:"spaceBetween",space:"s"},topLeftElement,_react.default.createElement(_Stack.Stack,{space:"xxs",vAlignItems:"bottom"},_react.default.createElement(StyledTitle,null,_react.default.createElement(_TextClamped.TextClamped,{size:"m",weight:"bold",lines:2},title)),subtitle&&_react.default.createElement(_TextClamped.TextClamped,{size:"s",color:"tertiary"},subtitle))))),_react.default.createElement(_Columns.Column,{size:canShowDropdownMenu?2:"auto"},_react.default.createElement(_Inline.Inline,{alignItems:"right"},canShowDropdownMenu&&_react.default.createElement(_Box.Box,{space:"xxs",bSpace:"zero"},_react.default.createElement(StyledDropdownMenuContainer,{isMobile:isMobile},_react.default.createElement(_DropdownMenu.DropdownMenu,{iconName:"more-horizontal",menuItems:dropdownMenuOptions,onMenuOpen:onDropdownClick,portalContainer:portalContainer,size:"s"}))))))))))}
@@ -1,7 +1,6 @@
1
- import React from "react";
1
+ import React, { type PropsWithChildren } from "react";
2
2
  import type { MQ, HorizontalAlignment, SpaceSizes, VerticalAlignment, ColumnSizes, ColumnAlignment, Order } from "../../types";
3
- export type ColumnsProps = {
4
- children: React.ReactNode[] | React.ReactNode;
3
+ export type ColumnsProps = PropsWithChildren<{
5
4
  /** represents the size of both horizontal and vertical gap between children, can be a single string or an array of 3 strings
6
5
  * specify [small screen gap size, medium screen gap size, large screen gap size] to apply different gap sizes for different screen sizes
7
6
  */
@@ -20,9 +19,8 @@ export type ColumnsProps = {
20
19
  "data-e2e-test-id"?: string;
21
20
  /** @ignore */
22
21
  "data-ds-id"?: string;
23
- };
24
- export type ColumnProps = {
25
- children: React.ReactNode[] | React.ReactNode;
22
+ }> & React.HTMLAttributes<HTMLDivElement>;
23
+ export type ColumnProps = PropsWithChildren<{
26
24
  /** represents the size of the column, can be a single number or an array of 3 numbers with a value ranging from 1 to 12
27
25
  * specify [small screen column size, medium screen column size, large screen column size] to apply different values for different screen sizes
28
26
  */
@@ -36,6 +34,6 @@ export type ColumnProps = {
36
34
  "data-e2e-test-id"?: string;
37
35
  /** @ignore */
38
36
  "data-ds-id"?: string;
39
- };
37
+ }> & React.HTMLAttributes<HTMLDivElement>;
40
38
  export declare const Column: ({ children, size, order, alignSelf, show, "data-e2e-test-id": dataE2eTestId, "data-ds-id": dataDsId, ...rest }: ColumnProps) => React.ReactElement;
41
39
  export declare const Columns: ({ children, gap, alwaysFillSpace, alignItems, vAlignItems, "data-e2e-test-id": dataE2eTestId, "data-ds-id": dataDsId, ...rest }: ColumnsProps) => React.ReactElement;