cnhis-design-vue 2.1.50 → 2.1.51

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (100) hide show
  1. package/CHANGELOG.md +17 -4
  2. package/es/affix/index.js +8 -8
  3. package/es/age/index.js +10 -10
  4. package/es/alert/index.js +8 -8
  5. package/es/anchor/index.js +8 -8
  6. package/es/auto-complete/index.js +8 -8
  7. package/es/avatar/index.js +8 -8
  8. package/es/back-top/index.js +8 -8
  9. package/es/badge/index.js +8 -8
  10. package/es/base/index.js +8 -8
  11. package/es/big-table/index.js +68 -68
  12. package/es/breadcrumb/index.js +8 -8
  13. package/es/button/index.js +22 -22
  14. package/es/calendar/index.js +8 -8
  15. package/es/captcha/index.js +3 -3
  16. package/es/card/index.js +8 -8
  17. package/es/carousel/index.js +8 -8
  18. package/es/cascader/index.js +8 -8
  19. package/es/checkbox/index.js +9 -9
  20. package/es/col/index.js +8 -8
  21. package/es/collapse/index.js +8 -8
  22. package/es/color-picker/index.js +1 -1
  23. package/es/comment/index.js +8 -8
  24. package/es/config-provider/index.js +8 -8
  25. package/es/date-picker/index.js +8 -8
  26. package/es/descriptions/index.js +8 -8
  27. package/es/divider/index.js +8 -8
  28. package/es/drag-layout/index.js +3 -3
  29. package/es/drawer/index.js +8 -8
  30. package/es/dropdown/index.js +8 -8
  31. package/es/editor/index.js +1 -1
  32. package/es/empty/index.js +8 -8
  33. package/es/fabric-chart/index.js +9 -9
  34. package/es/form/index.js +8 -8
  35. package/es/form-model/index.js +8 -8
  36. package/es/form-table/index.js +62 -62
  37. package/es/index/index.js +577 -506
  38. package/es/index/style.css +1 -1
  39. package/es/input/index.js +9 -9
  40. package/es/input-number/index.js +8 -8
  41. package/es/layout/index.js +8 -8
  42. package/es/list/index.js +8 -8
  43. package/es/locale-provider/index.js +8 -8
  44. package/es/map/index.js +9 -9
  45. package/es/mentions/index.js +8 -8
  46. package/es/menu/index.js +8 -8
  47. package/es/message/index.js +8 -8
  48. package/es/multi-chat/index.js +75 -75
  49. package/es/multi-chat-client/index.js +69 -69
  50. package/es/multi-chat-history/index.js +4 -4
  51. package/es/multi-chat-record/index.js +14 -14
  52. package/es/multi-chat-setting/index.js +22 -22
  53. package/es/multi-chat-sip/index.js +1 -1
  54. package/es/notification/index.js +8 -8
  55. package/es/page-header/index.js +8 -8
  56. package/es/pagination/index.js +8 -8
  57. package/es/popconfirm/index.js +8 -8
  58. package/es/popover/index.js +8 -8
  59. package/es/progress/index.js +8 -8
  60. package/es/radio/index.js +9 -9
  61. package/es/rate/index.js +8 -8
  62. package/es/result/index.js +8 -8
  63. package/es/row/index.js +8 -8
  64. package/es/scale-view/index.js +33 -33
  65. package/es/select/index.js +53 -40
  66. package/es/select/style.css +1 -1
  67. package/es/select-label/index.js +11 -11
  68. package/es/select-person/index.js +39 -24
  69. package/es/select-person/style.css +1 -1
  70. package/es/shortcut-setter/index.js +10 -10
  71. package/es/skeleton/index.js +8 -8
  72. package/es/slider/index.js +8 -8
  73. package/es/space/index.js +8 -8
  74. package/es/spin/index.js +8 -8
  75. package/es/statistic/index.js +8 -8
  76. package/es/steps/index.js +8 -8
  77. package/es/switch/index.js +8 -8
  78. package/es/table-filter/index.js +152 -109
  79. package/es/table-filter/style.css +1 -1
  80. package/es/tabs/index.js +8 -8
  81. package/es/tag/index.js +9 -9
  82. package/es/time-picker/index.js +8 -8
  83. package/es/timeline/index.js +8 -8
  84. package/es/tooltip/index.js +8 -8
  85. package/es/transfer/index.js +8 -8
  86. package/es/tree/index.js +8 -8
  87. package/es/tree-select/index.js +8 -8
  88. package/es/upload/index.js +8 -8
  89. package/es/verification-code/index.js +2 -2
  90. package/lib/cui.common.js +601 -531
  91. package/lib/cui.umd.js +601 -531
  92. package/lib/cui.umd.min.js +29 -29
  93. package/package.json +1 -1
  94. package/packages/fabric-chart/src/const/defaultVaule.js +59 -59
  95. package/packages/scale-view/scaleView.vue +2010 -2010
  96. package/packages/select/src/TableSelect/index.vue +27 -10
  97. package/packages/select-person/select-person.vue +12 -0
  98. package/packages/table-filter/src/components/out-quick-search/out-quick-search.vue +1 -5
  99. package/packages/table-filter/src/components/search-condition/SearchCondition.vue +47 -10
  100. package/packages/table-filter/src/quick-search/QuickSearch.vue +2 -2
