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,105 @@
1
+ /**
2
+ * TimePicker 时间选择框 - Semi Design 风格
3
+ */
4
+
5
+ .semi:where([data-semi="all"], [data-semi-timepicker]) .ant-picker-time {
6
+ background-color: var(--semi-color-fill-0);
7
+ border: 1px solid transparent;
8
+ border-radius: var(--semi-border-radius-small);
9
+ box-shadow: none;
10
+ transition: all var(--semi-transition-duration) var(--semi-transition-timing);
11
+ }
12
+
13
+ .semi:where([data-semi="all"], [data-semi-timepicker]) .ant-picker-time:hover {
14
+ background-color: var(--semi-color-fill-1);
15
+ border-color: transparent;
16
+ }
17
+
18
+ .semi:where([data-semi="all"], [data-semi-timepicker]) .ant-picker-time.ant-picker-focused {
19
+ background-color: var(--semi-color-fill-0);
20
+ border-color: var(--semi-color-focus-border);
21
+ box-shadow: none;
22
+ }
23
+
24
+ .semi:where([data-semi="all"], [data-semi-timepicker]) .ant-picker-time .ant-picker-input > input {
25
+ color: var(--semi-color-text-0);
26
+ }
27
+
28
+ .semi:where([data-semi="all"], [data-semi-timepicker]) .ant-picker-time .ant-picker-input > input::placeholder {
29
+ color: var(--semi-color-text-2);
30
+ }
31
+
32
+ .semi:where([data-semi="all"], [data-semi-timepicker]) .ant-picker-time .ant-picker-suffix {
33
+ color: var(--semi-color-text-2);
34
+ }
35
+
36
+ .semi:where([data-semi="all"], [data-semi-timepicker]) .ant-picker-time .ant-picker-clear {
37
+ background: var(--semi-color-fill-0);
38
+ color: var(--semi-color-text-2);
39
+ }
40
+
41
+ .semi:where([data-semi="all"], [data-semi-timepicker]) .ant-picker-time .ant-picker-clear:hover {
42
+ color: var(--semi-color-text-1);
43
+ }
44
+
45
+ /* 时间面板 */
46
+ body.semi .ant-picker-time-panel {
47
+ padding: 0;
48
+ }
49
+
50
+ body.semi .ant-picker-time-panel-column {
51
+ padding: 0;
52
+ }
53
+
54
+ body.semi .ant-picker-time-panel-column > li.ant-picker-time-panel-cell {
55
+ padding: 0;
56
+ }
57
+
58
+ body.semi .ant-picker-time-panel-column > li.ant-picker-time-panel-cell .ant-picker-time-panel-cell-inner {
59
+ color: var(--semi-color-text-0);
60
+ border-radius: var(--semi-border-radius-small);
61
+ height: 28px;
62
+ line-height: 28px;
63
+ margin: 2px 4px;
64
+ padding: 0 8px;
65
+ width: calc(100% - 8px);
66
+ }
67
+
68
+ body.semi .ant-picker-time-panel-column > li.ant-picker-time-panel-cell:hover .ant-picker-time-panel-cell-inner {
69
+ background-color: var(--semi-color-fill-0);
70
+ }
71
+
72
+ body.semi .ant-picker-time-panel-column > li.ant-picker-time-panel-cell-selected .ant-picker-time-panel-cell-inner {
73
+ background-color: var(--semi-color-primary-light-default);
74
+ color: var(--semi-color-primary);
75
+ font-weight: 500;
76
+ }
77
+
78
+ body.semi .ant-picker-time-panel-column > li.ant-picker-time-panel-cell-disabled .ant-picker-time-panel-cell-inner {
79
+ color: var(--semi-color-disabled-text);
80
+ }
81
+
82
+ /* 范围选择 */
83
+ .semi:where([data-semi="all"], [data-semi-timepicker]) .ant-picker-time.ant-picker-range {
84
+ background-color: var(--semi-color-fill-0);
85
+ border: 1px solid transparent;
86
+ }
87
+
88
+ .semi:where([data-semi="all"], [data-semi-timepicker]) .ant-picker-time.ant-picker-range:hover {
89
+ background-color: var(--semi-color-fill-1);
90
+ }
91
+
92
+ .semi:where([data-semi="all"], [data-semi-timepicker]) .ant-picker-time.ant-picker-range.ant-picker-focused {
93
+ background-color: var(--semi-color-fill-0);
94
+ border-color: var(--semi-color-focus-border);
95
+ }
96
+
97
+ /* 禁用状态 */
98
+ .semi:where([data-semi="all"], [data-semi-timepicker]) .ant-picker-time.ant-picker-disabled {
99
+ background-color: var(--semi-color-disabled-fill);
100
+ border-color: transparent;
101
+ }
102
+
103
+ .semi:where([data-semi="all"], [data-semi-timepicker]) .ant-picker-time.ant-picker-disabled .ant-picker-input > input {
104
+ color: var(--semi-color-disabled-text);
105
+ }
@@ -0,0 +1,37 @@
1
+ /**
2
+ * Tooltip 文字提示 - Semi Design 风格
3
+ * Portal 组件 - 渲染在 body 下
4
+ */
5
+
6
+ body.semi .ant-tooltip,
7
+ .semi .ant-tooltip {
8
+ font-size: var(--semi-font-size-regular);
9
+ max-width: 300px;
10
+ }
11
+
12
+ body.semi .ant-tooltip-inner,
13
+ .semi .ant-tooltip-inner {
14
+ background: rgba(28, 31, 35, 0.88);
15
+ border-radius: var(--semi-border-radius-medium);
16
+ color: #fff;
17
+ min-height: auto;
18
+ padding: 8px 12px;
19
+ }
20
+
21
+ /* 箭头 */
22
+ body.semi .ant-tooltip-arrow::before,
23
+ .semi .ant-tooltip-arrow::before {
24
+ background: rgba(28, 31, 35, 0.88);
25
+ }
26
+
27
+ /* 暗黑模式调整 */
28
+ body.semi.semi-dark .ant-tooltip-inner,
29
+ body.semi-dark .ant-tooltip-inner {
30
+ background: rgba(255, 255, 255, 0.9);
31
+ color: rgba(28, 31, 35, 1);
32
+ }
33
+
34
+ body.semi.semi-dark .ant-tooltip-arrow::before,
35
+ body.semi-dark .ant-tooltip-arrow::before {
36
+ background: rgba(255, 255, 255, 0.9);
37
+ }
@@ -0,0 +1,114 @@
1
+ /**
2
+ * Tour 漫游式引导 - Semi Design 风格
3
+ */
4
+
5
+ body.semi .ant-tour {
6
+ --ant-tour-content-radius: var(--semi-border-radius-medium);
7
+ }
8
+
9
+ body.semi .ant-tour-content {
10
+ background: #fff;
11
+ border-radius: var(--semi-border-radius-medium);
12
+ box-shadow: var(--semi-shadow-elevated);
13
+ }
14
+
15
+ body.semi .ant-tour-inner {
16
+ padding: 16px;
17
+ }
18
+
19
+ body.semi .ant-tour-header {
20
+ padding: 0;
21
+ margin-bottom: 8px;
22
+ }
23
+
24
+ body.semi .ant-tour-title {
25
+ color: var(--semi-color-text-0);
26
+ font-size: 16px;
27
+ font-weight: 600;
28
+ }
29
+
30
+ body.semi .ant-tour-close {
31
+ color: var(--semi-color-text-2);
32
+ top: 16px;
33
+ right: 16px;
34
+ }
35
+
36
+ body.semi .ant-tour-close:hover {
37
+ color: var(--semi-color-text-0);
38
+ }
39
+
40
+ body.semi .ant-tour-description {
41
+ color: var(--semi-color-text-1);
42
+ font-size: var(--semi-font-size-regular);
43
+ padding: 8px 0;
44
+ }
45
+
46
+ body.semi .ant-tour-footer {
47
+ padding: 0;
48
+ margin-top: 12px;
49
+ }
50
+
51
+ body.semi .ant-tour-indicators {
52
+ gap: 4px;
53
+ }
54
+
55
+ body.semi .ant-tour-indicator {
56
+ background: var(--semi-color-fill-1);
57
+ border-radius: var(--semi-border-radius-full);
58
+ width: 6px;
59
+ height: 6px;
60
+ }
61
+
62
+ body.semi .ant-tour-indicator-active {
63
+ background: var(--semi-color-primary);
64
+ width: 16px;
65
+ }
66
+
67
+ body.semi .ant-tour-buttons {
68
+ gap: 8px;
69
+ }
70
+
71
+ /* Primary 类型 */
72
+ body.semi .ant-tour-primary .ant-tour-content {
73
+ background: var(--semi-color-primary);
74
+ }
75
+
76
+ body.semi .ant-tour-primary .ant-tour-title,
77
+ body.semi .ant-tour-primary .ant-tour-description {
78
+ color: #fff;
79
+ }
80
+
81
+ body.semi .ant-tour-primary .ant-tour-close {
82
+ color: rgba(255, 255, 255, 0.65);
83
+ }
84
+
85
+ body.semi .ant-tour-primary .ant-tour-close:hover {
86
+ color: #fff;
87
+ }
88
+
89
+ body.semi .ant-tour-primary .ant-tour-indicator {
90
+ background: rgba(255, 255, 255, 0.3);
91
+ }
92
+
93
+ body.semi .ant-tour-primary .ant-tour-indicator-active {
94
+ background: #fff;
95
+ }
96
+
97
+ /* 箭头 */
98
+ body.semi .ant-tour-arrow::before {
99
+ background: #fff;
100
+ }
101
+
102
+ body.semi .ant-tour-primary .ant-tour-arrow::before {
103
+ background: var(--semi-color-primary);
104
+ }
105
+
106
+ /* 遮罩 */
107
+ body.semi .ant-tour-mask {
108
+ fill: rgba(0, 0, 0, 0.5);
109
+ }
110
+
111
+ /* 目标高亮 */
112
+ body.semi .ant-tour-target-placeholder {
113
+ border-radius: var(--semi-border-radius-small);
114
+ }
@@ -0,0 +1,232 @@
1
+ /**
2
+ * Transfer 穿梭框 - Semi Design 风格
3
+ * 参考 semi-foundation/transfer/variables.scss
4
+ */
5
+
6
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer {
7
+ color: var(--semi-color-text-0);
8
+ font-size: var(--semi-font-size-regular);
9
+ }
10
+
11
+ /* 列表容器 */
12
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list {
13
+ background: var(--semi-color-bg-1);
14
+ border: 1px solid var(--semi-color-border);
15
+ border-radius: var(--semi-border-radius-medium);
16
+ height: 400px;
17
+ min-width: 200px;
18
+ }
19
+
20
+ /* 列表头部 */
21
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-header {
22
+ background: var(--semi-color-bg-1);
23
+ border-bottom: none;
24
+ border-radius: var(--semi-border-radius-medium) var(--semi-border-radius-medium) 0 0;
25
+ color: var(--semi-color-text-2);
26
+ padding: 12px 12px 8px;
27
+ height: auto;
28
+ display: flex;
29
+ align-items: center;
30
+ }
31
+
32
+ /* 全选 checkbox */
33
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-header > .ant-checkbox-wrapper {
34
+ margin-right: 8px;
35
+ }
36
+
37
+ /* 下拉箭头(全选下拉) */
38
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-header-dropdown {
39
+ color: var(--semi-color-text-2);
40
+ font-size: 12px;
41
+ cursor: pointer;
42
+ margin-right: 4px;
43
+ }
44
+
45
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-header-dropdown:hover {
46
+ color: var(--semi-color-text-0);
47
+ }
48
+
49
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-header-selected {
50
+ flex: none;
51
+ }
52
+
53
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-header-selected span {
54
+ color: var(--semi-color-text-2);
55
+ font-size: var(--semi-font-size-small);
56
+ }
57
+
58
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-header-title {
59
+ color: var(--semi-color-text-2);
60
+ font-weight: 600;
61
+ font-size: var(--semi-font-size-small);
62
+ flex: auto;
63
+ text-align: right;
64
+ }
65
+
66
+ /* 搜索框包裹 */
67
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-body-search-wrapper {
68
+ padding: 12px;
69
+ }
70
+
71
+ /* 旧版搜索框容器 */
72
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-search {
73
+ padding: 0;
74
+ width: 100%;
75
+ }
76
+
77
+ /* 搜索框输入 - 带前缀图标的情况 */
78
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-search .ant-input-affix-wrapper {
79
+ background: var(--semi-color-fill-0) !important;
80
+ border: 1px solid transparent !important;
81
+ border-radius: var(--semi-border-radius-small);
82
+ box-shadow: none !important;
83
+ }
84
+
85
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-search .ant-input-affix-wrapper:hover:not(.ant-input-affix-wrapper-focused) {
86
+ background: var(--semi-color-fill-1) !important;
87
+ border-color: transparent !important;
88
+ }
89
+
90
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-search .ant-input-affix-wrapper:focus,
91
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-search .ant-input-affix-wrapper-focused,
92
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-search .ant-input-affix-wrapper:focus-within {
93
+ background: var(--semi-color-fill-0) !important;
94
+ border-color: var(--semi-color-focus-border) !important;
95
+ box-shadow: none !important;
96
+ outline: none !important;
97
+ }
98
+
99
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-search .ant-input-affix-wrapper .ant-input,
100
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-search .ant-input-affix-wrapper .ant-input:focus {
101
+ background: transparent !important;
102
+ box-shadow: none !important;
103
+ outline: none !important;
104
+ }
105
+
106
+ /* 搜索框 - 纯 Input 情况 */
107
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-search.ant-input {
108
+ background: var(--semi-color-fill-0) !important;
109
+ border: 1px solid transparent !important;
110
+ border-radius: var(--semi-border-radius-small);
111
+ box-shadow: none !important;
112
+ }
113
+
114
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-search.ant-input:hover {
115
+ background: var(--semi-color-fill-1) !important;
116
+ border-color: transparent !important;
117
+ }
118
+
119
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-search.ant-input:focus {
120
+ background: var(--semi-color-fill-0) !important;
121
+ border-color: var(--semi-color-focus-border) !important;
122
+ box-shadow: none !important;
123
+ }
124
+
125
+ /* 搜索图标 */
126
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-search .anticon-search {
127
+ color: var(--semi-color-text-2);
128
+ }
129
+
130
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-search-action {
131
+ color: var(--semi-color-text-2);
132
+ }
133
+
134
+ /* 列表主体 */
135
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-body {
136
+ background: var(--semi-color-bg-1);
137
+ }
138
+
139
+ /* 列表内容 */
140
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-content {
141
+ overflow: auto;
142
+ padding: 4px 0;
143
+ }
144
+
145
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-content-item {
146
+ padding: 8px 12px;
147
+ min-height: 36px;
148
+ color: var(--semi-color-text-1);
149
+ background: transparent;
150
+ transition: background var(--semi-transition-duration) var(--semi-transition-timing);
151
+ display: flex;
152
+ align-items: center;
153
+ }
154
+
155
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-content-item:hover {
156
+ background: var(--semi-color-fill-0);
157
+ }
158
+
159
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-content-item:active {
160
+ background: var(--semi-color-fill-1);
161
+ }
162
+
163
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-content-item-checked {
164
+ background: var(--semi-color-fill-0);
165
+ color: var(--semi-color-text-0);
166
+ }
167
+
168
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-content-item-checked:hover {
169
+ background: var(--semi-color-fill-1);
170
+ }
171
+
172
+ /* 列表项文本 */
173
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-content-item-text {
174
+ flex: auto;
175
+ overflow: hidden;
176
+ text-overflow: ellipsis;
177
+ white-space: nowrap;
178
+ }
179
+
180
+ /* 移除按钮 */
181
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-content-item-remove {
182
+ color: var(--semi-color-text-2);
183
+ cursor: pointer;
184
+ transition: color var(--semi-transition-duration);
185
+ }
186
+
187
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-content-item-remove:hover {
188
+ color: var(--semi-color-primary);
189
+ }
190
+
191
+ /* 禁用项 */
192
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-content-item-disabled {
193
+ color: var(--semi-color-disabled-text);
194
+ background: transparent;
195
+ cursor: not-allowed;
196
+ }
197
+
198
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-content-item-disabled:hover {
199
+ background: transparent;
200
+ }
201
+
202
+ /* 列表底部 */
203
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-footer {
204
+ border-top: 1px solid var(--semi-color-border);
205
+ padding: 8px 16px;
206
+ }
207
+
208
+ /* 操作按钮 */
209
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-operation {
210
+ margin: 0 8px;
211
+ display: flex;
212
+ flex-direction: column;
213
+ gap: 8px;
214
+ }
215
+
216
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-operation .ant-btn {
217
+ margin: 0;
218
+ }
219
+
220
+ /* 分页 */
221
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-pagination {
222
+ border-top: 1px solid var(--semi-color-border);
223
+ padding: 8px;
224
+ text-align: end;
225
+ }
226
+
227
+ /* 空状态 */
228
+ .semi:where([data-semi="all"], [data-semi-transfer]) .ant-transfer-list-body-not-found {
229
+ color: var(--semi-color-text-2);
230
+ padding: 16px;
231
+ text-align: center;
232
+ }
@@ -0,0 +1,143 @@
1
+ /**
2
+ * Tree 树形控件 - Semi Design 风格
3
+ * 参考 semi-foundation/tree/variables.scss
4
+ */
5
+
6
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree {
7
+ color: var(--semi-color-text-0);
8
+ font-size: var(--semi-font-size-regular);
9
+ padding: 8px 0;
10
+ }
11
+
12
+ /* 树节点 */
13
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-treenode {
14
+ align-items: center;
15
+ padding: 4px 0;
16
+ }
17
+
18
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-node-content-wrapper {
19
+ border-radius: var(--semi-border-radius-small);
20
+ color: var(--semi-color-text-0);
21
+ min-height: 32px;
22
+ line-height: 32px;
23
+ padding: 0 8px;
24
+ transition: all var(--semi-transition-duration) var(--semi-transition-timing);
25
+ }
26
+
27
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-node-content-wrapper:hover {
28
+ background: var(--semi-color-fill-0);
29
+ }
30
+
31
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-node-content-wrapper:active {
32
+ background: var(--semi-color-fill-1);
33
+ }
34
+
35
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-node-content-wrapper.ant-tree-node-selected {
36
+ background: var(--semi-color-primary-light-default);
37
+ color: var(--semi-color-text-0);
38
+ }
39
+
40
+ /* 展开图标 */
41
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-switcher {
42
+ align-items: center;
43
+ color: var(--semi-color-text-2);
44
+ display: flex;
45
+ height: 32px;
46
+ justify-content: center;
47
+ width: 24px;
48
+ }
49
+
50
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-switcher:hover {
51
+ color: var(--semi-color-text-0);
52
+ }
53
+
54
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-switcher-noop {
55
+ cursor: default;
56
+ }
57
+
58
+ /* 复选框 */
59
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-checkbox {
60
+ margin-inline-end: 4px;
61
+ }
62
+
63
+ /* 图标 */
64
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-iconEle {
65
+ color: var(--semi-color-text-1);
66
+ margin-inline-end: 4px;
67
+ width: 24px;
68
+ }
69
+
70
+ /* 标题 */
71
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-title {
72
+ flex: 1;
73
+ }
74
+
75
+ /* 连接线 */
76
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-show-line .ant-tree-indent-unit::before {
77
+ border-inline-end: 1px solid var(--semi-color-border);
78
+ }
79
+
80
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-show-line .ant-tree-switcher {
81
+ background: var(--semi-color-bg-0);
82
+ }
83
+
84
+ /* 拖拽 */
85
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-treenode-draggable .ant-tree-draggable-icon {
86
+ color: var(--semi-color-text-2);
87
+ cursor: grab;
88
+ opacity: 0;
89
+ transition: opacity var(--semi-transition-duration) var(--semi-transition-timing);
90
+ width: 24px;
91
+ }
92
+
93
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-treenode:hover .ant-tree-draggable-icon {
94
+ opacity: 1;
95
+ }
96
+
97
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-treenode.drop-target > .ant-tree-draggable-icon {
98
+ opacity: 1;
99
+ }
100
+
101
+ /* 拖拽指示器 */
102
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree .ant-tree-treenode.drop-target > .ant-tree-node-content-wrapper {
103
+ background: var(--semi-color-primary-light-default);
104
+ }
105
+
106
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-drop-indicator {
107
+ background: var(--semi-color-primary);
108
+ border-radius: 2px;
109
+ height: 2px;
110
+ }
111
+
112
+ /* 禁用状态 */
113
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-treenode-disabled .ant-tree-node-content-wrapper {
114
+ color: var(--semi-color-text-3);
115
+ cursor: not-allowed;
116
+ }
117
+
118
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-treenode-disabled .ant-tree-node-content-wrapper:hover {
119
+ background: transparent;
120
+ }
121
+
122
+ /* 目录树 */
123
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-directory .ant-tree-treenode::before {
124
+ border-radius: var(--semi-border-radius-small);
125
+ transition: background var(--semi-transition-duration) var(--semi-transition-timing);
126
+ }
127
+
128
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-directory .ant-tree-treenode:hover::before {
129
+ background: var(--semi-color-fill-0);
130
+ }
131
+
132
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-directory .ant-tree-treenode-selected::before {
133
+ background: var(--semi-color-primary);
134
+ }
135
+
136
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-directory .ant-tree-treenode-selected .ant-tree-node-content-wrapper {
137
+ color: #fff;
138
+ }
139
+
140
+ /* 虚拟滚动 */
141
+ .semi:where([data-semi="all"], [data-semi-tree]) .ant-tree-list-holder-inner {
142
+ align-items: stretch;
143
+ }
@@ -0,0 +1,46 @@
1
+ /**
2
+ * TreeSelect 树选择 - Semi Design 风格
3
+ */
4
+
5
+ .semi:where([data-semi="all"], [data-semi-treeselect]) .ant-tree-select .ant-select-selector {
6
+ background-color: var(--semi-color-fill-0);
7
+ border: 1px solid transparent;
8
+ border-radius: var(--semi-border-radius-small);
9
+ box-shadow: none;
10
+ transition: all var(--semi-transition-duration) var(--semi-transition-timing);
11
+ }
12
+
13
+ .semi:where([data-semi="all"], [data-semi-treeselect]) .ant-tree-select .ant-select-selector:hover {
14
+ background-color: var(--semi-color-fill-1);
15
+ }
16
+
17
+ .semi:where([data-semi="all"], [data-semi-treeselect]) .ant-tree-select.ant-select-focused .ant-select-selector {
18
+ background-color: var(--semi-color-fill-0);
19
+ border-color: var(--semi-color-focus-border);
20
+ box-shadow: none;
21
+ }
22
+
23
+ .semi:where([data-semi="all"], [data-semi-treeselect]) .ant-tree-select .ant-select-selection-item {
24
+ color: var(--semi-color-text-0);
25
+ }
26
+
27
+ .semi:where([data-semi="all"], [data-semi-treeselect]) .ant-tree-select .ant-select-selection-placeholder {
28
+ color: var(--semi-color-text-2);
29
+ }
30
+
31
+ /* 下拉面板 */
32
+ body.semi .ant-tree-select-dropdown {
33
+ background: #fff;
34
+ border: none;
35
+ border-radius: var(--semi-border-radius-medium);
36
+ box-shadow: var(--semi-shadow-elevated);
37
+ padding: 4px 0;
38
+ }
39
+
40
+ /* 树节点样式继承 tree.css */
41
+
42
+ /* 禁用状态 */
43
+ .semi:where([data-semi="all"], [data-semi-treeselect]) .ant-tree-select.ant-select-disabled .ant-select-selector {
44
+ background-color: var(--semi-color-disabled-fill);
45
+ color: var(--semi-color-disabled-text);
46
+ }