@weitutech/by-components 1.1.69 → 1.1.70
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/by-components.common.js +236 -32
- package/lib/by-components.css +1 -1
- package/lib/by-components.umd.js +236 -32
- package/lib/by-components.umd.min.js +9 -9
- package/lib/index.css +1 -1
- package/package.json +1 -1
package/lib/by-components.umd.js
CHANGED
|
@@ -62403,8 +62403,8 @@ var table_component = normalizeComponent(
|
|
|
62403
62403
|
)
|
|
62404
62404
|
|
|
62405
62405
|
/* harmony default export */ var table = (table_component.exports);
|
|
62406
|
-
;// ./node_modules/cache-loader/dist/cjs.js?{"cacheDirectory":"node_modules/.cache/vue-loader","cacheIdentifier":"7d802f52-vue-loader-template"}!./node_modules/babel-loader/lib/index.js??clonedRuleSet-82.use[1]!./node_modules/@vue/cli-service/node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??ruleSet[1].rules[3]!./node_modules/cache-loader/dist/cjs.js??ruleSet[0].use[0]!./node_modules/@vue/cli-service/node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/form/form.vue?vue&type=template&id=
|
|
62407
|
-
var
|
|
62406
|
+
;// ./node_modules/cache-loader/dist/cjs.js?{"cacheDirectory":"node_modules/.cache/vue-loader","cacheIdentifier":"7d802f52-vue-loader-template"}!./node_modules/babel-loader/lib/index.js??clonedRuleSet-82.use[1]!./node_modules/@vue/cli-service/node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??ruleSet[1].rules[3]!./node_modules/cache-loader/dist/cjs.js??ruleSet[0].use[0]!./node_modules/@vue/cli-service/node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/form/form.vue?vue&type=template&id=6681f49c&scoped=true
|
|
62407
|
+
var formvue_type_template_id_6681f49c_scoped_true_render = function render() {
|
|
62408
62408
|
var _vm = this,
|
|
62409
62409
|
_c = _vm._self._c;
|
|
62410
62410
|
return _c('div', {
|
|
@@ -62583,7 +62583,7 @@ var formvue_type_template_id_12f005aa_scoped_true_render = function render() {
|
|
|
62583
62583
|
"batch-input-complete": function ($event) {
|
|
62584
62584
|
return _vm.handleBatchInputComplete($event, item);
|
|
62585
62585
|
},
|
|
62586
|
-
"focus": function ($event) {
|
|
62586
|
+
"batch-selector-focus": function ($event) {
|
|
62587
62587
|
return _vm.handleBatchSelectorFocus($event, item);
|
|
62588
62588
|
}
|
|
62589
62589
|
}
|
|
@@ -62753,7 +62753,7 @@ var formvue_type_template_id_12f005aa_scoped_true_render = function render() {
|
|
|
62753
62753
|
staticClass: "footer"
|
|
62754
62754
|
}, [_vm._t("footer")], 2)], 1);
|
|
62755
62755
|
};
|
|
62756
|
-
var
|
|
62756
|
+
var formvue_type_template_id_6681f49c_scoped_true_staticRenderFns = [];
|
|
62757
62757
|
|
|
62758
62758
|
;// ./node_modules/cache-loader/dist/cjs.js?{"cacheDirectory":"node_modules/.cache/vue-loader","cacheIdentifier":"7d802f52-vue-loader-template"}!./node_modules/babel-loader/lib/index.js??clonedRuleSet-82.use[1]!./node_modules/@vue/cli-service/node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??ruleSet[1].rules[3]!./node_modules/cache-loader/dist/cjs.js??ruleSet[0].use[0]!./node_modules/@vue/cli-service/node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/form/comps/pair-number-input.vue?vue&type=template&id=604235f6
|
|
62759
62759
|
var pair_number_inputvue_type_template_id_604235f6_render = function render() {
|
|
@@ -74210,8 +74210,8 @@ var ByCommonSelector_component = normalizeComponent(
|
|
|
74210
74210
|
)
|
|
74211
74211
|
|
|
74212
74212
|
/* harmony default export */ var ByCommonSelector = (ByCommonSelector_component.exports);
|
|
74213
|
-
;// ./node_modules/cache-loader/dist/cjs.js?{"cacheDirectory":"node_modules/.cache/vue-loader","cacheIdentifier":"7d802f52-vue-loader-template"}!./node_modules/babel-loader/lib/index.js??clonedRuleSet-82.use[1]!./node_modules/@vue/cli-service/node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??ruleSet[1].rules[3]!./node_modules/cache-loader/dist/cjs.js??ruleSet[0].use[0]!./node_modules/@vue/cli-service/node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/batch-query-selector/BatchQuerySelector.vue?vue&type=template&id=
|
|
74214
|
-
var
|
|
74213
|
+
;// ./node_modules/cache-loader/dist/cjs.js?{"cacheDirectory":"node_modules/.cache/vue-loader","cacheIdentifier":"7d802f52-vue-loader-template"}!./node_modules/babel-loader/lib/index.js??clonedRuleSet-82.use[1]!./node_modules/@vue/cli-service/node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??ruleSet[1].rules[3]!./node_modules/cache-loader/dist/cjs.js??ruleSet[0].use[0]!./node_modules/@vue/cli-service/node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/batch-query-selector/BatchQuerySelector.vue?vue&type=template&id=14840bc6
|
|
74214
|
+
var BatchQuerySelectorvue_type_template_id_14840bc6_render = function render() {
|
|
74215
74215
|
var _vm = this,
|
|
74216
74216
|
_c = _vm._self._c;
|
|
74217
74217
|
return _c('div', {
|
|
@@ -74220,6 +74220,7 @@ var BatchQuerySelectorvue_type_template_id_18d5c3ce_render = function render() {
|
|
|
74220
74220
|
}, [_c('div', {
|
|
74221
74221
|
staticClass: "selector-container"
|
|
74222
74222
|
}, [_c('el-select', {
|
|
74223
|
+
ref: "elSelect",
|
|
74223
74224
|
staticClass: "selector-input",
|
|
74224
74225
|
attrs: {
|
|
74225
74226
|
"placeholder": _vm.placeholder,
|
|
@@ -74229,11 +74230,13 @@ var BatchQuerySelectorvue_type_template_id_18d5c3ce_render = function render() {
|
|
|
74229
74230
|
"multiple": _vm.multiple,
|
|
74230
74231
|
"collapse-tags": _vm.collapseTags,
|
|
74231
74232
|
"filterable": "",
|
|
74232
|
-
"loading": _vm.loading
|
|
74233
|
+
"loading": _vm.loading,
|
|
74234
|
+
"filter-method": _vm.filterOptions
|
|
74233
74235
|
},
|
|
74234
74236
|
on: {
|
|
74235
74237
|
"change": _vm.handleChange,
|
|
74236
|
-
"focus": _vm.handleFocus
|
|
74238
|
+
"focus": _vm.handleFocus,
|
|
74239
|
+
"visible-change": _vm.handleDropdownVisibleChange
|
|
74237
74240
|
},
|
|
74238
74241
|
model: {
|
|
74239
74242
|
value: _vm.selectedValues,
|
|
@@ -74242,7 +74245,7 @@ var BatchQuerySelectorvue_type_template_id_18d5c3ce_render = function render() {
|
|
|
74242
74245
|
},
|
|
74243
74246
|
expression: "selectedValues"
|
|
74244
74247
|
}
|
|
74245
|
-
}, _vm._l(_vm.
|
|
74248
|
+
}, [_vm._l(_vm.visibleOptions, function (item) {
|
|
74246
74249
|
return _c('el-option', {
|
|
74247
74250
|
key: item[_vm.valueKey],
|
|
74248
74251
|
attrs: {
|
|
@@ -74251,7 +74254,26 @@ var BatchQuerySelectorvue_type_template_id_18d5c3ce_render = function render() {
|
|
|
74251
74254
|
"disabled": _vm.isOptionDisabled(item)
|
|
74252
74255
|
}
|
|
74253
74256
|
});
|
|
74254
|
-
}),
|
|
74257
|
+
}), _vm.hasMoreOptions ? _c('el-option', {
|
|
74258
|
+
staticClass: "load-more-option",
|
|
74259
|
+
attrs: {
|
|
74260
|
+
"disabled": "",
|
|
74261
|
+
"value": "load-more-option",
|
|
74262
|
+
"label": "加载更多..."
|
|
74263
|
+
}
|
|
74264
|
+
}, [_c('div', {
|
|
74265
|
+
staticClass: "load-more-text",
|
|
74266
|
+
on: {
|
|
74267
|
+
"click": function ($event) {
|
|
74268
|
+
$event.stopPropagation();
|
|
74269
|
+
return _vm.loadMoreOptions.apply(null, arguments);
|
|
74270
|
+
}
|
|
74271
|
+
}
|
|
74272
|
+
}, [_vm.loadingMore ? _c('i', {
|
|
74273
|
+
staticClass: "el-icon-loading"
|
|
74274
|
+
}) : _vm._e(), _c('span', [_vm._v(_vm._s(_vm.loadingMore ? '加载中...' : '点击加载更多'))]), _c('div', {
|
|
74275
|
+
staticClass: "load-more-info"
|
|
74276
|
+
}, [_vm._v("已显示 " + _vm._s(_vm.visibleOptions.length) + " / " + _vm._s(_vm.filteredOptions.length) + " 条")])])]) : _vm._e()], 2), _c('el-popover', {
|
|
74255
74277
|
attrs: {
|
|
74256
74278
|
"placement": "bottom-end",
|
|
74257
74279
|
"width": _vm.popoverWidth,
|
|
@@ -74342,7 +74364,7 @@ var BatchQuerySelectorvue_type_template_id_18d5c3ce_render = function render() {
|
|
|
74342
74364
|
}
|
|
74343
74365
|
})])], 1)], 1)]);
|
|
74344
74366
|
};
|
|
74345
|
-
var
|
|
74367
|
+
var BatchQuerySelectorvue_type_template_id_14840bc6_staticRenderFns = [];
|
|
74346
74368
|
|
|
74347
74369
|
;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-82.use[1]!./node_modules/cache-loader/dist/cjs.js??ruleSet[0].use[0]!./node_modules/@vue/cli-service/node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/batch-query-selector/BatchQuerySelector.vue?vue&type=script&lang=js
|
|
74348
74370
|
|
|
@@ -74355,6 +74377,7 @@ var BatchQuerySelectorvue_type_template_id_18d5c3ce_staticRenderFns = [];
|
|
|
74355
74377
|
|
|
74356
74378
|
|
|
74357
74379
|
|
|
74380
|
+
|
|
74358
74381
|
/* harmony default export */ var BatchQuerySelectorvue_type_script_lang_js = ({
|
|
74359
74382
|
name: 'BatchQuerySelector',
|
|
74360
74383
|
props: {
|
|
@@ -74442,6 +74465,16 @@ var BatchQuerySelectorvue_type_template_id_18d5c3ce_staticRenderFns = [];
|
|
|
74442
74465
|
customMapFunction: {
|
|
74443
74466
|
type: Function,
|
|
74444
74467
|
default: null
|
|
74468
|
+
},
|
|
74469
|
+
// 每页加载数量
|
|
74470
|
+
pageSize: {
|
|
74471
|
+
type: Number,
|
|
74472
|
+
default: 100
|
|
74473
|
+
},
|
|
74474
|
+
// 初始加载页数
|
|
74475
|
+
initialPageCount: {
|
|
74476
|
+
type: Number,
|
|
74477
|
+
default: 1
|
|
74445
74478
|
}
|
|
74446
74479
|
},
|
|
74447
74480
|
data() {
|
|
@@ -74451,8 +74484,15 @@ var BatchQuerySelectorvue_type_template_id_18d5c3ce_staticRenderFns = [];
|
|
|
74451
74484
|
inputType: 'id',
|
|
74452
74485
|
batchInputContent: '',
|
|
74453
74486
|
optionsList: [],
|
|
74487
|
+
filteredOptions: [],
|
|
74488
|
+
visibleOptions: [],
|
|
74454
74489
|
loading: false,
|
|
74455
|
-
hasLoaded: false
|
|
74490
|
+
hasLoaded: false,
|
|
74491
|
+
keyword: '',
|
|
74492
|
+
debounceTimer: null,
|
|
74493
|
+
dropdownVisible: false,
|
|
74494
|
+
currentPage: 1,
|
|
74495
|
+
loadingMore: false
|
|
74456
74496
|
};
|
|
74457
74497
|
},
|
|
74458
74498
|
computed: {
|
|
@@ -74468,6 +74508,20 @@ var BatchQuerySelectorvue_type_template_id_18d5c3ce_staticRenderFns = [];
|
|
|
74468
74508
|
return {
|
|
74469
74509
|
maxWidth: width
|
|
74470
74510
|
};
|
|
74511
|
+
},
|
|
74512
|
+
// 选中项的展示
|
|
74513
|
+
selectedOptionsDisplay() {
|
|
74514
|
+
return this.optionsList.filter(item => {
|
|
74515
|
+
if (this.multiple && Array.isArray(this.selectedValues)) {
|
|
74516
|
+
return this.selectedValues.includes(item[this.valueKey]);
|
|
74517
|
+
} else {
|
|
74518
|
+
return this.selectedValues === item[this.valueKey];
|
|
74519
|
+
}
|
|
74520
|
+
});
|
|
74521
|
+
},
|
|
74522
|
+
// 是否还有更多选项
|
|
74523
|
+
hasMoreOptions() {
|
|
74524
|
+
return this.visibleOptions.length < this.filteredOptions.length;
|
|
74471
74525
|
}
|
|
74472
74526
|
},
|
|
74473
74527
|
watch: {
|
|
@@ -74480,8 +74534,24 @@ var BatchQuerySelectorvue_type_template_id_18d5c3ce_staticRenderFns = [];
|
|
|
74480
74534
|
options: {
|
|
74481
74535
|
handler(val) {
|
|
74482
74536
|
this.optionsList = [...val];
|
|
74537
|
+
this.filteredOptions = [...val];
|
|
74538
|
+
// 初始加载多页数据
|
|
74539
|
+
this.currentPage = this.initialPageCount;
|
|
74540
|
+
this.updateVisibleOptions();
|
|
74483
74541
|
},
|
|
74484
74542
|
immediate: true
|
|
74543
|
+
},
|
|
74544
|
+
keyword(val) {
|
|
74545
|
+
this.filterOptionsByKeyword(val);
|
|
74546
|
+
},
|
|
74547
|
+
dropdownVisible(val) {
|
|
74548
|
+
if (val) {
|
|
74549
|
+
this.$nextTick(() => {
|
|
74550
|
+
this.setupScrollListener();
|
|
74551
|
+
});
|
|
74552
|
+
} else {
|
|
74553
|
+
this.removeScrollListener();
|
|
74554
|
+
}
|
|
74485
74555
|
}
|
|
74486
74556
|
},
|
|
74487
74557
|
created() {
|
|
@@ -74507,12 +74577,81 @@ var BatchQuerySelectorvue_type_template_id_18d5c3ce_staticRenderFns = [];
|
|
|
74507
74577
|
this.$emit('change', val);
|
|
74508
74578
|
},
|
|
74509
74579
|
// 处理获取焦点
|
|
74510
|
-
handleFocus() {
|
|
74580
|
+
handleFocus(e) {
|
|
74511
74581
|
// 如果配置了自动加载且提供了loadOptions方法,每次获取焦点时都加载数据
|
|
74512
74582
|
if (this.autoLoad && this.loadOptions) {
|
|
74513
74583
|
this.fetchOptions();
|
|
74514
74584
|
}
|
|
74515
|
-
this.$emit('focus');
|
|
74585
|
+
this.$emit('batch-selector-focus', e);
|
|
74586
|
+
},
|
|
74587
|
+
// 处理下拉框显示/隐藏
|
|
74588
|
+
handleDropdownVisibleChange(visible) {
|
|
74589
|
+
this.dropdownVisible = visible;
|
|
74590
|
+
},
|
|
74591
|
+
// 设置滚动监听
|
|
74592
|
+
setupScrollListener() {
|
|
74593
|
+
this.removeScrollListener(); // 先移除之前的监听器
|
|
74594
|
+
|
|
74595
|
+
// 获取el-select-dropdown元素
|
|
74596
|
+
const dropdownEl = document.querySelector('.el-select-dropdown.el-popper');
|
|
74597
|
+
if (!dropdownEl) return;
|
|
74598
|
+
|
|
74599
|
+
// 获取下拉框的滚动容器
|
|
74600
|
+
const scrollContainer = dropdownEl.querySelector('.el-select-dropdown__wrap');
|
|
74601
|
+
if (!scrollContainer) return;
|
|
74602
|
+
|
|
74603
|
+
// 添加滚动监听
|
|
74604
|
+
this.handleScroll = this.createScrollHandler(scrollContainer);
|
|
74605
|
+
scrollContainer.addEventListener('scroll', this.handleScroll);
|
|
74606
|
+
|
|
74607
|
+
// 保存引用,以便后续移除
|
|
74608
|
+
this.scrollContainer = scrollContainer;
|
|
74609
|
+
},
|
|
74610
|
+
// 创建滚动处理函数
|
|
74611
|
+
createScrollHandler(container) {
|
|
74612
|
+
return () => {
|
|
74613
|
+
const {
|
|
74614
|
+
scrollTop,
|
|
74615
|
+
scrollHeight,
|
|
74616
|
+
clientHeight
|
|
74617
|
+
} = container;
|
|
74618
|
+
|
|
74619
|
+
// 当滚动到底部附近时,自动加载更多数据
|
|
74620
|
+
if (scrollTop + clientHeight >= scrollHeight - 50) {
|
|
74621
|
+
this.loadMoreOptions();
|
|
74622
|
+
}
|
|
74623
|
+
};
|
|
74624
|
+
},
|
|
74625
|
+
// 移除滚动监听
|
|
74626
|
+
removeScrollListener() {
|
|
74627
|
+
if (this.scrollContainer && this.handleScroll) {
|
|
74628
|
+
this.scrollContainer.removeEventListener('scroll', this.handleScroll);
|
|
74629
|
+
this.scrollContainer = null;
|
|
74630
|
+
}
|
|
74631
|
+
},
|
|
74632
|
+
// 加载更多选项
|
|
74633
|
+
loadMoreOptions() {
|
|
74634
|
+
if (this.loadingMore || this.currentPage * this.pageSize >= this.filteredOptions.length) return;
|
|
74635
|
+
this.loadingMore = true;
|
|
74636
|
+
|
|
74637
|
+
// 使用setTimeout模拟异步加载,避免界面卡顿
|
|
74638
|
+
setTimeout(() => {
|
|
74639
|
+
this.currentPage++;
|
|
74640
|
+
this.updateVisibleOptions();
|
|
74641
|
+
this.loadingMore = false;
|
|
74642
|
+
|
|
74643
|
+
// 如果下拉列表已经打开,更新滚动监听
|
|
74644
|
+
if (this.dropdownVisible) {
|
|
74645
|
+
this.$nextTick(() => {
|
|
74646
|
+
this.setupScrollListener();
|
|
74647
|
+
});
|
|
74648
|
+
}
|
|
74649
|
+
}, 200);
|
|
74650
|
+
},
|
|
74651
|
+
// 更新可见选项
|
|
74652
|
+
updateVisibleOptions() {
|
|
74653
|
+
// 直接从过滤后的选项中获取当前页的选项,保持原始顺序
|
|
74654
|
+
this.visibleOptions = this.filteredOptions.slice(0, this.currentPage * this.pageSize);
|
|
74516
74655
|
},
|
|
74517
74656
|
// 获取选项数据
|
|
74518
74657
|
async fetchOptions(params) {
|
|
@@ -74522,6 +74661,11 @@ var BatchQuerySelectorvue_type_template_id_18d5c3ce_staticRenderFns = [];
|
|
|
74522
74661
|
const result = await this.loadOptions(params);
|
|
74523
74662
|
if (Array.isArray(result)) {
|
|
74524
74663
|
this.optionsList = result;
|
|
74664
|
+
this.filteredOptions = result;
|
|
74665
|
+
|
|
74666
|
+
// 初始加载多页数据
|
|
74667
|
+
this.currentPage = this.initialPageCount;
|
|
74668
|
+
this.updateVisibleOptions();
|
|
74525
74669
|
} else {
|
|
74526
74670
|
console.warn('【BatchQuerySelector组件】: loadOptions 应该返回一个数组');
|
|
74527
74671
|
}
|
|
@@ -74537,6 +74681,36 @@ var BatchQuerySelectorvue_type_template_id_18d5c3ce_staticRenderFns = [];
|
|
|
74537
74681
|
refreshOptions(params) {
|
|
74538
74682
|
return this.fetchOptions(params);
|
|
74539
74683
|
},
|
|
74684
|
+
// 过滤选项方法
|
|
74685
|
+
filterOptions(query) {
|
|
74686
|
+
this.keyword = query;
|
|
74687
|
+
return true; // 返回true让所有选项通过,实际过滤在filterOptionsByKeyword中处理
|
|
74688
|
+
},
|
|
74689
|
+
// 根据关键词过滤选项
|
|
74690
|
+
filterOptionsByKeyword(query) {
|
|
74691
|
+
// 使用防抖处理,避免频繁计算
|
|
74692
|
+
clearTimeout(this.debounceTimer);
|
|
74693
|
+
this.debounceTimer = setTimeout(() => {
|
|
74694
|
+
if (query) {
|
|
74695
|
+
// 如果有搜索关键词,按关键词过滤
|
|
74696
|
+
this.filteredOptions = this.optionsList.filter(item => {
|
|
74697
|
+
const label = String(item[this.labelKey]).toLowerCase();
|
|
74698
|
+
const value = String(item[this.valueKey]).toLowerCase();
|
|
74699
|
+
const lowercaseQuery = query.toLowerCase();
|
|
74700
|
+
return label.includes(lowercaseQuery) || value.includes(lowercaseQuery);
|
|
74701
|
+
});
|
|
74702
|
+
} else {
|
|
74703
|
+
// 如果没有搜索关键词,显示所有选项
|
|
74704
|
+
this.filteredOptions = [...this.optionsList];
|
|
74705
|
+
}
|
|
74706
|
+
|
|
74707
|
+
// 重置当前页,但加载多页
|
|
74708
|
+
this.currentPage = this.initialPageCount;
|
|
74709
|
+
|
|
74710
|
+
// 更新可见选项
|
|
74711
|
+
this.updateVisibleOptions();
|
|
74712
|
+
}, 200);
|
|
74713
|
+
},
|
|
74540
74714
|
// 处理批量输入
|
|
74541
74715
|
handleBatchInput() {
|
|
74542
74716
|
if (!this.batchInputContent.trim()) {
|
|
@@ -74553,20 +74727,36 @@ var BatchQuerySelectorvue_type_template_id_18d5c3ce_staticRenderFns = [];
|
|
|
74553
74727
|
|
|
74554
74728
|
// 根据输入类型匹配数据
|
|
74555
74729
|
let matchedValues = [];
|
|
74730
|
+
let matchedItems = [];
|
|
74556
74731
|
if (this.customMapFunction) {
|
|
74557
74732
|
// 使用自定义映射函数
|
|
74558
|
-
matchedValues = this.customMapFunction(inputValues, this.inputType, this.
|
|
74733
|
+
matchedValues = this.customMapFunction(inputValues, this.inputType, this.optionsList);
|
|
74734
|
+
// 获取匹配的完整选项对象
|
|
74735
|
+
matchedItems = this.optionsList.filter(item => matchedValues.includes(item[this.valueKey]));
|
|
74559
74736
|
} else {
|
|
74560
74737
|
// 默认映射逻辑
|
|
74561
74738
|
const searchKey = this.inputType === 'id' ? this.valueKey : this.labelKey;
|
|
74562
|
-
|
|
74563
|
-
|
|
74739
|
+
|
|
74740
|
+
// 先获取匹配的完整选项对象
|
|
74741
|
+
matchedItems = this.optionsList.filter(item => {
|
|
74564
74742
|
// 排除禁用的选项
|
|
74565
74743
|
if (this.isOptionDisabled(item)) {
|
|
74566
74744
|
return false;
|
|
74567
74745
|
}
|
|
74568
|
-
return inputValues.
|
|
74569
|
-
})
|
|
74746
|
+
return inputValues.some(input => String(item[searchKey]).toLowerCase() === String(input).toLowerCase());
|
|
74747
|
+
});
|
|
74748
|
+
|
|
74749
|
+
// 然后提取值
|
|
74750
|
+
matchedValues = matchedItems.map(item => item[this.valueKey]);
|
|
74751
|
+
}
|
|
74752
|
+
|
|
74753
|
+
// 如果没有匹配项,尝试进行模糊匹配
|
|
74754
|
+
if (matchedValues.length === 0 && this.inputType === 'name') {
|
|
74755
|
+
matchedItems = this.optionsList.filter(item => {
|
|
74756
|
+
if (this.isOptionDisabled(item)) return false;
|
|
74757
|
+
return inputValues.some(input => String(item[this.labelKey]).toLowerCase().includes(String(input).toLowerCase()));
|
|
74758
|
+
});
|
|
74759
|
+
matchedValues = matchedItems.map(item => item[this.valueKey]);
|
|
74570
74760
|
}
|
|
74571
74761
|
|
|
74572
74762
|
// 更新选中值
|
|
@@ -74593,9 +74783,14 @@ var BatchQuerySelectorvue_type_template_id_18d5c3ce_staticRenderFns = [];
|
|
|
74593
74783
|
this.$emit('batch-input-complete', {
|
|
74594
74784
|
inputValues,
|
|
74595
74785
|
matchedValues,
|
|
74786
|
+
matchedItems,
|
|
74596
74787
|
type: this.inputType
|
|
74597
74788
|
});
|
|
74598
74789
|
}
|
|
74790
|
+
},
|
|
74791
|
+
beforeDestroy() {
|
|
74792
|
+
// 移除滚动监听器
|
|
74793
|
+
this.removeScrollListener();
|
|
74599
74794
|
}
|
|
74600
74795
|
});
|
|
74601
74796
|
;// ./src/components/batch-query-selector/BatchQuerySelector.vue?vue&type=script&lang=js
|
|
@@ -74610,8 +74805,8 @@ var BatchQuerySelectorvue_type_template_id_18d5c3ce_staticRenderFns = [];
|
|
|
74610
74805
|
;
|
|
74611
74806
|
var BatchQuerySelector_component = normalizeComponent(
|
|
74612
74807
|
batch_query_selector_BatchQuerySelectorvue_type_script_lang_js,
|
|
74613
|
-
|
|
74614
|
-
|
|
74808
|
+
BatchQuerySelectorvue_type_template_id_14840bc6_render,
|
|
74809
|
+
BatchQuerySelectorvue_type_template_id_14840bc6_staticRenderFns,
|
|
74615
74810
|
false,
|
|
74616
74811
|
null,
|
|
74617
74812
|
null,
|
|
@@ -74903,6 +75098,7 @@ var BatchQuerySelector_component = normalizeComponent(
|
|
|
74903
75098
|
});
|
|
74904
75099
|
},
|
|
74905
75100
|
handleBatchSelectorFocus(event, item) {
|
|
75101
|
+
console.log('focus-22222222');
|
|
74906
75102
|
this.$emit('batch-selector-focus', {
|
|
74907
75103
|
...event,
|
|
74908
75104
|
item
|
|
@@ -74912,10 +75108,10 @@ var BatchQuerySelector_component = normalizeComponent(
|
|
|
74912
75108
|
});
|
|
74913
75109
|
;// ./src/components/form/form.vue?vue&type=script&lang=js
|
|
74914
75110
|
/* harmony default export */ var form_formvue_type_script_lang_js = (formvue_type_script_lang_js);
|
|
74915
|
-
;// ./node_modules/@vue/cli-service/node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-64.use[0]!./node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??clonedRuleSet-64.use[1]!./node_modules/@vue/cli-service/node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/@vue/cli-service/node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-64.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-64.use[3]!./node_modules/cache-loader/dist/cjs.js??ruleSet[0].use[0]!./node_modules/@vue/cli-service/node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/form/form.vue?vue&type=style&index=0&id=
|
|
75111
|
+
;// ./node_modules/@vue/cli-service/node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-64.use[0]!./node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??clonedRuleSet-64.use[1]!./node_modules/@vue/cli-service/node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/@vue/cli-service/node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-64.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-64.use[3]!./node_modules/cache-loader/dist/cjs.js??ruleSet[0].use[0]!./node_modules/@vue/cli-service/node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/form/form.vue?vue&type=style&index=0&id=6681f49c&prod&lang=scss&scoped=true
|
|
74916
75112
|
// extracted by mini-css-extract-plugin
|
|
74917
75113
|
|
|
74918
|
-
;// ./src/components/form/form.vue?vue&type=style&index=0&id=
|
|
75114
|
+
;// ./src/components/form/form.vue?vue&type=style&index=0&id=6681f49c&prod&lang=scss&scoped=true
|
|
74919
75115
|
|
|
74920
75116
|
;// ./src/components/form/form.vue
|
|
74921
75117
|
|
|
@@ -74928,18 +75124,18 @@ var BatchQuerySelector_component = normalizeComponent(
|
|
|
74928
75124
|
|
|
74929
75125
|
var form_component = normalizeComponent(
|
|
74930
75126
|
form_formvue_type_script_lang_js,
|
|
74931
|
-
|
|
74932
|
-
|
|
75127
|
+
formvue_type_template_id_6681f49c_scoped_true_render,
|
|
75128
|
+
formvue_type_template_id_6681f49c_scoped_true_staticRenderFns,
|
|
74933
75129
|
false,
|
|
74934
75130
|
null,
|
|
74935
|
-
"
|
|
75131
|
+
"6681f49c",
|
|
74936
75132
|
null
|
|
74937
75133
|
|
|
74938
75134
|
)
|
|
74939
75135
|
|
|
74940
75136
|
/* harmony default export */ var form_form = (form_component.exports);
|
|
74941
|
-
;// ./node_modules/cache-loader/dist/cjs.js?{"cacheDirectory":"node_modules/.cache/vue-loader","cacheIdentifier":"7d802f52-vue-loader-template"}!./node_modules/babel-loader/lib/index.js??clonedRuleSet-82.use[1]!./node_modules/@vue/cli-service/node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??ruleSet[1].rules[3]!./node_modules/cache-loader/dist/cjs.js??ruleSet[0].use[0]!./node_modules/@vue/cli-service/node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/page-search/page-search.vue?vue&type=template&id=
|
|
74942
|
-
var
|
|
75137
|
+
;// ./node_modules/cache-loader/dist/cjs.js?{"cacheDirectory":"node_modules/.cache/vue-loader","cacheIdentifier":"7d802f52-vue-loader-template"}!./node_modules/babel-loader/lib/index.js??clonedRuleSet-82.use[1]!./node_modules/@vue/cli-service/node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??ruleSet[1].rules[3]!./node_modules/cache-loader/dist/cjs.js??ruleSet[0].use[0]!./node_modules/@vue/cli-service/node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/page-search/page-search.vue?vue&type=template&id=69194707
|
|
75138
|
+
var page_searchvue_type_template_id_69194707_render = function render() {
|
|
74943
75139
|
var _vm = this,
|
|
74944
75140
|
_c = _vm._self._c;
|
|
74945
75141
|
return _c('div', {
|
|
@@ -74955,7 +75151,9 @@ var page_searchvue_type_template_id_d39cfe72_render = function render() {
|
|
|
74955
75151
|
"change": _vm.handleChange,
|
|
74956
75152
|
"queryBtnClick": _vm.handleQueryClick,
|
|
74957
75153
|
"submit": _vm.submit,
|
|
74958
|
-
"reset": _vm.reset
|
|
75154
|
+
"reset": _vm.reset,
|
|
75155
|
+
"batch-input-complete": _vm.handleBatchInputComplete,
|
|
75156
|
+
"batch-selector-focus": _vm.handleBatchSelectorFocus
|
|
74959
75157
|
},
|
|
74960
75158
|
scopedSlots: _vm._u([{
|
|
74961
75159
|
key: "header",
|
|
@@ -74986,7 +75184,7 @@ var page_searchvue_type_template_id_d39cfe72_render = function render() {
|
|
|
74986
75184
|
})], null, true)
|
|
74987
75185
|
}, 'by-form', _vm.searchFormConfig, false))], 1);
|
|
74988
75186
|
};
|
|
74989
|
-
var
|
|
75187
|
+
var page_searchvue_type_template_id_69194707_staticRenderFns = [];
|
|
74990
75188
|
|
|
74991
75189
|
;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-82.use[1]!./node_modules/cache-loader/dist/cjs.js??ruleSet[0].use[0]!./node_modules/@vue/cli-service/node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/components/page-search/page-search.vue?vue&type=script&lang=js
|
|
74992
75190
|
|
|
@@ -75085,6 +75283,12 @@ var page_searchvue_type_template_id_d39cfe72_staticRenderFns = [];
|
|
|
75085
75283
|
},
|
|
75086
75284
|
reset() {
|
|
75087
75285
|
this.$emit('reset');
|
|
75286
|
+
},
|
|
75287
|
+
handleBatchSelectorFocus(event) {
|
|
75288
|
+
this.$emit('batch-selector-focus', event);
|
|
75289
|
+
},
|
|
75290
|
+
handleBatchInputComplete(event) {
|
|
75291
|
+
this.$emit('batch-input-complete', event);
|
|
75088
75292
|
}
|
|
75089
75293
|
}
|
|
75090
75294
|
});
|
|
@@ -75100,8 +75304,8 @@ var page_searchvue_type_template_id_d39cfe72_staticRenderFns = [];
|
|
|
75100
75304
|
;
|
|
75101
75305
|
var page_search_component = normalizeComponent(
|
|
75102
75306
|
page_search_page_searchvue_type_script_lang_js,
|
|
75103
|
-
|
|
75104
|
-
|
|
75307
|
+
page_searchvue_type_template_id_69194707_render,
|
|
75308
|
+
page_searchvue_type_template_id_69194707_staticRenderFns,
|
|
75105
75309
|
false,
|
|
75106
75310
|
null,
|
|
75107
75311
|
null,
|