@panpanzhao/component-ui 0.0.53 → 1.0.1

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 (36) hide show
  1. package/lib/component-ui.common.js +1738 -556
  2. package/lib/components/crud.js +545 -292
  3. package/lib/components/dialog.js +44 -13
  4. package/lib/components/drawer.js +10 -10
  5. package/lib/components/form-dialog.js +242 -140
  6. package/lib/components/form-drawer.js +112 -45
  7. package/lib/components/form-group.js +105 -37
  8. package/lib/components/form-input.js +804 -94
  9. package/lib/components/form-item.js +19 -8
  10. package/lib/components/form-query.js +24 -9
  11. package/lib/components/form-view-dialog.js +94 -33
  12. package/lib/components/form-view-group.js +75 -18
  13. package/lib/components/form-view.js +7 -2
  14. package/lib/components/form.js +20 -10
  15. package/lib/components/formula.js +23 -23
  16. package/lib/components/table-column.js +47 -47
  17. package/lib/components/table-editable.js +22 -23
  18. package/lib/components/table-operate.js +354 -191
  19. package/lib/components/table-search.js +23 -17
  20. package/lib/components/table.js +22 -23
  21. package/lib/components/tree-line.js +272 -0
  22. package/lib/index.js +1 -1
  23. package/lib/styles/component-ui.css +2 -2
  24. package/lib/styles/dialog.css +1 -1
  25. package/lib/styles/form-item.css +1 -0
  26. package/lib/styles/form-view.css +1 -1
  27. package/lib/styles/index.css +2 -2
  28. package/lib/styles/tree-line.css +1 -0
  29. package/lib/styles/upload-process.css +1 -0
  30. package/lib/utils/formula/doc.js +2 -3
  31. package/lib/utils/formula/evalutor.js +4 -3
  32. package/lib/utils/formula/filter.js +1 -2
  33. package/lib/utils/formula/function.js +1 -2
  34. package/lib/utils/formula/lexer.js +1 -4
  35. package/lib/utils/helper.js +3 -5
  36. package/package.json +5 -2
@@ -82,7 +82,7 @@ module.exports =
82
82
  /******/
83
83
  /******/
84
84
  /******/ // Load entry module and return exports
85
- /******/ return __webpack_require__(__webpack_require__.s = 80);
85
+ /******/ return __webpack_require__(__webpack_require__.s = 81);
86
86
  /******/ })
87
87
  /************************************************************************/
88
88
  /******/ ({
@@ -227,7 +227,7 @@ module.exports = require("@panpanzhao/component-ui/lib/components/form-item");
227
227
 
228
228
  /***/ }),
229
229
 
