@tongfun/tf-widget 0.1.172 → 0.1.174

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.
@@ -133371,7 +133371,7 @@ src.install = function (Vue) {
133371
133371
 
133372
133372
  /***/ }),
133373
133373
 
133374
- /***/ 45422:
133374
+ /***/ 48143:
133375
133375
  /***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
133376
133376
 
133377
133377
  "use strict";
@@ -133381,7 +133381,7 @@ __webpack_require__.d(__webpack_exports__, {
133381
133381
  "Z": function() { return /* binding */ tf_ag_grid; }
133382
133382
  });
133383
133383
 
133384
- ;// CONCATENATED MODULE: ./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/tf-ag-grid/src/index.vue?vue&type=template&id=369aa5c8&scoped=true&
133384
+ ;// CONCATENATED MODULE: ./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/tf-ag-grid/src/index.vue?vue&type=template&id=4250fa0d&scoped=true&
133385
133385
  var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"tf-common-table-container"},[_c('ag-grid-vue',_vm._b({directives:[{name:"loading",rawName:"v-loading",value:(_vm.loading),expression:"loading"},{name:"agGridSetting",rawName:"v-agGridSetting",value:(_vm.entityTableName),expression:"entityTableName"}],ref:_vm.tableRef,staticClass:"ag-theme-alpine",staticStyle:{"width":"100%","height":"100%"},attrs:{"context":_vm.context,"column-defs":_vm.columns},on:{"grid-ready":_vm.onGridReady,"cell-clicked":_vm.cellClick,"body-scroll":_vm.bodyScroll,"row-drag-end":_vm.rowDragEnd,"row-clicked":_vm.rowClicked,"row-selected":_vm.rowSelected,"drag-stopped":_vm.dragStopped,"column-moved":_vm.columnMoved,"column-resized":_vm.columnResized,"cell-double-clicked":_vm.cellDBLClick,"selection-changed":_vm.selectionChange}},'ag-grid-vue',_vm.customAttrs,false))],1)}
133386
133386
  var staticRenderFns = []
133387
133387
 
@@ -133390,16 +133390,43 @@ var staticRenderFns = []
133390
133390
  var decimal = __webpack_require__(90482);
133391
133391
  // EXTERNAL MODULE: ./node_modules/ag-grid-vue/main.js
133392
133392
  var main = __webpack_require__(61146);
133393
- ;// CONCATENATED MODULE: ./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/tf-ag-grid/src/components/tf-filter/index.vue?vue&type=template&id=385b6903&scoped=true&
133394
- var tf_filtervue_type_template_id_385b6903_scoped_true_render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"column-header-directive",on:{"click":function($event){return _vm.onSortRequested($event)}}},[_c('span',[_vm._v(_vm._s(_vm.params.displayName))]),(_vm.order)?_c('span',[_c('i',{class:[_vm.order === 'asc' ? 'el-icon-top' : 'el-icon-bottom']})]):_vm._e(),_c('div',{class:{'filter-main': _vm.isClick || _vm.isFilter }},[_c('el-popover',{attrs:{"width":"200","trigger":"manual","placement":"bottom"},model:{value:(_vm.isClick),callback:function ($$v) {_vm.isClick=$$v},expression:"isClick"}},[(_vm.isClick)?_c('div',{directives:[{name:"clickoutside",rawName:"v-clickoutside",value:(_vm.handleClickOut),expression:"handleClickOut"}],staticClass:"filter-main-context"},[_c('TfInput',{attrs:{"full-border":"","not-form":"","placeholder":"输入需要过滤的值"},nativeOn:{"keyup":function($event){if(!$event.type.indexOf('key')&&_vm._k($event.keyCode,"enter",13,$event.key,"Enter")){ return null; }return _vm.handleSubmit.apply(null, arguments)}},model:{value:(_vm.text),callback:function ($$v) {_vm.text=$$v},expression:"text"}}),_c('div',{staticClass:"option-buttons"},[_c('el-button',{attrs:{"size":"mini"},on:{"click":_vm.handleCancel}},[_vm._v("重置")]),_c('el-button',{attrs:{"size":"mini"},on:{"click":_vm.handleSubmit}},[_vm._v("确定")])],1)],1):_vm._e(),_c('SvgIcon',{staticClass:"filter-icon",attrs:{"slot":"reference","icon-class":"filter"},on:{"click":function($event){$event.stopPropagation();return _vm.handleFilterClick.apply(null, arguments)}},slot:"reference"})],1)],1)])}
133395
- var tf_filtervue_type_template_id_385b6903_scoped_true_staticRenderFns = []
133393
+ ;// CONCATENATED MODULE: ./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/tf-ag-grid/src/components/tf-filter/index.vue?vue&type=template&id=25660bba&scoped=true&
133394
+ var tf_filtervue_type_template_id_25660bba_scoped_true_render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"column-header-directive",on:{"click":function($event){return _vm.onSortRequested($event)}}},[_c('span',[_vm._v(_vm._s(_vm.params.displayName))]),(_vm.order)?_c('span',[_c('i',{class:[_vm.order === 'asc' ? 'el-icon-top' : 'el-icon-bottom']})]):_vm._e(),_c('div',{class:{'filter-main': _vm.isClick || _vm.isFilter }},[_c('el-popover',{attrs:{"width":"200","trigger":"manual","placement":"bottom"},model:{value:(_vm.isClick),callback:function ($$v) {_vm.isClick=$$v},expression:"isClick"}},[(_vm.isClick)?_c('div',{directives:[{name:"clickoutside",rawName:"v-clickoutside",value:(_vm.handleClickOut),expression:"handleClickOut"}],staticClass:"filter-main-context"},[_c('TfInput',{attrs:{"full-border":"","not-form":"","placeholder":"输入需要过滤的值"},on:{"input":function($event){return _vm.handleInput($event)}},nativeOn:{"keyup":function($event){if(!$event.type.indexOf('key')&&_vm._k($event.keyCode,"enter",13,$event.key,"Enter")){ return null; }return _vm.handleSubmit.apply(null, arguments)}},model:{value:(_vm.text),callback:function ($$v) {_vm.text=$$v},expression:"text"}}),(_vm.params.column.colDef.isSelectQuery)?[_c('div',{staticClass:"filter-list filter-select-list"},_vm._l((_vm.searchData),function(item,index){return _c('div',{key:index,staticClass:"filter-list-item",class:{select:_vm.searchData.find(function (value) { return value.name === item.name; })},on:{"click":function($event){return _vm.handleSelect(item)}}},[_c('div',{staticClass:"text-select"},[_vm._v(_vm._s(item.name))])])}),0),_c('div',{staticClass:"filter-list"},_vm._l((_vm.options),function(item,index){return _c('div',{key:index,staticClass:"filter-list-item",on:{"click":function($event){return _vm.handleSelect(item)}}},[_c('div',{staticClass:"text"},[_vm._v(_vm._s(item.name))])])}),0)]:_vm._e(),_c('div',{staticClass:"option-buttons"},[_c('el-button',{attrs:{"size":"mini"},on:{"click":_vm.handleCancel}},[_vm._v("重置")]),_c('el-button',{attrs:{"size":"mini"},on:{"click":_vm.handleSubmit}},[_vm._v("确定")])],1)],2):_vm._e(),_c('SvgIcon',{staticClass:"filter-icon",attrs:{"slot":"reference","icon-class":"filter"},on:{"click":function($event){$event.stopPropagation();return _vm.handleFilterClick.apply(null, arguments)}},slot:"reference"})],1)],1)])}
133395
+ var tf_filtervue_type_template_id_25660bba_scoped_true_staticRenderFns = []
133396
133396
 
133397
133397
 
133398
+ // EXTERNAL MODULE: ./node_modules/core-js/modules/es.array.push.js
133399
+ var es_array_push = __webpack_require__(57658);
133398
133400
  // EXTERNAL MODULE: ./package/tf-input/index.js + 94 modules
133399
133401
  var tf_input = __webpack_require__(99610);
133400
133402
  // EXTERNAL MODULE: ./node_modules/element-ui/src/utils/clickoutside.js + 1 modules
