@alfalab/core-components-steps 3.0.3 → 3.0.4-alfasans
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/components/step/Component.d.ts +2 -2
- package/components/step/Component.js +8 -11
- package/components/step/Component.js.map +1 -1
- package/components/step/index.css +38 -36
- package/components/step/index.module.css.js +1 -1
- package/components/step/index.module.css.js.map +1 -1
- package/components/step-indicator/Component.d.ts +5 -1
- package/components/step-indicator/Component.js +3 -3
- package/components/step-indicator/Component.js.map +1 -1
- package/components/step-indicator/index.css +1 -1
- package/components/step-indicator/index.module.css.js +1 -1
- package/cssm/components/step/Component.d.ts +2 -2
- package/cssm/components/step/Component.js +8 -11
- package/cssm/components/step/Component.js.map +1 -1
- package/cssm/components/step/index.module.css +8 -6
- package/cssm/components/step-indicator/Component.d.ts +5 -1
- package/cssm/components/step-indicator/Component.js +3 -3
- package/cssm/components/step-indicator/Component.js.map +1 -1
- package/esm/components/step/Component.d.ts +2 -2
- package/esm/components/step/Component.js +8 -11
- package/esm/components/step/Component.js.map +1 -1
- package/esm/components/step/index.css +38 -36
- package/esm/components/step/index.module.css.js +1 -1
- package/esm/components/step/index.module.css.js.map +1 -1
- package/esm/components/step-indicator/Component.d.ts +5 -1
- package/esm/components/step-indicator/Component.js +3 -3
- package/esm/components/step-indicator/Component.js.map +1 -1
- package/esm/components/step-indicator/index.css +1 -1
- package/esm/components/step-indicator/index.module.css.js +1 -1
- package/esm/index.css +2 -2
- package/esm/index.module.css.js +1 -1
- package/index.css +2 -2
- package/index.module.css.js +1 -1
- package/modern/components/step/Component.d.ts +2 -2
- package/modern/components/step/Component.js +8 -11
- package/modern/components/step/Component.js.map +1 -1
- package/modern/components/step/index.css +38 -36
- package/modern/components/step/index.module.css.js +1 -1
- package/modern/components/step/index.module.css.js.map +1 -1
- package/modern/components/step-indicator/Component.d.ts +5 -1
- package/modern/components/step-indicator/Component.js +2 -2
- package/modern/components/step-indicator/Component.js.map +1 -1
- package/modern/components/step-indicator/index.css +1 -1
- package/modern/components/step-indicator/index.module.css.js +1 -1
- package/modern/index.css +2 -2
- package/modern/index.module.css.js +1 -1
- package/moderncssm/components/step/Component.d.ts +2 -2
- package/moderncssm/components/step/Component.js +8 -11
- package/moderncssm/components/step/Component.js.map +1 -1
- package/moderncssm/components/step/index.module.css +5 -4
- package/moderncssm/components/step-indicator/Component.d.ts +5 -1
- package/moderncssm/components/step-indicator/Component.js +2 -2
- package/moderncssm/components/step-indicator/Component.js.map +1 -1
- package/package.json +6 -6
- package/src/components/step/Component.tsx +10 -17
- package/src/components/step/index.module.css +1 -2
- package/src/components/step-indicator/Component.tsx +10 -7
|
@@ -23,8 +23,9 @@
|
|
|
23
23
|
--gap-16: var(--gap-m);
|
|
24
24
|
}
|
|
25
25
|
:root {
|
|
26
|
-
--font-family-
|
|
27
|
-
system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue',
|
|
26
|
+
--font-family-alfasans:
|
|
27
|
+
'Alfa Interface Sans', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue',
|
|
28
|
+
Helvetica, sans-serif;
|
|
28
29
|
}
|
|
29
30
|
:root {
|
|
30
31
|
--focus-color: var(--color-light-status-info);
|
|
@@ -33,44 +34,45 @@
|
|
|
33
34
|
--steps-option-svg-color: var(--color-light-status-positive);
|
|
34
35
|
--steps-dash-border: 2px solid var(--color-light-status-positive);
|
|
35
36
|
}
|
|
36
|
-
.
|
|
37
|
+
.steps__step_u8o8k {
|
|
37
38
|
display: flex;
|
|
38
39
|
outline: none;
|
|
39
40
|
}
|
|
40
|
-
.
|
|
41
|
+
.steps__step_u8o8k.steps__horizontal_u8o8k {
|
|
41
42
|
flex-grow: 1;
|
|
42
43
|
}
|
|
43
|
-
.
|
|
44
|
+
.steps__step_u8o8k:not(.steps__vertical_u8o8k) {
|
|
44
45
|
align-items: center;
|
|
45
46
|
}
|
|
46
|
-
.
|
|
47
|
+
.steps__step_u8o8k:last-of-type .steps__textWrapper_u8o8k.steps__vertical_u8o8k {
|
|
47
48
|
margin-bottom: var(--gap-0);
|
|
48
49
|
}
|
|
49
|
-
.
|
|
50
|
+
.steps__step_u8o8k.steps__interactive_u8o8k:not(.steps__disabled_u8o8k):hover {
|
|
50
51
|
cursor: pointer;
|
|
51
52
|
}
|
|
52
|
-
.
|
|
53
|
+
.steps__step_u8o8k.steps__disabled_u8o8k:hover .steps__text_u8o8k {
|
|
53
54
|
background: transparent none repeat 0 0 / auto auto padding-box border-box scroll;
|
|
54
55
|
background: initial;
|
|
55
56
|
}
|
|
56
|
-
.
|
|
57
|
+
.steps__step_u8o8k.steps__disabled_u8o8k .steps__indicator_u8o8k {
|
|
57
58
|
cursor: inherit;
|
|
58
59
|
}
|
|
59
|
-
.
|
|
60
|
+
.steps__indicator_u8o8k {
|
|
60
61
|
cursor: pointer;
|
|
61
62
|
display: flex;
|
|
62
63
|
align-items: center;
|
|
63
64
|
margin-right: var(--gap-4);
|
|
64
65
|
}
|
|
65
|
-
.
|
|
66
|
+
.steps__indicator_u8o8k.steps__vertical_u8o8k {
|
|
66
67
|
flex-direction: column;
|
|
67
68
|
margin-right: var(--gap-8);
|
|
68
69
|
}
|
|
69
|
-
.
|
|
70
|
+
.steps__option_u8o8k {
|
|
70
71
|
font-size: 14px;
|
|
71
72
|
line-height: 20px;
|
|
72
73
|
font-weight: 700;
|
|
73
|
-
|
|
74
|
+
letter-spacing: 0.47px;
|
|
75
|
+
font-family: var(--font-family-alfasans);
|
|
74
76
|
|
|
75
77
|
display: flex;
|
|
76
78
|
align-items: center;
|
|
@@ -81,19 +83,19 @@
|
|
|
81
83
|
height: 24px;
|
|
82
84
|
border-radius: var(--border-radius-circle);
|
|
83
85
|
}
|
|
84
|
-
.
|
|
86
|
+
.steps__option_u8o8k.steps__vertical_u8o8k {
|
|
85
87
|
margin-top: var(--gap-8);
|
|
86
88
|
}
|
|
87
|
-
.
|
|
89
|
+
.steps__dash_u8o8k {
|
|
88
90
|
flex: 1 1 auto;
|
|
89
91
|
min-width: 24px;
|
|
90
92
|
border-top: 2px solid var(--color-light-neutral-translucent-300);
|
|
91
93
|
margin-right: var(--gap-8);
|
|
92
94
|
}
|
|
93
|
-
.
|
|
95
|
+
.steps__dash_u8o8k.steps__completed_u8o8k {
|
|
94
96
|
border-top: var(--steps-dash-border);
|
|
95
97
|
}
|
|
96
|
-
.
|
|
98
|
+
.steps__dash_u8o8k.steps__vertical_u8o8k {
|
|
97
99
|
min-width: 0;
|
|
98
100
|
min-width: initial;
|
|
99
101
|
min-height: 8px;
|
|
@@ -102,23 +104,24 @@
|
|
|
102
104
|
border-left: 2px solid var(--color-light-neutral-translucent-300);
|
|
103
105
|
border-top: none;
|
|
104
106
|
}
|
|
105
|
-
.
|
|
107
|
+
.steps__dash_u8o8k.steps__completed_u8o8k.steps__vertical_u8o8k {
|
|
106
108
|
border-left: var(--steps-dash-border);
|
|
107
109
|
}
|
|
108
|
-
.
|
|
110
|
+
.steps__textWrapper_u8o8k.steps__vertical_u8o8k {
|
|
109
111
|
min-height: 48px;
|
|
110
112
|
}
|
|
111
|
-
.
|
|
113
|
+
.steps__textWrapper_u8o8k.steps__vertical_u8o8k.steps__gap-24_u8o8k {
|
|
112
114
|
margin-bottom: var(--gap-8);
|
|
113
115
|
}
|
|
114
|
-
.
|
|
116
|
+
.steps__textWrapper_u8o8k.steps__vertical_u8o8k.steps__gap-32_u8o8k {
|
|
115
117
|
margin-bottom: var(--gap-16);
|
|
116
118
|
}
|
|
117
|
-
.
|
|
119
|
+
.steps__text_u8o8k {
|
|
118
120
|
font-size: 16px;
|
|
119
121
|
line-height: 24px;
|
|
120
122
|
font-weight: 400;
|
|
121
|
-
|
|
123
|
+
letter-spacing: -0.24px;
|
|
124
|
+
font-family: var(--font-family-alfasans);
|
|
122
125
|
|
|
123
126
|
transition: background 0.2s;
|
|
124
127
|
padding: var(--gap-8);
|
|
@@ -127,24 +130,24 @@
|
|
|
127
130
|
height: -moz-min-content;
|
|
128
131
|
height: min-content;
|
|
129
132
|
}
|
|
130
|
-
.
|
|
133
|
+
.steps__text_u8o8k.steps__interactive_u8o8k:not(.steps__disabled_u8o8k):hover {
|
|
131
134
|
background: var(--color-light-transparent-default-hover);
|
|
132
135
|
}
|
|
133
|
-
.
|
|
136
|
+
.steps__text_u8o8k.steps__interactive_u8o8k:not(.steps__disabled_u8o8k):active {
|
|
134
137
|
background: var(--color-light-transparent-default-press);
|
|
135
138
|
}
|
|
136
|
-
.
|
|
139
|
+
.steps__focused_u8o8k {
|
|
137
140
|
outline: var(--gap-2) solid var(--focus-color);
|
|
138
141
|
outline-offset: var(--gap-2);
|
|
139
142
|
}
|
|
140
|
-
.
|
|
143
|
+
.steps__selected_u8o8k .steps__text_u8o8k {
|
|
141
144
|
color: var(--color-light-text-primary);
|
|
142
145
|
}
|
|
143
|
-
.
|
|
146
|
+
.steps__selected_u8o8k .steps__option_u8o8k {
|
|
144
147
|
color: var(--color-light-text-primary-inverted);
|
|
145
148
|
background: var(--color-light-neutral-translucent-1300);
|
|
146
149
|
}
|
|
147
|
-
.
|
|
150
|
+
.steps__checkbox_u8o8k {
|
|
148
151
|
display: flex;
|
|
149
152
|
justify-content: center;
|
|
150
153
|
align-items: center;
|
|
@@ -153,26 +156,25 @@
|
|
|
153
156
|
height: 20px;
|
|
154
157
|
border: 2px solid var(--color-light-neutral-translucent-300);
|
|
155
158
|
}
|
|
156
|
-
.
|
|
159
|
+
.steps__dot_u8o8k {
|
|
157
160
|
width: 10px;
|
|
158
161
|
height: 10px;
|
|
159
162
|
border-radius: var(--border-radius-circle);
|
|
160
163
|
background: var(--color-light-neutral-translucent-300);
|
|
161
164
|
}
|
|
162
|
-
.
|
|
165
|
+
.steps__selected_u8o8k .steps__checkbox_u8o8k {
|
|
163
166
|
border: 2px solid var(--color-light-neutral-translucent-1300);
|
|
164
167
|
}
|
|
165
|
-
.
|
|
168
|
+
.steps__selected_u8o8k .steps__checkbox_u8o8k .steps__dot_u8o8k {
|
|
166
169
|
background: var(--color-light-neutral-translucent-1300);
|
|
167
170
|
}
|
|
168
|
-
.
|
|
171
|
+
.steps__option_u8o8k:not(.steps__error_u8o8k).steps__unordered_u8o8k {
|
|
169
172
|
background: transparent none repeat 0 0 / auto auto padding-box border-box scroll;
|
|
170
173
|
background: initial;
|
|
171
174
|
}
|
|
172
|
-
.
|
|
173
|
-
color: var(--steps-option-svg-color);
|
|
175
|
+
.steps__completedIndicator_u8o8k[class*='positive-checkmark'] {
|
|
174
176
|
background-color: var(--steps-option-svg-color);
|
|
175
177
|
}
|
|
176
|
-
.
|
|
178
|
+
.steps__fullWidth_u8o8k {
|
|
177
179
|
width: 100%;
|
|
178
180
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import './index.css';
|
|
2
2
|
|
|
3
|
-
const styles = {"step":"
|
|
3
|
+
const styles = {"step":"steps__step_u8o8k","horizontal":"steps__horizontal_u8o8k","vertical":"steps__vertical_u8o8k","textWrapper":"steps__textWrapper_u8o8k","interactive":"steps__interactive_u8o8k","disabled":"steps__disabled_u8o8k","text":"steps__text_u8o8k","indicator":"steps__indicator_u8o8k","option":"steps__option_u8o8k","dash":"steps__dash_u8o8k","completed":"steps__completed_u8o8k","gap-24":"steps__gap-24_u8o8k","gap-32":"steps__gap-32_u8o8k","focused":"steps__focused_u8o8k","selected":"steps__selected_u8o8k","checkbox":"steps__checkbox_u8o8k","dot":"steps__dot_u8o8k","error":"steps__error_u8o8k","unordered":"steps__unordered_u8o8k","completedIndicator":"steps__completedIndicator_u8o8k","fullWidth":"steps__fullWidth_u8o8k"};
|
|
4
4
|
|
|
5
5
|
export { styles as default };
|
|
6
6
|
//# sourceMappingURL=index.module.css.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.module.css.js","sources":["../../src/components/step/index.module.css"],"sourcesContent":["@import '@alfalab/core-components-vars/src/index.css';\n\n:root {\n --steps-option-svg-color: var(--color-light-status-positive);\n --steps-dash-border: 2px solid var(--color-light-status-positive);\n}\n\n.step {\n display: flex;\n outline: none;\n\n &.horizontal {\n flex-grow: 1;\n }\n\n &:not(.vertical) {\n align-items: center;\n }\n\n &:last-of-type .textWrapper.vertical {\n margin-bottom: var(--gap-0);\n }\n}\n\n.step.interactive:not(.disabled):hover {\n cursor: pointer;\n}\n\n.step.disabled:hover {\n & .text {\n background: unset;\n }\n}\n\n.step.disabled {\n & .indicator {\n cursor: unset;\n }\n}\n\n.indicator {\n cursor: pointer;\n display: flex;\n align-items: center;\n margin-right: var(--gap-4);\n\n &.vertical {\n flex-direction: column;\n margin-right: var(--gap-8);\n }\n}\n\n.option {\n @mixin accent_primary_small;\n\n display: flex;\n align-items: center;\n justify-content: center;\n color: var(--color-light-text-primary);\n background: var(--color-light-neutral-translucent-300);\n min-width: 24px;\n height: 24px;\n border-radius: var(--border-radius-circle);\n\n &.vertical {\n margin-top: var(--gap-8);\n }\n}\n\n.dash {\n flex: 1 1 auto;\n min-width: 24px;\n border-top: 2px solid var(--color-light-neutral-translucent-300);\n margin-right: var(--gap-8);\n\n &.completed {\n border-top: var(--steps-dash-border);\n }\n\n &.vertical {\n min-width: unset;\n min-height: 8px;\n margin-right: var(--gap-0);\n margin-top: var(--gap-8);\n border-left: 2px solid var(--color-light-neutral-translucent-300);\n border-top: none;\n }\n\n &.completed.vertical {\n border-left: var(--steps-dash-border);\n }\n}\n\n.textWrapper {\n &.vertical {\n min-height: 48px;\n\n &.gap-24 {\n margin-bottom: var(--gap-8);\n }\n\n &.gap-32 {\n margin-bottom: var(--gap-16);\n }\n }\n}\n\n.text {\n @mixin paragraph_primary_medium;\n\n transition: background 0.2s;\n padding: var(--gap-8);\n color: var(--color-light-text-primary);\n border-radius: var(--gap-8);\n height: min-content;\n\n &.interactive:not(.disabled) {\n &:hover {\n background: var(--color-light-transparent-default-hover);\n }\n\n &:active {\n background: var(--color-light-transparent-default-press);\n }\n }\n}\n\n.focused {\n outline: var(--gap-2) solid var(--focus-color);\n outline-offset: var(--gap-2);\n}\n\n.selected {\n & .text {\n color: var(--color-light-text-primary);\n }\n\n & .option {\n color: var(--color-light-text-primary-inverted);\n background: var(--color-light-neutral-translucent-1300);\n }\n}\n\n.checkbox {\n display: flex;\n justify-content: center;\n align-items: center;\n border-radius: var(--border-radius-circle);\n width: 20px;\n height: 20px;\n border: 2px solid var(--color-light-neutral-translucent-300);\n}\n\n.dot {\n width: 10px;\n height: 10px;\n border-radius: var(--border-radius-circle);\n background: var(--color-light-neutral-translucent-300);\n}\n\n.selected .checkbox {\n border: 2px solid var(--color-light-neutral-translucent-1300);\n\n & .dot {\n background: var(--color-light-neutral-translucent-1300);\n }\n}\n\n.option:not(.error).unordered {\n background: unset;\n}\n\n.completedIndicator
|
|
1
|
+
{"version":3,"file":"index.module.css.js","sources":["../../src/components/step/index.module.css"],"sourcesContent":["@import '@alfalab/core-components-vars/src/index.css';\n\n:root {\n --steps-option-svg-color: var(--color-light-status-positive);\n --steps-dash-border: 2px solid var(--color-light-status-positive);\n}\n\n.step {\n display: flex;\n outline: none;\n\n &.horizontal {\n flex-grow: 1;\n }\n\n &:not(.vertical) {\n align-items: center;\n }\n\n &:last-of-type .textWrapper.vertical {\n margin-bottom: var(--gap-0);\n }\n}\n\n.step.interactive:not(.disabled):hover {\n cursor: pointer;\n}\n\n.step.disabled:hover {\n & .text {\n background: unset;\n }\n}\n\n.step.disabled {\n & .indicator {\n cursor: unset;\n }\n}\n\n.indicator {\n cursor: pointer;\n display: flex;\n align-items: center;\n margin-right: var(--gap-4);\n\n &.vertical {\n flex-direction: column;\n margin-right: var(--gap-8);\n }\n}\n\n.option {\n @mixin accent_primary_small;\n\n display: flex;\n align-items: center;\n justify-content: center;\n color: var(--color-light-text-primary);\n background: var(--color-light-neutral-translucent-300);\n min-width: 24px;\n height: 24px;\n border-radius: var(--border-radius-circle);\n\n &.vertical {\n margin-top: var(--gap-8);\n }\n}\n\n.dash {\n flex: 1 1 auto;\n min-width: 24px;\n border-top: 2px solid var(--color-light-neutral-translucent-300);\n margin-right: var(--gap-8);\n\n &.completed {\n border-top: var(--steps-dash-border);\n }\n\n &.vertical {\n min-width: unset;\n min-height: 8px;\n margin-right: var(--gap-0);\n margin-top: var(--gap-8);\n border-left: 2px solid var(--color-light-neutral-translucent-300);\n border-top: none;\n }\n\n &.completed.vertical {\n border-left: var(--steps-dash-border);\n }\n}\n\n.textWrapper {\n &.vertical {\n min-height: 48px;\n\n &.gap-24 {\n margin-bottom: var(--gap-8);\n }\n\n &.gap-32 {\n margin-bottom: var(--gap-16);\n }\n }\n}\n\n.text {\n @mixin paragraph_primary_medium;\n\n transition: background 0.2s;\n padding: var(--gap-8);\n color: var(--color-light-text-primary);\n border-radius: var(--gap-8);\n height: min-content;\n\n &.interactive:not(.disabled) {\n &:hover {\n background: var(--color-light-transparent-default-hover);\n }\n\n &:active {\n background: var(--color-light-transparent-default-press);\n }\n }\n}\n\n.focused {\n outline: var(--gap-2) solid var(--focus-color);\n outline-offset: var(--gap-2);\n}\n\n.selected {\n & .text {\n color: var(--color-light-text-primary);\n }\n\n & .option {\n color: var(--color-light-text-primary-inverted);\n background: var(--color-light-neutral-translucent-1300);\n }\n}\n\n.checkbox {\n display: flex;\n justify-content: center;\n align-items: center;\n border-radius: var(--border-radius-circle);\n width: 20px;\n height: 20px;\n border: 2px solid var(--color-light-neutral-translucent-300);\n}\n\n.dot {\n width: 10px;\n height: 10px;\n border-radius: var(--border-radius-circle);\n background: var(--color-light-neutral-translucent-300);\n}\n\n.selected .checkbox {\n border: 2px solid var(--color-light-neutral-translucent-1300);\n\n & .dot {\n background: var(--color-light-neutral-translucent-1300);\n }\n}\n\n.option:not(.error).unordered {\n background: unset;\n}\n\n.completedIndicator[class*='positive-checkmark'] {\n background-color: var(--steps-option-svg-color);\n}\n\n.fullWidth {\n width: 100%;\n}\n"],"names":[],"mappings":";;AAEgB,eAAe,CAAC,MAAM,CAAC,mBAAmB,CAAC,YAAY,CAAC,yBAAyB,CAAC,UAAU,CAAC,uBAAuB,CAAC,aAAa,CAAC,0BAA0B,CAAC,aAAa,CAAC,0BAA0B,CAAC,UAAU,CAAC,uBAAuB,CAAC,MAAM,CAAC,mBAAmB,CAAC,WAAW,CAAC,wBAAwB,CAAC,QAAQ,CAAC,qBAAqB,CAAC,MAAM,CAAC,mBAAmB,CAAC,WAAW,CAAC,wBAAwB,CAAC,QAAQ,CAAC,qBAAqB,CAAC,QAAQ,CAAC,qBAAqB,CAAC,SAAS,CAAC,sBAAsB,CAAC,UAAU,CAAC,uBAAuB,CAAC,UAAU,CAAC,uBAAuB,CAAC,KAAK,CAAC,kBAAkB,CAAC,OAAO,CAAC,oBAAoB,CAAC,WAAW,CAAC,wBAAwB,CAAC,oBAAoB,CAAC,iCAAiC,CAAC,WAAW,CAAC,wBAAwB,CAAC;;;;"}
|
|
@@ -1,4 +1,8 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import { type BadgeProps } from '@alfalab/core-components-badge/modern';
|
|
3
|
+
import { type StatusBadgeProps } from '@alfalab/core-components-status-badge/modern';
|
|
4
|
+
/** @description В `@alfalab/core-components@51.0.0` тип будет изменен на Pick<StatusBadgeProps, 'view' | 'className' | 'colors'> */
|
|
3
5
|
export type StepIndicatorProps = Pick<BadgeProps, 'content' | 'iconColor' | 'className'>;
|
|
4
|
-
|
|
6
|
+
type StatusBadgeIndicatorProps = Pick<StatusBadgeProps, 'view' | 'className' | 'colors'>;
|
|
7
|
+
export declare const StepIndicator: React.FC<StatusBadgeIndicatorProps>;
|
|
8
|
+
export {};
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import cn from 'classnames';
|
|
3
|
-
import {
|
|
3
|
+
import { StatusBadge } from '@alfalab/core-components-status-badge/modern';
|
|
4
4
|
import styles from './index.module.css.js';
|
|
5
5
|
|
|
6
|
-
const StepIndicator = ({
|
|
6
|
+
const StepIndicator = ({ view, className, colors }) => (React.createElement(StatusBadge, { size: 24, view: view, colors: colors, className: cn(styles.component, className) }));
|
|
7
7
|
|
|
8
8
|
export { StepIndicator };
|
|
9
9
|
//# sourceMappingURL=Component.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Component.js","sources":["../../../src/components/step-indicator/Component.tsx"],"sourcesContent":["import React from 'react';\nimport cn from 'classnames';\n\nimport {
|
|
1
|
+
{"version":3,"file":"Component.js","sources":["../../../src/components/step-indicator/Component.tsx"],"sourcesContent":["import React from 'react';\nimport cn from 'classnames';\n\nimport { type BadgeProps } from '@alfalab/core-components-badge';\nimport { StatusBadge, type StatusBadgeProps } from '@alfalab/core-components-status-badge';\n\nimport styles from './index.module.css';\n\n/** @description В `@alfalab/core-components@51.0.0` тип будет изменен на Pick<StatusBadgeProps, 'view' | 'className' | 'colors'> */\nexport type StepIndicatorProps = Pick<BadgeProps, 'content' | 'iconColor' | 'className'>;\n\ntype StatusBadgeIndicatorProps = Pick<StatusBadgeProps, 'view' | 'className' | 'colors'>;\n\nexport const StepIndicator: React.FC<StatusBadgeIndicatorProps> = ({ view, className, colors }) => (\n <StatusBadge\n size={24}\n view={view}\n colors={colors}\n className={cn(styles.component, className)}\n />\n);\n"],"names":[],"mappings":";;;;;AAaa,MAAA,aAAa,GAAwC,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,MAC1F,KAAC,CAAA,aAAA,CAAA,WAAW,IACR,IAAI,EAAE,EAAE,EACR,IAAI,EAAE,IAAI,EACV,MAAM,EAAE,MAAM,EACd,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE,SAAS,CAAC,EAAA,CAC5C;;;;"}
|
package/modern/index.css
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
.
|
|
1
|
+
.steps__component_1w1wc {
|
|
2
2
|
display: flex;
|
|
3
3
|
align-items: center;
|
|
4
4
|
flex-direction: row;
|
|
5
5
|
}
|
|
6
|
-
.
|
|
6
|
+
.steps__component_1w1wc.steps__vertical_1w1wc {
|
|
7
7
|
flex-direction: column;
|
|
8
8
|
align-items: flex-start;
|
|
9
9
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import './index.css';
|
|
2
2
|
|
|
3
|
-
const styles = {"component":"
|
|
3
|
+
const styles = {"component":"steps__component_1w1wc","vertical":"steps__vertical_1w1wc"};
|
|
4
4
|
|
|
5
5
|
export { styles as default };
|
|
6
6
|
//# sourceMappingURL=index.module.css.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { type FC } from 'react';
|
|
2
2
|
import { type CommonProps } from '../../types/common-props';
|
|
3
3
|
import { type StepIndicatorProps } from '../step-indicator';
|
|
4
|
-
|
|
4
|
+
interface StepProps extends CommonProps {
|
|
5
5
|
/**
|
|
6
6
|
* Номер шага
|
|
7
7
|
*/
|
|
@@ -51,6 +51,6 @@ type StepProps = {
|
|
|
51
51
|
* @param stepNumber - номер шага
|
|
52
52
|
*/
|
|
53
53
|
onClick: (stepNumber: number) => void;
|
|
54
|
-
}
|
|
54
|
+
}
|
|
55
55
|
export declare const Step: FC<StepProps>;
|
|
56
56
|
export {};
|
|
@@ -1,11 +1,8 @@
|
|
|
1
1
|
import React, { useRef } from 'react';
|
|
2
2
|
import cn from 'classnames';
|
|
3
|
+
import { Badge } from '@alfalab/core-components-badge/moderncssm';
|
|
3
4
|
import { getDataTestId } from '@alfalab/core-components-shared/moderncssm';
|
|
4
5
|
import { useFocus } from '@alfalab/hooks';
|
|
5
|
-
import { CheckmarkCircleMIcon } from '@alfalab/icons-glyph/CheckmarkCircleMIcon';
|
|
6
|
-
import { ClockMIcon } from '@alfalab/icons-glyph/ClockMIcon';
|
|
7
|
-
import { CrossCompactMIcon } from '@alfalab/icons-glyph/CrossCompactMIcon';
|
|
8
|
-
import { ExclamationCircleMIcon } from '@alfalab/icons-glyph/ExclamationCircleMIcon';
|
|
9
6
|
import { StepIndicator } from '../step-indicator/Component.js';
|
|
10
7
|
import styles from './index.module.css';
|
|
11
8
|
|
|
@@ -29,25 +26,25 @@ const Step = ({ children, stepNumber, isSelected, disabled, ordered, isPositive,
|
|
|
29
26
|
};
|
|
30
27
|
const getStepIndicator = () => {
|
|
31
28
|
if (customStepIndicator) {
|
|
32
|
-
return React.createElement(
|
|
29
|
+
return React.createElement(Badge, { view: 'icon', size: 'l', ...customStepIndicator });
|
|
33
30
|
}
|
|
34
31
|
if (isCriticalError) {
|
|
35
|
-
return React.createElement(StepIndicator, {
|
|
32
|
+
return React.createElement(StepIndicator, { view: 'negative-cross' });
|
|
36
33
|
}
|
|
37
34
|
if (isError) {
|
|
38
|
-
return React.createElement(StepIndicator, {
|
|
35
|
+
return React.createElement(StepIndicator, { view: 'negative-alert' });
|
|
39
36
|
}
|
|
40
37
|
if (isWarning) {
|
|
41
|
-
return React.createElement(StepIndicator, {
|
|
38
|
+
return React.createElement(StepIndicator, { view: 'attention-alert' });
|
|
42
39
|
}
|
|
43
40
|
if (isWaiting) {
|
|
44
|
-
return React.createElement(StepIndicator, {
|
|
41
|
+
return React.createElement(StepIndicator, { view: 'neutral-operation' });
|
|
45
42
|
}
|
|
46
43
|
if (isPositive) {
|
|
47
|
-
return React.createElement(StepIndicator, {
|
|
44
|
+
return React.createElement(StepIndicator, { view: 'positive-checkmark' });
|
|
48
45
|
}
|
|
49
46
|
if (isStepCompleted) {
|
|
50
|
-
return (React.createElement(StepIndicator, {
|
|
47
|
+
return (React.createElement(StepIndicator, { view: 'positive-checkmark', className: styles.completedIndicator }));
|
|
51
48
|
}
|
|
52
49
|
if (!ordered) {
|
|
53
50
|
return (React.createElement("div", { className: styles.checkbox },
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Component.js","sources":["../../../src/components/step/Component.tsx"],"sourcesContent":["import React, { type FC, useRef } from 'react';\nimport cn from 'classnames';\n\nimport { getDataTestId } from '@alfalab/core-components-shared';\nimport { useFocus } from '@alfalab/hooks';\nimport { CheckmarkCircleMIcon } from '@alfalab/icons-glyph/CheckmarkCircleMIcon';\nimport { ClockMIcon } from '@alfalab/icons-glyph/ClockMIcon';\nimport { CrossCompactMIcon } from '@alfalab/icons-glyph/CrossCompactMIcon';\nimport { ExclamationCircleMIcon } from '@alfalab/icons-glyph/ExclamationCircleMIcon';\n\nimport { type CommonProps } from '../../types/common-props';\nimport { StepIndicator, type StepIndicatorProps } from '../step-indicator';\n\nimport styles from './index.module.css';\n\ntype StepProps = {\n /**\n * Номер шага\n */\n stepNumber: number;\n\n /**\n * Маркер того, что текущий шаг выбран\n */\n isSelected: boolean;\n\n /**\n * Маркер того, что текущий шаг доступен для клика\n */\n disabled: boolean;\n\n /**\n * Маркер того, что текущий шаг находится в состоянии \"Positive\"\n */\n isPositive: boolean;\n\n /**\n * Маркер того, что текущий шаг находится в состоянии \"Error\"\n */\n isError: boolean;\n\n /**\n * Маркер того, что текущий шаг находится в состоянии \"isCriticalError\"\n */\n isCriticalError: boolean;\n\n /**\n * Маркер того, что текущий шаг находится в состоянии \"Warning\"\n */\n isWarning: boolean;\n\n /**\n * Маркер того, что текущий шаг находится в состоянии \"Waiting\"\n */\n isWaiting: boolean;\n\n /**\n * Маркер того, что текущий шаг нужно пометить как завершенный\n */\n isStepCompleted: boolean;\n\n /**\n * Свойства кастомного индикатора текущего шага\n */\n customStepIndicator?: StepIndicatorProps | null;\n\n /**\n * Указывает, является ли текущий шаг последним в списке\n */\n isNotLastStep?: boolean;\n\n /**\n * Обработчик нажатия на текущей шаг\n * @param stepNumber - номер шага\n */\n onClick: (stepNumber: number) => void;\n} & CommonProps;\n\nexport const Step: FC<StepProps> = ({\n children,\n stepNumber,\n isSelected,\n disabled,\n ordered,\n isPositive,\n isError,\n isCriticalError,\n isWarning,\n isWaiting,\n customStepIndicator,\n isStepCompleted,\n onClick,\n interactive,\n isVerticalAlign,\n isNotLastStep,\n fullWidth,\n minSpaceBetweenSteps = 24,\n completedDashColor,\n dataTestId,\n}) => {\n const stepRef = useRef<HTMLDivElement>(null);\n\n const [focused] = useFocus(stepRef, 'keyboard');\n\n const handleButtonClick = () => {\n if (!disabled && interactive && onClick) {\n onClick(stepNumber);\n }\n };\n\n const handleTextClick = (e: React.MouseEvent<HTMLElement>) => {\n if (!interactive) {\n e.stopPropagation();\n }\n };\n\n const handleKeyDown = (event: React.KeyboardEvent) => {\n if (event.key === 'Enter') {\n handleButtonClick();\n }\n };\n\n const getStepIndicator = () => {\n if (customStepIndicator) {\n return <StepIndicator {...customStepIndicator} />;\n }\n if (isCriticalError) {\n return <StepIndicator iconColor='negative' content={<CrossCompactMIcon />} />;\n }\n if (isError) {\n return <StepIndicator iconColor='negative' content={<ExclamationCircleMIcon />} />;\n }\n if (isWarning) {\n return <StepIndicator iconColor='attention' content={<ExclamationCircleMIcon />} />;\n }\n if (isWaiting) {\n return <StepIndicator iconColor='secondary' content={<ClockMIcon />} />;\n }\n if (isPositive) {\n return <StepIndicator iconColor='positive' content={<CheckmarkCircleMIcon />} />;\n }\n if (isStepCompleted) {\n return (\n <StepIndicator\n iconColor='positive'\n content={<CheckmarkCircleMIcon />}\n className={styles.completedIndicator}\n />\n );\n }\n if (!ordered) {\n return (\n <div className={styles.checkbox}>\n <span className={styles.dot} />\n </div>\n );\n }\n\n return stepNumber;\n };\n\n const getCustomDashColor = () => {\n if (isStepCompleted && completedDashColor) {\n return {\n borderColor: completedDashColor,\n };\n }\n\n return {};\n };\n\n const renderDash = () => (\n <div\n className={cn(styles.dash, {\n [styles.vertical]: isVerticalAlign,\n [styles.completed]: isStepCompleted,\n })}\n style={{\n ...getCustomDashColor(),\n }}\n />\n );\n\n return (\n <div\n data-test-id={getDataTestId(dataTestId, 'step')}\n role='button'\n tabIndex={0}\n ref={stepRef}\n className={cn(styles.step, {\n [styles.completed]: isStepCompleted,\n [styles.error]: isError,\n [styles.selected]: isSelected,\n [styles.disabled]: disabled,\n [styles.focused]: focused,\n [styles.vertical]: isVerticalAlign,\n [styles.interactive]: interactive,\n [styles.fullWidth]: fullWidth && isVerticalAlign,\n [styles.horizontal]: !isVerticalAlign,\n })}\n onClick={handleButtonClick}\n onKeyDown={handleKeyDown}\n >\n <div\n className={cn(styles.indicator, {\n [styles.vertical]: isVerticalAlign,\n [styles.interactive]: interactive,\n })}\n >\n <div\n className={cn(styles.option, {\n [styles.unordered]: !ordered,\n [styles.vertical]: isVerticalAlign,\n [styles.error]: isError,\n })}\n >\n {getStepIndicator()}\n </div>\n {isNotLastStep && isVerticalAlign && renderDash()}\n </div>\n <div\n className={cn(styles.textWrapper, styles[`gap-${minSpaceBetweenSteps}`], {\n [styles.vertical]: isVerticalAlign,\n })}\n >\n {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n <div\n className={cn(styles.text, {\n [styles.interactive]: interactive,\n [styles.fullWidth]: fullWidth && isVerticalAlign,\n })}\n onClick={handleTextClick}\n >\n {children}\n </div>\n </div>\n {isNotLastStep && !isVerticalAlign && renderDash()}\n </div>\n );\n};\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"Component.js","sources":["../../../src/components/step/Component.tsx"],"sourcesContent":["import React, { type FC, useRef } from 'react';\nimport cn from 'classnames';\n\nimport { Badge } from '@alfalab/core-components-badge';\nimport { getDataTestId } from '@alfalab/core-components-shared';\nimport { useFocus } from '@alfalab/hooks';\n\nimport { type CommonProps } from '../../types/common-props';\nimport { StepIndicator, type StepIndicatorProps } from '../step-indicator';\n\nimport styles from './index.module.css';\n\ninterface StepProps extends CommonProps {\n /**\n * Номер шага\n */\n stepNumber: number;\n\n /**\n * Маркер того, что текущий шаг выбран\n */\n isSelected: boolean;\n\n /**\n * Маркер того, что текущий шаг доступен для клика\n */\n disabled: boolean;\n\n /**\n * Маркер того, что текущий шаг находится в состоянии \"Positive\"\n */\n isPositive: boolean;\n\n /**\n * Маркер того, что текущий шаг находится в состоянии \"Error\"\n */\n isError: boolean;\n\n /**\n * Маркер того, что текущий шаг находится в состоянии \"isCriticalError\"\n */\n isCriticalError: boolean;\n\n /**\n * Маркер того, что текущий шаг находится в состоянии \"Warning\"\n */\n isWarning: boolean;\n\n /**\n * Маркер того, что текущий шаг находится в состоянии \"Waiting\"\n */\n isWaiting: boolean;\n\n /**\n * Маркер того, что текущий шаг нужно пометить как завершенный\n */\n isStepCompleted: boolean;\n\n /**\n * Свойства кастомного индикатора текущего шага\n */\n customStepIndicator?: StepIndicatorProps | null;\n\n /**\n * Указывает, является ли текущий шаг последним в списке\n */\n isNotLastStep?: boolean;\n\n /**\n * Обработчик нажатия на текущей шаг\n * @param stepNumber - номер шага\n */\n onClick: (stepNumber: number) => void;\n}\n\nexport const Step: FC<StepProps> = ({\n children,\n stepNumber,\n isSelected,\n disabled,\n ordered,\n isPositive,\n isError,\n isCriticalError,\n isWarning,\n isWaiting,\n customStepIndicator,\n isStepCompleted,\n onClick,\n interactive,\n isVerticalAlign,\n isNotLastStep,\n fullWidth,\n minSpaceBetweenSteps = 24,\n completedDashColor,\n dataTestId,\n}) => {\n const stepRef = useRef<HTMLDivElement>(null);\n\n const [focused] = useFocus(stepRef, 'keyboard');\n\n const handleButtonClick = () => {\n if (!disabled && interactive && onClick) {\n onClick(stepNumber);\n }\n };\n\n const handleTextClick = (e: React.MouseEvent<HTMLElement>) => {\n if (!interactive) {\n e.stopPropagation();\n }\n };\n\n const handleKeyDown = (event: React.KeyboardEvent) => {\n if (event.key === 'Enter') {\n handleButtonClick();\n }\n };\n\n const getStepIndicator = () => {\n if (customStepIndicator) {\n return <Badge view='icon' size='l' {...customStepIndicator} />;\n }\n if (isCriticalError) {\n return <StepIndicator view='negative-cross' />;\n }\n if (isError) {\n return <StepIndicator view='negative-alert' />;\n }\n if (isWarning) {\n return <StepIndicator view='attention-alert' />;\n }\n if (isWaiting) {\n return <StepIndicator view='neutral-operation' />;\n }\n if (isPositive) {\n return <StepIndicator view='positive-checkmark' />;\n }\n if (isStepCompleted) {\n return (\n <StepIndicator view='positive-checkmark' className={styles.completedIndicator} />\n );\n }\n if (!ordered) {\n return (\n <div className={styles.checkbox}>\n <span className={styles.dot} />\n </div>\n );\n }\n\n return stepNumber;\n };\n\n const getCustomDashColor = () => {\n if (isStepCompleted && completedDashColor) {\n return {\n borderColor: completedDashColor,\n };\n }\n\n return {};\n };\n\n const renderDash = () => (\n <div\n className={cn(styles.dash, {\n [styles.vertical]: isVerticalAlign,\n [styles.completed]: isStepCompleted,\n })}\n style={{\n ...getCustomDashColor(),\n }}\n />\n );\n\n return (\n <div\n data-test-id={getDataTestId(dataTestId, 'step')}\n role='button'\n tabIndex={0}\n ref={stepRef}\n className={cn(styles.step, {\n [styles.completed]: isStepCompleted,\n [styles.error]: isError,\n [styles.selected]: isSelected,\n [styles.disabled]: disabled,\n [styles.focused]: focused,\n [styles.vertical]: isVerticalAlign,\n [styles.interactive]: interactive,\n [styles.fullWidth]: fullWidth && isVerticalAlign,\n [styles.horizontal]: !isVerticalAlign,\n })}\n onClick={handleButtonClick}\n onKeyDown={handleKeyDown}\n >\n <div\n className={cn(styles.indicator, {\n [styles.vertical]: isVerticalAlign,\n [styles.interactive]: interactive,\n })}\n >\n <div\n className={cn(styles.option, {\n [styles.unordered]: !ordered,\n [styles.vertical]: isVerticalAlign,\n [styles.error]: isError,\n })}\n >\n {getStepIndicator()}\n </div>\n {isNotLastStep && isVerticalAlign && renderDash()}\n </div>\n <div\n className={cn(styles.textWrapper, styles[`gap-${minSpaceBetweenSteps}`], {\n [styles.vertical]: isVerticalAlign,\n })}\n >\n {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n <div\n className={cn(styles.text, {\n [styles.interactive]: interactive,\n [styles.fullWidth]: fullWidth && isVerticalAlign,\n })}\n onClick={handleTextClick}\n >\n {children}\n </div>\n </div>\n {isNotLastStep && !isVerticalAlign && renderDash()}\n </div>\n );\n};\n"],"names":[],"mappings":"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"}
|
|
@@ -51,7 +51,8 @@
|
|
|
51
51
|
font-size: 14px;
|
|
52
52
|
line-height: 20px;
|
|
53
53
|
font-weight: 700;
|
|
54
|
-
|
|
54
|
+
letter-spacing: 0.47px;
|
|
55
|
+
font-family: var(--font-family-alfasans);
|
|
55
56
|
|
|
56
57
|
display: flex;
|
|
57
58
|
align-items: center;
|
|
@@ -108,7 +109,8 @@
|
|
|
108
109
|
font-size: 16px;
|
|
109
110
|
line-height: 24px;
|
|
110
111
|
font-weight: 400;
|
|
111
|
-
|
|
112
|
+
letter-spacing: -0.24px;
|
|
113
|
+
font-family: var(--font-family-alfasans);
|
|
112
114
|
|
|
113
115
|
transition: background 0.2s;
|
|
114
116
|
padding: var(--gap-8);
|
|
@@ -170,8 +172,7 @@
|
|
|
170
172
|
background: initial;
|
|
171
173
|
}
|
|
172
174
|
|
|
173
|
-
.completedIndicator
|
|
174
|
-
color: var(--steps-option-svg-color);
|
|
175
|
+
.completedIndicator[class*='positive-checkmark'] {
|
|
175
176
|
background-color: var(--steps-option-svg-color);
|
|
176
177
|
}
|
|
177
178
|
|
|
@@ -1,4 +1,8 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import { type BadgeProps } from '@alfalab/core-components-badge/moderncssm';
|
|
3
|
+
import { type StatusBadgeProps } from '@alfalab/core-components-status-badge/moderncssm';
|
|
4
|
+
/** @description В `@alfalab/core-components@51.0.0` тип будет изменен на Pick<StatusBadgeProps, 'view' | 'className' | 'colors'> */
|
|
3
5
|
export type StepIndicatorProps = Pick<BadgeProps, 'content' | 'iconColor' | 'className'>;
|
|
4
|
-
|
|
6
|
+
type StatusBadgeIndicatorProps = Pick<StatusBadgeProps, 'view' | 'className' | 'colors'>;
|
|
7
|
+
export declare const StepIndicator: React.FC<StatusBadgeIndicatorProps>;
|
|
8
|
+
export {};
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import cn from 'classnames';
|
|
3
|
-
import {
|
|
3
|
+
import { StatusBadge } from '@alfalab/core-components-status-badge/moderncssm';
|
|
4
4
|
import styles from './index.module.css';
|
|
5
5
|
|
|
6
|
-
const StepIndicator = ({
|
|
6
|
+
const StepIndicator = ({ view, className, colors }) => (React.createElement(StatusBadge, { size: 24, view: view, colors: colors, className: cn(styles.component, className) }));
|
|
7
7
|
|
|
8
8
|
export { StepIndicator };
|
|
9
9
|
//# sourceMappingURL=Component.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Component.js","sources":["../../../src/components/step-indicator/Component.tsx"],"sourcesContent":["import React from 'react';\nimport cn from 'classnames';\n\nimport {
|
|
1
|
+
{"version":3,"file":"Component.js","sources":["../../../src/components/step-indicator/Component.tsx"],"sourcesContent":["import React from 'react';\nimport cn from 'classnames';\n\nimport { type BadgeProps } from '@alfalab/core-components-badge';\nimport { StatusBadge, type StatusBadgeProps } from '@alfalab/core-components-status-badge';\n\nimport styles from './index.module.css';\n\n/** @description В `@alfalab/core-components@51.0.0` тип будет изменен на Pick<StatusBadgeProps, 'view' | 'className' | 'colors'> */\nexport type StepIndicatorProps = Pick<BadgeProps, 'content' | 'iconColor' | 'className'>;\n\ntype StatusBadgeIndicatorProps = Pick<StatusBadgeProps, 'view' | 'className' | 'colors'>;\n\nexport const StepIndicator: React.FC<StatusBadgeIndicatorProps> = ({ view, className, colors }) => (\n <StatusBadge\n size={24}\n view={view}\n colors={colors}\n className={cn(styles.component, className)}\n />\n);\n"],"names":[],"mappings":";;;;;AAaa,MAAA,aAAa,GAAwC,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,MAC1F,KAAC,CAAA,aAAA,CAAA,WAAW,IACR,IAAI,EAAE,EAAE,EACR,IAAI,EAAE,IAAI,EACV,MAAM,EAAE,MAAM,EACd,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE,SAAS,CAAC,EAAA,CAC5C;;;;"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@alfalab/core-components-steps",
|
|
3
|
-
"version": "3.0.
|
|
3
|
+
"version": "3.0.4-alfasans",
|
|
4
4
|
"description": "",
|
|
5
5
|
"keywords": [],
|
|
6
6
|
"license": "MIT",
|
|
@@ -10,10 +10,10 @@
|
|
|
10
10
|
"main": "index.js",
|
|
11
11
|
"module": "./esm/index.js",
|
|
12
12
|
"dependencies": {
|
|
13
|
-
"@alfalab/core-components-badge": "
|
|
14
|
-
"@alfalab/core-components-shared": "
|
|
13
|
+
"@alfalab/core-components-badge": "7.0.2-alfasans",
|
|
14
|
+
"@alfalab/core-components-shared": "2.1.1-alfasans",
|
|
15
|
+
"@alfalab/core-components-status-badge": "3.0.2-alfasans",
|
|
15
16
|
"@alfalab/hooks": "^1.13.1",
|
|
16
|
-
"@alfalab/icons-glyph": "^2.260.0",
|
|
17
17
|
"classnames": "^2.5.1",
|
|
18
18
|
"tslib": "^2.4.0"
|
|
19
19
|
},
|
|
@@ -25,6 +25,6 @@
|
|
|
25
25
|
"access": "public",
|
|
26
26
|
"directory": "dist"
|
|
27
27
|
},
|
|
28
|
-
"themesVersion": "15.0.2",
|
|
29
|
-
"varsVersion": "11.0.2"
|
|
28
|
+
"themesVersion": "15.0.2-alfasans",
|
|
29
|
+
"varsVersion": "11.0.2-alfasans"
|
|
30
30
|
}
|
|
@@ -1,19 +1,16 @@
|
|
|
1
1
|
import React, { type FC, useRef } from 'react';
|
|
2
2
|
import cn from 'classnames';
|
|
3
3
|
|
|
4
|
+
import { Badge } from '@alfalab/core-components-badge';
|
|
4
5
|
import { getDataTestId } from '@alfalab/core-components-shared';
|
|
5
6
|
import { useFocus } from '@alfalab/hooks';
|
|
6
|
-
import { CheckmarkCircleMIcon } from '@alfalab/icons-glyph/CheckmarkCircleMIcon';
|
|
7
|
-
import { ClockMIcon } from '@alfalab/icons-glyph/ClockMIcon';
|
|
8
|
-
import { CrossCompactMIcon } from '@alfalab/icons-glyph/CrossCompactMIcon';
|
|
9
|
-
import { ExclamationCircleMIcon } from '@alfalab/icons-glyph/ExclamationCircleMIcon';
|
|
10
7
|
|
|
11
8
|
import { type CommonProps } from '../../types/common-props';
|
|
12
9
|
import { StepIndicator, type StepIndicatorProps } from '../step-indicator';
|
|
13
10
|
|
|
14
11
|
import styles from './index.module.css';
|
|
15
12
|
|
|
16
|
-
|
|
13
|
+
interface StepProps extends CommonProps {
|
|
17
14
|
/**
|
|
18
15
|
* Номер шага
|
|
19
16
|
*/
|
|
@@ -74,7 +71,7 @@ type StepProps = {
|
|
|
74
71
|
* @param stepNumber - номер шага
|
|
75
72
|
*/
|
|
76
73
|
onClick: (stepNumber: number) => void;
|
|
77
|
-
}
|
|
74
|
+
}
|
|
78
75
|
|
|
79
76
|
export const Step: FC<StepProps> = ({
|
|
80
77
|
children,
|
|
@@ -122,30 +119,26 @@ export const Step: FC<StepProps> = ({
|
|
|
122
119
|
|
|
123
120
|
const getStepIndicator = () => {
|
|
124
121
|
if (customStepIndicator) {
|
|
125
|
-
return <
|
|
122
|
+
return <Badge view='icon' size='l' {...customStepIndicator} />;
|
|
126
123
|
}
|
|
127
124
|
if (isCriticalError) {
|
|
128
|
-
return <StepIndicator
|
|
125
|
+
return <StepIndicator view='negative-cross' />;
|
|
129
126
|
}
|
|
130
127
|
if (isError) {
|
|
131
|
-
return <StepIndicator
|
|
128
|
+
return <StepIndicator view='negative-alert' />;
|
|
132
129
|
}
|
|
133
130
|
if (isWarning) {
|
|
134
|
-
return <StepIndicator
|
|
131
|
+
return <StepIndicator view='attention-alert' />;
|
|
135
132
|
}
|
|
136
133
|
if (isWaiting) {
|
|
137
|
-
return <StepIndicator
|
|
134
|
+
return <StepIndicator view='neutral-operation' />;
|
|
138
135
|
}
|
|
139
136
|
if (isPositive) {
|
|
140
|
-
return <StepIndicator
|
|
137
|
+
return <StepIndicator view='positive-checkmark' />;
|
|
141
138
|
}
|
|
142
139
|
if (isStepCompleted) {
|
|
143
140
|
return (
|
|
144
|
-
<StepIndicator
|
|
145
|
-
iconColor='positive'
|
|
146
|
-
content={<CheckmarkCircleMIcon />}
|
|
147
|
-
className={styles.completedIndicator}
|
|
148
|
-
/>
|
|
141
|
+
<StepIndicator view='positive-checkmark' className={styles.completedIndicator} />
|
|
149
142
|
);
|
|
150
143
|
}
|
|
151
144
|
if (!ordered) {
|
|
@@ -1,18 +1,21 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import cn from 'classnames';
|
|
3
3
|
|
|
4
|
-
import {
|
|
4
|
+
import { type BadgeProps } from '@alfalab/core-components-badge';
|
|
5
|
+
import { StatusBadge, type StatusBadgeProps } from '@alfalab/core-components-status-badge';
|
|
5
6
|
|
|
6
7
|
import styles from './index.module.css';
|
|
7
8
|
|
|
9
|
+
/** @description В `@alfalab/core-components@51.0.0` тип будет изменен на Pick<StatusBadgeProps, 'view' | 'className' | 'colors'> */
|
|
8
10
|
export type StepIndicatorProps = Pick<BadgeProps, 'content' | 'iconColor' | 'className'>;
|
|
9
11
|
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
12
|
+
type StatusBadgeIndicatorProps = Pick<StatusBadgeProps, 'view' | 'className' | 'colors'>;
|
|
13
|
+
|
|
14
|
+
export const StepIndicator: React.FC<StatusBadgeIndicatorProps> = ({ view, className, colors }) => (
|
|
15
|
+
<StatusBadge
|
|
16
|
+
size={24}
|
|
17
|
+
view={view}
|
|
18
|
+
colors={colors}
|
|
15
19
|
className={cn(styles.component, className)}
|
|
16
|
-
content={content}
|
|
17
20
|
/>
|
|
18
21
|
);
|