@@ -76,7 +76,7 @@
76
76
  @search="value => cellSearch(value, scope.row, item.field)"
77
77
  >
78
78
  <a-select-option :key="option.value" :value="option.value" v-for="option in item.editRender.options">
79
- {{option.label}}
79
+ {{ option.label }}
80
80
  </a-select-option>
81
81
  </a-select>
82
82
  </template>
@@ -89,7 +89,17 @@
89
89
  </template>
90
90
  </c-grid>
91
91
  <div class="bottom-box">
92
- <a-pagination v-if="type === 'noEdit'" :total="total" show-size-changer show-quick-jumper @change="change" :current="page" @showSizeChange="showSizeChange" size="small" />
92
+ <a-pagination
93
+ v-if="type === 'noEdit'"
94
+ :total="total"
95
+ show-size-changer
96
+ show-quick-jumper
97
+ @change="change"
98
+ :current="page"
99
+ @showSizeChange="showSizeChange"
100
+ :page-size.sync="pageSize"
101
+ size="small"
102
+ />
93
103
  <template v-else>
94
104
  <a-button type="primary" style="margin-right: auto" @click="addRow">新增</a-button>
95
105
  <span v-show="!isOk" class="tips">请完善表格信息</span>
@@ -154,10 +164,14 @@ export default create({
154
164
  },
155
165
  colSelectList() {
156
166
  return this.columns.filter(v => v.slots?.edit);
157
- },
167
+ }
158
168
  },
159
169
  beforeCreate() {
160
- Vue.use(Select).use(Icon).use(Spin).use(Pagination).use(Button);
170
+ Vue.use(Select)
171
+ .use(Icon)
172
+ .use(Spin)
173
+ .use(Pagination)
174
+ .use(Button);
161
175
  },
