@itcase/ui-web 1.9.112 → 1.9.113
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/cjs/components/AvatarStack.js +1 -1
- package/dist/cjs/components/Dropzone.js +1 -1
- package/dist/components/AvatarStack.js +1 -1
- package/dist/components/Dropzone.js +1 -1
- package/dist/types/components/Avatar/stories/AvatarCount.stories.d.ts +4 -0
- package/dist/types/components/Avatar/stories/AvatarCount.stories.js +4 -0
- package/dist/types/components/Avatar/stories/AvatarDemo.stories.js +4 -0
- package/dist/types/components/Avatar/stories/AvatarImage.stories.d.ts +4 -0
- package/dist/types/components/Avatar/stories/AvatarImage.stories.js +4 -0
- package/dist/types/components/Avatar/stories/AvatarInteraction.stories.d.ts +4 -0
- package/dist/types/components/Avatar/stories/AvatarInteraction.stories.js +4 -0
- package/dist/types/components/Avatar/stories/AvatarLetters.stories.d.ts +4 -0
- package/dist/types/components/Avatar/stories/AvatarLetters.stories.js +4 -0
- package/dist/types/components/Avatar/stories/AvatarSkeleton.stories.d.ts +4 -0
- package/dist/types/components/Avatar/stories/AvatarSkeleton.stories.js +4 -0
- package/dist/types/components/AvatarStack/AvatarStack.interface.d.ts +6 -11
- package/dist/types/components/AvatarStack/AvatarStack.js +3 -13
- package/dist/types/components/AvatarStack/index.d.ts +1 -1
- package/dist/types/components/AvatarStack/stories/AvatarStackCount.stories.d.ts +12 -4
- package/dist/types/components/AvatarStack/stories/AvatarStackCount.stories.js +49 -13
- package/dist/types/components/AvatarStack/stories/AvatarStackDemo.stories.d.ts +6 -2
- package/dist/types/components/AvatarStack/stories/AvatarStackDemo.stories.js +7 -12
- package/dist/types/components/AvatarStack/stories/AvatarStackSize.stories.d.ts +9 -1
- package/dist/types/components/AvatarStack/stories/AvatarStackSize.stories.js +51 -37
- package/dist/types/components/AvatarStack/{__test__/AvatarStackTest.stories.d.ts → stories/AvatarStackSkeleton.stories.d.ts} +7 -2
- package/dist/types/components/AvatarStack/stories/AvatarStackSkeleton.stories.js +47 -0
- package/dist/types/components/AvatarStack/stories/__mock__/index.js +11 -5
- package/dist/types/components/Badge/stories/BadgeDotIconCounter.stories.d.ts +8 -9
- package/dist/types/components/Badge/stories/BadgeDotIconCounter.stories.js +33 -72
- package/dist/types/components/Divider/__test__/DividerTest.stories.js +3 -3
- package/dist/types/components/Dropzone/Dropzone.appearance.d.ts +1 -0
- package/dist/types/components/Dropzone/Dropzone.js +1 -1
- package/dist/types/components/Dropzone/appearance/dropzoneDefault.d.ts +1 -0
- package/dist/types/components/Dropzone/appearance/dropzoneDefault.js +1 -0
- package/dist/types/components/Dropzone/stories/DropzoneDemo.stories.d.ts +1 -0
- package/dist/types/components/Dropzone/stories/DropzoneDemo.stories.js +7 -0
- package/dist/types/components/Dropzone/stories/__mock__/index.d.ts +4 -0
- package/dist/types/components/Dropzone/stories/__mock__/index.js +19 -0
- package/package.json +2 -2
- package/dist/types/components/AvatarStack/AvatarStack.appearance.d.ts +0 -21
- package/dist/types/components/AvatarStack/AvatarStack.appearance.js +0 -5
- package/dist/types/components/AvatarStack/__test__/AvatarStackTest.stories.js +0 -45
- package/dist/types/components/AvatarStack/appearance/avatarStackSize.d.ts +0 -21
- package/dist/types/components/AvatarStack/appearance/avatarStackSize.js +0 -21
|
@@ -1,88 +1,49 @@
|
|
|
1
1
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import * as storybookTest from 'storybook/test';
|
|
2
3
|
import { icons24 } from '@itcase/icons-default';
|
|
3
4
|
import { Badge } from '../Badge';
|
|
4
5
|
const meta = {
|
|
5
|
-
title: 'Atoms / Badge
|
|
6
|
+
title: 'Atoms / Badge',
|
|
6
7
|
component: Badge,
|
|
7
8
|
args: {
|
|
9
|
+
appearance: 'accentPrimary sizeXXL solid rounded',
|
|
10
|
+
dataTestId: 'badgeDotIconCounterTestId',
|
|
8
11
|
dot: true,
|
|
9
12
|
icon: icons24.Placeholder.Default,
|
|
10
13
|
value: 3,
|
|
11
14
|
},
|
|
12
15
|
parameters: {
|
|
13
16
|
layout: 'centered',
|
|
17
|
+
design: {
|
|
18
|
+
type: 'figma',
|
|
19
|
+
url: 'https://www.figma.com/design/HmHn0BShJPXHU8SmuIP71M/ITCase---Atoms?node-id=0-1&t=n7EGLyP33amnXKYl-1',
|
|
20
|
+
},
|
|
14
21
|
},
|
|
22
|
+
tags: ['test'],
|
|
15
23
|
};
|
|
16
24
|
export default meta;
|
|
17
|
-
export const
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
};
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
},
|
|
40
|
-
}
|
|
41
|
-
export const Surface = {
|
|
42
|
-
args: {
|
|
43
|
-
appearance: 'surfacePrimary sizeXXL solid rounded',
|
|
44
|
-
},
|
|
45
|
-
render: (args) => {
|
|
46
|
-
return _jsx(Badge, { ...args });
|
|
47
|
-
},
|
|
48
|
-
};
|
|
49
|
-
export const Success = {
|
|
50
|
-
args: {
|
|
51
|
-
appearance: 'successPrimary sizeXXL solid rounded',
|
|
52
|
-
},
|
|
53
|
-
render: (args) => {
|
|
54
|
-
return _jsx(Badge, { ...args });
|
|
55
|
-
},
|
|
56
|
-
};
|
|
57
|
-
export const Warning = {
|
|
58
|
-
args: {
|
|
59
|
-
appearance: 'warningPrimary sizeXXL solid rounded',
|
|
60
|
-
},
|
|
61
|
-
render: (args) => {
|
|
62
|
-
return _jsx(Badge, { ...args });
|
|
63
|
-
},
|
|
64
|
-
};
|
|
65
|
-
export const Danger = {
|
|
66
|
-
args: {
|
|
67
|
-
appearance: 'dangerPrimary sizeXXL solid rounded',
|
|
68
|
-
},
|
|
69
|
-
render: (args) => {
|
|
70
|
-
return _jsx(Badge, { ...args });
|
|
71
|
-
},
|
|
72
|
-
};
|
|
73
|
-
export const Info = {
|
|
74
|
-
args: {
|
|
75
|
-
appearance: 'infoPrimary sizeXXL solid rounded',
|
|
76
|
-
},
|
|
77
|
-
render: (args) => {
|
|
78
|
-
return _jsx(Badge, { ...args });
|
|
79
|
-
},
|
|
80
|
-
};
|
|
81
|
-
export const Disabled = {
|
|
82
|
-
args: {
|
|
83
|
-
appearance: 'disabledPrimary sizeXXL solid rounded',
|
|
84
|
-
},
|
|
85
|
-
render: (args) => {
|
|
86
|
-
return _jsx(Badge, { ...args });
|
|
87
|
-
},
|
|
25
|
+
export const DotIconCounter = {
|
|
26
|
+
name: 'Dot + Icon + Counter',
|
|
27
|
+
play: async ({ args, canvas, step }) => {
|
|
28
|
+
await step('Badge: dot, icon and counter', async () => {
|
|
29
|
+
const badge = canvas.getByTestId(args.dataTestId);
|
|
30
|
+
await step(`Badge has class "badge_type_dot-icon-counter"`, async () => {
|
|
31
|
+
await storybookTest
|
|
32
|
+
.expect(badge)
|
|
33
|
+
.toHaveClass('badge_type_dot-icon-counter');
|
|
34
|
+
});
|
|
35
|
+
await step(`Badge has counter value is ${args.value}`, async () => {
|
|
36
|
+
await storybookTest.expect(badge).toHaveTextContent(String(args.value));
|
|
37
|
+
});
|
|
38
|
+
await step('Badge has icon', async () => {
|
|
39
|
+
await storybookTest.expect(badge.querySelector('.icon')).toBeTruthy();
|
|
40
|
+
});
|
|
41
|
+
await step('Badge has dot', async () => {
|
|
42
|
+
await storybookTest
|
|
43
|
+
.expect(badge.querySelector('.badge__dot'))
|
|
44
|
+
.toBeTruthy();
|
|
45
|
+
});
|
|
46
|
+
});
|
|
47
|
+
},
|
|
48
|
+
render: (args) => _jsx(Badge, { ...args }),
|
|
88
49
|
};
|
|
@@ -25,6 +25,9 @@ export const Children = {
|
|
|
25
25
|
render: (args) => _jsx(Divider, { ...args }),
|
|
26
26
|
};
|
|
27
27
|
export const Skeleton = {
|
|
28
|
+
args: {
|
|
29
|
+
isSkeleton: true,
|
|
30
|
+
},
|
|
28
31
|
play: async ({ args, canvas, step }) => {
|
|
29
32
|
await step('Divider renders with skelton class', async () => {
|
|
30
33
|
const divider = canvas.getByTestId(args.dataTestId);
|
|
@@ -32,8 +35,5 @@ export const Skeleton = {
|
|
|
32
35
|
await storybookTest.expect(divider).toHaveClass('skeleton');
|
|
33
36
|
});
|
|
34
37
|
},
|
|
35
|
-
args: {
|
|
36
|
-
isSkeleton: true,
|
|
37
|
-
},
|
|
38
38
|
render: (args) => _jsx(Divider, { ...args }),
|
|
39
39
|
};
|
|
@@ -79,6 +79,7 @@ declare const dropzoneAppearance: {
|
|
|
79
79
|
hintTitle: string;
|
|
80
80
|
hintTitleTextColor: "surfaceTextPrimary";
|
|
81
81
|
hintTitleTextSize: "m";
|
|
82
|
+
removeThumbAppearance: "dangerPrimary sizeM solid rounded";
|
|
82
83
|
removeThumbText: string;
|
|
83
84
|
removeThumbTextColor: "errorTextPrimary";
|
|
84
85
|
thumbBorderColor: "surfaceBorderTertiary";
|
|
@@ -17,7 +17,7 @@ const dropzoneConfig = {
|
|
|
17
17
|
};
|
|
18
18
|
const Dropzone = React.memo(function Dropzone(props) {
|
|
19
19
|
const { appearance, maxFiles = 5, maxSize = 10485760, // 10mb
|
|
20
|
-
dropzoneProps = {}, fieldValuesList: maybeFieldValuesList, fileErrorText, hintDescription, inputName, showFilename = true, thumbColumn, isSkeleton, isPreviews = true, onClickPreview, onAddFiles, onChangeFiles, onDeleteFile,
|
|
20
|
+
dropzoneProps = {}, fieldValuesList: maybeFieldValuesList, fileErrorText, hintDescription, inputName, showFilename = true, thumbColumn = 2, isSkeleton, isPreviews = true, onClickPreview, onAddFiles, onChangeFiles, onDeleteFile,
|
|
21
21
|
// className, unused
|
|
22
22
|
// size, unused
|
|
23
23
|
} = props;
|
|
@@ -5,6 +5,7 @@ declare const dropzoneAppearanceDefault: {
|
|
|
5
5
|
hintTitle: string;
|
|
6
6
|
hintTitleTextColor: "surfaceTextPrimary";
|
|
7
7
|
hintTitleTextSize: "m";
|
|
8
|
+
removeThumbAppearance: "dangerPrimary sizeM solid rounded";
|
|
8
9
|
removeThumbText: string;
|
|
9
10
|
removeThumbTextColor: "errorTextPrimary";
|
|
10
11
|
thumbBorderColor: "surfaceBorderTertiary";
|
|
@@ -5,6 +5,7 @@ const dropzoneAppearanceDefault = {
|
|
|
5
5
|
hintTitle: 'Перетащите изображение или выберите файл с компьютера',
|
|
6
6
|
hintTitleTextColor: 'surfaceTextPrimary',
|
|
7
7
|
hintTitleTextSize: 'm',
|
|
8
|
+
removeThumbAppearance: 'dangerPrimary sizeM solid rounded',
|
|
8
9
|
removeThumbText: 'удалить',
|
|
9
10
|
removeThumbTextColor: 'errorTextPrimary',
|
|
10
11
|
thumbBorderColor: 'surfaceBorderTertiary',
|
|
@@ -2,6 +2,7 @@ import { jsx as _jsx } from "react/jsx-runtime";
|
|
|
2
2
|
/* eslint-disable react-hooks/rules-of-hooks */
|
|
3
3
|
import { useState } from 'react';
|
|
4
4
|
import { Dropzone } from '../';
|
|
5
|
+
import { dropzoneFieldValuesListMock } from './__mock__';
|
|
5
6
|
const meta = {
|
|
6
7
|
title: 'Molecules / Dropzone',
|
|
7
8
|
component: Dropzone,
|
|
@@ -17,6 +18,12 @@ export const Default = {
|
|
|
17
18
|
return (_jsx(Dropzone, { ...args, fieldValuesList: values, onChangeFiles: setValues }));
|
|
18
19
|
},
|
|
19
20
|
};
|
|
21
|
+
export const WithFiles = {
|
|
22
|
+
render: (args) => {
|
|
23
|
+
const [values, setValues] = useState(dropzoneFieldValuesListMock);
|
|
24
|
+
return (_jsx(Dropzone, { ...args, fieldValuesList: values, onChangeFiles: setValues }));
|
|
25
|
+
},
|
|
26
|
+
};
|
|
20
27
|
export const Skeleton = {
|
|
21
28
|
args: {
|
|
22
29
|
isSkeleton: true,
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/** Form/backend values before hook converts them to DropzoneFileItem */
|
|
2
|
+
const dropzoneFieldValuesListMock = [
|
|
3
|
+
{
|
|
4
|
+
id: 'dropzone-story-mock-1',
|
|
5
|
+
name: 'image-1.png',
|
|
6
|
+
image: '/avatar/Man.png',
|
|
7
|
+
},
|
|
8
|
+
{
|
|
9
|
+
id: 'dropzone-story-mock-2',
|
|
10
|
+
name: 'image-2.png',
|
|
11
|
+
image: '/avatar/Woman.png',
|
|
12
|
+
},
|
|
13
|
+
{
|
|
14
|
+
id: 'dropzone-story-mock-3',
|
|
15
|
+
name: 'image-3.png',
|
|
16
|
+
image: '/avatar/Woman2.png',
|
|
17
|
+
},
|
|
18
|
+
];
|
|
19
|
+
export { dropzoneFieldValuesListMock };
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@itcase/ui-web",
|
|
3
|
-
"version": "1.9.
|
|
3
|
+
"version": "1.9.113",
|
|
4
4
|
"description": "UI components",
|
|
5
5
|
"keywords": "",
|
|
6
6
|
"license": "MIT",
|
|
@@ -114,5 +114,5 @@
|
|
|
114
114
|
"storybook": "^10.4.0",
|
|
115
115
|
"typescript": "^6.0.3"
|
|
116
116
|
},
|
|
117
|
-
"gitHead": "
|
|
117
|
+
"gitHead": "1a3cb82207abc56131b2ba26fa8f837886168942"
|
|
118
118
|
}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
declare const avatarStackAppearance: {
|
|
2
|
-
size16: {
|
|
3
|
-
size: "16";
|
|
4
|
-
};
|
|
5
|
-
size20: {
|
|
6
|
-
size: "20";
|
|
7
|
-
};
|
|
8
|
-
size24: {
|
|
9
|
-
size: "24";
|
|
10
|
-
};
|
|
11
|
-
size32: {
|
|
12
|
-
size: "32";
|
|
13
|
-
};
|
|
14
|
-
size40: {
|
|
15
|
-
size: "40";
|
|
16
|
-
};
|
|
17
|
-
size56: {
|
|
18
|
-
size: "56";
|
|
19
|
-
};
|
|
20
|
-
};
|
|
21
|
-
export { avatarStackAppearance };
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
-
import * as storybookTest from 'storybook/test';
|
|
3
|
-
import { AvatarStack } from '../AvatarStack';
|
|
4
|
-
import { avatarsListMock } from '../stories/__mock__';
|
|
5
|
-
const meta = {
|
|
6
|
-
title: 'Molecules / Avatar Stack / __test__',
|
|
7
|
-
component: AvatarStack,
|
|
8
|
-
args: {
|
|
9
|
-
dataTestId: 'avatarStackTestId',
|
|
10
|
-
avatarAppearance: `surfaceSecondary size56 solid rounded`,
|
|
11
|
-
avatarsList: avatarsListMock,
|
|
12
|
-
},
|
|
13
|
-
parameters: {
|
|
14
|
-
layout: 'centered',
|
|
15
|
-
},
|
|
16
|
-
tags: ['test'],
|
|
17
|
-
};
|
|
18
|
-
export default meta;
|
|
19
|
-
export const Skeleton = {
|
|
20
|
-
play: async ({ args, canvas, step }) => {
|
|
21
|
-
await step('AvatarStack renders with skeleton class', async () => {
|
|
22
|
-
const avatarStack = canvas.getByTestId(args.dataTestId);
|
|
23
|
-
await storybookTest.expect(avatarStack).toBeInTheDocument();
|
|
24
|
-
await storybookTest.expect(avatarStack).toHaveClass('skeleton');
|
|
25
|
-
});
|
|
26
|
-
},
|
|
27
|
-
args: {
|
|
28
|
-
isSkeleton: true,
|
|
29
|
-
},
|
|
30
|
-
render: (args) => _jsx(AvatarStack, { ...args }),
|
|
31
|
-
};
|
|
32
|
-
export const Length = {
|
|
33
|
-
play: async ({ args, canvas, step }) => {
|
|
34
|
-
await step('AvatarStack renders with skeleton class', async () => {
|
|
35
|
-
const avatarStack = canvas.getByTestId(args.dataTestId);
|
|
36
|
-
await storybookTest.expect(avatarStack).toBeInTheDocument();
|
|
37
|
-
const avatarsItems = avatarStack.children;
|
|
38
|
-
await storybookTest.expect(avatarsItems.length).toBe(args.length);
|
|
39
|
-
});
|
|
40
|
-
},
|
|
41
|
-
args: {
|
|
42
|
-
length: 4,
|
|
43
|
-
},
|
|
44
|
-
render: (args) => _jsx(AvatarStack, { ...args }),
|
|
45
|
-
};
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
declare const avatarStackAppearanceSize: {
|
|
2
|
-
size16: {
|
|
3
|
-
size: "16";
|
|
4
|
-
};
|
|
5
|
-
size20: {
|
|
6
|
-
size: "20";
|
|
7
|
-
};
|
|
8
|
-
size24: {
|
|
9
|
-
size: "24";
|
|
10
|
-
};
|
|
11
|
-
size32: {
|
|
12
|
-
size: "32";
|
|
13
|
-
};
|
|
14
|
-
size40: {
|
|
15
|
-
size: "40";
|
|
16
|
-
};
|
|
17
|
-
size56: {
|
|
18
|
-
size: "56";
|
|
19
|
-
};
|
|
20
|
-
};
|
|
21
|
-
export { avatarStackAppearanceSize };
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
const avatarStackAppearanceSize = {
|
|
2
|
-
size16: {
|
|
3
|
-
size: '16',
|
|
4
|
-
},
|
|
5
|
-
size20: {
|
|
6
|
-
size: '20',
|
|
7
|
-
},
|
|
8
|
-
size24: {
|
|
9
|
-
size: '24',
|
|
10
|
-
},
|
|
11
|
-
size32: {
|
|
12
|
-
size: '32',
|
|
13
|
-
},
|
|
14
|
-
size40: {
|
|
15
|
-
size: '40',
|
|
16
|
-
},
|
|
17
|
-
size56: {
|
|
18
|
-
size: '56',
|
|
19
|
-
},
|
|
20
|
-
};
|
|
21
|
-
export { avatarStackAppearanceSize };
|