funda-ui 4.5.677 → 4.5.682

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 (40) hide show
  1. package/ColorPicker/index.js +3 -1
  2. package/DragDropList/index.css +188 -0
  3. package/DragDropList/index.d.ts +43 -0
  4. package/DragDropList/index.js +1589 -0
  5. package/LICENSE +21 -0
  6. package/MultipleSelect/index.css +237 -144
  7. package/MultipleSelect/index.d.ts +23 -10
  8. package/MultipleSelect/index.js +2242 -1225
  9. package/README.md +3 -1
  10. package/Utils/useBoundedDrag.d.ts +127 -0
  11. package/Utils/useBoundedDrag.js +382 -0
  12. package/Utils/useDragDropPosition.d.ts +169 -0
  13. package/Utils/useDragDropPosition.js +456 -0
  14. package/all.d.ts +1 -0
  15. package/all.js +1 -0
  16. package/lib/cjs/ColorPicker/index.js +3 -1
  17. package/lib/cjs/DragDropList/index.d.ts +43 -0
  18. package/lib/cjs/DragDropList/index.js +1589 -0
  19. package/lib/cjs/MultipleSelect/index.d.ts +23 -10
  20. package/lib/cjs/MultipleSelect/index.js +2242 -1225
  21. package/lib/cjs/Utils/useBoundedDrag.d.ts +127 -0
  22. package/lib/cjs/Utils/useBoundedDrag.js +382 -0
  23. package/lib/cjs/Utils/useDragDropPosition.d.ts +169 -0
  24. package/lib/cjs/Utils/useDragDropPosition.js +456 -0
  25. package/lib/cjs/index.d.ts +1 -0
  26. package/lib/cjs/index.js +1 -0
  27. package/lib/css/DragDropList/index.css +188 -0
  28. package/lib/css/MultipleSelect/index.css +237 -144
  29. package/lib/esm/ColorPicker/index.tsx +53 -49
  30. package/lib/esm/DragDropList/index.scss +245 -0
  31. package/lib/esm/DragDropList/index.tsx +493 -0
  32. package/lib/esm/MultipleSelect/index.scss +288 -183
  33. package/lib/esm/MultipleSelect/index.tsx +304 -166
  34. package/lib/esm/MultipleSelect/utils/func.ts +21 -1
  35. package/lib/esm/Tabs/Tabs.tsx +1 -1
  36. package/lib/esm/Utils/hooks/useBoundedDrag.tsx +303 -0
  37. package/lib/esm/Utils/hooks/useDragDropPosition.tsx +420 -0
  38. package/lib/esm/index.js +1 -0
  39. package/package.json +1 -1
  40. package/lib/esm/MultipleSelect/ItemList.tsx +0 -323
@@ -1,220 +1,313 @@
1
1
  /* ======================================================
2
2
  <!-- Multiple Select -->
3
3
  /* ====================================================== */
