@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.
Files changed (44) hide show
  1. package/dist/cjs/components/AvatarStack.js +1 -1
  2. package/dist/cjs/components/Dropzone.js +1 -1
  3. package/dist/components/AvatarStack.js +1 -1
  4. package/dist/components/Dropzone.js +1 -1
  5. package/dist/types/components/Avatar/stories/AvatarCount.stories.d.ts +4 -0
  6. package/dist/types/components/Avatar/stories/AvatarCount.stories.js +4 -0
  7. package/dist/types/components/Avatar/stories/AvatarDemo.stories.js +4 -0
  8. package/dist/types/components/Avatar/stories/AvatarImage.stories.d.ts +4 -0
  9. package/dist/types/components/Avatar/stories/AvatarImage.stories.js +4 -0
  10. package/dist/types/components/Avatar/stories/AvatarInteraction.stories.d.ts +4 -0
  11. package/dist/types/components/Avatar/stories/AvatarInteraction.stories.js +4 -0
  12. package/dist/types/components/Avatar/stories/AvatarLetters.stories.d.ts +4 -0
  13. package/dist/types/components/Avatar/stories/AvatarLetters.stories.js +4 -0
  14. package/dist/types/components/Avatar/stories/AvatarSkeleton.stories.d.ts +4 -0
  15. package/dist/types/components/Avatar/stories/AvatarSkeleton.stories.js +4 -0
  16. package/dist/types/components/AvatarStack/AvatarStack.interface.d.ts +6 -11
  17. package/dist/types/components/AvatarStack/AvatarStack.js +3 -13
  18. package/dist/types/components/AvatarStack/index.d.ts +1 -1
  19. package/dist/types/components/AvatarStack/stories/AvatarStackCount.stories.d.ts +12 -4
  20. package/dist/types/components/AvatarStack/stories/AvatarStackCount.stories.js +49 -13
  21. package/dist/types/components/AvatarStack/stories/AvatarStackDemo.stories.d.ts +6 -2
  22. package/dist/types/components/AvatarStack/stories/AvatarStackDemo.stories.js +7 -12
  23. package/dist/types/components/AvatarStack/stories/AvatarStackSize.stories.d.ts +9 -1
  24. package/dist/types/components/AvatarStack/stories/AvatarStackSize.stories.js +51 -37
  25. package/dist/types/components/AvatarStack/{__test__/AvatarStackTest.stories.d.ts → stories/AvatarStackSkeleton.stories.d.ts} +7 -2
  26. package/dist/types/components/AvatarStack/stories/AvatarStackSkeleton.stories.js +47 -0
  27. package/dist/types/components/AvatarStack/stories/__mock__/index.js +11 -5
  28. package/dist/types/components/Badge/stories/BadgeDotIconCounter.stories.d.ts +8 -9
  29. package/dist/types/components/Badge/stories/BadgeDotIconCounter.stories.js +33 -72
  30. package/dist/types/components/Divider/__test__/DividerTest.stories.js +3 -3
  31. package/dist/types/components/Dropzone/Dropzone.appearance.d.ts +1 -0
  32. package/dist/types/components/Dropzone/Dropzone.js +1 -1
  33. package/dist/types/components/Dropzone/appearance/dropzoneDefault.d.ts +1 -0
  34. package/dist/types/components/Dropzone/appearance/dropzoneDefault.js +1 -0
  35. package/dist/types/components/Dropzone/stories/DropzoneDemo.stories.d.ts +1 -0
  36. package/dist/types/components/Dropzone/stories/DropzoneDemo.stories.js +7 -0
  37. package/dist/types/components/Dropzone/stories/__mock__/index.d.ts +4 -0
  38. package/dist/types/components/Dropzone/stories/__mock__/index.js +19 -0
  39. package/package.json +2 -2
  40. package/dist/types/components/AvatarStack/AvatarStack.appearance.d.ts +0 -21
  41. package/dist/types/components/AvatarStack/AvatarStack.appearance.js +0 -5
  42. package/dist/types/components/AvatarStack/__test__/AvatarStackTest.stories.js +0 -45
  43. package/dist/types/components/AvatarStack/appearance/avatarStackSize.d.ts +0 -21
  44. 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 / Dot + Icon + Counter',
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 Accent = {
18
- args: {
19
- appearance: 'accentPrimary sizeXXL solid rounded',
20
- },
21
- render: (args) => {
22
- return _jsx(Badge, { ...args });
23
- },
24
- };
25
- export const Special = {
26
- args: {
27
- appearance: 'specialPrimary sizeXXL solid rounded',
28
- },
29
- render: (args) => {
30
- return _jsx(Badge, { ...args });
31
- },
32
- };
33
- export const Extra = {
34
- args: {
35
- appearance: 'extraPrimary sizeXXL solid rounded',
36
- },
37
- render: (args) => {
38
- return _jsx(Badge, { ...args });
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',
@@ -11,4 +11,5 @@ declare const meta: {
11
11
  export default meta;
12
12
  type Story = StoryObj<typeof meta>;
13
13
  export declare const Default: Story;
14
+ export declare const WithFiles: Story;
14
15
  export declare const Skeleton: Story;
@@ -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,4 @@
1
+ import type { DropzoneFileItem } from '../../Dropzone.interface';
2
+ /** Form/backend values before hook converts them to DropzoneFileItem */
3
+ declare const dropzoneFieldValuesListMock: DropzoneFileItem[];
4
+ export { dropzoneFieldValuesListMock };
@@ -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.112",
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": "985b7cd49b2f7db7233d288d4561b5af826037f0"
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,5 +0,0 @@
1
- import { avatarStackAppearanceSize } from './appearance/avatarStackSize';
2
- const avatarStackAppearance = {
3
- ...avatarStackAppearanceSize,
4
- };
5
- 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 };