@apify/ui-library 1.98.3 → 1.99.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (51) hide show
  1. package/dist/src/components/button.d.ts +6 -2
  2. package/dist/src/components/button.d.ts.map +1 -1
  3. package/dist/src/components/button.js +35 -8
  4. package/dist/src/components/button.js.map +1 -1
  5. package/dist/src/components/button.stories.d.ts +6 -0
  6. package/dist/src/components/button.stories.d.ts.map +1 -0
  7. package/dist/src/components/button.stories.js +46 -0
  8. package/dist/src/components/button.stories.js.map +1 -0
  9. package/dist/src/components/code/one_light_theme.d.ts +3 -0
  10. package/dist/src/components/code/one_light_theme.d.ts.map +1 -0
  11. package/dist/src/components/code/one_light_theme.js +108 -0
  12. package/dist/src/components/code/one_light_theme.js.map +1 -0
  13. package/dist/src/components/code/prism_highlighter.d.ts.map +1 -1
  14. package/dist/src/components/code/prism_highlighter.js +4 -3
  15. package/dist/src/components/code/prism_highlighter.js.map +1 -1
  16. package/dist/src/components/code/prism_python.d.ts +1 -0
  17. package/dist/src/components/code/prism_python.d.ts.map +1 -0
  18. package/dist/src/components/code/prism_python.js +76 -0
  19. package/dist/src/components/code/prism_python.js.map +1 -0
  20. package/dist/src/components/icon_button.d.ts +55 -0
  21. package/dist/src/components/icon_button.d.ts.map +1 -0
  22. package/dist/src/components/icon_button.js +134 -0
  23. package/dist/src/components/icon_button.js.map +1 -0
  24. package/dist/src/components/icon_button.stories.d.ts +36 -0
  25. package/dist/src/components/icon_button.stories.d.ts.map +1 -0
  26. package/dist/src/components/icon_button.stories.js +59 -0
  27. package/dist/src/components/icon_button.stories.js.map +1 -0
  28. package/dist/src/components/index.d.ts +2 -0
  29. package/dist/src/components/index.d.ts.map +1 -1
  30. package/dist/src/components/index.js +2 -0
  31. package/dist/src/components/index.js.map +1 -1
  32. package/dist/src/components/spinner.d.ts +32 -0
  33. package/dist/src/components/spinner.d.ts.map +1 -0
  34. package/dist/src/components/spinner.js +84 -0
  35. package/dist/src/components/spinner.js.map +1 -0
  36. package/dist/src/components/spinner.stories.d.ts +8 -0
  37. package/dist/src/components/spinner.stories.d.ts.map +1 -0
  38. package/dist/src/components/spinner.stories.js +24 -0
  39. package/dist/src/components/spinner.stories.js.map +1 -0
  40. package/dist/tsconfig.build.tsbuildinfo +1 -1
  41. package/package.json +2 -2
  42. package/src/components/{button.stories.jsx → button.stories.tsx} +26 -11
  43. package/src/components/button.tsx +43 -11
  44. package/src/components/code/one_light_theme.ts +110 -0
  45. package/src/components/code/prism_highlighter.tsx +4 -3
  46. package/src/components/code/prism_python.ts +76 -0
  47. package/src/components/icon_button.stories.tsx +251 -0
  48. package/src/components/icon_button.tsx +211 -0
  49. package/src/components/index.ts +2 -0
  50. package/src/components/spinner.stories.tsx +37 -0
  51. package/src/components/spinner.tsx +116 -0