230
- /***/ 18:
230
+ /***/ 19:
231
231
  /***/ (function(module, __webpack_exports__, __webpack_require__) {
232
232
 
233
233
  "use strict";
@@ -260,6 +260,12 @@ var components_form = __webpack_require__(4);
260
260
  render: Function,
261
261
  slots: Object,
262
262
  config: Object,
263
+ formModel: {
264
+ type: Object,
265
+ default: function _default() {
266
+ return {};
267
+ }
268
+ },
263
269
  show: {
264
270
  type: [Boolean, Function],
265
271
  default: true
@@ -285,8 +291,11 @@ var components_form = __webpack_require__(4);
285
291
  },
286
292
  created: function created() {
287
293
  if (this._formGroup) {
288
- var defaultVal = this.prop ? this._formGroup.formModel[this.prop] : this._formGroup.formModel;
289
- this.formModel = defaultVal || {};
294
+ // if (!(this.prop&&this._formGroup.formModel[this.prop])) {
295
+ // this._formGroup.formModel[this.prop]={}
296
+ // }
297
+ //const defaultVal= this.prop?this._formGroup.formModel[this.prop]:this._formGroup.formModel
298
+ //this.formModel=defaultVal
290
299
  }
291
300
  // if (this.prop && this._formGroup) {
292
301
  // this._formGroup.formModel[this.prop] = this.formModel;
@@ -349,6 +358,7 @@ var collapse_item_default = /*#__PURE__*/__webpack_require__.n(collapse_item_);
349
358
 
350
359
 
351
360
 
361
+
352
362
  /* harmony default export */ var src = ({
353
363
  name: "FormGroup",
354
364
  componentName: "FormGroup",
@@ -395,9 +405,23 @@ var collapse_item_default = /*#__PURE__*/__webpack_require__.n(collapse_item_);
395
405
  openedCode: null
396
406
  };
397
407
  },
408
+ created: function created() {
409
+ var _this = this;
410
+ this.items.forEach(function (item) {
411
+ var _item$formItems;
412
+ var formData = item.prop && _this.formModel[item.prop] || {};
413
+ if ((item == null || (_item$formItems = item.formItems) == null ? void 0 : _item$formItems.length) > 0) {
414
+ item == null || item.formItems.forEach(function (itemCh) {
415
+ _this.$set(formData, itemCh.prop, formData[itemCh.prop]);
416
+ });
417
+ }
418
+ //初始化数据值
419
+ _this.$set(_this.formModel, item.prop, formData);
420
+ });
421
+ },
398
422
  computed: {
399
423
  actionFormMap: function actionFormMap() {
400
- var _this = this;
424
+ var _this2 = this;
401
425
  var actionForm = {};
402
426
  this.actions.forEach(function (action) {
403
427
  if (!action.trigger) {
@@ -420,15 +444,16 @@ var collapse_item_default = /*#__PURE__*/__webpack_require__.n(collapse_item_);
420
444
  if (!targetConfig[formTarget.formCode]) {
421
445
  targetConfig[formTarget.formCode] = {};
422
446
  }
423
- targetConfig[formTarget.formCode][formTarget.fieldCode] = _this.formLayout[formTarget.formCode][formTarget.fieldCode];
424
- targetForm[formTarget.formCode] = _this.formModel[formTarget.formCode];
447
+ targetConfig[formTarget.formCode][formTarget.fieldCode] = _this2.formLayout[formTarget.formCode][formTarget.fieldCode];
448
+ targetForm[formTarget.formCode] = _this2.formModel[formTarget.formCode];
425
449
  });
426
450
  config.targetConfig = targetConfig;
427
451
  config.targetForm = targetForm;
452
+ config.formModel = _this2.formModel;
428
453
  for (var _len = arguments.length, arg = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
429
454
  arg[_key - 1] = arguments[_key];
430
455
  }
431
- (_action$exec = action.exec).call.apply(_action$exec, [_this, config].concat(arg));
456
+ (_action$exec = action.exec).call.apply(_action$exec, [_this2, config].concat(arg));
432
457
  }
433
458
  });
434
459
  });
@@ -437,7 +462,7 @@ var collapse_item_default = /*#__PURE__*/__webpack_require__.n(collapse_item_);
437
462
  },