4
- .m-select__wrapper {
5
- --m-select-wrapper-min-w: 350px;
6
- --m-select-wrapper-min-h: 315px;
7
- --m-select-header-font-size: 0.75rem;
8
- --m-select-body-font-size: 0.75rem;
9
- --m-select-scrollbar-color: rgba(0, 0, 0, 0.2);
10
- --m-select-scrollbar-track: rgba(0, 0, 0, 0);
11
- --m-select-scrollbar-w: 10px;
12
- --m-select-search-icon-color: #333;
13
- --m-select-body-bg: #fff;
14
- --m-select-header-bg: #dee2e6;
15
- --m-select-border-color: #dee2e6;
16
- --m-select-options-item-bg: #f6f6f6;
17
- --m-select-options-item-icon-color: #000;
18
- --m-select-options-item-selected-bg: #0b5ed7;
19
- --m-select-options-item-selected-icon-color: #fff;
20
- --m-select-options-item-selected-text-color: #fff;
21
- --m-select-options-item-dividingline-color: rgba(255, 255, 255, 1);
22
- --m-select-search-input-w: 100px;
23
- --m-select-search-input-bg: #fff;
24
- --m-select-search-input-text-color: #333;
25
- min-width: var(--m-select-wrapper-min-w);
26
- min-height: var(--m-select-wrapper-min-h);
4
+ .m-select-v2__wrapper {
5
+ --m-select-v2-wrapper-min-w: 350px;
6
+ --m-select-v2-wrapper-min-h: 315px;
7
+ --m-select-v2-header-font-size: 0.75rem;
8
+ --m-select-v2-body-font-size: 0.75rem;
9
+ --m-select-v2-scrollbar-color: rgba(0, 0, 0, 0.2);
10
+ --m-select-v2-scrollbar-track: rgba(0, 0, 0, 0);
11
+ --m-select-v2-scrollbar-w: 10px;
12
+ --m-select-v2-search-icon-color: #333;
13
+ --m-select-v2-body-bg: #fff;
14
+ --m-select-v2-header-bg: #dee2e6;
15
+ --m-select-v2-border-color: #dee2e6;
16
+ --m-select-v2-search-input-w: 100px;
17
+ --m-select-v2-search-input-bg: #fff;
18
+ --m-select-v2-search-input-text-color: #333;
19
+ min-width: var(--m-select-v2-wrapper-min-w);
20
+ min-height: var(--m-select-v2-wrapper-min-h);
27
21
  width: 100%;
28
22
  height: 100%;
29
- border: solid 1px var(--m-select-border-color);
23
+ border: solid 1px var(--m-select-v2-border-color);
30
24
  border-radius: 0.35rem;
31
25
  position: relative;
32
- background: var(--m-select-body-bg);
33
- /*-------- Multilevel --------*/
34
- /*-------- List --------*/
26
+ background: var(--m-select-v2-body-bg);
35
27
  }
36
- .m-select__wrapper .m-select-diving-line {
28
+ .m-select-v2__wrapper .m-select-v2-diving-line {
37
29
  width: 1px;
38
- background-color: var(--m-select-border-color);
30
+ background-color: var(--m-select-v2-border-color);
39
31
  left: 50%;
40
32
  top: 0;
41
33
  position: absolute;
42
34
  height: 100%;
43
35
  z-index: 1;
44
36
  }
45
- .m-select__wrapper .m-select-inner {
37
+ .m-select-v2__wrapper .m-select-v2-inner {
46
38
  display: flex;
47
39
  font-size: 0.8em;
48
40
  height: 100%;
41
+ /* Main */
42
+ /* List */
43
+ /* Header */
49
44
  /* Search */
50
45
  }
51
- .m-select__wrapper .m-select-inner ul,
52
- .m-select__wrapper .m-select-inner li {
53
- margin: 0;
54
- padding: 0;
55
- list-style: none;
56
- }
57
- .m-select__wrapper .m-select-inner div.m-select__selected__container,
58
- .m-select__wrapper .m-select-inner div.m-select__available__container {
46
+ .m-select-v2__wrapper .m-select-v2-inner div.m-select-v2__selected__container,
47
+ .m-select-v2__wrapper .m-select-v2-inner div.m-select-v2__available__container {
59
48
  position: relative;
60
49
  flex: 1;
61
50
  }
62
- .m-select__wrapper .m-select-inner ul.m-select__selected,
63
- .m-select__wrapper .m-select-inner ul.m-select__available {
64
- position: relative;
65
- overflow: auto;
66
- overflow-x: hidden;
67
- border: none;
68
- position: relative;
69
- width: 100%;
70
- }
71
- .m-select__wrapper .m-select-inner ul {
72
- user-select: none;
73
- }
74
- .m-select__wrapper .m-select-inner li {
75
- cursor: default;
76
- position: relative;
77
- font-size: var(--m-select-body-font-size);
78
- display: block;
79
- background: var(--m-select-options-item-bg);
80
- border-bottom: 1px solid var(--m-select-options-item-dividingline-color);
81
- }
82
- .m-select__wrapper .m-select-inner li.disabled {
83
- pointer-events: none;
84
- opacity: 0.4;
85
- }
86
- .m-select__wrapper .m-select-inner li.hide {
87
- display: none;
88
- }
89
- .m-select__wrapper .m-select-inner li:hover {
90
- opacity: 0.8;
91
- }
92
- .m-select__wrapper .m-select-inner li.selected {
93
- background: var(--m-select-options-item-selected-bg);
94
- color: var(--m-select-options-item-selected-text-color);
95
- }
96
- .m-select__wrapper .m-select-inner li.selected > i svg path {
97
- fill: var(--m-select-options-item-selected-icon-color);
51
+ .m-select-v2__wrapper .m-select-v2-inner div.m-select-v2__selected__container .m-select-v2__header {
52
+ border-radius: 0 0.35rem 0 0;
98
53
  }
99
- .m-select__wrapper .m-select-inner li:last-child {
100
- border-bottom: none;
54
+ .m-select-v2__wrapper .m-select-v2-inner div.m-select-v2__available__container .m-select-v2__header {
55
+ border-radius: 0.35rem 0 0 0;
101
56
  }
102
- .m-select__wrapper .m-select-inner li > div {
103
- padding: 0.35rem 0.75rem;
104
- display: flex;
105
- justify-content: space-between;
106
- width: 100%;
57
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2-draggable-list {
58
+ font-size: var(--m-select-v2-body-font-size);
107
59
  overflow: hidden;
108
- text-overflow: ellipsis;
109
- word-wrap: break-word;
110
- word-break: break-word;
111
- }
112
- .m-select__wrapper .m-select-inner li > div > strong {
113
- font-weight: normal;
114
- display: flex;
115
- align-items: center;
116
- }
117
- .m-select__wrapper .m-select-inner li > div > strong .arrow {
118
- display: inline-block;
119
- margin-left: 0.2rem;
120
- }
121
- .m-select__wrapper .m-select-inner li > div.active .arrow {
122
- transform: rotate(90deg);
60
+ overflow-y: auto;
61
+ max-height: calc(var(--m-select-v2-wrapper-min-h) - 1.75rem);
62
+ /* Search Result */
123
63
  }
124
- .m-select__wrapper .m-select-inner li > div > i {
125
- display: inline-block;
126
- cursor: pointer;
64
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2-draggable-list::-webkit-scrollbar {
65
+ width: var(--m-select-v2-scrollbar-w);
127
66
  }
128
- .m-select__wrapper .m-select-inner li > div > i svg path {
129
- fill: var(--m-select-options-item-icon-color);
67
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2-draggable-list::-webkit-scrollbar-thumb {
68
+ background: var(--m-select-v2-scrollbar-color);
130
69
  }
131
- .m-select__wrapper .m-select-inner div.m-select__selected__container .m-select__header {
132
- border-radius: 0 0.35rem 0 0;
70
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2-draggable-list::-webkit-scrollbar-track {
71
+ background: var(--m-select-v2-scrollbar-track);
133
72
  }
134
- .m-select__wrapper .m-select-inner div.m-select__available__container .m-select__header {
135
- border-radius: 0.35rem 0 0 0;
73
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2-draggable-list .m-select-v2-draggable-list__item.hide {
74
+ display: none;
136
75
  }
137
- .m-select__wrapper .m-select-inner .m-select__header {
76
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2__header {
138
77
  border: none;
139
- font-size: var(--m-select-header-font-size);
78
+ font-size: var(--m-select-v2-header-font-size);
140
79
  margin-bottom: 1px;
141
- background: var(--m-select-header-bg);
80
+ background: var(--m-select-v2-header-bg);
142
81
  display: flex;
143
82
  justify-content: space-between;
144
83
  align-items: center;
145
84
  height: 1.625rem;
146
85
  }
147
- .m-select__wrapper .m-select-inner .m-select__btn--add-all {
86
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2__btn--add-all {
148
87
  padding: 0.2rem;
149
88
  }
150
- .m-select__wrapper .m-select-inner .m-select__btn--remove-all {
89
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2__btn--remove-all {
151
90
  padding: 0.2rem;
152
91
  }
153
- .m-select__wrapper .m-select-inner .m-select__count {
92
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2__count {
154
93
  padding: 0.2rem;
155
94
  }
156
- .m-select__wrapper .m-select-inner .m-select__title {
95
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2__title {
157
96
  padding: 0.2rem;
158
97
  font-weight: bold;
159
98
  }
160
- .m-select__wrapper .m-select-inner .m-select__search__container {
99
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2__search__container {
161
100
  position: relative;
162
101
  /* required */
163
102
  align-items: center;
164
103
  display: flex;
165
104
  }
166
- .m-select__wrapper .m-select-inner .m-select__search__container input.m-select__search {
105
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2__search__container input.m-select-v2__search {
167
106
  height: 14px;
168
107
  padding: 0.1rem 0.5rem;
169
108
  opacity: 0.5;
170
109
  margin: 4px;
171
- width: var(--m-select-search-input-w);
172
- background-color: var(--m-select-search-input-bg);
173
- color: var(--m-select-search-input-text-color);
110
+ width: var(--m-select-v2-search-input-w);
111
+ background-color: var(--m-select-v2-search-input-bg);
112
+ color: var(--m-select-v2-search-input-text-color);
174
113
  border-radius: 25px;
175
114
  border: none;
176
115
  outline: none;
177
116
  box-shadow: none;
178
117
  }
179
- .m-select__wrapper .m-select-inner .m-select__search__container i {
118
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2__search__container i {
180
119
  position: absolute;
181
120
  right: 0.6em;
182
121
  }
183
- .m-select__wrapper .m-select-inner .m-select__search__container i svg {
184
- fill: var(--m-select-search-icon-color);
122
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2__search__container i svg {
123
+ fill: var(--m-select-v2-search-icon-color);
124
+ }
125
+
126
+ /*
127
+ ///////////////////////////////////////////////////////////
128
+ //////////////////// DragDrop List //////////////////
129
+ ///////////////////////////////////////////////////////////
130
+ */
131
+ .m-select-v2-draggable-list {
132
+ --m-select-v2-draggable-content-bg: transparent;
133
+ --m-select-v2-draggable-content-color: inherit;
134
+ --m-select-v2-draggable-border-color: #ddd;
135
+ --m-select-v2-draggable-wrapper-radius: 0.25rem;
136
+ --m-select-v2-draggable-control-radius: 0.25rem;
137
+ --m-select-v2-draggable-primary-color: #ffa940;
138
+ --m-select-v2-draggable-content-diff-bg: #fafafa;
139
+ --m-select-v2-draggable-content-diff-border-color: #d9d9d9;
140
+ --m-select-v2-draggable-control-fs: 0.75rem;
141
+ --m-select-v2-draggable-control-w: 100px;
142
+ --m-select-v2-draggable-btn-confirm-bg: #52c41a;
143
+ --m-select-v2-draggable-btn-cancel-bg: #ff4d4f;
144
+ --m-select-v2-draggable-btn-color: #fff;
145
+ list-style: none;
146
+ padding: 0;
147
+ margin: 0;
148
+ width: 100%;
149
+ position: relative;
150
+ /* hide wrapper border */
151
+ border-width: 0;
152
+ border-radius: 0;
153
+ /* Fix the problem that mobile terminals cannot be touched, DO NOT USE "<svg>" */
154
+ /* FORM */
155
+ }
156
+ .m-select-v2-draggable-list li {
157
+ margin: 0;
158
+ padding: 0;
185
159
  }
186
- .m-select__wrapper ul.m-select__options-contentlist > li ul {
187
- transition: max-height 0.25s ease;
188
- overflow: hidden;
160
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item {
161
+ padding: 0;
162
+ position: relative;
163
+ transition: transform 0.15s ease;
189
164
  position: relative;
190
- padding-left: 1rem;
191
165
  }
192
- .m-select__wrapper ul.m-select__options-contentlist > li:not(.active) ul {
193
- max-height: 0;
166
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item .m-select-v2-draggable-list__itemcontent {
167
+ padding: 5px 15px;
168
+ background: var(--m-select-v2-draggable-content-bg);
169
+ color: var(--m-select-v2-draggable-content-color);
170
+ border-bottom: 1px solid var(--m-select-v2-draggable-border-color);
171
+ display: flex;
172
+ align-items: center;
173
+ user-select: none;
174
+ transition: all 0.15s ease;
175
+ }
176
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item .m-select-v2-draggable-list__itemcontent .m-select-v2-draggable-list__itemcontent-inner {
177
+ display: flex;
178
+ align-items: center;
179
+ justify-content: space-between;
180
+ width: 100%;
181
+ }
182
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item.disabled {
183
+ pointer-events: none !important;
184
+ opacity: 0.4 !important;
185
+ }
186
+ .m-select-v2-draggable-list.alternate-collapse .m-select-v2-draggable-list__collapse-arrow {
187
+ cursor: pointer;
188
+ display: inline-block;
189
+ width: 20px;
190
+ text-align: center;
191
+ user-select: none;
192
+ margin-left: 0.2rem;
193
+ }
194
+ .m-select-v2-draggable-list.alternate-collapse .m-select-v2-draggable-list__collapse-arrow svg {
195
+ transition: all 0.15s ease;
194
196
  }
195
- .m-select__wrapper ul.m-select__options-contentlist > li ul ul {
196
- margin-top: auto;
197
+ .m-select-v2-draggable-list.alternate-collapse .m-select-v2-draggable-list__collapse-arrow:hover {
198
+ opacity: 0.7;
197
199
  }
198
- .m-select__wrapper ul.m-select__options-contentlist {
200
+ .m-select-v2-draggable-list.alternate-collapse .m-select-v2-draggable-list__item.has-children {
199
201
  position: relative;
200
- width: 100%;
201
- overflow: hidden;
202
- overflow-y: auto;
203
- max-height: calc(315px - 1.75rem);
204
202
  }
205
- .m-select__wrapper ul.m-select__options-contentlist::-webkit-scrollbar {
206
- width: var(--m-select-scrollbar-w);
203
+ .m-select-v2-draggable-list.alternate-collapse .m-select-v2-draggable-list__item.collapsed .m-select-v2-draggable-list__collapse-arrow svg {
204
+ transform: rotate(-90deg);
207
205
  }
208
- .m-select__wrapper ul.m-select__options-contentlist::-webkit-scrollbar-thumb {
209
- background: var(--m-select-scrollbar-color);
206
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item.draggable .m-select-v2-draggable-list__itemcontent {
207
+ padding-left: 1.5em;
210
208
  }
211
- .m-select__wrapper ul.m-select__options-contentlist::-webkit-scrollbar-track {
212
- background: var(--m-select-scrollbar-track);
209
+ .m-select-v2-draggable-list.handle-pos-right .m-select-v2-draggable-list__item.draggable .m-select-v2-draggable-list__itemcontent, .m-select-v2-draggable-list.icon-hide .m-select-v2-draggable-list__item.draggable .m-select-v2-draggable-list__itemcontent {
210
+ padding-left: 0.5rem;
213
211
  }
214
- .m-select__wrapper ul.m-select__options-contentlist.dragging {
215
- cursor: grab;
212
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item.block.draggable {
213
+ cursor: move;
216
214
  }
217
- .m-select__wrapper ul.m-select__options-contentlist--hide {
218
- overflow: hidden;
219
- height: auto;
215
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item.dragging .m-select-v2-draggable-list__itemcontent {
216
+ background: #fff9e6;
217
+ border: 1px dashed #ffd591;
218
+ opacity: 0.8;
219
+ }
220
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item.drag-over .m-select-v2-draggable-list__itemcontent {
221
+ background: #fff9e6;
222
+ border: 2px solid #ffd591;
223
+ }
224
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item.drag-over-top::before {
225
+ content: "";
226
+ position: absolute;
227
+ top: -3px;
228
+ left: 0;
229
+ right: 0;
230
+ height: 2px;
231
+ background: var(--m-select-v2-draggable-primary-color);
232
+ border-radius: 1px;
233
+ }
234
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item.drag-over-bottom::after {
235
+ content: "";
236
+ position: absolute;
237
+ bottom: -3px;
238
+ left: 0;
239
+ right: 0;
240
+ height: 2px;
241
+ background: var(--m-select-v2-draggable-primary-color);
242
+ border-radius: 1px;
243
+ }
244
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__handle {
245
+ color: #999;
246
+ padding: 5px;
247
+ cursor: move;
248
+ transition: color 0.15s ease;
249
+ position: absolute;
250
+ width: 1em;
251
+ height: 1em;
252
+ top: 50%;
253
+ transform: translateY(-50%);
254
+ z-index: 1;
255
+ display: flex;
256
+ align-items: center;
257
+ font-size: 0.75rem;
258
+ }
259
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__handle.left {
260
+ left: 0;
261
+ }
262
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__handle.right {
263
+ right: 1em;
264
+ }
265
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item,
266
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__itemcontent {
267
+ transition: all 0.15s ease;
268
+ }
269
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item.editing .m-select-v2-draggable-list__itemcontent, .m-select-v2-draggable-list .m-select-v2-draggable-list__item:hover .m-select-v2-draggable-list__itemcontent {
270
+ background: var(--m-select-v2-draggable-content-diff-bg);
271
+ border-color: var(--m-select-v2-draggable-content-diff-border-color);
272
+ }
273
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item.block:hover .m-select-v2-draggable-list__handle {
274
+ color: var(--m-select-v2-draggable-primary-color);
275
+ }
276
+ .m-select-v2-draggable-list.handle .m-select-v2-draggable-list__handle:hover {
277
+ color: var(--m-select-v2-draggable-primary-color);
278
+ }
279
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__edit-form {
280
+ display: flex;
281
+ flex: 1;
282
+ gap: 10px;
283
+ align-items: center;
284
+ }
285
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__edit-form input {
286
+ padding: 4px 8px;
287
+ border: 1px solid var(--m-select-v2-draggable-border-color);
288
+ border-radius: var(--m-select-v2-draggable-control-radius);
289
+ font-size: var(--m-select-v2-draggable-control-fs);
290
+ width: var(--m-select-v2-draggable-control-w);
291
+ }
292
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__edit-buttons {
293
+ display: flex;
294
+ gap: 5px;
295
+ }
296
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__edit-buttons button {
297
+ padding: 0.2rem 0.5rem;
298
+ border: none;
299
+ font-size: 0.75rem;
300
+ border-radius: var(--m-select-v2-draggable-control-radius);
301
+ cursor: pointer;
302
+ }
303
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__edit-buttons button:first-child {
304
+ background: var(--m-select-v2-draggable-btn-confirm-bg);
305
+ color: var(--m-select-v2-draggable-btn-color);
306
+ }
307
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__edit-buttons button:last-child {
308
+ background: var(--m-select-v2-draggable-btn-cancel-bg);
309
+ color: var(--m-select-v2-draggable-btn-color);
310
+ }
311
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__edit-buttons button:hover {
312
+ opacity: 0.8;
220
313
  }
@@ -137,59 +137,63 @@ const ColorPicker = forwardRef((props: ColorPickerProps, externalRef: any) => {
137
137
  )} ref={rootRef}>
138
138
  {label ? <>{typeof label === 'string' ? <label htmlFor={idRes} className="form-label" dangerouslySetInnerHTML={{ __html: `${label}` }}></label> : <label htmlFor={idRes} className="form-label">{label}</label>}</> : null}
139
139
 
140
+ <div className="position-relative">
140
141
  <div className="input-group">
141
- <input
142
- ref={(node) => {
143
- valRef.current = node;
144
- if (typeof externalRef === 'function') {
145
- externalRef(node);
146
- } else if (externalRef) {
147
- externalRef.current = node;
148
- }
149
- }}
150
-
151
-
152
- tabIndex={tabIndex || 0}
153
- type='color'
154
- className={combinedCls(
155
- clsWrite(controlClassName, 'form-control custom-colorpicker-control flex-grow-0'),
156
- controlExClassName
157
- )}
158
- value={changedVal}
159
- onFocus={handleFocus}
160
- onBlur={handleBlur}
161
- onChange={handleChange}
162
- disabled={disabled || null}
163
- readOnly={readOnly || null}
164
- style={style}
165
- {...attributes}
166
- />
167
-
168
- {/* Prevents the color from automatically becoming #000000 when it is empty */}
169
- <input
170
- tabIndex={-1}
171
- type="hidden"
172
- id={idRes}
173
- name={name}
174
- value={changedVal} // do not use `defaultValue`
175
- onChange={() => void(0)}
176
- required={required || null}
177
- {...attributes}
178
- />
179
-
180
- {changedVal !== '' ? <><button tabIndex={-1} type="button" className={clearBtnClassName || 'btn btn-link btn-sm'} onClick={(e: React.MouseEvent) => {
181
- setChangedVal('');
182
- onChange?.(e);
183
- onClear?.(e);
184
- }}>{clearBtnLabel || 'clear'}
185
- </button></> : null}
186
-
142
+ <input
143
+ ref={(node) => {
144
+ valRef.current = node;
145
+ if (typeof externalRef === 'function') {
146
+ externalRef(node);
147
+ } else if (externalRef) {
148
+ externalRef.current = node;
149
+ }
150
+ }}
151
+
152
+
153
+ tabIndex={tabIndex || 0}
154
+ type='color'
155
+ className={combinedCls(
156
+ clsWrite(controlClassName, 'form-control custom-colorpicker-control flex-grow-0'),
157
+ controlExClassName
158
+ )}
159
+ value={changedVal}
160
+ onFocus={handleFocus}
161
+ onBlur={handleBlur}
162
+ onChange={handleChange}
163
+ disabled={disabled || null}
164
+ readOnly={readOnly || null}
165
+ style={style}
166
+ {...attributes}
167
+ />
168
+
169
+ {/* Prevents the color from automatically becoming #000000 when it is empty */}
170
+ <input
171
+ tabIndex={-1}
172
+ type="hidden"
173
+ id={idRes}
174
+ name={name}
175
+ value={changedVal} // do not use `defaultValue`
176
+ onChange={() => void(0)}
177
+ required={required || null}
178
+ {...attributes}
179
+ />
180
+
181
+ {changedVal !== '' ? <><button tabIndex={-1} type="button" className={clearBtnClassName || 'btn btn-link btn-sm'} onClick={(e: React.MouseEvent) => {
182
+ setChangedVal('');
183
+ onChange?.(e);
184
+ onClear?.(e);
185
+ }}>{clearBtnLabel || 'clear'}
186
+ </button></> : null}
187
+
188
+
189
+ </div>
190
+ {required ? <>{requiredLabel || requiredLabel === '' ? requiredLabel : <span className="position-absolute end-0 top-0 my-2 mx-2"><span className="text-danger">*</span></span>}</> : ''}
191
+
192
+ {changedVal === '' ? <><div className="custom-colorpicker__transparent-placeholder"></div></> : null}
187
193
 
188
194
  </div>
189
- {required ? <>{requiredLabel || requiredLabel === '' ? requiredLabel : <span className="position-absolute end-0 top-0 my-2 mx-2"><span className="text-danger">*</span></span>}</> : ''}
190
-
191
- {changedVal === '' ? <><div className="custom-colorpicker__transparent-placeholder"></div></> : null}
192
195
 
196
+
193
197
  </div>
194
198
 
195
199