@@ -0,0 +1,134 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { forwardRef } from 'react';
3
+ import styled, { css } from 'styled-components';
4
+ import { theme } from '../design_system/theme.js';
5
+ import { Button, BUTTON_SIZE_VARIANTS_CSS } from './button.js';
6
+ import { Tooltip } from './floating/tooltip.js';
7
+ import { Link } from './link.js';
8
+ import { InlineSpinner, spinnerClassNames } from './spinner.js';
9
+ export const ICON_BUTTON_VARIANTS = {
10
+ DEFAULT: 'DEFAULT',
11
+ BORDERED: 'BORDERED',
12
+ DANGER: 'DANGER',
13
+ DANGER_BORDERED: 'DANGER_BORDERED',
14
+ };
15
+ const iconButtonVariantStyle = {
16
+ [ICON_BUTTON_VARIANTS.DEFAULT]: {
17
+ backgroundColor: 'transparent',
18
+ backgroundHoverColor: theme.color.neutral.hover,
19
+ backgroundDisabledColor: 'transparent',
20
+ borderColor: 'transparent',
21
+ borderHoverColor: 'transparent',
22
+ borderDisabledColor: 'transparent',
23
+ iconColor: theme.color.neutral.text,
24
+ },
25
+ [ICON_BUTTON_VARIANTS.BORDERED]: {
26
+ backgroundColor: theme.color.neutral.backgroundMuted,
27
+ backgroundHoverColor: theme.color.neutral.hover,
28
+ backgroundDisabledColor: theme.color.neutral.disabled,
29
+ borderColor: theme.color.neutral.border,
30
+ borderHoverColor: theme.color.neutral.border,
31
+ borderDisabledColor: theme.color.neutral.border,
32
+ iconColor: theme.color.neutral.text,
33
+ },
34
+ [ICON_BUTTON_VARIANTS.DANGER_BORDERED]: {
35
+ backgroundColor: theme.color.neutral.backgroundMuted,
36
+ backgroundHoverColor: theme.color.danger.backgroundHover,
37
+ backgroundDisabledColor: theme.color.neutral.backgroundSubtle,
38
+ borderColor: theme.color.neutral.border,
39
+ borderHoverColor: theme.color.danger.borderSubtle,
40
+ borderDisabledColor: theme.color.neutral.border,
41
+ iconColor: theme.color.danger.text,
42
+ },
43
+ [ICON_BUTTON_VARIANTS.DANGER]: {
44
+ backgroundColor: 'transparent',
45
+ backgroundHoverColor: theme.color.danger.backgroundHover,
46
+ backgroundDisabledColor: theme.color.neutral.backgroundSubtle,
47
+ borderColor: 'transparent',
48
+ borderHoverColor: 'transparent',
49
+ borderDisabledColor: 'transparent',
50
+ iconColor: theme.color.danger.text,
51
+ },
52
+ };
53
+ const iconButtonSizeConfig = {
54
+ extraLarge: {
55
+ iconSize: '24',
56
+ spinnerSize: '2.4rem',
57
+ },
58
+ large: {
59
+ iconSize: '20',
60
+ spinnerSize: '2rem',
61
+ },
62
+ medium: {
63
+ iconSize: '16',
64
+ spinnerSize: '1.6rem',
65
+ },
66
+ small: {
67
+ iconSize: '16',
68
+ spinnerSize: '1.6rem',
69
+ },
70
+ extraSmall: {
71
+ iconSize: '12',
72
+ spinnerSize: '1.2rem',
73
+ },
74
+ };
75
+ const getIconButtonColorStyles = (variant) => {
76
+ const { backgroundColor, backgroundHoverColor, backgroundDisabledColor, borderDisabledColor, borderColor, borderHoverColor, iconColor, } = iconButtonVariantStyle[variant];
77
+ return css `
78
+ color: ${iconColor};
79
+ background-color: ${backgroundColor};
80
+ border-color: ${borderColor};
81
+
82
+ &:hover {
83
+ background-color: ${backgroundHoverColor};
84
+ border-color: ${borderHoverColor || borderColor};
85
+ color: ${iconColor};
86
+ }
87
+
88
+ &:focus {
89
+ border-color: ${theme.color.primary.fieldBorderActive};
90
+ }
91
+
92
+ &:active {
93
+ background-color: ${theme.color.neutral.actionSecondaryActive};
94
+ border-color: ${theme.color.neutral.actionSecondaryActive};
95
+ }
96
+
97
+ &:disabled {
98
+ color: ${theme.color.neutral.iconDisabled};
99
+ background-color: ${backgroundDisabledColor};
100
+ border-color: ${borderDisabledColor};
101
+
102
+ cursor: default;
103
+ }
104
+ `;
105
+ };
106
+ const StyledButton = styled(Button) `
107
+ ${({ $variant }) => getIconButtonColorStyles($variant)}
108
+
109
+ /* Override default button styles */
110
+ box-sizing: border-box;
111
+ width: ${({ $size }) => (BUTTON_SIZE_VARIANTS_CSS[$size].size)}px;
112
+ padding: 0;
113
+
114
+ .${spinnerClassNames.SPINNER} .path {
115
+ stroke: ${theme.color.neutral.icon};
116
+ }
117
+ `;
118
+ /**
119
+ * Simplified button component that displays an icon.
120
+ * Has a tooltip and a loading state.
121
+ */
122
+ export const IconButton = forwardRef(({ variant = ICON_BUTTON_VARIANTS.DEFAULT, size = 'medium', as = 'button', title, disabled = false, isLoading = false, Icon, tooltipProps, ...passThroughProps }, ref) => {
123
+ const otherProps = { ...passThroughProps, size };
124
+ const component = as === 'a' ? Link : as;
125
+ const { iconSize, spinnerSize } = iconButtonSizeConfig[size];
126
+ const button = (_jsx(StyledButton, { forwardedAs: component, ref: ref, disabled: disabled || isLoading, type: 'button', "aria-label": title, LeftIcon: isLoading ? () => _jsx(InlineSpinner, { size: spinnerSize }) : () => _jsx(Icon, { size: iconSize }),
127
+ // We apply our own styles to the button, so we need to override the default variant
128
+ variant: "tertiary", "$size": size, "$variant": variant, ...otherProps }));
129
+ return title ? (
130
+ // @ts-expect-error tooltip is not migrated to TS yet
131
+ _jsx(Tooltip, { content: title, ...tooltipProps, children: button })) : button;
132
+ });
133
+ IconButton.displayName = 'IconButton';
134
+ //# sourceMappingURL=icon_button.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"icon_button.js","sourceRoot":"","sources":["../../../src/components/icon_button.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,36 @@
1
+ import type { Meta } from '@storybook/react-vite';
2
+ import { IconButton, type IconButtonProps } from './icon_button.js';
3
+ declare const _default: Meta<typeof IconButton>;
4
+ export default _default;
5
+ export declare const Default: (props: IconButtonProps<"button">) => import("react/jsx-runtime").JSX.Element;
6
+ export declare const Playground: {
7
+ (props: IconButtonProps<"button">): import("react/jsx-runtime").JSX.Element;
8
+ args: {
9
+ variant: "DEFAULT";
10
+ size: string;
11
+ disabled: boolean;
12
+ isLoading: boolean;
13
+ };
14
+ argTypes: {
15
+ variant: {
16
+ options: {
17
+ readonly DEFAULT: "DEFAULT";
18
+ readonly BORDERED: "BORDERED";
19
+ readonly DANGER: "DANGER";
20
+ readonly DANGER_BORDERED: "DANGER_BORDERED";
21
+ };
22
+ control: string;
23
+ };
24
+ size: {
25
+ options: string[];
26
+ control: string;
27
+ };
28
+ disabled: {
29
+ control: string;
30
+ };
31
+ isLoading: {
32
+ control: string;
33
+ };
34
+ };
35
+ };
36
+ //# sourceMappingURL=icon_button.stories.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"icon_button.stories.d.ts","sourceRoot":"","sources":["../../../src/components/icon_button.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,uBAAuB,CAAC;AAUlD,OAAO,EAEH,UAAU,EACV,KAAK,eAAe,EACvB,MAAM,kBAAkB,CAAC;wBAcrB,IAAI,CAAC,OAAO,UAAU,CAAC;AAZ5B,wBAY6B;AAS7B,eAAO,MAAM,OAAO,UAAW,eAAe,CAAC,QAAQ,CAAC,4CAsKvD,CAAC;AAQF,eAAO,MAAM,UAAU;YAAW,eAAe,CAAC,QAAQ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAe1D,CAAC"}
@@ -0,0 +1,59 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ // eslint-disable-next-line import/extensions
3
+ import { action } from 'storybook/actions';
4
+ import styled from 'styled-components';
5
+ import { BellIcon, DeleteIcon, PeopleIcon, } from '@apify/ui-icons';
6
+ import { ICON_BUTTON_VARIANTS, IconButton, } from './icon_button.js';
7
+ export default {
8
+ title: 'UI-Library/IconButton',
9
+ component: IconButton,
10
+ args: {
11
+ onClick: action('onClick'),
12
+ },
13
+ parameters: {
14
+ design: {
15
+ type: 'figma',
16
+ url: 'https://www.figma.com/design/duSsGnk84UMYav8mg8QNgR/%F0%9F%93%96-Shared-library?node-id=5236-40552&t=fCZgSCLJK79g0Omo-4',
17
+ },
18
+ },
19
+ };
20
+ const Table = styled.table `
21
+ td {
22
+ padding: 8px;
23
+ }
24
+ margin-bottom: 32px;
25
+ `;
26
+ export const Default = (props) => {
27
+ return (_jsx(_Fragment, { children: _jsx(Table, { children: _jsx("tbody", { children: Object.values(ICON_BUTTON_VARIANTS).map((variant) => (_jsxs("tr", { children: [_jsx("td", { children: _jsx(IconButton, { ...props, variant: variant, Icon: DeleteIcon, size: 'extraLarge', title: 'Delete example' }) }), _jsx("td", { children: _jsx(IconButton, { ...props, variant: variant, Icon: DeleteIcon, size: 'large', title: 'Delete example' }) }), _jsx("td", { children: _jsx(IconButton, { ...props, variant: variant, Icon: DeleteIcon, size: 'medium', title: 'Delete example' }) }), _jsx("td", { children: _jsx(IconButton, { ...props, variant: variant, Icon: DeleteIcon, size: 'small', title: 'Delete example' }) }), _jsx("td", { children: _jsx(IconButton, { ...props, variant: variant, Icon: DeleteIcon, size: 'extraSmall', title: 'Delete example' }) }), _jsx("td", { children: _jsx(IconButton, { ...props, variant: variant, Icon: DeleteIcon, disabled: true, size: 'extraLarge', title: 'Disabled delete example' }) }), _jsx("td", { children: _jsx(IconButton, { ...props, variant: variant, Icon: DeleteIcon, disabled: true, size: 'large', title: 'Disabled delete example' }) }), _jsx("td", { children: _jsx(IconButton, { ...props, variant: variant, Icon: DeleteIcon, disabled: true, size: 'medium', title: 'Disabled delete example' }) }), _jsx("td", { children: _jsx(IconButton, { ...props, variant: variant, Icon: DeleteIcon, disabled: true, size: 'small', title: 'Disabled delete example' }) }), _jsx("td", { children: _jsx(IconButton, { ...props, variant: variant, Icon: DeleteIcon, disabled: true, size: 'extraSmall', title: 'Disabled delete example' }) }), _jsx("td", { children: _jsx(IconButton, { ...props, variant: variant, Icon: DeleteIcon, isLoading: true, size: 'extraLarge', title: 'Loading delete example' }) }), _jsx("td", { children: _jsx(IconButton, { ...props, variant: variant, Icon: DeleteIcon, isLoading: true, size: 'extraLarge', title: 'Loading delete example' }) }), _jsx("td", { children: _jsx(IconButton, { ...props, variant: variant, Icon: DeleteIcon, isLoading: true, size: 'large', title: 'Loading delete example' }) }), _jsx("td", { children: _jsx(IconButton, { ...props, variant: variant, Icon: DeleteIcon, isLoading: true, size: 'medium', title: 'Loading delete example' }) }), _jsx("td", { children: _jsx(IconButton, { ...props, variant: variant, Icon: DeleteIcon, isLoading: true, size: 'small', title: 'Loading delete example' }) }), _jsx("td", { children: _jsx(IconButton, { ...props, variant: variant, Icon: DeleteIcon, isLoading: true, size: 'extraSmall', title: 'Loading delete example' }) })] }, variant))) }) }) }));
28
+ };
29
+ const StyledPlayground = styled.div `
30
+ display: flex;
31
+ flex-direction: row;
32
+ gap: 8px;
33
+ `;
34
+ export const Playground = (props) => {
35
+ return (_jsxs(StyledPlayground, { children: [_jsx(IconButton, { ...props, Icon: PeopleIcon }), _jsx(IconButton, { ...props, Icon: DeleteIcon }), _jsx(IconButton, { ...props, Icon: BellIcon })] }));
36
+ };
37
+ Playground.args = {
38
+ variant: ICON_BUTTON_VARIANTS.DEFAULT,
39
+ size: 'medium',
40
+ disabled: false,
41
+ isLoading: false,
42
+ };
43
+ Playground.argTypes = {
44
+ variant: {
45
+ options: ICON_BUTTON_VARIANTS,
46
+ control: 'select',
47
+ },
48
+ size: {
49
+ options: ['medium', 'small'],
50
+ control: 'select',
51
+ },
52
+ disabled: {
53
+ control: 'boolean',
54
+ },
55
+ isLoading: {
56
+ control: 'boolean',
57
+ },
58
+ };
59
+ //# sourceMappingURL=icon_button.stories.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"icon_button.stories.js","sourceRoot":"","sources":["../../../src/components/icon_button.stories.tsx"],"names":[],"mappings":"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"}
@@ -21,4 +21,6 @@ export * from './badge.js';
21
21
  export * from './tag.js';