438
463
  methods: {
439
464
  validate: function validate(callback) {
440
- var _this2 = this;
465
+ var _this3 = this;
441
466
  var promise;
442
467
  // if no callback, return promise
443
468
  if (typeof callback !== "function" && Promise) {
@@ -455,9 +480,9 @@ var collapse_item_default = /*#__PURE__*/__webpack_require__.n(collapse_item_);
455
480
  }
456
481
  var invalidForms = {};
457
482
  this.items.forEach(function (form) {
458
- var formNode = _this2.$refs[form.prop];
483
+ var formNode = _this3.$refs[form.prop];
459
484
  if (!formNode) {
460
- if (typeof callback === "function" && ++count === _this2.items.length) {
485
+ if (typeof callback === "function" && ++count === _this3.items.length) {
461
486
  callback(valid, invalidForms);
462
487
  }
463
488
  return true;
@@ -467,7 +492,7 @@ var collapse_item_default = /*#__PURE__*/__webpack_require__.n(collapse_item_);
467
492
  valid = false;
468
493
  invalidForms[form.prop] = msgObj;
469
494
  }
470
- if (typeof callback === "function" && ++count === _this2.items.length) {
495
+ if (typeof callback === "function" && ++count === _this3.items.length) {
471
496
  callback(valid, invalidForms);
472
497
  }
473
498
  });
@@ -477,9 +502,9 @@ var collapse_item_default = /*#__PURE__*/__webpack_require__.n(collapse_item_);
477
502
  }
478
503
  },
479
504
  reset: function reset() {
480
- var _this3 = this;
505
+ var _this4 = this;
481
506
  this.items.forEach(function (form) {
482
- var formNode = _this3.$refs[form.prop];
507
+ var formNode = _this4.$refs[form.prop];
483
508
  if (!formNode) {
484
509
  return true;
485
510
  }
@@ -490,7 +515,8 @@ var collapse_item_default = /*#__PURE__*/__webpack_require__.n(collapse_item_);
490
515
  var h = this.$createElement;
491
516
  var formProp = {
492
517
  attrs: Object.assign({
493
- actions: this.actionFormMap[form.prop]
518
+ actions: this.actionFormMap[form.prop],
519
+ formModel: form.prop && this.formModel[form.prop]
494
520
  }, form),
495
521
  on: form.on
496
522
  };
@@ -504,10 +530,10 @@ var collapse_item_default = /*#__PURE__*/__webpack_require__.n(collapse_item_);
504
530
  }, formProp]));
505
531
  },
506
532
  renderTab: function renderTab(h, filterItems) {
507
- var _this4 = this;
533
+ var _this5 = this;
508
534
  var itemNode = filterItems.map(function (item) {
509
535
  if (typeof item.render === "function") {
510
- return item.render(h, _this4.formModel, item);
536
+ return item.render(h, _this5.formModel, item);
511
537
  }
512
538
  return h("el-tab-pane", {
513
539
  "key": item.prop,
@@ -517,7 +543,7 @@ var collapse_item_default = /*#__PURE__*/__webpack_require__.n(collapse_item_);
517
543
  }
518
544
  }, [h("template", {
519
545
  "slot": "label"
520
- }, [item.slots && typeof item.slots.title === "function" ? item.slots.title.call(_this4, h) : item.slots && item.slots.title]), _this4.formNode(item)]);
546
+ }, [item.slots && typeof item.slots.title === "function" ? item.slots.title.call(_this5, h) : item.slots && item.slots.title]), _this5.formNode(item)]);
521
547
  });
522
548
  var tabsProp = {
523
549
  attrs: {
@@ -526,17 +552,17 @@ var collapse_item_default = /*#__PURE__*/__webpack_require__.n(collapse_item_);
526
552
  },
527
553
  on: {
528
554
  "tab-click": function tabClick(tabNode) {
529
- _this4.$emit("openedCode", tabNode.name);
555
+ _this5.$emit("openedCode", tabNode.name);
530
556
  }
531
557
  }
532
558
  };
533
559
  return h("el-tabs", babel_helper_vue_jsx_merge_props_default()([{}, tabsProp]), [itemNode]);
534
560
  },
535
561
  renderCollapse: function renderCollapse(h, filterItems) {
536
- var _this5 = this;
562
+ var _this6 = this;
537
563
  var itemNode = filterItems.map(function (item) {
538
564
  if (typeof item.render === "function") {
539
- return item.render(h, _this5.formModel, item);
565
+ return item.render(h, _this6.formModel, item);
540
566
  }
541
567
  return h("el-collapse-item", {
542
568
  "key": item.prop,
@@ -546,7 +572,7 @@ var collapse_item_default = /*#__PURE__*/__webpack_require__.n(collapse_item_);
546
572
  }
547
573
  }, [h("template", {
548
574
  "slot": "title"
549
- }, [item.slots && typeof item.slots.title === "function" ? item.slots.title.call(_this5, h) : item.slots && item.slots.title]), _this5.formNode(item)]);
575
+ }, [item.slots && typeof item.slots.title === "function" ? item.slots.title.call(_this6, h) : item.slots && item.slots.title]), _this6.formNode(item)]);
550
576
  });