133401
133403
  var clickoutside = __webpack_require__(96410);
133402
133404
  ;// CONCATENATED MODULE: ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/tf-ag-grid/src/components/tf-filter/index.vue?vue&type=script&lang=js&
133405
+
133406
+ //
133407
+ //
133408
+ //
133409
+ //
133410
+ //
133411
+ //
133412
+ //
133413
+ //
133414
+ //
133415
+ //
133416
+ //
133417
+ //
133418
+ //
133419
+ //
133420
+ //
133421
+ //
133422
+ //
133423
+ //
133424
+ //
133425
+ //
133426
+ //
133427
+ //
133428
+ //
133429
+ //
133403
133430
  //
133404
133431
  //
133405
133432
  //
@@ -133453,7 +133480,11 @@ var clickoutside = __webpack_require__(96410);
133453
133480
  return {
133454
133481
  text: '',
133455
133482
  order: '',
133456
- isClick: false
133483
+ isClick: false,
133484
+ searchData: [],
133485
+ // 搜索结果列表
133486
+ allOptionsList: [],
133487
+ options: []
133457
133488
  };
133458
133489
  },
133459
133490
  computed: {
@@ -133462,6 +133493,25 @@ var clickoutside = __webpack_require__(96410);
133462
133493
  }
133463
133494
  },
