@vtx/components 3.1.43 → 3.1.45
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/index.js.map +1 -1
- package/lib/vtx-datagrid/style/index.css +1 -1
- package/lib/vtx-datagrid/style/index.less +223 -223
- package/lib/vtx-export/index.js +10 -10
- package/lib/vtx-export/index.js.map +1 -1
- package/lib/vtx-select/index.js +30 -5
- package/lib/vtx-select/index.js.map +1 -1
- package/package.json +1 -1
package/lib/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":[],"sources":["index.js"],"sourcesContent":["// layout\nexport { default as VtxFormLayout } from './vtx-form-layout';\nexport { default as VtxPageLayout } from './vtx-page-layout';\nexport { default as VtxSearch } from './vtx-search';\n\n// data entry\nexport { default as VtxColorPicker } from './vtx-color-picker';\nexport { default as VtxCombogrid } from './vtx-combogrid';\nexport { default as VtxDatePicker } from './vtx-date-picker';\nexport { default as VtxEditor } from './vtx-editor';\nexport { default as VtxWangEditor } from './vtx-wang-editor';\n\nexport { default as VtxExport } from './vtx-export';\nexport { default as VtxImport } from './vtx-import';\nexport { default as VtxImport2 } from './vtx-import2';\nexport { default as VtxSearchMapInput } from './vtx-search-map-input';\nexport { default as VtxSelect } from './vtx-select';\nexport { default as VtxInput } from './vtx-input';\nexport { default as VtxTimePicker } from './vtx-time-picker';\nexport { default as VtxUpload } from './vtx-upload';\nexport { default as VtxZtreeSelect } from './vtx-ztree-select';\n\n// data display\nexport { default as VtxDatagrid } from './vtx-datagrid';\nexport { default as VtxEllipsisText } from './vtx-ellipsis-text';\nexport { default as VtxImage } from './vtx-image';\nexport { default as VtxRpsFrame } from './vtx-rps-frame';\nexport { default as VtxStatisticsColumn } from './vtx-statistics-column';\nexport { default as VtxZtree } from './vtx-ztree';\nexport { default as VtxSplitPane } from './vtx-split-pane';\n\n// feedback\nexport { default as VtxModal } from './vtx-modal';\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA;;AACA;;AACA;;AAGA;;AACA;;AACA;;AACA;;AACA;;AAEA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAGA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAGA"}
|
|
1
|
+
{"version":3,"file":"index.js","names":[],"sources":["index.js"],"sourcesContent":["// layout\r\nexport { default as VtxFormLayout } from './vtx-form-layout';\r\nexport { default as VtxPageLayout } from './vtx-page-layout';\r\nexport { default as VtxSearch } from './vtx-search';\r\n\r\n// data entry\r\nexport { default as VtxColorPicker } from './vtx-color-picker';\r\nexport { default as VtxCombogrid } from './vtx-combogrid';\r\nexport { default as VtxDatePicker } from './vtx-date-picker';\r\nexport { default as VtxEditor } from './vtx-editor';\r\nexport { default as VtxWangEditor } from './vtx-wang-editor';\r\n\r\nexport { default as VtxExport } from './vtx-export';\r\nexport { default as VtxImport } from './vtx-import';\r\nexport { default as VtxImport2 } from './vtx-import2';\r\nexport { default as VtxSearchMapInput } from './vtx-search-map-input';\r\nexport { default as VtxSelect } from './vtx-select';\r\nexport { default as VtxInput } from './vtx-input';\r\nexport { default as VtxTimePicker } from './vtx-time-picker';\r\nexport { default as VtxUpload } from './vtx-upload';\r\nexport { default as VtxZtreeSelect } from './vtx-ztree-select';\r\n\r\n// data display\r\nexport { default as VtxDatagrid } from './vtx-datagrid';\r\nexport { default as VtxEllipsisText } from './vtx-ellipsis-text';\r\nexport { default as VtxImage } from './vtx-image';\r\nexport { default as VtxRpsFrame } from './vtx-rps-frame';\r\nexport { default as VtxStatisticsColumn } from './vtx-statistics-column';\r\nexport { default as VtxZtree } from './vtx-ztree';\r\nexport { default as VtxSplitPane } from './vtx-split-pane';\r\n\r\n// feedback\r\nexport { default as VtxModal } from './vtx-modal';\r\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA;;AACA;;AACA;;AAGA;;AACA;;AACA;;AACA;;AACA;;AAEA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAGA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAGA"}
|
|
@@ -1,223 +1,223 @@
|
|
|
1
|
-
@import (reference) '~antd/lib/style/themes/index.less';
|
|
2
|
-
@import '../../style/themes/index';
|
|
3
|
-
|
|
4
|
-
@prefix-cls: vtx-datagrid;
|
|
5
|
-
|
|
6
|
-
.@{prefix-cls} {
|
|
7
|
-
position: relative;
|
|
8
|
-
width: 100%;
|
|
9
|
-
overflow: hidden;
|
|
10
|
-
|
|
11
|
-
&-fit {
|
|
12
|
-
height: 100%;
|
|
13
|
-
.ant-table-container {
|
|
14
|
-
border-left: none !important;
|
|
15
|
-
table > thead > tr th:first-child {
|
|
16
|
-
border-left: 1px solid @table-border-color;
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
.ant-table-body {
|
|
20
|
-
// overflow-y: auto !important;
|
|
21
|
-
}
|
|
22
|
-
.ant-table-header,
|
|
23
|
-
.ant-table-body {
|
|
24
|
-
&::-webkit-scrollbar {
|
|
25
|
-
width: @webkit-scrollbar-width;
|
|
26
|
-
height: @webkit-scrollbar-height;
|
|
27
|
-
background-color: @webkit-scrollbar-color;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
&::-webkit-scrollbar-thumb {
|
|
31
|
-
background-color: @webkit-scrollbar-thumb-color;
|
|
32
|
-
border-radius: @webkit-scrollbar-thumb-radius;
|
|
33
|
-
}
|
|
34
|
-
> table {
|
|
35
|
-
min-height: 1px;
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
.ant-table-tbody > tr {
|
|
39
|
-
&:nth-child(odd) {
|
|
40
|
-
background: @table-row-odd;
|
|
41
|
-
> td {
|
|
42
|
-
background: @table-row-odd !important;
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
> td:first-child {
|
|
46
|
-
border-left: 1px solid @table-border-color;
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
.ant-table-fixed-header .ant-table-scroll .ant-table-header {
|
|
50
|
-
min-width: 5px !important;
|
|
51
|
-
}
|
|
52
|
-
.ant-table-pagination {
|
|
53
|
-
position: absolute;
|
|
54
|
-
right: 0;
|
|
55
|
-
bottom: 0;
|
|
56
|
-
}
|
|
57
|
-
.ant-spin-nested-loading {
|
|
58
|
-
height: 100%;
|
|
59
|
-
.ant-spin-container {
|
|
60
|
-
position: relative;
|
|
61
|
-
height: 100%;
|
|
62
|
-
.ant-table {
|
|
63
|
-
height: 100%;
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
&-noFit {
|
|
69
|
-
.ant-table-tbody > tr {
|
|
70
|
-
&:nth-child(even) when(@theme=default) {
|
|
71
|
-
background: #f6f6f6;
|
|
72
|
-
> td {
|
|
73
|
-
background: #f6f6f6 !important;
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
// 固定列目前没有办法用细的滚动条
|
|
79
|
-
// .ant-table-has-fix-right {
|
|
80
|
-
// .ant-table-body {
|
|
81
|
-
// &::-webkit-scrollbar {
|
|
82
|
-
// width: 5px;
|
|
83
|
-
// height: 5px;
|
|
84
|
-
// }
|
|
85
|
-
// }
|
|
86
|
-
// }
|
|
87
|
-
// mac 和 windows下有差异,window chrome下滚动条宽度17px,mac chrome下15px
|
|
88
|
-
// &-userAgent-mac {
|
|
89
|
-
// .ant-table-has-fix-right {
|
|
90
|
-
// .ant-table-body {
|
|
91
|
-
// &::-webkit-scrollbar {
|
|
92
|
-
// width: 5px;
|
|
93
|
-
// height: 5px;
|
|
94
|
-
// }
|
|
95
|
-
// }
|
|
96
|
-
// }
|
|
97
|
-
// }
|
|
98
|
-
.ant-table-tbody > tr.ant-table-row-selected > td {
|
|
99
|
-
// background: transparent !important;
|
|
100
|
-
border-color:
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
.ant-table-thead > tr > th when(@theme=default) {
|
|
104
|
-
// antd4.0 半透明会重叠
|
|
105
|
-
// background-color: fade(#1890ff, 8);
|
|
106
|
-
font-weight: bold;
|
|
107
|
-
background-color: rgba(237, 246, 255, 1);
|
|
108
|
-
}
|
|
109
|
-
.ant-table-tbody > tr {
|
|
110
|
-
// &:nth-child(even) when(@theme=default) {
|
|
111
|
-
// background: #f6f6f6;
|
|
112
|
-
// }
|
|
113
|
-
& > .ant-table-cell {
|
|
114
|
-
color:
|
|
115
|
-
}
|
|
116
|
-
&.ant-table-placeholder {
|
|
117
|
-
position: absolute;
|
|
118
|
-
top: 25%;
|
|
119
|
-
// top: auto;
|
|
120
|
-
right: 0;
|
|
121
|
-
// bottom: auto;
|
|
122
|
-
left: 0;
|
|
123
|
-
background-color: transparent;
|
|
124
|
-
border-top: none;
|
|
125
|
-
// height: 100%;
|
|
126
|
-
& > td.ant-table-cell {
|
|
127
|
-
display: flex;
|
|
128
|
-
align-items: center;
|
|
129
|
-
justify-content: center;
|
|
130
|
-
width: 100%;
|
|
131
|
-
height: 100%;
|
|
132
|
-
// border-right: @border-width-base @border-style-base @table-border-color;
|
|
133
|
-
// border-left: @border-width-base @border-style-base @table-border-color;
|
|
134
|
-
border: none;
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
// fix: checkbox 选中时 固定列 最上面一层透明会 和下面重叠
|
|
139
|
-
// .ant-table-tbody > tr.ant-table-row-selected td {
|
|
140
|
-
// background: transparent;
|
|
141
|
-
// }
|
|
142
|
-
&-alert {
|
|
143
|
-
margin-bottom: 8px;
|
|
144
|
-
&-message when(@theme=default) {
|
|
145
|
-
color: fade(@black, 65%);
|
|
146
|
-
}
|
|
147
|
-
&-message when(@theme=dark) {
|
|
148
|
-
color: @text-color;
|
|
149
|
-
}
|
|
150
|
-
&-info-content > strong {
|
|
151
|
-
margin: 0 4px;
|
|
152
|
-
color: #13c2c2;
|
|
153
|
-
}
|
|
154
|
-
&-info-option {
|
|
155
|
-
margin-left: 10px;
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
&-nodata {
|
|
159
|
-
.ant-table-scroll {
|
|
160
|
-
overflow-y: hidden;
|
|
161
|
-
}
|
|
162
|
-
}
|
|
163
|
-
&-toolbar {
|
|
164
|
-
display: table;
|
|
165
|
-
width: 100%;
|
|
166
|
-
margin: 16px 0;
|
|
167
|
-
color: @text-color;
|
|
168
|
-
}
|
|
169
|
-
&-toolbar-left,
|
|
170
|
-
&-toolbar-right {
|
|
171
|
-
display: inline-block;
|
|
172
|
-
display: table-cell;
|
|
173
|
-
vertical-align: middle;
|
|
174
|
-
}
|
|
175
|
-
&-toolbar-left {
|
|
176
|
-
color: @text-color;
|
|
177
|
-
font-size: 16px;
|
|
178
|
-
}
|
|
179
|
-
&-toolbar-right {
|
|
180
|
-
float: right;
|
|
181
|
-
}
|
|
182
|
-
&-toolbar-setting-item {
|
|
183
|
-
display: inline-block;
|
|
184
|
-
margin-left: 16px;
|
|
185
|
-
color: @icon-color;
|
|
186
|
-
font-size: 16px;
|
|
187
|
-
vertical-align: middle;
|
|
188
|
-
cursor: pointer;
|
|
189
|
-
&:hover {
|
|
190
|
-
color: @icon-color-hover;
|
|
191
|
-
}
|
|
192
|
-
}
|
|
193
|
-
&-column-setting-title {
|
|
194
|
-
height: 32px;
|
|
195
|
-
line-height: 32px;
|
|
196
|
-
a {
|
|
197
|
-
display: inline-block;
|
|
198
|
-
float: right;
|
|
199
|
-
vertical-align: middle;
|
|
200
|
-
}
|
|
201
|
-
}
|
|
202
|
-
&-column-setting-checkbox-wrapper {
|
|
203
|
-
color: @text-color;
|
|
204
|
-
vertical-align: middle;
|
|
205
|
-
}
|
|
206
|
-
&-space-item {
|
|
207
|
-
display: inline-block;
|
|
208
|
-
vertical-align: middle;
|
|
209
|
-
}
|
|
210
|
-
.react-resizable {
|
|
211
|
-
position: relative;
|
|
212
|
-
background-clip: padding-box;
|
|
213
|
-
}
|
|
214
|
-
.react-resizable-handle {
|
|
215
|
-
position: absolute;
|
|
216
|
-
right: -5px;
|
|
217
|
-
bottom: 0;
|
|
218
|
-
z-index: 1;
|
|
219
|
-
width: 10px;
|
|
220
|
-
height: 100%;
|
|
221
|
-
cursor: col-resize;
|
|
222
|
-
}
|
|
223
|
-
}
|
|
1
|
+
@import (reference) '~antd/lib/style/themes/index.less';
|
|
2
|
+
@import '../../style/themes/index';
|
|
3
|
+
|
|
4
|
+
@prefix-cls: vtx-datagrid;
|
|
5
|
+
|
|
6
|
+
.@{prefix-cls} {
|
|
7
|
+
position: relative;
|
|
8
|
+
width: 100%;
|
|
9
|
+
overflow: hidden;
|
|
10
|
+
|
|
11
|
+
&-fit {
|
|
12
|
+
height: 100%;
|
|
13
|
+
.ant-table-container {
|
|
14
|
+
border-left: none !important;
|
|
15
|
+
table > thead > tr th:first-child {
|
|
16
|
+
border-left: 1px solid @table-border-color;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
.ant-table-body {
|
|
20
|
+
// overflow-y: auto !important;
|
|
21
|
+
}
|
|
22
|
+
.ant-table-header,
|
|
23
|
+
.ant-table-body {
|
|
24
|
+
&::-webkit-scrollbar {
|
|
25
|
+
width: @webkit-scrollbar-width;
|
|
26
|
+
height: @webkit-scrollbar-height;
|
|
27
|
+
background-color: @webkit-scrollbar-color;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
&::-webkit-scrollbar-thumb {
|
|
31
|
+
background-color: @webkit-scrollbar-thumb-color;
|
|
32
|
+
border-radius: @webkit-scrollbar-thumb-radius;
|
|
33
|
+
}
|
|
34
|
+
> table {
|
|
35
|
+
min-height: 1px;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
.ant-table-tbody > tr {
|
|
39
|
+
&:nth-child(odd) {
|
|
40
|
+
background: @table-row-odd;
|
|
41
|
+
> td {
|
|
42
|
+
background: @table-row-odd !important;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
> td:first-child {
|
|
46
|
+
border-left: 1px solid @table-border-color;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
.ant-table-fixed-header .ant-table-scroll .ant-table-header {
|
|
50
|
+
min-width: 5px !important;
|
|
51
|
+
}
|
|
52
|
+
.ant-table-pagination {
|
|
53
|
+
position: absolute;
|
|
54
|
+
right: 0;
|
|
55
|
+
bottom: 0;
|
|
56
|
+
}
|
|
57
|
+
.ant-spin-nested-loading {
|
|
58
|
+
height: 100%;
|
|
59
|
+
.ant-spin-container {
|
|
60
|
+
position: relative;
|
|
61
|
+
height: 100%;
|
|
62
|
+
.ant-table {
|
|
63
|
+
height: 100%;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
&-noFit {
|
|
69
|
+
.ant-table-tbody > tr {
|
|
70
|
+
&:nth-child(even) when(@theme=default) {
|
|
71
|
+
background: #f6f6f6;
|
|
72
|
+
> td {
|
|
73
|
+
background: #f6f6f6 !important;
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
// 固定列目前没有办法用细的滚动条
|
|
79
|
+
// .ant-table-has-fix-right {
|
|
80
|
+
// .ant-table-body {
|
|
81
|
+
// &::-webkit-scrollbar {
|
|
82
|
+
// width: 5px;
|
|
83
|
+
// height: 5px;
|
|
84
|
+
// }
|
|
85
|
+
// }
|
|
86
|
+
// }
|
|
87
|
+
// mac 和 windows下有差异,window chrome下滚动条宽度17px,mac chrome下15px
|
|
88
|
+
// &-userAgent-mac {
|
|
89
|
+
// .ant-table-has-fix-right {
|
|
90
|
+
// .ant-table-body {
|
|
91
|
+
// &::-webkit-scrollbar {
|
|
92
|
+
// width: 5px;
|
|
93
|
+
// height: 5px;
|
|
94
|
+
// }
|
|
95
|
+
// }
|
|
96
|
+
// }
|
|
97
|
+
// }
|
|
98
|
+
.ant-table-tbody > tr.ant-table-row-selected > td {
|
|
99
|
+
// background: transparent !important;
|
|
100
|
+
border-color: @table-border-color !important;
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
.ant-table-thead > tr > th when(@theme=default) {
|
|
104
|
+
// antd4.0 半透明会重叠
|
|
105
|
+
// background-color: fade(#1890ff, 8);
|
|
106
|
+
font-weight: bold;
|
|
107
|
+
background-color: rgba(237, 246, 255, 1);
|
|
108
|
+
}
|
|
109
|
+
.ant-table-tbody > tr {
|
|
110
|
+
// &:nth-child(even) when(@theme=default) {
|
|
111
|
+
// background: #f6f6f6;
|
|
112
|
+
// }
|
|
113
|
+
& > .ant-table-cell {
|
|
114
|
+
color: @text-color;
|
|
115
|
+
}
|
|
116
|
+
&.ant-table-placeholder {
|
|
117
|
+
position: absolute;
|
|
118
|
+
top: 25%;
|
|
119
|
+
// top: auto;
|
|
120
|
+
right: 0;
|
|
121
|
+
// bottom: auto;
|
|
122
|
+
left: 0;
|
|
123
|
+
background-color: transparent;
|
|
124
|
+
border-top: none;
|
|
125
|
+
// height: 100%;
|
|
126
|
+
& > td.ant-table-cell {
|
|
127
|
+
display: flex;
|
|
128
|
+
align-items: center;
|
|
129
|
+
justify-content: center;
|
|
130
|
+
width: 100%;
|
|
131
|
+
height: 100%;
|
|
132
|
+
// border-right: @border-width-base @border-style-base @table-border-color;
|
|
133
|
+
// border-left: @border-width-base @border-style-base @table-border-color;
|
|
134
|
+
border: none;
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
// fix: checkbox 选中时 固定列 最上面一层透明会 和下面重叠
|
|
139
|
+
// .ant-table-tbody > tr.ant-table-row-selected td {
|
|
140
|
+
// background: transparent;
|
|
141
|
+
// }
|
|
142
|
+
&-alert {
|
|
143
|
+
margin-bottom: 8px;
|
|
144
|
+
&-message when(@theme=default) {
|
|
145
|
+
color: fade(@black, 65%);
|
|
146
|
+
}
|
|
147
|
+
&-message when(@theme=dark) {
|
|
148
|
+
color: @text-color;
|
|
149
|
+
}
|
|
150
|
+
&-info-content > strong {
|
|
151
|
+
margin: 0 4px;
|
|
152
|
+
color: #13c2c2;
|
|
153
|
+
}
|
|
154
|
+
&-info-option {
|
|
155
|
+
margin-left: 10px;
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
&-nodata {
|
|
159
|
+
.ant-table-scroll {
|
|
160
|
+
overflow-y: hidden;
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
&-toolbar {
|
|
164
|
+
display: table;
|
|
165
|
+
width: 100%;
|
|
166
|
+
margin: 16px 0;
|
|
167
|
+
color: @text-color;
|
|
168
|
+
}
|
|
169
|
+
&-toolbar-left,
|
|
170
|
+
&-toolbar-right {
|
|
171
|
+
display: inline-block;
|
|
172
|
+
display: table-cell;
|
|
173
|
+
vertical-align: middle;
|
|
174
|
+
}
|
|
175
|
+
&-toolbar-left {
|
|
176
|
+
color: @text-color;
|
|
177
|
+
font-size: 16px;
|
|
178
|
+
}
|
|
179
|
+
&-toolbar-right {
|
|
180
|
+
float: right;
|
|
181
|
+
}
|
|
182
|
+
&-toolbar-setting-item {
|
|
183
|
+
display: inline-block;
|
|
184
|
+
margin-left: 16px;
|
|
185
|
+
color: @icon-color;
|
|
186
|
+
font-size: 16px;
|
|
187
|
+
vertical-align: middle;
|
|
188
|
+
cursor: pointer;
|
|
189
|
+
&:hover {
|
|
190
|
+
color: @icon-color-hover;
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
&-column-setting-title {
|
|
194
|
+
height: 32px;
|
|
195
|
+
line-height: 32px;
|
|
196
|
+
a {
|
|
197
|
+
display: inline-block;
|
|
198
|
+
float: right;
|
|
199
|
+
vertical-align: middle;
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
&-column-setting-checkbox-wrapper {
|
|
203
|
+
color: @text-color;
|
|
204
|
+
vertical-align: middle;
|
|
205
|
+
}
|
|
206
|
+
&-space-item {
|
|
207
|
+
display: inline-block;
|
|
208
|
+
vertical-align: middle;
|
|
209
|
+
}
|
|
210
|
+
.react-resizable {
|
|
211
|
+
position: relative;
|
|
212
|
+
background-clip: padding-box;
|
|
213
|
+
}
|
|
214
|
+
.react-resizable-handle {
|
|
215
|
+
position: absolute;
|
|
216
|
+
right: -5px;
|
|
217
|
+
bottom: 0;
|
|
218
|
+
z-index: 1;
|
|
219
|
+
width: 10px;
|
|
220
|
+
height: 100%;
|
|
221
|
+
cursor: col-resize;
|
|
222
|
+
}
|
|
223
|
+
}
|
package/lib/vtx-export/index.js
CHANGED
|
@@ -34,10 +34,10 @@ var _ExportOutlined = _interopRequireDefault(require("@ant-design/icons/ExportOu
|
|
|
34
34
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
35
35
|
|
|
36
36
|
var _getUrlParam = (0, _getUrlParam2["default"])(),
|
|
37
|
-
token = _getUrlParam.token; // 默认
|
|
37
|
+
token = _getUrlParam.token; // 默认60秒超时
|
|
38
38
|
|
|
39
39
|
|
|
40
|
-
var SECOND =
|
|
40
|
+
var SECOND = 60;
|
|
41
41
|
var MILL_SECOND = 1000;
|
|
42
42
|
|
|
43
43
|
var VtxExport = function VtxExport(props) {
|
|
@@ -70,10 +70,10 @@ var VtxExport = function VtxExport(props) {
|
|
|
70
70
|
downLoadFile(passVal);
|
|
71
71
|
} // eslint-disable-next-line valid-jsdoc
|
|
72
72
|
|
|
73
|
-
/**
|
|
74
|
-
* 发送http请求
|
|
75
|
-
* @param {Object} postData api参数
|
|
76
|
-
* @return reponse
|
|
73
|
+
/**
|
|
74
|
+
* 发送http请求
|
|
75
|
+
* @param {Object} postData api参数
|
|
76
|
+
* @return reponse
|
|
77
77
|
*/
|
|
78
78
|
|
|
79
79
|
|
|
@@ -150,10 +150,10 @@ var VtxExport = function VtxExport(props) {
|
|
|
150
150
|
downloadByATag(window.URL.createObjectURL(blob), filename);
|
|
151
151
|
}
|
|
152
152
|
}
|
|
153
|
-
/**
|
|
154
|
-
* 通过a标签模拟下载
|
|
155
|
-
* @param {String} href
|
|
156
|
-
* @param {String} filename
|
|
153
|
+
/**
|
|
154
|
+
* 通过a标签模拟下载
|
|
155
|
+
* @param {String} href
|
|
156
|
+
* @param {String} filename
|
|
157
157
|
*/
|
|
158
158
|
|
|
159
159
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["getUrlParam","token","SECOND","MILL_SECOND","VtxExport","props","exportText","rowButton","pageButton","allButton","downloadURL","timeout","getExportParams","afterExport","exportButtonClick","param","passVal","key","downLoadFile","requestToResponse","postData","params","url","method","responseType","headers","Authorization","data","qs","stringify","Promise","resolve","reject","axios","then","res","err","div","document","createElement","ReactDOM","render","body","appendChild","status","contentDisposition","filename","indexOf","decodeURI","split","replace","download","message","warn","removeChild","content","blob","Blob","window","navigator","msSaveOrOpenBlob","downloadByATag","URL","createObjectURL","href","a","style","display","click","remove","revokeObjectURL","exportMenu","propTypes","PropTypes","string","bool","func","number"],"sources":["vtx-export/index.jsx"],"sourcesContent":["import React from 'react';\nimport ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport axios from 'axios';\nimport qs from 'querystring';\nimport Button from 'antd/lib/button';\nimport Menu from 'antd/lib/menu';\nimport Dropdown from 'antd/lib/dropdown';\nimport message from 'antd/lib/message';\nimport Spin from 'antd/lib/spin';\nimport getUrlParam from '@vtx/utils/lib/getUrlParam';\nimport DownOutlined from '@ant-design/icons/DownOutlined';\nimport ExportOutlined from '@ant-design/icons/ExportOutlined';\n\nconst { token } = getUrlParam();\n// 默认10秒超时\nconst SECOND = 10;\nconst MILL_SECOND = 1000;\n\nconst VtxExport = props => {\n const {\n exportText = '导出',\n rowButton = true,\n pageButton = true,\n allButton = true,\n downloadURL,\n timeout = SECOND,\n } = props;\n\n const { getExportParams, afterExport } = props;\n\n /* 菜单点击 */\n function exportButtonClick(param) {\n const passVal = typeof getExportParams == 'function' ? getExportParams(param.key) : null;\n if (!downloadURL) {\n return;\n }\n if (!passVal) {\n return;\n }\n downLoadFile(passVal);\n }\n\n // eslint-disable-next-line valid-jsdoc\n /**\n * 发送http请求\n * @param {Object} postData api参数\n * @return reponse\n */\n function requestToResponse(postData) {\n const params = {\n url: downloadURL,\n method: 'post',\n timeout: timeout * MILL_SECOND,\n responseType: 'blob',\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n Authorization: token ? `Bearer ${token}` : '',\n },\n data: qs.stringify(postData),\n };\n return new Promise((resolve, reject) => {\n axios(params)\n .then(res => {\n resolve(res);\n })\n .catch(err => {\n reject(err);\n });\n });\n }\n\n /* 下载文件 */\n function downLoadFile(postData) {\n const div = document.createElement('div');\n ReactDOM.render(<Spin spinning className=\"vtx-spin\" />, div);\n document.body.appendChild(div);\n\n requestToResponse(postData).then(res => {\n let status = false;\n // 文件存在\n if (res.headers['content-disposition']) {\n const contentDisposition = res.headers['content-disposition'];\n let filename;\n if (contentDisposition.indexOf('filename*=') > -1) {\n filename = decodeURI(\n contentDisposition.split('filename*=')[1].replace(\"utf-8'zh_cn'\", ''),\n );\n } else {\n filename = decodeURI(contentDisposition.split('filename=')[1]);\n }\n if ('download' in document.createElement('a')) {\n download(res.data, filename);\n status = true;\n } else {\n message.warn('浏览器不支持');\n }\n }\n // 关闭loading,执行回调\n document.body.removeChild(div);\n if (afterExport && typeof afterExport === 'function') {\n afterExport(status);\n }\n });\n }\n\n /* 下载并 兼容IE */\n function download(content, filename) {\n const blob = new Blob([content]);\n // IE\n if (window.navigator && window.navigator.msSaveOrOpenBlob) {\n window.navigator.msSaveOrOpenBlob(blob, filename);\n } else {\n downloadByATag(window.URL.createObjectURL(blob), filename);\n }\n }\n\n /**\n * 通过a标签模拟下载\n * @param {String} href\n * @param {String} filename\n */\n function downloadByATag(href, filename) {\n const a = document.createElement('a');\n a.download = filename;\n a.style.display = 'none';\n a.href = href;\n document.body.appendChild(a);\n a.click();\n a.remove();\n window.URL.revokeObjectURL(href);\n }\n\n const exportMenu = (\n <Menu onClick={exportButtonClick}>\n {rowButton === false ? null : <Menu.Item key=\"rows\">导出选中行</Menu.Item>}\n {pageButton === false ? null : <Menu.Item key=\"page\">导出当前页</Menu.Item>}\n {allButton === false ? null : <Menu.Item key=\"all\">导出全部</Menu.Item>}\n </Menu>\n );\n return (\n <Dropdown overlay={exportMenu} trigger={['click']}>\n <Button icon={<ExportOutlined />}>\n {exportText} <DownOutlined />\n </Button>\n </Dropdown>\n );\n};\n\nVtxExport.propTypes = {\n exportText: PropTypes.string,\n rowButton: PropTypes.bool,\n pageButton: PropTypes.bool,\n allButton: PropTypes.bool,\n downloadURL: PropTypes.string,\n getExportParams: PropTypes.func,\n afterExport: PropTypes.func,\n timeout: PropTypes.number,\n};\nexport default VtxExport;\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","names":["getUrlParam","token","SECOND","MILL_SECOND","VtxExport","props","exportText","rowButton","pageButton","allButton","downloadURL","timeout","getExportParams","afterExport","exportButtonClick","param","passVal","key","downLoadFile","requestToResponse","postData","params","url","method","responseType","headers","Authorization","data","qs","stringify","Promise","resolve","reject","axios","then","res","err","div","document","createElement","ReactDOM","render","body","appendChild","status","contentDisposition","filename","indexOf","decodeURI","split","replace","download","message","warn","removeChild","content","blob","Blob","window","navigator","msSaveOrOpenBlob","downloadByATag","URL","createObjectURL","href","a","style","display","click","remove","revokeObjectURL","exportMenu","propTypes","PropTypes","string","bool","func","number"],"sources":["vtx-export/index.jsx"],"sourcesContent":["import React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport PropTypes from 'prop-types';\r\nimport axios from 'axios';\r\nimport qs from 'querystring';\r\nimport Button from 'antd/lib/button';\r\nimport Menu from 'antd/lib/menu';\r\nimport Dropdown from 'antd/lib/dropdown';\r\nimport message from 'antd/lib/message';\r\nimport Spin from 'antd/lib/spin';\r\nimport getUrlParam from '@vtx/utils/lib/getUrlParam';\r\nimport DownOutlined from '@ant-design/icons/DownOutlined';\r\nimport ExportOutlined from '@ant-design/icons/ExportOutlined';\r\n\r\nconst { token } = getUrlParam();\r\n// 默认60秒超时\r\nconst SECOND = 60;\r\nconst MILL_SECOND = 1000;\r\n\r\nconst VtxExport = props => {\r\n const {\r\n exportText = '导出',\r\n rowButton = true,\r\n pageButton = true,\r\n allButton = true,\r\n downloadURL,\r\n timeout = SECOND,\r\n } = props;\r\n\r\n const { getExportParams, afterExport } = props;\r\n\r\n /* 菜单点击 */\r\n function exportButtonClick(param) {\r\n const passVal = typeof getExportParams == 'function' ? getExportParams(param.key) : null;\r\n if (!downloadURL) {\r\n return;\r\n }\r\n if (!passVal) {\r\n return;\r\n }\r\n downLoadFile(passVal);\r\n }\r\n\r\n // eslint-disable-next-line valid-jsdoc\r\n /**\r\n * 发送http请求\r\n * @param {Object} postData api参数\r\n * @return reponse\r\n */\r\n function requestToResponse(postData) {\r\n const params = {\r\n url: downloadURL,\r\n method: 'post',\r\n timeout: timeout * MILL_SECOND,\r\n responseType: 'blob',\r\n headers: {\r\n 'Content-Type': 'application/x-www-form-urlencoded',\r\n Authorization: token ? `Bearer ${token}` : '',\r\n },\r\n data: qs.stringify(postData),\r\n };\r\n return new Promise((resolve, reject) => {\r\n axios(params)\r\n .then(res => {\r\n resolve(res);\r\n })\r\n .catch(err => {\r\n reject(err);\r\n });\r\n });\r\n }\r\n\r\n /* 下载文件 */\r\n function downLoadFile(postData) {\r\n const div = document.createElement('div');\r\n ReactDOM.render(<Spin spinning className=\"vtx-spin\" />, div);\r\n document.body.appendChild(div);\r\n\r\n requestToResponse(postData).then(res => {\r\n let status = false;\r\n // 文件存在\r\n if (res.headers['content-disposition']) {\r\n const contentDisposition = res.headers['content-disposition'];\r\n let filename;\r\n if (contentDisposition.indexOf('filename*=') > -1) {\r\n filename = decodeURI(\r\n contentDisposition.split('filename*=')[1].replace(\"utf-8'zh_cn'\", ''),\r\n );\r\n } else {\r\n filename = decodeURI(contentDisposition.split('filename=')[1]);\r\n }\r\n if ('download' in document.createElement('a')) {\r\n download(res.data, filename);\r\n status = true;\r\n } else {\r\n message.warn('浏览器不支持');\r\n }\r\n }\r\n // 关闭loading,执行回调\r\n document.body.removeChild(div);\r\n if (afterExport && typeof afterExport === 'function') {\r\n afterExport(status);\r\n }\r\n });\r\n }\r\n\r\n /* 下载并 兼容IE */\r\n function download(content, filename) {\r\n const blob = new Blob([content]);\r\n // IE\r\n if (window.navigator && window.navigator.msSaveOrOpenBlob) {\r\n window.navigator.msSaveOrOpenBlob(blob, filename);\r\n } else {\r\n downloadByATag(window.URL.createObjectURL(blob), filename);\r\n }\r\n }\r\n\r\n /**\r\n * 通过a标签模拟下载\r\n * @param {String} href\r\n * @param {String} filename\r\n */\r\n function downloadByATag(href, filename) {\r\n const a = document.createElement('a');\r\n a.download = filename;\r\n a.style.display = 'none';\r\n a.href = href;\r\n document.body.appendChild(a);\r\n a.click();\r\n a.remove();\r\n window.URL.revokeObjectURL(href);\r\n }\r\n\r\n const exportMenu = (\r\n <Menu onClick={exportButtonClick}>\r\n {rowButton === false ? null : <Menu.Item key=\"rows\">导出选中行</Menu.Item>}\r\n {pageButton === false ? null : <Menu.Item key=\"page\">导出当前页</Menu.Item>}\r\n {allButton === false ? null : <Menu.Item key=\"all\">导出全部</Menu.Item>}\r\n </Menu>\r\n );\r\n return (\r\n <Dropdown overlay={exportMenu} trigger={['click']}>\r\n <Button icon={<ExportOutlined />}>\r\n {exportText} <DownOutlined />\r\n </Button>\r\n </Dropdown>\r\n );\r\n};\r\n\r\nVtxExport.propTypes = {\r\n exportText: PropTypes.string,\r\n rowButton: PropTypes.bool,\r\n pageButton: PropTypes.bool,\r\n allButton: PropTypes.bool,\r\n downloadURL: PropTypes.string,\r\n getExportParams: PropTypes.func,\r\n afterExport: PropTypes.func,\r\n timeout: PropTypes.number,\r\n};\r\nexport default VtxExport;\r\n"],"mappings":"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"}
|
package/lib/vtx-select/index.js
CHANGED
|
@@ -75,6 +75,12 @@ var VtxSelect = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
|
|
|
75
75
|
|
|
76
76
|
var elRef = (0, _react.useRef)();
|
|
77
77
|
var elId = (0, _react.useRef)("vtx-select-".concat(Date.now()));
|
|
78
|
+
|
|
79
|
+
var _useState3 = (0, _react.useState)(''),
|
|
80
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
81
|
+
searchValue = _useState4[0],
|
|
82
|
+
setSearchValue = _useState4[1];
|
|
83
|
+
|
|
78
84
|
var value = props.value,
|
|
79
85
|
mode = props.mode,
|
|
80
86
|
_props$size = props.size,
|
|
@@ -91,6 +97,8 @@ var VtxSelect = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
|
|
|
91
97
|
selectStyle = props.selectStyle,
|
|
92
98
|
_props$selectAll = props.selectAll,
|
|
93
99
|
selectAll = _props$selectAll === void 0 ? true : _props$selectAll,
|
|
100
|
+
_props$selectSearchAl = props.selectSearchAll,
|
|
101
|
+
selectSearchAll = _props$selectSearchAl === void 0 ? true : _props$selectSearchAl,
|
|
94
102
|
_props$defaultBindBod = props.defaultBindBodyToPopupContainer,
|
|
95
103
|
defaultBindBodyToPopupContainer = _props$defaultBindBod === void 0 ? true : _props$defaultBindBod;
|
|
96
104
|
(0, _react.useEffect)(function () {
|
|
@@ -149,12 +157,21 @@ var VtxSelect = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
|
|
|
149
157
|
}));
|
|
150
158
|
};
|
|
151
159
|
|
|
152
|
-
var newProps = _objectSpread({
|
|
160
|
+
var newProps = _objectSpread(_objectSpread({
|
|
153
161
|
showSearch: true,
|
|
154
162
|
optionFilterProp: 'children',
|
|
155
163
|
placeholder: '请选择',
|
|
156
164
|
allowClear: true
|
|
157
|
-
}, props)
|
|
165
|
+
}, props), {}, {
|
|
166
|
+
onSearch: function onSearch(value) {
|
|
167
|
+
setSearchValue(value ? String(value).toLowerCase() : '');
|
|
168
|
+
props.onSearch && props.onSearch(value);
|
|
169
|
+
},
|
|
170
|
+
onBlur: function onBlur(e) {
|
|
171
|
+
setSearchValue('');
|
|
172
|
+
props.onBlur && props.onBlur(e);
|
|
173
|
+
}
|
|
174
|
+
});
|
|
158
175
|
|
|
159
176
|
if (mode === 'multiple') {
|
|
160
177
|
newProps = _objectSpread(_objectSpread({}, newProps), {}, {
|
|
@@ -177,10 +194,17 @@ var VtxSelect = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
|
|
|
177
194
|
checked: valueLength && valueLength === newChildren.length,
|
|
178
195
|
onChange: function onChange(e) {
|
|
179
196
|
if (e.target.checked) {
|
|
180
|
-
var
|
|
197
|
+
var tempChildren = newChildren.filter(function (item) {
|
|
198
|
+
if (selectSearchAll && searchValue) {
|
|
199
|
+
return String(item.props.children).toLowerCase().indexOf(searchValue) > -1;
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
return true;
|
|
203
|
+
});
|
|
204
|
+
var keys = tempChildren.map(function (item) {
|
|
181
205
|
return item.key;
|
|
182
206
|
});
|
|
183
|
-
_onChange && _onChange(keys,
|
|
207
|
+
_onChange && _onChange(keys, tempChildren);
|
|
184
208
|
} else {
|
|
185
209
|
_onChange && _onChange([], []);
|
|
186
210
|
}
|
|
@@ -250,7 +274,8 @@ VtxSelect.propTypes = {
|
|
|
250
274
|
maxTagPlaceholder: _propTypes["default"].oneOfType([_propTypes["default"].func, _propTypes["default"].node]),
|
|
251
275
|
showAll: _propTypes["default"].bool,
|
|
252
276
|
children: _propTypes["default"].node,
|
|
253
|
-
selectAll: _propTypes["default"].bool
|
|
277
|
+
selectAll: _propTypes["default"].bool,
|
|
278
|
+
selectSearchAll: _propTypes["default"].bool
|
|
254
279
|
};
|
|
255
280
|
var _default = VtxSelect;
|
|
256
281
|
exports["default"] = _default;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["VtxSelect","forwardRef","props","ref","useState","popWidth","setPopWidth","elRef","useRef","elId","Date","now","value","mode","size","onChange","maxTagCount","maxTagTextLength","maxTagPlaceholder","showAll","selectStyle","selectAll","defaultBindBodyToPopupContainer","useEffect","timer","setInterval","_width","current","clientWidth","clearInterval","newChildren","children","Array","isArray","getContent","child","forEach","item","key","length","map","index","name","getChildren","margin","e","preventDefault","valueClone","splice","options","filter","ite","includes","substring","Empty","PRESENTED_IMAGE_SIMPLE","newProps","showSearch","optionFilterProp","placeholder","allowClear","dropdownRender","menu","valueLength","target","checked","keys","classnames","style","paddingRight","triggerNode","document","body","width","isObject","Option","Select","OptGroup","propTypes","PropTypes","oneOfType","string","array","number","object","func","bool","node"],"sources":["vtx-select/index.jsx"],"sourcesContent":["import React, { useState, useEffect, useRef, forwardRef } from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport classnames from 'classnames';\r\nimport Select from 'antd/lib/select';\r\nimport Tag from 'antd/lib/tag';\r\nimport Button from 'antd/lib/button';\r\nimport Empty from 'antd/lib/empty';\r\nimport Popover from 'antd/lib/popover';\r\nimport Tooltip from 'antd/lib/tooltip';\r\nimport Checkbox from 'antd/lib/checkbox';\r\nimport Divider from 'antd/lib/divider';\r\nimport MoreOutlined from '@ant-design/icons/MoreOutlined';\r\nimport isObject from '../_util/isObject';\r\n\r\nconst VtxSelect = forwardRef((props, ref) => {\r\n const [popWidth, setPopWidth] = useState(0);\r\n const elRef = useRef();\r\n const elId = useRef(`vtx-select-${Date.now()}`);\r\n\r\n const {\r\n value,\r\n mode,\r\n size = 'default', //同步button大小\r\n onChange,\r\n maxTagCount = 2,\r\n maxTagTextLength = 5,\r\n maxTagPlaceholder = '...',\r\n showAll = true, //是否显示全部选项\r\n selectStyle,\r\n selectAll = true,\r\n defaultBindBodyToPopupContainer = true,\r\n } = props;\r\n\r\n useEffect(() => {\r\n if(mode === 'multiple') {\r\n const timer = setInterval(() => {\r\n const _width = elRef.current?.clientWidth;\r\n if(_width > 0) {\r\n setPopWidth(_width);\r\n clearInterval(timer);\r\n }\r\n }, 1000)\r\n return () => clearInterval(timer);\r\n }\r\n }, []);\r\n\r\n const newChildren = props.children\r\n ? Array.isArray(props.children)\r\n ? props.children\r\n : [props.children]\r\n : [];\r\n\r\n const getContent = () => {\r\n const child = {};\r\n newChildren.forEach(item => {\r\n child[item.key] = item?.props?.children;\r\n });\r\n return (\r\n <div className=\"vtx-all-list\">\r\n {Array.isArray(value) && value.length ? (\r\n value.map((item, index) => {\r\n const name = getChildren(child, item);\r\n return (\r\n <Tag\r\n style={{ margin: '4px' }}\r\n key={index}\r\n closable\r\n onClose={e => {\r\n e.preventDefault();\r\n const valueClone = [...value];\r\n valueClone.splice(index, 1);\r\n const options = newChildren.filter(ite =>\r\n valueClone.includes(ite.props.value),\r\n );\r\n onChange(valueClone, options);\r\n }}\r\n >\r\n <Tooltip title={name}>\r\n {name.length > maxTagTextLength\r\n ? `${name.substring(0, maxTagTextLength)}...`\r\n : name}\r\n </Tooltip>\r\n </Tag>\r\n );\r\n })\r\n ) : (\r\n <Empty image={Empty.PRESENTED_IMAGE_SIMPLE} />\r\n )}\r\n </div>\r\n );\r\n };\r\n\r\n let newProps = {\r\n showSearch: true,\r\n optionFilterProp: 'children',\r\n placeholder: '请选择',\r\n allowClear: true,\r\n ...props,\r\n };\r\n\r\n if (mode === 'multiple') {\r\n newProps = {\r\n ...newProps,\r\n maxTagCount: maxTagCount,\r\n maxTagTextLength: maxTagTextLength,\r\n maxTagPlaceholder: maxTagPlaceholder,\r\n };\r\n if (selectAll) {\r\n newProps = {\r\n ...newProps,\r\n dropdownRender: menu => {\r\n const valueLength = Array.isArray(value) && value.length ? value.length : 0;\r\n return (\r\n <div>\r\n <div\r\n className=\"vtx-multi-select-all\"\r\n onMouseDown={e => e.preventDefault()}\r\n >\r\n <Checkbox\r\n indeterminate={valueLength && valueLength < newChildren.length}\r\n checked={valueLength && valueLength === newChildren.length}\r\n onChange={e => {\r\n if (e.target.checked) {\r\n const keys = newChildren.map(item => item.key);\r\n onChange && onChange(keys, newChildren);\r\n } else {\r\n onChange && onChange([], []);\r\n }\r\n }}\r\n >\r\n 全选\r\n </Checkbox>\r\n </div>\r\n <Divider style={{ margin: '4px 0' }} />\r\n {menu}\r\n </div>\r\n );\r\n },\r\n };\r\n }\r\n }\r\n\r\n return (\r\n <div\r\n className={classnames({\r\n 'vtx-select': mode !== 'multiple',\r\n 'vtx-multi-select': mode == 'multiple' || mode == 'tags',\r\n })}\r\n id={elId.current}\r\n ref={elRef}\r\n style={{\r\n ...props.style,\r\n paddingRight: (mode == 'multiple' || mode == 'tags') && showAll ? 32 : 0,\r\n }}\r\n >\r\n <Select\r\n ref={ref}\r\n getPopupContainer={triggerNode => {\r\n return defaultBindBodyToPopupContainer ? document.body : triggerNode;\r\n }}\r\n {...newProps}\r\n style={{ width: '100%', ...selectStyle }}\r\n >\r\n {props.children}\r\n </Select>\r\n {(mode == 'multiple' || mode == 'tags') && showAll ? (\r\n <Popover\r\n content={getContent()}\r\n placement=\"bottomRight\"\r\n trigger=\"click\"\r\n overlayStyle={{ width: popWidth }}\r\n >\r\n <Button className=\"vtx-select-count\" icon={<MoreOutlined />} size={size} />\r\n </Popover>\r\n ) : null}\r\n </div>\r\n );\r\n});\r\n\r\nfunction getChildren(child = {}, value) {\r\n const key = isObject(value) ? value.key : value;\r\n return child[key] || '';\r\n}\r\n\r\nVtxSelect.Option = Select.Option;\r\nVtxSelect.OptGroup = Select.OptGroup;\r\n\r\nVtxSelect.propTypes = {\r\n value: PropTypes.oneOfType([\r\n PropTypes.string,\r\n PropTypes.array,\r\n PropTypes.number,\r\n PropTypes.object,\r\n ]),\r\n mode: PropTypes.string,\r\n size: PropTypes.string,\r\n style: PropTypes.object,\r\n selectStyle: PropTypes.object,\r\n onChange: PropTypes.func,\r\n defaultBindBodyToPopupContainer: PropTypes.bool,\r\n maxTagCount: PropTypes.number,\r\n maxTagTextLength: PropTypes.number,\r\n maxTagPlaceholder: PropTypes.oneOfType([PropTypes.func, PropTypes.node]),\r\n showAll: PropTypes.bool,\r\n children: PropTypes.node,\r\n selectAll: PropTypes.bool,\r\n};\r\n\r\nexport default VtxSelect;\r\n"],"mappings":";;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,IAAMA,SAAS,gBAAG,IAAAC,iBAAA,EAAW,UAACC,KAAD,EAAQC,GAAR,EAAgB;EACzC,gBAAgC,IAAAC,eAAA,EAAS,CAAT,CAAhC;EAAA;EAAA,IAAOC,QAAP;EAAA,IAAiBC,WAAjB;;EACA,IAAMC,KAAK,GAAG,IAAAC,aAAA,GAAd;EACA,IAAMC,IAAI,GAAG,IAAAD,aAAA,uBAAqBE,IAAI,CAACC,GAAL,EAArB,EAAb;EAEA,IACIC,KADJ,GAYIV,KAZJ,CACIU,KADJ;EAAA,IAEIC,IAFJ,GAYIX,KAZJ,CAEIW,IAFJ;EAAA,kBAYIX,KAZJ,CAGIY,IAHJ;EAAA,IAGIA,IAHJ,4BAGW,SAHX;EAAA,IAIIC,SAJJ,GAYIb,KAZJ,CAIIa,QAJJ;EAAA,yBAYIb,KAZJ,CAKIc,WALJ;EAAA,IAKIA,WALJ,mCAKkB,CALlB;EAAA,4BAYId,KAZJ,CAMIe,gBANJ;EAAA,IAMIA,gBANJ,sCAMuB,CANvB;EAAA,4BAYIf,KAZJ,CAOIgB,iBAPJ;EAAA,IAOIA,iBAPJ,sCAOwB,KAPxB;EAAA,qBAYIhB,KAZJ,CAQIiB,OARJ;EAAA,IAQIA,OARJ,+BAQc,IARd;EAAA,IASIC,WATJ,GAYIlB,KAZJ,CASIkB,WATJ;EAAA,uBAYIlB,KAZJ,CAUImB,SAVJ;EAAA,IAUIA,SAVJ,iCAUgB,IAVhB;EAAA,4BAYInB,KAZJ,CAWIoB,+BAXJ;EAAA,IAWIA,+BAXJ,sCAWsC,IAXtC;EAcA,IAAAC,gBAAA,EAAU,YAAM;IACZ,IAAGV,IAAI,KAAK,UAAZ,EAAwB;MACpB,IAAMW,KAAK,GAAGC,WAAW,CAAC,YAAM;QAAA;;QAC5B,IAAMC,MAAM,qBAAGnB,KAAK,CAACoB,OAAT,mDAAG,eAAeC,WAA9B;;QACA,IAAGF,MAAM,GAAG,CAAZ,EAAe;UACXpB,WAAW,CAACoB,MAAD,CAAX;UACAG,aAAa,CAACL,KAAD,CAAb;QACH;MACJ,CANwB,EAMtB,IANsB,CAAzB;MAOA,OAAO;QAAA,OAAMK,aAAa,CAACL,KAAD,CAAnB;MAAA,CAAP;IACH;EACJ,CAXD,EAWG,EAXH;EAaA,IAAMM,WAAW,GAAG5B,KAAK,CAAC6B,QAAN,GACdC,KAAK,CAACC,OAAN,CAAc/B,KAAK,CAAC6B,QAApB,IACI7B,KAAK,CAAC6B,QADV,GAEI,CAAC7B,KAAK,CAAC6B,QAAP,CAHU,GAId,EAJN;;EAMA,IAAMG,UAAU,GAAG,SAAbA,UAAa,GAAM;IACrB,IAAMC,KAAK,GAAG,EAAd;IACAL,WAAW,CAACM,OAAZ,CAAoB,UAAAC,IAAI,EAAI;MAAA;;MACxBF,KAAK,CAACE,IAAI,CAACC,GAAN,CAAL,GAAkBD,IAAlB,aAAkBA,IAAlB,sCAAkBA,IAAI,CAAEnC,KAAxB,gDAAkB,YAAa6B,QAA/B;IACH,CAFD;IAGA,oBACI;MAAK,SAAS,EAAC;IAAf,GACKC,KAAK,CAACC,OAAN,CAAcrB,KAAd,KAAwBA,KAAK,CAAC2B,MAA9B,GACG3B,KAAK,CAAC4B,GAAN,CAAU,UAACH,IAAD,EAAOI,KAAP,EAAiB;MACvB,IAAMC,IAAI,GAAGC,WAAW,CAACR,KAAD,EAAQE,IAAR,CAAxB;MACA,oBACI,gCAAC,eAAD;QACI,KAAK,EAAE;UAAEO,MAAM,EAAE;QAAV,CADX;QAEI,GAAG,EAAEH,KAFT;QAGI,QAAQ,MAHZ;QAII,OAAO,EAAE,iBAAAI,CAAC,EAAI;UACVA,CAAC,CAACC,cAAF;;UACA,IAAMC,UAAU,sBAAOnC,KAAP,CAAhB;;UACAmC,UAAU,CAACC,MAAX,CAAkBP,KAAlB,EAAyB,CAAzB;UACA,IAAMQ,OAAO,GAAGnB,WAAW,CAACoB,MAAZ,CAAmB,UAAAC,GAAG;YAAA,OAClCJ,UAAU,CAACK,QAAX,CAAoBD,GAAG,CAACjD,KAAJ,CAAUU,KAA9B,CADkC;UAAA,CAAtB,CAAhB;;UAGAG,SAAQ,CAACgC,UAAD,EAAaE,OAAb,CAAR;QACH;MAZL,gBAcI,gCAAC,mBAAD;QAAS,KAAK,EAAEP;MAAhB,GACKA,IAAI,CAACH,MAAL,GAActB,gBAAd,aACQyB,IAAI,CAACW,SAAL,CAAe,CAAf,EAAkBpC,gBAAlB,CADR,WAEKyB,IAHV,CAdJ,CADJ;IAsBH,CAxBD,CADH,gBA2BG,gCAAC,iBAAD;MAAO,KAAK,EAAEY,iBAAA,CAAMC;IAApB,EA5BR,CADJ;EAiCH,CAtCD;;EAwCA,IAAIC,QAAQ;IACRC,UAAU,EAAE,IADJ;IAERC,gBAAgB,EAAE,UAFV;IAGRC,WAAW,EAAE,KAHL;IAIRC,UAAU,EAAE;EAJJ,GAKL1D,KALK,CAAZ;;EAQA,IAAIW,IAAI,KAAK,UAAb,EAAyB;IACrB2C,QAAQ,mCACDA,QADC;MAEJxC,WAAW,EAAEA,WAFT;MAGJC,gBAAgB,EAAEA,gBAHd;MAIJC,iBAAiB,EAAEA;IAJf,EAAR;;IAMA,IAAIG,SAAJ,EAAe;MACXmC,QAAQ,mCACDA,QADC;QAEJK,cAAc,EAAE,wBAAAC,IAAI,EAAI;UACpB,IAAMC,WAAW,GAAG/B,KAAK,CAACC,OAAN,CAAcrB,KAAd,KAAwBA,KAAK,CAAC2B,MAA9B,GAAuC3B,KAAK,CAAC2B,MAA7C,GAAsD,CAA1E;UACA,oBACI,0DACI;YACI,SAAS,EAAC,sBADd;YAEI,WAAW,EAAE,qBAAAM,CAAC;cAAA,OAAIA,CAAC,CAACC,cAAF,EAAJ;YAAA;UAFlB,gBAII,gCAAC,oBAAD;YACI,aAAa,EAAEiB,WAAW,IAAIA,WAAW,GAAGjC,WAAW,CAACS,MAD5D;YAEI,OAAO,EAAEwB,WAAW,IAAIA,WAAW,KAAKjC,WAAW,CAACS,MAFxD;YAGI,QAAQ,EAAE,kBAAAM,CAAC,EAAI;cACX,IAAIA,CAAC,CAACmB,MAAF,CAASC,OAAb,EAAsB;gBAClB,IAAMC,IAAI,GAAGpC,WAAW,CAACU,GAAZ,CAAgB,UAAAH,IAAI;kBAAA,OAAIA,IAAI,CAACC,GAAT;gBAAA,CAApB,CAAb;gBACAvB,SAAQ,IAAIA,SAAQ,CAACmD,IAAD,EAAOpC,WAAP,CAApB;cACH,CAHD,MAGO;gBACHf,SAAQ,IAAIA,SAAQ,CAAC,EAAD,EAAK,EAAL,CAApB;cACH;YACJ;UAVL,kBAJJ,CADJ,eAoBI,gCAAC,mBAAD;YAAS,KAAK,EAAE;cAAE6B,MAAM,EAAE;YAAV;UAAhB,EApBJ,EAqBKkB,IArBL,CADJ;QAyBH;MA7BG,EAAR;IA+BH;EACJ;;EAED,oBACI;IACI,SAAS,EAAE,IAAAK,sBAAA,EAAW;MAClB,cAActD,IAAI,KAAK,UADL;MAElB,oBAAoBA,IAAI,IAAI,UAAR,IAAsBA,IAAI,IAAI;IAFhC,CAAX,CADf;IAKI,EAAE,EAAEJ,IAAI,CAACkB,OALb;IAMI,GAAG,EAAEpB,KANT;IAOI,KAAK,kCACEL,KAAK,CAACkE,KADR;MAEDC,YAAY,EAAE,CAACxD,IAAI,IAAI,UAAR,IAAsBA,IAAI,IAAI,MAA/B,KAA0CM,OAA1C,GAAoD,EAApD,GAAyD;IAFtE;EAPT,gBAYI,gCAAC,kBAAD;IACI,GAAG,EAAEhB,GADT;IAEI,iBAAiB,EAAE,2BAAAmE,WAAW,EAAI;MAC9B,OAAOhD,+BAA+B,GAAGiD,QAAQ,CAACC,IAAZ,GAAmBF,WAAzD;IACH;EAJL,GAKQd,QALR;IAMI,KAAK;MAAIiB,KAAK,EAAE;IAAX,GAAsBrD,WAAtB;EANT,IAQKlB,KAAK,CAAC6B,QARX,CAZJ,EAsBK,CAAClB,IAAI,IAAI,UAAR,IAAsBA,IAAI,IAAI,MAA/B,KAA0CM,OAA1C,gBACG,gCAAC,mBAAD;IACI,OAAO,EAAEe,UAAU,EADvB;IAEI,SAAS,EAAC,aAFd;IAGI,OAAO,EAAC,OAHZ;IAII,YAAY,EAAE;MAAEuC,KAAK,EAAEpE;IAAT;EAJlB,gBAMI,gCAAC,kBAAD;IAAQ,SAAS,EAAC,kBAAlB;IAAqC,IAAI,eAAE,gCAAC,wBAAD,OAA3C;IAA6D,IAAI,EAAES;EAAnE,EANJ,CADH,GASG,IA/BR,CADJ;AAmCH,CAnKiB,CAAlB;;AAqKA,SAAS6B,WAAT,GAAwC;EAAA,IAAnBR,KAAmB,uEAAX,EAAW;EAAA,IAAPvB,KAAO;EACpC,IAAM0B,GAAG,GAAG,IAAAoC,oBAAA,EAAS9D,KAAT,IAAkBA,KAAK,CAAC0B,GAAxB,GAA8B1B,KAA1C;EACA,OAAOuB,KAAK,CAACG,GAAD,CAAL,IAAc,EAArB;AACH;;AAEDtC,SAAS,CAAC2E,MAAV,GAAmBC,kBAAA,CAAOD,MAA1B;AACA3E,SAAS,CAAC6E,QAAV,GAAqBD,kBAAA,CAAOC,QAA5B;AAEA7E,SAAS,CAAC8E,SAAV,GAAsB;EAClBlE,KAAK,EAAEmE,qBAAA,CAAUC,SAAV,CAAoB,CACvBD,qBAAA,CAAUE,MADa,EAEvBF,qBAAA,CAAUG,KAFa,EAGvBH,qBAAA,CAAUI,MAHa,EAIvBJ,qBAAA,CAAUK,MAJa,CAApB,CADW;EAOlBvE,IAAI,EAAEkE,qBAAA,CAAUE,MAPE;EAQlBnE,IAAI,EAAEiE,qBAAA,CAAUE,MARE;EASlBb,KAAK,EAAEW,qBAAA,CAAUK,MATC;EAUlBhE,WAAW,EAAE2D,qBAAA,CAAUK,MAVL;EAWlBrE,QAAQ,EAAEgE,qBAAA,CAAUM,IAXF;EAYlB/D,+BAA+B,EAAEyD,qBAAA,CAAUO,IAZzB;EAalBtE,WAAW,EAAE+D,qBAAA,CAAUI,MAbL;EAclBlE,gBAAgB,EAAE8D,qBAAA,CAAUI,MAdV;EAelBjE,iBAAiB,EAAE6D,qBAAA,CAAUC,SAAV,CAAoB,CAACD,qBAAA,CAAUM,IAAX,EAAiBN,qBAAA,CAAUQ,IAA3B,CAApB,CAfD;EAgBlBpE,OAAO,EAAE4D,qBAAA,CAAUO,IAhBD;EAiBlBvD,QAAQ,EAAEgD,qBAAA,CAAUQ,IAjBF;EAkBlBlE,SAAS,EAAE0D,qBAAA,CAAUO;AAlBH,CAAtB;eAqBetF,S"}
|
|
1
|
+
{"version":3,"file":"index.js","names":["VtxSelect","forwardRef","props","ref","useState","popWidth","setPopWidth","elRef","useRef","elId","Date","now","searchValue","setSearchValue","value","mode","size","onChange","maxTagCount","maxTagTextLength","maxTagPlaceholder","showAll","selectStyle","selectAll","selectSearchAll","defaultBindBodyToPopupContainer","useEffect","timer","setInterval","_width","current","clientWidth","clearInterval","newChildren","children","Array","isArray","getContent","child","forEach","item","key","length","map","index","name","getChildren","margin","e","preventDefault","valueClone","splice","options","filter","ite","includes","substring","Empty","PRESENTED_IMAGE_SIMPLE","newProps","showSearch","optionFilterProp","placeholder","allowClear","onSearch","String","toLowerCase","onBlur","dropdownRender","menu","valueLength","target","checked","tempChildren","indexOf","keys","classnames","style","paddingRight","triggerNode","document","body","width","isObject","Option","Select","OptGroup","propTypes","PropTypes","oneOfType","string","array","number","object","func","bool","node"],"sources":["vtx-select/index.jsx"],"sourcesContent":["import React, { useState, useEffect, useRef, forwardRef } from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport classnames from 'classnames';\r\nimport Select from 'antd/lib/select';\r\nimport Tag from 'antd/lib/tag';\r\nimport Button from 'antd/lib/button';\r\nimport Empty from 'antd/lib/empty';\r\nimport Popover from 'antd/lib/popover';\r\nimport Tooltip from 'antd/lib/tooltip';\r\nimport Checkbox from 'antd/lib/checkbox';\r\nimport Divider from 'antd/lib/divider';\r\nimport MoreOutlined from '@ant-design/icons/MoreOutlined';\r\nimport isObject from '../_util/isObject';\r\n\r\nconst VtxSelect = forwardRef((props, ref) => {\r\n const [popWidth, setPopWidth] = useState(0);\r\n const elRef = useRef();\r\n const elId = useRef(`vtx-select-${Date.now()}`);\r\n const [searchValue,setSearchValue] = useState('');\r\n\r\n const {\r\n value,\r\n mode,\r\n size = 'default', //同步button大小\r\n onChange,\r\n maxTagCount = 2,\r\n maxTagTextLength = 5,\r\n maxTagPlaceholder = '...',\r\n showAll = true, //是否显示全部选项\r\n selectStyle,\r\n selectAll = true,\r\n selectSearchAll = true,\r\n defaultBindBodyToPopupContainer = true,\r\n } = props;\r\n\r\n useEffect(() => {\r\n if(mode === 'multiple') {\r\n const timer = setInterval(() => {\r\n const _width = elRef.current?.clientWidth;\r\n if(_width > 0) {\r\n setPopWidth(_width);\r\n clearInterval(timer);\r\n }\r\n }, 1000)\r\n return () => clearInterval(timer);\r\n }\r\n }, []);\r\n\r\n const newChildren = props.children\r\n ? Array.isArray(props.children)\r\n ? props.children\r\n : [props.children]\r\n : [];\r\n\r\n const getContent = () => {\r\n const child = {};\r\n newChildren.forEach(item => {\r\n child[item.key] = item?.props?.children;\r\n });\r\n return (\r\n <div className=\"vtx-all-list\">\r\n {Array.isArray(value) && value.length ? (\r\n value.map((item, index) => {\r\n const name = getChildren(child, item);\r\n return (\r\n <Tag\r\n style={{ margin: '4px' }}\r\n key={index}\r\n closable\r\n onClose={e => {\r\n e.preventDefault();\r\n const valueClone = [...value];\r\n valueClone.splice(index, 1);\r\n const options = newChildren.filter(ite =>\r\n valueClone.includes(ite.props.value),\r\n );\r\n onChange(valueClone, options);\r\n }}\r\n >\r\n <Tooltip title={name}>\r\n {name.length > maxTagTextLength\r\n ? `${name.substring(0, maxTagTextLength)}...`\r\n : name}\r\n </Tooltip>\r\n </Tag>\r\n );\r\n })\r\n ) : (\r\n <Empty image={Empty.PRESENTED_IMAGE_SIMPLE} />\r\n )}\r\n </div>\r\n );\r\n };\r\n\r\n let newProps = {\r\n showSearch: true,\r\n optionFilterProp: 'children',\r\n placeholder: '请选择',\r\n allowClear: true,\r\n ...props,\r\n onSearch: value=>{\r\n setSearchValue(value?String(value).toLowerCase():'');\r\n props.onSearch && props.onSearch(value);\r\n },\r\n onBlur: e=>{\r\n setSearchValue('');\r\n props.onBlur && props.onBlur(e);\r\n }\r\n };\r\n\r\n if (mode === 'multiple') {\r\n newProps = {\r\n ...newProps,\r\n maxTagCount: maxTagCount,\r\n maxTagTextLength: maxTagTextLength,\r\n maxTagPlaceholder: maxTagPlaceholder,\r\n };\r\n if (selectAll) {\r\n newProps = {\r\n ...newProps,\r\n dropdownRender: menu => {\r\n const valueLength = Array.isArray(value) && value.length ? value.length : 0;\r\n return (\r\n <div>\r\n <div\r\n className=\"vtx-multi-select-all\"\r\n onMouseDown={e => e.preventDefault()}\r\n >\r\n <Checkbox\r\n indeterminate={valueLength && valueLength < newChildren.length}\r\n checked={valueLength && valueLength === newChildren.length}\r\n onChange={e => {\r\n if (e.target.checked) {\r\n let tempChildren = newChildren.filter(item=>{\r\n if(selectSearchAll && searchValue){\r\n return String(item.props.children).toLowerCase().indexOf(searchValue)>-1;\r\n }\r\n return true;\r\n })\r\n const keys = tempChildren.map(item => item.key);\r\n onChange && onChange(keys, tempChildren);\r\n } else {\r\n onChange && onChange([], []);\r\n }\r\n }}\r\n >\r\n 全选\r\n </Checkbox>\r\n </div>\r\n <Divider style={{ margin: '4px 0' }} />\r\n {menu}\r\n </div>\r\n );\r\n },\r\n };\r\n }\r\n }\r\n\r\n return (\r\n <div\r\n className={classnames({\r\n 'vtx-select': mode !== 'multiple',\r\n 'vtx-multi-select': mode == 'multiple' || mode == 'tags',\r\n })}\r\n id={elId.current}\r\n ref={elRef}\r\n style={{\r\n ...props.style,\r\n paddingRight: (mode == 'multiple' || mode == 'tags') && showAll ? 32 : 0,\r\n }}\r\n >\r\n <Select\r\n ref={ref}\r\n getPopupContainer={triggerNode => {\r\n return defaultBindBodyToPopupContainer ? document.body : triggerNode;\r\n }}\r\n {...newProps}\r\n style={{ width: '100%', ...selectStyle }}\r\n >\r\n {props.children}\r\n </Select>\r\n {(mode == 'multiple' || mode == 'tags') && showAll ? (\r\n <Popover\r\n content={getContent()}\r\n placement=\"bottomRight\"\r\n trigger=\"click\"\r\n overlayStyle={{ width: popWidth }}\r\n >\r\n <Button className=\"vtx-select-count\" icon={<MoreOutlined />} size={size} />\r\n </Popover>\r\n ) : null}\r\n </div>\r\n );\r\n});\r\n\r\nfunction getChildren(child = {}, value) {\r\n const key = isObject(value) ? value.key : value;\r\n return child[key] || '';\r\n}\r\n\r\nVtxSelect.Option = Select.Option;\r\nVtxSelect.OptGroup = Select.OptGroup;\r\n\r\nVtxSelect.propTypes = {\r\n value: PropTypes.oneOfType([\r\n PropTypes.string,\r\n PropTypes.array,\r\n PropTypes.number,\r\n PropTypes.object,\r\n ]),\r\n mode: PropTypes.string,\r\n size: PropTypes.string,\r\n style: PropTypes.object,\r\n selectStyle: PropTypes.object,\r\n onChange: PropTypes.func,\r\n defaultBindBodyToPopupContainer: PropTypes.bool,\r\n maxTagCount: PropTypes.number,\r\n maxTagTextLength: PropTypes.number,\r\n maxTagPlaceholder: PropTypes.oneOfType([PropTypes.func, PropTypes.node]),\r\n showAll: PropTypes.bool,\r\n children: PropTypes.node,\r\n selectAll: PropTypes.bool,\r\n selectSearchAll: PropTypes.bool,\r\n};\r\n\r\nexport default VtxSelect;\r\n"],"mappings":"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"}
|