551
577
  var collapseProp = {
552
578
  attrs: {
@@ -554,20 +580,46 @@ var collapse_item_default = /*#__PURE__*/__webpack_require__.n(collapse_item_);
554
580
  },
555
581
  on: {
556
582
  change: function change(val) {
557
- _this5.$emit("openedCode", val);
583
+ _this6.$emit("openedCode", val);
558
584
  }
559
585
  }
560
586
  };
561
587
  return h("el-collapse", babel_helper_vue_jsx_merge_props_default()([{}, collapseProp]), [itemNode]);
588
+ },
589
+ renderCustom: function renderCustom(h, filterItems) {
590
+ var _this7 = this;
591
+ var itemNode = filterItems.map(function (item) {
592
+ if (typeof item.render === "function") {
593
+ return item.render(h, _this7.formModel, item);
594
+ }
595
+ return h("div", {
596
+ "key": item.prop,
597
+ "attrs": {
598
+ "name": item.prop,
599
+ "title": item.label
600
+ }
601
+ }, [item.slots && typeof item.slots.title === "function" ? item.slots.title.call(_this7, h) : item.slots && item.slots.title || item.label, _this7.formNode(item)]);
602
+ });
603
+ var collapseProp = {
604
+ attrs: {
605
+ value: this.openedCode
606
+ },
607
+ on: {
608
+ change: function change(val) {
609
+ _this7.$emit("openedCode", val);
610
+ }
611
+ }
612
+ };
613
+ return h("div", babel_helper_vue_jsx_merge_props_default()([{}, collapseProp]), [itemNode]);
562
614
  }
563
615
  },
