advance-semi-theme 1.0.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.
Files changed (169) hide show
  1. package/README.md +214 -0
  2. package/dist/antd/index.d.ts +159 -0
  3. package/dist/antd/index.js +1378 -0
  4. package/dist/antd/plugin.d.ts +34 -0
  5. package/dist/antd/plugin.js +12 -0
  6. package/dist/antd/styles/all.css +83 -0
  7. package/dist/antd/styles/base.css +202 -0
  8. package/dist/antd/styles/components/affix.css +7 -0
  9. package/dist/antd/styles/components/ai.css +242 -0
  10. package/dist/antd/styles/components/alert.css +149 -0
  11. package/dist/antd/styles/components/anchor.css +40 -0
  12. package/dist/antd/styles/components/app.css +9 -0
  13. package/dist/antd/styles/components/autocomplete.css +56 -0
  14. package/dist/antd/styles/components/avatar.css +37 -0
  15. package/dist/antd/styles/components/backtop.css +106 -0
  16. package/dist/antd/styles/components/badge.css +76 -0
  17. package/dist/antd/styles/components/breadcrumb.css +37 -0
  18. package/dist/antd/styles/components/button.css +528 -0
  19. package/dist/antd/styles/components/calendar.css +55 -0
  20. package/dist/antd/styles/components/card.css +113 -0
  21. package/dist/antd/styles/components/carousel.css +57 -0
  22. package/dist/antd/styles/components/cascader.css +99 -0
  23. package/dist/antd/styles/components/checkableTag.css +26 -0
  24. package/dist/antd/styles/components/checkbox.css +119 -0
  25. package/dist/antd/styles/components/collapse.css +74 -0
  26. package/dist/antd/styles/components/colorpicker.css +94 -0
  27. package/dist/antd/styles/components/configprovider.css +6 -0
  28. package/dist/antd/styles/components/datepicker.css +346 -0
  29. package/dist/antd/styles/components/descriptions.css +63 -0
  30. package/dist/antd/styles/components/divider.css +34 -0
  31. package/dist/antd/styles/components/drawer.css +71 -0
  32. package/dist/antd/styles/components/dropdown.css +94 -0
  33. package/dist/antd/styles/components/empty.css +40 -0
  34. package/dist/antd/styles/components/flex.css +19 -0
  35. package/dist/antd/styles/components/floatbutton.css +65 -0
  36. package/dist/antd/styles/components/form.css +90 -0
  37. package/dist/antd/styles/components/grid.css +11 -0
  38. package/dist/antd/styles/components/icon.css +18 -0
  39. package/dist/antd/styles/components/image.css +125 -0
  40. package/dist/antd/styles/components/input.css +459 -0
  41. package/dist/antd/styles/components/inputnumber.css +102 -0
  42. package/dist/antd/styles/components/layout.css +63 -0
  43. package/dist/antd/styles/components/list.css +109 -0
  44. package/dist/antd/styles/components/mentions.css +84 -0
  45. package/dist/antd/styles/components/menu.css +190 -0
  46. package/dist/antd/styles/components/message.css +68 -0
  47. package/dist/antd/styles/components/modal.css +124 -0
  48. package/dist/antd/styles/components/notification.css +89 -0
  49. package/dist/antd/styles/components/pageheader.css +62 -0
  50. package/dist/antd/styles/components/pagination.css +139 -0
  51. package/dist/antd/styles/components/popconfirm.css +64 -0
  52. package/dist/antd/styles/components/popover.css +40 -0
  53. package/dist/antd/styles/components/progress.css +105 -0
  54. package/dist/antd/styles/components/qrcode.css +43 -0
  55. package/dist/antd/styles/components/radio.css +166 -0
  56. package/dist/antd/styles/components/rate.css +47 -0
  57. package/dist/antd/styles/components/result.css +63 -0
  58. package/dist/antd/styles/components/scrollbar.css +22 -0
  59. package/dist/antd/styles/components/segmented.css +75 -0
  60. package/dist/antd/styles/components/select.css +282 -0
  61. package/dist/antd/styles/components/skeleton.css +96 -0
  62. package/dist/antd/styles/components/slider.css +119 -0
  63. package/dist/antd/styles/components/space.css +59 -0
  64. package/dist/antd/styles/components/spin.css +91 -0
  65. package/dist/antd/styles/components/statistic.css +48 -0
  66. package/dist/antd/styles/components/steps.css +176 -0
  67. package/dist/antd/styles/components/switch.css +128 -0
  68. package/dist/antd/styles/components/table.css +197 -0
  69. package/dist/antd/styles/components/tabs.css +212 -0
  70. package/dist/antd/styles/components/tag.css +286 -0
  71. package/dist/antd/styles/components/textArea.css +40 -0
  72. package/dist/antd/styles/components/timeline.css +106 -0
  73. package/dist/antd/styles/components/timepicker.css +105 -0
  74. package/dist/antd/styles/components/tooltip.css +37 -0
  75. package/dist/antd/styles/components/tour.css +114 -0
  76. package/dist/antd/styles/components/transfer.css +232 -0
  77. package/dist/antd/styles/components/tree.css +143 -0
  78. package/dist/antd/styles/components/treeselect.css +46 -0
  79. package/dist/antd/styles/components/typography.css +184 -0
  80. package/dist/antd/styles/components/upload.css +181 -0
  81. package/dist/antd/styles/components/watermark.css +16 -0
  82. package/dist/antd/styles/dark.css +533 -0
  83. package/dist/antd/styles/index.css +115 -0
  84. package/dist/antd/styles/overrides.css +147 -0
  85. package/dist/antd/styles/variables.css +259 -0
  86. package/dist/chunk-FMQWBDDZ.js +207 -0
  87. package/dist/chunk-NGAVTDQ2.js +200 -0
  88. package/dist/chunk-QQOB6AOA.js +213 -0
  89. package/dist/core/index.d.ts +179 -0
  90. package/dist/core/index.js +10 -0
  91. package/dist/core/variables.css +258 -0
  92. package/dist/element/index.d.ts +3 -0
  93. package/dist/element/index.js +17 -0
  94. package/dist/element/plugin.d.ts +34 -0
  95. package/dist/element/plugin.js +12 -0
  96. package/dist/element/styles/base.css +277 -0
  97. package/dist/element/styles/components/affix.css +7 -0
  98. package/dist/element/styles/components/alert.css +44 -0
  99. package/dist/element/styles/components/anchor.css +34 -0
  100. package/dist/element/styles/components/autocomplete.css +61 -0
  101. package/dist/element/styles/components/avatar.css +31 -0
  102. package/dist/element/styles/components/backtop.css +22 -0
  103. package/dist/element/styles/components/badge.css +48 -0
  104. package/dist/element/styles/components/breadcrumb.css +38 -0
  105. package/dist/element/styles/components/button.css +193 -0
  106. package/dist/element/styles/components/calendar.css +58 -0
  107. package/dist/element/styles/components/card.css +29 -0
  108. package/dist/element/styles/components/carousel.css +78 -0
  109. package/dist/element/styles/components/cascader.css +120 -0
  110. package/dist/element/styles/components/check-tag.css +35 -0
  111. package/dist/element/styles/components/checkbox.css +39 -0
  112. package/dist/element/styles/components/collapse.css +58 -0
  113. package/dist/element/styles/components/color-picker.css +82 -0
  114. package/dist/element/styles/components/config-provider.css +6 -0
  115. package/dist/element/styles/components/container.css +26 -0
  116. package/dist/element/styles/components/datepicker.css +165 -0
  117. package/dist/element/styles/components/descriptions-item.css +6 -0
  118. package/dist/element/styles/components/descriptions.css +51 -0
  119. package/dist/element/styles/components/dialog.css +91 -0
  120. package/dist/element/styles/components/divider.css +37 -0
  121. package/dist/element/styles/components/drawer.css +33 -0
  122. package/dist/element/styles/components/dropdown.css +30 -0
  123. package/dist/element/styles/components/empty.css +28 -0
  124. package/dist/element/styles/components/form.css +106 -0
  125. package/dist/element/styles/components/image.css +59 -0
  126. package/dist/element/styles/components/infinite-scroll.css +24 -0
  127. package/dist/element/styles/components/input-number.css +95 -0
  128. package/dist/element/styles/components/input.css +170 -0
  129. package/dist/element/styles/components/link.css +73 -0
  130. package/dist/element/styles/components/loading.css +50 -0
  131. package/dist/element/styles/components/mention.css +49 -0
  132. package/dist/element/styles/components/menu.css +140 -0
  133. package/dist/element/styles/components/message.css +88 -0
  134. package/dist/element/styles/components/notification.css +81 -0
  135. package/dist/element/styles/components/page-header.css +41 -0
  136. package/dist/element/styles/components/pagination.css +135 -0
  137. package/dist/element/styles/components/popconfirm.css +35 -0
  138. package/dist/element/styles/components/popover.css +22 -0
  139. package/dist/element/styles/components/progress.css +28 -0
  140. package/dist/element/styles/components/radio.css +64 -0
  141. package/dist/element/styles/components/rate.css +33 -0
  142. package/dist/element/styles/components/result.css +51 -0
  143. package/dist/element/styles/components/row.css +11 -0
  144. package/dist/element/styles/components/scrollbar.css +33 -0
  145. package/dist/element/styles/components/segmented.css +59 -0
  146. package/dist/element/styles/components/select.css +226 -0
  147. package/dist/element/styles/components/skeleton.css +65 -0
  148. package/dist/element/styles/components/slider.css +93 -0
  149. package/dist/element/styles/components/space.css +19 -0
  150. package/dist/element/styles/components/statistic.css +33 -0
  151. package/dist/element/styles/components/steps.css +122 -0
  152. package/dist/element/styles/components/switch.css +32 -0
  153. package/dist/element/styles/components/table.css +144 -0
  154. package/dist/element/styles/components/tabs.css +125 -0
  155. package/dist/element/styles/components/tag.css +150 -0
  156. package/dist/element/styles/components/text.css +50 -0
  157. package/dist/element/styles/components/time-picker.css +106 -0
  158. package/dist/element/styles/components/timeline.css +58 -0
  159. package/dist/element/styles/components/tooltip.css +22 -0
  160. package/dist/element/styles/components/tour.css +58 -0
  161. package/dist/element/styles/components/transfer.css +181 -0
  162. package/dist/element/styles/components/tree-select.css +28 -0
  163. package/dist/element/styles/components/tree.css +66 -0
  164. package/dist/element/styles/components/upload.css +96 -0
  165. package/dist/element/styles/components/virtualized.css +75 -0
  166. package/dist/element/styles/components/watermark.css +20 -0
  167. package/dist/element/styles/dark.css +82 -0
  168. package/dist/element/styles/index.css +107 -0
  169. package/package.json +78 -0
