@douyinfe/semi-ui 2.27.0-alpha.0 → 2.27.0-alpha.2

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 (75) hide show
  1. package/dist/css/semi.css +0 -11
  2. package/dist/css/semi.min.css +1 -1
  3. package/dist/umd/semi-ui.js +67 -123
  4. package/dist/umd/semi-ui.js.map +1 -1
  5. package/dist/umd/semi-ui.min.js +1 -1
  6. package/dist/umd/semi-ui.min.js.map +1 -1
  7. package/lib/cjs/anchor/index.d.ts +1 -1
  8. package/lib/cjs/autoComplete/index.d.ts +1 -1
  9. package/lib/cjs/button/Button.d.ts +2 -2
  10. package/lib/cjs/button/buttonGroup.d.ts +1 -1
  11. package/lib/cjs/button/index.d.ts +2 -2
  12. package/lib/cjs/carousel/CarouselIndicator.d.ts +1 -1
  13. package/lib/cjs/carousel/index.d.ts +2 -2
  14. package/lib/cjs/cascader/index.d.ts +1 -1
  15. package/lib/cjs/cascader/item.d.ts +1 -1
  16. package/lib/cjs/datePicker/datePicker.d.ts +1 -1
  17. package/lib/cjs/form/baseForm.d.ts +1 -1
  18. package/lib/cjs/form/field.d.ts +1 -1
  19. package/lib/cjs/input/index.d.ts +1 -1
  20. package/lib/cjs/input/inputGroup.d.ts +1 -1
  21. package/lib/cjs/popover/index.d.ts +1 -1
  22. package/lib/cjs/rating/index.d.ts +1 -1
  23. package/lib/cjs/rating/item.d.ts +1 -1
  24. package/lib/cjs/switch/index.d.ts +1 -1
  25. package/lib/cjs/table/Table.d.ts +2 -2
  26. package/lib/cjs/table/index.d.ts +1 -1
  27. package/lib/cjs/tabs/TabBar.d.ts +0 -1
  28. package/lib/cjs/tabs/TabBar.js +3 -49
  29. package/lib/cjs/tabs/TabItem.d.ts +2 -22
  30. package/lib/cjs/tabs/TabItem.js +70 -79
  31. package/lib/cjs/tabs/index.d.ts +2 -3
  32. package/lib/cjs/tagInput/index.d.ts +1 -1
  33. package/lib/cjs/timePicker/TimePicker.d.ts +1 -1
  34. package/lib/cjs/timePicker/index.d.ts +1 -1
  35. package/lib/cjs/tooltip/index.d.ts +1 -1
  36. package/lib/cjs/typography/base.d.ts +1 -1
  37. package/lib/cjs/typography/numeral.d.ts +1 -1
  38. package/lib/cjs/typography/paragraph.d.ts +1 -1
  39. package/lib/cjs/typography/text.d.ts +1 -1
  40. package/lib/cjs/typography/title.d.ts +1 -1
  41. package/lib/es/anchor/index.d.ts +1 -1
  42. package/lib/es/autoComplete/index.d.ts +1 -1
  43. package/lib/es/button/Button.d.ts +2 -2
  44. package/lib/es/button/buttonGroup.d.ts +1 -1
  45. package/lib/es/button/index.d.ts +2 -2
  46. package/lib/es/carousel/CarouselIndicator.d.ts +1 -1
  47. package/lib/es/carousel/index.d.ts +2 -2
  48. package/lib/es/cascader/index.d.ts +1 -1
  49. package/lib/es/cascader/item.d.ts +1 -1
  50. package/lib/es/datePicker/datePicker.d.ts +1 -1
  51. package/lib/es/form/baseForm.d.ts +1 -1
  52. package/lib/es/form/field.d.ts +1 -1
  53. package/lib/es/input/index.d.ts +1 -1
  54. package/lib/es/input/inputGroup.d.ts +1 -1
  55. package/lib/es/popover/index.d.ts +1 -1
  56. package/lib/es/rating/index.d.ts +1 -1
  57. package/lib/es/rating/item.d.ts +1 -1
  58. package/lib/es/switch/index.d.ts +1 -1
  59. package/lib/es/table/Table.d.ts +2 -2
  60. package/lib/es/table/index.d.ts +1 -1
  61. package/lib/es/tabs/TabBar.d.ts +0 -1
  62. package/lib/es/tabs/TabBar.js +4 -50
  63. package/lib/es/tabs/TabItem.d.ts +2 -22
  64. package/lib/es/tabs/TabItem.js +67 -77
  65. package/lib/es/tabs/index.d.ts +2 -3
  66. package/lib/es/tagInput/index.d.ts +1 -1
  67. package/lib/es/timePicker/TimePicker.d.ts +1 -1
  68. package/lib/es/timePicker/index.d.ts +1 -1
  69. package/lib/es/tooltip/index.d.ts +1 -1
  70. package/lib/es/typography/base.d.ts +1 -1
  71. package/lib/es/typography/numeral.d.ts +1 -1
  72. package/lib/es/typography/paragraph.d.ts +1 -1
  73. package/lib/es/typography/text.d.ts +1 -1
  74. package/lib/es/typography/title.d.ts +1 -1
  75. package/package.json +8 -8
