@cloud-ru/uikit-product-mobile-chips 0.8.36

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 (46) hide show
  1. package/CHANGELOG.md +1178 -0
  2. package/LICENSE +201 -0
  3. package/README.md +8 -0
  4. package/package.json +60 -0
  5. package/src/components/AdaptiveChips/AdaptiveChips.tsx +21 -0
  6. package/src/components/AdaptiveChips/index.ts +1 -0
  7. package/src/components/MobileChipChoice/components/ChipChoiceBase/ChipChoiceBase.tsx +148 -0
  8. package/src/components/MobileChipChoice/components/ChipChoiceBase/index.ts +1 -0
  9. package/src/components/MobileChipChoice/components/ChipChoiceBase/styles.module.scss +89 -0
  10. package/src/components/MobileChipChoice/components/MobileChipChoiceCustom.tsx +81 -0
  11. package/src/components/MobileChipChoice/components/MobileChipChoiceDate.tsx +135 -0
  12. package/src/components/MobileChipChoice/components/MobileChipChoiceDateRange.tsx +101 -0
  13. package/src/components/MobileChipChoice/components/MobileChipChoiceMultiple.tsx +218 -0
  14. package/src/components/MobileChipChoice/components/MobileChipChoiceSingle.tsx +176 -0
  15. package/src/components/MobileChipChoice/components/MobileChipChoiceTime.tsx +122 -0
  16. package/src/components/MobileChipChoice/components/index.ts +6 -0
  17. package/src/components/MobileChipChoice/components/styles.module.scss +36 -0
  18. package/src/components/MobileChipChoice/constants.ts +20 -0
  19. package/src/components/MobileChipChoice/hooks.tsx +127 -0
  20. package/src/components/MobileChipChoice/index.ts +38 -0
  21. package/src/components/MobileChipChoice/styles.module.scss +103 -0
  22. package/src/components/MobileChipChoice/types.ts +139 -0
  23. package/src/components/MobileChipChoice/utils/index.ts +3 -0
  24. package/src/components/MobileChipChoice/utils/options.tsx +61 -0
  25. package/src/components/MobileChipChoice/utils/typeGuards.ts +35 -0
  26. package/src/components/MobileChipChoice/utils/utils.ts +62 -0
  27. package/src/components/MobileChipChoiceRow/MobileChipChoiceRow.tsx +275 -0
  28. package/src/components/MobileChipChoiceRow/components/ForwardedChipChoice.tsx +10 -0
  29. package/src/components/MobileChipChoiceRow/components/constants.ts +12 -0
  30. package/src/components/MobileChipChoiceRow/components/index.ts +1 -0
  31. package/src/components/MobileChipChoiceRow/constants.ts +21 -0
  32. package/src/components/MobileChipChoiceRow/index.ts +2 -0
  33. package/src/components/MobileChipChoiceRow/styles.module.scss +32 -0
  34. package/src/components/MobileChipChoiceRow/types.ts +60 -0
  35. package/src/components/index.ts +3 -0
  36. package/src/constants.ts +50 -0
  37. package/src/helperComponents/ButtonClearValue/ButtonClearValue.tsx +40 -0
  38. package/src/helperComponents/ButtonClearValue/index.ts +1 -0
  39. package/src/helperComponents/ButtonClearValue/styles.module.scss +50 -0
  40. package/src/helperComponents/ItemContent/ItemContent.tsx +37 -0
  41. package/src/helperComponents/ItemContent/index.ts +1 -0
  42. package/src/helperComponents/ItemContent/styles.module.scss +80 -0
  43. package/src/helperComponents/index.ts +2 -0
  44. package/src/index.ts +1 -0
  45. package/src/styles.module.scss +113 -0
  46. package/src/types.ts +26 -0
