vue-devui 1.0.0-beta.13 → 1.0.0-beta.14
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/auto-complete/index.d.ts +7 -0
- package/auto-complete/index.es.js +1121 -0
- package/auto-complete/index.umd.js +1 -0
- package/auto-complete/package.json +7 -0
- package/auto-complete/style.css +1 -0
- package/form/index.es.js +41 -12
- package/form/index.umd.js +1 -1
- package/nuxt/components/AutoComplete.js +3 -0
- package/package.json +1 -1
- package/statistic/index.es.js +2 -2
- package/statistic/index.umd.js +1 -1
- package/statistic/style.css +1 -1
- package/style.css +1 -1
- package/transfer/index.es.js +293 -52
- package/transfer/index.umd.js +1 -1
- package/transfer/style.css +1 -1
- package/tree/index.es.js +6 -5
- package/tree/index.umd.js +1 -1
- package/tree-select/index.es.js +129 -34
- package/tree-select/index.umd.js +1 -1
- package/tree-select/style.css +1 -1
- package/vue-devui.es.js +1628 -760
- package/vue-devui.umd.js +11 -11
package/vue-devui.es.js
CHANGED
|
@@ -33,7 +33,7 @@ var __publicField = (obj, key, value) => {
|
|
|
33
33
|
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
34
34
|
return value;
|
|
35
35
|
};
|
|
36
|
-
import { createVNode, getCurrentInstance, defineComponent as defineComponent$1, toRefs, inject, computed, Fragment, mergeProps, resolveComponent, createTextVNode, provide, onMounted, watch, ref, Transition, withDirectives, vShow,
|
|
36
|
+
import { createVNode, getCurrentInstance, defineComponent as defineComponent$1, toRefs, inject, computed, Fragment, mergeProps, resolveComponent, createTextVNode, provide, onMounted, watch, ref, Transition, withDirectives, vShow, nextTick as nextTick$1, h, render, resolveDirective, Teleport, renderSlot, isVNode, onUnmounted, reactive, toRef, isRef as isRef$1, onBeforeUnmount, Comment as Comment$1, onUpdated, onBeforeMount, readonly, unref as unref$1, createApp, useSlots, shallowRef } from "vue";
|
|
37
37
|
const accordionProps = {
|
|
38
38
|
data: {
|
|
39
39
|
type: Array,
|
|
@@ -958,6 +958,1121 @@ var AnchorInstall = {
|
|
|
958
958
|
app.use(Anchor);
|
|
959
959
|
}
|
|
960
960
|
};
|
|
961
|
+
const defaultFormatter = (item2) => item2 ? item2.label || item2.toString() : "";
|
|
962
|
+
const defaultValueParse = (item2) => item2;
|
|
963
|
+
const autoCompleteProps = {
|
|
964
|
+
modelValue: {
|
|
965
|
+
type: String,
|
|
966
|
+
default: ""
|
|
967
|
+
},
|
|
968
|
+
source: {
|
|
969
|
+
type: Array,
|
|
970
|
+
default: null
|
|
971
|
+
},
|
|
972
|
+
allowEmptyValueSearch: {
|
|
973
|
+
type: Boolean,
|
|
974
|
+
default: false
|
|
975
|
+
},
|
|
976
|
+
appendToBody: {
|
|
977
|
+
type: Boolean,
|
|
978
|
+
default: false
|
|
979
|
+
},
|
|
980
|
+
appendToBodyDirections: {
|
|
981
|
+
type: Object,
|
|
982
|
+
default: () => ({
|
|
983
|
+
originX: "left",
|
|
984
|
+
originY: "bottom",
|
|
985
|
+
overlayX: "left",
|
|
986
|
+
overlayY: "top"
|
|
987
|
+
})
|
|
988
|
+
},
|
|
989
|
+
disabled: {
|
|
990
|
+
type: Boolean,
|
|
991
|
+
default: false
|
|
992
|
+
},
|
|
993
|
+
delay: {
|
|
994
|
+
type: Number,
|
|
995
|
+
default: 300
|
|
996
|
+
},
|
|
997
|
+
disabledKey: {
|
|
998
|
+
type: String,
|
|
999
|
+
default: null
|
|
1000
|
+
},
|
|
1001
|
+
formatter: {
|
|
1002
|
+
type: Function,
|
|
1003
|
+
default: defaultFormatter
|
|
1004
|
+
},
|
|
1005
|
+
isSearching: {
|
|
1006
|
+
type: Boolean,
|
|
1007
|
+
default: false
|
|
1008
|
+
},
|
|
1009
|
+
sceneType: {
|
|
1010
|
+
type: String,
|
|
1011
|
+
default: null
|
|
1012
|
+
},
|
|
1013
|
+
searchFn: {
|
|
1014
|
+
type: Function,
|
|
1015
|
+
default: null
|
|
1016
|
+
},
|
|
1017
|
+
tipsText: {
|
|
1018
|
+
type: String,
|
|
1019
|
+
default: "\u6700\u8FD1\u8F93\u5165"
|
|
1020
|
+
},
|
|
1021
|
+
latestSource: {
|
|
1022
|
+
type: Array,
|
|
1023
|
+
default: null
|
|
1024
|
+
},
|
|
1025
|
+
valueParser: {
|
|
1026
|
+
type: Function,
|
|
1027
|
+
default: defaultValueParse
|
|
1028
|
+
},
|
|
1029
|
+
enableLazyLoad: {
|
|
1030
|
+
type: Boolean,
|
|
1031
|
+
default: false
|
|
1032
|
+
},
|
|
1033
|
+
dAutoCompleteWidth: {
|
|
1034
|
+
type: Number,
|
|
1035
|
+
default: null
|
|
1036
|
+
},
|
|
1037
|
+
showAnimation: {
|
|
1038
|
+
type: Boolean,
|
|
1039
|
+
default: true
|
|
1040
|
+
},
|
|
1041
|
+
maxHeight: {
|
|
1042
|
+
type: Number,
|
|
1043
|
+
default: 300
|
|
1044
|
+
},
|
|
1045
|
+
transInputFocusEmit: {
|
|
1046
|
+
type: Function,
|
|
1047
|
+
default: null
|
|
1048
|
+
},
|
|
1049
|
+
selectValue: {
|
|
1050
|
+
type: Function,
|
|
1051
|
+
default: null
|
|
1052
|
+
},
|
|
1053
|
+
loadMore: {
|
|
1054
|
+
type: Function,
|
|
1055
|
+
default: null
|
|
1056
|
+
}
|
|
1057
|
+
};
|
|
1058
|
+
const DropdownPropsKey = Symbol("DropdownPropsKey");
|
|
1059
|
+
function useCustomTemplate(ctx2, modelValue) {
|
|
1060
|
+
const itemTemplate = (item2, index2) => {
|
|
1061
|
+
const arr = { item: item2, index: index2 };
|
|
1062
|
+
if (ctx2.slots.itemTemplate) {
|
|
1063
|
+
return ctx2.slots.itemTemplate(arr);
|
|
1064
|
+
}
|
|
1065
|
+
return null;
|
|
1066
|
+
};
|
|
1067
|
+
const noResultItemTemplate = () => {
|
|
1068
|
+
if (ctx2.slots.noResultItemTemplate) {
|
|
1069
|
+
return ctx2.slots.noResultItemTemplate(modelValue.value);
|
|
1070
|
+
}
|
|
1071
|
+
return null;
|
|
1072
|
+
};
|
|
1073
|
+
const searchingTemplate = () => {
|
|
1074
|
+
if (ctx2.slots.searchingTemplate) {
|
|
1075
|
+
return ctx2.slots.searchingTemplate(modelValue.value);
|
|
1076
|
+
}
|
|
1077
|
+
return null;
|
|
1078
|
+
};
|
|
1079
|
+
const customRenderSolts = () => {
|
|
1080
|
+
const slots = {};
|
|
1081
|
+
if (ctx2.slots.itemTemplate) {
|
|
1082
|
+
slots["itemTemplate"] = itemTemplate;
|
|
1083
|
+
}
|
|
1084
|
+
if (ctx2.slots.noResultItemTemplate) {
|
|
1085
|
+
slots["noResultItemTemplate"] = noResultItemTemplate;
|
|
1086
|
+
}
|
|
1087
|
+
if (ctx2.slots.searchingTemplate) {
|
|
1088
|
+
slots["searchingTemplate"] = searchingTemplate;
|
|
1089
|
+
}
|
|
1090
|
+
return slots;
|
|
1091
|
+
};
|
|
1092
|
+
return { customRenderSolts };
|
|
1093
|
+
}
|
|
1094
|
+
function useSearchFn(ctx2, allowEmptyValueSearch, source, searchFn, formatter) {
|
|
1095
|
+
const searchList = ref([]);
|
|
1096
|
+
const showNoResultItemTemplate = ref(false);
|
|
1097
|
+
const handleSearch = async (term, enableLazyLoad) => {
|
|
1098
|
+
if (term == "" && !allowEmptyValueSearch.value) {
|
|
1099
|
+
searchList.value = [];
|
|
1100
|
+
showNoResultItemTemplate.value = false;
|
|
1101
|
+
return;
|
|
1102
|
+
}
|
|
1103
|
+
let arr = [];
|
|
1104
|
+
term = term.toLowerCase();
|
|
1105
|
+
if (enableLazyLoad) {
|
|
1106
|
+
arr = source.value;
|
|
1107
|
+
} else if (!searchFn.value) {
|
|
1108
|
+
source.value.forEach((item2) => {
|
|
1109
|
+
let cur = formatter.value(item2);
|
|
1110
|
+
cur = cur.toLowerCase();
|
|
1111
|
+
if (cur.startsWith(term)) {
|
|
1112
|
+
arr.push(item2);
|
|
1113
|
+
}
|
|
1114
|
+
});
|
|
1115
|
+
} else {
|
|
1116
|
+
arr = await searchFn.value(term);
|
|
1117
|
+
}
|
|
1118
|
+
searchList.value = arr;
|
|
1119
|
+
if (searchList.value.length == 0) {
|
|
1120
|
+
showNoResultItemTemplate.value = true;
|
|
1121
|
+
} else {
|
|
1122
|
+
showNoResultItemTemplate.value = false;
|
|
1123
|
+
}
|
|
1124
|
+
};
|
|
1125
|
+
const recentlyFocus = (latestSource) => {
|
|
1126
|
+
if (latestSource) {
|
|
1127
|
+
searchList.value = latestSource;
|
|
1128
|
+
}
|
|
1129
|
+
};
|
|
1130
|
+
return {
|
|
1131
|
+
handleSearch,
|
|
1132
|
+
recentlyFocus,
|
|
1133
|
+
searchList,
|
|
1134
|
+
showNoResultItemTemplate
|
|
1135
|
+
};
|
|
1136
|
+
}
|
|
1137
|
+
function useInputHandle(ctx2, searchList, showNoResultItemTemplate, modelValue, disabled, delay, handleSearch, transInputFocusEmit, recentlyFocus, latestSource) {
|
|
1138
|
+
const visible = ref(false);
|
|
1139
|
+
const inputRef = ref();
|
|
1140
|
+
const searchStatus = ref(false);
|
|
1141
|
+
const debounce2 = (cb, time) => {
|
|
1142
|
+
let timer;
|
|
1143
|
+
return (...args) => {
|
|
1144
|
+
if (timer) {
|
|
1145
|
+
clearTimeout(timer);
|
|
1146
|
+
}
|
|
1147
|
+
timer = setTimeout(async () => {
|
|
1148
|
+
searchStatus.value = true;
|
|
1149
|
+
await cb(...args);
|
|
1150
|
+
searchStatus.value = false;
|
|
1151
|
+
}, time);
|
|
1152
|
+
};
|
|
1153
|
+
};
|
|
1154
|
+
const onInputCb = async (value) => {
|
|
1155
|
+
await handleSearch(value);
|
|
1156
|
+
visible.value = true;
|
|
1157
|
+
};
|
|
1158
|
+
const onInputDebounce = debounce2(onInputCb, delay.value);
|
|
1159
|
+
const onInput = (e) => {
|
|
1160
|
+
const inp = e.target;
|
|
1161
|
+
searchStatus.value = false;
|
|
1162
|
+
showNoResultItemTemplate.value = false;
|
|
1163
|
+
ctx2.emit("update:modelValue", inp.value);
|
|
1164
|
+
onInputDebounce(inp.value);
|
|
1165
|
+
};
|
|
1166
|
+
const onFocus = () => {
|
|
1167
|
+
handleSearch(modelValue.value);
|
|
1168
|
+
recentlyFocus(latestSource.value);
|
|
1169
|
+
transInputFocusEmit.value && transInputFocusEmit.value();
|
|
1170
|
+
};
|
|
1171
|
+
const handleClose = () => {
|
|
1172
|
+
visible.value = false;
|
|
1173
|
+
searchStatus.value = false;
|
|
1174
|
+
showNoResultItemTemplate.value = false;
|
|
1175
|
+
};
|
|
1176
|
+
const toggleMenu = () => {
|
|
1177
|
+
if (!disabled.value) {
|
|
1178
|
+
if (visible.value) {
|
|
1179
|
+
handleClose();
|
|
1180
|
+
} else {
|
|
1181
|
+
visible.value = true;
|
|
1182
|
+
if (ctx2.slots.noResultItemTemplate && searchList.value.length == 0 && modelValue.value.trim() != "") {
|
|
1183
|
+
showNoResultItemTemplate.value = true;
|
|
1184
|
+
}
|
|
1185
|
+
}
|
|
1186
|
+
}
|
|
1187
|
+
};
|
|
1188
|
+
return {
|
|
1189
|
+
handleClose,
|
|
1190
|
+
toggleMenu,
|
|
1191
|
+
onInput,
|
|
1192
|
+
onFocus,
|
|
1193
|
+
inputRef,
|
|
1194
|
+
visible,
|
|
1195
|
+
searchStatus
|
|
1196
|
+
};
|
|
1197
|
+
}
|
|
1198
|
+
function useSelectHandle(ctx2, searchList, selectValue, handleSearch, formatter, handleClose) {
|
|
1199
|
+
const selectedIndex = ref(0);
|
|
1200
|
+
const getListIndex = (item2) => {
|
|
1201
|
+
if (searchList.value.length == 0) {
|
|
1202
|
+
return 0;
|
|
1203
|
+
}
|
|
1204
|
+
const ind = searchList.value.indexOf(item2);
|
|
1205
|
+
return ind == -1 ? 0 : ind;
|
|
1206
|
+
};
|
|
1207
|
+
const selectOptionClick = async (item2) => {
|
|
1208
|
+
const cur = formatter.value(item2);
|
|
1209
|
+
ctx2.emit("update:modelValue", cur);
|
|
1210
|
+
handleClose();
|
|
1211
|
+
await handleSearch(cur);
|
|
1212
|
+
selectedIndex.value = getListIndex(cur);
|
|
1213
|
+
selectValue.value && selectValue.value();
|
|
1214
|
+
};
|
|
1215
|
+
return {
|
|
1216
|
+
selectedIndex,
|
|
1217
|
+
selectOptionClick
|
|
1218
|
+
};
|
|
1219
|
+
}
|
|
1220
|
+
function useLazyHandle(props, ctx2, handleSearch) {
|
|
1221
|
+
const showLoading = ref(false);
|
|
1222
|
+
const dropDownRef = ref();
|
|
1223
|
+
const loadMore = () => {
|
|
1224
|
+
if (!props.enableLazyLoad && showLoading)
|
|
1225
|
+
return;
|
|
1226
|
+
const dropDownValue = dropDownRef.value;
|
|
1227
|
+
const height = dropDownValue.scrollHeight;
|
|
1228
|
+
const scrollTop = dropDownValue.clientHeight + dropDownValue.scrollTop;
|
|
1229
|
+
if (scrollTop >= height && scrollTop >= props.maxHeight) {
|
|
1230
|
+
props.loadMore();
|
|
1231
|
+
showLoading.value = true;
|
|
1232
|
+
}
|
|
1233
|
+
};
|
|
1234
|
+
ctx2.expose({ loadFinish });
|
|
1235
|
+
async function loadFinish() {
|
|
1236
|
+
await handleSearch(props.modelValue, props.enableLazyLoad);
|
|
1237
|
+
showLoading.value = false;
|
|
1238
|
+
}
|
|
1239
|
+
return {
|
|
1240
|
+
showLoading,
|
|
1241
|
+
dropDownRef,
|
|
1242
|
+
loadMore
|
|
1243
|
+
};
|
|
1244
|
+
}
|
|
1245
|
+
function useKeyBoardHandle(dropDownRef, visible, searchList, selectedIndex, searchStatus, showNoResultItemTemplate, selectOptionClick, handleClose) {
|
|
1246
|
+
var _a;
|
|
1247
|
+
const hoverIndex = ref((_a = selectedIndex.value) != null ? _a : 0);
|
|
1248
|
+
const scrollToActive = (index2) => {
|
|
1249
|
+
const ul = dropDownRef.value;
|
|
1250
|
+
const li = ul.children[index2];
|
|
1251
|
+
nextTick$1(() => {
|
|
1252
|
+
if (li.scrollIntoViewIfNeeded) {
|
|
1253
|
+
li.scrollIntoViewIfNeeded(false);
|
|
1254
|
+
} else {
|
|
1255
|
+
const containerInfo = ul.getBoundingClientRect();
|
|
1256
|
+
const elementInfo = li.getBoundingClientRect();
|
|
1257
|
+
if (elementInfo.bottom > containerInfo.bottom || elementInfo.top < containerInfo.top) {
|
|
1258
|
+
li.scrollIntoView(false);
|
|
1259
|
+
}
|
|
1260
|
+
}
|
|
1261
|
+
});
|
|
1262
|
+
};
|
|
1263
|
+
const handlekeyDown = (e) => {
|
|
1264
|
+
var _a2;
|
|
1265
|
+
const keyCode = e.key || e.code;
|
|
1266
|
+
if (keyCode === "Escape" && (visible.value && searchList.value.length || searchStatus.value || showNoResultItemTemplate.value)) {
|
|
1267
|
+
handleClose();
|
|
1268
|
+
return;
|
|
1269
|
+
}
|
|
1270
|
+
const status2 = visible.value && searchList.value.length && !searchStatus.value && !showNoResultItemTemplate.value;
|
|
1271
|
+
if (keyCode === "ArrowDown" && status2) {
|
|
1272
|
+
if (hoverIndex.value === searchList.value.length - 1) {
|
|
1273
|
+
hoverIndex.value = 0;
|
|
1274
|
+
scrollToActive(hoverIndex.value);
|
|
1275
|
+
return;
|
|
1276
|
+
}
|
|
1277
|
+
hoverIndex.value = hoverIndex.value + 1;
|
|
1278
|
+
scrollToActive(hoverIndex.value);
|
|
1279
|
+
} else if (keyCode === "ArrowUp" && status2) {
|
|
1280
|
+
if (hoverIndex.value === 0) {
|
|
1281
|
+
hoverIndex.value = searchList.value.length - 1;
|
|
1282
|
+
scrollToActive(hoverIndex.value);
|
|
1283
|
+
return;
|
|
1284
|
+
}
|
|
1285
|
+
hoverIndex.value = hoverIndex.value - 1;
|
|
1286
|
+
scrollToActive(hoverIndex.value);
|
|
1287
|
+
}
|
|
1288
|
+
if (keyCode === "Enter" && status2) {
|
|
1289
|
+
selectOptionClick(searchList.value[hoverIndex.value]);
|
|
1290
|
+
hoverIndex.value = (_a2 = selectedIndex.value) != null ? _a2 : 0;
|
|
1291
|
+
return;
|
|
1292
|
+
}
|
|
1293
|
+
};
|
|
1294
|
+
return {
|
|
1295
|
+
hoverIndex,
|
|
1296
|
+
handlekeyDown
|
|
1297
|
+
};
|
|
1298
|
+
}
|
|
1299
|
+
var autoComplete = "";
|
|
1300
|
+
class View {
|
|
1301
|
+
constructor() {
|
|
1302
|
+
__publicField(this, "top", "50%");
|
|
1303
|
+
__publicField(this, "left", "50%");
|
|
1304
|
+
}
|
|
1305
|
+
}
|
|
1306
|
+
const componentProps$1 = {
|
|
1307
|
+
message: String,
|
|
1308
|
+
backdrop: Boolean,
|
|
1309
|
+
view: {
|
|
1310
|
+
type: Object,
|
|
1311
|
+
default: () => new View()
|
|
1312
|
+
},
|
|
1313
|
+
zIndex: Number,
|
|
1314
|
+
isFull: {
|
|
1315
|
+
type: Boolean,
|
|
1316
|
+
default: false
|
|
1317
|
+
}
|
|
1318
|
+
};
|
|
1319
|
+
class LoadingProps {
|
|
1320
|
+
constructor() {
|
|
1321
|
+
__publicField(this, "target");
|
|
1322
|
+
__publicField(this, "message");
|
|
1323
|
+
__publicField(this, "loadingTemplateRef");
|
|
1324
|
+
__publicField(this, "backdrop", true);
|
|
1325
|
+
__publicField(this, "positionType", "relative");
|
|
1326
|
+
__publicField(this, "view", new View());
|
|
1327
|
+
__publicField(this, "zIndex");
|
|
1328
|
+
}
|
|
1329
|
+
}
|
|
1330
|
+
var loading$1 = "";
|
|
1331
|
+
var Loading = defineComponent$1({
|
|
1332
|
+
name: "DLoading",
|
|
1333
|
+
inheritAttrs: false,
|
|
1334
|
+
props: componentProps$1,
|
|
1335
|
+
setup(props) {
|
|
1336
|
+
const style2 = {
|
|
1337
|
+
top: props.view.top,
|
|
1338
|
+
left: props.view.left,
|
|
1339
|
+
zIndex: props.zIndex
|
|
1340
|
+
};
|
|
1341
|
+
if (!props.message) {
|
|
1342
|
+
style2.background = "none";
|
|
1343
|
+
}
|
|
1344
|
+
const isShow = ref(false);
|
|
1345
|
+
const open = () => {
|
|
1346
|
+
isShow.value = true;
|
|
1347
|
+
};
|
|
1348
|
+
const close = () => {
|
|
1349
|
+
isShow.value = false;
|
|
1350
|
+
};
|
|
1351
|
+
return {
|
|
1352
|
+
style: style2,
|
|
1353
|
+
isShow,
|
|
1354
|
+
open,
|
|
1355
|
+
close
|
|
1356
|
+
};
|
|
1357
|
+
},
|
|
1358
|
+
render() {
|
|
1359
|
+
var _a;
|
|
1360
|
+
const {
|
|
1361
|
+
isShow,
|
|
1362
|
+
isFull,
|
|
1363
|
+
backdrop,
|
|
1364
|
+
style: style2,
|
|
1365
|
+
message,
|
|
1366
|
+
$slots
|
|
1367
|
+
} = this;
|
|
1368
|
+
return isShow && createVNode("div", {
|
|
1369
|
+
"class": ["devui-loading-contanier", isFull ? "devui-loading--full" : ""]
|
|
1370
|
+
}, [((_a = $slots.default) == null ? void 0 : _a.call($slots)) || createVNode("div", {
|
|
1371
|
+
"class": "devui-loading-wrapper"
|
|
1372
|
+
}, [backdrop ? createVNode("div", {
|
|
1373
|
+
"class": "devui-loading-mask"
|
|
1374
|
+
}, null) : null, createVNode("div", {
|
|
1375
|
+
"style": style2,
|
|
1376
|
+
"class": "devui-loading-area"
|
|
1377
|
+
}, [createVNode("div", {
|
|
1378
|
+
"class": "devui-busy-default-spinner"
|
|
1379
|
+
}, [createVNode("div", {
|
|
1380
|
+
"class": "devui-loading-bar1"
|
|
1381
|
+
}, null), createVNode("div", {
|
|
1382
|
+
"class": "devui-loading-bar2"
|
|
1383
|
+
}, null), createVNode("div", {
|
|
1384
|
+
"class": "devui-loading-bar3"
|
|
1385
|
+
}, null), createVNode("div", {
|
|
1386
|
+
"class": "devui-loading-bar4"
|
|
1387
|
+
}, null)]), message ? createVNode("span", {
|
|
1388
|
+
"class": "devui-loading-text"
|
|
1389
|
+
}, [message]) : null])])]);
|
|
1390
|
+
}
|
|
1391
|
+
});
|
|
1392
|
+
const COMPONENT_CONTAINER_SYMBOL = Symbol("dev_component_container");
|
|
1393
|
+
function createComponent$1(Component, props, children = null) {
|
|
1394
|
+
const vnode = h(Component, __spreadValues({}, props), children);
|
|
1395
|
+
const container = document.createElement("div");
|
|
1396
|
+
vnode[COMPONENT_CONTAINER_SYMBOL] = container;
|
|
1397
|
+
render(vnode, container);
|
|
1398
|
+
return vnode.component;
|
|
1399
|
+
}
|
|
1400
|
+
function unmountComponent(ComponnetInstance) {
|
|
1401
|
+
render(null, ComponnetInstance == null ? void 0 : ComponnetInstance.vnode[COMPONENT_CONTAINER_SYMBOL]);
|
|
1402
|
+
}
|
|
1403
|
+
const loadingConstructor$1 = defineComponent$1(Loading);
|
|
1404
|
+
const cacheInstance = new WeakSet();
|
|
1405
|
+
const isEmpty = (val) => {
|
|
1406
|
+
if (!val)
|
|
1407
|
+
return true;
|
|
1408
|
+
if (Array.isArray(val))
|
|
1409
|
+
return val.length === 0;
|
|
1410
|
+
if (val instanceof Set || val instanceof Map)
|
|
1411
|
+
return val.size === 0;
|
|
1412
|
+
if (val instanceof Promise)
|
|
1413
|
+
return false;
|
|
1414
|
+
if (typeof val === "object") {
|
|
1415
|
+
try {
|
|
1416
|
+
return Object.keys(val).length === 0;
|
|
1417
|
+
} catch (e) {
|
|
1418
|
+
return false;
|
|
1419
|
+
}
|
|
1420
|
+
}
|
|
1421
|
+
return false;
|
|
1422
|
+
};
|
|
1423
|
+
const getType = (vari) => {
|
|
1424
|
+
return Object.prototype.toString.call(vari).slice(8, -1).toLowerCase();
|
|
1425
|
+
};
|
|
1426
|
+
const isPromise$1 = (value) => {
|
|
1427
|
+
const type4 = getType(value);
|
|
1428
|
+
switch (type4) {
|
|
1429
|
+
case "promise":
|
|
1430
|
+
return [value];
|
|
1431
|
+
case "array":
|
|
1432
|
+
if (value.some((val) => getType(val) !== "promise")) {
|
|
1433
|
+
console.error(new TypeError("Binding values should all be of type Promise"));
|
|
1434
|
+
return "error";
|
|
1435
|
+
}
|
|
1436
|
+
return value;
|
|
1437
|
+
default:
|
|
1438
|
+
return false;
|
|
1439
|
+
}
|
|
1440
|
+
};
|
|
1441
|
+
const unmount = (el) => {
|
|
1442
|
+
cacheInstance.delete(el);
|
|
1443
|
+
el.instance.proxy.close();
|
|
1444
|
+
unmountComponent(el.instance);
|
|
1445
|
+
};
|
|
1446
|
+
const toggleLoading = (el, binding) => {
|
|
1447
|
+
if (binding.value) {
|
|
1448
|
+
const vals = isPromise$1(binding.value);
|
|
1449
|
+
if (vals === "error")
|
|
1450
|
+
return;
|
|
1451
|
+
el.instance.proxy.open();
|
|
1452
|
+
el.appendChild(el.mask);
|
|
1453
|
+
cacheInstance.add(el);
|
|
1454
|
+
if (vals) {
|
|
1455
|
+
Promise.all(vals).catch((err) => {
|
|
1456
|
+
console.error(new Error("Promise handling errors"), err);
|
|
1457
|
+
}).finally(() => {
|
|
1458
|
+
unmount(el);
|
|
1459
|
+
});
|
|
1460
|
+
}
|
|
1461
|
+
} else {
|
|
1462
|
+
unmount(el);
|
|
1463
|
+
}
|
|
1464
|
+
};
|
|
1465
|
+
const removeAttribute = (el) => {
|
|
1466
|
+
el.removeAttribute("zindex");
|
|
1467
|
+
el.removeAttribute("positiontype");
|
|
1468
|
+
el.removeAttribute("backdrop");
|
|
1469
|
+
el.removeAttribute("message");
|
|
1470
|
+
el.removeAttribute("view");
|
|
1471
|
+
el.removeAttribute("loadingtemplateref");
|
|
1472
|
+
};
|
|
1473
|
+
const handleProps = (el, vprops) => {
|
|
1474
|
+
const props = __spreadValues(__spreadValues({}, new LoadingProps()), vprops);
|
|
1475
|
+
const loadingTemplateRef = props.loadingTemplateRef;
|
|
1476
|
+
const loadingInstance = createComponent$1(loadingConstructor$1, __spreadValues({}, props), loadingTemplateRef ? () => loadingTemplateRef : null);
|
|
1477
|
+
el.style.position = props.positionType;
|
|
1478
|
+
el.options = props;
|
|
1479
|
+
el.instance = loadingInstance;
|
|
1480
|
+
el.mask = loadingInstance.proxy.$el;
|
|
1481
|
+
};
|
|
1482
|
+
const loadingDirective = {
|
|
1483
|
+
mounted: function(el, binding, vnode) {
|
|
1484
|
+
handleProps(el, vnode.props);
|
|
1485
|
+
removeAttribute(el);
|
|
1486
|
+
!isEmpty(binding.value) && toggleLoading(el, binding);
|
|
1487
|
+
},
|
|
1488
|
+
updated: function(el, binding, vnode) {
|
|
1489
|
+
if (!isEmpty(binding.value) && cacheInstance.has(el) || isEmpty(binding.value) && !cacheInstance.has(el))
|
|
1490
|
+
return;
|
|
1491
|
+
!cacheInstance.has(el) && handleProps(el, vnode.props);
|
|
1492
|
+
removeAttribute(el);
|
|
1493
|
+
toggleLoading(el, binding);
|
|
1494
|
+
}
|
|
1495
|
+
};
|
|
1496
|
+
var DAutoCompleteDropdown = defineComponent$1({
|
|
1497
|
+
name: "DAutoCompleteDropdown",
|
|
1498
|
+
directives: {
|
|
1499
|
+
dLoading: loadingDirective
|
|
1500
|
+
},
|
|
1501
|
+
setup(props, ctx2) {
|
|
1502
|
+
const propsData = inject(DropdownPropsKey);
|
|
1503
|
+
const {
|
|
1504
|
+
visible,
|
|
1505
|
+
selectedIndex,
|
|
1506
|
+
selectOptionClick,
|
|
1507
|
+
searchList,
|
|
1508
|
+
searchStatus,
|
|
1509
|
+
dropDownRef,
|
|
1510
|
+
loadMore,
|
|
1511
|
+
showLoading,
|
|
1512
|
+
showNoResultItemTemplate,
|
|
1513
|
+
latestSource,
|
|
1514
|
+
modelValue,
|
|
1515
|
+
hoverIndex
|
|
1516
|
+
} = propsData;
|
|
1517
|
+
const {
|
|
1518
|
+
disabled,
|
|
1519
|
+
maxHeight,
|
|
1520
|
+
appendToBody,
|
|
1521
|
+
formatter,
|
|
1522
|
+
disabledKey,
|
|
1523
|
+
isSearching
|
|
1524
|
+
} = propsData.props;
|
|
1525
|
+
const onSelect = (item2) => {
|
|
1526
|
+
if (item2[disabledKey]) {
|
|
1527
|
+
return;
|
|
1528
|
+
}
|
|
1529
|
+
selectOptionClick(item2);
|
|
1530
|
+
};
|
|
1531
|
+
return () => {
|
|
1532
|
+
return withDirectives(createVNode("div", {
|
|
1533
|
+
"class": ["devui-dropdown-menu", appendToBody && "devui-dropdown-menu-cdk", disabled && "disabled", latestSource.value && "devui-dropdown-latestSource"]
|
|
1534
|
+
}, [createVNode("ul", {
|
|
1535
|
+
"ref": dropDownRef,
|
|
1536
|
+
"class": "devui-list-unstyled scroll-height",
|
|
1537
|
+
"style": {
|
|
1538
|
+
maxHeight: `${maxHeight}px`
|
|
1539
|
+
},
|
|
1540
|
+
"onScroll": loadMore
|
|
1541
|
+
}, [isSearching && ctx2.slots.searchingTemplate && searchStatus.value && createVNode("li", {
|
|
1542
|
+
"class": "devui-is-searching-template"
|
|
1543
|
+
}, [createVNode("div", {
|
|
1544
|
+
"class": "devui-no-data-tip"
|
|
1545
|
+
}, [ctx2.slots.searchingTemplate()])]), latestSource.value && !modelValue.value && createVNode("li", {
|
|
1546
|
+
"class": "devui-popup-tips"
|
|
1547
|
+
}, [createTextVNode("\u6700\u8FD1\u8F93\u5165")]), !showNoResultItemTemplate.value && !searchStatus.value && searchList != null && searchList.value.length > 0 && searchList.value.map((item2, index2) => {
|
|
1548
|
+
return createVNode("li", {
|
|
1549
|
+
"onClick": () => onSelect(item2),
|
|
1550
|
+
"class": ["devui-dropdown-item", selectedIndex.value == index2 && "selected", {
|
|
1551
|
+
"disabled": disabledKey && item2[disabledKey]
|
|
1552
|
+
}, {
|
|
1553
|
+
"devui-dropdown-bg": hoverIndex.value == index2
|
|
1554
|
+
}],
|
|
1555
|
+
"title": formatter(item2),
|
|
1556
|
+
"key": formatter(item2)
|
|
1557
|
+
}, [ctx2.slots.itemTemplate ? ctx2.slots.itemTemplate(item2, index2) : formatter(item2)]);
|
|
1558
|
+
}), !searchStatus.value && searchList.value.length == 0 && ctx2.slots.noResultItemTemplate && showNoResultItemTemplate.value && createVNode("li", {
|
|
1559
|
+
"class": "devui-no-result-template"
|
|
1560
|
+
}, [createVNode("div", {
|
|
1561
|
+
"class": "devui-no-data-tip"
|
|
1562
|
+
}, [ctx2.slots.noResultItemTemplate()])])])]), [[resolveDirective("dLoading"), showLoading.value], [vShow, visible.value && searchList.value.length > 0 || ctx2.slots.noResultItemTemplate && showNoResultItemTemplate.value || isSearching && ctx2.slots.searchingTemplate && searchStatus.value]]);
|
|
1563
|
+
};
|
|
1564
|
+
}
|
|
1565
|
+
});
|
|
1566
|
+
function on(element, eventName, handler) {
|
|
1567
|
+
if (document.addEventListener) {
|
|
1568
|
+
if (element && eventName && handler) {
|
|
1569
|
+
element.addEventListener(eventName, handler, false);
|
|
1570
|
+
}
|
|
1571
|
+
} else {
|
|
1572
|
+
if (element && eventName && handler) {
|
|
1573
|
+
element.attachEvent("on" + eventName, handler);
|
|
1574
|
+
}
|
|
1575
|
+
}
|
|
1576
|
+
}
|
|
1577
|
+
function off(element, eventName, handler) {
|
|
1578
|
+
if (document.removeEventListener) {
|
|
1579
|
+
if (element && eventName && handler) {
|
|
1580
|
+
element.removeEventListener(eventName, handler, false);
|
|
1581
|
+
}
|
|
1582
|
+
} else {
|
|
1583
|
+
if (element && eventName && handler) {
|
|
1584
|
+
element.detachEvent("on" + eventName, handler);
|
|
1585
|
+
}
|
|
1586
|
+
}
|
|
1587
|
+
}
|
|
1588
|
+
const ctx = Symbol("@@clickoutside");
|
|
1589
|
+
const nodeList = new Map();
|
|
1590
|
+
let startClick;
|
|
1591
|
+
let nid = 0;
|
|
1592
|
+
let isFirst = true;
|
|
1593
|
+
function createDocumentHandler(el, binding, vnode) {
|
|
1594
|
+
if (inBrowser && isFirst) {
|
|
1595
|
+
isFirst = false;
|
|
1596
|
+
on(document, "mousedown", (e) => {
|
|
1597
|
+
startClick = e;
|
|
1598
|
+
});
|
|
1599
|
+
on(document, "mouseup", (e) => {
|
|
1600
|
+
for (const [id, node] of nodeList) {
|
|
1601
|
+
node[ctx].documentHandler(e, startClick);
|
|
1602
|
+
}
|
|
1603
|
+
});
|
|
1604
|
+
}
|
|
1605
|
+
return function(mouseup, mousedown) {
|
|
1606
|
+
if (!vnode || !binding.instance || !mouseup.target || !mousedown.target || el.contains(mouseup.target) || el.contains(mousedown.target) || el === mouseup.target) {
|
|
1607
|
+
return;
|
|
1608
|
+
}
|
|
1609
|
+
el[ctx].bindingFn && el[ctx].bindingFn();
|
|
1610
|
+
};
|
|
1611
|
+
}
|
|
1612
|
+
const clickoutsideDirective = {
|
|
1613
|
+
beforeMount: function(el, binding, vnode) {
|
|
1614
|
+
nid++;
|
|
1615
|
+
nodeList.set(nid, el);
|
|
1616
|
+
el[ctx] = {
|
|
1617
|
+
nid,
|
|
1618
|
+
documentHandler: createDocumentHandler(el, binding, vnode),
|
|
1619
|
+
bindingFn: binding.value
|
|
1620
|
+
};
|
|
1621
|
+
},
|
|
1622
|
+
updated: function(el, binding, vnode) {
|
|
1623
|
+
el[ctx].documentHandler = createDocumentHandler(el, binding, vnode);
|
|
1624
|
+
el[ctx].bindingFn = binding.value;
|
|
1625
|
+
},
|
|
1626
|
+
unmounted: function(el) {
|
|
1627
|
+
nodeList.delete(el[ctx].nid);
|
|
1628
|
+
delete el[ctx];
|
|
1629
|
+
}
|
|
1630
|
+
};
|
|
1631
|
+
var overlay = "";
|
|
1632
|
+
function _isSlot$6(s) {
|
|
1633
|
+
return typeof s === "function" || Object.prototype.toString.call(s) === "[object Object]" && !isVNode(s);
|
|
1634
|
+
}
|
|
1635
|
+
const CommonOverlay = defineComponent$1({
|
|
1636
|
+
setup(props, ctx2) {
|
|
1637
|
+
return () => {
|
|
1638
|
+
let _slot;
|
|
1639
|
+
return createVNode(Teleport, {
|
|
1640
|
+
"to": "#d-overlay-anchor"
|
|
1641
|
+
}, {
|
|
1642
|
+
default: () => [createVNode(Transition, {
|
|
1643
|
+
"name": "devui-overlay-fade"
|
|
1644
|
+
}, _isSlot$6(_slot = renderSlot(ctx2.slots, "default")) ? _slot : {
|
|
1645
|
+
default: () => [_slot]
|
|
1646
|
+
})]
|
|
1647
|
+
});
|
|
1648
|
+
};
|
|
1649
|
+
}
|
|
1650
|
+
});
|
|
1651
|
+
const overlayProps = {
|
|
1652
|
+
visible: {
|
|
1653
|
+
type: Boolean
|
|
1654
|
+
},
|
|
1655
|
+
backgroundBlock: {
|
|
1656
|
+
type: Boolean,
|
|
1657
|
+
default: false
|
|
1658
|
+
},
|
|
1659
|
+
backgroundClass: {
|
|
1660
|
+
type: String,
|
|
1661
|
+
default: ""
|
|
1662
|
+
},
|
|
1663
|
+
backgroundStyle: {
|
|
1664
|
+
type: [String, Object]
|
|
1665
|
+
},
|
|
1666
|
+
onBackdropClick: {
|
|
1667
|
+
type: Function
|
|
1668
|
+
},
|
|
1669
|
+
backdropClose: {
|
|
1670
|
+
type: Boolean,
|
|
1671
|
+
default: true
|
|
1672
|
+
},
|
|
1673
|
+
hasBackdrop: {
|
|
1674
|
+
type: Boolean,
|
|
1675
|
+
default: true
|
|
1676
|
+
}
|
|
1677
|
+
};
|
|
1678
|
+
const overlayEmits = ["update:visible", "backdropClick"];
|
|
1679
|
+
const fixedOverlayProps = __spreadProps(__spreadValues({}, overlayProps), {
|
|
1680
|
+
overlayStyle: {
|
|
1681
|
+
type: [String, Object],
|
|
1682
|
+
default: void 0
|
|
1683
|
+
}
|
|
1684
|
+
});
|
|
1685
|
+
const flexibleOverlayProps = __spreadValues({
|
|
1686
|
+
origin: {
|
|
1687
|
+
type: Object,
|
|
1688
|
+
require: true
|
|
1689
|
+
},
|
|
1690
|
+
position: {
|
|
1691
|
+
type: Object,
|
|
1692
|
+
default: () => ({
|
|
1693
|
+
originX: "left",
|
|
1694
|
+
originY: "top",
|
|
1695
|
+
overlayX: "left",
|
|
1696
|
+
overlayY: "top"
|
|
1697
|
+
})
|
|
1698
|
+
}
|
|
1699
|
+
}, overlayProps);
|
|
1700
|
+
function useOverlayLogic(props, ctx2) {
|
|
1701
|
+
const backgroundClass = computed(() => {
|
|
1702
|
+
return [
|
|
1703
|
+
"devui-overlay-background",
|
|
1704
|
+
props.backgroundClass,
|
|
1705
|
+
!props.hasBackdrop ? "devui-overlay-background__disabled" : "devui-overlay-background__color"
|
|
1706
|
+
];
|
|
1707
|
+
});
|
|
1708
|
+
const overlayClass = computed(() => {
|
|
1709
|
+
return "devui-overlay";
|
|
1710
|
+
});
|
|
1711
|
+
const handleBackdropClick = (event) => {
|
|
1712
|
+
var _a;
|
|
1713
|
+
event.preventDefault();
|
|
1714
|
+
(_a = props.onBackdropClick) == null ? void 0 : _a.call(props);
|
|
1715
|
+
if (props.backdropClose) {
|
|
1716
|
+
ctx2.emit("update:visible", false);
|
|
1717
|
+
}
|
|
1718
|
+
};
|
|
1719
|
+
const handleOverlayBubbleCancel = (event) => event.cancelBubble = true;
|
|
1720
|
+
onMounted(() => {
|
|
1721
|
+
const body2 = document.body;
|
|
1722
|
+
const originOverflow = body2.style.overflow;
|
|
1723
|
+
const originPosition = body2.style.position;
|
|
1724
|
+
watch([() => props.visible, () => props.backgroundBlock], ([visible, backgroundBlock]) => {
|
|
1725
|
+
if (backgroundBlock) {
|
|
1726
|
+
const top = body2.getBoundingClientRect().y;
|
|
1727
|
+
if (visible) {
|
|
1728
|
+
body2.style.overflowY = "scroll";
|
|
1729
|
+
body2.style.position = visible ? "fixed" : "";
|
|
1730
|
+
body2.style.top = `${top}px`;
|
|
1731
|
+
} else {
|
|
1732
|
+
body2.style.overflowY = originOverflow;
|
|
1733
|
+
body2.style.position = originPosition;
|
|
1734
|
+
body2.style.top = "";
|
|
1735
|
+
window.scrollTo(0, -top);
|
|
1736
|
+
}
|
|
1737
|
+
}
|
|
1738
|
+
});
|
|
1739
|
+
onUnmounted(() => {
|
|
1740
|
+
document.body.style.overflow = originOverflow;
|
|
1741
|
+
});
|
|
1742
|
+
});
|
|
1743
|
+
return {
|
|
1744
|
+
backgroundClass,
|
|
1745
|
+
overlayClass,
|
|
1746
|
+
handleBackdropClick,
|
|
1747
|
+
handleOverlayBubbleCancel
|
|
1748
|
+
};
|
|
1749
|
+
}
|
|
1750
|
+
function isComponent(target) {
|
|
1751
|
+
return !!(target == null ? void 0 : target.$el);
|
|
1752
|
+
}
|
|
1753
|
+
function getElement(element) {
|
|
1754
|
+
if (element instanceof Element) {
|
|
1755
|
+
return element;
|
|
1756
|
+
}
|
|
1757
|
+
if (element && typeof element === "object" && element.$el instanceof Element) {
|
|
1758
|
+
return element.$el;
|
|
1759
|
+
}
|
|
1760
|
+
return null;
|
|
1761
|
+
}
|
|
1762
|
+
const FlexibleOverlay = defineComponent$1({
|
|
1763
|
+
name: "DFlexibleOverlay",
|
|
1764
|
+
props: flexibleOverlayProps,
|
|
1765
|
+
emits: overlayEmits,
|
|
1766
|
+
setup(props, ctx2) {
|
|
1767
|
+
const overlayRef = ref(null);
|
|
1768
|
+
const positionedStyle = reactive({
|
|
1769
|
+
position: "absolute"
|
|
1770
|
+
});
|
|
1771
|
+
onMounted(async () => {
|
|
1772
|
+
const handleRectChange = (position, rect, origin) => {
|
|
1773
|
+
const point = calculatePosition(position, rect, origin);
|
|
1774
|
+
positionedStyle.left = `${point.x}px`;
|
|
1775
|
+
positionedStyle.top = `${point.y}px`;
|
|
1776
|
+
};
|
|
1777
|
+
const locationElements = computed(() => {
|
|
1778
|
+
const overlay2 = overlayRef.value;
|
|
1779
|
+
const origin = getOrigin(props.origin);
|
|
1780
|
+
if (!overlay2 || !origin) {
|
|
1781
|
+
return;
|
|
1782
|
+
}
|
|
1783
|
+
return {
|
|
1784
|
+
origin,
|
|
1785
|
+
overlay: overlay2
|
|
1786
|
+
};
|
|
1787
|
+
});
|
|
1788
|
+
const visibleRef = toRef(props, "visible");
|
|
1789
|
+
const positionRef = toRef(props, "position");
|
|
1790
|
+
watch([locationElements, visibleRef, positionRef], async ([locationElements2, visible, position], ov, onInvalidate) => {
|
|
1791
|
+
if (!visible || !locationElements2) {
|
|
1792
|
+
return;
|
|
1793
|
+
}
|
|
1794
|
+
const {
|
|
1795
|
+
origin,
|
|
1796
|
+
overlay: overlay2
|
|
1797
|
+
} = locationElements2;
|
|
1798
|
+
handleRectChange(position, overlay2.getBoundingClientRect(), origin);
|
|
1799
|
+
const unsubscriptions = [subscribeLayoutEvent(() => handleRectChange(position, overlay2.getBoundingClientRect(), origin)), subscribeOverlayResize(overlay2, (entries) => handleRectChange(position, entries[0].contentRect, origin)), subscribeOriginResize(origin, () => handleRectChange(position, overlay2.getBoundingClientRect(), origin))];
|
|
1800
|
+
onInvalidate(() => {
|
|
1801
|
+
unsubscriptions.forEach((fn) => fn());
|
|
1802
|
+
});
|
|
1803
|
+
});
|
|
1804
|
+
});
|
|
1805
|
+
const {
|
|
1806
|
+
backgroundClass,
|
|
1807
|
+
overlayClass,
|
|
1808
|
+
handleBackdropClick,
|
|
1809
|
+
handleOverlayBubbleCancel
|
|
1810
|
+
} = useOverlayLogic(props, ctx2);
|
|
1811
|
+
return () => createVNode(CommonOverlay, null, {
|
|
1812
|
+
default: () => [withDirectives(createVNode("div", {
|
|
1813
|
+
"style": props.backgroundStyle,
|
|
1814
|
+
"class": backgroundClass.value,
|
|
1815
|
+
"onClick": handleBackdropClick
|
|
1816
|
+
}, [createVNode("div", {
|
|
1817
|
+
"ref": overlayRef,
|
|
1818
|
+
"class": overlayClass.value,
|
|
1819
|
+
"style": positionedStyle,
|
|
1820
|
+
"onClick": handleOverlayBubbleCancel
|
|
1821
|
+
}, [renderSlot(ctx2.slots, "default")])]), [[vShow, props.visible]])]
|
|
1822
|
+
});
|
|
1823
|
+
}
|
|
1824
|
+
});
|
|
1825
|
+
function getOrigin(origin) {
|
|
1826
|
+
if (origin instanceof Element) {
|
|
1827
|
+
return origin;
|
|
1828
|
+
}
|
|
1829
|
+
if (isRef$1(origin)) {
|
|
1830
|
+
return getElement(origin.value);
|
|
1831
|
+
}
|
|
1832
|
+
if (isComponent(origin)) {
|
|
1833
|
+
return getElement(origin);
|
|
1834
|
+
}
|
|
1835
|
+
return origin;
|
|
1836
|
+
}
|
|
1837
|
+
function calculatePosition(position, rect, origin) {
|
|
1838
|
+
const originRect = getOriginRect(origin);
|
|
1839
|
+
const originPoint = getOriginRelativePoint(originRect, position);
|
|
1840
|
+
return getOverlayPoint(originPoint, rect, position);
|
|
1841
|
+
}
|
|
1842
|
+
function getOriginRect(origin) {
|
|
1843
|
+
if (origin instanceof Element) {
|
|
1844
|
+
return origin.getBoundingClientRect();
|
|
1845
|
+
}
|
|
1846
|
+
const width = origin.width || 0;
|
|
1847
|
+
const height = origin.height || 0;
|
|
1848
|
+
return {
|
|
1849
|
+
top: origin.y,
|
|
1850
|
+
bottom: origin.y + height,
|
|
1851
|
+
left: origin.x,
|
|
1852
|
+
right: origin.x + width,
|
|
1853
|
+
height,
|
|
1854
|
+
width
|
|
1855
|
+
};
|
|
1856
|
+
}
|
|
1857
|
+
function getOverlayPoint(originPoint, rect, position) {
|
|
1858
|
+
let x;
|
|
1859
|
+
const {
|
|
1860
|
+
width,
|
|
1861
|
+
height
|
|
1862
|
+
} = rect;
|
|
1863
|
+
if (position.overlayX == "center") {
|
|
1864
|
+
x = originPoint.x - width / 2;
|
|
1865
|
+
} else {
|
|
1866
|
+
x = position.overlayX == "left" ? originPoint.x : originPoint.x - width;
|
|
1867
|
+
}
|
|
1868
|
+
let y;
|
|
1869
|
+
if (position.overlayY == "center") {
|
|
1870
|
+
y = originPoint.y - height / 2;
|
|
1871
|
+
} else {
|
|
1872
|
+
y = position.overlayY == "top" ? originPoint.y : originPoint.y - height;
|
|
1873
|
+
}
|
|
1874
|
+
return {
|
|
1875
|
+
x,
|
|
1876
|
+
y
|
|
1877
|
+
};
|
|
1878
|
+
}
|
|
1879
|
+
function getOriginRelativePoint(originRect, position) {
|
|
1880
|
+
let x;
|
|
1881
|
+
if (position.originX == "center") {
|
|
1882
|
+
x = originRect.left + originRect.width / 2;
|
|
1883
|
+
} else {
|
|
1884
|
+
const startX = originRect.left;
|
|
1885
|
+
const endX = originRect.right;
|
|
1886
|
+
x = position.originX == "left" ? startX : endX;
|
|
1887
|
+
}
|
|
1888
|
+
let y;
|
|
1889
|
+
if (position.originY == "center") {
|
|
1890
|
+
y = originRect.top + originRect.height / 2;
|
|
1891
|
+
} else {
|
|
1892
|
+
y = position.originY == "top" ? originRect.top : originRect.bottom;
|
|
1893
|
+
}
|
|
1894
|
+
return {
|
|
1895
|
+
x,
|
|
1896
|
+
y
|
|
1897
|
+
};
|
|
1898
|
+
}
|
|
1899
|
+
function subscribeLayoutEvent(event) {
|
|
1900
|
+
window.addEventListener("scroll", event, true);
|
|
1901
|
+
window.addEventListener("resize", event);
|
|
1902
|
+
window.addEventListener("orientationchange", event);
|
|
1903
|
+
return () => {
|
|
1904
|
+
window.removeEventListener("scroll", event, true);
|
|
1905
|
+
window.removeEventListener("resize", event);
|
|
1906
|
+
window.removeEventListener("orientationchange", event);
|
|
1907
|
+
};
|
|
1908
|
+
}
|
|
1909
|
+
function subscribeOverlayResize(overlay2, callback) {
|
|
1910
|
+
if (overlay2 instanceof Element) {
|
|
1911
|
+
const resizeObserver = new ResizeObserver(callback);
|
|
1912
|
+
resizeObserver.observe(overlay2);
|
|
1913
|
+
return () => resizeObserver.disconnect();
|
|
1914
|
+
}
|
|
1915
|
+
return () => {
|
|
1916
|
+
};
|
|
1917
|
+
}
|
|
1918
|
+
function subscribeOriginResize(origin, callback) {
|
|
1919
|
+
if (origin instanceof Element) {
|
|
1920
|
+
const observer = new MutationObserver(callback);
|
|
1921
|
+
observer.observe(origin, {
|
|
1922
|
+
attributeFilter: ["style"]
|
|
1923
|
+
});
|
|
1924
|
+
return () => observer.disconnect();
|
|
1925
|
+
}
|
|
1926
|
+
return () => {
|
|
1927
|
+
};
|
|
1928
|
+
}
|
|
1929
|
+
function _isSlot$5(s) {
|
|
1930
|
+
return typeof s === "function" || Object.prototype.toString.call(s) === "[object Object]" && !isVNode(s);
|
|
1931
|
+
}
|
|
1932
|
+
var AutoComplete = defineComponent$1({
|
|
1933
|
+
name: "DAutoComplete",
|
|
1934
|
+
directives: {
|
|
1935
|
+
ClickOutside: clickoutsideDirective
|
|
1936
|
+
},
|
|
1937
|
+
props: autoCompleteProps,
|
|
1938
|
+
emits: ["update:modelValue"],
|
|
1939
|
+
setup(props, ctx2) {
|
|
1940
|
+
const {
|
|
1941
|
+
disabled,
|
|
1942
|
+
modelValue,
|
|
1943
|
+
appendToBody,
|
|
1944
|
+
dAutoCompleteWidth,
|
|
1945
|
+
delay,
|
|
1946
|
+
allowEmptyValueSearch,
|
|
1947
|
+
formatter,
|
|
1948
|
+
transInputFocusEmit,
|
|
1949
|
+
selectValue,
|
|
1950
|
+
source,
|
|
1951
|
+
searchFn,
|
|
1952
|
+
appendToBodyDirections,
|
|
1953
|
+
latestSource,
|
|
1954
|
+
showAnimation
|
|
1955
|
+
} = toRefs(props);
|
|
1956
|
+
const {
|
|
1957
|
+
handleSearch,
|
|
1958
|
+
searchList,
|
|
1959
|
+
showNoResultItemTemplate,
|
|
1960
|
+
recentlyFocus
|
|
1961
|
+
} = useSearchFn(ctx2, allowEmptyValueSearch, source, searchFn, formatter);
|
|
1962
|
+
const {
|
|
1963
|
+
onInput,
|
|
1964
|
+
onFocus,
|
|
1965
|
+
inputRef,
|
|
1966
|
+
visible,
|
|
1967
|
+
searchStatus,
|
|
1968
|
+
handleClose,
|
|
1969
|
+
toggleMenu
|
|
1970
|
+
} = useInputHandle(ctx2, searchList, showNoResultItemTemplate, modelValue, disabled, delay, handleSearch, transInputFocusEmit, recentlyFocus, latestSource);
|
|
1971
|
+
const {
|
|
1972
|
+
selectedIndex,
|
|
1973
|
+
selectOptionClick
|
|
1974
|
+
} = useSelectHandle(ctx2, searchList, selectValue, handleSearch, formatter, handleClose);
|
|
1975
|
+
const {
|
|
1976
|
+
showLoading,
|
|
1977
|
+
dropDownRef,
|
|
1978
|
+
loadMore
|
|
1979
|
+
} = useLazyHandle(props, ctx2, handleSearch);
|
|
1980
|
+
const {
|
|
1981
|
+
customRenderSolts
|
|
1982
|
+
} = useCustomTemplate(ctx2, modelValue);
|
|
1983
|
+
const {
|
|
1984
|
+
hoverIndex,
|
|
1985
|
+
handlekeyDown
|
|
1986
|
+
} = useKeyBoardHandle(dropDownRef, visible, searchList, selectedIndex, searchStatus, showNoResultItemTemplate, selectOptionClick, handleClose);
|
|
1987
|
+
provide(DropdownPropsKey, {
|
|
1988
|
+
props,
|
|
1989
|
+
visible,
|
|
1990
|
+
term: "",
|
|
1991
|
+
searchList,
|
|
1992
|
+
selectedIndex,
|
|
1993
|
+
searchStatus,
|
|
1994
|
+
selectOptionClick,
|
|
1995
|
+
dropDownRef,
|
|
1996
|
+
showLoading,
|
|
1997
|
+
loadMore,
|
|
1998
|
+
latestSource,
|
|
1999
|
+
modelValue,
|
|
2000
|
+
showNoResultItemTemplate,
|
|
2001
|
+
hoverIndex
|
|
2002
|
+
});
|
|
2003
|
+
const origin = ref();
|
|
2004
|
+
const position = reactive({
|
|
2005
|
+
appendToBodyDirections: {}
|
|
2006
|
+
});
|
|
2007
|
+
position.appendToBodyDirections = appendToBodyDirections;
|
|
2008
|
+
const renderDropdown = () => {
|
|
2009
|
+
if (appendToBody.value) {
|
|
2010
|
+
let _slot;
|
|
2011
|
+
return createVNode(FlexibleOverlay, {
|
|
2012
|
+
"hasBackdrop": false,
|
|
2013
|
+
"origin": origin,
|
|
2014
|
+
"position": position.appendToBodyDirections,
|
|
2015
|
+
"visible": visible.value,
|
|
2016
|
+
"onUpdate:visible": ($event) => visible.value = $event
|
|
2017
|
+
}, {
|
|
2018
|
+
default: () => [createVNode("div", {
|
|
2019
|
+
"class": "devui-dropdown devui-auto-complete-menu",
|
|
2020
|
+
"style": {
|
|
2021
|
+
width: dAutoCompleteWidth.value > 0 && dAutoCompleteWidth.value + "px"
|
|
2022
|
+
}
|
|
2023
|
+
}, [createVNode(DAutoCompleteDropdown, null, _isSlot$5(_slot = customRenderSolts()) ? _slot : {
|
|
2024
|
+
default: () => [_slot]
|
|
2025
|
+
})])]
|
|
2026
|
+
});
|
|
2027
|
+
} else {
|
|
2028
|
+
let _slot2;
|
|
2029
|
+
return createVNode("div", {
|
|
2030
|
+
"class": "devui-dropdown",
|
|
2031
|
+
"style": {
|
|
2032
|
+
width: dAutoCompleteWidth.value > 0 && dAutoCompleteWidth.value + "px"
|
|
2033
|
+
}
|
|
2034
|
+
}, [createVNode(Transition, {
|
|
2035
|
+
"name": showAnimation ? "fade" : ""
|
|
2036
|
+
}, {
|
|
2037
|
+
default: () => [createVNode(DAutoCompleteDropdown, null, _isSlot$5(_slot2 = customRenderSolts()) ? _slot2 : {
|
|
2038
|
+
default: () => [_slot2]
|
|
2039
|
+
})]
|
|
2040
|
+
})]);
|
|
2041
|
+
}
|
|
2042
|
+
};
|
|
2043
|
+
return () => {
|
|
2044
|
+
return withDirectives(createVNode("div", {
|
|
2045
|
+
"class": ["devui-auto-complete", "devui-form-group", "devui-has-feedback", visible.value && "devui-select-open"],
|
|
2046
|
+
"ref": origin,
|
|
2047
|
+
"style": {
|
|
2048
|
+
width: dAutoCompleteWidth.value > 0 && dAutoCompleteWidth.value + "px"
|
|
2049
|
+
}
|
|
2050
|
+
}, [createVNode("input", {
|
|
2051
|
+
"disabled": disabled.value,
|
|
2052
|
+
"type": "text",
|
|
2053
|
+
"onClick": toggleMenu,
|
|
2054
|
+
"class": ["devui-form-control", "devui-dropdown-origin", "devui-dropdown-origin-open", disabled.value && "disabled"],
|
|
2055
|
+
"placeholder": "Search",
|
|
2056
|
+
"onInput": onInput,
|
|
2057
|
+
"onFocus": onFocus,
|
|
2058
|
+
"value": modelValue.value,
|
|
2059
|
+
"ref": inputRef,
|
|
2060
|
+
"onKeydown": handlekeyDown
|
|
2061
|
+
}, null), renderDropdown()]), [[resolveDirective("click-outside"), handleClose]]);
|
|
2062
|
+
};
|
|
2063
|
+
}
|
|
2064
|
+
});
|
|
2065
|
+
AutoComplete.install = function(app) {
|
|
2066
|
+
app.component(AutoComplete.name, AutoComplete);
|
|
2067
|
+
};
|
|
2068
|
+
var AutoCompleteInstall = {
|
|
2069
|
+
title: "AutoComplete \u81EA\u52A8\u8865\u5168",
|
|
2070
|
+
category: "\u6570\u636E\u5F55\u5165",
|
|
2071
|
+
status: "100%",
|
|
2072
|
+
install(app) {
|
|
2073
|
+
app.use(AutoComplete);
|
|
2074
|
+
}
|
|
2075
|
+
};
|
|
961
2076
|
const IconBody = (props) => {
|
|
962
2077
|
const {
|
|
963
2078
|
width,
|
|
@@ -1618,221 +2733,25 @@ var Icon = defineComponent$1({
|
|
|
1618
2733
|
"style": {
|
|
1619
2734
|
width: size,
|
|
1620
2735
|
verticalAlign: "text-bottom"
|
|
1621
|
-
}
|
|
1622
|
-
}, null) : createVNode("i", {
|
|
1623
|
-
"class": `${classPrefix} ${classPrefix}-${name}`,
|
|
1624
|
-
"style": {
|
|
1625
|
-
fontSize: size,
|
|
1626
|
-
color: color2
|
|
1627
|
-
}
|
|
1628
|
-
}, null);
|
|
1629
|
-
}
|
|
1630
|
-
});
|
|
1631
|
-
Icon.install = function(app) {
|
|
1632
|
-
app.component(Icon.name, Icon);
|
|
1633
|
-
};
|
|
1634
|
-
var IconInstall = {
|
|
1635
|
-
title: "Icon \u56FE\u6807",
|
|
1636
|
-
category: "\u901A\u7528",
|
|
1637
|
-
status: "100%",
|
|
1638
|
-
install(app) {
|
|
1639
|
-
app.use(Icon);
|
|
1640
|
-
}
|
|
1641
|
-
};
|
|
1642
|
-
class View {
|
|
1643
|
-
constructor() {
|
|
1644
|
-
__publicField(this, "top", "50%");
|
|
1645
|
-
__publicField(this, "left", "50%");
|
|
1646
|
-
}
|
|
1647
|
-
}
|
|
1648
|
-
const componentProps$1 = {
|
|
1649
|
-
message: String,
|
|
1650
|
-
backdrop: Boolean,
|
|
1651
|
-
view: {
|
|
1652
|
-
type: Object,
|
|
1653
|
-
default: () => new View()
|
|
1654
|
-
},
|
|
1655
|
-
zIndex: Number,
|
|
1656
|
-
isFull: {
|
|
1657
|
-
type: Boolean,
|
|
1658
|
-
default: false
|
|
1659
|
-
}
|
|
1660
|
-
};
|
|
1661
|
-
class LoadingProps {
|
|
1662
|
-
constructor() {
|
|
1663
|
-
__publicField(this, "target");
|
|
1664
|
-
__publicField(this, "message");
|
|
1665
|
-
__publicField(this, "loadingTemplateRef");
|
|
1666
|
-
__publicField(this, "backdrop", true);
|
|
1667
|
-
__publicField(this, "positionType", "relative");
|
|
1668
|
-
__publicField(this, "view", new View());
|
|
1669
|
-
__publicField(this, "zIndex");
|
|
1670
|
-
}
|
|
1671
|
-
}
|
|
1672
|
-
var loading$1 = "";
|
|
1673
|
-
var Loading = defineComponent$1({
|
|
1674
|
-
name: "DLoading",
|
|
1675
|
-
inheritAttrs: false,
|
|
1676
|
-
props: componentProps$1,
|
|
1677
|
-
setup(props) {
|
|
1678
|
-
const style2 = {
|
|
1679
|
-
top: props.view.top,
|
|
1680
|
-
left: props.view.left,
|
|
1681
|
-
zIndex: props.zIndex
|
|
1682
|
-
};
|
|
1683
|
-
if (!props.message) {
|
|
1684
|
-
style2.background = "none";
|
|
1685
|
-
}
|
|
1686
|
-
const isShow = ref(false);
|
|
1687
|
-
const open = () => {
|
|
1688
|
-
isShow.value = true;
|
|
1689
|
-
};
|
|
1690
|
-
const close = () => {
|
|
1691
|
-
isShow.value = false;
|
|
1692
|
-
};
|
|
1693
|
-
return {
|
|
1694
|
-
style: style2,
|
|
1695
|
-
isShow,
|
|
1696
|
-
open,
|
|
1697
|
-
close
|
|
1698
|
-
};
|
|
1699
|
-
},
|
|
1700
|
-
render() {
|
|
1701
|
-
var _a;
|
|
1702
|
-
const {
|
|
1703
|
-
isShow,
|
|
1704
|
-
isFull,
|
|
1705
|
-
backdrop,
|
|
1706
|
-
style: style2,
|
|
1707
|
-
message,
|
|
1708
|
-
$slots
|
|
1709
|
-
} = this;
|
|
1710
|
-
return isShow && createVNode("div", {
|
|
1711
|
-
"class": ["devui-loading-contanier", isFull ? "devui-loading--full" : ""]
|
|
1712
|
-
}, [((_a = $slots.default) == null ? void 0 : _a.call($slots)) || createVNode("div", {
|
|
1713
|
-
"class": "devui-loading-wrapper"
|
|
1714
|
-
}, [backdrop ? createVNode("div", {
|
|
1715
|
-
"class": "devui-loading-mask"
|
|
1716
|
-
}, null) : null, createVNode("div", {
|
|
1717
|
-
"style": style2,
|
|
1718
|
-
"class": "devui-loading-area"
|
|
1719
|
-
}, [createVNode("div", {
|
|
1720
|
-
"class": "devui-busy-default-spinner"
|
|
1721
|
-
}, [createVNode("div", {
|
|
1722
|
-
"class": "devui-loading-bar1"
|
|
1723
|
-
}, null), createVNode("div", {
|
|
1724
|
-
"class": "devui-loading-bar2"
|
|
1725
|
-
}, null), createVNode("div", {
|
|
1726
|
-
"class": "devui-loading-bar3"
|
|
1727
|
-
}, null), createVNode("div", {
|
|
1728
|
-
"class": "devui-loading-bar4"
|
|
1729
|
-
}, null)]), message ? createVNode("span", {
|
|
1730
|
-
"class": "devui-loading-text"
|
|
1731
|
-
}, [message]) : null])])]);
|
|
1732
|
-
}
|
|
1733
|
-
});
|
|
1734
|
-
const COMPONENT_CONTAINER_SYMBOL = Symbol("dev_component_container");
|
|
1735
|
-
function createComponent$1(Component, props, children = null) {
|
|
1736
|
-
const vnode = h(Component, __spreadValues({}, props), children);
|
|
1737
|
-
const container = document.createElement("div");
|
|
1738
|
-
vnode[COMPONENT_CONTAINER_SYMBOL] = container;
|
|
1739
|
-
render(vnode, container);
|
|
1740
|
-
return vnode.component;
|
|
1741
|
-
}
|
|
1742
|
-
function unmountComponent(ComponnetInstance) {
|
|
1743
|
-
render(null, ComponnetInstance == null ? void 0 : ComponnetInstance.vnode[COMPONENT_CONTAINER_SYMBOL]);
|
|
1744
|
-
}
|
|
1745
|
-
const loadingConstructor$1 = defineComponent$1(Loading);
|
|
1746
|
-
const cacheInstance = new WeakSet();
|
|
1747
|
-
const isEmpty = (val) => {
|
|
1748
|
-
if (!val)
|
|
1749
|
-
return true;
|
|
1750
|
-
if (Array.isArray(val))
|
|
1751
|
-
return val.length === 0;
|
|
1752
|
-
if (val instanceof Set || val instanceof Map)
|
|
1753
|
-
return val.size === 0;
|
|
1754
|
-
if (val instanceof Promise)
|
|
1755
|
-
return false;
|
|
1756
|
-
if (typeof val === "object") {
|
|
1757
|
-
try {
|
|
1758
|
-
return Object.keys(val).length === 0;
|
|
1759
|
-
} catch (e) {
|
|
1760
|
-
return false;
|
|
1761
|
-
}
|
|
1762
|
-
}
|
|
1763
|
-
return false;
|
|
1764
|
-
};
|
|
1765
|
-
const getType = (vari) => {
|
|
1766
|
-
return Object.prototype.toString.call(vari).slice(8, -1).toLowerCase();
|
|
1767
|
-
};
|
|
1768
|
-
const isPromise$1 = (value) => {
|
|
1769
|
-
const type4 = getType(value);
|
|
1770
|
-
switch (type4) {
|
|
1771
|
-
case "promise":
|
|
1772
|
-
return [value];
|
|
1773
|
-
case "array":
|
|
1774
|
-
if (value.some((val) => getType(val) !== "promise")) {
|
|
1775
|
-
console.error(new TypeError("Binding values should all be of type Promise"));
|
|
1776
|
-
return "error";
|
|
1777
|
-
}
|
|
1778
|
-
return value;
|
|
1779
|
-
default:
|
|
1780
|
-
return false;
|
|
1781
|
-
}
|
|
1782
|
-
};
|
|
1783
|
-
const unmount = (el) => {
|
|
1784
|
-
cacheInstance.delete(el);
|
|
1785
|
-
el.instance.proxy.close();
|
|
1786
|
-
unmountComponent(el.instance);
|
|
1787
|
-
};
|
|
1788
|
-
const toggleLoading = (el, binding) => {
|
|
1789
|
-
if (binding.value) {
|
|
1790
|
-
const vals = isPromise$1(binding.value);
|
|
1791
|
-
if (vals === "error")
|
|
1792
|
-
return;
|
|
1793
|
-
el.instance.proxy.open();
|
|
1794
|
-
el.appendChild(el.mask);
|
|
1795
|
-
cacheInstance.add(el);
|
|
1796
|
-
if (vals) {
|
|
1797
|
-
Promise.all(vals).catch((err) => {
|
|
1798
|
-
console.error(new Error("Promise handling errors"), err);
|
|
1799
|
-
}).finally(() => {
|
|
1800
|
-
unmount(el);
|
|
1801
|
-
});
|
|
1802
|
-
}
|
|
1803
|
-
} else {
|
|
1804
|
-
unmount(el);
|
|
2736
|
+
}
|
|
2737
|
+
}, null) : createVNode("i", {
|
|
2738
|
+
"class": `${classPrefix} ${classPrefix}-${name}`,
|
|
2739
|
+
"style": {
|
|
2740
|
+
fontSize: size,
|
|
2741
|
+
color: color2
|
|
2742
|
+
}
|
|
2743
|
+
}, null);
|
|
1805
2744
|
}
|
|
2745
|
+
});
|
|
2746
|
+
Icon.install = function(app) {
|
|
2747
|
+
app.component(Icon.name, Icon);
|
|
1806
2748
|
};
|
|
1807
|
-
|
|
1808
|
-
|
|
1809
|
-
|
|
1810
|
-
|
|
1811
|
-
|
|
1812
|
-
|
|
1813
|
-
el.removeAttribute("loadingtemplateref");
|
|
1814
|
-
};
|
|
1815
|
-
const handleProps = (el, vprops) => {
|
|
1816
|
-
const props = __spreadValues(__spreadValues({}, new LoadingProps()), vprops);
|
|
1817
|
-
const loadingTemplateRef = props.loadingTemplateRef;
|
|
1818
|
-
const loadingInstance = createComponent$1(loadingConstructor$1, __spreadValues({}, props), loadingTemplateRef ? () => loadingTemplateRef : null);
|
|
1819
|
-
el.style.position = props.positionType;
|
|
1820
|
-
el.options = props;
|
|
1821
|
-
el.instance = loadingInstance;
|
|
1822
|
-
el.mask = loadingInstance.proxy.$el;
|
|
1823
|
-
};
|
|
1824
|
-
const loadingDirective = {
|
|
1825
|
-
mounted: function(el, binding, vnode) {
|
|
1826
|
-
handleProps(el, vnode.props);
|
|
1827
|
-
removeAttribute(el);
|
|
1828
|
-
!isEmpty(binding.value) && toggleLoading(el, binding);
|
|
1829
|
-
},
|
|
1830
|
-
updated: function(el, binding, vnode) {
|
|
1831
|
-
if (!isEmpty(binding.value) && cacheInstance.has(el) || isEmpty(binding.value) && !cacheInstance.has(el))
|
|
1832
|
-
return;
|
|
1833
|
-
!cacheInstance.has(el) && handleProps(el, vnode.props);
|
|
1834
|
-
removeAttribute(el);
|
|
1835
|
-
toggleLoading(el, binding);
|
|
2749
|
+
var IconInstall = {
|
|
2750
|
+
title: "Icon \u56FE\u6807",
|
|
2751
|
+
category: "\u901A\u7528",
|
|
2752
|
+
status: "100%",
|
|
2753
|
+
install(app) {
|
|
2754
|
+
app.use(Icon);
|
|
1836
2755
|
}
|
|
1837
2756
|
};
|
|
1838
2757
|
const buttonProps = {
|
|
@@ -9430,18 +10349,6 @@ const dropdownProps = {
|
|
|
9430
10349
|
default: "102px"
|
|
9431
10350
|
}
|
|
9432
10351
|
};
|
|
9433
|
-
function isComponent(target) {
|
|
9434
|
-
return !!(target == null ? void 0 : target.$el);
|
|
9435
|
-
}
|
|
9436
|
-
function getElement(element) {
|
|
9437
|
-
if (element instanceof Element) {
|
|
9438
|
-
return element;
|
|
9439
|
-
}
|
|
9440
|
-
if (element && typeof element === "object" && element.$el instanceof Element) {
|
|
9441
|
-
return element.$el;
|
|
9442
|
-
}
|
|
9443
|
-
return null;
|
|
9444
|
-
}
|
|
9445
10352
|
function subscribeEvent(dom, type4, callback) {
|
|
9446
10353
|
dom == null ? void 0 : dom.addEventListener(type4, callback);
|
|
9447
10354
|
return () => {
|
|
@@ -9507,205 +10414,24 @@ const useDropdown = ({
|
|
|
9507
10414
|
originEnter = false;
|
|
9508
10415
|
if (!closeOnMouseLeaveMenu.value) {
|
|
9509
10416
|
handleLeave("origin");
|
|
9510
|
-
}
|
|
9511
|
-
}), subscribeEvent(dropdownEl, "mouseenter", () => {
|
|
9512
|
-
overlayEnter = true;
|
|
9513
|
-
visible.value = true;
|
|
9514
|
-
}), subscribeEvent(dropdownEl, "mouseleave", () => {
|
|
9515
|
-
overlayEnter = false;
|
|
9516
|
-
handleLeave("dropdown");
|
|
9517
|
-
}));
|
|
9518
|
-
}
|
|
9519
|
-
onInvalidate(() => subscriptions.forEach((v) => v()));
|
|
9520
|
-
});
|
|
9521
|
-
return { dropdownEl: dropdownElRef };
|
|
9522
|
-
};
|
|
9523
|
-
|
|
9524
|
-
|
|
9525
|
-
|
|
9526
|
-
|
|
9527
|
-
|
|
9528
|
-
setup(props, ctx2) {
|
|
9529
|
-
return () => {
|
|
9530
|
-
let _slot;
|
|
9531
|
-
return createVNode(Teleport, {
|
|
9532
|
-
"to": "#d-overlay-anchor"
|
|
9533
|
-
}, {
|
|
9534
|
-
default: () => [createVNode(Transition, {
|
|
9535
|
-
"name": "devui-overlay-fade"
|
|
9536
|
-
}, _isSlot$4(_slot = renderSlot(ctx2.slots, "default")) ? _slot : {
|
|
9537
|
-
default: () => [_slot]
|
|
9538
|
-
})]
|
|
9539
|
-
});
|
|
9540
|
-
};
|
|
9541
|
-
}
|
|
9542
|
-
});
|
|
9543
|
-
const overlayProps = {
|
|
9544
|
-
visible: {
|
|
9545
|
-
type: Boolean
|
|
9546
|
-
},
|
|
9547
|
-
backgroundBlock: {
|
|
9548
|
-
type: Boolean,
|
|
9549
|
-
default: false
|
|
9550
|
-
},
|
|
9551
|
-
backgroundClass: {
|
|
9552
|
-
type: String,
|
|
9553
|
-
default: ""
|
|
9554
|
-
},
|
|
9555
|
-
backgroundStyle: {
|
|
9556
|
-
type: [String, Object]
|
|
9557
|
-
},
|
|
9558
|
-
onBackdropClick: {
|
|
9559
|
-
type: Function
|
|
9560
|
-
},
|
|
9561
|
-
backdropClose: {
|
|
9562
|
-
type: Boolean,
|
|
9563
|
-
default: true
|
|
9564
|
-
},
|
|
9565
|
-
hasBackdrop: {
|
|
9566
|
-
type: Boolean,
|
|
9567
|
-
default: true
|
|
9568
|
-
}
|
|
9569
|
-
};
|
|
9570
|
-
const overlayEmits = ["update:visible", "backdropClick"];
|
|
9571
|
-
const fixedOverlayProps = __spreadProps(__spreadValues({}, overlayProps), {
|
|
9572
|
-
overlayStyle: {
|
|
9573
|
-
type: [String, Object],
|
|
9574
|
-
default: void 0
|
|
9575
|
-
}
|
|
9576
|
-
});
|
|
9577
|
-
const flexibleOverlayProps = __spreadValues({
|
|
9578
|
-
origin: {
|
|
9579
|
-
type: Object,
|
|
9580
|
-
require: true
|
|
9581
|
-
},
|
|
9582
|
-
position: {
|
|
9583
|
-
type: Object,
|
|
9584
|
-
default: () => ({
|
|
9585
|
-
originX: "left",
|
|
9586
|
-
originY: "top",
|
|
9587
|
-
overlayX: "left",
|
|
9588
|
-
overlayY: "top"
|
|
9589
|
-
})
|
|
9590
|
-
}
|
|
9591
|
-
}, overlayProps);
|
|
9592
|
-
function useOverlayLogic(props, ctx2) {
|
|
9593
|
-
const backgroundClass = computed(() => {
|
|
9594
|
-
return [
|
|
9595
|
-
"devui-overlay-background",
|
|
9596
|
-
props.backgroundClass,
|
|
9597
|
-
!props.hasBackdrop ? "devui-overlay-background__disabled" : "devui-overlay-background__color"
|
|
9598
|
-
];
|
|
9599
|
-
});
|
|
9600
|
-
const overlayClass = computed(() => {
|
|
9601
|
-
return "devui-overlay";
|
|
9602
|
-
});
|
|
9603
|
-
const handleBackdropClick = (event) => {
|
|
9604
|
-
var _a;
|
|
9605
|
-
event.preventDefault();
|
|
9606
|
-
(_a = props.onBackdropClick) == null ? void 0 : _a.call(props);
|
|
9607
|
-
if (props.backdropClose) {
|
|
9608
|
-
ctx2.emit("update:visible", false);
|
|
9609
|
-
}
|
|
9610
|
-
};
|
|
9611
|
-
const handleOverlayBubbleCancel = (event) => event.cancelBubble = true;
|
|
9612
|
-
onMounted(() => {
|
|
9613
|
-
const body2 = document.body;
|
|
9614
|
-
const originOverflow = body2.style.overflow;
|
|
9615
|
-
const originPosition = body2.style.position;
|
|
9616
|
-
watch([() => props.visible, () => props.backgroundBlock], ([visible, backgroundBlock]) => {
|
|
9617
|
-
if (backgroundBlock) {
|
|
9618
|
-
const top = body2.getBoundingClientRect().y;
|
|
9619
|
-
if (visible) {
|
|
9620
|
-
body2.style.overflowY = "scroll";
|
|
9621
|
-
body2.style.position = visible ? "fixed" : "";
|
|
9622
|
-
body2.style.top = `${top}px`;
|
|
9623
|
-
} else {
|
|
9624
|
-
body2.style.overflowY = originOverflow;
|
|
9625
|
-
body2.style.position = originPosition;
|
|
9626
|
-
body2.style.top = "";
|
|
9627
|
-
window.scrollTo(0, -top);
|
|
9628
|
-
}
|
|
9629
|
-
}
|
|
9630
|
-
});
|
|
9631
|
-
onUnmounted(() => {
|
|
9632
|
-
document.body.style.overflow = originOverflow;
|
|
9633
|
-
});
|
|
9634
|
-
});
|
|
9635
|
-
return {
|
|
9636
|
-
backgroundClass,
|
|
9637
|
-
overlayClass,
|
|
9638
|
-
handleBackdropClick,
|
|
9639
|
-
handleOverlayBubbleCancel
|
|
9640
|
-
};
|
|
9641
|
-
}
|
|
9642
|
-
const FixedOverlay = defineComponent$1({
|
|
9643
|
-
name: "DFixedOverlay",
|
|
9644
|
-
props: fixedOverlayProps,
|
|
9645
|
-
emits: overlayEmits,
|
|
9646
|
-
setup(props, ctx2) {
|
|
9647
|
-
const {
|
|
9648
|
-
backgroundClass,
|
|
9649
|
-
overlayClass,
|
|
9650
|
-
handleBackdropClick,
|
|
9651
|
-
handleOverlayBubbleCancel
|
|
9652
|
-
} = useOverlayLogic(props, ctx2);
|
|
9653
|
-
return () => createVNode(CommonOverlay, null, {
|
|
9654
|
-
default: () => [withDirectives(createVNode("div", {
|
|
9655
|
-
"class": backgroundClass.value,
|
|
9656
|
-
"style": props.backgroundStyle,
|
|
9657
|
-
"onClick": handleBackdropClick
|
|
9658
|
-
}, [createVNode("div", {
|
|
9659
|
-
"class": overlayClass.value,
|
|
9660
|
-
"style": props.overlayStyle,
|
|
9661
|
-
"onClick": handleOverlayBubbleCancel
|
|
9662
|
-
}, [renderSlot(ctx2.slots, "default")])]), [[vShow, props.visible]])]
|
|
9663
|
-
});
|
|
9664
|
-
}
|
|
9665
|
-
});
|
|
9666
|
-
const FlexibleOverlay = defineComponent$1({
|
|
9667
|
-
name: "DFlexibleOverlay",
|
|
9668
|
-
props: flexibleOverlayProps,
|
|
9669
|
-
emits: overlayEmits,
|
|
9670
|
-
setup(props, ctx2) {
|
|
9671
|
-
const overlayRef = ref(null);
|
|
9672
|
-
const positionedStyle = reactive({
|
|
9673
|
-
position: "absolute"
|
|
9674
|
-
});
|
|
9675
|
-
onMounted(async () => {
|
|
9676
|
-
const handleRectChange = (position, rect, origin) => {
|
|
9677
|
-
const point = calculatePosition(position, rect, origin);
|
|
9678
|
-
positionedStyle.left = `${point.x}px`;
|
|
9679
|
-
positionedStyle.top = `${point.y}px`;
|
|
9680
|
-
};
|
|
9681
|
-
const locationElements = computed(() => {
|
|
9682
|
-
const overlay2 = overlayRef.value;
|
|
9683
|
-
const origin = getOrigin(props.origin);
|
|
9684
|
-
if (!overlay2 || !origin) {
|
|
9685
|
-
return;
|
|
9686
|
-
}
|
|
9687
|
-
return {
|
|
9688
|
-
origin,
|
|
9689
|
-
overlay: overlay2
|
|
9690
|
-
};
|
|
9691
|
-
});
|
|
9692
|
-
const visibleRef = toRef(props, "visible");
|
|
9693
|
-
const positionRef = toRef(props, "position");
|
|
9694
|
-
watch([locationElements, visibleRef, positionRef], async ([locationElements2, visible, position], ov, onInvalidate) => {
|
|
9695
|
-
if (!visible || !locationElements2) {
|
|
9696
|
-
return;
|
|
9697
|
-
}
|
|
9698
|
-
const {
|
|
9699
|
-
origin,
|
|
9700
|
-
overlay: overlay2
|
|
9701
|
-
} = locationElements2;
|
|
9702
|
-
handleRectChange(position, overlay2.getBoundingClientRect(), origin);
|
|
9703
|
-
const unsubscriptions = [subscribeLayoutEvent(() => handleRectChange(position, overlay2.getBoundingClientRect(), origin)), subscribeOverlayResize(overlay2, (entries) => handleRectChange(position, entries[0].contentRect, origin)), subscribeOriginResize(origin, () => handleRectChange(position, overlay2.getBoundingClientRect(), origin))];
|
|
9704
|
-
onInvalidate(() => {
|
|
9705
|
-
unsubscriptions.forEach((fn) => fn());
|
|
9706
|
-
});
|
|
9707
|
-
});
|
|
9708
|
-
});
|
|
10417
|
+
}
|
|
10418
|
+
}), subscribeEvent(dropdownEl, "mouseenter", () => {
|
|
10419
|
+
overlayEnter = true;
|
|
10420
|
+
visible.value = true;
|
|
10421
|
+
}), subscribeEvent(dropdownEl, "mouseleave", () => {
|
|
10422
|
+
overlayEnter = false;
|
|
10423
|
+
handleLeave("dropdown");
|
|
10424
|
+
}));
|
|
10425
|
+
}
|
|
10426
|
+
onInvalidate(() => subscriptions.forEach((v) => v()));
|
|
10427
|
+
});
|
|
10428
|
+
return { dropdownEl: dropdownElRef };
|
|
10429
|
+
};
|
|
10430
|
+
const FixedOverlay = defineComponent$1({
|
|
10431
|
+
name: "DFixedOverlay",
|
|
10432
|
+
props: fixedOverlayProps,
|
|
10433
|
+
emits: overlayEmits,
|
|
10434
|
+
setup(props, ctx2) {
|
|
9709
10435
|
const {
|
|
9710
10436
|
backgroundClass,
|
|
9711
10437
|
overlayClass,
|
|
@@ -9714,122 +10440,17 @@ const FlexibleOverlay = defineComponent$1({
|
|
|
9714
10440
|
} = useOverlayLogic(props, ctx2);
|
|
9715
10441
|
return () => createVNode(CommonOverlay, null, {
|
|
9716
10442
|
default: () => [withDirectives(createVNode("div", {
|
|
9717
|
-
"style": props.backgroundStyle,
|
|
9718
10443
|
"class": backgroundClass.value,
|
|
10444
|
+
"style": props.backgroundStyle,
|
|
9719
10445
|
"onClick": handleBackdropClick
|
|
9720
10446
|
}, [createVNode("div", {
|
|
9721
|
-
"ref": overlayRef,
|
|
9722
10447
|
"class": overlayClass.value,
|
|
9723
|
-
"style":
|
|
10448
|
+
"style": props.overlayStyle,
|
|
9724
10449
|
"onClick": handleOverlayBubbleCancel
|
|
9725
10450
|
}, [renderSlot(ctx2.slots, "default")])]), [[vShow, props.visible]])]
|
|
9726
10451
|
});
|
|
9727
10452
|
}
|
|
9728
10453
|
});
|
|
9729
|
-
function getOrigin(origin) {
|
|
9730
|
-
if (origin instanceof Element) {
|
|
9731
|
-
return origin;
|
|
9732
|
-
}
|
|
9733
|
-
if (isRef$1(origin)) {
|
|
9734
|
-
return getElement(origin.value);
|
|
9735
|
-
}
|
|
9736
|
-
if (isComponent(origin)) {
|
|
9737
|
-
return getElement(origin);
|
|
9738
|
-
}
|
|
9739
|
-
return origin;
|
|
9740
|
-
}
|
|
9741
|
-
function calculatePosition(position, rect, origin) {
|
|
9742
|
-
const originRect = getOriginRect(origin);
|
|
9743
|
-
const originPoint = getOriginRelativePoint(originRect, position);
|
|
9744
|
-
return getOverlayPoint(originPoint, rect, position);
|
|
9745
|
-
}
|
|
9746
|
-
function getOriginRect(origin) {
|
|
9747
|
-
if (origin instanceof Element) {
|
|
9748
|
-
return origin.getBoundingClientRect();
|
|
9749
|
-
}
|
|
9750
|
-
const width = origin.width || 0;
|
|
9751
|
-
const height = origin.height || 0;
|
|
9752
|
-
return {
|
|
9753
|
-
top: origin.y,
|
|
9754
|
-
bottom: origin.y + height,
|
|
9755
|
-
left: origin.x,
|
|
9756
|
-
right: origin.x + width,
|
|
9757
|
-
height,
|
|
9758
|
-
width
|
|
9759
|
-
};
|
|
9760
|
-
}
|
|
9761
|
-
function getOverlayPoint(originPoint, rect, position) {
|
|
9762
|
-
let x;
|
|
9763
|
-
const {
|
|
9764
|
-
width,
|
|
9765
|
-
height
|
|
9766
|
-
} = rect;
|
|
9767
|
-
if (position.overlayX == "center") {
|
|
9768
|
-
x = originPoint.x - width / 2;
|
|
9769
|
-
} else {
|
|
9770
|
-
x = position.overlayX == "left" ? originPoint.x : originPoint.x - width;
|
|
9771
|
-
}
|
|
9772
|
-
let y;
|
|
9773
|
-
if (position.overlayY == "center") {
|
|
9774
|
-
y = originPoint.y - height / 2;
|
|
9775
|
-
} else {
|
|
9776
|
-
y = position.overlayY == "top" ? originPoint.y : originPoint.y - height;
|
|
9777
|
-
}
|
|
9778
|
-
return {
|
|
9779
|
-
x,
|
|
9780
|
-
y
|
|
9781
|
-
};
|
|
9782
|
-
}
|
|
9783
|
-
function getOriginRelativePoint(originRect, position) {
|
|
9784
|
-
let x;
|
|
9785
|
-
if (position.originX == "center") {
|
|
9786
|
-
x = originRect.left + originRect.width / 2;
|
|
9787
|
-
} else {
|
|
9788
|
-
const startX = originRect.left;
|
|
9789
|
-
const endX = originRect.right;
|
|
9790
|
-
x = position.originX == "left" ? startX : endX;
|
|
9791
|
-
}
|
|
9792
|
-
let y;
|
|
9793
|
-
if (position.originY == "center") {
|
|
9794
|
-
y = originRect.top + originRect.height / 2;
|
|
9795
|
-
} else {
|
|
9796
|
-
y = position.originY == "top" ? originRect.top : originRect.bottom;
|
|
9797
|
-
}
|
|
9798
|
-
return {
|
|
9799
|
-
x,
|
|
9800
|
-
y
|
|
9801
|
-
};
|
|
9802
|
-
}
|
|
9803
|
-
function subscribeLayoutEvent(event) {
|
|
9804
|
-
window.addEventListener("scroll", event, true);
|
|
9805
|
-
window.addEventListener("resize", event);
|
|
9806
|
-
window.addEventListener("orientationchange", event);
|
|
9807
|
-
return () => {
|
|
9808
|
-
window.removeEventListener("scroll", event, true);
|
|
9809
|
-
window.removeEventListener("resize", event);
|
|
9810
|
-
window.removeEventListener("orientationchange", event);
|
|
9811
|
-
};
|
|
9812
|
-
}
|
|
9813
|
-
function subscribeOverlayResize(overlay2, callback) {
|
|
9814
|
-
if (overlay2 instanceof Element) {
|
|
9815
|
-
const resizeObserver = new ResizeObserver(callback);
|
|
9816
|
-
resizeObserver.observe(overlay2);
|
|
9817
|
-
return () => resizeObserver.disconnect();
|
|
9818
|
-
}
|
|
9819
|
-
return () => {
|
|
9820
|
-
};
|
|
9821
|
-
}
|
|
9822
|
-
function subscribeOriginResize(origin, callback) {
|
|
9823
|
-
if (origin instanceof Element) {
|
|
9824
|
-
const observer = new MutationObserver(callback);
|
|
9825
|
-
observer.observe(origin, {
|
|
9826
|
-
attributeFilter: ["style"]
|
|
9827
|
-
});
|
|
9828
|
-
return () => observer.disconnect();
|
|
9829
|
-
}
|
|
9830
|
-
return () => {
|
|
9831
|
-
};
|
|
9832
|
-
}
|
|
9833
10454
|
FlexibleOverlay.install = function(app) {
|
|
9834
10455
|
app.component(FlexibleOverlay.name, FlexibleOverlay);
|
|
9835
10456
|
};
|
|
@@ -9981,137 +10602,72 @@ const editableSelectProps = {
|
|
|
9981
10602
|
};
|
|
9982
10603
|
const selectDropdownProps = {
|
|
9983
10604
|
options: {
|
|
9984
|
-
type: Array,
|
|
9985
|
-
default: () => []
|
|
9986
|
-
}
|
|
9987
|
-
};
|
|
9988
|
-
function className$2(classStr, classOpt) {
|
|
9989
|
-
let classname = classStr;
|
|
9990
|
-
if (typeof classOpt === "object") {
|
|
9991
|
-
Object.keys(classOpt).forEach((key) => {
|
|
9992
|
-
classOpt[key] && (classname += ` ${key}`);
|
|
9993
|
-
});
|
|
9994
|
-
}
|
|
9995
|
-
return classname;
|
|
9996
|
-
}
|
|
9997
|
-
var SelectDropdown = defineComponent$1({
|
|
9998
|
-
name: "DSelectDropdown",
|
|
9999
|
-
props: selectDropdownProps,
|
|
10000
|
-
setup(props) {
|
|
10001
|
-
const select2 = inject("InjectionKey");
|
|
10002
|
-
const {
|
|
10003
|
-
props: selectProps2,
|
|
10004
|
-
dropdownRef,
|
|
10005
|
-
visible,
|
|
10006
|
-
selectOptionClick,
|
|
10007
|
-
renderDefaultSlots,
|
|
10008
|
-
renderEmptySlots,
|
|
10009
|
-
selectedIndex,
|
|
10010
|
-
hoverIndex,
|
|
10011
|
-
loadMore
|
|
10012
|
-
} = select2;
|
|
10013
|
-
const {
|
|
10014
|
-
maxHeight
|
|
10015
|
-
} = selectProps2;
|
|
10016
|
-
return () => {
|
|
10017
|
-
const getLiCls = (item2, index2) => {
|
|
10018
|
-
const {
|
|
10019
|
-
disabledKey
|
|
10020
|
-
} = selectProps2;
|
|
10021
|
-
return className$2("devui-dropdown-item", {
|
|
10022
|
-
disabled: disabledKey ? !!item2[disabledKey] : false,
|
|
10023
|
-
selected: selectedIndex.value === index2,
|
|
10024
|
-
"devui-dropdown-bg": hoverIndex.value === index2
|
|
10025
|
-
});
|
|
10026
|
-
};
|
|
10027
|
-
return withDirectives(createVNode("div", {
|
|
10028
|
-
"class": "devui-dropdown-menu"
|
|
10029
|
-
}, [createVNode("ul", {
|
|
10030
|
-
"ref": dropdownRef,
|
|
10031
|
-
"class": "devui-list-unstyled scroll-height",
|
|
10032
|
-
"style": {
|
|
10033
|
-
maxHeight: maxHeight + "px"
|
|
10034
|
-
},
|
|
10035
|
-
"onScroll": loadMore
|
|
10036
|
-
}, [props.options.map((o, index2) => {
|
|
10037
|
-
return createVNode("li", {
|
|
10038
|
-
"class": getLiCls(o, index2),
|
|
10039
|
-
"onClick": ($evnet) => selectOptionClick($evnet, o)
|
|
10040
|
-
}, [renderDefaultSlots(o)]);
|
|
10041
|
-
}), withDirectives(createVNode("li", {
|
|
10042
|
-
"class": "devui-no-result-template"
|
|
10043
|
-
}, [createVNode("div", {
|
|
10044
|
-
"class": "devui-no-data-tip"
|
|
10045
|
-
}, [renderEmptySlots()])]), [[vShow, props.options.length === 0]])])]), [[vShow, visible]]);
|
|
10046
|
-
};
|
|
10047
|
-
}
|
|
10048
|
-
});
|
|
10049
|
-
var editableSelect = "";
|
|
10050
|
-
function on(element, eventName, handler) {
|
|
10051
|
-
if (document.addEventListener) {
|
|
10052
|
-
if (element && eventName && handler) {
|
|
10053
|
-
element.addEventListener(eventName, handler, false);
|
|
10054
|
-
}
|
|
10055
|
-
} else {
|
|
10056
|
-
if (element && eventName && handler) {
|
|
10057
|
-
element.attachEvent("on" + eventName, handler);
|
|
10058
|
-
}
|
|
10059
|
-
}
|
|
10060
|
-
}
|
|
10061
|
-
function off(element, eventName, handler) {
|
|
10062
|
-
if (document.removeEventListener) {
|
|
10063
|
-
if (element && eventName && handler) {
|
|
10064
|
-
element.removeEventListener(eventName, handler, false);
|
|
10065
|
-
}
|
|
10066
|
-
} else {
|
|
10067
|
-
if (element && eventName && handler) {
|
|
10068
|
-
element.detachEvent("on" + eventName, handler);
|
|
10069
|
-
}
|
|
10070
|
-
}
|
|
10071
|
-
}
|
|
10072
|
-
const ctx = Symbol("@@clickoutside");
|
|
10073
|
-
const nodeList = new Map();
|
|
10074
|
-
let startClick;
|
|
10075
|
-
let nid = 0;
|
|
10076
|
-
let isFirst = true;
|
|
10077
|
-
function createDocumentHandler(el, binding, vnode) {
|
|
10078
|
-
if (inBrowser && isFirst) {
|
|
10079
|
-
isFirst = false;
|
|
10080
|
-
on(document, "mousedown", (e) => {
|
|
10081
|
-
startClick = e;
|
|
10082
|
-
});
|
|
10083
|
-
on(document, "mouseup", (e) => {
|
|
10084
|
-
for (const [id, node] of nodeList) {
|
|
10085
|
-
node[ctx].documentHandler(e, startClick);
|
|
10086
|
-
}
|
|
10087
|
-
});
|
|
10088
|
-
}
|
|
10089
|
-
return function(mouseup, mousedown) {
|
|
10090
|
-
if (!vnode || !binding.instance || !mouseup.target || !mousedown.target || el.contains(mouseup.target) || el.contains(mousedown.target) || el === mouseup.target) {
|
|
10091
|
-
return;
|
|
10092
|
-
}
|
|
10093
|
-
el[ctx].bindingFn && el[ctx].bindingFn();
|
|
10094
|
-
};
|
|
10095
|
-
}
|
|
10096
|
-
const clickoutsideDirective = {
|
|
10097
|
-
beforeMount: function(el, binding, vnode) {
|
|
10098
|
-
nid++;
|
|
10099
|
-
nodeList.set(nid, el);
|
|
10100
|
-
el[ctx] = {
|
|
10101
|
-
nid,
|
|
10102
|
-
documentHandler: createDocumentHandler(el, binding, vnode),
|
|
10103
|
-
bindingFn: binding.value
|
|
10104
|
-
};
|
|
10105
|
-
},
|
|
10106
|
-
updated: function(el, binding, vnode) {
|
|
10107
|
-
el[ctx].documentHandler = createDocumentHandler(el, binding, vnode);
|
|
10108
|
-
el[ctx].bindingFn = binding.value;
|
|
10109
|
-
},
|
|
10110
|
-
unmounted: function(el) {
|
|
10111
|
-
nodeList.delete(el[ctx].nid);
|
|
10112
|
-
delete el[ctx];
|
|
10605
|
+
type: Array,
|
|
10606
|
+
default: () => []
|
|
10113
10607
|
}
|
|
10114
10608
|
};
|
|
10609
|
+
function className$2(classStr, classOpt) {
|
|
10610
|
+
let classname = classStr;
|
|
10611
|
+
if (typeof classOpt === "object") {
|
|
10612
|
+
Object.keys(classOpt).forEach((key) => {
|
|
10613
|
+
classOpt[key] && (classname += ` ${key}`);
|
|
10614
|
+
});
|
|
10615
|
+
}
|
|
10616
|
+
return classname;
|
|
10617
|
+
}
|
|
10618
|
+
var SelectDropdown = defineComponent$1({
|
|
10619
|
+
name: "DSelectDropdown",
|
|
10620
|
+
props: selectDropdownProps,
|
|
10621
|
+
setup(props) {
|
|
10622
|
+
const select2 = inject("InjectionKey");
|
|
10623
|
+
const {
|
|
10624
|
+
props: selectProps2,
|
|
10625
|
+
dropdownRef,
|
|
10626
|
+
visible,
|
|
10627
|
+
selectOptionClick,
|
|
10628
|
+
renderDefaultSlots,
|
|
10629
|
+
renderEmptySlots,
|
|
10630
|
+
selectedIndex,
|
|
10631
|
+
hoverIndex,
|
|
10632
|
+
loadMore
|
|
10633
|
+
} = select2;
|
|
10634
|
+
const {
|
|
10635
|
+
maxHeight
|
|
10636
|
+
} = selectProps2;
|
|
10637
|
+
return () => {
|
|
10638
|
+
const getLiCls = (item2, index2) => {
|
|
10639
|
+
const {
|
|
10640
|
+
disabledKey
|
|
10641
|
+
} = selectProps2;
|
|
10642
|
+
return className$2("devui-dropdown-item", {
|
|
10643
|
+
disabled: disabledKey ? !!item2[disabledKey] : false,
|
|
10644
|
+
selected: selectedIndex.value === index2,
|
|
10645
|
+
"devui-dropdown-bg": hoverIndex.value === index2
|
|
10646
|
+
});
|
|
10647
|
+
};
|
|
10648
|
+
return withDirectives(createVNode("div", {
|
|
10649
|
+
"class": "devui-dropdown-menu"
|
|
10650
|
+
}, [createVNode("ul", {
|
|
10651
|
+
"ref": dropdownRef,
|
|
10652
|
+
"class": "devui-list-unstyled scroll-height",
|
|
10653
|
+
"style": {
|
|
10654
|
+
maxHeight: maxHeight + "px"
|
|
10655
|
+
},
|
|
10656
|
+
"onScroll": loadMore
|
|
10657
|
+
}, [props.options.map((o, index2) => {
|
|
10658
|
+
return createVNode("li", {
|
|
10659
|
+
"class": getLiCls(o, index2),
|
|
10660
|
+
"onClick": ($evnet) => selectOptionClick($evnet, o)
|
|
10661
|
+
}, [renderDefaultSlots(o)]);
|
|
10662
|
+
}), withDirectives(createVNode("li", {
|
|
10663
|
+
"class": "devui-no-result-template"
|
|
10664
|
+
}, [createVNode("div", {
|
|
10665
|
+
"class": "devui-no-data-tip"
|
|
10666
|
+
}, [renderEmptySlots()])]), [[vShow, props.options.length === 0]])])]), [[vShow, visible]]);
|
|
10667
|
+
};
|
|
10668
|
+
}
|
|
10669
|
+
});
|
|
10670
|
+
var editableSelect = "";
|
|
10115
10671
|
var commonjsGlobal = typeof globalThis !== "undefined" ? globalThis : typeof window !== "undefined" ? window : typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : {};
|
|
10116
10672
|
var lodash = { exports: {} };
|
|
10117
10673
|
/**
|
|
@@ -16180,6 +16736,9 @@ var FormItem = defineComponent$1({
|
|
|
16180
16736
|
var formControl = "";
|
|
16181
16737
|
var FormControl = defineComponent$1({
|
|
16182
16738
|
name: "DFormControl",
|
|
16739
|
+
directives: {
|
|
16740
|
+
clickoutside: clickoutsideDirective
|
|
16741
|
+
},
|
|
16183
16742
|
props: formControlProps,
|
|
16184
16743
|
setup(props, ctx2) {
|
|
16185
16744
|
const formControl2 = ref();
|
|
@@ -16188,6 +16747,7 @@ var FormControl = defineComponent$1({
|
|
|
16188
16747
|
const isHorizontal = labelData.layout === "horizontal";
|
|
16189
16748
|
const uid = uniqueId("dfc-");
|
|
16190
16749
|
const showPopover = ref(false);
|
|
16750
|
+
const updateOn = ref("change");
|
|
16191
16751
|
const tipMessage = ref("");
|
|
16192
16752
|
const popPosition = ref("bottom");
|
|
16193
16753
|
let rectInfo = {
|
|
@@ -16204,13 +16764,15 @@ var FormControl = defineComponent$1({
|
|
|
16204
16764
|
const el = document.getElementById(uid);
|
|
16205
16765
|
elOffset = getElOffset(el);
|
|
16206
16766
|
EventBus.on("showPopoverErrorMessage", (data) => {
|
|
16767
|
+
var _a;
|
|
16207
16768
|
if (uid === data.uid) {
|
|
16208
16769
|
rectInfo = el.getBoundingClientRect();
|
|
16209
|
-
popoverLeftPosition = popPosition.value === "top" || popPosition.value === "bottom" ? rectInfo.right - rectInfo.width / 2 : rectInfo.right;
|
|
16210
|
-
popoverTopPosition = popPosition.value === "top" ? elOffset.top + rectInfo.height / 2 - rectInfo.height : elOffset.top + rectInfo.height / 2;
|
|
16211
16770
|
showPopover.value = data.showPopover;
|
|
16212
16771
|
tipMessage.value = data.message;
|
|
16213
16772
|
popPosition.value = data.popPosition;
|
|
16773
|
+
popoverLeftPosition = popPosition.value === "top" || popPosition.value === "bottom" ? rectInfo.right - rectInfo.width / 2 : rectInfo.right;
|
|
16774
|
+
popoverTopPosition = popPosition.value === "top" ? elOffset.top + rectInfo.height / 2 - rectInfo.height : elOffset.top + rectInfo.height / 2;
|
|
16775
|
+
updateOn.value = (_a = data.updateOn) != null ? _a : "change";
|
|
16214
16776
|
}
|
|
16215
16777
|
});
|
|
16216
16778
|
});
|
|
@@ -16238,17 +16800,22 @@ var FormControl = defineComponent$1({
|
|
|
16238
16800
|
};
|
|
16239
16801
|
}
|
|
16240
16802
|
});
|
|
16803
|
+
const handleClickOutside = () => {
|
|
16804
|
+
if (updateOn.value !== "change") {
|
|
16805
|
+
showPopover.value = false;
|
|
16806
|
+
}
|
|
16807
|
+
};
|
|
16241
16808
|
return () => {
|
|
16242
16809
|
var _a, _b, _c, _d, _e, _f, _g, _h;
|
|
16243
16810
|
const {
|
|
16244
16811
|
feedbackStatus,
|
|
16245
16812
|
extraInfo
|
|
16246
16813
|
} = props;
|
|
16247
|
-
return createVNode("div", {
|
|
16814
|
+
return withDirectives(createVNode("div", {
|
|
16248
16815
|
"class": "form-control",
|
|
16249
16816
|
"ref": formControl2,
|
|
16250
16817
|
"data-uid": uid
|
|
16251
|
-
}, [createVNode(Teleport, {
|
|
16818
|
+
}, [showPopover.value && createVNode(Teleport, {
|
|
16252
16819
|
"to": "body"
|
|
16253
16820
|
}, {
|
|
16254
16821
|
default: () => [createVNode("div", {
|
|
@@ -16260,6 +16827,7 @@ var FormControl = defineComponent$1({
|
|
|
16260
16827
|
height: rectInfo.height + "px"
|
|
16261
16828
|
}
|
|
16262
16829
|
}, [createVNode(Popover, {
|
|
16830
|
+
"controlled": updateOn.value !== "change",
|
|
16263
16831
|
"visible": showPopover.value,
|
|
16264
16832
|
"content": tipMessage.value,
|
|
16265
16833
|
"popType": "error",
|
|
@@ -16277,7 +16845,7 @@ var FormControl = defineComponent$1({
|
|
|
16277
16845
|
"color": iconData.value.color
|
|
16278
16846
|
}, null)])]), extraInfo && createVNode("div", {
|
|
16279
16847
|
"class": "devui-form-control-extra-info"
|
|
16280
|
-
}, [extraInfo])]);
|
|
16848
|
+
}, [extraInfo])]), [[resolveDirective("clickoutside"), handleClickOutside]]);
|
|
16281
16849
|
};
|
|
16282
16850
|
}
|
|
16283
16851
|
});
|
|
@@ -16446,13 +17014,25 @@ function handleErrorStrategyPass(el) {
|
|
|
16446
17014
|
index2 !== -1 && classList.splice(index2, 1);
|
|
16447
17015
|
el.setAttribute("class", classList.join(" "));
|
|
16448
17016
|
}
|
|
16449
|
-
function
|
|
17017
|
+
function getFormControlUID(el) {
|
|
17018
|
+
if (el.tagName.toLocaleLowerCase() === "body")
|
|
17019
|
+
return "";
|
|
17020
|
+
if (el.parentElement.id.startsWith("dfc-")) {
|
|
17021
|
+
return el.parentElement.id;
|
|
17022
|
+
} else {
|
|
17023
|
+
getFormControlUID(el.parentElement);
|
|
17024
|
+
}
|
|
17025
|
+
}
|
|
17026
|
+
function handleValidateError({ el, tipEl, message = "", isFormTag, messageShowType, dfcUID, popPosition = "right-bottom", updateOn }) {
|
|
16450
17027
|
if (isFormTag && messageShowType === MessageShowTypeEnum.toast) {
|
|
16451
17028
|
alert(message);
|
|
16452
17029
|
return;
|
|
16453
17030
|
}
|
|
17031
|
+
if (!dfcUID) {
|
|
17032
|
+
dfcUID = getFormControlUID(el);
|
|
17033
|
+
}
|
|
16454
17034
|
if (MessageShowTypeEnum.popover === messageShowType) {
|
|
16455
|
-
EventBus.emit("showPopoverErrorMessage", { showPopover: true, message, uid: dfcUID, popPosition });
|
|
17035
|
+
EventBus.emit("showPopoverErrorMessage", { showPopover: true, message, uid: dfcUID, popPosition, updateOn });
|
|
16456
17036
|
return;
|
|
16457
17037
|
}
|
|
16458
17038
|
tipEl.innerText = "" + message;
|
|
@@ -16474,7 +17054,7 @@ function getFormName(binding) {
|
|
|
16474
17054
|
const key = Object.keys(_refs)[0];
|
|
16475
17055
|
return _refs[key]["name"];
|
|
16476
17056
|
}
|
|
16477
|
-
function validateFn({ validator, modelValue, el, tipEl, isFormTag, messageShowType, dfcUID, popPosition }) {
|
|
17057
|
+
function validateFn({ validator, modelValue, el, tipEl, isFormTag, messageShowType, dfcUID, popPosition, updateOn }) {
|
|
16478
17058
|
validator.validate({ modelName: modelValue }).then(() => {
|
|
16479
17059
|
handleValidatePass(el, tipEl);
|
|
16480
17060
|
}).catch((err) => {
|
|
@@ -16487,7 +17067,7 @@ function validateFn({ validator, modelValue, el, tipEl, isFormTag, messageShowTy
|
|
|
16487
17067
|
} else {
|
|
16488
17068
|
msg = errors[0].message;
|
|
16489
17069
|
}
|
|
16490
|
-
handleValidateError({ el, tipEl, message: msg, isFormTag, messageShowType, dfcUID, popPosition });
|
|
17070
|
+
handleValidateError({ el, tipEl, message: msg, isFormTag, messageShowType, dfcUID, popPosition, updateOn });
|
|
16491
17071
|
});
|
|
16492
17072
|
}
|
|
16493
17073
|
function checkValidPopsition(positionStr) {
|
|
@@ -16586,11 +17166,16 @@ var dValidateRules = {
|
|
|
16586
17166
|
const htmlEventValidateHandler = (e) => {
|
|
16587
17167
|
const modelValue = e.target.value;
|
|
16588
17168
|
if (messageShowType === MessageShowTypeEnum.popover) {
|
|
16589
|
-
EventBus.emit("showPopoverErrorMessage", { showPopover: false, message: "", uid: dfcUID, popPosition });
|
|
17169
|
+
EventBus.emit("showPopoverErrorMessage", { showPopover: false, message: "", uid: dfcUID, popPosition, updateOn });
|
|
16590
17170
|
}
|
|
16591
|
-
validateFn({ validator, modelValue, el, tipEl, isFormTag: false, messageShowType, dfcUID, popPosition });
|
|
17171
|
+
validateFn({ validator, modelValue, el, tipEl, isFormTag: false, messageShowType, dfcUID, popPosition, updateOn });
|
|
16592
17172
|
};
|
|
16593
17173
|
vnode.children[0].el.addEventListener(updateOn, htmlEventValidateHandler);
|
|
17174
|
+
if (messageShowType === MessageShowTypeEnum.popover && updateOn === UpdateOnEnum.change) {
|
|
17175
|
+
vnode.children[0].el.addEventListener("focus", () => {
|
|
17176
|
+
EventBus.emit("showPopoverErrorMessage", { showPopover: false, uid: dfcUID, updateOn });
|
|
17177
|
+
});
|
|
17178
|
+
}
|
|
16594
17179
|
if (errorStrategy === ErrorStrategyEnum.pristine) {
|
|
16595
17180
|
handleErrorStrategy(el);
|
|
16596
17181
|
vnode.children[0].props.value = "" + vnode.children[0].props.value;
|
|
@@ -16598,7 +17183,7 @@ var dValidateRules = {
|
|
|
16598
17183
|
const formName = getFormName(binding);
|
|
16599
17184
|
formName && EventBus.on(`formSubmit:${formName}`, () => {
|
|
16600
17185
|
const modelValue = isFormTag ? "" : vnode.children[0].el.value;
|
|
16601
|
-
validateFn({ validator, modelValue, el, tipEl, isFormTag, messageShowType });
|
|
17186
|
+
validateFn({ validator, modelValue, el, tipEl, isFormTag, messageShowType, updateOn: "submit" });
|
|
16602
17187
|
});
|
|
16603
17188
|
}
|
|
16604
17189
|
};
|
|
@@ -18727,7 +19312,7 @@ const getRangeValueOf = (value, min, max) => {
|
|
|
18727
19312
|
}
|
|
18728
19313
|
return value;
|
|
18729
19314
|
};
|
|
18730
|
-
function _isSlot$
|
|
19315
|
+
function _isSlot$4(s) {
|
|
18731
19316
|
return typeof s === "function" || Object.prototype.toString.call(s) === "[object Object]" && !isVNode(s);
|
|
18732
19317
|
}
|
|
18733
19318
|
var Dialog = defineComponent$1({
|
|
@@ -18792,7 +19377,7 @@ var Dialog = defineComponent$1({
|
|
|
18792
19377
|
"variant": variant,
|
|
18793
19378
|
"disabled": disabled,
|
|
18794
19379
|
"onClick": handler
|
|
18795
|
-
}, _isSlot$
|
|
19380
|
+
}, _isSlot$4(text) ? text : {
|
|
18796
19381
|
default: () => [text]
|
|
18797
19382
|
});
|
|
18798
19383
|
});
|
|
@@ -21043,7 +21628,7 @@ var Radio = defineComponent$1({
|
|
|
21043
21628
|
}
|
|
21044
21629
|
});
|
|
21045
21630
|
var radioGroup = "";
|
|
21046
|
-
function _isSlot$
|
|
21631
|
+
function _isSlot$3(s) {
|
|
21047
21632
|
return typeof s === "function" || Object.prototype.toString.call(s) === "[object Object]" && !isVNode(s);
|
|
21048
21633
|
}
|
|
21049
21634
|
var RadioGroup = defineComponent$1({
|
|
@@ -21079,7 +21664,7 @@ var RadioGroup = defineComponent$1({
|
|
|
21079
21664
|
return createVNode(Radio, {
|
|
21080
21665
|
"key": item2,
|
|
21081
21666
|
"value": item2
|
|
21082
|
-
}, _isSlot$
|
|
21667
|
+
}, _isSlot$3(item2) ? item2 : {
|
|
21083
21668
|
default: () => [item2]
|
|
21084
21669
|
});
|
|
21085
21670
|
});
|
|
@@ -23580,11 +24165,11 @@ const statisticProps = {
|
|
|
23580
24165
|
},
|
|
23581
24166
|
groupSeparator: {
|
|
23582
24167
|
type: String,
|
|
23583
|
-
default: "
|
|
24168
|
+
default: ""
|
|
23584
24169
|
},
|
|
23585
24170
|
showGroupSeparator: {
|
|
23586
24171
|
type: Boolean,
|
|
23587
|
-
default:
|
|
24172
|
+
default: true
|
|
23588
24173
|
},
|
|
23589
24174
|
titleStyle: {
|
|
23590
24175
|
type: Object
|
|
@@ -27292,7 +27877,37 @@ var TooltipInstall = {
|
|
|
27292
27877
|
app.use(DTooltip);
|
|
27293
27878
|
}
|
|
27294
27879
|
};
|
|
27295
|
-
const
|
|
27880
|
+
const transferCommon = {
|
|
27881
|
+
showTooltip: {
|
|
27882
|
+
type: Boolean,
|
|
27883
|
+
default: () => false
|
|
27884
|
+
},
|
|
27885
|
+
tooltipPosition: {
|
|
27886
|
+
type: String,
|
|
27887
|
+
default: () => "top"
|
|
27888
|
+
}
|
|
27889
|
+
};
|
|
27890
|
+
const transferDragFunctions = {
|
|
27891
|
+
onDragstart: {
|
|
27892
|
+
type: Function
|
|
27893
|
+
},
|
|
27894
|
+
onDrop: {
|
|
27895
|
+
type: Function
|
|
27896
|
+
},
|
|
27897
|
+
onDragleave: {
|
|
27898
|
+
type: Function
|
|
27899
|
+
},
|
|
27900
|
+
onDragover: {
|
|
27901
|
+
type: Function
|
|
27902
|
+
},
|
|
27903
|
+
onDragenter: {
|
|
27904
|
+
type: Function
|
|
27905
|
+
},
|
|
27906
|
+
onDragend: {
|
|
27907
|
+
type: Function
|
|
27908
|
+
}
|
|
27909
|
+
};
|
|
27910
|
+
const transferBaseProps = __spreadProps(__spreadValues(__spreadValues({}, transferCommon), transferDragFunctions), {
|
|
27296
27911
|
sourceOption: {
|
|
27297
27912
|
type: Array,
|
|
27298
27913
|
default() {
|
|
@@ -27345,13 +27960,13 @@ const transferBaseProps = {
|
|
|
27345
27960
|
type: Number,
|
|
27346
27961
|
default: () => 0
|
|
27347
27962
|
},
|
|
27348
|
-
|
|
27963
|
+
isSourceDroppable: {
|
|
27349
27964
|
type: Boolean,
|
|
27350
27965
|
default: () => false
|
|
27351
27966
|
},
|
|
27352
|
-
|
|
27353
|
-
type:
|
|
27354
|
-
default: () =>
|
|
27967
|
+
isTargetDroppable: {
|
|
27968
|
+
type: Boolean,
|
|
27969
|
+
default: () => false
|
|
27355
27970
|
},
|
|
27356
27971
|
scopedSlots: {
|
|
27357
27972
|
type: Object
|
|
@@ -27364,8 +27979,11 @@ const transferBaseProps = {
|
|
|
27364
27979
|
},
|
|
27365
27980
|
onUpdateCheckeds: {
|
|
27366
27981
|
type: Function
|
|
27982
|
+
},
|
|
27983
|
+
onDragend: {
|
|
27984
|
+
type: Function
|
|
27367
27985
|
}
|
|
27368
|
-
};
|
|
27986
|
+
});
|
|
27369
27987
|
const getFilterData = (props, type4) => {
|
|
27370
27988
|
const newModel = [];
|
|
27371
27989
|
const data = type4 === "source" ? props.sourceOption : props.targetOption;
|
|
@@ -27397,6 +28015,168 @@ const TransferBaseClass = (props) => {
|
|
|
27397
28015
|
return `devui-transfer-panel devui-transfer-${props.type}`;
|
|
27398
28016
|
});
|
|
27399
28017
|
};
|
|
28018
|
+
const transferDragProps = __spreadProps(__spreadValues(__spreadValues({}, transferCommon), transferDragFunctions), {
|
|
28019
|
+
itemData: {
|
|
28020
|
+
type: Object
|
|
28021
|
+
},
|
|
28022
|
+
id: {
|
|
28023
|
+
type: Number,
|
|
28024
|
+
default: () => null
|
|
28025
|
+
}
|
|
28026
|
+
});
|
|
28027
|
+
const transferCheckboxProps = __spreadProps(__spreadValues({}, transferCommon), {
|
|
28028
|
+
data: {
|
|
28029
|
+
type: Object
|
|
28030
|
+
},
|
|
28031
|
+
id: {
|
|
28032
|
+
type: Number
|
|
28033
|
+
}
|
|
28034
|
+
});
|
|
28035
|
+
function _isSlot$2(s) {
|
|
28036
|
+
return typeof s === "function" || Object.prototype.toString.call(s) === "[object Object]" && !isVNode(s);
|
|
28037
|
+
}
|
|
28038
|
+
var DTransfeCheckbox = defineComponent$1({
|
|
28039
|
+
name: "DTransferCheckbox",
|
|
28040
|
+
components: {
|
|
28041
|
+
DCheckbox: Checkbox,
|
|
28042
|
+
DTooltip
|
|
28043
|
+
},
|
|
28044
|
+
props: transferCheckboxProps,
|
|
28045
|
+
setup(props) {
|
|
28046
|
+
const renderCheckbox = () => {
|
|
28047
|
+
return createVNode(Checkbox, {
|
|
28048
|
+
"label": props.data.key,
|
|
28049
|
+
"value": props.data.value,
|
|
28050
|
+
"disabled": props.data.disabled,
|
|
28051
|
+
"class": "devui-transfer-panel-body-list-item",
|
|
28052
|
+
"key": props.id
|
|
28053
|
+
}, null);
|
|
28054
|
+
};
|
|
28055
|
+
return () => {
|
|
28056
|
+
let _slot;
|
|
28057
|
+
return !props.showTooltip ? renderCheckbox() : createVNode(DTooltip, {
|
|
28058
|
+
"class": "devui-transfer-panel-body-list-tooltip",
|
|
28059
|
+
"position": props.tooltipPosition,
|
|
28060
|
+
"content": props.data.key
|
|
28061
|
+
}, _isSlot$2(_slot = renderCheckbox()) ? _slot : {
|
|
28062
|
+
default: () => [_slot]
|
|
28063
|
+
});
|
|
28064
|
+
};
|
|
28065
|
+
}
|
|
28066
|
+
});
|
|
28067
|
+
var devuiIcon = "";
|
|
28068
|
+
var DTransferDrag = defineComponent$1({
|
|
28069
|
+
name: "DTransferDrag",
|
|
28070
|
+
components: {
|
|
28071
|
+
DTransfeCheckbox
|
|
28072
|
+
},
|
|
28073
|
+
props: transferDragProps,
|
|
28074
|
+
setup(props) {
|
|
28075
|
+
const dragRef = ref(null);
|
|
28076
|
+
const dragHighlight = ref(false);
|
|
28077
|
+
const dragOverNodeKey = ref("");
|
|
28078
|
+
const dropPosition = ref(null);
|
|
28079
|
+
const dragTimer = ref(null);
|
|
28080
|
+
const calcDropPosition = (event) => {
|
|
28081
|
+
const {
|
|
28082
|
+
clientY
|
|
28083
|
+
} = event;
|
|
28084
|
+
const {
|
|
28085
|
+
top,
|
|
28086
|
+
bottom,
|
|
28087
|
+
height
|
|
28088
|
+
} = dragRef.value.getBoundingClientRect();
|
|
28089
|
+
const des = Math.max(height * 0.25, 2);
|
|
28090
|
+
if (clientY <= top + des) {
|
|
28091
|
+
return -1;
|
|
28092
|
+
}
|
|
28093
|
+
if (clientY >= bottom - des) {
|
|
28094
|
+
return 1;
|
|
28095
|
+
}
|
|
28096
|
+
return 0;
|
|
28097
|
+
};
|
|
28098
|
+
const resetState = () => {
|
|
28099
|
+
dragOverNodeKey.value = "";
|
|
28100
|
+
dropPosition.value = null;
|
|
28101
|
+
dragHighlight.value = null;
|
|
28102
|
+
};
|
|
28103
|
+
onUnmounted(() => {
|
|
28104
|
+
clearTimeout(dragTimer.value);
|
|
28105
|
+
});
|
|
28106
|
+
return () => {
|
|
28107
|
+
const state = dragOverNodeKey.value === props.itemData.key;
|
|
28108
|
+
return createVNode("div", {
|
|
28109
|
+
"class": {
|
|
28110
|
+
"devui-transfer-panel-body-list-item": true,
|
|
28111
|
+
"devui-transfer-drag-dragging": dragHighlight.value,
|
|
28112
|
+
"devui-transfer-drag-over": state && dropPosition.value === 0,
|
|
28113
|
+
"devui-transfer\u2013drag-over-top": state && dropPosition.value === -1,
|
|
28114
|
+
"devui-transfer\u2013drag-over-bottom": state && dropPosition.value === 1
|
|
28115
|
+
},
|
|
28116
|
+
"onDragenter": (event) => {
|
|
28117
|
+
event.preventDefault();
|
|
28118
|
+
event.stopPropagation();
|
|
28119
|
+
clearTimeout(dragTimer.value);
|
|
28120
|
+
const curDropPosition = calcDropPosition(event);
|
|
28121
|
+
if (props.itemData.key === dragOverNodeKey.value && curDropPosition === 0) {
|
|
28122
|
+
resetState();
|
|
28123
|
+
return;
|
|
28124
|
+
}
|
|
28125
|
+
dragTimer.value = setTimeout(() => {
|
|
28126
|
+
dragOverNodeKey.value = props.itemData.key;
|
|
28127
|
+
dropPosition.value = curDropPosition;
|
|
28128
|
+
}, 0);
|
|
28129
|
+
props.onDragenter && props.onDragenter(event, props.itemData);
|
|
28130
|
+
},
|
|
28131
|
+
"onDragover": (event) => {
|
|
28132
|
+
event.preventDefault();
|
|
28133
|
+
event.stopPropagation();
|
|
28134
|
+
if (props.itemData.key === dragOverNodeKey.value) {
|
|
28135
|
+
const curDropPosition = calcDropPosition(event);
|
|
28136
|
+
if (curDropPosition === dropPosition.value) {
|
|
28137
|
+
return;
|
|
28138
|
+
}
|
|
28139
|
+
dropPosition.value = curDropPosition;
|
|
28140
|
+
}
|
|
28141
|
+
props.onDragover && props.onDragover(event, props.itemData);
|
|
28142
|
+
},
|
|
28143
|
+
"onDragleave": (event) => {
|
|
28144
|
+
event.stopPropagation();
|
|
28145
|
+
resetState();
|
|
28146
|
+
props.onDragleave && props.onDragleave(event, props.itemData);
|
|
28147
|
+
},
|
|
28148
|
+
"onDrop": (event) => {
|
|
28149
|
+
event.preventDefault();
|
|
28150
|
+
event.stopPropagation();
|
|
28151
|
+
resetState();
|
|
28152
|
+
props.onDrop && props.onDrop(event, props.itemData);
|
|
28153
|
+
},
|
|
28154
|
+
"onDragend": (event) => {
|
|
28155
|
+
event.stopPropagation();
|
|
28156
|
+
props.onDragend && props.onDragend(event, props.itemData);
|
|
28157
|
+
}
|
|
28158
|
+
}, [createVNode("div", {
|
|
28159
|
+
"class": "devui-transfer-panel-body-list-drag",
|
|
28160
|
+
"draggable": true,
|
|
28161
|
+
"ref": dragRef,
|
|
28162
|
+
"onDragstart": (event) => {
|
|
28163
|
+
event.stopPropagation();
|
|
28164
|
+
dragHighlight.value = true;
|
|
28165
|
+
props.onDragstart && props.onDragstart(event, props.itemData);
|
|
28166
|
+
}
|
|
28167
|
+
}, [createVNode("span", {
|
|
28168
|
+
"class": "devui-transfer-panel-body-list-drag__icon"
|
|
28169
|
+
}, [createVNode(resolveComponent("d-icon"), {
|
|
28170
|
+
"name": "drag-small"
|
|
28171
|
+
}, null)]), createVNode(DTransfeCheckbox, {
|
|
28172
|
+
"data": props.itemData,
|
|
28173
|
+
"id": props.id,
|
|
28174
|
+
"showTooltip": props.showTooltip,
|
|
28175
|
+
"tooltipPosition": props.tooltipPosition
|
|
28176
|
+
}, null)])]);
|
|
28177
|
+
};
|
|
28178
|
+
}
|
|
28179
|
+
});
|
|
27400
28180
|
function _isSlot$1(s) {
|
|
27401
28181
|
return typeof s === "function" || Object.prototype.toString.call(s) === "[object Object]" && !isVNode(s);
|
|
27402
28182
|
}
|
|
@@ -27406,54 +28186,98 @@ var DTransferBase = defineComponent$1({
|
|
|
27406
28186
|
DSearch,
|
|
27407
28187
|
DCheckboxGroup,
|
|
27408
28188
|
DCheckbox: Checkbox,
|
|
27409
|
-
|
|
28189
|
+
DTransferDrag,
|
|
28190
|
+
DTransfeCheckbox
|
|
27410
28191
|
},
|
|
27411
28192
|
props: transferBaseProps,
|
|
27412
28193
|
setup(props, ctx2) {
|
|
28194
|
+
const allHalfchecked = ref(false);
|
|
27413
28195
|
const modelValues = computed(() => props.checkedValues);
|
|
28196
|
+
const dragWrapClass = computed(() => {
|
|
28197
|
+
const isDrag = props.isSourceDroppable || props.isTargetDroppable;
|
|
28198
|
+
return `devui-transfer-panel-body-list devui-transfer-panel-body-${isDrag ? "" : "no"}drag`;
|
|
28199
|
+
});
|
|
27414
28200
|
const searchQuery = computed(() => props.filter);
|
|
27415
28201
|
const baseClass = TransferBaseClass(props);
|
|
28202
|
+
const dropItem = ref(null);
|
|
28203
|
+
watch(() => props.checkedNum, (nVal) => {
|
|
28204
|
+
if (props.allChecked) {
|
|
28205
|
+
allHalfchecked.value = !props.allChecked;
|
|
28206
|
+
} else {
|
|
28207
|
+
allHalfchecked.value = nVal !== 0;
|
|
28208
|
+
}
|
|
28209
|
+
}, {
|
|
28210
|
+
immediate: true
|
|
28211
|
+
});
|
|
27416
28212
|
const updateSearchQuery = (val) => ctx2.emit("changeQuery", val);
|
|
27417
|
-
const
|
|
27418
|
-
|
|
27419
|
-
|
|
27420
|
-
"
|
|
27421
|
-
"
|
|
27422
|
-
|
|
27423
|
-
|
|
27424
|
-
|
|
27425
|
-
|
|
27426
|
-
|
|
27427
|
-
|
|
27428
|
-
|
|
27429
|
-
|
|
28213
|
+
const renderCheckboxGroup = () => {
|
|
28214
|
+
let _slot;
|
|
28215
|
+
return createVNode(DCheckboxGroup, {
|
|
28216
|
+
"modelValue": modelValues.value,
|
|
28217
|
+
"onChange": (values) => ctx2.emit("updateCheckeds", values)
|
|
28218
|
+
}, _isSlot$1(_slot = props.sourceOption.map((item2, idx) => {
|
|
28219
|
+
return createVNode(DTransfeCheckbox, {
|
|
28220
|
+
"data": item2,
|
|
28221
|
+
"id": idx,
|
|
28222
|
+
"showTooltip": props.showTooltip,
|
|
28223
|
+
"tooltipPosition": props.tooltipPosition
|
|
28224
|
+
}, null);
|
|
28225
|
+
})) ? _slot : {
|
|
28226
|
+
default: () => [_slot]
|
|
28227
|
+
});
|
|
28228
|
+
};
|
|
28229
|
+
const renderDragCheckboxGroup = () => {
|
|
28230
|
+
let _slot2;
|
|
28231
|
+
return createVNode(DCheckboxGroup, {
|
|
28232
|
+
"modelValue": modelValues.value,
|
|
28233
|
+
"onChange": (values) => ctx2.emit("updateCheckeds", values)
|
|
28234
|
+
}, _isSlot$1(_slot2 = props.sourceOption.map((item2, idx) => {
|
|
28235
|
+
return createVNode(DTransferDrag, {
|
|
28236
|
+
"itemData": item2,
|
|
28237
|
+
"id": idx,
|
|
28238
|
+
"showTooltip": props.showTooltip,
|
|
28239
|
+
"tooltipPosition": props.tooltipPosition,
|
|
28240
|
+
"onDrop": (event, item3) => {
|
|
28241
|
+
dropItem.value = item3;
|
|
28242
|
+
},
|
|
28243
|
+
"onDragend": (event, dragItem) => {
|
|
28244
|
+
props.onDragend && props.onDragend(dragItem, dropItem.value);
|
|
28245
|
+
}
|
|
28246
|
+
}, null);
|
|
28247
|
+
})) ? _slot2 : {
|
|
28248
|
+
default: () => [_slot2]
|
|
27430
28249
|
});
|
|
27431
28250
|
};
|
|
27432
28251
|
return {
|
|
27433
28252
|
baseClass,
|
|
27434
28253
|
searchQuery,
|
|
28254
|
+
dragWrapClass,
|
|
27435
28255
|
modelValues,
|
|
28256
|
+
dropItem,
|
|
28257
|
+
allHalfchecked,
|
|
27436
28258
|
updateSearchQuery,
|
|
27437
|
-
|
|
28259
|
+
renderCheckboxGroup,
|
|
28260
|
+
renderDragCheckboxGroup
|
|
27438
28261
|
};
|
|
27439
28262
|
},
|
|
27440
28263
|
render() {
|
|
27441
|
-
let _slot;
|
|
27442
28264
|
const {
|
|
27443
28265
|
title,
|
|
27444
28266
|
baseClass,
|
|
27445
28267
|
checkedNum,
|
|
27446
28268
|
allChecked,
|
|
28269
|
+
allHalfchecked,
|
|
27447
28270
|
sourceOption,
|
|
27448
28271
|
allCount,
|
|
27449
28272
|
updateSearchQuery,
|
|
27450
28273
|
search: search2,
|
|
27451
28274
|
searchQuery,
|
|
27452
|
-
|
|
28275
|
+
dragWrapClass,
|
|
27453
28276
|
height,
|
|
27454
|
-
|
|
27455
|
-
|
|
27456
|
-
|
|
28277
|
+
isSourceDroppable,
|
|
28278
|
+
isTargetDroppable,
|
|
28279
|
+
renderCheckboxGroup,
|
|
28280
|
+
renderDragCheckboxGroup
|
|
27457
28281
|
} = this;
|
|
27458
28282
|
return createVNode("div", {
|
|
27459
28283
|
"class": baseClass
|
|
@@ -27462,8 +28286,11 @@ var DTransferBase = defineComponent$1({
|
|
|
27462
28286
|
}, [createVNode("div", {
|
|
27463
28287
|
"class": "devui-transfer-panel-header-allChecked"
|
|
27464
28288
|
}, [createVNode(Checkbox, {
|
|
28289
|
+
"halfchecked": allHalfchecked,
|
|
27465
28290
|
"modelValue": allChecked,
|
|
27466
|
-
"onChange": (value) =>
|
|
28291
|
+
"onChange": (value) => {
|
|
28292
|
+
this.$emit("changeAllSource", value);
|
|
28293
|
+
}
|
|
27467
28294
|
}, _isSlot$1(title) ? title : {
|
|
27468
28295
|
default: () => [title]
|
|
27469
28296
|
})]), createVNode("div", {
|
|
@@ -27476,18 +28303,11 @@ var DTransferBase = defineComponent$1({
|
|
|
27476
28303
|
"modelValue": searchQuery,
|
|
27477
28304
|
"onUpdate:modelValue": updateSearchQuery
|
|
27478
28305
|
}, null)]), createVNode("div", {
|
|
27479
|
-
"class":
|
|
28306
|
+
"class": dragWrapClass,
|
|
27480
28307
|
"style": {
|
|
27481
28308
|
height
|
|
27482
28309
|
}
|
|
27483
|
-
}, [sourceOption.length ? createVNode(
|
|
27484
|
-
"modelValue": modelValues,
|
|
27485
|
-
"onChange": (values) => this.$emit("updateCheckeds", values)
|
|
27486
|
-
}, _isSlot$1(_slot = sourceOption.map((item2, idx) => {
|
|
27487
|
-
return renderCheckbox(item2, idx, showTooltip, tooltipPosition);
|
|
27488
|
-
})) ? _slot : {
|
|
27489
|
-
default: () => [_slot]
|
|
27490
|
-
}) : createVNode("div", {
|
|
28310
|
+
}, [sourceOption.length ? isSourceDroppable || isTargetDroppable ? renderDragCheckboxGroup() : renderCheckboxGroup() : createVNode("div", {
|
|
27491
28311
|
"class": "devui-transfer-panel-body-list-empty"
|
|
27492
28312
|
}, [createTextVNode("\u65E0\u6570\u636E")])])])]);
|
|
27493
28313
|
}
|
|
@@ -27544,7 +28364,7 @@ var DTransferOperation = defineComponent$1({
|
|
|
27544
28364
|
};
|
|
27545
28365
|
}
|
|
27546
28366
|
});
|
|
27547
|
-
const transferProps = {
|
|
28367
|
+
const transferProps = __spreadProps(__spreadValues({}, transferCommon), {
|
|
27548
28368
|
sourceOption: {
|
|
27549
28369
|
type: Array,
|
|
27550
28370
|
require: true,
|
|
@@ -27587,14 +28407,6 @@ const transferProps = {
|
|
|
27587
28407
|
type: Boolean,
|
|
27588
28408
|
default: () => false
|
|
27589
28409
|
},
|
|
27590
|
-
showTooltip: {
|
|
27591
|
-
type: Boolean,
|
|
27592
|
-
default: () => false
|
|
27593
|
-
},
|
|
27594
|
-
tooltipPosition: {
|
|
27595
|
-
type: String,
|
|
27596
|
-
default: () => "top"
|
|
27597
|
-
},
|
|
27598
28410
|
beforeTransfer: {
|
|
27599
28411
|
type: Function
|
|
27600
28412
|
},
|
|
@@ -27615,8 +28427,11 @@ const transferProps = {
|
|
|
27615
28427
|
},
|
|
27616
28428
|
afterTransfer: {
|
|
27617
28429
|
type: Function
|
|
28430
|
+
},
|
|
28431
|
+
onDragend: {
|
|
28432
|
+
type: Function
|
|
27618
28433
|
}
|
|
27619
|
-
};
|
|
28434
|
+
});
|
|
27620
28435
|
const headerSlot = (ctx2, name) => {
|
|
27621
28436
|
return !ctx2.slots[`${name}-header`] ? null : () => ctx2.slots[`${name}-header`] && ctx2.slots[`${name}-header`]();
|
|
27622
28437
|
};
|
|
@@ -27645,7 +28460,7 @@ var Transfer = defineComponent$1({
|
|
|
27645
28460
|
watch(() => props.targetOption, () => {
|
|
27646
28461
|
rightOptions = reactive(initState(props, "target"));
|
|
27647
28462
|
});
|
|
27648
|
-
watch(() => leftOptions.keyword, (
|
|
28463
|
+
watch(() => leftOptions.keyword, () => {
|
|
27649
28464
|
searchFilterData(leftOptions);
|
|
27650
28465
|
});
|
|
27651
28466
|
watch(() => leftOptions.checkedValues, (values) => {
|
|
@@ -27654,7 +28469,7 @@ var Transfer = defineComponent$1({
|
|
|
27654
28469
|
}, {
|
|
27655
28470
|
deep: true
|
|
27656
28471
|
});
|
|
27657
|
-
watch(() => rightOptions.keyword, (
|
|
28472
|
+
watch(() => rightOptions.keyword, () => {
|
|
27658
28473
|
searchFilterData(rightOptions);
|
|
27659
28474
|
});
|
|
27660
28475
|
watch(() => rightOptions.checkedValues, (values) => {
|
|
@@ -27738,6 +28553,13 @@ var Transfer = defineComponent$1({
|
|
|
27738
28553
|
const isFunction2 = (type4) => {
|
|
27739
28554
|
return props[type4] && typeof props[type4] === "function";
|
|
27740
28555
|
};
|
|
28556
|
+
const dataSort = (target, dragItem, dropItem, direction) => {
|
|
28557
|
+
const startIndex = target.filterData.findIndex((item2) => item2.key === dragItem.key);
|
|
28558
|
+
const endIndex = target.filterData.findIndex((item2) => item2.key === dropItem.key);
|
|
28559
|
+
target.filterData.splice(endIndex, 1, dragItem);
|
|
28560
|
+
target.filterData.splice(startIndex, 1, dropItem);
|
|
28561
|
+
props.onDragend && props.onDragend(direction, dragItem, dropItem);
|
|
28562
|
+
};
|
|
27741
28563
|
return () => {
|
|
27742
28564
|
return createVNode("div", {
|
|
27743
28565
|
"class": "devui-transfer"
|
|
@@ -27754,9 +28576,11 @@ var Transfer = defineComponent$1({
|
|
|
27754
28576
|
"allCount": leftOptions.data.length,
|
|
27755
28577
|
"showTooltip": props.showTooltip,
|
|
27756
28578
|
"tooltipPosition": props.tooltipPosition,
|
|
28579
|
+
"isSourceDroppable": props.isSourceDroppable,
|
|
27757
28580
|
"onChangeAllSource": (value) => changeAllSource(leftOptions, value),
|
|
27758
28581
|
"onUpdateCheckeds": updateLeftCheckeds,
|
|
27759
|
-
"onChangeQuery": (value) => changeQueryHandle(leftOptions, "left", value)
|
|
28582
|
+
"onChangeQuery": (value) => changeQueryHandle(leftOptions, "left", value),
|
|
28583
|
+
"onDragend": (dragItem, dropItem) => dataSort(leftOptions, dragItem, dropItem, "left")
|
|
27760
28584
|
}, {
|
|
27761
28585
|
header: headerSlot(ctx2, "left"),
|
|
27762
28586
|
body: bodySlot(ctx2, "left")
|
|
@@ -27785,9 +28609,11 @@ var Transfer = defineComponent$1({
|
|
|
27785
28609
|
"allCount": rightOptions.data.length,
|
|
27786
28610
|
"showTooltip": props.showTooltip,
|
|
27787
28611
|
"tooltipPosition": props.tooltipPosition,
|
|
28612
|
+
"isTargetDroppable": props.isTargetDroppable,
|
|
27788
28613
|
"onChangeAllSource": (value) => changeAllSource(rightOptions, value),
|
|
27789
28614
|
"onUpdateCheckeds": updateRightCheckeds,
|
|
27790
|
-
"onChangeQuery": (value) => changeQueryHandle(rightOptions, "right", value)
|
|
28615
|
+
"onChangeQuery": (value) => changeQueryHandle(rightOptions, "right", value),
|
|
28616
|
+
"onDragend": (dragItem, dropItem) => dataSort(rightOptions, dragItem, dropItem, "right")
|
|
27791
28617
|
}, {
|
|
27792
28618
|
header: headerSlot(ctx2, "right"),
|
|
27793
28619
|
body: bodySlot(ctx2, "right")
|
|
@@ -27801,7 +28627,7 @@ Transfer.install = function(app) {
|
|
|
27801
28627
|
var TransferInstall = {
|
|
27802
28628
|
title: "Transfer \u7A7F\u68AD\u6846",
|
|
27803
28629
|
category: "\u6570\u636E\u5F55\u5165",
|
|
27804
|
-
status: "
|
|
28630
|
+
status: "40%",
|
|
27805
28631
|
install(app) {
|
|
27806
28632
|
app.use(Transfer);
|
|
27807
28633
|
}
|
|
@@ -28290,13 +29116,14 @@ var Tree = defineComponent$1({
|
|
|
28290
29116
|
}
|
|
28291
29117
|
return toggle(target, item3);
|
|
28292
29118
|
};
|
|
28293
|
-
return
|
|
28294
|
-
"class": "
|
|
29119
|
+
return createVNode("div", {
|
|
29120
|
+
"class": "devui-tree-node__folder",
|
|
28295
29121
|
"onClick": handleClick
|
|
29122
|
+
}, [isParent || children && children.length ? open ? createVNode(IconOpen$1, {
|
|
29123
|
+
"class": "mr-xs"
|
|
28296
29124
|
}, null) : createVNode(IconClose$1, {
|
|
28297
|
-
"class": "mr-xs"
|
|
28298
|
-
|
|
28299
|
-
}, null) : createVNode(Indent, null, null);
|
|
29125
|
+
"class": "mr-xs"
|
|
29126
|
+
}, null) : createVNode(Indent, null, null)]);
|
|
28300
29127
|
};
|
|
28301
29128
|
const checkState = CHECK_CONFIG[(_a = selected.value[id]) != null ? _a : "none"];
|
|
28302
29129
|
return createVNode("div", {
|
|
@@ -28375,6 +29202,10 @@ const treeSelectProps = {
|
|
|
28375
29202
|
type: Boolean,
|
|
28376
29203
|
default: false
|
|
28377
29204
|
},
|
|
29205
|
+
enableLabelization: {
|
|
29206
|
+
type: Boolean,
|
|
29207
|
+
default: false
|
|
29208
|
+
},
|
|
28378
29209
|
onToggleChange: {
|
|
28379
29210
|
type: Function,
|
|
28380
29211
|
default: void 0
|
|
@@ -28384,10 +29215,12 @@ const treeSelectProps = {
|
|
|
28384
29215
|
default: void 0
|
|
28385
29216
|
}
|
|
28386
29217
|
};
|
|
29218
|
+
const nodeMap = new Map();
|
|
28387
29219
|
function attributeExtension(data) {
|
|
28388
29220
|
data.forEach((el) => {
|
|
28389
29221
|
let level = 1;
|
|
28390
29222
|
el.level = level;
|
|
29223
|
+
nodeMap.set(el.label, el);
|
|
28391
29224
|
const nodeQueue = [];
|
|
28392
29225
|
nodeQueue.push(el);
|
|
28393
29226
|
while (nodeQueue.length !== 0) {
|
|
@@ -28396,6 +29229,7 @@ function attributeExtension(data) {
|
|
|
28396
29229
|
node.children.forEach((el2) => {
|
|
28397
29230
|
el2.level = level + 1;
|
|
28398
29231
|
el2.parent = node;
|
|
29232
|
+
nodeMap.set(el2.label, el2);
|
|
28399
29233
|
nodeQueue.push(el2);
|
|
28400
29234
|
});
|
|
28401
29235
|
}
|
|
@@ -28432,7 +29266,7 @@ function useToggle(props) {
|
|
|
28432
29266
|
};
|
|
28433
29267
|
}
|
|
28434
29268
|
function useSelect(props) {
|
|
28435
|
-
const inputValue = ref(
|
|
29269
|
+
const inputValue = ref([]);
|
|
28436
29270
|
const selectedCache = new Set();
|
|
28437
29271
|
const selectValue = (item2) => {
|
|
28438
29272
|
if (!props.multiple) {
|
|
@@ -28444,7 +29278,7 @@ function useSelect(props) {
|
|
|
28444
29278
|
useCache(item2);
|
|
28445
29279
|
searchUp(item2);
|
|
28446
29280
|
searchDown(item2);
|
|
28447
|
-
inputValue.value = [...selectedCache]
|
|
29281
|
+
inputValue.value = [...selectedCache];
|
|
28448
29282
|
}
|
|
28449
29283
|
};
|
|
28450
29284
|
const useCache = (item2) => {
|
|
@@ -28495,27 +29329,43 @@ function useSelect(props) {
|
|
|
28495
29329
|
}
|
|
28496
29330
|
function useClear(props, ctx2, data) {
|
|
28497
29331
|
const isClearable = computed(() => {
|
|
28498
|
-
return !props.disabled && props.allowClear
|
|
29332
|
+
return !props.disabled && props.allowClear;
|
|
28499
29333
|
});
|
|
28500
|
-
const
|
|
29334
|
+
const handleClearAll = (e) => {
|
|
28501
29335
|
e.preventDefault();
|
|
28502
29336
|
e.stopPropagation();
|
|
28503
29337
|
if (props.multiple) {
|
|
28504
29338
|
ctx2.emit("update:modelValue", []);
|
|
29339
|
+
data.value = [];
|
|
28505
29340
|
} else {
|
|
28506
29341
|
ctx2.emit("update:modelValue", "");
|
|
28507
29342
|
data.value = "";
|
|
28508
29343
|
}
|
|
28509
29344
|
};
|
|
29345
|
+
const handleClearItem = (e, item2) => {
|
|
29346
|
+
e.preventDefault();
|
|
29347
|
+
e.stopPropagation();
|
|
29348
|
+
if (props.multiple) {
|
|
29349
|
+
data.value.splice(data.value.indexOf(item2), 1);
|
|
29350
|
+
ctx2.emit("update:modelValue", data.value);
|
|
29351
|
+
} else {
|
|
29352
|
+
ctx2.emit("update:modelValue", []);
|
|
29353
|
+
data.value = [];
|
|
29354
|
+
}
|
|
29355
|
+
};
|
|
28510
29356
|
return {
|
|
28511
29357
|
isClearable,
|
|
28512
|
-
|
|
29358
|
+
handleClearAll,
|
|
29359
|
+
handleClearItem
|
|
28513
29360
|
};
|
|
28514
29361
|
}
|
|
28515
29362
|
var IconOpen = "";
|
|
28516
29363
|
var IconClose = "";
|
|
28517
29364
|
var TreeSelect = defineComponent$1({
|
|
28518
29365
|
name: "DTreeSelect",
|
|
29366
|
+
directives: {
|
|
29367
|
+
ClickOutside: clickoutsideDirective
|
|
29368
|
+
},
|
|
28519
29369
|
props: treeSelectProps,
|
|
28520
29370
|
emits: ["toggleChange", "valueChange", "update:modelValue"],
|
|
28521
29371
|
setup(props, ctx2) {
|
|
@@ -28524,8 +29374,9 @@ var TreeSelect = defineComponent$1({
|
|
|
28524
29374
|
placeholder,
|
|
28525
29375
|
disabled,
|
|
28526
29376
|
multiple,
|
|
28527
|
-
leafOnly
|
|
28528
|
-
|
|
29377
|
+
leafOnly,
|
|
29378
|
+
enableLabelization
|
|
29379
|
+
} = toRefs(props);
|
|
28529
29380
|
const {
|
|
28530
29381
|
visible,
|
|
28531
29382
|
selectToggle,
|
|
@@ -28537,22 +29388,30 @@ var TreeSelect = defineComponent$1({
|
|
|
28537
29388
|
} = useSelect(props);
|
|
28538
29389
|
const {
|
|
28539
29390
|
isClearable,
|
|
28540
|
-
|
|
29391
|
+
handleClearAll,
|
|
29392
|
+
handleClearItem
|
|
28541
29393
|
} = useClear(props, ctx2, inputValue);
|
|
28542
29394
|
const clickNode = (item2) => {
|
|
28543
|
-
if (!leafOnly) {
|
|
29395
|
+
if (!leafOnly.value) {
|
|
28544
29396
|
selectValue(item2);
|
|
28545
|
-
!multiple && selectToggle(item2);
|
|
29397
|
+
!multiple.value && selectToggle(item2);
|
|
28546
29398
|
} else {
|
|
28547
29399
|
if (!item2.children) {
|
|
28548
29400
|
selectValue(item2);
|
|
28549
|
-
!multiple && selectToggle(item2);
|
|
29401
|
+
!multiple.value && selectToggle(item2);
|
|
28550
29402
|
}
|
|
28551
29403
|
}
|
|
28552
29404
|
};
|
|
29405
|
+
const deleteNode2 = (e, item2) => {
|
|
29406
|
+
handleClearItem(e, item2);
|
|
29407
|
+
selectValue(nodeMap.get(item2));
|
|
29408
|
+
};
|
|
28553
29409
|
const treeSelectCls = className("devui-tree-select", {
|
|
28554
29410
|
"devui-tree-select-open": visible.value,
|
|
28555
|
-
"devui-tree-select-disabled": disabled
|
|
29411
|
+
"devui-tree-select-disabled": disabled.value
|
|
29412
|
+
});
|
|
29413
|
+
const treeSelectInputItem = className("devui-tree-select-value", {
|
|
29414
|
+
"devui-tree-select-value-enableLabelization": enableLabelization.value
|
|
28556
29415
|
});
|
|
28557
29416
|
const renderNode = (item2) => createVNode("div", {
|
|
28558
29417
|
"class": "devui-tree-select-item",
|
|
@@ -28566,7 +29425,9 @@ var TreeSelect = defineComponent$1({
|
|
|
28566
29425
|
}, null) : createVNode(IconClose, {
|
|
28567
29426
|
"class": "mr-xs",
|
|
28568
29427
|
"onClick": (e) => treeToggle(e, item2)
|
|
28569
|
-
}, null) : createVNode("span", null, ["\xA0\xA0\xA0"]),
|
|
29428
|
+
}, null) : createVNode("span", null, ["\xA0\xA0\xA0"]), ctx2.slots.default ? ctx2.slots.default({
|
|
29429
|
+
item: item2
|
|
29430
|
+
}) : multiple.value ? item2.halfchecked ? createVNode(Checkbox, {
|
|
28570
29431
|
"label": item2.label,
|
|
28571
29432
|
"halfchecked": item2.halfchecked
|
|
28572
29433
|
}, null) : createVNode(Checkbox, {
|
|
@@ -28582,20 +29443,26 @@ var TreeSelect = defineComponent$1({
|
|
|
28582
29443
|
});
|
|
28583
29444
|
};
|
|
28584
29445
|
return () => {
|
|
28585
|
-
return createVNode("div", {
|
|
29446
|
+
return withDirectives(createVNode("div", {
|
|
28586
29447
|
"class": treeSelectCls
|
|
28587
29448
|
}, [createVNode("div", {
|
|
28588
29449
|
"class": isClearable.value ? "devui-tree-select-clearable" : "devui-tree-select-notclearable",
|
|
28589
29450
|
"onClick": () => selectToggle()
|
|
28590
|
-
}, [createVNode("
|
|
28591
|
-
"value": inputValue.value,
|
|
28592
|
-
"type": "text",
|
|
29451
|
+
}, [createVNode("div", {
|
|
28593
29452
|
"class": "devui-tree-select-input",
|
|
28594
|
-
"placeholder": placeholder
|
|
28595
|
-
|
|
28596
|
-
"
|
|
28597
|
-
},
|
|
28598
|
-
"
|
|
29453
|
+
"placeholder": placeholder.value
|
|
29454
|
+
}, [multiple.value ? inputValue.value.map((item2) => createVNode("div", {
|
|
29455
|
+
"class": treeSelectInputItem
|
|
29456
|
+
}, [item2, enableLabelization.value ? createVNode(resolveComponent("d-icon"), {
|
|
29457
|
+
"name": "close",
|
|
29458
|
+
"onClick": (e) => deleteNode2(e, item2)
|
|
29459
|
+
}, null) : createVNode("span", null, [createTextVNode(",")])])) : !Array.isArray(inputValue.value) && createVNode("div", {
|
|
29460
|
+
"class": treeSelectInputItem
|
|
29461
|
+
}, [inputValue.value, enableLabelization.value && createVNode(resolveComponent("d-icon"), {
|
|
29462
|
+
"name": "close",
|
|
29463
|
+
"onClick": (e) => handleClearItem(e)
|
|
29464
|
+
}, null)])]), createVNode("span", {
|
|
29465
|
+
"onClick": (e) => handleClearAll(e),
|
|
28599
29466
|
"class": "devui-tree-select-clear"
|
|
28600
29467
|
}, [createVNode(resolveComponent("d-icon"), {
|
|
28601
29468
|
"name": "close"
|
|
@@ -28611,8 +29478,8 @@ var TreeSelect = defineComponent$1({
|
|
|
28611
29478
|
"class": "devui-tree-select-dropdown"
|
|
28612
29479
|
}, [createVNode("ul", {
|
|
28613
29480
|
"class": "devui-tree-select-dropdown-list"
|
|
28614
|
-
}, [renderTree(attributeExtension(treeData))])]), [[vShow, visible.value]])]
|
|
28615
|
-
})]);
|
|
29481
|
+
}, [renderTree(attributeExtension(treeData.value))])]), [[vShow, visible.value]])]
|
|
29482
|
+
})]), [[resolveDirective("click-outside"), () => visible.value = false]]);
|
|
28616
29483
|
};
|
|
28617
29484
|
}
|
|
28618
29485
|
});
|
|
@@ -29410,6 +30277,7 @@ const installs = [
|
|
|
29410
30277
|
AccordionInstall,
|
|
29411
30278
|
AlertInstall,
|
|
29412
30279
|
AnchorInstall,
|
|
30280
|
+
AutoCompleteInstall,
|
|
29413
30281
|
AvatarInstall,
|
|
29414
30282
|
BackTopInstall,
|
|
29415
30283
|
BadgeInstall,
|
|
@@ -29481,4 +30349,4 @@ var vueDevui = {
|
|
|
29481
30349
|
installs.forEach((p) => app.use(p));
|
|
29482
30350
|
}
|
|
29483
30351
|
};
|
|
29484
|
-
export { Accordion, Alert, Anchor, Aside, Avatar, BackTop, Badge, Breadcrumb, DButton as Button, Card, Carousel, Cascader, Checkbox, Col, ColorPicker, Column, Comment, Content, Countdown, DatePicker, DraggableDirective, Drawer, DrawerService, Dropdown, DroppableDirective, EditableSelect, FixedOverlay, FlexibleOverlay, Footer, Form, FormControl, FormItem, FormLabel, FormOperation, Fullscreen, Gantt, Header, Icon, ImagePreviewDirective, ImagePreviewService, DInput as Input, InputIcon, InputNumber, Layout, loadingDirective as Loading, loading as LoadingService, Modal, NavSprite, Pagination, Panel, Popover, Progress, QuadrantDiagram, Radio, RadioGroup, Rate, ReadTip, Result, RippleDirective, Row, DSearch as Search, Select, Skeleton, SkeletonItem, Slider, SortableDirective, Splitter, Statistic, Status, StepsGuide, StickSlider, Sticky, Switch, Table, Tabs, Tag, TagInput, Textarea, TimeAxis, TimeAxisItem, TimePicker, Toast, ToastService, DTooltip as Tooltip, Transfer, Tree, TreeSelect, Upload, vueDevui as default };
|
|
30352
|
+
export { Accordion, Alert, Anchor, Aside, AutoComplete, Avatar, BackTop, Badge, Breadcrumb, DButton as Button, Card, Carousel, Cascader, Checkbox, Col, ColorPicker, Column, Comment, Content, Countdown, DatePicker, DraggableDirective, Drawer, DrawerService, Dropdown, DroppableDirective, EditableSelect, FixedOverlay, FlexibleOverlay, Footer, Form, FormControl, FormItem, FormLabel, FormOperation, Fullscreen, Gantt, Header, Icon, ImagePreviewDirective, ImagePreviewService, DInput as Input, InputIcon, InputNumber, Layout, loadingDirective as Loading, loading as LoadingService, Modal, NavSprite, Pagination, Panel, Popover, Progress, QuadrantDiagram, Radio, RadioGroup, Rate, ReadTip, Result, RippleDirective, Row, DSearch as Search, Select, Skeleton, SkeletonItem, Slider, SortableDirective, Splitter, Statistic, Status, StepsGuide, StickSlider, Sticky, Switch, Table, Tabs, Tag, TagInput, Textarea, TimeAxis, TimeAxisItem, TimePicker, Toast, ToastService, DTooltip as Tooltip, Transfer, Tree, TreeSelect, Upload, vueDevui as default };
|