564
616
  render: function render(h) {
565
- var _this6 = this;
617
+ var _this8 = this;
566
618
  var filterItems = this.items.filter(function (item) {
567
619
  if (item.show === false) {
568
620
  return false;
569
621
  }
570
- if (typeof item.show === "function" && !item.show.call(_this6, {
622
+ if (typeof item.show === "function" && !item.show.call(_this8, {
571
623
  config: item
572
624
  })) {
573
625
  return false;
@@ -578,9 +630,14 @@ var collapse_item_default = /*#__PURE__*/__webpack_require__.n(collapse_item_);
578
630
  return null;
579
631
  }
580
632
  this.openedCode = filterItems[0] && filterItems[0].prop;
633
+ var group = {
634
+ Custom: this.renderCustom,
635
+ Tab: this.renderTab,
636
+ Collapse: this.renderCollapse
637
+ };
581
638
  return h("div", {
582
- "class": ["form-group", "is-" + (this.control === "Tab" ? "tab" : "collapse")]
583
- }, [this.control === "Tab" ? this.renderTab(h, filterItems) : this.renderCollapse(h, filterItems)]);
639
+ "class": ["form-group", "is-" + this.control]
640
+ }, [group[this.control] ? group[this.control](h, filterItems) : null]);
584
641
  }
585
642
  });
586
643
  // CONCATENATED MODULE: ./src/components/form-group/index.js
@@ -620,7 +677,7 @@ module.exports = require("@panpanzhao/component-ui/lib/components/drawer");
620
677
  // ESM COMPAT FLAG
621
678
  __webpack_require__.r(__webpack_exports__);
622
679
 
623
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--5!./node_modules/vue-loader/lib??vue-loader-options!./src/components/form/src/form.vue?vue&type=template&id=097bf622&
680
+ // CONCATENATED MODULE: ./node_modules/.pnpm/vue-loader@15.11.1_css-loader@2.1.1_lodash@4.17.21_vue-template-compiler@2.7.16_webpack@4.47.0/node_modules/vue-loader/lib/loaders/templateLoader.js??ref--5!./node_modules/.pnpm/vue-loader@15.11.1_css-loader@2.1.1_lodash@4.17.21_vue-template-compiler@2.7.16_webpack@4.47.0/node_modules/vue-loader/lib??vue-loader-options!./src/components/form/src/form.vue?vue&type=template&id=74ff4c20
624
681
  var render = function render() {
625
682
  var _vm = this,
626
683
  _c = _vm._self._c
@@ -691,7 +748,7 @@ var staticRenderFns = []
691
748
  render._withStripped = true
692
749
 
693
750
 
694
- // CONCATENATED MODULE: ./src/components/form/src/form.vue?vue&type=template&id=097bf622&
751
+ // CONCATENATED MODULE: ./src/components/form/src/form.vue?vue&type=template&id=74ff4c20
695
752
 
696
753
  // EXTERNAL MODULE: external "element-ui/lib/form"
697
754
  var form_ = __webpack_require__(13);
@@ -715,14 +772,14 @@ var formula_ = __webpack_require__(3);
715
772
  // EXTERNAL MODULE: external "lodash"
716
773
  var external_lodash_ = __webpack_require__(2);
717
774
 
718
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./src/components/form/src/form.vue?vue&type=script&lang=js&
775
+ // CONCATENATED MODULE: ./node_modules/.pnpm/babel-loader@8.3.0_@babel+core@7.23.9_webpack@4.47.0/node_modules/babel-loader/lib!./node_modules/.pnpm/vue-loader@15.11.1_css-loader@2.1.1_lodash@4.17.21_vue-template-compiler@2.7.16_webpack@4.47.0/node_modules/vue-loader/lib??vue-loader-options!./src/components/form/src/form.vue?vue&type=script&lang=js
719
776
 
720
777
 
721
778
 
722
779
 
723
780
 
724
781
 
725
- /* harmony default export */ var formvue_type_script_lang_js_ = ({
782
+ /* harmony default export */ var formvue_type_script_lang_js = ({
726
783
  name: "Form",
727
784
  componentName: "Form",
728
785
  components: {
@@ -863,9 +920,19 @@ var external_lodash_ = __webpack_require__(2);
863
920
  var _callback = null;
864
921
  if (callback) {
865
922
  _callback = function _callback(flag, message) {
866
- callback.call(_this3, flag, message);
867
923
  if (typeof _this3.verify === "function") {
868
- _this3.verify.call(_this3, flag, message);
924
+ var promiset = _this3.verify.call(_this3, flag, message);
925
+ if (promiset && Object.prototype.toString.call(promiset) == "[object Promise]") {
926
+ promiset.then(function (vFlag, vMessage) {
927
+ callback.call(_this3, flag && vFlag !== false, message, vMessage);
928
+ }).catch(function (error) {
929
+ callback.call(_this3, false, message, error);
930
+ });
931
+ } else {
932
+ callback.call(_this3, flag && promiset !== false, message);
933
+ }
934
+ } else {
935
+ callback.call(_this3, flag, message);
869
936
  }
870
937
  };
871
938
  }
@@ -900,9 +967,9 @@ var external_lodash_ = __webpack_require__(2);
900
967
  }
901
968
  }
902
969
  });
903
- // CONCATENATED MODULE: ./src/components/form/src/form.vue?vue&type=script&lang=js&
904
- /* harmony default export */ var src_formvue_type_script_lang_js_ = (formvue_type_script_lang_js_);
905
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
970
+ // CONCATENATED MODULE: ./src/components/form/src/form.vue?vue&type=script&lang=js
971
+ /* harmony default export */ var src_formvue_type_script_lang_js = (formvue_type_script_lang_js);
972
+ // EXTERNAL MODULE: ./node_modules/.pnpm/vue-loader@15.11.1_css-loader@2.1.1_lodash@4.17.21_vue-template-compiler@2.7.16_webpack@4.47.0/node_modules/vue-loader/lib/runtime/componentNormalizer.js
906
973
  var componentNormalizer = __webpack_require__(1);
907
974
 
908
975
  // CONCATENATED MODULE: ./src/components/form/src/form.vue
@@ -914,7 +981,7 @@ var componentNormalizer = __webpack_require__(1);
914
981
  /* normalize component */
915
982
 
916
983
  var component = Object(componentNormalizer["a" /* default */])(
917
- src_formvue_type_script_lang_js_,
984
+ src_formvue_type_script_lang_js,
918
985
  render,
919
986
  staticRenderFns,
920
987
  false,
@@ -962,7 +1029,7 @@ module.exports = require("element-ui/lib/collapse");
962
1029
 
963
1030
  /***/ }),
964
1031
 
965
- /***/ 80:
1032
+ /***/ 81:
966
1033
  /***/ (function(module, __webpack_exports__, __webpack_require__) {
967
1034
 
968
1035
  "use strict";
@@ -985,7 +1052,7 @@ var button_default = /*#__PURE__*/__webpack_require__.n(button_);
985
1052
  var components_form = __webpack_require__(4);
986
1053
 
987
1054
  // EXTERNAL MODULE: ./src/components/form-group/index.js + 2 modules
988
- var form_group = __webpack_require__(18);
1055
+ var form_group = __webpack_require__(19);
989
1056
 
990
1057
  // EXTERNAL MODULE: external "@panpanzhao/component-ui/lib/utils/formula"
991
1058
  var formula_ = __webpack_require__(3);
@@ -993,7 +1060,7 @@ var formula_ = __webpack_require__(3);
993
1060
  // EXTERNAL MODULE: external "lodash"
994
1061
  var external_lodash_ = __webpack_require__(2);
995
1062
 
996
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./src/components/form-drawer/src/index.vue?vue&type=script&lang=js&
1063
+ // CONCATENATED MODULE: ./node_modules/.pnpm/babel-loader@8.3.0_@babel+core@7.23.9_webpack@4.47.0/node_modules/babel-loader/lib!./node_modules/.pnpm/vue-loader@15.11.1_css-loader@2.1.1_lodash@4.17.21_vue-template-compiler@2.7.16_webpack@4.47.0/node_modules/vue-loader/lib??vue-loader-options!./src/components/form-drawer/src/index.vue?vue&type=script&lang=js
997
1064
 
998
1065
 
999
1066
 
@@ -1005,7 +1072,7 @@ var external_lodash_ = __webpack_require__(2);
1005
1072
 
1006
1073
 
1007
1074
 
1008
- /* harmony default export */ var srcvue_type_script_lang_js_ = ({
1075
+ /* harmony default export */ var srcvue_type_script_lang_js = ({
1009
1076
  name: "FormDrawer",
1010
1077
  componentName: "FormDrawer",
1011
1078
  components: {
@@ -1251,9 +1318,9 @@ var external_lodash_ = __webpack_require__(2);
1251
1318
  }, [this.renderTools(h)]), this.renderForm(h)]);
1252
1319
  }
1253
1320
  });
1254
- // CONCATENATED MODULE: ./src/components/form-drawer/src/index.vue?vue&type=script&lang=js&
1255
- /* harmony default export */ var form_drawer_srcvue_type_script_lang_js_ = (srcvue_type_script_lang_js_);
1256
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
1321
+ // CONCATENATED MODULE: ./src/components/form-drawer/src/index.vue?vue&type=script&lang=js
1322
+ /* harmony default export */ var form_drawer_srcvue_type_script_lang_js = (srcvue_type_script_lang_js);
1323
+ // EXTERNAL MODULE: ./node_modules/.pnpm/vue-loader@15.11.1_css-loader@2.1.1_lodash@4.17.21_vue-template-compiler@2.7.16_webpack@4.47.0/node_modules/vue-loader/lib/runtime/componentNormalizer.js
1257
1324
  var componentNormalizer = __webpack_require__(1);
1258
1325
 
1259
1326
  // CONCATENATED MODULE: ./src/components/form-drawer/src/index.vue
@@ -1265,7 +1332,7 @@ var src_render, staticRenderFns
1265
1332
  /* normalize component */
1266
1333
 
1267
1334
  var component = Object(componentNormalizer["a" /* default */])(
1268
- form_drawer_srcvue_type_script_lang_js_,
1335
+ form_drawer_srcvue_type_script_lang_js,
1269
1336
  src_render,
1270
1337
  staticRenderFns,
1271
1338
  false,