@@ -0,0 +1,63 @@
1
+ /**
2
+ * Result 结果 - Semi Design 风格
3
+ */
4
+
5
+ .semi:where([data-semi="all"], [data-semi-result]) .ant-result {
6
+ padding: 48px 32px;
7
+ }
8
+
9
+ /* 图标 */
10
+ .semi:where([data-semi="all"], [data-semi-result]) .ant-result-icon {
11
+ margin-bottom: 24px;
12
+ }
13
+
14
+ .semi:where([data-semi="all"], [data-semi-result]) .ant-result-icon > .anticon {
15
+ font-size: 72px;
16
+ }
17
+
18
+ .semi:where([data-semi="all"], [data-semi-result]) .ant-result-success .ant-result-icon > .anticon {
19
+ color: var(--semi-color-success);
20
+ }
21
+
22
+ .semi:where([data-semi="all"], [data-semi-result]) .ant-result-error .ant-result-icon > .anticon {
23
+ color: var(--semi-color-danger);
24
+ }
25
+
26
+ .semi:where([data-semi="all"], [data-semi-result]) .ant-result-info .ant-result-icon > .anticon {
27
+ color: var(--semi-color-primary);
28
+ }
29
+
30
+ .semi:where([data-semi="all"], [data-semi-result]) .ant-result-warning .ant-result-icon > .anticon {
31
+ color: var(--semi-color-warning);
32
+ }
33
+
34
+ /* 标题 */
35
+ .semi:where([data-semi="all"], [data-semi-result]) .ant-result-title {
36
+ color: var(--semi-color-text-0);
37
+ font-size: 24px;
38
+ font-weight: 600;
39
+ margin-bottom: 8px;
40
+ }
41
+
42
+ /* 副标题 */
43
+ .semi:where([data-semi="all"], [data-semi-result]) .ant-result-subtitle {
44
+ color: var(--semi-color-text-2);
45
+ font-size: var(--semi-font-size-regular);
46
+ }
47
+
48
+ /* 额外内容 */
49
+ .semi:where([data-semi="all"], [data-semi-result]) .ant-result-extra {
50
+ margin-top: 24px;
51
+ }
52
+
53
+ .semi:where([data-semi="all"], [data-semi-result]) .ant-result-extra > * {
54
+ margin-inline-end: 8px;
55
+ }
56
+
57
+ /* 内容区 */
58
+ .semi:where([data-semi="all"], [data-semi-result]) .ant-result-content {
59
+ background: var(--semi-color-fill-0);
60
+ border-radius: var(--semi-border-radius-medium);
61
+ margin-top: 24px;
62
+ padding: 24px;
63
+ }
@@ -0,0 +1,22 @@
1
+ /**
2
+ * Scrollbar 滚动条 - Semi Design 风格
3
+ * 用于自定义滚动条样式
4
+ */
5
+
6
+ .semi:where([data-semi="all"]) ::-webkit-scrollbar {
7
+ width: 8px;
8
+ height: 8px;
9
+ }
10
+
11
+ .semi:where([data-semi="all"]) ::-webkit-scrollbar-track {
12
+ background: transparent;
13
+ }
14
+
15
+ .semi:where([data-semi="all"]) ::-webkit-scrollbar-thumb {
16
+ background-color: var(--semi-color-fill-2);
17
+ border-radius: 100px;
18
+ }
19
+
20
+ .semi:where([data-semi="all"]) ::-webkit-scrollbar-thumb:hover {
21
+ background-color: var(--semi-color-fill-3);
22
+ }
@@ -0,0 +1,75 @@
1
+ /**
2
+ * Segmented 分段控制器 - Semi Design 风格
3
+ */
4
+
5
+ .semi:where([data-semi="all"], [data-semi-segmented]) .ant-segmented {
6
+ background-color: var(--semi-color-fill-0);
7
+ border-radius: var(--semi-border-radius-small);
8
+ padding: 2px;
9
+ }
10
+
11
+ .semi:where([data-semi="all"], [data-semi-segmented]) .ant-segmented-group {
12
+ gap: 2px;
13
+ }
14
+
15
+ .semi:where([data-semi="all"], [data-semi-segmented]) .ant-segmented-item {
16
+ border-radius: calc(var(--semi-border-radius-small) - 2px);
17
+ color: var(--semi-color-text-1);
18
+ transition: all var(--semi-transition-duration) var(--semi-transition-timing);
19
+ }
20
+
21
+ .semi:where([data-semi="all"], [data-semi-segmented]) .ant-segmented-item:hover:not(.ant-segmented-item-selected):not(.ant-segmented-item-disabled) {
22
+ color: var(--semi-color-text-0);
23
+ }
24
+
25
+ .semi:where([data-semi="all"], [data-semi-segmented]) .ant-segmented-item-selected {
26
+ background-color: #fff;
27
+ box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
28
+ color: var(--semi-color-text-0);
29
+ }
30
+
31
+ .semi:where([data-semi="all"], [data-semi-segmented]) .ant-segmented-item-disabled {
32
+ color: var(--semi-color-disabled-text);
33
+ }
34
+
35
+ .semi:where([data-semi="all"], [data-semi-segmented]) .ant-segmented-item-label {
36
+ min-height: 28px;
37
+ line-height: 28px;
38
+ padding: 0 12px;
39
+ }
40
+
41
+ .semi:where([data-semi="all"], [data-semi-segmented]) .ant-segmented-item-icon {
42
+ margin-right: 6px;
43
+ }
44
+
45
+ /* 大尺寸 */
46
+ .semi:where([data-semi="all"], [data-semi-segmented]) .ant-segmented-lg .ant-segmented-item-label {
47
+ min-height: 36px;
48
+ line-height: 36px;
49
+ padding: 0 16px;
50
+ font-size: 16px;
51
+ }
52
+
53
+ /* 小尺寸 */
54
+ .semi:where([data-semi="all"], [data-semi-segmented]) .ant-segmented-sm .ant-segmented-item-label {
55
+ min-height: 24px;
56
+ line-height: 24px;
57
+ padding: 0 8px;
58
+ font-size: var(--semi-font-size-small);
59
+ }
60
+
61
+ /* Block 模式 */
62
+ .semi:where([data-semi="all"], [data-semi-segmented]) .ant-segmented-block {
63
+ width: 100%;
64
+ }
65
+
66
+ .semi:where([data-semi="all"], [data-semi-segmented]) .ant-segmented-block .ant-segmented-item {
67
+ flex: 1;
68
+ }
69
+
70
+ /* 滑块动画 */
71
+ .semi:where([data-semi="all"], [data-semi-segmented]) .ant-segmented-thumb {
72
+ background-color: #fff;
73
+ border-radius: calc(var(--semi-border-radius-small) - 2px);
74
+ box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
75
+ }
@@ -0,0 +1,282 @@
1
+ /**
2
+ * Select 选择器 - Semi Design 风格
3
+ *
4
+ * 基于 Semi Design 源码: packages/semi-foundation/select/select.scss
5
+ *
6
+ * 状态说明:
7
+ * - 默认: fill-0 背景 + 透明边框
8
+ * - 悬浮: fill-1 背景 + 透明边框
9
+ * - 聚焦/打开: fill-0 背景 + focus-border 边框
10
+ */
11
+
12
+ /* ========== 基础样式 ========== */
13
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select:not(.ant-select-customize-input) .ant-select-selector {
14
+ background-color: var(--semi-color-fill-0);
15
+ border: 1px solid transparent;
16
+ border-radius: var(--semi-border-radius-small);
17
+ height: 32px;
18
+ padding: 0 12px;
19
+ transition: background-color 0.1s ease, border 0.1s ease;
20
+ }
21
+
22
+ /* 悬浮状态 */
23
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select:not(.ant-select-disabled):not(.ant-select-customize-input):not(.ant-select-focused):not(.ant-select-open):hover .ant-select-selector {
24
+ background-color: var(--semi-color-fill-1);
25
+ border-color: transparent;
26
+ }
27
+
28
+ /* 聚焦/打开状态 */
29
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select:not(.ant-select-disabled):not(.ant-select-customize-input).ant-select-focused .ant-select-selector,
30
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select:not(.ant-select-disabled):not(.ant-select-customize-input).ant-select-open .ant-select-selector {
31
+ background-color: var(--semi-color-fill-0);
32
+ border-color: var(--semi-color-focus-border);
33
+ box-shadow: none;
34
+ outline: none;
35
+ }
36
+
37
+ /* ========== 选中值显示 ========== */
38
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-selection-item {
39
+ color: var(--semi-color-text-0);
40
+ line-height: 30px;
41
+ }
42
+
43
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-selection-placeholder {
44
+ color: var(--semi-color-text-2);
45
+ }
46
+
47
+ /* ========== 箭头图标 ========== */
48
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-arrow {
49
+ color: var(--semi-color-text-2);
50
+ transition: transform 0.15s ease;
51
+ }
52
+
53
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-open .ant-select-arrow {
54
+ transform: rotate(180deg);
55
+ }
56
+
57
+ /* ========== 清除按钮 ========== */
58
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-clear {
59
+ background: transparent;
60
+ color: var(--semi-color-text-2);
61
+ }
62
+
63
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-clear:hover {
64
+ color: var(--semi-color-primary-hover);
65
+ }
66
+
67
+ /* ========== 尺寸 ========== */
68
+ /* Large */
69
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-lg:not(.ant-select-customize-input) .ant-select-selector {
70
+ height: 40px;
71
+ border-radius: var(--semi-border-radius-small);
72
+ }
73
+
74
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-lg .ant-select-selection-item {
75
+ line-height: 38px;
76
+ }
77
+
78
+ /* Small */
79
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-sm:not(.ant-select-customize-input) .ant-select-selector {
80
+ height: 24px;
81
+ padding: 0 8px;
82
+ border-radius: var(--semi-border-radius-small);
83
+ }
84
+
85
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-sm .ant-select-selection-item {
86
+ line-height: 22px;
87
+ }
88
+
89
+ /* ========== 多选模式 ========== */
90
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-multiple .ant-select-selector {
91
+ padding: 2px 4px;
92
+ min-height: 32px;
93
+ height: auto;
94
+ }
95
+
96
+ /* 多选标签样式 - Semi Design Tag Light 风格 */
97
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-multiple .ant-select-selection-item {
98
+ background: rgba(46, 50, 56, 0.09);
99
+ border: none;
100
+ border-radius: 3px;
101
+ color: var(--semi-color-text-0);
102
+ height: 24px;
103
+ line-height: 24px;
104
+ margin-inline-end: 4px;
105
+ margin-block: 1px;
106
+ padding-inline-start: 8px;
107
+ padding-inline-end: 4px;
108
+ font-size: 12px;
109
+ }
110
+
111
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-multiple .ant-select-selection-item-content {
112
+ margin-inline-end: 4px;
113
+ line-height: 24px;
114
+ }
115
+
116
+ /* 删除按钮 */
117
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-multiple .ant-select-selection-item-remove {
118
+ color: var(--semi-color-text-2);
119
+ font-size: 10px;
120
+ display: inline-flex;
121
+ align-items: center;
122
+ justify-content: center;
123
+ }
124
+
125
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-multiple .ant-select-selection-item-remove:hover {
126
+ color: var(--semi-color-text-0);
127
+ }
128
+
129
+ /* 多选搜索 */
130
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-multiple .ant-select-selection-search {
131
+ margin-inline-start: 0;
132
+ }
133
+
134
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-multiple .ant-select-selection-search-input {
135
+ height: 24px;
136
+ }
137
+
138
+ /* 多选溢出容器 */
139
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-multiple .ant-select-selection-overflow {
140
+ display: flex;
141
+ flex-wrap: wrap;
142
+ align-items: center;
143
+ }
144
+
145
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-multiple .ant-select-selection-overflow-item {
146
+ display: inline-flex;
147
+ align-items: center;
148
+ }
149
+
150
+ /* ========== 状态 - Error ========== */
151
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-status-error:not(.ant-select-disabled) .ant-select-selector {
152
+ background-color: var(--semi-color-danger-light-default);
153
+ border-color: var(--semi-color-danger-light-default);
154
+ }
155
+
156
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-status-error:not(.ant-select-disabled):not(.ant-select-focused):hover .ant-select-selector {
157
+ background-color: var(--semi-color-danger-light-hover);
158
+ border-color: var(--semi-color-danger-light-hover);
159
+ }
160
+
161
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-status-error:not(.ant-select-disabled).ant-select-focused .ant-select-selector {
162
+ background-color: var(--semi-color-danger-light-default);
163
+ border-color: var(--semi-color-danger);
164
+ box-shadow: none;
165
+ outline: none;
166
+ }
167
+
168
+ /* ========== 状态 - Warning ========== */
169
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-status-warning:not(.ant-select-disabled) .ant-select-selector {
170
+ background-color: var(--semi-color-warning-light-default);
171
+ border-color: var(--semi-color-warning-light-default);
172
+ }
173
+
174
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-status-warning:not(.ant-select-disabled):not(.ant-select-focused):hover .ant-select-selector {
175
+ background-color: var(--semi-color-warning-light-hover);
176
+ border-color: var(--semi-color-warning-light-hover);
177
+ }
178
+
179
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-status-warning:not(.ant-select-disabled).ant-select-focused .ant-select-selector {
180
+ background-color: var(--semi-color-warning-light-default);
181
+ border-color: var(--semi-color-warning);
182
+ box-shadow: none;
183
+ outline: none;
184
+ }
185
+
186
+ /* ========== 禁用状态 ========== */
187
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-disabled .ant-select-selector {
188
+ background-color: var(--semi-color-disabled-fill);
189
+ border-color: transparent;
190
+ color: var(--semi-color-disabled-text);
191
+ cursor: not-allowed;
192
+ }
193
+
194
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-disabled .ant-select-selection-item,
195
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-disabled .ant-select-selection-placeholder {
196
+ color: var(--semi-color-disabled-text);
197
+ }
198
+
199
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-disabled .ant-select-arrow {
200
+ color: var(--semi-color-disabled-text);
201
+ }
202
+
203
+ /* ========== 搜索 ========== */
204
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-selection-search-input {
205
+ color: var(--semi-color-text-0);
206
+ }
207
+
208
+ /* ========== 无边框模式 ========== */
209
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-borderless .ant-select-selector {
210
+ background: transparent;
211
+ border: none;
212
+ }
213
+
214
+ .semi:where([data-semi="all"], [data-semi-select]) .ant-select-borderless:not(.ant-select-focused):not(.ant-select-open):hover .ant-select-selector {
215
+ background-color: var(--semi-color-fill-0);
216
+ }
217
+
218
+ /* ==========================================================================
219
+ 下拉菜单 (Portal 组件 - 渲染在 body 下)
220
+ 使用 body.semi 选择器确保样式生效
221
+ ========================================================================== */
222
+
223
+ /* 下拉面板容器 */
224
+ body.semi .ant-select-dropdown,
225
+ .semi .ant-select-dropdown {
226
+ background-color: var(--semi-color-bg-0);
227
+ border-radius: var(--semi-border-radius-medium);
228
+ box-shadow: var(--semi-shadow-elevated);
229
+ padding: 4px;
230
+ }
231
+
232
+ /* 下拉选项 */
233
+ body.semi .ant-select-item,
234
+ .semi .ant-select-item {
235
+ border-radius: var(--semi-border-radius-small);
236
+ color: var(--semi-color-text-0);
237
+ min-height: 32px;
238
+ padding: 8px 12px;
239
+ transition: background-color 0.1s ease;
240
+ }
241
+
242
+ /* 选项悬浮 */
243
+ body.semi .ant-select-item-option-active:not(.ant-select-item-option-disabled),
244
+ .semi .ant-select-item-option-active:not(.ant-select-item-option-disabled) {
245
+ background-color: var(--semi-color-fill-0);
246
+ }
247
+
248
+ /* 选项选中 */
249
+ body.semi .ant-select-item-option-selected:not(.ant-select-item-option-disabled),
250
+ .semi .ant-select-item-option-selected:not(.ant-select-item-option-disabled) {
251
+ background-color: var(--semi-color-primary-light-default);
252
+ color: var(--semi-color-primary);
253
+ font-weight: 600;
254
+ }
255
+
256
+ body.semi .ant-select-item-option-selected:not(.ant-select-item-option-disabled):hover,
257
+ .semi .ant-select-item-option-selected:not(.ant-select-item-option-disabled):hover {
258
+ background-color: var(--semi-color-primary-light-hover);
259
+ }
260
+
261
+ /* 选项禁用 */
262
+ body.semi .ant-select-item-option-disabled,
263
+ .semi .ant-select-item-option-disabled {
264
+ color: var(--semi-color-disabled-text);
265
+ cursor: not-allowed;
266
+ }
267
+
268
+ /* 分组标题 */
269
+ body.semi .ant-select-item-group,
270
+ .semi .ant-select-item-group {
271
+ color: var(--semi-color-text-2);
272
+ font-size: var(--semi-font-size-small);
273
+ padding: 8px 12px 4px;
274
+ }
275
+
276
+ /* 空状态 */
277
+ body.semi .ant-select-item-empty,
278
+ .semi .ant-select-item-empty {
279
+ color: var(--semi-color-text-2);
280
+ text-align: center;
281
+ padding: 16px;
282
+ }
@@ -0,0 +1,96 @@
1
+ /**
2
+ * Skeleton 骨架屏 - Semi Design 风格
3
+ */
4
+
5
+ .semi:where([data-semi="all"], [data-semi-skeleton]) .ant-skeleton {
6
+ display: table;
7
+ width: 100%;
8
+ }
9
+
10
+ /* 头像骨架 */
11
+ .semi:where([data-semi="all"], [data-semi-skeleton]) .ant-skeleton-avatar {
12
+ background: var(--semi-color-fill-0);
13
+ border-radius: var(--semi-border-radius-full);
14
+ }
15
+
16
+ .semi:where([data-semi="all"], [data-semi-skeleton]) .ant-skeleton-avatar-square {
17
+ border-radius: var(--semi-border-radius-medium);
18
+ }
19
+
20
+ /* 标题骨架 */
21
+ .semi:where([data-semi="all"], [data-semi-skeleton]) .ant-skeleton-title {
22
+ background: var(--semi-color-fill-0);
23
+ border-radius: var(--semi-border-radius-small);
24
+ height: 16px;
25
+ margin-bottom: 16px;
26
+ }
27
+
28
+ /* 段落骨架 */
29
+ .semi:where([data-semi="all"], [data-semi-skeleton]) .ant-skeleton-paragraph > li {
30
+ background: var(--semi-color-fill-0);
31
+ border-radius: var(--semi-border-radius-small);
32
+ height: 16px;
33
+ margin-top: 12px;
34
+ }
35
+
36
+ .semi:where([data-semi="all"], [data-semi-skeleton]) .ant-skeleton-paragraph > li:first-child {
37
+ margin-top: 0;
38
+ }
39
+
40
+ /* 按钮骨架 */
41
+ .semi:where([data-semi="all"], [data-semi-skeleton]) .ant-skeleton-button {
42
+ background: var(--semi-color-fill-0);
43
+ border-radius: var(--semi-border-radius-medium);
44
+ height: 32px;
45
+ min-width: 64px;
46
+ }
47
+
48
+ .semi:where([data-semi="all"], [data-semi-skeleton]) .ant-skeleton-button-round {
49
+ border-radius: 32px;
50
+ }
51
+
52
+ .semi:where([data-semi="all"], [data-semi-skeleton]) .ant-skeleton-button-circle {
53
+ border-radius: var(--semi-border-radius-full);
54
+ min-width: 32px;
55
+ }
56
+
57
+ /* 输入框骨架 */
58
+ .semi:where([data-semi="all"], [data-semi-skeleton]) .ant-skeleton-input {
59
+ background: var(--semi-color-fill-0);
60
+ border-radius: var(--semi-border-radius-medium);
61
+ height: 32px;
62
+ min-width: 200px;
63
+ }
64
+
65
+ /* 图片骨架 */
66
+ .semi:where([data-semi="all"], [data-semi-skeleton]) .ant-skeleton-image {
67
+ background: var(--semi-color-fill-0);
68
+ border-radius: var(--semi-border-radius-medium);
69
+ }
70
+
71
+ .semi:where([data-semi="all"], [data-semi-skeleton]) .ant-skeleton-image-svg {
72
+ fill: var(--semi-color-fill-1);
73
+ }
74
+
75
+ /* 动画效果 */
76
+ .semi:where([data-semi="all"], [data-semi-skeleton]) .ant-skeleton-active .ant-skeleton-avatar,
77
+ .semi:where([data-semi="all"], [data-semi-skeleton]) .ant-skeleton-active .ant-skeleton-title,
78
+ .semi:where([data-semi="all"], [data-semi-skeleton]) .ant-skeleton-active .ant-skeleton-paragraph > li,
79
+ .semi:where([data-semi="all"], [data-semi-skeleton]) .ant-skeleton-active .ant-skeleton-button,
80
+ .semi:where([data-semi="all"], [data-semi-skeleton]) .ant-skeleton-active .ant-skeleton-input,
81
+ .semi:where([data-semi="all"], [data-semi-skeleton]) .ant-skeleton-active .ant-skeleton-image {
82
+ background: linear-gradient(
83
+ 90deg,
84
+ var(--semi-color-fill-0) 25%,
85
+ var(--semi-color-fill-1) 37%,
86
+ var(--semi-color-fill-0) 63%
87
+ );
88
+ background-size: 400% 100%;
89
+ animation: ant-skeleton-loading 1.4s ease infinite;
90
+ }
91
+
92
+ /* 节点骨架 */
93
+ .semi:where([data-semi="all"], [data-semi-skeleton]) .ant-skeleton-element {
94
+ display: inline-block;
95
+ width: auto;
96
+ }
@@ -0,0 +1,119 @@
1
+ /**
2
+ * Slider 滑动输入条 - Semi Design 风格
3
+ */
4
+
5
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider {
6
+ margin: 10px 0;
7
+ }
8
+
9
+ /* 轨道 */
10
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider-rail {
11
+ background: var(--semi-color-fill-0);
12
+ border-radius: 100px;
13
+ height: 4px;
14
+ }
15
+
16
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider:hover .ant-slider-rail {
17
+ background: var(--semi-color-fill-1);
18
+ }
19
+
20
+ /* 已选择轨道 */
21
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider-track {
22
+ background: var(--semi-color-primary);
23
+ border-radius: 100px;
24
+ height: 4px;
25
+ }
26
+
27
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider:hover .ant-slider-track {
28
+ background: var(--semi-color-primary-hover);
29
+ }
30
+
31
+ /* 滑块 */
32
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider-handle {
33
+ background: #fff;
34
+ border: 2px solid var(--semi-color-primary);
35
+ border-radius: var(--semi-border-radius-full);
36
+ box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
37
+ height: 14px;
38
+ width: 14px;
39
+ margin-top: -5px;
40
+ transition: all var(--semi-transition-duration) var(--semi-transition-timing);
41
+ }
42
+
43
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider-handle::after {
44
+ display: none;
45
+ }
46
+
47
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider-handle:hover,
48
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider-handle:focus {
49
+ border-color: var(--semi-color-primary);
50
+ box-shadow: 0 0 0 4px var(--semi-color-primary-light-default);
51
+ }
52
+
53
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider-handle-dragging {
54
+ border-color: var(--semi-color-primary);
55
+ box-shadow: 0 0 0 4px var(--semi-color-primary-light-default);
56
+ }
57
+
58
+ /* 刻度标记 */
59
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider-mark-text {
60
+ color: var(--semi-color-text-2);
61
+ font-size: var(--semi-font-size-small);
62
+ }
63
+
64
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider-mark-text-active {
65
+ color: var(--semi-color-text-0);
66
+ }
67
+
68
+ /* 刻度点 */
69
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider-dot {
70
+ background: #fff;
71
+ border: 2px solid var(--semi-color-fill-1);
72
+ border-radius: var(--semi-border-radius-full);
73
+ height: 8px;
74
+ width: 8px;
75
+ }
76
+
77
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider-dot-active {
78
+ border-color: var(--semi-color-primary);
79
+ }
80
+
81
+ /* 提示 */
82
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider-tooltip .ant-tooltip-inner {
83
+ background: var(--semi-color-bg-0);
84
+ border-radius: var(--semi-border-radius-small);
85
+ box-shadow: var(--semi-shadow-elevated);
86
+ color: var(--semi-color-text-0);
87
+ font-size: var(--semi-font-size-small);
88
+ min-height: auto;
89
+ padding: 4px 8px;
90
+ }
91
+
92
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider-tooltip .ant-tooltip-arrow::before {
93
+ background: var(--semi-color-bg-0);
94
+ }
95
+
96
+ /* 禁用状态 */
97
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider-disabled .ant-slider-rail {
98
+ background: var(--semi-color-fill-0);
99
+ }
100
+
101
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider-disabled .ant-slider-track {
102
+ background: var(--semi-color-fill-1);
103
+ }
104
+
105
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider-disabled .ant-slider-handle {
106
+ background: #fff;
107
+ border-color: var(--semi-color-fill-1);
108
+ cursor: not-allowed;
109
+ }
110
+
111
+ /* 垂直滑块 */
112
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider-vertical .ant-slider-rail,
113
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider-vertical .ant-slider-track {
114
+ width: 4px;
115
+ }
116
+
117
+ .semi:where([data-semi="all"], [data-semi-slider]) .ant-slider-vertical .ant-slider-handle {
118
+ margin-left: -5px;
119
+ }