@@ -39,7 +39,7 @@ declare class Anchor extends BaseComponent<AnchorProps, AnchorState> {
39
39
  static contextType: React.Context<ContextValue>;
40
40
  static Link: typeof Link;
41
41
  static PropTypes: {
42
- size: PropTypes.Requireable<"small" | "default">;
42
+ size: PropTypes.Requireable<"default" | "small">;
43
43
  railTheme: PropTypes.Requireable<"primary" | "tertiary" | "muted">;
44
44
  className: PropTypes.Requireable<string>;
45
45
  style: PropTypes.Requireable<object>;
@@ -125,7 +125,7 @@ declare class AutoComplete<T extends AutoCompleteItems> extends BaseComponent<Au
125
125
  renderSelectedItem: PropTypes.Requireable<(...args: any[]) => any>;
126
126
  suffix: PropTypes.Requireable<PropTypes.ReactNodeLike>;
127
127
  showClear: PropTypes.Requireable<boolean>;
128
- size: PropTypes.Requireable<"small" | "default" | "large">;
128
+ size: PropTypes.Requireable<"default" | "small" | "large">;
129
129
  style: PropTypes.Requireable<object>;
130
130
  stopPropagation: PropTypes.Requireable<NonNullable<string | boolean>>;
131
131
  maxHeight: PropTypes.Requireable<NonNullable<string | number>>;
@@ -47,8 +47,8 @@ export default class Button extends PureComponent<ButtonProps> {
47
47
  disabled: PropTypes.Requireable<boolean>;
48
48
  prefixCls: PropTypes.Requireable<string>;
49
49
  style: PropTypes.Requireable<object>;
50
- size: PropTypes.Requireable<"small" | "default" | "large">;
51
- type: PropTypes.Requireable<"warning" | "primary" | "tertiary" | "secondary" | "danger">;
50
+ size: PropTypes.Requireable<"default" | "small" | "large">;
51
+ type: PropTypes.Requireable<"warning" | "primary" | "secondary" | "tertiary" | "danger">;
52
52
  block: PropTypes.Requireable<boolean>;
53
53
  onClick: PropTypes.Requireable<(...args: any[]) => any>;
54
54
  onMouseDown: PropTypes.Requireable<(...args: any[]) => any>;
@@ -18,7 +18,7 @@ export default class ButtonGroup extends BaseComponent<ButtonGroupProps> {
18
18
  children: PropTypes.Requireable<PropTypes.ReactNodeLike>;
19
19
  disabled: PropTypes.Requireable<boolean>;
20
20
  type: PropTypes.Requireable<string>;
21
- size: PropTypes.Requireable<"small" | "default" | "large">;
21
+ size: PropTypes.Requireable<"default" | "small" | "large">;
22
22
  theme: PropTypes.Requireable<"solid" | "light" | "borderless">;
23
23
  'aria-label': PropTypes.Requireable<string>;
24
24
  };
@@ -22,8 +22,8 @@ declare class Button extends React.PureComponent<ButtonProps> {
22
22
  onMouseEnter: import("prop-types").Requireable<(...args: any[]) => any>;
23
23
  onMouseLeave: import("prop-types").Requireable<(...args: any[]) => any>;
24
24
  disabled: import("prop-types").Requireable<boolean>;
25
- size: import("prop-types").Requireable<"small" | "default" | "large">;
26
- type: import("prop-types").Requireable<"warning" | "primary" | "tertiary" | "secondary" | "danger">;
25
+ size: import("prop-types").Requireable<"default" | "small" | "large">;
26
+ type: import("prop-types").Requireable<"warning" | "primary" | "secondary" | "tertiary" | "danger">;
27
27
  block: import("prop-types").Requireable<boolean>;
28
28
  onClick: import("prop-types").Requireable<(...args: any[]) => any>;
29
29
  onMouseDown: import("prop-types").Requireable<(...args: any[]) => any>;
@@ -12,7 +12,7 @@ declare class CarouselIndicator extends React.PureComponent<CarouselIndicatorPro
12
12
  total: PropTypes.Requireable<number>;
13
13
  onIndicatorChange: PropTypes.Requireable<(...args: any[]) => any>;
14
14
  type: PropTypes.Requireable<"line" | "dot" | "columnar">;
15
- trigger: PropTypes.Requireable<"click" | "hover">;
15
+ trigger: PropTypes.Requireable<"hover" | "click">;
16
16
  };
17
17
  onIndicatorChange: (activeIndex: number) => void;
18
18
  handleIndicatorClick: (activeIndex: number) => void;
@@ -14,7 +14,7 @@ export interface CarouselState {
14
14
  declare class Carousel extends BaseComponent<CarouselProps, CarouselState> {
15
15
  static propTypes: {
16
16
  activeIndex: PropTypes.Requireable<number>;
17
- animation: PropTypes.Requireable<"slide" | "fade">;
17
+ animation: PropTypes.Requireable<"fade" | "slide">;
18
18
  arrowProps: PropTypes.Requireable<object>;
19
19
  autoPlay: PropTypes.Requireable<NonNullable<boolean | object>>;
20
20
  className: PropTypes.Requireable<string>;
@@ -30,7 +30,7 @@ declare class Carousel extends BaseComponent<CarouselProps, CarouselState> {
30
30
  slideDirection: PropTypes.Requireable<"left" | "right">;
31
31
  speed: PropTypes.Requireable<number>;
32
32
  style: PropTypes.Requireable<object>;
33
- trigger: PropTypes.Requireable<"click" | "hover">;
33
+ trigger: PropTypes.Requireable<"hover" | "click">;
34
34
  };
35
35
  static defaultProps: CarouselProps;
36
36
  foundation: CarouselFoundation;
@@ -110,7 +110,7 @@ declare class Cascader extends BaseComponent<CascaderProps, CascaderState> {
110
110
  zIndex: PropTypes.Requireable<number>;
111
111
  value: PropTypes.Requireable<NonNullable<string | number | any[]>>;
112
112
  validateStatus: PropTypes.Requireable<"default" | "error" | "warning" | "success">;
113
- showNext: PropTypes.Requireable<"click" | "hover">;
113
+ showNext: PropTypes.Requireable<"hover" | "click">;
114
114
  stopPropagation: PropTypes.Requireable<NonNullable<string | boolean>>;
115
115
  showClear: PropTypes.Requireable<boolean>;
116
116
  defaultOpen: PropTypes.Requireable<boolean>;
@@ -48,7 +48,7 @@ export default class Item extends PureComponent<CascaderItemProps> {
48
48
  onItemClick: PropTypes.Requireable<(...args: any[]) => any>;
49
49
  onItemHover: PropTypes.Requireable<(...args: any[]) => any>;
50
50
  multiple: PropTypes.Requireable<boolean>;
51
- showNext: PropTypes.Requireable<"click" | "hover">;
51
+ showNext: PropTypes.Requireable<"hover" | "click">;
52
52
  checkedKeys: PropTypes.Requireable<object>;
53
53
  halfCheckedKeys: PropTypes.Requireable<object>;
54
54
  onItemCheckboxClick: PropTypes.Requireable<(...args: any[]) => any>;
@@ -47,7 +47,7 @@ export default class DatePicker extends BaseComponent<DatePickerProps, DatePicke
47
47
  'aria-labelledby': PropTypes.Requireable<string>;
48
48
  'aria-required': PropTypes.Requireable<boolean>;
49
49
  type: PropTypes.Requireable<"date" | "month" | "dateTime" | "dateRange" | "year" | "dateTimeRange">;
50
- size: PropTypes.Requireable<"small" | "default" | "large">;
50
+ size: PropTypes.Requireable<"default" | "small" | "large">;
51
51
  clearIcon: PropTypes.Requireable<PropTypes.ReactNodeLike>;
52
52
  density: PropTypes.Requireable<"default" | "compact">;
53
53
  defaultValue: PropTypes.Requireable<NonNullable<string | number | object>>;
@@ -135,7 +135,7 @@ declare class Form<Values extends Record<string, any> = any> extends BaseCompone
135
135
  preventScroll?: boolean;
136
136
  showRestTagsPopover?: boolean;
137
137
  restTagsPopoverProps?: import("../popover").PopoverProps;
138
- } & Pick<import("../tooltip").TooltipProps, "motion" | "stopPropagation" | "getPopupContainer" | "spacing" | "mouseEnterDelay" | "autoAdjustOverflow" | "mouseLeaveDelay"> & React.RefAttributes<any> & import("./interface").CommonFieldProps, import("./interface").CommonexcludeType>> & import("./interface").SelectStatic;
138
+ } & Pick<import("../tooltip").TooltipProps, "stopPropagation" | "getPopupContainer" | "motion" | "spacing" | "mouseEnterDelay" | "autoAdjustOverflow" | "mouseLeaveDelay"> & React.RefAttributes<any> & import("./interface").CommonFieldProps, import("./interface").CommonexcludeType>> & import("./interface").SelectStatic;
139
139
  static Checkbox: React.ComponentType<import("utility-types").Subtract<import("./interface").CommonFieldProps, import("./interface").RadioCheckboxExcludeProps> & import("../checkbox").CheckboxProps & import("./interface").RCIncludeType>;
140
140
  static CheckboxGroup: React.ComponentType<import("utility-types").Subtract<import("../checkbox").CheckboxGroupProps, import("./interface").CommonexcludeType> & import("./interface").CommonFieldProps & React.RefAttributes<any>>;
141
141
  static Radio: React.ComponentType<import("utility-types").Subtract<import("./interface").CommonFieldProps, import("./interface").RadioCheckboxExcludeProps> & import("../radio").RadioProps & import("./interface").RCIncludeType>;
@@ -83,7 +83,7 @@ declare const FormSelect: import("react").ComponentType<import("utility-types").
83
83
  preventScroll?: boolean;
84
84
  showRestTagsPopover?: boolean;
85
85
  restTagsPopoverProps?: import("../popover").PopoverProps;
86
- } & Pick<import("../tooltip").TooltipProps, "motion" | "stopPropagation" | "getPopupContainer" | "spacing" | "mouseEnterDelay" | "autoAdjustOverflow" | "mouseLeaveDelay"> & import("react").RefAttributes<any> & import("./interface").CommonFieldProps, import("./interface").CommonexcludeType>> & import("./interface").SelectStatic;
86
+ } & Pick<import("../tooltip").TooltipProps, "stopPropagation" | "getPopupContainer" | "motion" | "spacing" | "mouseEnterDelay" | "autoAdjustOverflow" | "mouseLeaveDelay"> & import("react").RefAttributes<any> & import("./interface").CommonFieldProps, import("./interface").CommonexcludeType>> & import("./interface").SelectStatic;
87
87
  declare const FormCheckboxGroup: import("react").ComponentType<import("utility-types").Subtract<import("../checkbox/checkboxGroup").CheckboxGroupProps, import("./interface").CommonexcludeType> & import("./interface").CommonFieldProps & import("react").RefAttributes<any>>;
88
88
  declare const FormCheckbox: import("react").ComponentType<import("utility-types").Subtract<import("./interface").CommonFieldProps, import("./interface").RadioCheckboxExcludeProps> & import("../checkbox/checkbox").CheckboxProps & import("./interface").RCIncludeType>;
89
89
  declare const FormRadioGroup: import("react").ComponentType<import("utility-types").Subtract<import("../radio/radioGroup").RadioGroupProps, import("./interface").CommonexcludeType> & import("./interface").CommonFieldProps & import("react").RefAttributes<any>>;
@@ -83,7 +83,7 @@ declare class Input extends BaseComponent<InputProps, InputState> {
83
83
  showClear: PropTypes.Requireable<boolean>;
84
84
  hideSuffix: PropTypes.Requireable<boolean>;
85
85
  placeholder: PropTypes.Requireable<any>;
86
- size: PropTypes.Requireable<"small" | "default" | "large">;
86
+ size: PropTypes.Requireable<"default" | "small" | "large">;
87
87
  className: PropTypes.Requireable<string>;
88
88
  style: PropTypes.Requireable<object>;
89
89
  validateStatus: PropTypes.Requireable<"default" | "error" | "warning" | "success">;
@@ -21,7 +21,7 @@ export default class inputGroup extends BaseComponent<InputGroupProps, InputGrou
21
21
  static propTypes: {
22
22
  className: PropTypes.Requireable<string>;
23
23
  children: PropTypes.Requireable<PropTypes.ReactNodeLike>;
24
- size: PropTypes.Requireable<"small" | "default" | "large">;
24
+ size: PropTypes.Requireable<"default" | "small" | "large">;
25
25
  style: PropTypes.Requireable<object>;
26
26
  onBlur: PropTypes.Requireable<(...args: any[]) => any>;
27
27
  onFocus: PropTypes.Requireable<(...args: any[]) => any>;
@@ -58,7 +58,7 @@ declare class Popover extends React.PureComponent<PopoverProps, PopoverState> {
58
58
  margin: PropTypes.Requireable<NonNullable<number | object>>;
59
59
  mouseEnterDelay: PropTypes.Requireable<number>;
60
60
  mouseLeaveDelay: PropTypes.Requireable<number>;
61
- trigger: PropTypes.Validator<NonNullable<"click" | "focus" | "hover" | "custom">>;
61
+ trigger: PropTypes.Validator<NonNullable<"hover" | "focus" | "click" | "custom">>;
62
62
  contentClassName: PropTypes.Requireable<NonNullable<string | any[]>>;
63
63
  onVisibleChange: PropTypes.Requireable<(...args: any[]) => any>;
64
64
  onClickOutSide: PropTypes.Requireable<(...args: any[]) => any>;
@@ -69,7 +69,7 @@ export default class Rating extends BaseComponent<RatingProps, RatingState> {
69
69
  onBlur: PropTypes.Requireable<(...args: any[]) => any>;
70
70
  onKeyDown: PropTypes.Requireable<(...args: any[]) => any>;
71
71
  autoFocus: PropTypes.Requireable<boolean>;
72
- size: PropTypes.Requireable<NonNullable<number | "small" | "default">>;
72
+ size: PropTypes.Requireable<NonNullable<number | "default" | "small">>;
73
73
  tooltips: PropTypes.Requireable<string[]>;
74
74
  id: PropTypes.Requireable<string>;
75
75
  preventScroll: PropTypes.Requireable<boolean>;
@@ -40,7 +40,7 @@ export default class Item extends BaseComponent<RatingItemProps, RatingItemState
40
40
  disabled: PropTypes.Requireable<boolean>;
41
41
  count: PropTypes.Requireable<number>;
42
42
  ariaLabelPrefix: PropTypes.Requireable<string>;
43
- size: PropTypes.Requireable<NonNullable<number | "small" | "default">>;
43
+ size: PropTypes.Requireable<NonNullable<number | "default" | "small">>;
44
44
  'aria-describedby': PropTypes.Requireable<string>;
45
45
  onFocus: PropTypes.Requireable<(...args: any[]) => any>;
46
46
  onBlur: PropTypes.Requireable<(...args: any[]) => any>;
@@ -45,7 +45,7 @@ declare class Switch extends BaseComponent<SwitchProps, SwitchState> {
45
45
  onMouseEnter: PropTypes.Requireable<(...args: any[]) => any>;
46
46
  onMouseLeave: PropTypes.Requireable<(...args: any[]) => any>;
47
47
  style: PropTypes.Requireable<object>;
48
- size: PropTypes.Requireable<"small" | "default" | "large">;
48
+ size: PropTypes.Requireable<"default" | "small" | "large">;
49
49
  uncheckedText: PropTypes.Requireable<PropTypes.ReactNodeLike>;
50
50
  id: PropTypes.Requireable<string>;
51
51
  };
@@ -52,7 +52,7 @@ declare class Table<RecordType extends Record<string, any>> extends BaseComponen
52
52
  components: PropTypes.Requireable<any>;
53
53
  bordered: PropTypes.Requireable<boolean>;
54
54
  loading: PropTypes.Requireable<boolean>;
55
- size: PropTypes.Requireable<"small" | "default" | "middle">;
55
+ size: PropTypes.Requireable<"default" | "small" | "middle">;
56
56
  tableLayout: PropTypes.Requireable<"" | "fixed" | "auto">;
57
57
  columns: PropTypes.Requireable<PropTypes.InferProps<{
58
58
  align: PropTypes.Requireable<"left" | "right" | "center">;
@@ -289,7 +289,7 @@ declare class Table<RecordType extends Record<string, any>> extends BaseComponen
289
289
  showTotal?: boolean;
290
290
  pageSize?: number;
291
291
  pageSizeOpts?: number[];
292
- size?: "small" | "default";
292
+ size?: "default" | "small";
293
293
  currentPage?: number;
294
294
  defaultCurrentPage?: number;
295
295
  onPageChange?: (currentPage: number) => void;
@@ -15,7 +15,7 @@ declare class Table<RecordType extends Record<string, any> = Data> extends React
15
15
  components: PropTypes.Requireable<any>;
16
16
  bordered: PropTypes.Requireable<boolean>;
17
17
  loading: PropTypes.Requireable<boolean>;
18
- size: PropTypes.Requireable<"small" | "default" | "middle">;
18
+ size: PropTypes.Requireable<"default" | "small" | "middle">;
19
19
  tableLayout: PropTypes.Requireable<"" | "fixed" | "auto">;
20
20
  columns: PropTypes.Requireable<PropTypes.InferProps<{
21
21
  align: PropTypes.Requireable<"left" | "right" | "center">;
@@ -31,7 +31,6 @@ declare class TabBar extends React.Component<TabBarProps, TabBarState> {
31
31
  renderExtra(): ReactNode;
32
32
  handleItemClick: (itemKey: string, e: MouseEvent<Element>) => void;
33
33
  handleKeyDown: (event: React.KeyboardEvent, itemKey: string, closable: boolean) => void;
34
- renderTabItemInOverflowList: (panel: PlainTab) => ReactNode;
35
34
  renderTabItem: (panel: PlainTab) => ReactNode;
36
35
  renderTabComponents: (list: Array<PlainTab>) => Array<ReactNode>;
37
36
  handleArrowClick: (items: Array<OverflowItem>, pos: 'start' | 'end') => void;
@@ -66,51 +66,6 @@ class TabBar extends _react.default.Component {
66
66
  this.props.handleKeyDown(event, itemKey, closable);
67
67
  };
68
68
 
69
- this.renderTabItemInOverflowList = panel => {
70
- const {
71
- size,
72
- type,
73
- deleteTabItem
74
- } = this.props;
75
- const panelIcon = panel.icon ? this.renderIcon(panel.icon) : null;
76
- const closableIcon = type === 'card' && panel.closable ? /*#__PURE__*/_react.default.createElement(_semiIcons.IconClose, {
77
- "aria-label": "Close",
78
- role: "button",
79
- className: "".concat(_constants.cssClasses.TABS_TAB, "-icon-close"),
80
- onClick: e => deleteTabItem(panel.itemKey, e)
81
- }) : null;
82
- let events = {};
83
- const key = panel.itemKey;
84
-
85
- if (!panel.disabled) {
86
- events = {
87
- onClick: e => this.handleItemClick(key, e)
88
- };
89
- }
90
-
91
- const isSelected = this._isActive(key);
92
-
93
- const className = (0, _classnames.default)(_constants.cssClasses.TABS_TAB, {
94
- [_constants.cssClasses.TABS_TAB_ACTIVE]: isSelected,
95
- [_constants.cssClasses.TABS_TAB_DISABLED]: panel.disabled,
96
- ["".concat(_constants.cssClasses.TABS_TAB, "-small")]: size === 'small',
97
- ["".concat(_constants.cssClasses.TABS_TAB, "-medium")]: size === 'medium'
98
- });
99
- return /*#__PURE__*/_react.default.createElement("div", Object.assign({
100
- role: "tab",
101
- id: "semiTab".concat(key),
102
- "data-tabkey": "semiTab".concat(key),
103
- "aria-controls": "semiTabPanel".concat(key),
104
- "aria-disabled": panel.disabled ? 'true' : 'false',
105
- "aria-selected": isSelected ? 'true' : 'false',
106
- tabIndex: isSelected ? 0 : -1,
107
- onKeyDown: e => this.handleKeyDown(e, key, panel.closable)
108
- }, events, {
109
- className: className,
110
- key: this._getItemKey(key)
111
- }), panelIcon, panel.tab, closableIcon);
112
- };
113
-
114
69
  this.renderTabItem = panel => {
115
70
  const {
116
71
  size,
@@ -122,9 +77,8 @@ class TabBar extends _react.default.Component {
122
77
 
123
78
  const isSelected = this._isActive(panel.itemKey);
124
79
 
125
- return /*#__PURE__*/_react.default.createElement(_TabItem.default, Object.assign({
126
- key: this._getItemKey(panel.itemKey)
127
- }, panel, {
80
+ return /*#__PURE__*/_react.default.createElement(_TabItem.default, Object.assign({}, panel, {
81
+ key: this._getItemKey(panel.itemKey),
128
82
  selected: isSelected,
129
83
  size: size,
130
84
  type: type,
@@ -240,7 +194,7 @@ class TabBar extends _react.default.Component {
240
194
  overflowRenderer: this.renderOverflow,
241
195
  renderMode: "scroll",
242
196
  className: "".concat(_constants.cssClasses.TABS_BAR, "-overflow-list"),
243
- visibleItemRenderer: this.renderTabItemInOverflowList
197
+ visibleItemRenderer: this.renderTabItem
244
198
  });
245
199
  };
246
200
 
@@ -1,5 +1,4 @@
1
1
  import React, { ReactNode, MouseEvent } from 'react';
2
- import PropTypes from 'prop-types';
3
2
  import { TabType, TabSize, TabPosition } from './interface';
4
3
  export interface TabItemProps {
5
4
  tab?: ReactNode;
@@ -15,24 +14,5 @@ export interface TabItemProps {
15
14
  deleteTabItem?: (tabKey: string, event: MouseEvent<Element>) => void;
16
15
  onClick?: (itemKey: string, e: MouseEvent<Element>) => void;
17
16
  }
18
- export default class TabItem extends React.Component<TabItemProps> {
19
- static propsTypes: {
20
- tab: PropTypes.Requireable<PropTypes.ReactNodeLike>;
21
- icon: PropTypes.Requireable<PropTypes.ReactNodeLike>;
22
- size: PropTypes.Requireable<string>;
23
- type: PropTypes.Requireable<string>;
24
- tabPosition: PropTypes.Requireable<string>;
25
- selected: PropTypes.Requireable<boolean>;
26
- closable: PropTypes.Requireable<boolean>;
27
- disabled: PropTypes.Requireable<boolean>;
28
- itemKey: PropTypes.Requireable<string>;
29
- handleKeyDown: PropTypes.Requireable<(...args: any[]) => any>;
30
- deleteTabItem: PropTypes.Requireable<(...args: any[]) => any>;
31
- onClick: PropTypes.Requireable<(...args: any[]) => any>;
32
- };
33
- static elementType: string;
34
- renderIcon(icon: ReactNode): ReactNode;
35
- handleKeyDown: (event: React.KeyboardEvent) => void;
36
- handleClick: (e: React.MouseEvent) => void;
37
- render(): JSX.Element;
38
- }
17
+ declare const ForwardTabItem: React.ForwardRefExoticComponent<TabItemProps & React.RefAttributes<HTMLDivElement>>;
18
+ export default ForwardTabItem;
@@ -5,9 +5,7 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.default = void 0;
7
7
 
8
- var _react = _interopRequireDefault(require("react"));
9
-
10
- var _propTypes = _interopRequireDefault(require("prop-types"));
8
+ var _react = _interopRequireWildcard(require("react"));
11
9
 
12
10
  var _classnames = _interopRequireDefault(require("classnames"));
13
11
 
@@ -17,88 +15,81 @@ var _semiIcons = require("@douyinfe/semi-icons");
17
15
 
18
16
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
17
 
20
- class TabItem extends _react.default.Component {
21
- constructor() {
22
- super(...arguments);
23
-
24
- this.handleKeyDown = event => {
25
- const {
26
- itemKey,
27
- closable,
28
- handleKeyDown
29
- } = this.props;
30
- handleKeyDown && handleKeyDown(event, itemKey, closable);
31
- };
32
-
33
- this.handleClick = e => {
34
- const {
35
- itemKey,
36
- onClick,
37
- disabled
38
- } = this.props;
39
- !disabled && onClick && onClick(itemKey, e);
40
- };
41
- }
18
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
19
+
20
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
42
21
 
43
- renderIcon(icon) {
44
- return /*#__PURE__*/_react.default.createElement("span", null, icon);
22
+ var __rest = void 0 && (void 0).__rest || function (s, e) {
23
+ var t = {};
24
+
25
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
26
+
27
+ if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
28
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
45
29
  }
30
+ return t;
31
+ };
46
32
 
47
- render() {
48
- const {
49
- tab,
50
- size,
51
- type,
52
- icon,
53
- selected,
54
- closable,
55
- disabled,
56
- itemKey,
57
- deleteTabItem,
58
- tabPosition
59
- } = this.props;
60
- const panelIcon = icon ? this.renderIcon(icon) : null;
61
- const className = (0, _classnames.default)(_constants.cssClasses.TABS_TAB, "".concat(_constants.cssClasses.TABS_TAB, "-").concat(type), "".concat(_constants.cssClasses.TABS_TAB, "-").concat(tabPosition), "".concat(_constants.cssClasses.TABS_TAB, "-single"), {
62
- [_constants.cssClasses.TABS_TAB_ACTIVE]: selected,
63
- [_constants.cssClasses.TABS_TAB_DISABLED]: disabled,
64
- ["".concat(_constants.cssClasses.TABS_TAB, "-small")]: size === 'small',
65
- ["".concat(_constants.cssClasses.TABS_TAB, "-medium")]: size === 'medium'
66
- });
67
- const closableIcon = type === 'card' && closable ? /*#__PURE__*/_react.default.createElement(_semiIcons.IconClose, {
33
+ const TabItem = (props, ref) => {
34
+ const {
35
+ tab,
36
+ size,
37
+ type,
38
+ icon,
39
+ selected,
40
+ closable,
41
+ disabled,
42
+ itemKey,
43
+ deleteTabItem,
44
+ tabPosition,
45
+ handleKeyDown,
46
+ onClick
47
+ } = props,
48
+ resetProps = __rest(props, ["tab", "size", "type", "icon", "selected", "closable", "disabled", "itemKey", "deleteTabItem", "tabPosition", "handleKeyDown", "onClick"]);
49
+
50
+ const closableIcon = (0, _react.useMemo)(() => {
51
+ return type === 'card' && closable ? /*#__PURE__*/_react.default.createElement(_semiIcons.IconClose, {
68
52
  "aria-label": "Close",
69
53
  role: "button",
70
54
  className: "".concat(_constants.cssClasses.TABS_TAB, "-icon-close"),
71
55
  onClick: e => deleteTabItem(itemKey, e)
72
56
  }) : null;
73
- return /*#__PURE__*/_react.default.createElement("div", {
74
- role: "tab",
75
- id: "semiTab".concat(itemKey),
76
- "data-tabkey": "semiTab".concat(itemKey),
77
- "aria-controls": "semiTabPanel".concat(itemKey),
78
- "aria-disabled": disabled ? 'true' : 'false',
79
- "aria-selected": selected ? 'true' : 'false',
80
- tabIndex: selected ? 0 : -1,
81
- onKeyDown: this.handleKeyDown,
82
- onClick: this.handleClick,
83
- className: className
84
- }, panelIcon, tab, closableIcon);
85
- }
57
+ }, [type, closable, deleteTabItem, itemKey]);
58
+ const renderIcon = (0, _react.useCallback)(icon => /*#__PURE__*/_react.default.createElement("span", null, icon), []);
59
+ const handleKeyDownInItem = (0, _react.useCallback)(event => {
60
+ handleKeyDown && handleKeyDown(event, itemKey, closable);
61
+ }, [handleKeyDown, itemKey, closable]);
62
+ const handleItemClick = (0, _react.useCallback)(e => {
63
+ !disabled && onClick && onClick(itemKey, e);
64
+ }, [itemKey, disabled, onClick]);
65
+ const panelIcon = icon ? renderIcon(icon) : null;
66
+ const className = (0, _classnames.default)(_constants.cssClasses.TABS_TAB, "".concat(_constants.cssClasses.TABS_TAB, "-").concat(type), "".concat(_constants.cssClasses.TABS_TAB, "-").concat(tabPosition), "".concat(_constants.cssClasses.TABS_TAB, "-single"), {
67
+ [_constants.cssClasses.TABS_TAB_ACTIVE]: selected,
68
+ [_constants.cssClasses.TABS_TAB_DISABLED]: disabled,
69
+ ["".concat(_constants.cssClasses.TABS_TAB, "-small")]: size === 'small',
70
+ ["".concat(_constants.cssClasses.TABS_TAB, "-medium")]: size === 'medium'
71
+ });
72
+ return /*#__PURE__*/_react.default.createElement("div", Object.assign({
73
+ role: "tab",
74
+ id: "semiTab".concat(itemKey),
75
+ "data-tabkey": "semiTab".concat(itemKey),
76
+ "aria-controls": "semiTabPanel".concat(itemKey),
77
+ "aria-disabled": disabled ? 'true' : 'false',
78
+ "aria-selected": selected ? 'true' : 'false',
79
+ tabIndex: selected ? 0 : -1,
80
+ onKeyDown: handleKeyDownInItem,
81
+ onClick: handleItemClick,
82
+ className: className
83
+ }, resetProps, {
84
+ ref: ref
85
+ }), panelIcon, tab, closableIcon);
86
+ }; // Why is forwardRef needed here?
87
+ // Because TabItem needs to be used in OverflowList (when tabs' type is collapsible),
88
+ // OverflowList will pass ref to the outermost div DOM node of TabItem
86
89
 
87
- }
88
-
89
- exports.default = TabItem;
90
- TabItem.propsTypes = {
91
- tab: _propTypes.default.node,
92
- icon: _propTypes.default.node,
93
- size: _propTypes.default.oneOf(_constants.strings.SIZE),
94
- type: _propTypes.default.oneOf(_constants.strings.TYPE_MAP),
95
- tabPosition: _propTypes.default.oneOf(_constants.strings.POSITION_MAP),
96
- selected: _propTypes.default.bool,
97
- closable: _propTypes.default.bool,
98
- disabled: _propTypes.default.bool,
99
- itemKey: _propTypes.default.string,
100
- handleKeyDown: _propTypes.default.func,
101
- deleteTabItem: _propTypes.default.func,
102
- onClick: _propTypes.default.func
103
- };
104
- TabItem.elementType = 'TabItem';
90
+
91
+ const ForwardTabItem = /*#__PURE__*/(0, _react.forwardRef)(TabItem); // @ts-ignore
92
+
93
+ ForwardTabItem.elementType = 'TabItem';
94
+ var _default = ForwardTabItem;
95
+ exports.default = _default;
@@ -1,10 +1,9 @@
1
- import { MouseEvent, ReactElement, ReactNode, RefCallback, RefObject } from 'react';
1
+ import React, { MouseEvent, ReactElement, ReactNode, RefCallback, RefObject } from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  import TabsFoundation, { TabsAdapter } from '@douyinfe/semi-foundation/lib/cjs/tabs/foundation';
4
4
  import BaseComponent from '../_base/baseComponent';
5
5
  import '@douyinfe/semi-foundation/lib/cjs/tabs/tabs.css';
6
6
  import TabPane from './TabPane';
7
- import TabItem from './TabItem';
8
7
  import { PlainTab, TabsProps } from './interface';
9
8
  export * from './interface';
10
9
  export interface TabsState {
@@ -15,7 +14,7 @@ export interface TabsState {
15
14
  }
16
15
  declare class Tabs extends BaseComponent<TabsProps, TabsState> {
17
16
  static TabPane: typeof TabPane;
18
- static TabItem: typeof TabItem;
17
+ static TabItem: React.ForwardRefExoticComponent<import("./TabItem").TabItemProps & React.RefAttributes<HTMLDivElement>>;
19
18
  static propTypes: {
20
19
  activeKey: PropTypes.Requireable<string>;
21
20
  className: PropTypes.Requireable<string>;
@@ -92,7 +92,7 @@ declare class TagInput extends BaseComponent<TagInputProps, TagInputState> {
92
92
  onAdd: PropTypes.Requireable<(...args: any[]) => any>;
93
93
  onRemove: PropTypes.Requireable<(...args: any[]) => any>;
94
94
  onKeyDown: PropTypes.Requireable<(...args: any[]) => any>;
95
- size: PropTypes.Requireable<"small" | "default" | "large">;
95
+ size: PropTypes.Requireable<"default" | "small" | "large">;
96
96
  validateStatus: PropTypes.Requireable<"default" | "error" | "warning" | "success">;
97
97
  prefix: PropTypes.Requireable<NonNullable<PropTypes.ReactNodeLike>>;
98
98
  suffix: PropTypes.Requireable<NonNullable<PropTypes.ReactNodeLike>>;
@@ -130,7 +130,7 @@ export default class TimePicker extends BaseComponent<TimePickerProps, TimePicke
130
130
  secondStep: PropTypes.Requireable<number>;
131
131
  focusOnOpen: PropTypes.Requireable<boolean>;
132
132
  autoFocus: PropTypes.Requireable<boolean>;
133
- size: PropTypes.Requireable<"small" | "default" | "large">;
133
+ size: PropTypes.Requireable<"default" | "small" | "large">;
134
134
  panels: PropTypes.Requireable<PropTypes.InferProps<{
135
135
  panelHeader: PropTypes.Requireable<NonNullable<PropTypes.ReactNodeLike>>;
136
136
  panelFooter: PropTypes.Requireable<NonNullable<PropTypes.ReactNodeLike>>;
@@ -48,7 +48,7 @@ export default class LocaleTimePicker extends React.PureComponent<LocalePickerPr
48
48
  secondStep: import("prop-types").Requireable<number>;
49
49
  focusOnOpen: import("prop-types").Requireable<boolean>;
50
50
  autoFocus: import("prop-types").Requireable<boolean>;
51
- size: import("prop-types").Requireable<"small" | "default" | "large">;
51
+ size: import("prop-types").Requireable<"default" | "small" | "large">;
52
52
  panels: import("prop-types").Requireable<import("prop-types").InferProps<{
53
53
  panelHeader: import("prop-types").Requireable<NonNullable<import("prop-types").ReactNodeLike>>;
54
54
  panelFooter: import("prop-types").Requireable<NonNullable<import("prop-types").ReactNodeLike>>;
@@ -90,7 +90,7 @@ export default class Tooltip extends BaseComponent<TooltipProps, TooltipState> {
90
90
  getPopupContainer: PropTypes.Requireable<(...args: any[]) => any>;
91
91
  mouseEnterDelay: PropTypes.Requireable<number>;
92
92
  mouseLeaveDelay: PropTypes.Requireable<number>;
93
- trigger: PropTypes.Validator<NonNullable<"click" | "focus" | "hover" | "custom">>;
93
+ trigger: PropTypes.Validator<NonNullable<"hover" | "focus" | "click" | "custom">>;
94
94
  className: PropTypes.Requireable<string>;
95
95
  wrapperClassName: PropTypes.Requireable<string>;
96
96
  clickToHide: PropTypes.Requireable<boolean>;
@@ -64,7 +64,7 @@ export default class Base extends Component<BaseTypographyProps, BaseTypographyS
64
64
  spacing: PropTypes.Requireable<"normal" | "extended">;
65
65
  strong: PropTypes.Requireable<boolean>;
66
66
  size: PropTypes.Requireable<"small" | "normal">;
67
- type: PropTypes.Requireable<"warning" | "success" | "primary" | "tertiary" | "secondary" | "danger" | "quaternary">;
67
+ type: PropTypes.Requireable<"warning" | "success" | "primary" | "secondary" | "tertiary" | "danger" | "quaternary">;
68
68
  style: PropTypes.Requireable<object>;
69
69
  className: PropTypes.Requireable<string>;
70
70
  icon: PropTypes.Requireable<NonNullable<PropTypes.ReactNodeLike>>;
@@ -38,7 +38,7 @@ export default class Numeral extends PureComponent<NumeralProps> {
38
38
  underline: PropTypes.Requireable<boolean>;
39
39
  link: PropTypes.Requireable<NonNullable<boolean | object>>;
40
40
  strong: PropTypes.Requireable<boolean>;
41
- type: PropTypes.Requireable<"warning" | "success" | "primary" | "tertiary" | "secondary" | "danger" | "quaternary">;
41
+ type: PropTypes.Requireable<"warning" | "success" | "primary" | "secondary" | "tertiary" | "danger" | "quaternary">;
42
42
  size: PropTypes.Requireable<"small" | "normal">;
43
43
  style: PropTypes.Requireable<object>;
44
44
  className: PropTypes.Requireable<string>;
@@ -29,7 +29,7 @@ export default class Paragraph extends PureComponent<ParagraphProps> {
29
29
  link: PropTypes.Requireable<NonNullable<boolean | object>>;
30
30
  underline: PropTypes.Requireable<boolean>;
31
31
  strong: PropTypes.Requireable<boolean>;
32
- type: PropTypes.Requireable<"warning" | "success" | "primary" | "tertiary" | "secondary" | "danger" | "quaternary">;
32
+ type: PropTypes.Requireable<"warning" | "success" | "primary" | "secondary" | "tertiary" | "danger" | "quaternary">;
33
33
  size: PropTypes.Requireable<"small" | "normal">;
34
34
  spacing: PropTypes.Requireable<"normal" | "extended">;
35
35
  style: PropTypes.Requireable<object>;