133464
133495
  methods: {
133496
+ /** 下拉选择 */
133497
+ handleSelect(item) {
133498
+ if (this.searchData.find(value => value.name === item.name)) {
133499
+ this.searchData = (this.searchData || []).filter(value => value.name !== item.name);
133500
+ this.options.splice(item.index, 0, item);
133501
+ return;
133502
+ }
133503
+ this.searchData.push(item);
133504
+ this.options = this.options.filter(value => value.name !== item.name);
133505
+ },
133506
+ /** 处理输入框值的变化 */
133507
+ handleInput(query) {
133508
+ if (query !== '') {
133509
+ this.options = this.allOptionsList.filter(item => item.name.toLowerCase().includes(query.toLowerCase())).splice(0, 50);
133510
+ } else {
133511
+ const options = Array.from(this.allOptionsList);
133512
+ this.options = options.filter(item => !(this.searchData || []).find(value => value.name === item.name)).splice(0, 50);
133513
+ }
133514
+ },
133465
133515
  /** 排序 */
133466
133516
  onSortRequested(event) {
133467
133517
  switch (this.order) {
@@ -133484,17 +133534,37 @@ var clickoutside = __webpack_require__(96410);
133484
133534
  /** 图标点击事件 */
133485
133535
  handleFilterClick() {
133486
133536
  this.isClick = !this.isClick;
133537
+ if (this.params.column.colDef.isSelectQuery) {
133538
+ this.handelOptions();
133539
+ }
133540
+ },
133541
+ /** 处理下拉筛选的数据 */
133542
+ handelOptions() {
133543
+ this.allOptionsList = [];
133544
+ this.options = [];
133545
+ let options = this.params.context.componentParent.data.map(item => {
133546
+ return item[this.params.column.colDef.field];
133547
+ });
133548
+ options = Array.from(new Set(options)).filter(item => item);
133549
+ options.forEach((item, index) => {
133550
+ this.allOptionsList.push({
133551
+ name: item,
133552
+ index: index
133553
+ });
133554
+ });
133555
+ this.handleInput(this.text || '');
133487
133556
  },
133488
133557
  /** 重置 */
133489
133558
  handleCancel() {
133490
133559
  this.text = '';
133491
133560
  this.handleSubmit();
133561
+ this.searchData = [];
133492
133562
  },
133493
133563
  /** 确认 */
133494
133564
  handleSubmit() {
133495
133565
  this.isClick = false;
133496
133566
  this.params.context.componentParent.handleUpdateFilter({
133497
- value: this.text,
133567
+ value: this.searchData.length ? this.searchData : this.text,
133498
133568
  params: this.params
133499
133569
  });
133500
133570
  // 过滤后根据当前列的排序方式进行排序
@@ -133504,10 +133574,10 @@ var clickoutside = __webpack_require__(96410);
133504
133574
  });
133505
133575
  ;// CONCATENATED MODULE: ./package/tf-ag-grid/src/components/tf-filter/index.vue?vue&type=script&lang=js&
133506
133576
  /* harmony default export */ var components_tf_filtervue_type_script_lang_js_ = (tf_filtervue_type_script_lang_js_);
133507
- ;// CONCATENATED MODULE: ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-32.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-32.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-32.use[2]!./node_modules/less-loader/dist/cjs.js??clonedRuleSet-32.use[3]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/tf-ag-grid/src/components/tf-filter/index.vue?vue&type=style&index=0&id=385b6903&prod&lang=less&scoped=true&
133577
+ ;// CONCATENATED MODULE: ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-32.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-32.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-32.use[2]!./node_modules/less-loader/dist/cjs.js??clonedRuleSet-32.use[3]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/tf-ag-grid/src/components/tf-filter/index.vue?vue&type=style&index=0&id=25660bba&prod&lang=less&scoped=true&
133508
133578
  // extracted by mini-css-extract-plugin
133509
133579
 
133510
- ;// CONCATENATED MODULE: ./package/tf-ag-grid/src/components/tf-filter/index.vue?vue&type=style&index=0&id=385b6903&prod&lang=less&scoped=true&
133580
+ ;// CONCATENATED MODULE: ./package/tf-ag-grid/src/components/tf-filter/index.vue?vue&type=style&index=0&id=25660bba&prod&lang=less&scoped=true&
133511
133581
 
133512
133582
  // EXTERNAL MODULE: ./node_modules/@vue/vue-loader-v15/lib/runtime/componentNormalizer.js
133513
133583
  var componentNormalizer = __webpack_require__(1001);
@@ -133522,11 +133592,11 @@ var componentNormalizer = __webpack_require__(1001);
133522
133592
 
133523
133593
  var component = (0,componentNormalizer/* default */.Z)(
133524
133594
  components_tf_filtervue_type_script_lang_js_,
133525
- tf_filtervue_type_template_id_385b6903_scoped_true_render,
133526
- tf_filtervue_type_template_id_385b6903_scoped_true_staticRenderFns,
133595
+ tf_filtervue_type_template_id_25660bba_scoped_true_render,
133596
+ tf_filtervue_type_template_id_25660bba_scoped_true_staticRenderFns,
133527
133597
  false,
133528
133598
  null,
133529
- "385b6903",
133599
+ "25660bba",
133530
133600
  null
133531
133601
 
133532
133602
  )
@@ -134067,7 +134137,7 @@ var utils = __webpack_require__(42325);
134067
134137
  if (this.filterOption[key]?.value) {
134068
134138
  // 基础资料和枚举要特殊处理
134069
134139
  const currentName = this.isBasicData(current[key]) ? current[key].name : current[key];
134070
- if (currentName === null || currentName === undefined || !`${currentName}`.includes(`${this.filterOption[key].value}`)) {
134140
+ if (currentName === null || currentName === undefined || Array.isArray(this.filterOption[key].value) ? !this.filterOption[key].value.find(item => currentName.includes(item.name)) : !`${currentName}`.includes(`${this.filterOption[key].value}`)) {
134071
134141
  isFilter = false;
134072
134142
  return true;
134073
134143
  }
@@ -134197,10 +134267,10 @@ var utils = __webpack_require__(42325);
134197
134267
  });
134198
134268
  ;// CONCATENATED MODULE: ./package/tf-ag-grid/src/index.vue?vue&type=script&lang=js&
134199
134269
  /* harmony default export */ var tf_ag_grid_srcvue_type_script_lang_js_ = (srcvue_type_script_lang_js_);
134200
- ;// CONCATENATED MODULE: ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-22.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-22.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-22.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-22.use[3]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/tf-ag-grid/src/index.vue?vue&type=style&index=0&id=369aa5c8&prod&lang=scss&scoped=true&
134270
+ ;// CONCATENATED MODULE: ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-22.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-22.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-22.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-22.use[3]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/tf-ag-grid/src/index.vue?vue&type=style&index=0&id=4250fa0d&prod&lang=scss&scoped=true&
134201
134271
  // extracted by mini-css-extract-plugin
134202
134272
 
134203
- ;// CONCATENATED MODULE: ./package/tf-ag-grid/src/index.vue?vue&type=style&index=0&id=369aa5c8&prod&lang=scss&scoped=true&
134273
+ ;// CONCATENATED MODULE: ./package/tf-ag-grid/src/index.vue?vue&type=style&index=0&id=4250fa0d&prod&lang=scss&scoped=true&
134204
134274
 
134205
134275
  ;// CONCATENATED MODULE: ./package/tf-ag-grid/src/index.vue
134206
134276
 
@@ -134217,7 +134287,7 @@ var src_component = (0,componentNormalizer/* default */.Z)(
134217
134287
  staticRenderFns,
134218
134288
  false,
134219
134289
  null,
134220
- "369aa5c8",
134290
+ "4250fa0d",
134221
134291
  null
134222
134292
 
134223
134293
  )
@@ -137482,7 +137552,7 @@ var component = (0,componentNormalizer/* default */.Z)(
137482
137552
  // EXTERNAL MODULE: ./src/utils/index.js
137483
137553
  var utils = __webpack_require__(42325);
137484
137554
  // EXTERNAL MODULE: ./src/directives/index.js + 61 modules
137485
- var directives = __webpack_require__(94159);
137555
+ var directives = __webpack_require__(65320);
137486
137556
  ;// CONCATENATED MODULE: ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/tf-table/src/index.vue?vue&type=script&lang=js&
137487
137557
  //
137488
137558
  //
@@ -138217,7 +138287,7 @@ function getVoucherIds(data) {
138217
138287
 
138218
138288
  /***/ }),
138219
138289
 
138220
- /***/ 94159:
138290
+ /***/ 65320:
138221
138291
  /***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
138222
138292
 
138223
138293
  "use strict";
@@ -138490,8 +138560,8 @@ var external_commonjs_vue_commonjs2_vue_root_Vue_ = __webpack_require__(13797);
138490
138560
  var external_commonjs_vue_commonjs2_vue_root_Vue_default = /*#__PURE__*/__webpack_require__.n(external_commonjs_vue_commonjs2_vue_root_Vue_);
138491
138561
  // EXTERNAL MODULE: ./node_modules/element-ui/lib/element-ui.common.js
138492
138562
  var element_ui_common = __webpack_require__(64720);
138493
- ;// CONCATENATED MODULE: ./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/directives/modules/umy-table-setting/components/column-header/index.vue?vue&type=template&id=052f7289&scoped=true&
138494
- var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"column-header-directive",on:{"click":_vm.sortColumn}},[_c('span',[_vm._v(_vm._s(_vm.column.title))]),(_vm.column.orderBy)?_c('span',[_c('i',{class:[_vm.column.orderBy === 'asc' ? 'el-icon-top' : 'el-icon-bottom']})]):_vm._e(),_c('div',{class:{ 'filter-main': _vm.isClick || _vm.isFilter }},[_c('el-popover',{attrs:{"width":"200","trigger":"manual","placement":"bottom"},model:{value:(_vm.isClick),callback:function ($$v) {_vm.isClick=$$v},expression:"isClick"}},[(_vm.isClick)?_c('div',{directives:[{name:"clickoutside",rawName:"v-clickoutside",value:(_vm.handleClickOut),expression:"handleClickOut"}],staticClass:"filter-main-context"},[_c('TfInput',{attrs:{"not-form":"","full-border":"","placeholder":"输入需要过滤的值"},nativeOn:{"keyup":function($event){if(!$event.type.indexOf('key')&&_vm._k($event.keyCode,"enter",13,$event.key,"Enter")){ return null; }return _vm.handleSubmit.apply(null, arguments)}},model:{value:(_vm.column.filterValue),callback:function ($$v) {_vm.$set(_vm.column, "filterValue", $$v)},expression:"column.filterValue"}}),_c('div',{staticClass:"option-buttons"},[_c('el-button',{attrs:{"size":"mini"},on:{"click":_vm.handleCancel}},[_vm._v("重置")]),_c('el-button',{attrs:{"size":"mini"},on:{"click":_vm.handleSubmit}},[_vm._v("确定")])],1)],1):_vm._e(),_c('SvgIcon',{staticClass:"filter-icon",attrs:{"slot":"reference","icon-class":"filter"},on:{"click":function($event){$event.stopPropagation();return _vm.handleFilterClick.apply(null, arguments)}},slot:"reference"})],1)],1)])}
138563
+ ;// CONCATENATED MODULE: ./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/directives/modules/umy-table-setting/components/column-header/index.vue?vue&type=template&id=fedb3f24&scoped=true&
138564
+ var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"column-header-directive",on:{"click":_vm.sortColumn}},[_c('span',[_vm._v(_vm._s(_vm.column.title))]),(_vm.column.orderBy)?_c('span',[_c('i',{class:[_vm.column.orderBy === 'asc' ? 'el-icon-top' : 'el-icon-bottom']})]):_vm._e(),_c('div',{class:{ 'filter-main': _vm.isClick || _vm.isFilter }},[_c('el-popover',{attrs:{"width":"200","trigger":"manual","placement":"bottom"},model:{value:(_vm.isClick),callback:function ($$v) {_vm.isClick=$$v},expression:"isClick"}},[(_vm.isClick)?_c('div',{directives:[{name:"clickoutside",rawName:"v-clickoutside",value:(_vm.handleClickOut),expression:"handleClickOut"}],staticClass:"filter-main-context"},[_c('TfInput',{attrs:{"not-form":"","full-border":"","placeholder":"输入需要过滤的值"},on:{"input":function($event){return _vm.handleInput($event)}},nativeOn:{"keyup":function($event){if(!$event.type.indexOf('key')&&_vm._k($event.keyCode,"enter",13,$event.key,"Enter")){ return null; }return _vm.handleSubmit.apply(null, arguments)}},model:{value:(_vm.column.filterValue),callback:function ($$v) {_vm.$set(_vm.column, "filterValue", $$v)},expression:"column.filterValue"}}),(_vm.column.isSelectQuery)?[_c('div',{staticClass:"filter-list filter-select-list"},_vm._l((_vm.column.filters || []),function(item,index){return _c('div',{key:index,staticClass:"filter-list-item",class:{select:(_vm.column.filters || []).find(function (value) { return value.name === item.name; })},on:{"click":function($event){return _vm.handleSelect(item)}}},[_vm._v(" "+_vm._s(item.name)+" ")])}),0),_c('div',{staticClass:"filter-list"},_vm._l((_vm.options),function(item,index){return _c('div',{key:index,staticClass:"filter-list-item",on:{"click":function($event){return _vm.handleSelect(item)}}},[_c('div',{staticClass:"text"},[_vm._v(_vm._s(item.name))])])}),0)]:_vm._e(),_c('div',{staticClass:"option-buttons"},[_c('el-button',{attrs:{"size":"mini"},on:{"click":_vm.handleCancel}},[_vm._v("重置")]),_c('el-button',{attrs:{"size":"mini"},on:{"click":_vm.handleSubmit}},[_vm._v("确定")])],1)],2):_vm._e(),_c('SvgIcon',{staticClass:"filter-icon",attrs:{"slot":"reference","icon-class":"filter"},on:{"click":function($event){$event.stopPropagation();return _vm.handleFilterClick.apply(null, arguments)}},slot:"reference"})],1)],1)])}
138495
138565
  var staticRenderFns = []
138496
138566
 
138497
138567
 
@@ -138500,6 +138570,31 @@ var tf_input = __webpack_require__(99610);
138500
138570
  // EXTERNAL MODULE: ./node_modules/element-ui/src/utils/clickoutside.js + 1 modules
138501
138571
  var clickoutside = __webpack_require__(96410);
138502
138572
  ;// CONCATENATED MODULE: ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/directives/modules/umy-table-setting/components/column-header/index.vue?vue&type=script&lang=js&
