@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.
- package/dist/src/components/button.d.ts +6 -2
- package/dist/src/components/button.d.ts.map +1 -1
- package/dist/src/components/button.js +35 -8
- package/dist/src/components/button.js.map +1 -1
- package/dist/src/components/button.stories.d.ts +6 -0
- package/dist/src/components/button.stories.d.ts.map +1 -0
- package/dist/src/components/button.stories.js +46 -0
- package/dist/src/components/button.stories.js.map +1 -0
- package/dist/src/components/code/one_light_theme.d.ts +3 -0
- package/dist/src/components/code/one_light_theme.d.ts.map +1 -0
- package/dist/src/components/code/one_light_theme.js +108 -0
- package/dist/src/components/code/one_light_theme.js.map +1 -0
- package/dist/src/components/code/prism_highlighter.d.ts.map +1 -1
- package/dist/src/components/code/prism_highlighter.js +4 -3
- package/dist/src/components/code/prism_highlighter.js.map +1 -1
- package/dist/src/components/code/prism_python.d.ts +1 -0
- package/dist/src/components/code/prism_python.d.ts.map +1 -0
- package/dist/src/components/code/prism_python.js +76 -0
- package/dist/src/components/code/prism_python.js.map +1 -0
- package/dist/src/components/icon_button.d.ts +55 -0
- package/dist/src/components/icon_button.d.ts.map +1 -0
- package/dist/src/components/icon_button.js +134 -0
- package/dist/src/components/icon_button.js.map +1 -0
- package/dist/src/components/icon_button.stories.d.ts +36 -0
- package/dist/src/components/icon_button.stories.d.ts.map +1 -0
- package/dist/src/components/icon_button.stories.js +59 -0
- package/dist/src/components/icon_button.stories.js.map +1 -0
- package/dist/src/components/index.d.ts +2 -0
- package/dist/src/components/index.d.ts.map +1 -1
- package/dist/src/components/index.js +2 -0
- package/dist/src/components/index.js.map +1 -1
- package/dist/src/components/spinner.d.ts +32 -0
- package/dist/src/components/spinner.d.ts.map +1 -0
- package/dist/src/components/spinner.js +84 -0
- package/dist/src/components/spinner.js.map +1 -0
- package/dist/src/components/spinner.stories.d.ts +8 -0
- package/dist/src/components/spinner.stories.d.ts.map +1 -0
- package/dist/src/components/spinner.stories.js +24 -0
- package/dist/src/components/spinner.stories.js.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/package.json +2 -2
- package/src/components/{button.stories.jsx → button.stories.tsx} +26 -11
- package/src/components/button.tsx +43 -11
- package/src/components/code/one_light_theme.ts +110 -0
- package/src/components/code/prism_highlighter.tsx +4 -3
- package/src/components/code/prism_python.ts +76 -0
- package/src/components/icon_button.stories.tsx +251 -0
- package/src/components/icon_button.tsx +211 -0
- package/src/components/index.ts +2 -0
- package/src/components/spinner.stories.tsx +37 -0
- 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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"}
|
|
@@ -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"}
|
|
@@ -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"}
|