162
176
  components: {
163
177
  VNodes: {
@@ -179,7 +193,8 @@ export default create({
179
193
  isRepeat: false,
180
194
  page: 1, // 配置page是因为,使用时分页触发page没有同步
181
195
  isSearch: true,
182
- rules: {}
196
+ rules: {},
197
+ pageSize: 10
183
198
  };
184
199
  },
185
200
  watch: {
@@ -194,7 +209,7 @@ export default create({
194
209
  this.defaultSelecteRow = this.tableData.find(v => v[this.selectAttr] === defaultValue).id;
195
210
  this.setDefaultValue = false;
196
211
  }
197
-
212
+
198
213
  if (this.type === 'edit' && this.tableData.length) {
199
214
  this.setValues(this.tableData);
200
215
  }
@@ -274,12 +289,14 @@ export default create({
274
289
  }
275
290
  },
276
291
  change(page, pageSize) {
292
+ this.pageSize = pageSize;
277
293
  this.$emit('update:fetching', true);
278
294
  this.page = page;
279
295
  this.$emit('paginationchange', { page, pageSize });
280
296
  this.isSearch = true; // 防止mousedown和focus方法都没有触发isSearch为true
281
297
  },
282
298
  showSizeChange(current, size) {
299
+ this.pageSize = size;
283
300
  this.$emit('update:fetching', true);
284
301
  this.page = current;
285
302
  this.$emit('paginationchange', { page: current, pageSize: size });
@@ -333,7 +350,7 @@ export default create({
333
350
  // 校验已经填入数据的行全部值不能为空
334
351
  // const effectiveTableData = tableData.filter(v => Object.keys(v).some(k => k !== 'id' && (v[k] !== '' || v[k].length)));
335
352
  // const invalidTableData = tableData.filter(v => Object.keys(v).every(k => k !== 'id' && (!v[k]?.length))); // 失效的数据,即新增全部为空的
336
-
353
+
337
354
  const effectiveTableData = tableData.filter(v => {
338
355
  return Object.keys(v).some(k => {
339
356
  if (k == 'id') {
@@ -341,7 +358,7 @@ export default create({
341
358
  } else {
342
359
  return v[k] || v[k]?.length;
343
360
  }
344
- })
361
+ });
345
362
  });
346
363
  const invalidTableData = tableData.filter(v => {
347
364
  return Object.keys(v).every(k => {
@@ -350,7 +367,7 @@ export default create({
350
367
  } else {
351
368
  return !v[k]?.length;
352
369
  }
353
- })
370
+ });
354
371
  });
355
372
 
356
373
  let isOk = false;
@@ -426,7 +443,7 @@ export default create({
426
443
  });
427
444
  </script>
428
445
  <style lang="less" scoped>
429
- @deep:~ '>>>';
446
+ @deep: ~'>>>';
430
447
  .nodata-box {
431
448
  display: flex;
432
449
  justify-content: center;
@@ -221,6 +221,10 @@ export default create({
221
221
  type: Boolean,
222
222
  default: false
223
223
  },
224
+ titleAddCode: {
225
+ type: Boolean,
226
+ default: true // 标题是否加上code
227
+ },
224
228
  queryMainTreeData: Function, // 主树请求
225
229
  queryLoadChildData: Function, // 懒加载请求
226
230
  queryTreeSearch: Function // 检索请求
@@ -417,6 +421,7 @@ export default create({
417
421
  data: {
418
422
  immediate: true,
419
423
  handler() {
424
+ this.handleData();
420
425
  this.staticDataInit();
421
426
  this.staticDeptAndRoleDataInit();
422
427
  const key = { person: 'main', dept: 'dept', role: 'role', multiple: 'main' }[this.selectType];
@@ -1490,6 +1495,13 @@ export default create({
1490
1495
  };
1491
1496
  return filterHandle(copyData);
1492
1497
  }
1498
+ },
1499
+ handleData() {
1500
+ vexutils.searchTree(this.data, item => {
1501
+ if (this.titleAddCode) {
1502
+ item.title = `${item.title}(${item.code})`;
1503
+ }
1504
+ });
1493
1505
  }
1494
1506
  }
1495
1507
  });
@@ -166,11 +166,7 @@ export default {
166
166
  return function(item) {
167
167
  if (!item.showTime) return false;
168
168
  return {
169
- defaultValue: [{
170
- format: 'HH:mm:ss'
171
- }, {
172
- format: 'HH:mm:ss'
173
- }]
169
+ defaultValue: [moment('00:00:00', 'HH:mm:ss'), moment('23:59:59', 'HH:mm:ss')]
174
170
  };
175
171
  };
176
172
  }
@@ -138,21 +138,27 @@
138
138
 
139
139
  <div class="date-item val-date-wrap" v-if="item.showDate">
140
140
  <a-date-picker
141
- :disabledDate="disabledStartDate || item.isIllegalField"
142
- format="YYYY-MM-DD"
141
+ :disabledDate="current => disabledDatePicker(current, item, 'start')"
142
+ format="YYYY-MM-DD HH:mm:ss"
143
143
  v-model="item.start_val"
144
+ :show-time="{
145
+ defaultValue: $moment('00:00:00', 'HH:mm:ss')
146
+ }"
144
147
  :placeholder="'请选择'"
145
148
  @openChange="handleStartOpenChange($event, item)"
146
- style="width: 120px"
149
+ style="width: 120px; minWidth: 170px"
147
150
  />
148
151
  <a-date-picker
149
- :disabledDate="disabledEndDate || item.isIllegalField"
150
- format="YYYY-MM-DD"
152
+ :disabledDate="current => disabledDatePicker(current, item, 'end')"
153
+ format="YYYY-MM-DD HH:mm:ss"
151
154
  :placeholder="'请选择'"
152
155
  v-model="item.end_val"
153
156
  :open="item.endOpen"
157
+ :show-time="{
158
+ defaultValue: $moment('23:59:59', 'HH:mm:ss')
159
+ }"
154
160
  @openChange="handleEndOpenChange($event, item)"
155
- style="width: 120px"
161
+ style="width: 120px; minWidth: 170px"
156
162
  />
157
163
  </div>
158
164
  <!-- 生日 -->
@@ -409,6 +415,9 @@ export default create({
409
415
  return item.alias || item[useKey];
410
416
  };
411
417
  },
418
+ $moment() {
419
+ return moment;
420
+ },
412
421
 
413
422
  is_search_professional() {
414
423
  return this.source == 'search-professional';
@@ -621,8 +630,13 @@ export default create({
621
630
  // searchChildList
622
631
  // 大于(BIG),小于 LESS,大于等于BIGEQ,小于等于LESSEQ,等于(IN)
623
632
  } else {
624
- start_val = item.start_val ? moment(item.start_val, 'YYYY-MM-DD') : '';
625
- end_val = item.end_val ? moment(item.end_val, 'YYYY-MM-DD') : '';
633
+ let curEnd = item.end_val;
634
+ // 只有YYYY-MM-DD 手动添加HH:mm:ss
635
+ if (curEnd && typeof curEnd === "string" && curEnd.length < 11 && !curEnd.includes(":")) {
636
+ curEnd += " 23:59:59";
637
+ }
638
+ start_val = item.start_val ? moment(item.start_val, 'YYYY-MM-DD HH:mm:ss') : '';
639
+ end_val = item.end_val ? moment(curEnd, 'YYYY-MM-DD HH:mm:ss') : '';
626
640
  item.curlimit_date = '';
627
641
  }
628
642
 
@@ -795,8 +809,8 @@ export default create({
795
809
  end_val = item.end_val;
796
810
  value = item.value;
797
811
  } else {
798
- start_val = item.start_val ? item.start_val.format('YYYY-MM-DD') : '';
799
- end_val = item.end_val ? item.end_val.format('YYYY-MM-DD') : '';
812
+ start_val = item.start_val ? item.start_val.format('YYYY-MM-DD HH:mm:ss') : '';
813
+ end_val = item.end_val ? item.end_val.format('YYYY-MM-DD HH:mm:ss') : '';
800
814
  }
801
815
 
802
816
  let is_custom = this.showCompareField ? item.compare_field == '_custom__input_' : false;
@@ -1314,6 +1328,29 @@ export default create({
1314
1328
  // this.$set(item, 'value', '');
1315
1329
  reset && this.$set(item, 'value', '');
1316
1330
  },
1331
+ disabledDatePicker(current, item, t){
1332
+ if(item.isIllegalField) return true
1333
+ let f = false;
1334
+ if(t=== 'start'){
1335
+ const end_val = item?.end_val;
1336
+ f = end_val && current.valueOf() > end_val.valueOf();
1337
+ } else if(t=== 'end') {
1338
+ const start_val = item?.start_val;
1339
+ f = start_val && current.valueOf() <= start_val.valueOf();
1340
+ }
1341
+ /**
1342
+ * 2 过去时间
1343
+ * 3 未来时间
1344
+ */
1345
+ let type = String(item?.advanceOptionSetting);
1346
+ if(!['2','3'].includes(type)) return f;
1347
+ if(type === '2'){
1348
+ return current >= moment().endOf('day') || f;
1349
+ } else if(type==='3'){
1350
+ return current && current < moment().startOf('day') || f;
1351
+ }
1352
+ return f
1353
+ },
1317
1354
  disabledStartDate(start_val) {
1318
1355
  const end_val = this.end_val;
1319
1356
  if (!start_val || !end_val) {
@@ -240,7 +240,7 @@
240
240
  format="YYYY-MM-DD HH:mm:ss"
241
241
  v-model="item.DATE.start_val"
242
242
  :show-time="{
243
- format: 'HH:mm:ss'
243
+ defaultValue: $moment('00:00:00', 'HH:mm:ss')
244
244
  }"
245
245
  :placeholder="getI18nText('1.1.4.53', '开始时间')"
246
246
  style="width: 120px"
@@ -251,7 +251,7 @@
251
251
  <a-date-picker
252
252
  format="YYYY-MM-DD HH:mm:ss"
253
253
  :show-time="{
254
- format: 'HH:mm:ss'
254
+ defaultValue: $moment('23:59:59', 'HH:mm:ss')
255
255
  }"
256
256
  :placeholder="getI18nText('1.9.147', '结束时间')"
257
257
  v-model="item.DATE.end_val"