138573
+
138574
+ //
138575
+ //
138576
+ //
138577
+ //
138578
+ //
138579
+ //
138580
+ //
138581
+ //
138582
+ //
138583
+ //
138584
+ //
138585
+ //
138586
+ //
138587
+ //
138588
+ //
138589
+ //
138590
+ //
138591
+ //
138592
+ //
138593
+ //
138594
+ //
138595
+ //
138596
+ //
138597
+ //
138503
138598
  //
138504
138599
  //
138505
138600
  //
@@ -138561,7 +138656,10 @@ var clickoutside = __webpack_require__(96410);
138561
138656
  data() {
138562
138657
  return {
138563
138658
  textBak: '',
138564
- isClick: false
138659
+ isClick: false,
138660
+ options: [],
138661
+ allOptionsList: [],
138662
+ searchData: []
138565
138663
  };
138566
138664
  },
138567
138665
  computed: {
@@ -138586,6 +138684,29 @@ var clickoutside = __webpack_require__(96410);
138586
138684
  }
138587
138685
  },
138588
138686
  methods: {
138687
+ /** 下拉选择 */
138688
+ handleSelect(item) {
138689
+ if ((this.column.filters || []).find(value => value.name === item.name)) {
138690
+ this.column.filters = (this.column.filters || []).filter(value => value.name !== item.name);
138691
+ this.options.splice(item.index, 0, item);
138692
+ return;
138693
+ }
138694
+ if (this.column.filters) {
138695
+ this.column.filters.push(item);
138696
+ } else {
138697
+ this.column.filters = [item];
138698
+ }
138699
+ this.options = this.options.filter(value => value.name !== item.name);
138700
+ },
138701
+ /** 处理输入框值的变化 */
138702
+ handleInput(query) {
138703
+ if (query !== '') {
138704
+ this.options = this.allOptionsList.filter(item => item.name.toLowerCase().includes(query.toLowerCase())).splice(0, 50);
138705
+ } else {
138706
+ const options = Array.from(this.allOptionsList);
138707
+ this.options = options.filter(item => !(this.column.filters || []).find(value => value.name === item.name)).splice(0, 50);
138708
+ }
138709
+ },
138589
138710
  /** 排序 */
138590
138711
  sortColumn() {
138591
138712
  const field = this.column.property;
@@ -138609,6 +138730,25 @@ var clickoutside = __webpack_require__(96410);
138609
138730
  handleFilterClick() {
138610
138731
  this.isClick = !this.isClick;
138611
138732
  this.textBak = this.column.filterValue;
138733
+ if (this.column.isSelectQuery) {
138734
+ this.handelOptions();
138735
+ }
138736
+ },
138737
+ /** 处理下拉筛选的数据 */
138738
+ handelOptions() {
138739
+ this.allOptionsList = [];
138740
+ this.options = [];
138741
+ let options = this.tableInstance.data.map(item => {
138742
+ return item[this.column.property];
138743
+ });
138744
+ options = Array.from(new Set(options)).filter(item => item);
138745
+ options.forEach((item, index) => {
138746
+ this.allOptionsList.push({
138747
+ name: item,
138748
+ index: index
138749
+ });
138750
+ });
138751
+ this.handleInput(this.textBak || '');
138612
138752
  },
138613
138753
  /** 单击外侧事件 */
138614
138754
  handleClickOut(e) {
@@ -138622,6 +138762,7 @@ var clickoutside = __webpack_require__(96410);
138622
138762
  handleCancel() {
138623
138763
  this.textBak = '';
138624
138764
  this.column.filterValue = '';
138765
+ this.column.filters = [];
138625
138766
  this.handleSubmit();
138626
138767
  },
138627
138768
  /** 确认 */
@@ -138630,12 +138771,12 @@ var clickoutside = __webpack_require__(96410);
138630
138771
  this.textBak = this.column.filterValue;
138631
138772
  // filterColumns 意为需要过滤的列
138632
138773
  const filterColumns = this.tableInstance.getTableColumn().fullColumn.filter(item => {
138633
- return ['index', 'checkbox'].indexOf(item.type) === -1 && item.filterValue;
138774
+ return ['index', 'checkbox'].indexOf(item.type) === -1 && (item.filterValue || item.filters);
138634
138775
  });
138635
138776
  if (filterColumns.length) {
138636
138777
  const filterMap = new Map();
138637
138778
  filterColumns.forEach(item => {
138638
- filterMap.set(item.property, item.filterValue);
138779
+ filterMap.set(item.property, item.filters && item.filters.length ? item.filters : item.filterValue);
138639
138780
  });
138640
138781
  // this.tableInstance.data 意为表格的原始数据
138641
138782
  const showTableData = this.tableInstance.data.filter(current => {
@@ -138646,7 +138787,7 @@ var clickoutside = __webpack_require__(96410);
138646
138787
  if (keyword !== null && keyword !== undefined) {
138647
138788
  // 基础资料和枚举要特殊处理
138648
138789
  const currentName = this.isBasicData(current[key]) ? current[key].name : current[key];
138649
- if (currentName === null || currentName === undefined || !`${currentName}`.includes(`${filterMap.get(key)}`)) {
138790
+ if (currentName === null || currentName === undefined || (Array.isArray(filterMap.get(key)) ? !filterMap.get(key).find(item => currentName.includes(item.name)) : !`${currentName}`.includes(`${filterMap.get(key)}`))) {
138650
138791
  isFilter = false;
138651
138792
  return true;
138652
138793
  }
@@ -138683,15 +138824,15 @@ var clickoutside = __webpack_require__(96410);
138683
138824
  });
138684
138825
  ;// CONCATENATED MODULE: ./src/directives/modules/umy-table-setting/components/column-header/index.vue?vue&type=script&lang=js&
138685
138826
  /* harmony default export */ var components_column_headervue_type_script_lang_js_ = (column_headervue_type_script_lang_js_);
138686
- ;// CONCATENATED MODULE: ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-32.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-32.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-32.use[2]!./node_modules/less-loader/dist/cjs.js??clonedRuleSet-32.use[3]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/directives/modules/umy-table-setting/components/column-header/index.vue?vue&type=style&index=0&id=052f7289&prod&lang=less&scoped=true&
138827
+ ;// CONCATENATED MODULE: ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-32.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-32.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-32.use[2]!./node_modules/less-loader/dist/cjs.js??clonedRuleSet-32.use[3]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/directives/modules/umy-table-setting/components/column-header/index.vue?vue&type=style&index=0&id=fedb3f24&prod&lang=less&scoped=true&
138687
138828
  // extracted by mini-css-extract-plugin
138688
138829
 
138689
- ;// CONCATENATED MODULE: ./src/directives/modules/umy-table-setting/components/column-header/index.vue?vue&type=style&index=0&id=052f7289&prod&lang=less&scoped=true&
138830
+ ;// CONCATENATED MODULE: ./src/directives/modules/umy-table-setting/components/column-header/index.vue?vue&type=style&index=0&id=fedb3f24&prod&lang=less&scoped=true&
138690
138831
 
138691
- ;// CONCATENATED MODULE: ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-32.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-32.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-32.use[2]!./node_modules/less-loader/dist/cjs.js??clonedRuleSet-32.use[3]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/directives/modules/umy-table-setting/components/column-header/index.vue?vue&type=style&index=1&id=052f7289&prod&lang=less&
138832
+ ;// CONCATENATED MODULE: ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-32.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-32.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-32.use[2]!./node_modules/less-loader/dist/cjs.js??clonedRuleSet-32.use[3]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/directives/modules/umy-table-setting/components/column-header/index.vue?vue&type=style&index=1&id=fedb3f24&prod&lang=less&
138692
138833
  // extracted by mini-css-extract-plugin
138693
138834
 
138694
- ;// CONCATENATED MODULE: ./src/directives/modules/umy-table-setting/components/column-header/index.vue?vue&type=style&index=1&id=052f7289&prod&lang=less&
138835
+ ;// CONCATENATED MODULE: ./src/directives/modules/umy-table-setting/components/column-header/index.vue?vue&type=style&index=1&id=fedb3f24&prod&lang=less&
138695
138836
 
138696
138837
  // EXTERNAL MODULE: ./node_modules/@vue/vue-loader-v15/lib/runtime/componentNormalizer.js
138697
138838
  var componentNormalizer = __webpack_require__(1001);
@@ -138711,7 +138852,7 @@ var component = (0,componentNormalizer/* default */.Z)(
138711
138852
  staticRenderFns,
138712
138853
  false,
138713
138854
  null,
138714
- "052f7289",
138855
+ "fedb3f24",
138715
138856
  null
138716
138857
 
138717
138858
  )
@@ -138722,9 +138863,9 @@ var tf_settingvue_type_template_id_89b35bfc_scoped_true_render = function () {va
138722
138863
  var tf_settingvue_type_template_id_89b35bfc_scoped_true_staticRenderFns = []
138723
138864
 
138724
138865
 
138725
- ;// CONCATENATED MODULE: ./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/tf-table/src/components/tf-setting/components/tf-setting-form/index.vue?vue&type=template&id=3634d456&scoped=true&
138726
- var tf_setting_formvue_type_template_id_3634d456_scoped_true_render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"tf-setting-form-content"},[_c('div',{staticClass:"tf-header-group"},[_c('div',{staticClass:"tf-search-text"},[_c('el-input',{attrs:{"placeholder":"搜索字段名称","clearable":""},on:{"input":_vm.handleSearchField},model:{value:(_vm.searchContent),callback:function ($$v) {_vm.searchContent=$$v},expression:"searchContent"}},[_c('i',{staticClass:"el-input__icon el-icon-search",attrs:{"slot":"prefix"},slot:"prefix"})])],1),_c('TfButtonGroup',[_c('el-button',{attrs:{"type":"primary","size":"mini"},on:{"click":function($event){return _vm.handlerButtons('showChange')}}},[_vm._v("显/隐切换")]),_c('el-button',{attrs:{"type":"primary","size":"mini"},on:{"click":function($event){return _vm.handlerButtons('freeze')}}},[_vm._v("冻结/固定")]),_c('el-button',{attrs:{"type":"primary","size":"mini","loading":_vm.saveLoading},on:{"click":function($event){return _vm.handlerButtons('save')}}},[_vm._v("保存")]),_c('el-button',{attrs:{"type":"danger","size":"mini"},on:{"click":function($event){return _vm.handlerButtons('close')}}},[_vm._v("关闭")])],1)],1),_c('div',{staticClass:"tf-common-table"},[_c('TfAgGridTable',{ref:"settingTable",attrs:{"columns":_vm.mainColumns,"table-data":_vm.showTableData,"row-drag-managed":false,"row-drag-entire-row":false,"row-drag-multi-row":false,"enable-cell-text-selection":false},on:{"rowDragEnd":_vm.rowDragEnd,"handleChangeCellValue":_vm.handleChangeCellValue,"sortRow":_vm.sortRow,"selectChange":_vm.selectChange}})],1)])}
138727
- var tf_setting_formvue_type_template_id_3634d456_scoped_true_staticRenderFns = []
138866
+ ;// CONCATENATED MODULE: ./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/tf-table/src/components/tf-setting/components/tf-setting-form/index.vue?vue&type=template&id=c1386070&scoped=true&
138867
+ var tf_setting_formvue_type_template_id_c1386070_scoped_true_render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"tf-setting-form-content"},[_c('div',{staticClass:"tf-header-group"},[_c('div',{staticClass:"tf-search-text"},[_c('el-input',{attrs:{"placeholder":"搜索字段名称","clearable":""},on:{"input":_vm.handleSearchField},model:{value:(_vm.searchContent),callback:function ($$v) {_vm.searchContent=$$v},expression:"searchContent"}},[_c('i',{staticClass:"el-input__icon el-icon-search",attrs:{"slot":"prefix"},slot:"prefix"})])],1),_c('TfButtonGroup',[_c('el-button',{attrs:{"type":"primary","size":"mini"},on:{"click":function($event){return _vm.handlerButtons('showChange')}}},[_vm._v("显/隐切换")]),_c('el-button',{attrs:{"type":"primary","size":"mini"},on:{"click":function($event){return _vm.handlerButtons('freeze')}}},[_vm._v("冻结/固定")]),_c('el-button',{attrs:{"type":"primary","size":"mini","loading":_vm.saveLoading},on:{"click":function($event){return _vm.handlerButtons('save')}}},[_vm._v("保存")]),_c('el-button',{attrs:{"type":"danger","size":"mini"},on:{"click":function($event){return _vm.handlerButtons('close')}}},[_vm._v("关闭")])],1)],1),_c('div',{staticClass:"tf-common-table"},[_c('TfAgGridTable',{ref:"settingTable",attrs:{"columns":_vm.mainColumns,"table-data":_vm.showTableData,"row-drag-managed":false,"row-drag-entire-row":false,"row-drag-multi-row":false,"enable-cell-text-selection":false},on:{"rowDragEnd":_vm.rowDragEnd,"handleChangeCellValue":_vm.handleChangeCellValue,"sortRow":_vm.sortRow,"selectChange":_vm.selectChange}})],1)])}
138868
+ var tf_setting_formvue_type_template_id_c1386070_scoped_true_staticRenderFns = []
138728
138869
 
138729
138870
 
138730
138871
  // EXTERNAL MODULE: ./package/tf-button-group/index.js + 6 modules
@@ -138823,6 +138964,15 @@ var tf_ag_grid_table = __webpack_require__(1596);
138823
138964
  inputType: 'switch'
138824
138965
  },
