@salutejs/plasma-new-hope 0.178.0-dev.0 → 0.179.0-canary.1500.11582881437.0
Sign up to get free protection for your applications and to get access to all the features.
- package/cjs/components/Badge/Badge.css +2 -0
- package/cjs/components/Badge/Badge.js +17 -4
- package/cjs/components/Badge/Badge.js.map +1 -1
- package/cjs/components/Badge/Badge.tokens.js +2 -1
- package/cjs/components/Badge/Badge.tokens.js.map +1 -1
- package/cjs/components/Badge/variations/_truncate/base.js +9 -0
- package/cjs/components/Badge/variations/_truncate/base.js.map +1 -0
- package/cjs/components/Badge/variations/_truncate/base_nf9u2h.css +1 -0
- package/cjs/components/Tabs/tokens.js +2 -1
- package/cjs/components/Tabs/tokens.js.map +1 -1
- package/cjs/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.css +7 -5
- package/cjs/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.js +14 -3
- package/cjs/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.js.map +1 -1
- package/cjs/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.styles.js +1 -1
- package/cjs/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.styles.js.map +1 -1
- package/cjs/components/Tabs/ui/horizontal/HorizontalTabItem/{HorizontalTabItem.styles_hfqv5b.css → HorizontalTabItem.styles_1vj7dbl.css} +1 -1
- package/cjs/components/Tabs/ui/horizontal/HorizontalTabItem/variations/_truncate/base.js +9 -0
- package/cjs/components/Tabs/ui/horizontal/HorizontalTabItem/variations/_truncate/base.js.map +1 -0
- package/cjs/components/Tabs/ui/horizontal/HorizontalTabItem/variations/_truncate/base_1b34xv3.css +1 -0
- package/cjs/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.css +7 -5
- package/cjs/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.js +14 -3
- package/cjs/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.js.map +1 -1
- package/cjs/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.styles.js +1 -1
- package/cjs/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.styles.js.map +1 -1
- package/cjs/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.styles_hh65kv.css +5 -0
- package/cjs/components/Tabs/ui/vertical/VerticalTabItem/variations/_truncate/base.js +9 -0
- package/cjs/components/Tabs/ui/vertical/VerticalTabItem/variations/_truncate/base.js.map +1 -0
- package/cjs/components/Tabs/ui/vertical/VerticalTabItem/variations/_truncate/base_1nwonlh.css +1 -0
- package/cjs/index.css +16 -10
- package/emotion/cjs/components/Badge/Badge.js +22 -4
- package/emotion/cjs/components/Badge/Badge.tokens.js +2 -1
- package/emotion/cjs/components/Badge/variations/_truncate/base.js +10 -0
- package/emotion/cjs/components/Badge/variations/_truncate/tokens.json +1 -0
- package/emotion/cjs/components/Tabs/tokens.js +2 -1
- package/emotion/cjs/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.js +19 -3
- package/emotion/cjs/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.styles.js +6 -6
- package/emotion/cjs/components/Tabs/ui/horizontal/HorizontalTabItem/variations/_truncate/base.js +10 -0
- package/emotion/cjs/components/Tabs/ui/horizontal/HorizontalTabItem/variations/_truncate/tokens.json +1 -0
- package/emotion/cjs/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.js +19 -3
- package/emotion/cjs/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.styles.js +6 -6
- package/emotion/cjs/components/Tabs/ui/vertical/VerticalTabItem/variations/_truncate/base.js +10 -0
- package/emotion/cjs/components/Tabs/ui/vertical/VerticalTabItem/variations/_truncate/tokens.json +1 -0
- package/emotion/cjs/examples/plasma_b2c/components/Badge/Badge.config.js +17 -14
- package/emotion/cjs/examples/plasma_b2c/components/Badge/Badge.stories.tsx +5 -1
- package/emotion/cjs/examples/plasma_b2c/components/Tabs/Tabs.stories.tsx +51 -19
- package/emotion/cjs/examples/plasma_b2c/components/Tabs/horizontal/HorizontalTabItem.config.js +18 -15
- package/emotion/cjs/examples/plasma_b2c/components/Tabs/vertical/VerticalTabItem.config.js +9 -6
- package/emotion/cjs/examples/plasma_web/components/Tabs/Tabs.stories.tsx +51 -19
- package/emotion/cjs/examples/plasma_web/components/Tabs/horizontal/HorizontalTabItem.config.js +18 -15
- package/emotion/cjs/examples/plasma_web/components/Tabs/vertical/VerticalTabItem.config.js +9 -6
- package/emotion/es/components/Badge/Badge.js +23 -4
- package/emotion/es/components/Badge/Badge.tokens.js +2 -1
- package/emotion/es/components/Badge/variations/_truncate/base.js +4 -0
- package/emotion/es/components/Badge/variations/_truncate/tokens.json +1 -0
- package/emotion/es/components/Tabs/tokens.js +2 -1
- package/emotion/es/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.js +20 -3
- package/emotion/es/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.styles.js +6 -6
- package/emotion/es/components/Tabs/ui/horizontal/HorizontalTabItem/variations/_truncate/base.js +4 -0
- package/emotion/es/components/Tabs/ui/horizontal/HorizontalTabItem/variations/_truncate/tokens.json +1 -0
- package/emotion/es/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.js +20 -3
- package/emotion/es/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.styles.js +6 -6
- package/emotion/es/components/Tabs/ui/vertical/VerticalTabItem/variations/_truncate/base.js +4 -0
- package/emotion/es/components/Tabs/ui/vertical/VerticalTabItem/variations/_truncate/tokens.json +1 -0
- package/emotion/es/examples/plasma_b2c/components/Badge/Badge.config.js +17 -14
- package/emotion/es/examples/plasma_b2c/components/Badge/Badge.stories.tsx +5 -1
- package/emotion/es/examples/plasma_b2c/components/Tabs/Tabs.stories.tsx +51 -19
- package/emotion/es/examples/plasma_b2c/components/Tabs/horizontal/HorizontalTabItem.config.js +18 -15
- package/emotion/es/examples/plasma_b2c/components/Tabs/vertical/VerticalTabItem.config.js +9 -6
- package/emotion/es/examples/plasma_web/components/Tabs/Tabs.stories.tsx +51 -19
- package/emotion/es/examples/plasma_web/components/Tabs/horizontal/HorizontalTabItem.config.js +18 -15
- package/emotion/es/examples/plasma_web/components/Tabs/vertical/VerticalTabItem.config.js +9 -6
- package/es/components/Badge/Badge.css +2 -0
- package/es/components/Badge/Badge.js +18 -5
- package/es/components/Badge/Badge.js.map +1 -1
- package/es/components/Badge/Badge.tokens.js +2 -1
- package/es/components/Badge/Badge.tokens.js.map +1 -1
- package/es/components/Badge/variations/_truncate/base.js +5 -0
- package/es/components/Badge/variations/_truncate/base.js.map +1 -0
- package/es/components/Badge/variations/_truncate/base_nf9u2h.css +1 -0
- package/es/components/Tabs/tokens.js +2 -1
- package/es/components/Tabs/tokens.js.map +1 -1
- package/es/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.css +7 -5
- package/es/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.js +15 -4
- package/es/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.js.map +1 -1
- package/es/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.styles.js +1 -1
- package/es/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.styles.js.map +1 -1
- package/es/components/Tabs/ui/horizontal/HorizontalTabItem/{HorizontalTabItem.styles_hfqv5b.css → HorizontalTabItem.styles_1vj7dbl.css} +1 -1
- package/es/components/Tabs/ui/horizontal/HorizontalTabItem/variations/_truncate/base.js +5 -0
- package/es/components/Tabs/ui/horizontal/HorizontalTabItem/variations/_truncate/base.js.map +1 -0
- package/es/components/Tabs/ui/horizontal/HorizontalTabItem/variations/_truncate/base_1b34xv3.css +1 -0
- package/es/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.css +7 -5
- package/es/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.js +15 -4
- package/es/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.js.map +1 -1
- package/es/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.styles.js +1 -1
- package/es/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.styles.js.map +1 -1
- package/es/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.styles_hh65kv.css +5 -0
- package/es/components/Tabs/ui/vertical/VerticalTabItem/variations/_truncate/base.js +5 -0
- package/es/components/Tabs/ui/vertical/VerticalTabItem/variations/_truncate/base.js.map +1 -0
- package/es/components/Tabs/ui/vertical/VerticalTabItem/variations/_truncate/base_1nwonlh.css +1 -0
- package/es/index.css +16 -10
- package/package.json +2 -2
- package/styled-components/cjs/components/Badge/Badge.js +22 -4
- package/styled-components/cjs/components/Badge/Badge.tokens.js +2 -1
- package/styled-components/cjs/components/Badge/variations/_truncate/base.js +10 -0
- package/styled-components/cjs/components/Badge/variations/_truncate/tokens.json +1 -0
- package/styled-components/cjs/components/Tabs/tokens.js +2 -1
- package/styled-components/cjs/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.js +19 -3
- package/styled-components/cjs/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.styles.js +1 -1
- package/styled-components/cjs/components/Tabs/ui/horizontal/HorizontalTabItem/variations/_truncate/base.js +10 -0
- package/styled-components/cjs/components/Tabs/ui/horizontal/HorizontalTabItem/variations/_truncate/tokens.json +1 -0
- package/styled-components/cjs/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.js +19 -3
- package/styled-components/cjs/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.styles.js +2 -2
- package/styled-components/cjs/components/Tabs/ui/vertical/VerticalTabItem/variations/_truncate/base.js +10 -0
- package/styled-components/cjs/components/Tabs/ui/vertical/VerticalTabItem/variations/_truncate/tokens.json +1 -0
- package/styled-components/cjs/examples/plasma_b2c/components/Badge/Badge.config.js +3 -0
- package/styled-components/cjs/examples/plasma_b2c/components/Badge/Badge.stories.tsx +5 -1
- package/styled-components/cjs/examples/plasma_b2c/components/Tabs/Tabs.stories.tsx +51 -19
- package/styled-components/cjs/examples/plasma_b2c/components/Tabs/horizontal/HorizontalTabItem.config.js +3 -0
- package/styled-components/cjs/examples/plasma_b2c/components/Tabs/vertical/VerticalTabItem.config.js +3 -0
- package/styled-components/cjs/examples/plasma_web/components/Tabs/Tabs.stories.tsx +51 -19
- package/styled-components/cjs/examples/plasma_web/components/Tabs/horizontal/HorizontalTabItem.config.js +3 -0
- package/styled-components/cjs/examples/plasma_web/components/Tabs/vertical/VerticalTabItem.config.js +3 -0
- package/styled-components/es/components/Badge/Badge.js +23 -4
- package/styled-components/es/components/Badge/Badge.tokens.js +2 -1
- package/styled-components/es/components/Badge/variations/_truncate/base.js +4 -0
- package/styled-components/es/components/Badge/variations/_truncate/tokens.json +1 -0
- package/styled-components/es/components/Tabs/tokens.js +2 -1
- package/styled-components/es/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.js +20 -3
- package/styled-components/es/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.styles.js +1 -1
- package/styled-components/es/components/Tabs/ui/horizontal/HorizontalTabItem/variations/_truncate/base.js +4 -0
- package/styled-components/es/components/Tabs/ui/horizontal/HorizontalTabItem/variations/_truncate/tokens.json +1 -0
- package/styled-components/es/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.js +20 -3
- package/styled-components/es/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.styles.js +2 -2
- package/styled-components/es/components/Tabs/ui/vertical/VerticalTabItem/variations/_truncate/base.js +4 -0
- package/styled-components/es/components/Tabs/ui/vertical/VerticalTabItem/variations/_truncate/tokens.json +1 -0
- package/styled-components/es/examples/plasma_b2c/components/Badge/Badge.config.js +3 -0
- package/styled-components/es/examples/plasma_b2c/components/Badge/Badge.stories.tsx +5 -1
- package/styled-components/es/examples/plasma_b2c/components/Tabs/Tabs.stories.tsx +51 -19
- package/styled-components/es/examples/plasma_b2c/components/Tabs/horizontal/HorizontalTabItem.config.js +3 -0
- package/styled-components/es/examples/plasma_b2c/components/Tabs/vertical/VerticalTabItem.config.js +3 -0
- package/styled-components/es/examples/plasma_web/components/Tabs/Tabs.stories.tsx +51 -19
- package/styled-components/es/examples/plasma_web/components/Tabs/horizontal/HorizontalTabItem.config.js +3 -0
- package/styled-components/es/examples/plasma_web/components/Tabs/vertical/VerticalTabItem.config.js +3 -0
- package/types/components/Badge/Badge.d.ts +10 -2
- package/types/components/Badge/Badge.d.ts.map +1 -1
- package/types/components/Badge/Badge.tokens.d.ts +1 -0
- package/types/components/Badge/Badge.tokens.d.ts.map +1 -1
- package/types/components/Badge/Badge.types.d.ts +5 -0
- package/types/components/Badge/Badge.types.d.ts.map +1 -1
- package/types/components/Badge/variations/_truncate/base.d.ts +2 -0
- package/types/components/Badge/variations/_truncate/base.d.ts.map +1 -0
- package/types/components/Tabs/TabItem.types.d.ts +5 -0
- package/types/components/Tabs/TabItem.types.d.ts.map +1 -1
- package/types/components/Tabs/tokens.d.ts +1 -0
- package/types/components/Tabs/tokens.d.ts.map +1 -1
- package/types/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.d.ts +9 -2
- package/types/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.d.ts.map +1 -1
- package/types/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.styles.d.ts.map +1 -1
- package/types/components/Tabs/ui/horizontal/HorizontalTabItem/variations/_truncate/base.d.ts +2 -0
- package/types/components/Tabs/ui/horizontal/HorizontalTabItem/variations/_truncate/base.d.ts.map +1 -0
- package/types/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.d.ts +9 -2
- package/types/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.d.ts.map +1 -1
- package/types/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.styles.d.ts.map +1 -1
- package/types/components/Tabs/ui/vertical/VerticalTabItem/variations/_truncate/base.d.ts +2 -0
- package/types/components/Tabs/ui/vertical/VerticalTabItem/variations/_truncate/base.d.ts.map +1 -0
- package/types/examples/plasma_b2c/components/Badge/Badge.config.d.ts +3 -0
- package/types/examples/plasma_b2c/components/Badge/Badge.config.d.ts.map +1 -1
- package/types/examples/plasma_b2c/components/Badge/Badge.d.ts +6 -0
- package/types/examples/plasma_b2c/components/Badge/Badge.d.ts.map +1 -1
- package/types/examples/plasma_b2c/components/Tabs/TabItem.d.ts +6 -0
- package/types/examples/plasma_b2c/components/Tabs/TabItem.d.ts.map +1 -1
- package/types/examples/plasma_b2c/components/Tabs/horizontal/HorizontalTabItem.config.d.ts +3 -0
- package/types/examples/plasma_b2c/components/Tabs/horizontal/HorizontalTabItem.config.d.ts.map +1 -1
- package/types/examples/plasma_b2c/components/Tabs/vertical/VerticalTabItem.config.d.ts +3 -0
- package/types/examples/plasma_b2c/components/Tabs/vertical/VerticalTabItem.config.d.ts.map +1 -1
- package/types/examples/plasma_web/components/Badge/Badge.d.ts +3 -0
- package/types/examples/plasma_web/components/Badge/Badge.d.ts.map +1 -1
- package/types/examples/plasma_web/components/Tabs/TabItem.d.ts +6 -0
- package/types/examples/plasma_web/components/Tabs/TabItem.d.ts.map +1 -1
- package/types/examples/plasma_web/components/Tabs/horizontal/HorizontalTabItem.config.d.ts +3 -0
- package/types/examples/plasma_web/components/Tabs/horizontal/HorizontalTabItem.config.d.ts.map +1 -1
- package/types/examples/plasma_web/components/Tabs/vertical/VerticalTabItem.config.d.ts +3 -0
- package/types/examples/plasma_web/components/Tabs/vertical/VerticalTabItem.config.d.ts.map +1 -1
- package/cjs/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.styles_16d3lah.css +0 -5
- package/es/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.styles_16d3lah.css +0 -5
@@ -29,6 +29,7 @@ type CustomStoryTabsProps = {
|
|
29
29
|
|
30
30
|
const contentLeftOptions = ['none', 'icon'];
|
31
31
|
const contentRightOptions = ['none', 'counter', 'icon'];
|
32
|
+
const labels = ['Label', 'Middle label', 'Very long label'];
|
32
33
|
|
33
34
|
const getContentLeft = (contentLeftOption: string, size: string) => {
|
34
35
|
const iconSize = size === 'xs' ? 'xs' : 's';
|
@@ -76,6 +77,12 @@ const meta: Meta<StoryTabsProps> = {
|
|
76
77
|
},
|
77
78
|
if: { arg: 'helperText', eq: '' },
|
78
79
|
},
|
80
|
+
maxItemWidth: {
|
81
|
+
control: {
|
82
|
+
type: 'text',
|
83
|
+
},
|
84
|
+
if: { arg: 'stretch', truthy: false },
|
85
|
+
},
|
79
86
|
},
|
80
87
|
};
|
81
88
|
|
@@ -90,13 +97,14 @@ const StoryHorizontalDefault = (props: HorizontalStoryTabsProps) => {
|
|
90
97
|
contentRight: contentRightOption,
|
91
98
|
hasDivider,
|
92
99
|
stretch,
|
100
|
+
maxItemWidth,
|
93
101
|
helperText,
|
94
102
|
} = props;
|
95
103
|
const items = Array(itemQuantity).fill(0);
|
96
104
|
const [index, setIndex] = useState(0);
|
97
105
|
|
98
106
|
return (
|
99
|
-
<Tabs view="divider" hasDivider={hasDivider} stretch={stretch} disabled={disabled} size={size}>
|
107
|
+
<Tabs clip="none" view="divider" hasDivider={hasDivider} stretch={stretch} disabled={disabled} size={size}>
|
100
108
|
{items.map((_, i) => {
|
101
109
|
if (helperText !== '') {
|
102
110
|
return (
|
@@ -110,8 +118,9 @@ const StoryHorizontalDefault = (props: HorizontalStoryTabsProps) => {
|
|
110
118
|
value={helperText}
|
111
119
|
contentLeft={getContentLeft(contentLeftOption, size as Size)}
|
112
120
|
size={size as Size}
|
121
|
+
maxItemWidth={maxItemWidth}
|
113
122
|
>
|
114
|
-
{
|
123
|
+
{`${labels[i % labels.length]} ${i + 1}`}
|
115
124
|
</TabItem>
|
116
125
|
);
|
117
126
|
}
|
@@ -127,8 +136,9 @@ const StoryHorizontalDefault = (props: HorizontalStoryTabsProps) => {
|
|
127
136
|
contentLeft={getContentLeft(contentLeftOption, size as Size)}
|
128
137
|
contentRight={getContentRight(contentRightOption, size as Size)}
|
129
138
|
size={size as Size}
|
139
|
+
maxItemWidth={maxItemWidth}
|
130
140
|
>
|
131
|
-
{
|
141
|
+
{`${labels[i % labels.length]} ${i + 1}`}
|
132
142
|
</TabItem>
|
133
143
|
);
|
134
144
|
})}
|
@@ -147,6 +157,7 @@ const StoryHorizontalScroll = (props: HorizontalStoryTabsProps) => {
|
|
147
157
|
hasDivider,
|
148
158
|
helperText,
|
149
159
|
width,
|
160
|
+
maxItemWidth,
|
150
161
|
} = props;
|
151
162
|
const items = Array(itemQuantity).fill(0);
|
152
163
|
const [index, setIndex] = useState(0);
|
@@ -166,8 +177,9 @@ const StoryHorizontalScroll = (props: HorizontalStoryTabsProps) => {
|
|
166
177
|
value={helperText}
|
167
178
|
contentLeft={getContentLeft(contentLeftOption, size as Size)}
|
168
179
|
size={size as Size}
|
180
|
+
maxItemWidth={maxItemWidth}
|
169
181
|
>
|
170
|
-
{
|
182
|
+
{`${labels[i % labels.length]} ${i + 1}`}
|
171
183
|
</TabItem>
|
172
184
|
);
|
173
185
|
}
|
@@ -183,8 +195,9 @@ const StoryHorizontalScroll = (props: HorizontalStoryTabsProps) => {
|
|
183
195
|
contentLeft={getContentLeft(contentLeftOption, size as Size)}
|
184
196
|
contentRight={getContentRight(contentRightOption, size as Size)}
|
185
197
|
size={size as Size}
|
198
|
+
maxItemWidth={maxItemWidth}
|
186
199
|
>
|
187
|
-
{
|
200
|
+
{`${labels[i % labels.length]} ${i + 1}`}
|
188
201
|
</TabItem>
|
189
202
|
);
|
190
203
|
})}
|
@@ -202,6 +215,7 @@ const StoryHorizontalShowAll = (props: HorizontalStoryTabsProps) => {
|
|
202
215
|
contentRight: contentRightOption,
|
203
216
|
hasDivider,
|
204
217
|
helperText,
|
218
|
+
maxItemWidth,
|
205
219
|
} = props;
|
206
220
|
const maxItemQuantity = 3;
|
207
221
|
const items = Array(itemQuantity).fill(0);
|
@@ -234,8 +248,9 @@ const StoryHorizontalShowAll = (props: HorizontalStoryTabsProps) => {
|
|
234
248
|
value={helperText}
|
235
249
|
contentLeft={getContentLeft(contentLeftOption, size as Size)}
|
236
250
|
size={size as Size}
|
251
|
+
maxItemWidth={maxItemWidth}
|
237
252
|
>
|
238
|
-
{
|
253
|
+
{`${labels[i % labels.length]} ${i + 1}`}
|
239
254
|
</TabItem>
|
240
255
|
);
|
241
256
|
}
|
@@ -251,8 +266,9 @@ const StoryHorizontalShowAll = (props: HorizontalStoryTabsProps) => {
|
|
251
266
|
contentLeft={getContentLeft(contentLeftOption, size as Size)}
|
252
267
|
contentRight={getContentRight(contentRightOption, size as Size)}
|
253
268
|
size={size as Size}
|
269
|
+
maxItemWidth={maxItemWidth}
|
254
270
|
>
|
255
|
-
{
|
271
|
+
{`${labels[i % labels.length]} ${i + 1}`}
|
256
272
|
</TabItem>
|
257
273
|
);
|
258
274
|
})}
|
@@ -269,6 +285,7 @@ const StoryHorizontalShowAll = (props: HorizontalStoryTabsProps) => {
|
|
269
285
|
tabIndex={!disabled ? 0 : -1}
|
270
286
|
disabled={disabled}
|
271
287
|
size={size as Size}
|
288
|
+
maxItemWidth="auto"
|
272
289
|
>
|
273
290
|
ShowAll
|
274
291
|
</TabItem>
|
@@ -285,9 +302,10 @@ export const HorizontalTabs: StoryObj<HorizontalStoryTabsProps> = {
|
|
285
302
|
disabled: false,
|
286
303
|
hasDivider: true,
|
287
304
|
helperText: '',
|
288
|
-
itemQuantity:
|
305
|
+
itemQuantity: 6,
|
289
306
|
stretch: false,
|
290
307
|
width: '15rem',
|
308
|
+
maxItemWidth: '',
|
291
309
|
},
|
292
310
|
argTypes: {
|
293
311
|
contentLeft: {
|
@@ -343,6 +361,7 @@ const StoryVerticalDefault = (props: VerticalStoryTabsProps) => {
|
|
343
361
|
contentRight: contentRightOption,
|
344
362
|
hasDivider,
|
345
363
|
helperText,
|
364
|
+
maxItemWidth,
|
346
365
|
} = props;
|
347
366
|
const items = Array(itemQuantity).fill(0);
|
348
367
|
const [index, setIndex] = useState(0);
|
@@ -363,8 +382,9 @@ const StoryVerticalDefault = (props: VerticalStoryTabsProps) => {
|
|
363
382
|
value={helperText}
|
364
383
|
contentLeft={getContentLeft(contentLeftOption, size as Size)}
|
365
384
|
size={size as Size}
|
385
|
+
maxItemWidth={maxItemWidth}
|
366
386
|
>
|
367
|
-
{
|
387
|
+
{`${labels[i % labels.length]} ${i + 1}`}
|
368
388
|
</TabItem>
|
369
389
|
);
|
370
390
|
}
|
@@ -381,8 +401,9 @@ const StoryVerticalDefault = (props: VerticalStoryTabsProps) => {
|
|
381
401
|
contentLeft={getContentLeft(contentLeftOption, size as Size)}
|
382
402
|
contentRight={getContentRight(contentRightOption, size as Size)}
|
383
403
|
size={size as Size}
|
404
|
+
maxItemWidth={maxItemWidth}
|
384
405
|
>
|
385
|
-
{
|
406
|
+
{`${labels[i % labels.length]} ${i + 1}`}
|
386
407
|
</TabItem>
|
387
408
|
);
|
388
409
|
})}
|
@@ -401,6 +422,7 @@ const StoryVerticalScroll = (props: VerticalStoryTabsProps) => {
|
|
401
422
|
hasDivider,
|
402
423
|
helperText,
|
403
424
|
height,
|
425
|
+
maxItemWidth,
|
404
426
|
} = props;
|
405
427
|
const items = Array(itemQuantity).fill(0);
|
406
428
|
const [index, setIndex] = useState(0);
|
@@ -428,8 +450,9 @@ const StoryVerticalScroll = (props: VerticalStoryTabsProps) => {
|
|
428
450
|
value={helperText}
|
429
451
|
contentLeft={getContentLeft(contentLeftOption, size as Size)}
|
430
452
|
size={size as Size}
|
453
|
+
maxItemWidth={maxItemWidth}
|
431
454
|
>
|
432
|
-
{
|
455
|
+
{`${labels[i % labels.length]} ${i + 1}`}
|
433
456
|
</TabItem>
|
434
457
|
);
|
435
458
|
}
|
@@ -446,8 +469,9 @@ const StoryVerticalScroll = (props: VerticalStoryTabsProps) => {
|
|
446
469
|
contentLeft={getContentLeft(contentLeftOption, size as Size)}
|
447
470
|
contentRight={getContentRight(contentRightOption, size as Size)}
|
448
471
|
size={size as Size}
|
472
|
+
maxItemWidth={maxItemWidth}
|
449
473
|
>
|
450
|
-
{
|
474
|
+
{`${labels[i % labels.length]} ${i + 1}`}
|
451
475
|
</TabItem>
|
452
476
|
);
|
453
477
|
})}
|
@@ -465,6 +489,7 @@ const StoryVerticalShowAll = (props: VerticalStoryTabsProps) => {
|
|
465
489
|
contentRight: contentRightOption,
|
466
490
|
hasDivider,
|
467
491
|
helperText,
|
492
|
+
maxItemWidth,
|
468
493
|
} = props;
|
469
494
|
const maxItemQuantity = 3;
|
470
495
|
const items = Array(itemQuantity).fill(0);
|
@@ -498,8 +523,9 @@ const StoryVerticalShowAll = (props: VerticalStoryTabsProps) => {
|
|
498
523
|
value={helperText}
|
499
524
|
contentLeft={getContentLeft(contentLeftOption, size as Size)}
|
500
525
|
size={size as Size}
|
526
|
+
maxItemWidth={maxItemWidth}
|
501
527
|
>
|
502
|
-
{
|
528
|
+
{`${labels[i % labels.length]} ${i + 1}`}
|
503
529
|
</TabItem>
|
504
530
|
);
|
505
531
|
}
|
@@ -516,8 +542,9 @@ const StoryVerticalShowAll = (props: VerticalStoryTabsProps) => {
|
|
516
542
|
contentLeft={getContentLeft(contentLeftOption, size as Size)}
|
517
543
|
contentRight={getContentRight(contentRightOption, size as Size)}
|
518
544
|
size={size as Size}
|
545
|
+
maxItemWidth={maxItemWidth}
|
519
546
|
>
|
520
|
-
{
|
547
|
+
{`${labels[i % labels.length]} ${i + 1}`}
|
521
548
|
</TabItem>
|
522
549
|
);
|
523
550
|
})}
|
@@ -534,6 +561,7 @@ const StoryVerticalShowAll = (props: VerticalStoryTabsProps) => {
|
|
534
561
|
tabIndex={!disabled ? 0 : -1}
|
535
562
|
disabled={disabled}
|
536
563
|
size={size as Size}
|
564
|
+
maxItemWidth="auto"
|
537
565
|
>
|
538
566
|
ShowAll
|
539
567
|
</TabItem>
|
@@ -548,10 +576,11 @@ export const VerticalTabs: StoryObj<VerticalStoryTabsProps> = {
|
|
548
576
|
size: 'xs',
|
549
577
|
disabled: false,
|
550
578
|
hasDivider: true,
|
551
|
-
itemQuantity:
|
579
|
+
itemQuantity: 6,
|
552
580
|
orientation: 'vertical',
|
553
581
|
helperText: '',
|
554
582
|
height: '10rem',
|
583
|
+
maxItemWidth: '',
|
555
584
|
},
|
556
585
|
argTypes: {
|
557
586
|
contentLeft: {
|
@@ -604,7 +633,7 @@ export const VerticalTabs: StoryObj<VerticalStoryTabsProps> = {
|
|
604
633
|
};
|
605
634
|
|
606
635
|
const StoryHeaderDefault = (props: HorizontalStoryTabsProps) => {
|
607
|
-
const { disabled, itemQuantity, size, helperText } = props;
|
636
|
+
const { disabled, itemQuantity, size, helperText, maxItemWidth } = props;
|
608
637
|
const items = Array(itemQuantity).fill(0);
|
609
638
|
const [index, setIndex] = useState(0);
|
610
639
|
|
@@ -620,6 +649,7 @@ const StoryHeaderDefault = (props: HorizontalStoryTabsProps) => {
|
|
620
649
|
disabled={disabled}
|
621
650
|
value={helperText}
|
622
651
|
size={size as HeaderSize}
|
652
|
+
maxItemWidth={maxItemWidth}
|
623
653
|
>
|
624
654
|
{`Label${i + 1}`}
|
625
655
|
</TabItem>
|
@@ -629,7 +659,7 @@ const StoryHeaderDefault = (props: HorizontalStoryTabsProps) => {
|
|
629
659
|
};
|
630
660
|
|
631
661
|
const StoryHeaderScroll = (props: HorizontalStoryTabsProps) => {
|
632
|
-
const { disabled, itemQuantity, size, helperText, width } = props;
|
662
|
+
const { disabled, itemQuantity, size, helperText, width, maxItemWidth } = props;
|
633
663
|
const items = Array(itemQuantity).fill(0);
|
634
664
|
const [index, setIndex] = useState(0);
|
635
665
|
|
@@ -645,8 +675,9 @@ const StoryHeaderScroll = (props: HorizontalStoryTabsProps) => {
|
|
645
675
|
disabled={disabled}
|
646
676
|
value={helperText}
|
647
677
|
size={size as HeaderSize}
|
678
|
+
maxItemWidth={maxItemWidth}
|
648
679
|
>
|
649
|
-
{
|
680
|
+
{`${labels[i % labels.length]} ${i + 1}`}
|
650
681
|
</TabItem>
|
651
682
|
))}
|
652
683
|
</Tabs>
|
@@ -658,8 +689,9 @@ export const HeaderTabs: StoryObj<HorizontalStoryTabsProps> = {
|
|
658
689
|
size: 'h5',
|
659
690
|
disabled: false,
|
660
691
|
helperText: '',
|
661
|
-
itemQuantity:
|
692
|
+
itemQuantity: 4,
|
662
693
|
width: '12rem',
|
694
|
+
maxItemWidth: '',
|
663
695
|
},
|
664
696
|
argTypes: {
|
665
697
|
clip: {
|
@@ -1,5 +1,11 @@
|
|
1
|
-
|
1
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
2
|
+
var _excluded = ["children", "className", "text", "contentLeft", "contentRight", "size", "view", "pilled", "transparent", "clear", "maxWidth"];
|
2
3
|
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
4
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
5
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
6
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
7
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
|
8
|
+
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
3
9
|
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
|
4
10
|
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
|
5
11
|
import React, { forwardRef } from 'react';
|
@@ -9,6 +15,7 @@ import { base as sizeCSS } from './variations/_size/base';
|
|
9
15
|
import { base as pilledCSS } from './variations/_pilled/base';
|
10
16
|
import { base as transparentCSS } from './variations/_transparent/base';
|
11
17
|
import { base as clearCSS } from './variations/_clear/base';
|
18
|
+
import { base as truncateCSS } from './variations/_truncate/base';
|
12
19
|
import { StyledContentLeft, StyledContentMain, StyledContentRight, base } from './Badge.styles';
|
13
20
|
import { classes } from './Badge.tokens';
|
14
21
|
export var badgeRoot = function badgeRoot(Root) {
|
@@ -26,20 +33,28 @@ export var badgeRoot = function badgeRoot(Root) {
|
|
26
33
|
transparent = _props$transparent === void 0 ? false : _props$transparent,
|
27
34
|
_props$clear = props.clear,
|
28
35
|
clear = _props$clear === void 0 ? false : _props$clear,
|
36
|
+
_props$maxWidth = props.maxWidth,
|
37
|
+
maxWidth = _props$maxWidth === void 0 ? 'auto' : _props$maxWidth,
|
29
38
|
rest = _objectWithoutProperties(props, _excluded);
|
30
39
|
var pilledClass = pilled ? classes.badgePilled : undefined;
|
31
40
|
var transparentClass = transparent ? classes.badgeTransparent : undefined;
|
32
41
|
var clearClass = clear ? classes.badgeClear : undefined;
|
33
42
|
var txt = !text && typeof children === 'string' ? children : text;
|
43
|
+
var truncate = maxWidth !== 'auto';
|
34
44
|
return /*#__PURE__*/React.createElement(Root, _extends({
|
35
45
|
ref: ref,
|
36
|
-
className: cx(pilledClass, transparentClass, clearClass, className),
|
46
|
+
className: cx(pilledClass, transparentClass, clearClass, truncate && classes.badgeTruncate, className),
|
37
47
|
view: view,
|
38
48
|
size: size,
|
39
49
|
pilled: pilled,
|
40
50
|
transparent: transparent,
|
41
|
-
clear: clear
|
42
|
-
|
51
|
+
clear: clear,
|
52
|
+
truncate: truncate
|
53
|
+
}, rest, {
|
54
|
+
style: _objectSpread(_objectSpread({}, rest.style), {}, {
|
55
|
+
maxWidth: maxWidth
|
56
|
+
})
|
57
|
+
}), contentLeft && /*#__PURE__*/React.createElement(StyledContentLeft, null, contentLeft), txt ? /*#__PURE__*/React.createElement(StyledContentMain, null, txt) : children, contentRight && /*#__PURE__*/React.createElement(StyledContentRight, null, contentRight));
|
43
58
|
});
|
44
59
|
};
|
45
60
|
export var badgeConfig = {
|
@@ -65,6 +80,10 @@ export var badgeConfig = {
|
|
65
80
|
clear: {
|
66
81
|
css: clearCSS,
|
67
82
|
attrs: true
|
83
|
+
},
|
84
|
+
truncate: {
|
85
|
+
css: truncateCSS,
|
86
|
+
attrs: true
|
68
87
|
}
|
69
88
|
},
|
70
89
|
defaults: {
|
@@ -0,0 +1,4 @@
|
|
1
|
+
import { css } from 'styled-components';
|
2
|
+
import { classes } from '../../Badge.tokens';
|
3
|
+
import { StyledContentMain } from '../../Badge.styles';
|
4
|
+
export var base = /*#__PURE__*/css(["&.", "{max-width:100%;", "{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}}"], classes.badgeTruncate, StyledContentMain);
|
@@ -0,0 +1 @@
|
|
1
|
+
[]
|
@@ -14,7 +14,8 @@ export var classes = {
|
|
14
14
|
tabsHasTopArrow: 'tabs-has-top-arrow',
|
15
15
|
tabsHasBottomArrow: 'tabs-has-bottom-arrow',
|
16
16
|
tabsClipScroll: 'tabs-clip-scroll',
|
17
|
-
tabsClipShowAll: 'tabs-clip-show-all'
|
17
|
+
tabsClipShowAll: 'tabs-clip-show-all',
|
18
|
+
tabsTruncate: 'tabs-truncate'
|
18
19
|
};
|
19
20
|
export var tokens = {
|
20
21
|
disabledOpacity: '--plasma-tabs-disabled-opacity',
|
package/styled-components/es/components/Tabs/ui/horizontal/HorizontalTabItem/HorizontalTabItem.js
CHANGED
@@ -1,5 +1,11 @@
|
|
1
|
-
|
1
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
2
|
+
var _excluded = ["size", "view", "isActive", "selected", "disabled", "pilled", "children", "value", "contentLeft", "contentRight", "animated", "onIndexChange", "itemIndex", "tabIndex", "className", "onClick", "maxItemWidth"];
|
2
3
|
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
4
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
5
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
6
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
7
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
|
8
|
+
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
3
9
|
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
|
4
10
|
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
|
5
11
|
import React, { forwardRef, useRef, useContext, useEffect, useCallback } from 'react';
|
@@ -11,6 +17,7 @@ import { base as viewCSS } from './variations/_view/base';
|
|
11
17
|
import { base as sizeCSS } from './variations/_size/base';
|
12
18
|
import { base as pilledCSS } from './variations/_pilled/base';
|
13
19
|
import { base as disabledCSS } from './variations/_disabled/base';
|
20
|
+
import { base as truncateCSS } from './variations/_truncate/base';
|
14
21
|
import { LeftContent, RightContent, StyledContent, TabItemValue, base } from './HorizontalTabItem.styles';
|
15
22
|
export var horizontalTabItemRoot = function horizontalTabItemRoot(Root) {
|
16
23
|
return /*#__PURE__*/forwardRef(function (props, outerRef) {
|
@@ -33,11 +40,13 @@ export var horizontalTabItemRoot = function horizontalTabItemRoot(Root) {
|
|
33
40
|
tabIndex = props.tabIndex,
|
34
41
|
className = props.className,
|
35
42
|
onClick = props.onClick,
|
43
|
+
maxWidth = props.maxItemWidth,
|
36
44
|
rest = _objectWithoutProperties(props, _excluded);
|
37
45
|
var innerRef = useRef(null);
|
38
46
|
var ref = useForkRef(outerRef, innerRef);
|
39
47
|
var refs = useContext(TabsContext);
|
40
48
|
var role = 'tab';
|
49
|
+
var truncate = maxWidth !== 'auto';
|
41
50
|
var pilledAttr = view !== 'clear' && pilled;
|
42
51
|
var animatedClass = animated ? classes.tabItemAnimated : undefined;
|
43
52
|
var pilledClass = pilledAttr ? classes.tabsPilled : undefined;
|
@@ -96,11 +105,16 @@ export var horizontalTabItemRoot = function horizontalTabItemRoot(Root) {
|
|
96
105
|
// TODO: убрать каст any, когда будут удалены deprecated props
|
97
106
|
,
|
98
107
|
size: size,
|
108
|
+
truncate: truncate,
|
99
109
|
onFocus: onItemFocus,
|
100
110
|
tabIndex: hasKeyNavigation ? navigationTabIndex : tabIndex,
|
101
|
-
className: cx(pilledClass, selectedClass, animatedClass, className),
|
111
|
+
className: cx(pilledClass, selectedClass, animatedClass, truncate && classes.tabsTruncate, className),
|
102
112
|
onClick: handleClick
|
103
|
-
}, rest
|
113
|
+
}, rest, {
|
114
|
+
style: _objectSpread(_objectSpread({}, rest.style), {}, {
|
115
|
+
maxWidth: maxWidth
|
116
|
+
})
|
117
|
+
}), /*#__PURE__*/React.createElement(React.Fragment, null, contentLeft && /*#__PURE__*/React.createElement(LeftContent, {
|
104
118
|
className: classes.tabLeftContent
|
105
119
|
}, contentLeft), /*#__PURE__*/React.createElement(StyledContent, {
|
106
120
|
className: classes.tabContent
|
@@ -127,6 +141,9 @@ export var horizontalTabItemConfig = {
|
|
127
141
|
},
|
128
142
|
pilled: {
|
129
143
|
css: pilledCSS
|
144
|
+
},
|
145
|
+
truncate: {
|
146
|
+
css: truncateCSS
|
130
147
|
}
|
131
148
|
},
|
132
149
|
defaults: {
|
@@ -2,7 +2,7 @@ import styled from 'styled-components';
|
|
2
2
|
import { css } from 'styled-components';
|
3
3
|
import { addFocus } from '../../../../../mixins';
|
4
4
|
import { tokens } from '../../../tokens';
|
5
|
-
export var base = /*#__PURE__*/css(["position:relative;display:flex;align-items:center;justify-content:center;box-sizing:border-box;align-items:center;gap:var(", ");padding:var(", ",var(", "));appearance:none;border:none;outline:none;cursor:pointer;-webkit-tap-highlight-color:transparent;&:first-child{margin-left:0;}", ";"], tokens.itemContentGap, tokens.itemPaddingClear, tokens.itemPadding, /*#__PURE__*/addFocus({
|
5
|
+
export var base = /*#__PURE__*/css(["position:relative;display:flex;align-items:center;justify-content:center;box-sizing:border-box;align-items:center;white-space:nowrap;gap:var(", ");padding:var(", ",var(", "));appearance:none;border:none;outline:none;cursor:pointer;-webkit-tap-highlight-color:transparent;&:first-child{margin-left:0;}", ";"], tokens.itemContentGap, tokens.itemPaddingClear, tokens.itemPadding, /*#__PURE__*/addFocus({
|
6
6
|
outlineSize: '0.063rem',
|
7
7
|
outlineOffset: '-0.125rem',
|
8
8
|
outlineColor: /*#__PURE__*/"var(".concat(tokens.outlineFocusColor, ")"),
|
@@ -0,0 +1,4 @@
|
|
1
|
+
import { css } from 'styled-components';
|
2
|
+
import { classes } from '../../../../../tokens';
|
3
|
+
import { StyledContent, TabItemValue } from '../../HorizontalTabItem.styles';
|
4
|
+
export var base = /*#__PURE__*/css(["&.", "{", "{overflow:hidden;text-overflow:ellipsis;}", "{overflow:hidden;text-overflow:ellipsis;}}"], classes.tabsTruncate, StyledContent, TabItemValue);
|
@@ -0,0 +1 @@
|
|
1
|
+
[]
|
@@ -1,5 +1,11 @@
|
|
1
|
-
|
1
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
2
|
+
var _excluded = ["size", "view", "selected", "disabled", "children", "value", "contentLeft", "contentRight", "onIndexChange", "itemIndex", "tabIndex", "className", "onClick", "maxItemWidth"];
|
2
3
|
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
4
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
5
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
6
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
7
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
|
8
|
+
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
3
9
|
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
|
4
10
|
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
|
5
11
|
import React, { forwardRef, useRef, useContext, useEffect, useCallback } from 'react';
|
@@ -11,6 +17,7 @@ import { base, LeftContent, RightContent, StyledContent, TabItemValue } from './
|
|
11
17
|
import { base as viewCSS } from './variations/_view/base';
|
12
18
|
import { base as sizeCSS } from './variations/_size/base';
|
13
19
|
import { base as disabledCSS } from './variations/_disabled/base';
|
20
|
+
import { base as truncateCSS } from './variations/_truncate/base';
|
14
21
|
export var verticalTabItemRoot = function verticalTabItemRoot(Root) {
|
15
22
|
return /*#__PURE__*/forwardRef(function (props, outerRef) {
|
16
23
|
var size = props.size,
|
@@ -27,11 +34,13 @@ export var verticalTabItemRoot = function verticalTabItemRoot(Root) {
|
|
27
34
|
tabIndex = props.tabIndex,
|
28
35
|
className = props.className,
|
29
36
|
onClick = props.onClick,
|
37
|
+
maxWidth = props.maxItemWidth,
|
30
38
|
rest = _objectWithoutProperties(props, _excluded);
|
31
39
|
var innerRef = useRef(null);
|
32
40
|
var ref = useForkRef(outerRef, innerRef);
|
33
41
|
var refs = useContext(TabsContext);
|
34
42
|
var role = 'tab';
|
43
|
+
var truncate = maxWidth !== 'auto';
|
35
44
|
var selectedClass = selected ? classes.selectedTabsItem : undefined;
|
36
45
|
var hasKeyNavigation = itemIndex !== undefined && onIndexChange !== undefined;
|
37
46
|
var navigationTabIndex = !disabled && (refs === null || refs === void 0 ? void 0 : refs.current) === itemIndex ? 0 : -1;
|
@@ -83,11 +92,16 @@ export var verticalTabItemRoot = function verticalTabItemRoot(Root) {
|
|
83
92
|
role: role,
|
84
93
|
view: view,
|
85
94
|
size: size,
|
95
|
+
truncate: truncate,
|
86
96
|
onFocus: onItemFocus,
|
87
97
|
tabIndex: hasKeyNavigation ? navigationTabIndex : tabIndex,
|
88
|
-
className: cx(selectedClass, className),
|
98
|
+
className: cx(selectedClass, truncate && classes.tabsTruncate, className),
|
89
99
|
onClick: handleClick
|
90
|
-
}, rest
|
100
|
+
}, rest, {
|
101
|
+
style: _objectSpread(_objectSpread({}, rest.style), {}, {
|
102
|
+
maxWidth: maxWidth
|
103
|
+
})
|
104
|
+
}), /*#__PURE__*/React.createElement(React.Fragment, null, contentLeft && /*#__PURE__*/React.createElement(LeftContent, {
|
91
105
|
className: classes.tabLeftContent
|
92
106
|
}, contentLeft), /*#__PURE__*/React.createElement(StyledContent, {
|
93
107
|
className: classes.tabContent
|
@@ -111,6 +125,9 @@ export var verticalTabItemConfig = {
|
|
111
125
|
disabled: {
|
112
126
|
css: disabledCSS,
|
113
127
|
attrs: true
|
128
|
+
},
|
129
|
+
truncate: {
|
130
|
+
css: truncateCSS
|
114
131
|
}
|
115
132
|
},
|
116
133
|
defaults: {
|
package/styled-components/es/components/Tabs/ui/vertical/VerticalTabItem/VerticalTabItem.styles.js
CHANGED
@@ -4,7 +4,7 @@ import { css } from 'styled-components';
|
|
4
4
|
import styled from 'styled-components';
|
5
5
|
import { addFocus } from '../../../../../mixins';
|
6
6
|
import { tokens } from '../../../tokens';
|
7
|
-
export var base = /*#__PURE__*/css(_templateObject || (_templateObject = /*#__PURE__*/_taggedTemplateLiteral(["\n position: relative;\n display: flex;\n align-items: center;\n justify-content: flex-start;\n box-sizing: border-box;\n
|
7
|
+
export var base = /*#__PURE__*/css(_templateObject || (_templateObject = /*#__PURE__*/_taggedTemplateLiteral(["\n position: relative;\n display: flex;\n align-items: center;\n justify-content: flex-start;\n box-sizing: border-box;\n white-space: nowrap;\n\n gap: var(", ");\n padding: var(", ");\n\n appearance: none;\n border: none;\n outline: none;\n cursor: pointer;\n -webkit-tap-highlight-color: transparent;\n\n ", ";\n"])), tokens.itemContentGap, tokens.itemPaddingOrientationVertical, /*#__PURE__*/addFocus({
|
8
8
|
outlineSize: '0.063rem',
|
9
9
|
outlineOffset: '-0.125rem',
|
10
10
|
outlineColor: /*#__PURE__*/"var(".concat(tokens.outlineFocusColor, ")"),
|
@@ -16,7 +16,7 @@ export var StyledContent = /*#__PURE__*/styled.div.withConfig({
|
|
16
16
|
})(["display:inline-block;width:fit-content;padding:0 var(", ",var(", "));"], tokens.itemContentPaddingClear, tokens.itemContentPadding);
|
17
17
|
export var TabItemValue = /*#__PURE__*/styled.span.withConfig({
|
18
18
|
componentId: "plasma-new-hope__sc-1pflgj8-1"
|
19
|
-
})(["color:var(", ");"], tokens.itemValueColor);
|
19
|
+
})(["white-space:nowrap;color:var(", ");"], tokens.itemValueColor);
|
20
20
|
export var RightContent = /*#__PURE__*/styled.div.withConfig({
|
21
21
|
componentId: "plasma-new-hope__sc-1pflgj8-2"
|
22
22
|
})(["display:flex;color:inherit;&:hover{color:inherit;}"]);
|
@@ -0,0 +1,4 @@
|
|
1
|
+
import { css } from 'styled-components';
|
2
|
+
import { classes } from '../../../../../tokens';
|
3
|
+
import { StyledContent, TabItemValue } from '../../VerticalTabItem.styles';
|
4
|
+
export var base = /*#__PURE__*/css(["&.", "{", "{overflow:hidden;text-overflow:ellipsis;}", "{overflow:hidden;text-overflow:ellipsis;}}"], classes.tabsTruncate, StyledContent, TabItemValue);
|
@@ -0,0 +1 @@
|
|
1
|
+
[]
|
@@ -31,6 +31,9 @@ const meta: Meta<typeof Badge> = {
|
|
31
31
|
control: { type: 'boolean' },
|
32
32
|
if: { arg: 'clear', truthy: false },
|
33
33
|
},
|
34
|
+
maxWidth: {
|
35
|
+
control: { type: 'text' },
|
36
|
+
},
|
34
37
|
...disableProps(['contentLeft', 'contentRight']),
|
35
38
|
},
|
36
39
|
};
|
@@ -64,7 +67,7 @@ export const Default: Story = {
|
|
64
67
|
},
|
65
68
|
},
|
66
69
|
args: {
|
67
|
-
text: 'Hello',
|
70
|
+
text: 'Hello Kitty',
|
68
71
|
view: 'default',
|
69
72
|
size: 'm',
|
70
73
|
enableContentLeft: false,
|
@@ -72,6 +75,7 @@ export const Default: Story = {
|
|
72
75
|
clear: false,
|
73
76
|
pilled: false,
|
74
77
|
transparent: false,
|
78
|
+
maxWidth: '',
|
75
79
|
},
|
76
80
|
render: ({ enableContentLeft, enableContentRight, size, ...rest }: StoryProps) => {
|
77
81
|
const iconSize = size === 'l' ? '1rem' : '0.75rem';
|