@salutejs/plasma-web 1.583.0-canary.1991.15252784001.0 → 1.583.0-canary.1992.15255012441.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/Accordion/Accordion.d.ts +10 -9
- package/components/Attach/Attach.d.ts +159 -158
- package/components/Autocomplete/Autocomplete.d.ts +345 -344
- package/components/Avatar/Avatar.d.ts +47 -46
- package/components/AvatarGroup/AvatarGroup.d.ts +2 -1
- package/components/Badge/Badge.d.ts +41 -40
- package/components/Breadcrumbs/Breadcrumbs.d.ts +4 -3
- package/components/Button/Button.d.ts +36 -35
- package/components/ButtonGroup/ButtonGroup.d.ts +4 -0
- package/components/Carousel/Carousel.d.ts +3 -2
- package/components/Cell/Cell.d.ts +20 -19
- package/components/Checkbox/Checkbox.d.ts +1 -1
- package/components/Chip/Chip.d.ts +1 -0
- package/components/ChipGroup/ChipGroup.d.ts +1 -0
- package/components/Combobox/Combobox.d.ts +953 -953
- package/components/Combobox/Legacy/Combobox.d.ts +37 -36
- package/components/Counter/Counter.d.ts +1 -0
- package/components/DatePicker/DatePicker.d.ts +54 -53
- package/components/Divider/Divider.d.ts +1 -0
- package/components/Drawer/Drawer.d.ts +19 -18
- package/components/Dropdown/Dropdown.d.ts +52 -52
- package/components/Dropdown/components/DropdownItem.d.ts +14 -14
- package/components/Dropzone/Dropzone.d.ts +16 -15
- package/components/Editable/Editable.d.ts +1 -0
- package/components/EmptyState/EmptyState.d.ts +1 -0
- package/components/Flow/Flow.d.ts +2 -1
- package/components/Grid/Grid.d.ts +1 -0
- package/components/IconButton/IconButton.d.ts +36 -35
- package/components/Image/Image.d.ts +4 -3
- package/components/Indicator/Indicator.d.ts +1 -0
- package/components/Link/Link.d.ts +1 -0
- package/components/LinkButton/LinkButton.d.ts +9 -8
- package/components/Mask/Mask.d.ts +225 -224
- package/components/Note/Note.d.ts +12 -11
- package/components/NumberFormat/NumberFormat.d.ts +1 -1
- package/components/NumberInput/NumberInput.d.ts +39 -38
- package/components/Pagination/Pagination.d.ts +1 -0
- package/components/Popover/Popover.d.ts +1 -0
- package/components/Price/Price.d.ts +1 -0
- package/components/Progress/Progress.d.ts +1 -0
- package/components/Radiobox/Radiobox.d.ts +1 -1
- package/components/Range/Range.d.ts +106 -105
- package/components/Rating/Rating.d.ts +14 -13
- package/components/Segment/Segment.d.ts +9 -8
- package/components/Select/Select.d.ts +244 -244
- package/components/Sheet/Sheet.d.ts +1 -0
- package/components/Skeleton/Skeleton.d.ts +5 -4
- package/components/Slider/Slider.d.ts +105 -96
- package/components/Steps/Steps.d.ts +1 -0
- package/components/Switch/Switch.d.ts +1 -1
- package/components/Table/Table.d.ts +1 -0
- package/components/Tabs/TabItem.d.ts +14 -14
- package/components/Tabs/Tabs.d.ts +7 -5
- package/components/TextArea/TextArea.d.ts +206 -205
- package/components/TextArea/index.d.ts +4 -4
- package/components/TextField/TextField.d.ts +269 -261
- package/components/TextFieldGroup/TextFieldGroup.d.ts +13 -12
- package/components/Toast/Toast.d.ts +1 -0
- package/components/Tokens/Colors/Colors.styles.d.ts +26 -25
- package/components/Tokens/Typography/Typography.styles.d.ts +24 -23
- package/components/Toolbar/Toolbar.d.ts +6 -5
- package/components/Tree/Tree.d.ts +1 -0
- package/components/Typography/Old/index.d.ts +37 -36
- package/components/Typography/Typography.d.ts +205 -204
- package/mixins/index.d.ts +2 -1
- package/package.json +12 -12
@@ -1,3 +1,4 @@
|
|
1
|
+
/// <reference types="react" />
|
1
2
|
/**
|
2
3
|
* Слайдер позволяет определить числовое значение в пределах указанного промежутка.
|
3
4
|
* Можно указать два значения.
|
@@ -17,135 +18,143 @@ export declare const Slider: import("react").FunctionComponent<import("@salutejs
|
|
17
18
|
true: import("@salutejs/plasma-new-hope/types/engines/types").PolymorphicClassName;
|
18
19
|
};
|
19
20
|
}> & ((import("@salutejs/plasma-new-hope/types/components/Slider/components/SliderBase/SliderBase.types").SliderBaseProps & import("@salutejs/plasma-new-hope/types/components/Slider/components").SliderInternalProps & {
|
20
|
-
|
21
|
+
/**
|
22
|
+
* Слайдер позволяет определить числовое значение в пределах указанного промежутка.
|
23
|
+
* Можно указать два значения.
|
24
|
+
*/
|
25
|
+
onChange?: ((event: import("@salutejs/plasma-new-hope/types/types/FormType").FormTypeNumber) => void) | undefined;
|
21
26
|
name: string;
|
22
|
-
value?:
|
23
|
-
defaultValue?: number;
|
27
|
+
value?: undefined;
|
28
|
+
defaultValue?: number | undefined;
|
24
29
|
} & {
|
25
|
-
orientation?: "horizontal";
|
26
|
-
labelPlacement?: "
|
27
|
-
scaleAlign?: "
|
28
|
-
sliderAlign?:
|
29
|
-
reversed?:
|
30
|
-
labelReversed?:
|
30
|
+
orientation?: "horizontal" | undefined;
|
31
|
+
labelPlacement?: "none" | "left" | "top" | undefined;
|
32
|
+
scaleAlign?: "none" | "bottom" | "side" | undefined;
|
33
|
+
sliderAlign?: "none" | undefined;
|
34
|
+
reversed?: undefined;
|
35
|
+
labelReversed?: undefined;
|
31
36
|
} & Omit<import("react").HTMLAttributes<HTMLDivElement>, "onChange" | "defaultValue"> & {
|
32
|
-
onChangeCommitted?: (value: number) => void;
|
33
|
-
ariaLabel?: string;
|
34
|
-
showCurrentValue?: boolean;
|
35
|
-
showRangeValues?: boolean;
|
36
|
-
rangeValuesPlacement?: string;
|
37
|
-
showScale?: boolean;
|
38
|
-
hideMinValueDiff?: number;
|
39
|
-
hideMaxValueDiff?: number;
|
40
|
-
labelPlacement?: "
|
37
|
+
onChangeCommitted?: ((value: number) => void) | undefined;
|
38
|
+
ariaLabel?: string | undefined;
|
39
|
+
showCurrentValue?: boolean | undefined;
|
40
|
+
showRangeValues?: boolean | undefined;
|
41
|
+
rangeValuesPlacement?: string | undefined;
|
42
|
+
showScale?: boolean | undefined;
|
43
|
+
hideMinValueDiff?: number | undefined;
|
44
|
+
hideMaxValueDiff?: number | undefined;
|
45
|
+
labelPlacement?: "outer" | "inner" | undefined;
|
41
46
|
labelContentLeft?: import("react").ReactNode;
|
42
47
|
labelContent?: import("react").ReactNode;
|
43
|
-
multipleStepSize?: number;
|
44
|
-
view?: string;
|
45
|
-
size?: "s" | "m" | "l";
|
46
|
-
type?: "single";
|
47
|
-
pointerSize?: "small" | "
|
48
|
+
multipleStepSize?: number | undefined;
|
49
|
+
view?: string | undefined;
|
50
|
+
size?: "s" | "m" | "l" | undefined;
|
51
|
+
type?: "single" | undefined;
|
52
|
+
pointerSize?: "small" | "none" | "large" | undefined;
|
48
53
|
pointerVisibility: "always" | "hover";
|
49
54
|
currentValueVisibility: "always" | "hover";
|
50
55
|
} & import("react").RefAttributes<HTMLDivElement>) | (import("@salutejs/plasma-new-hope/types/components/Slider/components/SliderBase/SliderBase.types").SliderBaseProps & import("@salutejs/plasma-new-hope/types/components/Slider/components").SliderInternalProps & {
|
51
|
-
|
56
|
+
/**
|
57
|
+
* Слайдер позволяет определить числовое значение в пределах указанного промежутка.
|
58
|
+
* Можно указать два значения.
|
59
|
+
*/
|
60
|
+
onChange?: ((event: import("@salutejs/plasma-new-hope/types/types/FormType").FormTypeNumber) => void) | undefined;
|
52
61
|
name: string;
|
53
|
-
value?:
|
54
|
-
defaultValue?: number;
|
62
|
+
value?: undefined;
|
63
|
+
defaultValue?: number | undefined;
|
55
64
|
} & {
|
56
65
|
orientation: "vertical";
|
57
|
-
sliderAlign?: "center" | "left" | "right" |
|
58
|
-
scaleAlign?:
|
59
|
-
reversed?: boolean;
|
60
|
-
labelReversed?: boolean;
|
66
|
+
sliderAlign?: "center" | "none" | "left" | "right" | undefined;
|
67
|
+
scaleAlign?: undefined;
|
68
|
+
reversed?: boolean | undefined;
|
69
|
+
labelReversed?: boolean | undefined;
|
61
70
|
} & Omit<import("react").HTMLAttributes<HTMLDivElement>, "onChange" | "defaultValue"> & {
|
62
|
-
onChangeCommitted?: (value: number) => void;
|
63
|
-
ariaLabel?: string;
|
64
|
-
showCurrentValue?: boolean;
|
65
|
-
showRangeValues?: boolean;
|
66
|
-
rangeValuesPlacement?: string;
|
67
|
-
showScale?: boolean;
|
68
|
-
hideMinValueDiff?: number;
|
69
|
-
hideMaxValueDiff?: number;
|
70
|
-
labelPlacement?: "
|
71
|
+
onChangeCommitted?: ((value: number) => void) | undefined;
|
72
|
+
ariaLabel?: string | undefined;
|
73
|
+
showCurrentValue?: boolean | undefined;
|
74
|
+
showRangeValues?: boolean | undefined;
|
75
|
+
rangeValuesPlacement?: string | undefined;
|
76
|
+
showScale?: boolean | undefined;
|
77
|
+
hideMinValueDiff?: number | undefined;
|
78
|
+
hideMaxValueDiff?: number | undefined;
|
79
|
+
labelPlacement?: "outer" | "inner" | undefined;
|
71
80
|
labelContentLeft?: import("react").ReactNode;
|
72
81
|
labelContent?: import("react").ReactNode;
|
73
|
-
multipleStepSize?: number;
|
74
|
-
view?: string;
|
75
|
-
size?: "s" | "m" | "l";
|
76
|
-
type?: "single";
|
77
|
-
pointerSize?: "small" | "
|
82
|
+
multipleStepSize?: number | undefined;
|
83
|
+
view?: string | undefined;
|
84
|
+
size?: "s" | "m" | "l" | undefined;
|
85
|
+
type?: "single" | undefined;
|
86
|
+
pointerSize?: "small" | "none" | "large" | undefined;
|
78
87
|
pointerVisibility: "always" | "hover";
|
79
88
|
currentValueVisibility: "always" | "hover";
|
80
89
|
} & import("react").RefAttributes<HTMLDivElement>) | (import("@salutejs/plasma-new-hope/types/components/Slider/components/SliderBase/SliderBase.types").SliderBaseProps & import("@salutejs/plasma-new-hope/types/components/Slider/components").SliderInternalProps & {
|
81
|
-
onChange?: (value: number) => void;
|
90
|
+
onChange?: ((value: number) => void) | undefined;
|
82
91
|
value: number;
|
83
|
-
name?:
|
84
|
-
defaultValue?:
|
92
|
+
name?: undefined;
|
93
|
+
defaultValue?: undefined;
|
85
94
|
} & {
|
86
|
-
orientation?: "horizontal";
|
87
|
-
labelPlacement?: "
|
88
|
-
scaleAlign?: "
|
89
|
-
sliderAlign?:
|
90
|
-
reversed?:
|
91
|
-
labelReversed?:
|
95
|
+
orientation?: "horizontal" | undefined;
|
96
|
+
labelPlacement?: "none" | "left" | "top" | undefined;
|
97
|
+
scaleAlign?: "none" | "bottom" | "side" | undefined;
|
98
|
+
sliderAlign?: "none" | undefined;
|
99
|
+
reversed?: undefined;
|
100
|
+
labelReversed?: undefined;
|
92
101
|
} & Omit<import("react").HTMLAttributes<HTMLDivElement>, "onChange" | "defaultValue"> & {
|
93
|
-
onChangeCommitted?: (value: number) => void;
|
94
|
-
ariaLabel?: string;
|
95
|
-
showCurrentValue?: boolean;
|
96
|
-
showRangeValues?: boolean;
|
97
|
-
rangeValuesPlacement?: string;
|
98
|
-
showScale?: boolean;
|
99
|
-
hideMinValueDiff?: number;
|
100
|
-
hideMaxValueDiff?: number;
|
101
|
-
labelPlacement?: "
|
102
|
+
onChangeCommitted?: ((value: number) => void) | undefined;
|
103
|
+
ariaLabel?: string | undefined;
|
104
|
+
showCurrentValue?: boolean | undefined;
|
105
|
+
showRangeValues?: boolean | undefined;
|
106
|
+
rangeValuesPlacement?: string | undefined;
|
107
|
+
showScale?: boolean | undefined;
|
108
|
+
hideMinValueDiff?: number | undefined;
|
109
|
+
hideMaxValueDiff?: number | undefined;
|
110
|
+
labelPlacement?: "outer" | "inner" | undefined;
|
102
111
|
labelContentLeft?: import("react").ReactNode;
|
103
112
|
labelContent?: import("react").ReactNode;
|
104
|
-
multipleStepSize?: number;
|
105
|
-
view?: string;
|
106
|
-
size?: "s" | "m" | "l";
|
107
|
-
type?: "single";
|
108
|
-
pointerSize?: "small" | "
|
113
|
+
multipleStepSize?: number | undefined;
|
114
|
+
view?: string | undefined;
|
115
|
+
size?: "s" | "m" | "l" | undefined;
|
116
|
+
type?: "single" | undefined;
|
117
|
+
pointerSize?: "small" | "none" | "large" | undefined;
|
109
118
|
pointerVisibility: "always" | "hover";
|
110
119
|
currentValueVisibility: "always" | "hover";
|
111
120
|
} & import("react").RefAttributes<HTMLDivElement>) | (import("@salutejs/plasma-new-hope/types/components/Slider/components/SliderBase/SliderBase.types").SliderBaseProps & import("@salutejs/plasma-new-hope/types/components/Slider/components").SliderInternalProps & {
|
112
|
-
onChange?: (value: number) => void;
|
121
|
+
onChange?: ((value: number) => void) | undefined;
|
113
122
|
value: number;
|
114
|
-
name?:
|
115
|
-
defaultValue?:
|
123
|
+
name?: undefined;
|
124
|
+
defaultValue?: undefined;
|
116
125
|
} & {
|
117
126
|
orientation: "vertical";
|
118
|
-
sliderAlign?: "center" | "left" | "right" |
|
119
|
-
scaleAlign?:
|
120
|
-
reversed?: boolean;
|
121
|
-
labelReversed?: boolean;
|
127
|
+
sliderAlign?: "center" | "none" | "left" | "right" | undefined;
|
128
|
+
scaleAlign?: undefined;
|
129
|
+
reversed?: boolean | undefined;
|
130
|
+
labelReversed?: boolean | undefined;
|
122
131
|
} & Omit<import("react").HTMLAttributes<HTMLDivElement>, "onChange" | "defaultValue"> & {
|
123
|
-
onChangeCommitted?: (value: number) => void;
|
124
|
-
ariaLabel?: string;
|
125
|
-
showCurrentValue?: boolean;
|
126
|
-
showRangeValues?: boolean;
|
127
|
-
rangeValuesPlacement?: string;
|
128
|
-
showScale?: boolean;
|
129
|
-
hideMinValueDiff?: number;
|
130
|
-
hideMaxValueDiff?: number;
|
131
|
-
labelPlacement?: "
|
132
|
+
onChangeCommitted?: ((value: number) => void) | undefined;
|
133
|
+
ariaLabel?: string | undefined;
|
134
|
+
showCurrentValue?: boolean | undefined;
|
135
|
+
showRangeValues?: boolean | undefined;
|
136
|
+
rangeValuesPlacement?: string | undefined;
|
137
|
+
showScale?: boolean | undefined;
|
138
|
+
hideMinValueDiff?: number | undefined;
|
139
|
+
hideMaxValueDiff?: number | undefined;
|
140
|
+
labelPlacement?: "outer" | "inner" | undefined;
|
132
141
|
labelContentLeft?: import("react").ReactNode;
|
133
142
|
labelContent?: import("react").ReactNode;
|
134
|
-
multipleStepSize?: number;
|
135
|
-
view?: string;
|
136
|
-
size?: "s" | "m" | "l";
|
137
|
-
type?: "single";
|
138
|
-
pointerSize?: "small" | "
|
143
|
+
multipleStepSize?: number | undefined;
|
144
|
+
view?: string | undefined;
|
145
|
+
size?: "s" | "m" | "l" | undefined;
|
146
|
+
type?: "single" | undefined;
|
147
|
+
pointerSize?: "small" | "none" | "large" | undefined;
|
139
148
|
pointerVisibility: "always" | "hover";
|
140
149
|
currentValueVisibility: "always" | "hover";
|
141
150
|
} & import("react").RefAttributes<HTMLDivElement>) | (Omit<import("@salutejs/plasma-new-hope/styled-components").DoubleSliderProps, "onChange" | "defaultValue" | "value"> & {
|
142
|
-
onChange?: (event: import("@salutejs/plasma-new-hope/types/types/FormType").FormTypeString) => void;
|
143
|
-
name?: string;
|
144
|
-
value?:
|
145
|
-
defaultValue?: number[];
|
151
|
+
onChange?: ((event: import("@salutejs/plasma-new-hope/types/types/FormType").FormTypeString) => void) | undefined;
|
152
|
+
name?: string | undefined;
|
153
|
+
value?: undefined;
|
154
|
+
defaultValue?: number[] | undefined;
|
146
155
|
} & import("react").RefAttributes<HTMLDivElement>) | (Omit<import("@salutejs/plasma-new-hope/styled-components").DoubleSliderProps, "onChange" | "defaultValue" | "value"> & {
|
147
|
-
onChange?: (values: number[]) => void;
|
148
|
-
name?:
|
149
|
-
value?: number[];
|
150
|
-
defaultValue?:
|
156
|
+
onChange?: ((values: number[]) => void) | undefined;
|
157
|
+
name?: undefined;
|
158
|
+
value?: number[] | undefined;
|
159
|
+
defaultValue?: undefined;
|
151
160
|
} & import("react").RefAttributes<HTMLDivElement>))>;
|
@@ -39,5 +39,5 @@ export declare const Switch: import("react").FunctionComponent<import("@salutejs
|
|
39
39
|
true: import("@salutejs/plasma-new-hope/types/engines/types").PolymorphicClassName;
|
40
40
|
};
|
41
41
|
}> & import("@salutejs/plasma-new-hope/styled-components").SwitchProps & import("react").RefAttributes<HTMLInputElement>>;
|
42
|
-
export type SwitchProps = ComponentProps<typeof SwitchComponent>;
|
42
|
+
export declare type SwitchProps = ComponentProps<typeof SwitchComponent>;
|
43
43
|
export {};
|
@@ -19,24 +19,24 @@ declare const VerticalTabItem: React.FunctionComponent<import("@salutejs/plasma-
|
|
19
19
|
};
|
20
20
|
}> & ((BaseTabItemProps & {
|
21
21
|
orientation: "vertical";
|
22
|
-
contentLeft?: ReactNode;
|
23
|
-
view?: string;
|
24
|
-
size?: string;
|
22
|
+
contentLeft?: React.ReactNode;
|
23
|
+
view?: string | undefined;
|
24
|
+
size?: string | undefined;
|
25
25
|
} & {
|
26
|
-
value?: string | number;
|
27
|
-
contentRight?:
|
26
|
+
value?: string | number | undefined;
|
27
|
+
contentRight?: undefined;
|
28
28
|
} & React.RefAttributes<HTMLButtonElement>) | (BaseTabItemProps & {
|
29
29
|
orientation: "vertical";
|
30
|
-
contentLeft?: ReactNode;
|
31
|
-
view?: string;
|
32
|
-
size?: string;
|
30
|
+
contentLeft?: React.ReactNode;
|
31
|
+
view?: string | undefined;
|
32
|
+
size?: string | undefined;
|
33
33
|
} & {
|
34
|
-
value?:
|
35
|
-
contentRight?: ReactNode;
|
34
|
+
value?: undefined;
|
35
|
+
contentRight?: React.ReactNode;
|
36
36
|
} & React.RefAttributes<HTMLButtonElement>))>;
|
37
|
-
type Sizes = keyof typeof horizontalConfig['variations']['size'];
|
38
|
-
type Views = keyof typeof horizontalConfig['variations']['view'];
|
39
|
-
export type CustomHorizontalTabItemProps = {
|
37
|
+
declare type Sizes = keyof typeof horizontalConfig['variations']['size'];
|
38
|
+
declare type Views = keyof typeof horizontalConfig['variations']['view'];
|
39
|
+
export declare type CustomHorizontalTabItemProps = {
|
40
40
|
/**
|
41
41
|
* Расположение табов
|
42
42
|
*/
|
@@ -71,7 +71,7 @@ export type CustomHorizontalTabItemProps = {
|
|
71
71
|
*/
|
72
72
|
isActive?: boolean;
|
73
73
|
} & RightContent;
|
74
|
-
type TabItemProps = (BaseTabItemProps & CustomHorizontalTabItemProps) | ComponentProps<typeof VerticalTabItem>;
|
74
|
+
declare type TabItemProps = (BaseTabItemProps & CustomHorizontalTabItemProps) | ComponentProps<typeof VerticalTabItem>;
|
75
75
|
/**
|
76
76
|
* Элемент списка, недопустимо использовать вне компонента Tabs.
|
77
77
|
*/
|
@@ -4,7 +4,9 @@ import { config as horizontalConfig } from './horizontal/HorizontalTabs.config';
|
|
4
4
|
declare const VerticalTabs: React.FunctionComponent<import("@salutejs/plasma-new-hope/types/engines/types").PropsType<{
|
5
5
|
view: {
|
6
6
|
divider: import("@salutejs/plasma-new-hope/types/engines/types").PolymorphicClassName;
|
7
|
-
};
|
7
|
+
}; /**
|
8
|
+
* Расположение табов
|
9
|
+
*/
|
8
10
|
size: {
|
9
11
|
xs: import("@salutejs/plasma-new-hope/types/engines/types").PolymorphicClassName;
|
10
12
|
s: import("@salutejs/plasma-new-hope/types/engines/types").PolymorphicClassName;
|
@@ -18,9 +20,9 @@ declare const VerticalTabs: React.FunctionComponent<import("@salutejs/plasma-new
|
|
18
20
|
true: import("@salutejs/plasma-new-hope/types/engines/types").PolymorphicClassName;
|
19
21
|
};
|
20
22
|
}> & BaseTabsProps & import("@salutejs/plasma-new-hope/types/components/Tabs/Tabs.types").CustomVerticalTabsProps & React.RefAttributes<HTMLDivElement>>;
|
21
|
-
type Sizes = keyof typeof horizontalConfig['variations']['size'];
|
22
|
-
type Views = keyof typeof horizontalConfig['variations']['view'];
|
23
|
-
type CustomHorizontalTabsProps = {
|
23
|
+
declare type Sizes = keyof typeof horizontalConfig['variations']['size'];
|
24
|
+
declare type Views = keyof typeof horizontalConfig['variations']['view'];
|
25
|
+
declare type CustomHorizontalTabsProps = {
|
24
26
|
/**
|
25
27
|
* Расположение табов
|
26
28
|
*/
|
@@ -58,7 +60,7 @@ type CustomHorizontalTabsProps = {
|
|
58
60
|
right?: string;
|
59
61
|
};
|
60
62
|
};
|
61
|
-
type TabsProps = (BaseTabsProps & CustomHorizontalTabsProps) | ComponentProps<typeof VerticalTabs>;
|
63
|
+
declare type TabsProps = (BaseTabsProps & CustomHorizontalTabsProps) | ComponentProps<typeof VerticalTabs>;
|
62
64
|
/**
|
63
65
|
* Контейнер вкладок, основной компонент для пользовательской сборки вкладок.
|
64
66
|
*/
|