138825
138966
  width: 145
138967
+ }, {
138968
+ field: 'isSelectQuery',
138969
+ headerName: '下拉筛选',
138970
+ suppressMovable: true,
138971
+ cellRenderer: 'TfPlanCellRender',
138972
+ cellRendererParams: {
138973
+ inputType: 'switch'
138974
+ },
138975
+ width: 145
138826
138976
  }],
138827
138977
  tableData: [],
138828
138978
  selectRows: [],
@@ -139013,17 +139163,18 @@ var tf_ag_grid_table = __webpack_require__(1596);
139013
139163
  field: item.field,
139014
139164
  isShow: item.isShow,
139015
139165
  fieldIndex: index + 1,
139016
- isFreeze: item.isFreeze
139166
+ isFreeze: item.isFreeze,
139167
+ isSelectQuery: item.isSelectQuery
139017
139168
  }));
139018
139169
  }
139019
139170
  }
139020
139171
  });
139021
139172
  ;// CONCATENATED MODULE: ./package/tf-table/src/components/tf-setting/components/tf-setting-form/index.vue?vue&type=script&lang=js&
139022
139173
  /* harmony default export */ var components_tf_setting_formvue_type_script_lang_js_ = (tf_setting_formvue_type_script_lang_js_);
139023
- ;// CONCATENATED MODULE: ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-22.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-22.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-22.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-22.use[3]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/tf-table/src/components/tf-setting/components/tf-setting-form/index.vue?vue&type=style&index=0&id=3634d456&prod&lang=scss&scoped=true&
139174
+ ;// CONCATENATED MODULE: ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-22.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-22.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-22.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-22.use[3]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/tf-table/src/components/tf-setting/components/tf-setting-form/index.vue?vue&type=style&index=0&id=c1386070&prod&lang=scss&scoped=true&
139024
139175
  // extracted by mini-css-extract-plugin
139025
139176
 
139026
- ;// CONCATENATED MODULE: ./package/tf-table/src/components/tf-setting/components/tf-setting-form/index.vue?vue&type=style&index=0&id=3634d456&prod&lang=scss&scoped=true&
139177
+ ;// CONCATENATED MODULE: ./package/tf-table/src/components/tf-setting/components/tf-setting-form/index.vue?vue&type=style&index=0&id=c1386070&prod&lang=scss&scoped=true&
139027
139178
 
139028
139179
  ;// CONCATENATED MODULE: ./package/tf-table/src/components/tf-setting/components/tf-setting-form/index.vue