22
22
  export * from './tabs/index.js';
23
23
  export * from './shortcut.js';
24
+ export * from './icon_button.js';
25
+ export * from './spinner.js';
24
26
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAC;AAChC,cAAc,UAAU,CAAC;AACzB,cAAc,cAAc,CAAC;AAC7B,cAAc,qBAAqB,CAAC;AACpC,cAAc,aAAa,CAAC;AAC5B,cAAc,WAAW,CAAC;AAC1B,cAAc,kBAAkB,CAAC;AACjC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,iBAAiB,CAAC;AAChC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,4BAA4B,CAAC;AAC3C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,iBAAiB,CAAC;AAChC,cAAc,mBAAmB,CAAC;AAClC,cAAc,aAAa,CAAC;AAC5B,cAAc,0BAA0B,CAAC;AACzC,cAAc,WAAW,CAAC;AAC1B,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,YAAY,CAAC;AAC3B,cAAc,UAAU,CAAC;AACzB,cAAc,iBAAiB,CAAC;AAChC,cAAc,eAAe,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAC;AAChC,cAAc,UAAU,CAAC;AACzB,cAAc,cAAc,CAAC;AAC7B,cAAc,qBAAqB,CAAC;AACpC,cAAc,aAAa,CAAC;AAC5B,cAAc,WAAW,CAAC;AAC1B,cAAc,kBAAkB,CAAC;AACjC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,iBAAiB,CAAC;AAChC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,4BAA4B,CAAC;AAC3C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,iBAAiB,CAAC;AAChC,cAAc,mBAAmB,CAAC;AAClC,cAAc,aAAa,CAAC;AAC5B,cAAc,0BAA0B,CAAC;AACzC,cAAc,WAAW,CAAC;AAC1B,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,YAAY,CAAC;AAC3B,cAAc,UAAU,CAAC;AACzB,cAAc,iBAAiB,CAAC;AAChC,cAAc,eAAe,CAAC;AAC9B,cAAc,kBAAkB,CAAC;AACjC,cAAc,cAAc,CAAC"}
@@ -21,4 +21,6 @@ export * from './badge.js';
21
21
  export * from './tag.js';