@@ -0,0 +1,80 @@
1
+ @use '@sbercloud/figma-tokens-cloud-platform/build/scss/components/styles-tokens-dropList';
2
+ @use '@sbercloud/figma-tokens-cloud-platform/build/scss/components/styles-tokens-element';
3
+
4
+ $sizes: 's', 'm', 'l';
5
+ $typography: (
6
+ 's': (
7
+ 'label': styles-tokens-element.$sans-body-s,
8
+ 'caption': styles-tokens-element.$sans-body-s,
9
+ 'description': styles-tokens-element.$sans-body-s,
10
+ 'separator': styles-tokens-element.$light-label-m,
11
+ ),
12
+ 'm': (
13
+ 'label': styles-tokens-element.$sans-body-m,
14
+ 'caption': styles-tokens-element.$sans-body-s,
15
+ 'description': styles-tokens-element.$sans-body-s,
16
+ 'separator': styles-tokens-element.$light-label-l,
17
+ ),
18
+ 'l': (
19
+ 'label': styles-tokens-element.$sans-body-l,
20
+ 'caption': styles-tokens-element.$sans-body-m,
21
+ 'description': styles-tokens-element.$sans-body-m,
22
+ 'separator': styles-tokens-element.$light-label-l,
23
+ ),
24
+ );
25
+
26
+ .headline {
27
+ display: flex;
28
+ }
29
+
30
+ .label {
31
+ overflow: hidden;
32
+ flex: 1;
33
+ color: styles-tokens-element.$sys-neutral-text-main;
34
+ }
35
+
36
+ .caption {
37
+ overflow: hidden;
38
+ color: styles-tokens-element.$sys-neutral-text-light;
39
+ text-overflow: ellipsis;
40
+ white-space: nowrap;
41
+ }
42
+
43
+ .description {
44
+ color: styles-tokens-element.$sys-neutral-text-support;
45
+ }
46
+
47
+ .content {
48
+ overflow: hidden;
49
+ flex-grow: 1;
50
+ flex-shrink: 1;
51
+ box-sizing: border-box;
52
+
53
+ @each $size in $sizes {
54
+ &[data-size='#{$size}'] {
55
+ .headline {
56
+ @include styles-tokens-element.composite-var(styles-tokens-dropList.$drop-list, 'item', $size, 'headline');
57
+ }
58
+ .label {
59
+ @include styles-tokens-element.composite-var($typography, $size, 'label');
60
+
61
+ display: flex;
62
+ align-items: center;
63
+ }
64
+ .caption {
65
+ @include styles-tokens-element.composite-var($typography, $size, 'caption');
66
+ }
67
+ .description {
68
+ @include styles-tokens-element.composite-var($typography, $size, 'description');
69
+ }
70
+ }
71
+ }
72
+
73
+ &[data-disabled] {
74
+ .label,
75
+ .description,
76
+ .caption {
77
+ color: styles-tokens-element.$sys-neutral-text-disabled;
78
+ }
79
+ }
80
+ }
@@ -0,0 +1,2 @@
1
+ export * from './ButtonClearValue';
2
+ export * from './ItemContent';
package/src/index.ts ADDED
@@ -0,0 +1 @@
1
+ export * from './components';
@@ -0,0 +1,113 @@
1
+ @use '@sbercloud/figma-tokens-cloud-platform/build/scss/components/styles-tokens-element';
2
+
3
+ @mixin chip-defaults {
4
+ cursor: pointer;
5
+
6
+ position: relative;
7
+
8
+ display: inline-flex;
9
+ align-items: center;
10
+
11
+ box-sizing: border-box;
12
+ width: max-content;
13
+ min-width: max-content;
14
+ margin: 0;
15
+ padding: 0;
16
+
17
+ text-decoration: none;
18
+ text-transform: none;
19
+
20
+ border-style: solid;
21
+ outline: 0;
22
+ outline-offset: 0;
23
+
24
+ .spinner {
25
+ display: inline-flex;
26
+ }
27
+ }
28
+
29
+ @mixin chip-anatomy-styles($chip-theme, $sizes, $typography, $contentClassName: null) {
30
+ @include icon-size;
31
+
32
+ .labelLayout {
33
+ display: inline-flex;
34
+ align-items: center;
35
+ min-width: 0;
36
+ }
37
+
38
+ @each $size in $sizes {
39
+ &[data-size='#{$size}'] {
40
+ .label {
41
+ @include styles-tokens-element.composite-var($typography, $size);
42
+ }
43
+
44
+ .labelLayout {
45
+ @include styles-tokens-element.composite-var($chip-theme, 'label-layout', $size);
46
+ }
47
+
48
+ @if ($contentClassName) {
49
+ .#{$contentClassName} {
50
+ @include styles-tokens-element.composite-var($chip-theme, 'container', $size);
51
+ }
52
+ }
53
+ @else {
54
+ @include styles-tokens-element.composite-var($chip-theme, 'container', $size);
55
+ }
56
+ }
57
+ }
58
+ }
59
+
60
+ @mixin icon-size {
61
+ .icon {
62
+ display: inline-flex;
63
+
64
+ svg {
65
+ width: styles-tokens-element.$icon-s !important; /* stylelint-disable-line declaration-no-important */
66
+ height: styles-tokens-element.$icon-s !important; /* stylelint-disable-line declaration-no-important */
67
+ }
68
+ }
69
+ }
70
+
71
+ @mixin chip-loading-state($chip-theme, $condition, $classNamesToHide, $contentClassName: null, $relativeSpinner: null) {
72
+ @if ($contentClassName) {
73
+ .#{$contentClassName} {
74
+ cursor: progress;
75
+ }
76
+ }
77
+
78
+ @else {
79
+ cursor: progress;
80
+ }
81
+
82
+ #{$condition} {
83
+ @if $classNamesToHide {
84
+ @each $className in $classNamesToHide {
85
+ .#{$className} {
86
+ @include styles-tokens-element.composite-var($chip-theme, 'label-layout', 'label', 'load-label-only');
87
+ }
88
+ }
89
+ }
90
+
91
+ .spinner {
92
+ @if not $relativeSpinner {
93
+ position: absolute;
94
+ top: 0;
95
+ left: 0;
96
+
97
+ width: 100%;
98
+ height: 100%;
99
+ }
100
+
101
+ display: flex;
102
+ align-items: center;
103
+ justify-content: center;
104
+ }
105
+ }
106
+ }
107
+
108
+ @mixin chip-outline {
109
+ @include styles-tokens-element.outline-var(styles-tokens-element.$container-focused-s);
110
+
111
+ outline-color: styles-tokens-element.$sys-available-complementary;
112
+ outline-offset: styles-tokens-element.$spacing-state-focus-offset;
113
+ }
package/src/types.ts ADDED
@@ -0,0 +1,26 @@
1
+ import { ReactElement } from 'react';
2
+
3
+ import { ValueOf } from '@snack-uikit/utils';
4
+
5
+ import { BUTTON_SIZE, SIZE, VARIANT } from './constants';
6
+
7
+ export type Size = ValueOf<typeof SIZE>;
8
+
9
+ export type ButtonSize = ValueOf<typeof BUTTON_SIZE>;
10
+
11
+ export type Variant = ValueOf<typeof VARIANT>;
12
+
13
+ export type BaseChipProps = {
14
+ /** Лейбл */
15
+ label: string;
16
+ /** Деактивирован ли компонент */
17
+ disabled?: boolean;
18
+ /** Состояние загрузки */
19
+ loading?: boolean;
20
+ /** Иконка */
21
+ icon?: ReactElement;
22
+ /** CSS-класс */
23
+ className?: string;
24
+ /** HTML tab index */
25
+ tabIndex?: number;
26
+ };