139029
139180
 
@@ -139036,11 +139187,11 @@ var tf_ag_grid_table = __webpack_require__(1596);
139036
139187
 
139037
139188
  var tf_setting_form_component = (0,componentNormalizer/* default */.Z)(
139038
139189
  components_tf_setting_formvue_type_script_lang_js_,
139039
- tf_setting_formvue_type_template_id_3634d456_scoped_true_render,
139040
- tf_setting_formvue_type_template_id_3634d456_scoped_true_staticRenderFns,
139190
+ tf_setting_formvue_type_template_id_c1386070_scoped_true_render,
139191
+ tf_setting_formvue_type_template_id_c1386070_scoped_true_staticRenderFns,
139041
139192
  false,
139042
139193
  null,
139043
- "3634d456",
139194
+ "c1386070",
139044
139195
  null
139045
139196
 
139046
139197
  )
@@ -139207,6 +139358,7 @@ async function initTableConfigList(el, binding, vNode) {
139207
139358
  isChild: collectArr.indexOf(item.property) === -1,
139208
139359
  isShow: testField(current, 'isShow') ? current.isShow : true,
139209
139360
  isFreeze: testField(current, 'isFreeze') ? current.isFreeze : false,
139361
+ isSelectQuery: testField(current, 'isSelectQuery') ? current.isSelectQuery : false,
139210
139362
  fieldWidth: testField(current, 'fieldWidth') ? current.fieldWidth : item.width ? (item.width + '').split('px')[0] : 150,
139211
139363
  fieldIndex: current.fieldIndex
139212
139364
  };
@@ -139304,6 +139456,7 @@ function updateColumn(el, binding, vNode, fullColumn) {
139304
139456
  fullColumn[index].width = current.fieldWidth + 'px';
139305
139457
  fullColumn[index].fixed = current.isFreeze ? 'left' : column.fixed === 'right' ? 'right' : '';
139306
139458
  fullColumn[index].visible = current.isShow;
139459
+ fullColumn[index].isSelectQuery = current.isSelectQuery; // 是否下拉筛选
139307
139460
  fullColumn[index].fieldIndex = current.fieldIndex;
139308
139461
  }
139309
139462
  // 记录没有配置的列总共有多少
@@ -139680,6 +139833,7 @@ async function init_initTableConfigList(el, binding, vNode) {
139680
139833
  isChild: collectArr.indexOf(item.property) === -1,
139681
139834
  isShow: testField(current, 'isShow') ? current.isShow : true,
139682
139835
  isFreeze: testField(current, 'isFreeze') ? current.isFreeze : false,
139836
+ isSelectQuery: testField(current, 'isSelectQuery') ? current.isSelectQuery : false,
139683
139837
  fieldWidth: testField(current, 'fieldWidth') ? current.fieldWidth : item.width ? (item.width + '').split('px')[0] : 150,
139684
139838
  fieldIndex: current.fieldIndex
139685
139839
  };
@@ -139777,6 +139931,7 @@ function init_updateColumn(el, binding, vNode, fullColumn) {
139777
139931
  fullColumn[index].width = current.fieldWidth + 'px';
139778
139932
  fullColumn[index].fixed = current.isFreeze ? 'left' : column.fixed === 'right' ? 'right' : '';
139779
139933
  fullColumn[index].visible = current.isShow;
139934
+ fullColumn[index].isSelectQuery = current.isSelectQuery; // 是否下拉筛选
139780
139935
  fullColumn[index].fieldIndex = current.fieldIndex;
139781
139936
  }
139782
139937
  // 记录没有配置的列总共有多少
@@ -140348,13 +140503,13 @@ var settingvue_type_template_id_e45c9f3e_scoped_true_render = function () {var _
140348
140503
  var settingvue_type_template_id_e45c9f3e_scoped_true_staticRenderFns = []
140349
140504
 
140350
140505
 
140351
- ;// CONCATENATED MODULE: ./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/directives/modules/ag-grid-setting/components/setting/components/tf-setting-form/index.vue?vue&type=template&id=01be3b48&scoped=true&
140352
- var tf_setting_formvue_type_template_id_01be3b48_scoped_true_render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"tf-setting-form-content"},[_c('div',{staticClass:"tf-header-group"},[_c('div',{staticClass:"tf-search-text"},[_c('el-input',{attrs:{"clearable":"","placeholder":"搜索字段名称"},on:{"input":_vm.handleSearchField},model:{value:(_vm.searchContent),callback:function ($$v) {_vm.searchContent=$$v},expression:"searchContent"}},[_c('i',{staticClass:"el-input__icon el-icon-search",attrs:{"slot":"prefix"},slot:"prefix"})])],1),_c('TfButtonGroup',[_c('el-button',{attrs:{"type":"primary","size":"mini"},on:{"click":function($event){return _vm.handlerButtons('showChange')}}},[_vm._v("显/隐切换")]),_c('el-button',{attrs:{"type":"primary","size":"mini"},on:{"click":function($event){return _vm.handlerButtons('freeze')}}},[_vm._v("冻结/固定")]),_c('el-button',{attrs:{"type":"primary","size":"mini","loading":_vm.saveLoading},on:{"click":function($event){return _vm.handlerButtons('save')}}},[_vm._v("保存")]),_c('el-button',{attrs:{"type":"danger","size":"mini"},on:{"click":function($event){return _vm.handlerButtons('close')}}},[_vm._v("关闭")])],1)],1),_c('div',{staticClass:"tf-ag-grid-setting-table"},[_c('TfAgGrid',{ref:"settingTable",attrs:{"data":_vm.showTableData,"columns":_vm.mainColumns,"enable-cell-text-selection":false},on:{"selection-changed":_vm.selectChange,"handleChangeCellValue":_vm.handleChangeCellValue}})],1)])}
140353
- var tf_setting_formvue_type_template_id_01be3b48_scoped_true_staticRenderFns = []
140506
+ ;// CONCATENATED MODULE: ./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/directives/modules/ag-grid-setting/components/setting/components/tf-setting-form/index.vue?vue&type=template&id=b3113b4e&scoped=true&
140507
+ var tf_setting_formvue_type_template_id_b3113b4e_scoped_true_render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"tf-setting-form-content"},[_c('div',{staticClass:"tf-header-group"},[_c('div',{staticClass:"tf-search-text"},[_c('el-input',{attrs:{"clearable":"","placeholder":"搜索字段名称"},on:{"input":_vm.handleSearchField},model:{value:(_vm.searchContent),callback:function ($$v) {_vm.searchContent=$$v},expression:"searchContent"}},[_c('i',{staticClass:"el-input__icon el-icon-search",attrs:{"slot":"prefix"},slot:"prefix"})])],1),_c('TfButtonGroup',[_c('el-button',{attrs:{"type":"primary","size":"mini"},on:{"click":function($event){return _vm.handlerButtons('showChange')}}},[_vm._v("显/隐切换")]),_c('el-button',{attrs:{"type":"primary","size":"mini"},on:{"click":function($event){return _vm.handlerButtons('freeze')}}},[_vm._v("冻结/固定")]),_c('el-button',{attrs:{"type":"primary","size":"mini","loading":_vm.saveLoading},on:{"click":function($event){return _vm.handlerButtons('save')}}},[_vm._v("保存")]),_c('el-button',{attrs:{"type":"danger","size":"mini"},on:{"click":function($event){return _vm.handlerButtons('close')}}},[_vm._v("关闭")])],1)],1),_c('div',{staticClass:"tf-ag-grid-setting-table"},[_c('TfAgGrid',{ref:"settingTable",attrs:{"data":_vm.showTableData,"columns":_vm.mainColumns,"enable-cell-text-selection":false},on:{"selection-changed":_vm.selectChange,"handleChangeCellValue":_vm.handleChangeCellValue}})],1)])}
140508
+ var tf_setting_formvue_type_template_id_b3113b4e_scoped_true_staticRenderFns = []
140354
140509
 
140355
140510
 
140356
140511
  // EXTERNAL MODULE: ./package/tf-ag-grid/index.js + 26 modules