22
22
  export * from './tabs/index.js';
23
23
  export * from './shortcut.js';
24
+ export * from './icon_button.js';
25
+ export * from './spinner.js';
24
26
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAC;AAChC,cAAc,UAAU,CAAC;AACzB,cAAc,cAAc,CAAC;AAC7B,cAAc,qBAAqB,CAAC;AACpC,cAAc,aAAa,CAAC;AAC5B,cAAc,WAAW,CAAC;AAC1B,cAAc,kBAAkB,CAAC;AACjC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,iBAAiB,CAAC;AAChC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,4BAA4B,CAAC;AAC3C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,iBAAiB,CAAC;AAChC,cAAc,mBAAmB,CAAC;AAClC,cAAc,aAAa,CAAC;AAC5B,cAAc,0BAA0B,CAAC;AACzC,cAAc,WAAW,CAAC;AAC1B,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,YAAY,CAAC;AAC3B,cAAc,UAAU,CAAC;AACzB,cAAc,iBAAiB,CAAC;AAChC,cAAc,eAAe,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAC;AAChC,cAAc,UAAU,CAAC;AACzB,cAAc,cAAc,CAAC;AAC7B,cAAc,qBAAqB,CAAC;AACpC,cAAc,aAAa,CAAC;AAC5B,cAAc,WAAW,CAAC;AAC1B,cAAc,kBAAkB,CAAC;AACjC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,iBAAiB,CAAC;AAChC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,4BAA4B,CAAC;AAC3C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,iBAAiB,CAAC;AAChC,cAAc,mBAAmB,CAAC;AAClC,cAAc,aAAa,CAAC;AAC5B,cAAc,0BAA0B,CAAC;AACzC,cAAc,WAAW,CAAC;AAC1B,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,YAAY,CAAC;AAC3B,cAAc,UAAU,CAAC;AACzB,cAAc,iBAAiB,CAAC;AAChC,cAAc,eAAe,CAAC;AAC9B,cAAc,kBAAkB,CAAC;AACjC,cAAc,cAAc,CAAC"}
@@ -0,0 +1,32 @@
1
+ export declare const spinnerClassNames: {
2
+ SPINNER: string;
3
+ };
4
+ export type SpinnerProps = {
5
+ id?: string;
6
+ as?: React.ElementType;
7
+ className?: string;
8
+ style?: React.CSSProperties;
9
+ small?: boolean;
10
+ loadingReason?: string;
11
+ };
12
+ /**
13
+ * Visualize loading state of a component.
14
+ *
15
+ * Use this spinner when a page or section is waiting for asynchronous data.
16
+ * Do not use it for buttons and small components, apply only for bigger sections.
17
+ *
18
+ * Keep the spinner centered (eg. by setting position to parent container).
19
+ */
20
+ export declare const Spinner: ({ loadingReason, small, ...props }: SpinnerProps) => import("react/jsx-runtime").JSX.Element;
21
+ /**
22
+ * Spinner with basic block styling
23
+ * This styles should probably be in default spinner, but it's dangerous to modify it as it's used on so many places
24
+ */
25
+ export declare const BlockSpinner: import("styled-components").StyledComponent<({ loadingReason, small, ...props }: SpinnerProps) => import("react/jsx-runtime").JSX.Element, any, {}, never>;
26
+ /**
27
+ * Use the inline variant within buttons, texts etc. The color of the spinner is set to current color of text.
28
+ */
29
+ export declare const InlineSpinner: import("styled-components").StyledComponent<({ loadingReason, small, ...props }: SpinnerProps) => import("react/jsx-runtime").JSX.Element, any, {
30
+ size?: string;
31
+ }, never>;
32
+ //# sourceMappingURL=spinner.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spinner.d.ts","sourceRoot":"","sources":["../../../src/components/spinner.tsx"],"names":[],"mappings":"AAKA,eAAO,MAAM,iBAAiB;;CAE7B,CAAC;AAuBF,MAAM,MAAM,YAAY,GAAG;IACvB,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,EAAE,CAAC,EAAE,KAAK,CAAC,WAAW,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;IAC5B,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,aAAa,CAAC,EAAE,MAAM,CAAC;CAC1B,CAAC;AA4BF;;;;;;;GAOG;AACH,eAAO,MAAM,OAAO,uCAAwC,YAAY,4CAgBvE,CAAC;AAEF;;;GAGG;AACH,eAAO,MAAM,YAAY,mFAtBmC,YAAY,6DA0BvE,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,aAAa,mFA/BkC,YAAY;WA+BnB,MAAM;SAW1D,CAAC"}
@@ -0,0 +1,84 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import styled, { keyframes } from 'styled-components';
3
+ import { theme } from '../design_system/theme.js';
4
+ export const spinnerClassNames = {
5
+ SPINNER: 'spinner',
6
+ };
7
+ const rotate = keyframes `
8
+ 100% {
9
+ transform: rotate(360deg);
10
+ }
11
+ `;
12
+ const dash = keyframes `
13
+ 0% {
14
+ stroke-dasharray: 1, 150;
15
+ stroke-dashoffset: 0;
16
+ }
17
+ 50% {
18
+ stroke-dasharray: 90, 150;
19
+ stroke-dashoffset: -35;
20
+ }
21
+ 100% {
22
+ stroke-dasharray: 90, 150;
23
+ stroke-dashoffset: -124;
24
+ }
25
+ `;
26
+ // styled-components used in order to make 'as' prop work by default
27
+ // span is intentional instead of div, so it can be validly nested in a <p>
28
+ // display: block is used because it was div before and we don't wanna break anything
29
+ const SpinnerWrapper = styled.span `
30
+ display: block;
31
+
32
+ .${spinnerClassNames.SPINNER} {
33
+ position: absolute;
34
+ top: 50%;
35
+ left: 50%;
36
+ transform: translate(-50%, -50%);
37
+ z-index: 2;
38
+
39
+ width: ${({ $small }) => ($small ? '3rem' : '5rem')};
40
+ height: ${({ $small }) => ($small ? '3rem' : '5rem')};
41
+
42
+ & .path {
43
+ transform-origin: center;
44
+ stroke: ${theme.color.primary.text};
45
+ animation: ${dash} 1.5s ease-in-out infinite, ${rotate} 2s linear infinite;
46
+ }
47
+ }
48
+ `;
49
+ /**
50
+ * Visualize loading state of a component.
51
+ *
52
+ * Use this spinner when a page or section is waiting for asynchronous data.
53
+ * Do not use it for buttons and small components, apply only for bigger sections.
54
+ *
55
+ * Keep the spinner centered (eg. by setting position to parent container).
56
+ */
57
+ export const Spinner = ({ loadingReason, small, ...props }) => {
58
+ return (_jsx(SpinnerWrapper, { ...props, title: loadingReason, "$small": small, children: _jsx("svg", { className: spinnerClassNames.SPINNER, viewBox: "0 0 50 50", children: _jsx("circle", { className: "path", cx: "25", cy: "25", r: "20", fill: "none", strokeWidth: "5", strokeLinecap: "round" }) }) }));
59
+ };
60
+ /**
61
+ * Spinner with basic block styling
62
+ * This styles should probably be in default spinner, but it's dangerous to modify it as it's used on so many places
63
+ */
64
+ export const BlockSpinner = styled(Spinner) `
65
+ position: relative; /* "hold" absolutely positioned spinner */
66
+ width: 100%;
67
+ min-height: 8rem;
68
+ `;
69
+ /**
70
+ * Use the inline variant within buttons, texts etc. The color of the spinner is set to current color of text.
71
+ */
72
+ export const InlineSpinner = styled(Spinner) `
73
+ display: inline-block;
74
+ position: relative;
75
+ height: ${({ size }) => size || theme.space.space12};
76
+ width: ${({ size }) => size || theme.space.space12};
77
+ vertical-align: middle;
78
+
79
+ .${spinnerClassNames.SPINNER} {
80
+ width: 100%;
81
+ height: 100%;
82
+ }
83
+ `;
84
+ //# sourceMappingURL=spinner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spinner.js","sourceRoot":"","sources":["../../../src/components/spinner.tsx"],"names":[],"mappings":";AAAA,OAAO,MAAM,EAAE,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAEtD,OAAO,EAAE,KAAK,EAAE,MAAM,2BAA2B,CAAC;AAGlD,MAAM,CAAC,MAAM,iBAAiB,GAAG;IAC7B,OAAO,EAAE,SAAS;CACrB,CAAC;AAEF,MAAM,MAAM,GAAG,SAAS,CAAA;;;;CAIvB,CAAC;AAEF,MAAM,IAAI,GAAG,SAAS,CAAA;;;;;;;;;;;;;CAarB,CAAC;AAaF,oEAAoE;AACpE,2EAA2E;AAC3E,qFAAqF;AACrF,MAAM,cAAc,GAAG,MAAM,CAAC,IAAI,CAAqB;;;OAGhD,iBAAiB,CAAC,OAAO;;;;;;;iBAOf,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;kBACzC,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;;;;sBAItC,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI;yBACrB,IAAI,+BAA+B,MAAM;;;CAGjE,CAAC;AAEF;;;;;;;GAOG;AACH,MAAM,CAAC,MAAM,OAAO,GAAG,CAAC,EAAE,aAAa,EAAE,KAAK,EAAE,GAAG,KAAK,EAAgB,EAAE,EAAE;IACxE,OAAO,CACH,KAAC,cAAc,OAAK,KAAK,EAAE,KAAK,EAAE,aAAa,YAAU,KAAK,YAC1D,cAAK,SAAS,EAAE,iBAAiB,CAAC,OAAO,EAAE,OAAO,EAAC,WAAW,YAC1D,iBACI,SAAS,EAAC,MAAM,EAChB,EAAE,EAAC,IAAI,EACP,EAAE,EAAC,IAAI,EACP,CAAC,EAAC,IAAI,EACN,IAAI,EAAC,MAAM,EACX,WAAW,EAAC,GAAG,EACf,aAAa,EAAC,OAAO,GACf,GACR,GACO,CACpB,CAAC;AACN,CAAC,CAAC;AAEF;;;GAGG;AACH,MAAM,CAAC,MAAM,YAAY,GAAG,MAAM,CAAC,OAAO,CAAC,CAAA;;;;CAI1C,CAAC;AAEF;;GAEG;AACH,MAAM,CAAC,MAAM,aAAa,GAAG,MAAM,CAAC,OAAO,CAAC,CAAiB;;;cAG/C,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,IAAI,KAAK,CAAC,KAAK,CAAC,OAAO;aAC1C,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,IAAI,KAAK,CAAC,KAAK,CAAC,OAAO;;;OAG/C,iBAAiB,CAAC,OAAO;;;;CAI/B,CAAC"}
@@ -0,0 +1,8 @@
1
+ import type { Meta } from '@storybook/react-vite';
2
+ import { Spinner, type SpinnerProps } from './spinner.js';
3
+ declare const _default: Meta<typeof Spinner>;
4
+ export default _default;
5
+ export declare const Standalone: (args: SpinnerProps) => import("react/jsx-runtime").JSX.Element;
6
+ export declare const WithinContainer: (args: SpinnerProps) => import("react/jsx-runtime").JSX.Element;
7
+ export declare const Inline: () => import("react/jsx-runtime").JSX.Element;
8
+ //# sourceMappingURL=spinner.stories.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spinner.stories.d.ts","sourceRoot":"","sources":["../../../src/components/spinner.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,uBAAuB,CAAC;AAElD,OAAO,EAAiB,OAAO,EAAE,KAAK,YAAY,EAAE,MAAM,cAAc,CAAC;wBAOpE,IAAI,CAAC,OAAO,OAAO,CAAC;AALzB,wBAK0B;AAI1B,eAAO,MAAM,UAAU,SAFC,YAAY,4CAEO,CAAC;AAE5C,eAAO,MAAM,eAAe,SAAU,YAAY,4CAYjD,CAAC;AAEF,eAAO,MAAM,MAAM,+CAOlB,CAAC"}
@@ -0,0 +1,24 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { InlineSpinner, Spinner } from './spinner.js';
3
+ export default {
4
+ title: 'UI-Library/Spinner',
5
+ parameters: { layout: 'padded' },
6
+ component: Spinner,
7
+ args: {},
8
+ };
9
+ const Template = (args) => _jsx(Spinner, { ...args });
10
+ export const Standalone = Template.bind({});
11
+ export const WithinContainer = (args) => {
12
+ return (_jsx("div", { style: {
13
+ minWidth: '100px',
14
+ minHeight: '200px',
15
+ border: 'solid 1px lightgray',
16
+ borderRadius: '1rem',
17
+ position: 'relative',
18
+ }, children: _jsx(Spinner, { ...args }) }));
19
+ };
20
+ export const Inline = () => {
21
+ const elements = ['h1', 'h2', 'h3', 'p'];
22
+ return (_jsx("div", { style: { width: '100%' }, children: elements.map((Element) => _jsxs(Element, { children: [Element, ": There was a ", _jsx(InlineSpinner, {}), " in New Orleans."] }, Element)) }));
23
+ };
24
+ //# sourceMappingURL=spinner.stories.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spinner.stories.js","sourceRoot":"","sources":["../../../src/components/spinner.stories.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,aAAa,EAAE,OAAO,EAAqB,MAAM,cAAc,CAAC;AAEzE,eAAe;IACX,KAAK,EAAE,oBAAoB;IAC3B,UAAU,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE;IAChC,SAAS,EAAE,OAAO;IAClB,IAAI,EAAE,EAAE;CACa,CAAC;AAE1B,MAAM,QAAQ,GAAG,CAAC,IAAkB,EAAE,EAAE,CAAC,KAAC,OAAO,OAAK,IAAI,GAAI,CAAC;AAE/D,MAAM,CAAC,MAAM,UAAU,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AAE5C,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,IAAkB,EAAE,EAAE;IAClD,OAAO,CACH,cAAK,KAAK,EAAE;YACR,QAAQ,EAAE,OAAO;YACjB,SAAS,EAAE,OAAO;YAClB,MAAM,EAAE,qBAAqB;YAC7B,YAAY,EAAE,MAAM;YACpB,QAAQ,EAAE,UAAU;SACvB,YACG,KAAC,OAAO,OAAK,IAAI,GAAI,GACnB,CACT,CAAC;AACN,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,EAAE;IACvB,MAAM,QAAQ,GAAwB,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,CAAC,CAAC;IAC9D,OAAO,CACH,cAAK,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,YACxB,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,MAAC,OAAO,eAAgB,OAAO,oBAAe,KAAC,aAAa,KAAG,yBAAjD,OAAO,CAAoE,CAAC,GACnH,CACT,CAAC;AACN,CAAC,CAAC"}