@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.
Files changed (57) hide show
  1. package/components/step/Component.d.ts +2 -2
  2. package/components/step/Component.js +8 -11
  3. package/components/step/Component.js.map +1 -1
  4. package/components/step/index.css +38 -36
  5. package/components/step/index.module.css.js +1 -1
  6. package/components/step/index.module.css.js.map +1 -1
  7. package/components/step-indicator/Component.d.ts +5 -1
  8. package/components/step-indicator/Component.js +3 -3
  9. package/components/step-indicator/Component.js.map +1 -1
  10. package/components/step-indicator/index.css +1 -1
  11. package/components/step-indicator/index.module.css.js +1 -1
  12. package/cssm/components/step/Component.d.ts +2 -2
  13. package/cssm/components/step/Component.js +8 -11
  14. package/cssm/components/step/Component.js.map +1 -1
  15. package/cssm/components/step/index.module.css +8 -6
  16. package/cssm/components/step-indicator/Component.d.ts +5 -1
  17. package/cssm/components/step-indicator/Component.js +3 -3
  18. package/cssm/components/step-indicator/Component.js.map +1 -1
  19. package/esm/components/step/Component.d.ts +2 -2
  20. package/esm/components/step/Component.js +8 -11
  21. package/esm/components/step/Component.js.map +1 -1
  22. package/esm/components/step/index.css +38 -36
  23. package/esm/components/step/index.module.css.js +1 -1
  24. package/esm/components/step/index.module.css.js.map +1 -1
  25. package/esm/components/step-indicator/Component.d.ts +5 -1
  26. package/esm/components/step-indicator/Component.js +3 -3
  27. package/esm/components/step-indicator/Component.js.map +1 -1
  28. package/esm/components/step-indicator/index.css +1 -1
  29. package/esm/components/step-indicator/index.module.css.js +1 -1
  30. package/esm/index.css +2 -2
  31. package/esm/index.module.css.js +1 -1
  32. package/index.css +2 -2
  33. package/index.module.css.js +1 -1
  34. package/modern/components/step/Component.d.ts +2 -2
  35. package/modern/components/step/Component.js +8 -11
  36. package/modern/components/step/Component.js.map +1 -1
  37. package/modern/components/step/index.css +38 -36
  38. package/modern/components/step/index.module.css.js +1 -1
  39. package/modern/components/step/index.module.css.js.map +1 -1
  40. package/modern/components/step-indicator/Component.d.ts +5 -1
  41. package/modern/components/step-indicator/Component.js +2 -2
  42. package/modern/components/step-indicator/Component.js.map +1 -1
  43. package/modern/components/step-indicator/index.css +1 -1
  44. package/modern/components/step-indicator/index.module.css.js +1 -1
  45. package/modern/index.css +2 -2
  46. package/modern/index.module.css.js +1 -1
  47. package/moderncssm/components/step/Component.d.ts +2 -2
  48. package/moderncssm/components/step/Component.js +8 -11
  49. package/moderncssm/components/step/Component.js.map +1 -1
  50. package/moderncssm/components/step/index.module.css +5 -4
  51. package/moderncssm/components/step-indicator/Component.d.ts +5 -1
  52. package/moderncssm/components/step-indicator/Component.js +2 -2
  53. package/moderncssm/components/step-indicator/Component.js.map +1 -1
  54. package/package.json +6 -6
  55. package/src/components/step/Component.tsx +10 -17
  56. package/src/components/step/index.module.css +1 -2
  57. 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-system:
27
- system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Helvetica, sans-serif;
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
- .steps__step_ywsii {
37
+ .steps__step_u8o8k {
37
38
  display: flex;
38
39
  outline: none;
39
40
  }
40
- .steps__step_ywsii.steps__horizontal_ywsii {
41
+ .steps__step_u8o8k.steps__horizontal_u8o8k {
41
42
  flex-grow: 1;
42
43
  }
43
- .steps__step_ywsii:not(.steps__vertical_ywsii) {
44
+ .steps__step_u8o8k:not(.steps__vertical_u8o8k) {
44
45
  align-items: center;
45
46
  }
46
- .steps__step_ywsii:last-of-type .steps__textWrapper_ywsii.steps__vertical_ywsii {
47
+ .steps__step_u8o8k:last-of-type .steps__textWrapper_u8o8k.steps__vertical_u8o8k {
47
48
  margin-bottom: var(--gap-0);
48
49
  }
49
- .steps__step_ywsii.steps__interactive_ywsii:not(.steps__disabled_ywsii):hover {
50
+ .steps__step_u8o8k.steps__interactive_u8o8k:not(.steps__disabled_u8o8k):hover {
50
51
  cursor: pointer;
51
52
  }
52
- .steps__step_ywsii.steps__disabled_ywsii:hover .steps__text_ywsii {
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
- .steps__step_ywsii.steps__disabled_ywsii .steps__indicator_ywsii {
57
+ .steps__step_u8o8k.steps__disabled_u8o8k .steps__indicator_u8o8k {
57
58
  cursor: inherit;
58
59
  }
59
- .steps__indicator_ywsii {
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
- .steps__indicator_ywsii.steps__vertical_ywsii {
66
+ .steps__indicator_u8o8k.steps__vertical_u8o8k {
66
67
  flex-direction: column;
67
68
  margin-right: var(--gap-8);
68
69
  }
69
- .steps__option_ywsii {
70
+ .steps__option_u8o8k {
70
71
  font-size: 14px;
71
72
  line-height: 20px;
72
73
  font-weight: 700;
73
- font-family: var(--font-family-system);
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
- .steps__option_ywsii.steps__vertical_ywsii {
86
+ .steps__option_u8o8k.steps__vertical_u8o8k {
85
87
  margin-top: var(--gap-8);
86
88
  }
87
- .steps__dash_ywsii {
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
- .steps__dash_ywsii.steps__completed_ywsii {
95
+ .steps__dash_u8o8k.steps__completed_u8o8k {
94
96
  border-top: var(--steps-dash-border);
95
97
  }
96
- .steps__dash_ywsii.steps__vertical_ywsii {
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
- .steps__dash_ywsii.steps__completed_ywsii.steps__vertical_ywsii {
107
+ .steps__dash_u8o8k.steps__completed_u8o8k.steps__vertical_u8o8k {
106
108
  border-left: var(--steps-dash-border);
107
109
  }
108
- .steps__textWrapper_ywsii.steps__vertical_ywsii {
110
+ .steps__textWrapper_u8o8k.steps__vertical_u8o8k {
109
111
  min-height: 48px;
110
112
  }
111
- .steps__textWrapper_ywsii.steps__vertical_ywsii.steps__gap-24_ywsii {
113
+ .steps__textWrapper_u8o8k.steps__vertical_u8o8k.steps__gap-24_u8o8k {
112
114
  margin-bottom: var(--gap-8);
113
115
  }
114
- .steps__textWrapper_ywsii.steps__vertical_ywsii.steps__gap-32_ywsii {
116
+ .steps__textWrapper_u8o8k.steps__vertical_u8o8k.steps__gap-32_u8o8k {
115
117
  margin-bottom: var(--gap-16);
116
118
  }
117
- .steps__text_ywsii {
119
+ .steps__text_u8o8k {
118
120
  font-size: 16px;
119
121
  line-height: 24px;
120
122
  font-weight: 400;
121
- font-family: var(--font-family-system);
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
- .steps__text_ywsii.steps__interactive_ywsii:not(.steps__disabled_ywsii):hover {
133
+ .steps__text_u8o8k.steps__interactive_u8o8k:not(.steps__disabled_u8o8k):hover {
131
134
  background: var(--color-light-transparent-default-hover);
132
135
  }
133
- .steps__text_ywsii.steps__interactive_ywsii:not(.steps__disabled_ywsii):active {
136
+ .steps__text_u8o8k.steps__interactive_u8o8k:not(.steps__disabled_u8o8k):active {
134
137
  background: var(--color-light-transparent-default-press);
135
138
  }
136
- .steps__focused_ywsii {
139
+ .steps__focused_u8o8k {
137
140
  outline: var(--gap-2) solid var(--focus-color);
138
141
  outline-offset: var(--gap-2);
139
142
  }
140
- .steps__selected_ywsii .steps__text_ywsii {
143
+ .steps__selected_u8o8k .steps__text_u8o8k {
141
144
  color: var(--color-light-text-primary);
142
145
  }
143
- .steps__selected_ywsii .steps__option_ywsii {
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
- .steps__checkbox_ywsii {
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
- .steps__dot_ywsii {
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
- .steps__selected_ywsii .steps__checkbox_ywsii {
165
+ .steps__selected_u8o8k .steps__checkbox_u8o8k {
163
166
  border: 2px solid var(--color-light-neutral-translucent-1300);
164
167
  }
165
- .steps__selected_ywsii .steps__checkbox_ywsii .steps__dot_ywsii {
168
+ .steps__selected_u8o8k .steps__checkbox_u8o8k .steps__dot_u8o8k {
166
169
  background: var(--color-light-neutral-translucent-1300);
167
170
  }
168
- .steps__option_ywsii:not(.steps__error_ywsii).steps__unordered_ywsii {
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
- .steps__completedIndicator_ywsii > [class*='positive'] {
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
- .steps__fullWidth_ywsii {
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":"steps__step_ywsii","horizontal":"steps__horizontal_ywsii","vertical":"steps__vertical_ywsii","textWrapper":"steps__textWrapper_ywsii","interactive":"steps__interactive_ywsii","disabled":"steps__disabled_ywsii","text":"steps__text_ywsii","indicator":"steps__indicator_ywsii","option":"steps__option_ywsii","dash":"steps__dash_ywsii","completed":"steps__completed_ywsii","gap-24":"steps__gap-24_ywsii","gap-32":"steps__gap-32_ywsii","focused":"steps__focused_ywsii","selected":"steps__selected_ywsii","checkbox":"steps__checkbox_ywsii","dot":"steps__dot_ywsii","error":"steps__error_ywsii","unordered":"steps__unordered_ywsii","completedIndicator":"steps__completedIndicator_ywsii","fullWidth":"steps__fullWidth_ywsii"};
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 > [class*='positive'] {\n color: var(--steps-option-svg-color);\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
+ {"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
- export declare const StepIndicator: React.FC<StepIndicatorProps>;
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 { Badge } from '@alfalab/core-components-badge/modern';
3
+ import { StatusBadge } from '@alfalab/core-components-status-badge/modern';
4
4
  import styles from './index.module.css.js';
5
5
 
6
- const StepIndicator = ({ content, iconColor, className }) => (React.createElement(Badge, { size: 'l', view: 'icon', iconColor: iconColor, className: cn(styles.component, className), content: content }));
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 { Badge, type BadgeProps } from '@alfalab/core-components-badge';\n\nimport styles from './index.module.css';\n\nexport type StepIndicatorProps = Pick<BadgeProps, 'content' | 'iconColor' | 'className'>;\n\nexport const StepIndicator: React.FC<StepIndicatorProps> = ({ content, iconColor, className }) => (\n <Badge\n size='l'\n view='icon'\n iconColor={iconColor}\n className={cn(styles.component, className)}\n content={content}\n />\n);\n"],"names":[],"mappings":";;;;;MASa,aAAa,GAAiC,CAAC,EAAE,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,MACzF,oBAAC,KAAK,EAAA,EACF,IAAI,EAAC,GAAG,EACR,IAAI,EAAC,MAAM,EACX,SAAS,EAAE,SAAS,EACpB,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE,SAAS,CAAC,EAC1C,OAAO,EAAE,OAAO,EAClB,CAAA;;;;"}
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;;;;"}
@@ -1,6 +1,6 @@
1
1
  :root {
2
2
  --gap-0: 0px;
3
3
  }
4
- .steps__component_1b5b5.steps__component_1b5b5 {
4
+ .steps__component_5xchg.steps__component_5xchg {
5
5
  padding: var(--gap-0);
6
6
  }
@@ -1,6 +1,6 @@
1
1
  import './index.css';
2
2
 
3
- const styles = {"component":"steps__component_1b5b5"};
3
+ const styles = {"component":"steps__component_5xchg"};
4
4
 
5
5
  export { styles as default };
6
6
  //# sourceMappingURL=index.module.css.js.map
package/modern/index.css CHANGED
@@ -1,9 +1,9 @@
1
- .steps__component_fsruq {
1
+ .steps__component_1w1wc {
2
2
  display: flex;
3
3
  align-items: center;
4
4
  flex-direction: row;
5
5
  }
6
- .steps__component_fsruq.steps__vertical_fsruq {
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":"steps__component_fsruq","vertical":"steps__vertical_fsruq"};
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
- type StepProps = {
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
- } & CommonProps;
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(StepIndicator, { ...customStepIndicator });
29
+ return React.createElement(Badge, { view: 'icon', size: 'l', ...customStepIndicator });
33
30
  }
34
31
  if (isCriticalError) {
35
- return React.createElement(StepIndicator, { iconColor: 'negative', content: React.createElement(CrossCompactMIcon, null) });
32
+ return React.createElement(StepIndicator, { view: 'negative-cross' });
36
33
  }
37
34
  if (isError) {
38
- return React.createElement(StepIndicator, { iconColor: 'negative', content: React.createElement(ExclamationCircleMIcon, null) });
35
+ return React.createElement(StepIndicator, { view: 'negative-alert' });
39
36
  }
40
37
  if (isWarning) {
41
- return React.createElement(StepIndicator, { iconColor: 'attention', content: React.createElement(ExclamationCircleMIcon, null) });
38
+ return React.createElement(StepIndicator, { view: 'attention-alert' });
42
39
  }
43
40
  if (isWaiting) {
44
- return React.createElement(StepIndicator, { iconColor: 'secondary', content: React.createElement(ClockMIcon, null) });
41
+ return React.createElement(StepIndicator, { view: 'neutral-operation' });
45
42
  }
46
43
  if (isPositive) {
47
- return React.createElement(StepIndicator, { iconColor: 'positive', content: React.createElement(CheckmarkCircleMIcon, null) });
44
+ return React.createElement(StepIndicator, { view: 'positive-checkmark' });
48
45
  }
49
46
  if (isStepCompleted) {
50
- return (React.createElement(StepIndicator, { iconColor: 'positive', content: React.createElement(CheckmarkCircleMIcon, null), className: styles.completedIndicator }));
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":";;;;;;;;;;;MA8Ea,IAAI,GAAkB,CAAC,EAChC,QAAQ,EACR,UAAU,EACV,UAAU,EACV,QAAQ,EACR,OAAO,EACP,UAAU,EACV,OAAO,EACP,eAAe,EACf,SAAS,EACT,SAAS,EACT,mBAAmB,EACnB,eAAe,EACf,OAAO,EACP,WAAW,EACX,eAAe,EACf,aAAa,EACb,SAAS,EACT,oBAAoB,GAAG,EAAE,EACzB,kBAAkB,EAClB,UAAU,GACb,KAAI;AACD,IAAA,MAAM,OAAO,GAAG,MAAM,CAAiB,IAAI,CAAC;IAE5C,MAAM,CAAC,OAAO,CAAC,GAAG,QAAQ,CAAC,OAAO,EAAE,UAAU,CAAC;IAE/C,MAAM,iBAAiB,GAAG,MAAK;AAC3B,QAAA,IAAI,CAAC,QAAQ,IAAI,WAAW,IAAI,OAAO,EAAE;YACrC,OAAO,CAAC,UAAU,CAAC;;AAE3B,KAAC;AAED,IAAA,MAAM,eAAe,GAAG,CAAC,CAAgC,KAAI;QACzD,IAAI,CAAC,WAAW,EAAE;YACd,CAAC,CAAC,eAAe,EAAE;;AAE3B,KAAC;AAED,IAAA,MAAM,aAAa,GAAG,CAAC,KAA0B,KAAI;AACjD,QAAA,IAAI,KAAK,CAAC,GAAG,KAAK,OAAO,EAAE;AACvB,YAAA,iBAAiB,EAAE;;AAE3B,KAAC;IAED,MAAM,gBAAgB,GAAG,MAAK;QAC1B,IAAI,mBAAmB,EAAE;AACrB,YAAA,OAAO,KAAC,CAAA,aAAA,CAAA,aAAa,EAAK,EAAA,GAAA,mBAAmB,GAAI;;QAErD,IAAI,eAAe,EAAE;AACjB,YAAA,OAAO,KAAC,CAAA,aAAA,CAAA,aAAa,EAAC,EAAA,SAAS,EAAC,UAAU,EAAC,OAAO,EAAE,KAAA,CAAA,aAAA,CAAC,iBAAiB,EAAA,IAAA,CAAG,GAAI;;QAEjF,IAAI,OAAO,EAAE;AACT,YAAA,OAAO,KAAC,CAAA,aAAA,CAAA,aAAa,EAAC,EAAA,SAAS,EAAC,UAAU,EAAC,OAAO,EAAE,KAAA,CAAA,aAAA,CAAC,sBAAsB,EAAA,IAAA,CAAG,GAAI;;QAEtF,IAAI,SAAS,EAAE;AACX,YAAA,OAAO,KAAC,CAAA,aAAA,CAAA,aAAa,EAAC,EAAA,SAAS,EAAC,WAAW,EAAC,OAAO,EAAE,KAAA,CAAA,aAAA,CAAC,sBAAsB,EAAA,IAAA,CAAG,GAAI;;QAEvF,IAAI,SAAS,EAAE;AACX,YAAA,OAAO,KAAC,CAAA,aAAA,CAAA,aAAa,EAAC,EAAA,SAAS,EAAC,WAAW,EAAC,OAAO,EAAE,KAAA,CAAA,aAAA,CAAC,UAAU,EAAA,IAAA,CAAG,GAAI;;QAE3E,IAAI,UAAU,EAAE;AACZ,YAAA,OAAO,KAAC,CAAA,aAAA,CAAA,aAAa,EAAC,EAAA,SAAS,EAAC,UAAU,EAAC,OAAO,EAAE,KAAA,CAAA,aAAA,CAAC,oBAAoB,EAAA,IAAA,CAAG,GAAI;;QAEpF,IAAI,eAAe,EAAE;YACjB,QACI,oBAAC,aAAa,EAAA,EACV,SAAS,EAAC,UAAU,EACpB,OAAO,EAAE,oBAAC,oBAAoB,EAAA,IAAA,CAAG,EACjC,SAAS,EAAE,MAAM,CAAC,kBAAkB,EACtC,CAAA;;QAGV,IAAI,CAAC,OAAO,EAAE;AACV,YAAA,QACI,KAAK,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,SAAS,EAAE,MAAM,CAAC,QAAQ,EAAA;gBAC3B,KAAM,CAAA,aAAA,CAAA,MAAA,EAAA,EAAA,SAAS,EAAE,MAAM,CAAC,GAAG,EAAI,CAAA,CAC7B;;AAId,QAAA,OAAO,UAAU;AACrB,KAAC;IAED,MAAM,kBAAkB,GAAG,MAAK;AAC5B,QAAA,IAAI,eAAe,IAAI,kBAAkB,EAAE;YACvC,OAAO;AACH,gBAAA,WAAW,EAAE,kBAAkB;aAClC;;AAGL,QAAA,OAAO,EAAE;AACb,KAAC;AAED,IAAA,MAAM,UAAU,GAAG,OACf,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EACI,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE;AACvB,YAAA,CAAC,MAAM,CAAC,QAAQ,GAAG,eAAe;AAClC,YAAA,CAAC,MAAM,CAAC,SAAS,GAAG,eAAe;SACtC,CAAC,EACF,KAAK,EAAE;AACH,YAAA,GAAG,kBAAkB,EAAE;AAC1B,SAAA,EAAA,CACH,CACL;AAED,IAAA,QACI,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,cAAA,EACkB,aAAa,CAAC,UAAU,EAAE,MAAM,CAAC,EAC/C,IAAI,EAAC,QAAQ,EACb,QAAQ,EAAE,CAAC,EACX,GAAG,EAAE,OAAO,EACZ,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE;AACvB,YAAA,CAAC,MAAM,CAAC,SAAS,GAAG,eAAe;AACnC,YAAA,CAAC,MAAM,CAAC,KAAK,GAAG,OAAO;AACvB,YAAA,CAAC,MAAM,CAAC,QAAQ,GAAG,UAAU;AAC7B,YAAA,CAAC,MAAM,CAAC,QAAQ,GAAG,QAAQ;AAC3B,YAAA,CAAC,MAAM,CAAC,OAAO,GAAG,OAAO;AACzB,YAAA,CAAC,MAAM,CAAC,QAAQ,GAAG,eAAe;AAClC,YAAA,CAAC,MAAM,CAAC,WAAW,GAAG,WAAW;AACjC,YAAA,CAAC,MAAM,CAAC,SAAS,GAAG,SAAS,IAAI,eAAe;AAChD,YAAA,CAAC,MAAM,CAAC,UAAU,GAAG,CAAC,eAAe;AACxC,SAAA,CAAC,EACF,OAAO,EAAE,iBAAiB,EAC1B,SAAS,EAAE,aAAa,EAAA;AAExB,QAAA,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EACI,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE;AAC5B,gBAAA,CAAC,MAAM,CAAC,QAAQ,GAAG,eAAe;AAClC,gBAAA,CAAC,MAAM,CAAC,WAAW,GAAG,WAAW;aACpC,CAAC,EAAA;AAEF,YAAA,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EACI,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,EAAE;AACzB,oBAAA,CAAC,MAAM,CAAC,SAAS,GAAG,CAAC,OAAO;AAC5B,oBAAA,CAAC,MAAM,CAAC,QAAQ,GAAG,eAAe;AAClC,oBAAA,CAAC,MAAM,CAAC,KAAK,GAAG,OAAO;iBAC1B,CAAC,EAAA,EAED,gBAAgB,EAAE,CACjB;AACL,YAAA,aAAa,IAAI,eAAe,IAAI,UAAU,EAAE,CAC/C;AACN,QAAA,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EACI,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,CAAA,IAAA,EAAO,oBAAoB,CAAA,CAAE,CAAC,EAAE;AACrE,gBAAA,CAAC,MAAM,CAAC,QAAQ,GAAG,eAAe;aACrC,CAAC,EAAA;AAGF,YAAA,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EACI,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE;AACvB,oBAAA,CAAC,MAAM,CAAC,WAAW,GAAG,WAAW;AACjC,oBAAA,CAAC,MAAM,CAAC,SAAS,GAAG,SAAS,IAAI,eAAe;AACnD,iBAAA,CAAC,EACF,OAAO,EAAE,eAAe,EAEvB,EAAA,QAAQ,CACP,CACJ;QACL,aAAa,IAAI,CAAC,eAAe,IAAI,UAAU,EAAE,CAChD;AAEd;;;;"}
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
- font-family: var(--font-family-system);
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
- font-family: var(--font-family-system);
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 > [class*='positive'] {
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
- export declare const StepIndicator: React.FC<StepIndicatorProps>;
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 { Badge } from '@alfalab/core-components-badge/moderncssm';
3
+ import { StatusBadge } from '@alfalab/core-components-status-badge/moderncssm';
4
4
  import styles from './index.module.css';
5
5
 
6
- const StepIndicator = ({ content, iconColor, className }) => (React.createElement(Badge, { size: 'l', view: 'icon', iconColor: iconColor, className: cn(styles.component, className), content: content }));
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 { Badge, type BadgeProps } from '@alfalab/core-components-badge';\n\nimport styles from './index.module.css';\n\nexport type StepIndicatorProps = Pick<BadgeProps, 'content' | 'iconColor' | 'className'>;\n\nexport const StepIndicator: React.FC<StepIndicatorProps> = ({ content, iconColor, className }) => (\n <Badge\n size='l'\n view='icon'\n iconColor={iconColor}\n className={cn(styles.component, className)}\n content={content}\n />\n);\n"],"names":[],"mappings":";;;;;MASa,aAAa,GAAiC,CAAC,EAAE,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,MACzF,oBAAC,KAAK,EAAA,EACF,IAAI,EAAC,GAAG,EACR,IAAI,EAAC,MAAM,EACX,SAAS,EAAE,SAAS,EACpB,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE,SAAS,CAAC,EAC1C,OAAO,EAAE,OAAO,EAClB,CAAA;;;;"}
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",
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": "^7.0.2",
14
- "@alfalab/core-components-shared": "^2.1.1",
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
- type StepProps = {
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
- } & CommonProps;
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 <StepIndicator {...customStepIndicator} />;
122
+ return <Badge view='icon' size='l' {...customStepIndicator} />;
126
123
  }
127
124
  if (isCriticalError) {
128
- return <StepIndicator iconColor='negative' content={<CrossCompactMIcon />} />;
125
+ return <StepIndicator view='negative-cross' />;
129
126
  }
130
127
  if (isError) {
131
- return <StepIndicator iconColor='negative' content={<ExclamationCircleMIcon />} />;
128
+ return <StepIndicator view='negative-alert' />;
132
129
  }
133
130
  if (isWarning) {
134
- return <StepIndicator iconColor='attention' content={<ExclamationCircleMIcon />} />;
131
+ return <StepIndicator view='attention-alert' />;
135
132
  }
136
133
  if (isWaiting) {
137
- return <StepIndicator iconColor='secondary' content={<ClockMIcon />} />;
134
+ return <StepIndicator view='neutral-operation' />;
138
135
  }
139
136
  if (isPositive) {
140
- return <StepIndicator iconColor='positive' content={<CheckmarkCircleMIcon />} />;
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) {
@@ -170,8 +170,7 @@
170
170
  background: unset;
171
171
  }
172
172
 
173
- .completedIndicator > [class*='positive'] {
174
- color: var(--steps-option-svg-color);
173
+ .completedIndicator[class*='positive-checkmark'] {
175
174
  background-color: var(--steps-option-svg-color);
176
175
  }
177
176
 
@@ -1,18 +1,21 @@
1
1
  import React from 'react';
2
2
  import cn from 'classnames';
3
3
 
4
- import { Badge, type BadgeProps } from '@alfalab/core-components-badge';
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
- export const StepIndicator: React.FC<StepIndicatorProps> = ({ content, iconColor, className }) => (
11
- <Badge
12
- size='l'
13
- view='icon'
14
- iconColor={iconColor}
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
  );