140357
- var tf_ag_grid = __webpack_require__(45422);
140512
+ var tf_ag_grid = __webpack_require__(48143);
140358
140513
  ;// CONCATENATED MODULE: ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/directives/modules/ag-grid-setting/components/setting/components/tf-setting-form/index.vue?vue&type=script&lang=js&
140359
140514
  //
140360
140515
  //
@@ -140441,6 +140596,15 @@ var tf_ag_grid = __webpack_require__(45422);
140441
140596
  type: 'switch'
140442
140597
  },
140443
140598
  width: 145
140599
+ }, {
140600
+ field: 'isSelectQuery',
140601
+ headerName: '下拉筛选',
140602
+ suppressMovable: true,
140603
+ cellRenderer: 'TfInputCellRender',
140604
+ cellRendererParams: {
140605
+ type: 'switch'
140606
+ },
140607
+ width: 145
140444
140608
  }],
140445
140609
  tableData: [],
140446
140610
  selectRows: [],
@@ -140549,10 +140713,10 @@ var tf_ag_grid = __webpack_require__(45422);
140549
140713
  });
140550
140714
  ;// CONCATENATED MODULE: ./src/directives/modules/ag-grid-setting/components/setting/components/tf-setting-form/index.vue?vue&type=script&lang=js&
140551
140715
  /* harmony default export */ var components_setting_components_tf_setting_formvue_type_script_lang_js_ = (setting_components_tf_setting_formvue_type_script_lang_js_);
140552
- ;// CONCATENATED MODULE: ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-22.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-22.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-22.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-22.use[3]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/directives/modules/ag-grid-setting/components/setting/components/tf-setting-form/index.vue?vue&type=style&index=0&id=01be3b48&prod&lang=scss&scoped=true&
140716
+ ;// CONCATENATED MODULE: ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-22.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-22.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-22.use[2]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-22.use[3]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./src/directives/modules/ag-grid-setting/components/setting/components/tf-setting-form/index.vue?vue&type=style&index=0&id=b3113b4e&prod&lang=scss&scoped=true&
140553
140717
  // extracted by mini-css-extract-plugin
140554
140718
 
140555
- ;// CONCATENATED MODULE: ./src/directives/modules/ag-grid-setting/components/setting/components/tf-setting-form/index.vue?vue&type=style&index=0&id=01be3b48&prod&lang=scss&scoped=true&
140719
+ ;// CONCATENATED MODULE: ./src/directives/modules/ag-grid-setting/components/setting/components/tf-setting-form/index.vue?vue&type=style&index=0&id=b3113b4e&prod&lang=scss&scoped=true&
140556
140720
 
140557
140721
  ;// CONCATENATED MODULE: ./src/directives/modules/ag-grid-setting/components/setting/components/tf-setting-form/index.vue
140558
140722
 
@@ -140565,11 +140729,11 @@ var tf_ag_grid = __webpack_require__(45422);
140565
140729
 
140566
140730
  var components_tf_setting_form_component = (0,componentNormalizer/* default */.Z)(
140567
140731
  components_setting_components_tf_setting_formvue_type_script_lang_js_,
140568
- tf_setting_formvue_type_template_id_01be3b48_scoped_true_render,
140569
- tf_setting_formvue_type_template_id_01be3b48_scoped_true_staticRenderFns,
140732
+ tf_setting_formvue_type_template_id_b3113b4e_scoped_true_render,
140733
+ tf_setting_formvue_type_template_id_b3113b4e_scoped_true_staticRenderFns,
140570
140734
  false,
140571
140735
  null,
140572
- "01be3b48",
140736
+ "b3113b4e",
140573
140737
  null
140574
140738
 
140575
140739
  )
@@ -140882,6 +141046,7 @@ async function js_init_initTableConfigList(el, binding, vNode) {
140882
141046
  isChild: isChild,
140883
141047
  isShow: testField(current, 'isShow') ? current.isShow : true,
140884
141048
  isFreeze: testField(current, 'isFreeze') ? current.isFreeze : false,
141049
+ isSelectQuery: testField(current, 'isSelectQuery') ? current.isSelectQuery : false,
140885
141050
  fieldWidth: testField(current, 'fieldWidth') ? current.fieldWidth : item.width || 150,
140886
141051
  fieldIndex: current.fieldIndex
140887
141052
  });
@@ -140903,12 +141068,14 @@ async function js_init_initTableConfigList(el, binding, vNode) {
140903
141068
  const js_init_reloadColumns = (el, binding, vNode) => {
140904
141069
  const tableInstance = vNode.componentInstance;
140905
141070
  const newColumns = [...tableInstance.columnDefs];
141071
+ console.log('手粗这个newColumns', newColumns);
140906
141072
  const deepReloadColumn = arr => {
140907
141073
  arr.forEach((item, index) => {
140908
141074
  const current = el.umyTableSetting.tableConfigList.find(d => item.field && d.field === item.field) || {};
140909
141075
  arr[index].hide = !current.isShow;
140910
141076
  arr[index].fieldIndex = current.fieldIndex;
140911
141077
  arr[index].width = current.fieldWidth || 150;
141078
+ arr[index].isSelectQuery = current.isSelectQuery;
140912
141079
  arr[index].comparator = arr[index].comparator || util_customSort;
140913
141080
  arr[index].pinned = current.isFreeze ? 'left' : item.pinned === 'right' ? 'right' : null;
140914
141081
  if (arr[index].children) {
@@ -140922,6 +141089,7 @@ const js_init_reloadColumns = (el, binding, vNode) => {
140922
141089
  };
140923
141090
  // 修改列配置
140924
141091
  deepReloadColumn(newColumns);
141092
+ console.log('deepReloadColumn之后的新的newColumns', newColumns);
140925
141093
  // 重新加载列配置
140926
141094
  setNewColumns(el, newColumns);
140927
141095
  };
@@ -260216,7 +260384,7 @@ var push_down_component = (0,componentNormalizer/* default */.Z)(
260216
260384
  }
260217
260385
  });
260218
260386
  // EXTERNAL MODULE: ./src/directives/index.js + 61 modules
260219
- var directives = __webpack_require__(94159);
260387
+ var directives = __webpack_require__(65320);
260220
260388
  ;// CONCATENATED MODULE: ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/t-data-list/main.vue?vue&type=script&lang=js&
260221
260389
  //
260222
260390
  //
@@ -261052,9 +261220,9 @@ var srcvue_type_template_id_368dedec_scoped_true_render = function () {var _vm=t
261052
261220
  var srcvue_type_template_id_368dedec_scoped_true_staticRenderFns = []
261053
261221
 
261054
261222
 
261055
- ;// CONCATENATED MODULE: ./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/tf-print-render/src/print-render.vue?vue&type=template&id=42afd652&scoped=true&
261056
- var print_rendervue_type_template_id_42afd652_scoped_true_render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"print-render",style:({width:_vm.silentMode? _vm.displayWidth.width : 'unset'})},[_c('div',{ref:"printTarget",staticClass:"print-target",style:(_vm.displayWidth)},_vm._l((_vm.data),function(receipt){return _c('div',{key:receipt.rowId,staticClass:"single-receipt",style:(_vm.displayWidth)},[_c('div',{staticClass:"paper-dom",style:(_vm.paperStyle)},_vm._l((_vm.config.layout),function(container){return _c('ContainerRender',{key:container.id,attrs:{"type":container.type,"property":container.property,"widgets":container.widgets,"print-data":receipt.records}})}),1)])}),0),_c('div',{directives:[{name:"show",rawName:"v-show",value:(_vm.printTargetImgDisplay),expression:"printTargetImgDisplay"}],ref:"printTargetImg",staticClass:"print-target-imgs"},_vm._l((_vm.renderImgList),function(imgItem,index){return _c('div',{key:index,staticClass:"paper-img"},[_c('img',{style:({display:'block'}),attrs:{"src":imgItem,"width":"100%"}})])}),0)])}
261057
- var print_rendervue_type_template_id_42afd652_scoped_true_staticRenderFns = []
261223
+ ;// CONCATENATED MODULE: ./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/tf-print-render/src/print-render.vue?vue&type=template&id=679ace7c&scoped=true&
261224
+ var print_rendervue_type_template_id_679ace7c_scoped_true_render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"print-render",style:({width:_vm.silentMode? _vm.displayWidth.width : 'unset'})},[_c('div',{ref:"printTarget",staticClass:"print-target",style:(_vm.displayWidth)},_vm._l((_vm.data),function(receipt){return _c('div',{key:receipt.rowId,staticClass:"single-receipt",style:(_vm.displayWidth)},[_c('div',{staticClass:"paper-dom",style:(_vm.paperStyle)},_vm._l((_vm.config.layout),function(container){return _c('ContainerRender',{key:container.id,attrs:{"type":container.type,"property":container.property,"widgets":container.widgets,"print-data":receipt.records}})}),1)])}),0),_c('div',{directives:[{name:"show",rawName:"v-show",value:(_vm.printTargetImgDisplay),expression:"printTargetImgDisplay"}],ref:"printTargetImg",staticClass:"print-target-imgs"},_vm._l((_vm.renderImgList),function(imgItem,index){return _c('div',{key:index,staticClass:"paper-img"},[_c('img',{style:({display:'block'}),attrs:{"src":imgItem,"width":"100%"}})])}),0)])}
261225
+ var print_rendervue_type_template_id_679ace7c_scoped_true_staticRenderFns = []
261058
261226
 
261059
261227
 
261060
261228
  ;// CONCATENATED MODULE: ./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/tf-print-render/src/container/index.vue?vue&type=template&id=3ee9d2ec&scoped=true&
@@ -262020,13 +262188,19 @@ var dom_to_image_default = /*#__PURE__*/__webpack_require__.n(dom_to_image);
262020
262188
  * 激光打印机使用转换成图片的方式再打印
262021
262189
  */
262022
262190
  async runLaserPrintor() {
262023
- const imgList = await this.getDomImgList();
262024
- this.printTargetImgDisplay = true;
262025
- this.renderImgList = imgList;
262026
- this.$nextTick(() => {
262027
- (0,utils/* print */.S0)(this.$refs.printTargetImg);
262028
- this.printTargetImgDisplay = false;
262029
- });
262191
+ try {
262192
+ const imgList = await this.getDomImgList();
262193
+ this.printTargetImgDisplay = true;
262194
+ this.renderImgList = imgList;
262195
+ this.$nextTick(() => {
262196
+ (0,utils/* print */.S0)(this.$refs.printTargetImg);
262197
+ this.printTargetImgDisplay = false;
262198
+ });
262199
+ } catch (err) {
262200
+ this.$message.error('转换图片过程中出错');
262201
+ } finally {
262202
+ this.afterPrint();
262203
+ }
262030
262204
  },
262031
262205
  /**
262032
262206
  * 针式打印机使用直接对dom元素进行打印的方式
@@ -262041,7 +262215,7 @@ var dom_to_image_default = /*#__PURE__*/__webpack_require__.n(dom_to_image);
262041
262215
  */
262042
262216
  afterPrint() {
262043
262217
  // 可能放在这里也不是很合适
262044
- this.printMediaStyleNode.remove();
262218
+ // this.printMediaStyleNode.remove()
262045
262219
  this.loading.close();
262046
262220
  this.$emit('printTriggered');
262047
262221
  }
@@ -262049,10 +262223,10 @@ var dom_to_image_default = /*#__PURE__*/__webpack_require__.n(dom_to_image);
262049
262223
  });
262050
262224
  ;// CONCATENATED MODULE: ./package/tf-print-render/src/print-render.vue?vue&type=script&lang=js&
262051
262225
  /* harmony default export */ var src_print_rendervue_type_script_lang_js_ = (print_rendervue_type_script_lang_js_);
262052
- ;// CONCATENATED MODULE: ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-32.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-32.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-32.use[2]!./node_modules/less-loader/dist/cjs.js??clonedRuleSet-32.use[3]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/tf-print-render/src/print-render.vue?vue&type=style&index=0&id=42afd652&prod&scoped=true&lang=less&
262226
+ ;// CONCATENATED MODULE: ./node_modules/mini-css-extract-plugin/dist/loader.js??clonedRuleSet-32.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-32.use[1]!./node_modules/@vue/vue-loader-v15/lib/loaders/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-32.use[2]!./node_modules/less-loader/dist/cjs.js??clonedRuleSet-32.use[3]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/tf-print-render/src/print-render.vue?vue&type=style&index=0&id=679ace7c&prod&scoped=true&lang=less&
262053
262227
  // extracted by mini-css-extract-plugin
262054
262228
 
262055
- ;// CONCATENATED MODULE: ./package/tf-print-render/src/print-render.vue?vue&type=style&index=0&id=42afd652&prod&scoped=true&lang=less&
262229
+ ;// CONCATENATED MODULE: ./package/tf-print-render/src/print-render.vue?vue&type=style&index=0&id=679ace7c&prod&scoped=true&lang=less&
262056
262230
 
262057
262231
  ;// CONCATENATED MODULE: ./package/tf-print-render/src/print-render.vue
262058
262232
 
@@ -262065,11 +262239,11 @@ var dom_to_image_default = /*#__PURE__*/__webpack_require__.n(dom_to_image);
262065
262239
 
262066
262240
  var print_render_component = (0,componentNormalizer/* default */.Z)(
262067
262241
  src_print_rendervue_type_script_lang_js_,
262068
- print_rendervue_type_template_id_42afd652_scoped_true_render,
262069
- print_rendervue_type_template_id_42afd652_scoped_true_staticRenderFns,
262242
+ print_rendervue_type_template_id_679ace7c_scoped_true_render,
262243
+ print_rendervue_type_template_id_679ace7c_scoped_true_staticRenderFns,
262070
262244
  false,
262071
262245
  null,
262072
- "42afd652",
262246
+ "679ace7c",
262073
262247
  null
262074
262248
 
262075
262249
  )
@@ -262531,7 +262705,7 @@ var tf_input = __webpack_require__(99610);
262531
262705
  // EXTERNAL MODULE: ./package/tf-table/index.js + 12 modules
262532
262706
  var tf_table = __webpack_require__(20335);
262533
262707
  // EXTERNAL MODULE: ./package/tf-ag-grid/index.js + 26 modules
262534
- var tf_ag_grid = __webpack_require__(45422);
262708
+ var tf_ag_grid = __webpack_require__(48143);
262535
262709
  ;// CONCATENATED MODULE: ./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./package/tf-vxe-table/src/index.vue?vue&type=template&id=38f78afd&scoped=true&
262536
262710
  var srcvue_type_template_id_38f78afd_scoped_true_render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"tf-common-table-container"},[_c('vxe-table',_vm._b({directives:[{name:"vxeTableSetting",rawName:"v-vxeTableSetting",value:(_vm.entityTableName),expression:"entityTableName"}],ref:_vm.tableRef,staticClass:"tf-common-table-scrollbar",attrs:{"data":_vm.data},on:{"cell-click":_vm.cellClick,"cell-dblclick":_vm.cellDBLClick,"current-change":_vm.currentChange,"checkbox-change":_vm.checkboxChange,"checkbox-all":_vm.checkboxAll}},'vxe-table',_vm.customAttrs,false),[_c('vxe-column',{attrs:{"type":"checkbox","width":"40","fixed":"left"}}),_c('vxe-column',{attrs:{"type":"seq","width":"60","fixed":"left","title":"#"}}),_vm._l((_vm.columns),function(item){return _c('vxe-column',_vm._b({key:item.field},'vxe-column',item,false))}),(_vm.customColumns)?_vm._t("default"):_vm._e(),_c('template',{slot:"empty"},[_c('SvgIcon',{staticStyle:{"width":"6vw","height":"6vh"},attrs:{"icon-class":"table-empty"}}),_c('div',{staticStyle:{"font-size":"1.4vh"}},[_vm._v("暂无数据")])],1)],2)],1)}
262537
262711
  var srcvue_type_template_id_38f78afd_scoped_true_staticRenderFns = []