nubomed-ui 2.0.43 → 2.0.45

Sign up to get free protection for your applications and to get access to all the features.
package/nubomed-ui.umd.js CHANGED
@@ -306,6 +306,90 @@ module.exports = function (i) {
306
306
 
307
307
  /***/ }),
308
308
 
309
+ /***/ 3134:
310
+ /***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
311
+
312
+ "use strict";
313
+ // ESM COMPAT FLAG
314
+ __webpack_require__.r(__webpack_exports__);
315
+
316
+ // EXPORTS
317
+ __webpack_require__.d(__webpack_exports__, {
318
+ "default": function() { return /* binding */ NBBadge; }
319
+ });
320
+
321
+ ;// ./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!./packages/components/NBBadge/src/index.vue?vue&type=template&id=a2f7b152
322
+ var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return (_vm.value > 0)?_c('span',{staticClass:"nb-badge",class:("nb-badge--" + _vm.type)},[_vm._v(_vm._s(_vm.value > _vm.max ? (_vm.max + "+") : _vm.value))]):_vm._e()}
323
+ var staticRenderFns = []
324
+
325
+
326
+ ;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-80.use[1]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./packages/components/NBBadge/src/index.vue?vue&type=script&lang=js
327
+ //
328
+ //
329
+ //
330
+ //
331
+ //
332
+ //
333
+ //
334
+ //
335
+ //
336
+ //
337
+ //
338
+ //
339
+
340
+ /* harmony default export */ var srcvue_type_script_lang_js = ({
341
+ name: 'NBBadge',
342
+ props: {
343
+ // 类型,success/info/warning/danger,默认主题色状态
344
+ value: {
345
+ type: [String, Number],
346
+ default: ''
347
+ },
348
+ // 尺寸,large-大标签(高度36),默认小标签(高度32)
349
+ max: {
350
+ type: Number,
351
+ default: null
352
+ },
353
+ // 类型 primary / success / warning / danger / info
354
+ type: {
355
+ type: String,
356
+ default: 'danger'
357
+ }
358
+ }
359
+ });
360
+ ;// ./packages/components/NBBadge/src/index.vue?vue&type=script&lang=js
361
+ /* harmony default export */ var NBBadge_srcvue_type_script_lang_js = (srcvue_type_script_lang_js);
362
+ // EXTERNAL MODULE: ./node_modules/@vue/vue-loader-v15/lib/runtime/componentNormalizer.js
363
+ var componentNormalizer = __webpack_require__(1656);
364
+ ;// ./packages/components/NBBadge/src/index.vue
365
+
366
+
367
+
368
+
369
+
370
+ /* normalize component */
371
+ ;
372
+ var component = (0,componentNormalizer/* default */.A)(
373
+ NBBadge_srcvue_type_script_lang_js,
374
+ render,
375
+ staticRenderFns,
376
+ false,
377
+ null,
378
+ null,
379
+ null
380
+
381
+ )
382
+
383
+ /* harmony default export */ var src = (component.exports);
384
+ ;// ./packages/components/NBBadge/index.js
385
+
386
+ src.install = function (Vue) {
387
+ Vue.component(src.name, src);
388
+ };
389
+ /* harmony default export */ var NBBadge = (src);
390
+
391
+ /***/ }),
392
+
309
393
  /***/ 2129:
310
394
  /***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
311
395
 
@@ -462,6 +546,271 @@ src.install = function (Vue) {
462
546
 
463
547
  /***/ }),
464
548
 
549
+ /***/ 4227:
550
+ /***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
551
+
552
+ "use strict";
553
+ // ESM COMPAT FLAG
554
+ __webpack_require__.r(__webpack_exports__);
555
+
556
+ // EXPORTS
557
+ __webpack_require__.d(__webpack_exports__, {
558
+ "default": function() { return /* binding */ NBDialog; }
559
+ });
560
+
561
+ ;// ./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!./packages/components/NBDialog/src/index.vue?vue&type=template&id=d8856578&scoped=true
562
+ var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('el-dialog',{staticClass:"nb-dialog__wrapper",attrs:{"visible":_vm.visible,"show-close":_vm.showClose,"close-on-click-modal":false,"close-on-press-escape":false,"center":_vm.center,"dialog-center":_vm.dialogCenter,"type":_vm.size,"title":_vm.$slots['title-right'] ? '' : _vm.title,"custom-class":_vm.dialogCustomClass,"before-close":_vm.handleClose,"append-to-body":"","destroy-on-close":""},on:{"closed":_vm.closedDialog}},[_c('template',{slot:"title"},[_vm._t("title"),(_vm.$slots['title-right'])?_c('div',{staticClass:"nb-dialog__header--has-form"},[_c('span',{staticClass:"el-dialog__title"},[_vm._v(_vm._s(_vm.title))]),_c('div',{staticClass:"el-dialog__right"},[_vm._t("title-right")],2)]):_vm._e()],2),_vm._t("default"),_c('template',{slot:"footer"},[_vm._t("footer",function(){return [(_vm.showCancelButton)?_c('el-button',{on:{"click":_vm.handleCancel}},[_vm._v(_vm._s(_vm.cancelButtonText)),(_vm.cancelButtonTime > -1)?[_vm._v("("+_vm._s(_vm.cancelAutoTime)+"S)")]:_vm._e()],2):_vm._e(),(_vm.showConfirmButton)?_c('el-button',{attrs:{"type":"primary","plain":_vm.confirmButtonPlain},on:{"click":_vm.handleConfirm}},[_vm._v(_vm._s(_vm.confirmButtonText)),(_vm.confirmButtonTime > -1)?[_vm._v("("+_vm._s(_vm.confirmAutoTime)+"S)")]:_vm._e()],2):_vm._e()]})],2)],2)}
563
+ var staticRenderFns = []
564
+
565
+
566
+ ;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-80.use[1]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./packages/components/NBDialog/src/index.vue?vue&type=script&lang=js
567
+ //
568
+ //
569
+ //
570
+ //
571
+ //
572
+ //
573
+ //
574
+ //
575
+ //
576
+ //
577
+ //
578
+ //
579
+ //
580
+ //
581
+ //
582
+ //
583
+ //
584
+ //
585
+ //
586
+ //
587
+ //
588
+ //
589
+ //
590
+ //
591
+ //
592
+ //
593
+ //
594
+ //
595
+ //
596
+ //
597
+ //
598
+ //
599
+ //
600
+ //
601
+ //
602
+ //
603
+ //
604
+ //
605
+ //
606
+ //
607
+
608
+ /* harmony default export */ var srcvue_type_script_lang_js = ({
609
+ name: 'NBDialog',
610
+ // 使用v-model即可
611
+ model: {
612
+ prop: 'visible',
613
+ event: 'update'
614
+ },
615
+ props: {
616
+ // 是否显示弹框
617
+ visible: {
618
+ type: Boolean,
619
+ default: false
620
+ },
621
+ // 大小:'' 表示自定义尺寸 / small / medium / large
622
+ size: {
623
+ type: String,
624
+ default: '',
625
+ validator(value) {
626
+ return ['', 'small', 'medium', 'large'].includes(value);
627
+ }
628
+ },
629
+ // 弹框标题
630
+ title: {
631
+ type: String,
632
+ default: ''
633
+ },
634
+ // 是否显示关闭按钮
635
+ showClose: {
636
+ type: Boolean,
637
+ default: false
638
+ },
639
+ // 是否居中显示
640
+ center: {
641
+ type: Boolean,
642
+ default: false
643
+ },
644
+ // 弹框是否居中
645
+ dialogCenter: {
646
+ type: Boolean,
647
+ default: true
648
+ },
649
+ // 自定义样式
650
+ customClass: {
651
+ type: String,
652
+ default: ''
653
+ },
654
+ // 是否显示取消按钮
655
+ showCancelButton: {
656
+ type: Boolean,
657
+ default: true
658
+ },
659
+ // 取消按钮的文本内容,默认取消
660
+ cancelButtonText: {
661
+ type: String,
662
+ default: ''
663
+ },
664
+ // 取消按钮倒计时时间
665
+ cancelButtonTime: {
666
+ type: Number,
667
+ default: -1
668
+ },
669
+ // 是否显示确定按钮
670
+ showConfirmButton: {
671
+ type: Boolean,
672
+ default: true
673
+ },
674
+ // 确定按钮的文本内容,默认确定
675
+ confirmButtonText: {
676
+ type: String,
677
+ default: ''
678
+ },
679
+ // 确定按钮倒计时时间
680
+ confirmButtonTime: {
681
+ type: Number,
682
+ default: -1
683
+ },
684
+ // 内容是表单
685
+ form: {
686
+ type: [Boolean, String],
687
+ default: false
688
+ }
689
+ },
690
+ data() {
691
+ return {
692
+ cancelAutoTimer: null,
693
+ cancelAutoTime: this.cancelButtonTime,
694
+ confirmAutoTimer: null,
695
+ confirmAutoTime: this.confirmButtonTime
696
+ };
697
+ },
698
+ computed: {
699
+ // 如果只显示确定按钮,那么确定按钮plain显示镂空
700
+ confirmButtonPlain() {
701
+ if (!this.showCancelButton && this.showConfirmButton) {
702
+ return true;
703
+ }
704
+ return false;
705
+ },
706
+ // 表单自定义样式
707
+ dialogCustomClass() {
708
+ let cls = 'nb-dialog';
709
+ if (this.form) {
710
+ cls += ` nb-form-dialog`;
711
+ }
712
+ if (this.customClass) {
713
+ cls += this.customClass;
714
+ }
715
+ return cls;
716
+ }
717
+ },
718
+ watch: {
719
+ visible(val) {
720
+ if (val && this.cancelButtonTime > -1) {
721
+ this.startCancelButtonAutoTimer();
722
+ }
723
+ if (val && this.confirmButtonTime > -1) {
724
+ this.startConfirmButtonAutoTimer();
725
+ }
726
+ }
727
+ },
728
+ beforeDestroy() {
729
+ clearInterval(this.cancelAutoTimer);
730
+ clearInterval(this.confirmAutoTimer);
731
+ },
732
+ methods: {
733
+ startCancelButtonAutoTimer() {
734
+ clearInterval(this.cancelAutoTimer);
735
+ this.cancelAutoTime = this.cancelButtonTime;
736
+ this.cancelAutoTimer = setInterval(() => {
737
+ this.cancelAutoTime--;
738
+ if (this.cancelAutoTime <= 0) {
739
+ clearInterval(this.cancelAutoTimer);
740
+ this.handleCancel();
741
+ }
742
+ }, 1000);
743
+ },
744
+ startConfirmButtonAutoTimer() {
745
+ clearInterval(this.confirmAutoTimer);
746
+ this.confirmAutoTime = this.confirmButtonTime;
747
+ this.confirmAutoTimer = setInterval(() => {
748
+ this.confirmAutoTime--;
749
+ if (this.confirmAutoTime <= 0) {
750
+ clearInterval(this.confirmAutoTimer);
751
+ this.handleConfirm();
752
+ }
753
+ }, 1000);
754
+ },
755
+ // 取消
756
+ handleCancel() {
757
+ if (!this.$listeners['cancel']) {
758
+ this.$emit('update', false);
759
+ }
760
+ this.$emit('cancel');
761
+ },
762
+ // 确定
763
+ handleConfirm() {
764
+ if (!this.$listeners['confirm']) {
765
+ this.$emit('update', false);
766
+ }
767
+ this.$emit('confirm');
768
+ },
769
+ // 点击右上角关闭按钮
770
+ handleClose() {
771
+ this.$emit('update', false);
772
+ },
773
+ // 关闭弹框
774
+ closedDialog() {
775
+ clearInterval(this.cancelAutoTimer);
776
+ clearInterval(this.confirmAutoTimer);
777
+ this.$emit('closed');
778
+ }
779
+ }
780
+ });
781
+ ;// ./packages/components/NBDialog/src/index.vue?vue&type=script&lang=js
782
+ /* harmony default export */ var NBDialog_srcvue_type_script_lang_js = (srcvue_type_script_lang_js);
783
+ // EXTERNAL MODULE: ./node_modules/@vue/vue-loader-v15/lib/runtime/componentNormalizer.js
784
+ var componentNormalizer = __webpack_require__(1656);
785
+ ;// ./packages/components/NBDialog/src/index.vue
786
+
787
+
788
+
789
+
790
+
791
+ /* normalize component */
792
+ ;
793
+ var component = (0,componentNormalizer/* default */.A)(
794
+ NBDialog_srcvue_type_script_lang_js,
795
+ render,
796
+ staticRenderFns,
797
+ false,
798
+ null,
799
+ "d8856578",
800
+ null
801
+
802
+ )
803
+
804
+ /* harmony default export */ var src = (component.exports);
805
+ ;// ./packages/components/NBDialog/index.js
806
+
807
+ src.install = function (Vue) {
808
+ Vue.component(src.name, src);
809
+ };
810
+ /* harmony default export */ var NBDialog = (src);
811
+
812
+ /***/ }),
813
+
465
814
  /***/ 2846:
466
815
  /***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
467
816
 
@@ -686,7 +1035,7 @@ src.install = function (Vue) {
686
1035
 
687
1036
  /***/ }),
688
1037
 
689
- /***/ 2229:
1038
+ /***/ 6523:
690
1039
  /***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
691
1040
 
692
1041
  "use strict";
@@ -698,14 +1047,84 @@ __webpack_require__.d(__webpack_exports__, {
698
1047
  "default": function() { return /* binding */ NBHeader; }
699
1048
  });
700
1049
 
701
- ;// ./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!./packages/components/NBHeader/src/index.vue?vue&type=template&id=e09e670c&scoped=true
702
- var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"nb-header"},[(_vm.back)?_c('div',{staticClass:"nb-header__back",on:{"click":function($event){$event.stopPropagation();return _vm.handleBack.apply(null, arguments)}}},[_c('NBIcon',{attrs:{"icon":"back"}}),_c('span',{staticClass:"nb-header__back__text"},[_vm._v(_vm._s(_vm.backText))])],1):_vm._e(),_c('div',{staticClass:"nb-header__left"},[_vm._t("left")],2),(_vm.tabs.length)?_c('ul',{staticClass:"nb-header__tabs"},_vm._l((_vm.tabs),function(item,index){return _c('li',{key:index,staticClass:"nb-header__tab",class:_vm.tabsItemClass(item, index),on:{"click":function($event){$event.stopPropagation();return _vm.handleChangeTab(item, index)}}},[_c('div',{staticClass:"nb-header__tab__text"},[_c('span',[_c('el-badge',{attrs:{"value":item[_vm.tabProps.badge],"hidden":!item[_vm.tabProps.badge],"max":99}},[_vm._v(_vm._s(item[_vm.tabProps.text]))])],1)])])}),0):_vm._e(),(_vm.title)?_c('div',{staticClass:"nb-header__title"},[_vm._v(_vm._s(_vm.title))]):_vm._e(),(_vm.$slots.title)?_c('div',{staticClass:"nb-header__title"},[_vm._t("title")],2):_vm._e(),_c('div',{staticClass:"nb-header__right"},[_vm._t("right")],2),(_vm.logout)?_c('div',{staticClass:"nb-header__logout",on:{"click":function($event){$event.stopPropagation();return _vm.handleLogout.apply(null, arguments)}}},[_c('NBIcon',{attrs:{"icon":"logout"}}),_c('span',{staticClass:"nb-header__logout__text"},[_vm._v(_vm._s(_vm.logoutText)),(_vm.logoutTime > -1)?[_vm._v("("+_vm._s(_vm.logoutTime)+"S)")]:_vm._e()],2)],1):_vm._e()])}
1050
+ ;// ./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!./packages/components/NBHeader/src/index.vue?vue&type=template&id=8de13f1a&scoped=true
1051
+ var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"nb-header"},[(_vm.back)?_c('div',{staticClass:"nb-header__back",on:{"click":function($event){$event.stopPropagation();return _vm.handleBack.apply(null, arguments)}}},[_c('NBIcon',{attrs:{"icon":"back"}}),_c('span',{staticClass:"nb-header__back__text"},[_vm._v(_vm._s(_vm.backText))])],1):_vm._e(),_c('div',{staticClass:"nb-header__left"},[_vm._t("left")],2),(_vm.tabs.length)?_c('ul',{ref:"refNBHeaderTabs",staticClass:"nb-header__tabs"},_vm._l((_vm.tabs),function(item,index){return _c('li',{key:index,staticClass:"nb-header__tab",class:_vm.tabsItemClass(item, index),on:{"click":function($event){$event.stopPropagation();return _vm.handleChangeTab(item, index)}}},[_c('div',{staticClass:"nb-header__tab__text"},[_c('span',{domProps:{"innerHTML":_vm._s(item[_vm.tabProps.text])}})]),_c('NBBadge',{attrs:{"value":item[_vm.tabProps.badge],"max":99}})],1)}),0):_vm._e(),(_vm.title)?_c('div',{staticClass:"nb-header__title"},[_vm._v(_vm._s(_vm.title))]):_vm._e(),(_vm.$slots.title)?_c('div',{staticClass:"nb-header__title"},[_vm._t("title")],2):_vm._e(),_c('div',{ref:"refNBHeaderRight",staticClass:"nb-header__right"},[_vm._t("right")],2),(_vm.logout)?_c('div',{staticClass:"nb-header__logout",on:{"click":function($event){$event.stopPropagation();return _vm.handleLogout.apply(null, arguments)}}},[_c('NBIcon',{attrs:{"icon":"logout"}}),_c('span',{staticClass:"nb-header__logout__text"},[_vm._v(_vm._s(_vm.logoutText)),(_vm.logoutTime > -1)?[_vm._v("("+_vm._s(_vm.logoutTime)+"S)")]:_vm._e()],2)],1):_vm._e()])}
703
1052
  var staticRenderFns = []
704
1053
 
705
1054
 
1055
+ // EXTERNAL MODULE: ./node_modules/core-js/modules/esnext.iterator.constructor.js
1056
+ var esnext_iterator_constructor = __webpack_require__(8992);
1057
+ // EXTERNAL MODULE: ./node_modules/core-js/modules/esnext.iterator.for-each.js
1058
+ var esnext_iterator_for_each = __webpack_require__(3949);
706
1059
  // EXTERNAL MODULE: ./packages/components/NBIcon/index.js + 4 modules
707
1060
  var NBIcon = __webpack_require__(5408);
1061
+ // EXTERNAL MODULE: ./packages/components/NBBadge/index.js + 4 modules
1062
+ var NBBadge = __webpack_require__(3134);
1063
+ ;// ./packages/utils/dom.js
1064
+ /*
1065
+ * @Author: chenghuan.dong
1066
+ * @Date: 2024-11-14 14:48:30
1067
+ * @LastEditTime: 2024-11-14 14:50:14
1068
+ * @LastEditors: chenghuan.dong
1069
+ * @Description:
1070
+ * @FilePath: \nubomed-ui\packages\utils\dom.js
1071
+ */
1072
+ /* istanbul ignore next */
1073
+ function addClass(el, cls) {
1074
+ if (!el) return;
1075
+ var curClass = el.className;
1076
+ var classes = (cls || '').split(' ');
1077
+ for (var i = 0, j = classes.length; i < j; i++) {
1078
+ var clsName = classes[i];
1079
+ if (!clsName) continue;
1080
+ if (el.classList) {
1081
+ el.classList.add(clsName);
1082
+ } else if (!hasClass(el, clsName)) {
1083
+ curClass += ' ' + clsName;
1084
+ }
1085
+ }
1086
+ if (!el.classList) {
1087
+ el.setAttribute('class', curClass);
1088
+ }
1089
+ }
1090
+
1091
+ /* istanbul ignore next */
1092
+ function removeClass(el, cls) {
1093
+ if (!el || !cls) return;
1094
+ var classes = cls.split(' ');
1095
+ var curClass = ' ' + el.className + ' ';
1096
+ for (var i = 0, j = classes.length; i < j; i++) {
1097
+ var clsName = classes[i];
1098
+ if (!clsName) continue;
1099
+ if (el.classList) {
1100
+ el.classList.remove(clsName);
1101
+ } else if (hasClass(el, clsName)) {
1102
+ curClass = curClass.replace(' ' + clsName + ' ', ' ');
1103
+ }
1104
+ }
1105
+ if (!el.classList) {
1106
+ el.setAttribute('class', trim(curClass));
1107
+ }
1108
+ }
1109
+
1110
+ /* istanbul ignore next */
1111
+ function hasClass(el, cls) {
1112
+ if (!el || !cls) return false;
1113
+ if (cls.indexOf(' ') !== -1) throw new Error('className should not contain space.');
1114
+ if (el.classList) {
1115
+ return el.classList.contains(cls);
1116
+ } else {
1117
+ return (' ' + el.className + ' ').indexOf(' ' + cls + ' ') > -1;
1118
+ }
1119
+ }
1120
+
1121
+ /* istanbul ignore next */
1122
+ const trim = function (string) {
1123
+ return (string || '').replace(/^[\s\uFEFF]+|[\s\uFEFF]+$/g, '');
1124
+ };
708
1125
  ;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-80.use[1]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./packages/components/NBHeader/src/index.vue?vue&type=script&lang=js
1126
+
1127
+
709
1128
  //
710
1129
  //
711
1130
  //
@@ -757,13 +1176,15 @@ var NBIcon = __webpack_require__(5408);
757
1176
  //
758
1177
  //
759
1178
  //
760
- //
1179
+
1180
+
761
1181
 
762
1182
 
763
1183
  /* harmony default export */ var srcvue_type_script_lang_js = ({
764
1184
  name: 'NBHeader',
765
1185
  components: {
766
- NBIcon: NBIcon["default"]
1186
+ NBIcon: NBIcon["default"],
1187
+ NBBadge: NBBadge["default"]
767
1188
  },
768
1189
  props: {
769
1190
  // 是否显示返回
@@ -829,7 +1250,28 @@ var NBIcon = __webpack_require__(5408);
829
1250
  data() {
830
1251
  return {};
831
1252
  },
832
- computed: {},
1253
+ mounted() {
1254
+ // 缩小tab的字体
1255
+ if (this.$refs.refNBHeaderTabs) {
1256
+ const tabs = this.$refs.refNBHeaderTabs.querySelectorAll('.nb-header__tab');
1257
+ tabs.forEach(x => {
1258
+ const el = x.querySelector('.nb-header__tab__text>span');
1259
+ if (el) {
1260
+ addClass(x.querySelector('.nb-header__tab__text'), `nb-header__tab__text--${parseInt(el.clientHeight / 42)}`);
1261
+ }
1262
+ });
1263
+ }
1264
+
1265
+ // 缩小右侧按钮大小
1266
+ if (this.$refs.refNBHeaderRight && this.$refs.refNBHeaderTabs) {
1267
+ const rightButton = this.$refs.refNBHeaderRight.querySelectorAll('.nb-header__btn');
1268
+ rightButton.forEach(x => {
1269
+ if (x && x.clientWidth > 220) {
1270
+ addClass(x, 'nb-header__btn--small');
1271
+ }
1272
+ });
1273
+ }
1274
+ },
833
1275
  methods: {
834
1276
  // 返回
835
1277
  handleBack() {
@@ -880,7 +1322,7 @@ var component = (0,componentNormalizer/* default */.A)(
880
1322
  staticRenderFns,
881
1323
  false,
882
1324
  null,
883
- "e09e670c",
1325
+ "8de13f1a",
884
1326
  null
885
1327
 
886
1328
  )
@@ -977,6 +1419,282 @@ src.install = function (Vue) {
977
1419
 
978
1420
  /***/ }),
979
1421
 
1422
+ /***/ 3752:
1423
+ /***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
1424
+
1425
+ "use strict";
1426
+ // ESM COMPAT FLAG
1427
+ __webpack_require__.r(__webpack_exports__);
1428
+
1429
+ // EXPORTS
1430
+ __webpack_require__.d(__webpack_exports__, {
1431
+ "default": function() { return /* binding */ NBMessageDialog; }
1432
+ });
1433
+
1434
+ ;// ./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!./packages/components/NBMessageDialog/src/index.vue?vue&type=template&id=abd09ece&scoped=true
1435
+ var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('el-dialog',{staticClass:"nb-dialog__wrapper nb-message-dialog__wrapper",attrs:{"visible":_vm.visible,"show-close":false,"close-on-click-modal":false,"close-on-press-escape":false,"center":"","append-to-body":"","destroy-on-close":"","type":_vm.size,"custom-class":("nb-dialog nb-message-dialog nb-message-dialog--" + _vm.type + " " + _vm.isReduce),"dialog-center":_vm.dialogCenter},on:{"update:visible":function($event){_vm.visible=$event},"closed":_vm.closedDialog}},[(_vm.type === 'success')?_c('img',{staticClass:"message__icon",attrs:{"src":__webpack_require__(6559)}}):_vm._e(),(_vm.type === 'abnormal')?_c('img',{staticClass:"message__icon",attrs:{"src":__webpack_require__(3906)}}):_vm._e(),(_vm.type === 'error')?_c('img',{staticClass:"message__icon",attrs:{"src":__webpack_require__(8508)}}):_vm._e(),(_vm.type === 'warning')?_c('img',{staticClass:"message__icon",attrs:{"src":__webpack_require__(629)}}):_vm._e(),(_vm.type === 'progress' && _vm.visible)?_c('NBProgress',{attrs:{"percentage":_vm.percentage,"time":_vm.finishTime,"size":_vm.size}}):_vm._e(),(_vm.title)?_c('div',{staticClass:"message__title",domProps:{"innerHTML":_vm._s(_vm.title)}}):_vm._e(),(_vm.message)?_c('div',{staticClass:"message__message",domProps:{"innerHTML":_vm._s(_vm.message)}}):_vm._e(),(_vm.tips)?_c('div',{staticClass:"message__tips"},[_vm._v(_vm._s(_vm.tips))]):_vm._e(),_vm._t("default"),_c('template',{slot:"footer"},[_vm._t("footer",function(){return [(_vm.showCancelButton)?_c('el-button',{on:{"click":_vm.handleCancel}},[_vm._v(_vm._s(_vm.cancelButtonText)),(_vm.cancelButtonTime > -1)?[_vm._v("("+_vm._s(_vm.cancelAutoTime)+"S)")]:_vm._e()],2):_vm._e(),(_vm.showConfirmButton)?_c('el-button',{attrs:{"type":"primary","plain":_vm.confirmButtonPlain,"loading":_vm.confirmButtonLoading},on:{"click":_vm.handleConfirm}},[_vm._v(_vm._s(_vm.confirmButtonText)),(_vm.confirmButtonTime > -1)?[_vm._v("("+_vm._s(_vm.confirmAutoTime)+"S)")]:_vm._e()],2):_vm._e()]})],2)],2)}
1436
+ var staticRenderFns = []
1437
+
1438
+
1439
+ ;// ./packages/components/NBMessageDialog/src/index.vue?vue&type=template&id=abd09ece&scoped=true
1440
+
1441
+ // EXTERNAL MODULE: ./packages/components/NBProgress/index.js + 5 modules
1442
+ var NBProgress = __webpack_require__(849);
1443
+ ;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-80.use[1]!./node_modules/@vue/vue-loader-v15/lib/index.js??vue-loader-options!./packages/components/NBMessageDialog/src/index.vue?vue&type=script&lang=js
1444
+ //
1445
+ //
1446
+ //
1447
+ //
1448
+ //
1449
+ //
1450
+ //
1451
+ //
1452
+ //
1453
+ //
1454
+ //
1455
+ //
1456
+ //
1457
+ //
1458
+ //
1459
+ //
1460
+ //
1461
+ //
1462
+ //
1463
+ //
1464
+ //
1465
+ //
1466
+ //
1467
+ //
1468
+ //
1469
+ //
1470
+ //
1471
+ //
1472
+ //
1473
+ //
1474
+ //
1475
+ //
1476
+ //
1477
+ //
1478
+ //
1479
+ //
1480
+ //
1481
+
1482
+
1483
+ /* harmony default export */ var srcvue_type_script_lang_js = ({
1484
+ name: 'NBMessageDialog',
1485
+ components: {
1486
+ NBProgress: NBProgress["default"]
1487
+ },
1488
+ // 使用v-model即可
1489
+ model: {
1490
+ prop: 'visible',
1491
+ event: 'update'
1492
+ },
1493
+ props: {
1494
+ // 是否显示弹框
1495
+ visible: {
1496
+ type: Boolean,
1497
+ default: false
1498
+ },
1499
+ // 类型:info 提示,不显示图标 / success 成功 / warning 警告 / abnormal 异常 / error 失败 / progress 进度条
1500
+ type: {
1501
+ type: String,
1502
+ default: 'info',
1503
+ validator(value) {
1504
+ return ['info', 'success', 'warning', 'abnormal', 'error', 'progress'].includes(value);
1505
+ }
1506
+ },
1507
+ // 大小:small / medium
1508
+ size: {
1509
+ type: String,
1510
+ default: 'small',
1511
+ validator(value) {
1512
+ return ['small', 'medium'].includes(value);
1513
+ }
1514
+ },
1515
+ // 弹框是否居中
1516
+ dialogCenter: {
1517
+ type: Boolean,
1518
+ default: true
1519
+ },
1520
+ // 弹框标题
1521
+ title: {
1522
+ type: String,
1523
+ default: ''
1524
+ },
1525
+ // 消息正文内容(灰色字体)
1526
+ message: {
1527
+ type: String,
1528
+ default: ''
1529
+ },
1530
+ // 提示(绿色字体)
1531
+ tips: {
1532
+ type: String,
1533
+ default: ''
1534
+ },
1535
+ // 是否显示取消按钮
1536
+ showCancelButton: {
1537
+ type: Boolean,
1538
+ default: true
1539
+ },
1540
+ // 取消按钮的文本内容,默认取消
1541
+ cancelButtonText: {
1542
+ type: String,
1543
+ default: ''
1544
+ },
1545
+ // 取消按钮倒计时时间
1546
+ cancelButtonTime: {
1547
+ type: Number,
1548
+ default: -1
1549
+ },
1550
+ // 是否显示确定按钮
1551
+ showConfirmButton: {
1552
+ type: Boolean,
1553
+ default: true
1554
+ },
1555
+ // 确定按钮的文本内容,默认确定
1556
+ confirmButtonText: {
1557
+ type: String,
1558
+ default: ''
1559
+ },
1560
+ // 确定按钮倒计时时间
1561
+ confirmButtonTime: {
1562
+ type: Number,
1563
+ default: -1
1564
+ },
1565
+ // 确定按钮loading
1566
+ confirmButtonLoading: {
1567
+ type: Boolean,
1568
+ default: false
1569
+ },
1570
+ // 进度条完成时间,单位秒
1571
+ finishTime: {
1572
+ type: Number,
1573
+ default: 10
1574
+ },
1575
+ // 进度条百分比
1576
+ percentage: {
1577
+ type: Number,
1578
+ default: 0
1579
+ }
1580
+ },
1581
+ data() {
1582
+ return {
1583
+ cancelAutoTimer: null,
1584
+ cancelAutoTime: this.cancelButtonTime,
1585
+ confirmAutoTimer: null,
1586
+ confirmAutoTime: this.confirmButtonTime
1587
+ };
1588
+ },
1589
+ computed: {
1590
+ // 如果只显示确定按钮,那么确定按钮为朴素按钮
1591
+ confirmButtonPlain() {
1592
+ if (!this.showCancelButton && this.showConfirmButton) {
1593
+ return true;
1594
+ }
1595
+ return false;
1596
+ },
1597
+ // 有图标+标题+提示语
1598
+ isReduce() {
1599
+ return ['success', 'warning', 'abnormal', 'error'].includes(this.type) && this.title && (this.message || this.tips) ? 'nb-message-diaolog--reduce' : '';
1600
+ }
1601
+ },
1602
+ watch: {
1603
+ visible(val) {
1604
+ if (val && this.cancelButtonTime > -1) {
1605
+ this.startCancelButtonAutoTimer();
1606
+ }
1607
+ if (val && this.confirmButtonTime > -1) {
1608
+ this.startConfirmButtonAutoTimer();
1609
+ }
1610
+ }
1611
+ },
1612
+ beforeDestroy() {
1613
+ clearInterval(this.cancelAutoTimer);
1614
+ clearInterval(this.confirmAutoTimer);
1615
+ },
1616
+ methods: {
1617
+ startCancelButtonAutoTimer() {
1618
+ clearInterval(this.cancelAutoTimer);
1619
+ this.cancelAutoTime = this.cancelButtonTime;
1620
+ this.cancelAutoTimer = setInterval(() => {
1621
+ this.cancelAutoTime--;
1622
+ if (this.cancelAutoTime <= 0) {
1623
+ clearInterval(this.cancelAutoTimer);
1624
+ this.handleCancel();
1625
+ }
1626
+ }, 1000);
1627
+ },
1628
+ startConfirmButtonAutoTimer() {
1629
+ clearInterval(this.confirmAutoTimer);
1630
+ this.confirmAutoTime = this.confirmButtonTime;
1631
+ this.confirmAutoTimer = setInterval(() => {
1632
+ this.confirmAutoTime--;
1633
+ if (this.confirmAutoTime <= 0) {
1634
+ clearInterval(this.confirmAutoTimer);
1635
+ this.handleConfirm();
1636
+ }
1637
+ }, 1000);
1638
+ },
1639
+ // 取消
1640
+ handleCancel() {
1641
+ this.$emit('update', false);
1642
+ this.$emit('cancel');
1643
+ },
1644
+ // 确定
1645
+ handleConfirm() {
1646
+ this.$emit('update', false);
1647
+ this.$emit('confirm');
1648
+ },
1649
+ // 关闭弹框
1650
+ closedDialog() {
1651
+ clearInterval(this.cancelAutoTimer);
1652
+ clearInterval(this.confirmAutoTimer);
1653
+ this.$emit('closed');
1654
+ }
1655
+ }
1656
+ });
1657
+ ;// ./packages/components/NBMessageDialog/src/index.vue?vue&type=script&lang=js
1658
+ /* harmony default export */ var NBMessageDialog_srcvue_type_script_lang_js = (srcvue_type_script_lang_js);
1659
+ // EXTERNAL MODULE: ./node_modules/@vue/vue-loader-v15/lib/runtime/componentNormalizer.js
1660
+ var componentNormalizer = __webpack_require__(1656);
1661
+ ;// ./packages/components/NBMessageDialog/src/index.vue
1662
+
1663
+
1664
+
1665
+
1666
+
1667
+ /* normalize component */
1668
+ ;
1669
+ var component = (0,componentNormalizer/* default */.A)(
1670
+ NBMessageDialog_srcvue_type_script_lang_js,
1671
+ render,
1672
+ staticRenderFns,
1673
+ false,
1674
+ null,
1675
+ "abd09ece",
1676
+ null
1677
+
1678
+ )
1679
+
1680
+ /* harmony default export */ var src = (component.exports);
1681
+ ;// ./packages/components/NBMessageDialog/index.js
1682
+ /*
1683
+ * @Author: chenghuan.dong
1684
+ * @Date: 2024-11-12 11:27:05
1685
+ * @LastEditTime: 2024-11-12 14:38:34
1686
+ * @LastEditors: chenghuan.dong
1687
+ * @Description:
1688
+ * @FilePath: \nubomed-ui\packages\components\NBIcon\index.js
1689
+ */
1690
+
1691
+ src.install = function (Vue) {
1692
+ Vue.component(src.name, src);
1693
+ };
1694
+ /* harmony default export */ var NBMessageDialog = (src);
1695
+
1696
+ /***/ }),
1697
+
980
1698
  /***/ 9213:
981
1699
  /***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
982
1700
 
@@ -2160,11 +2878,14 @@ webpackContext.id = 1603;
2160
2878
  /***/ (function(module, __unused_webpack_exports, __webpack_require__) {
2161
2879
 
2162
2880
  var map = {
2881
+ "./NBBadge/index.js": 3134,
2163
2882
  "./NBCheckboxGroup/index.js": 2129,
2883
+ "./NBDialog/index.js": 4227,
2164
2884
  "./NBEmpty/index.js": 2846,
2165
2885
  "./NBFullscreenDialog/index.js": 1516,
2166
- "./NBHeader/index.js": 2229,
2886
+ "./NBHeader/index.js": 6523,
2167
2887
  "./NBIcon/index.js": 5408,
2888
+ "./NBMessageDialog/index.js": 3752,
2168
2889
  "./NBOutFooterDialog/index.js": 9213,
2169
2890
  "./NBPagination/index.js": 2407,
2170
2891
  "./NBProgress/index.js": 849,
@@ -2244,6 +2965,14 @@ module.exports = "
2244
2965
 
2245
2966
  /***/ }),
2246
2967
 
2968
+ /***/ 8508:
2969
+ /***/ (function(module) {
2970
+
2971
+ "use strict";
2972
+ module.exports = "";
2973
+
2974
+ /***/ }),
2975
+
2247
2976
  /***/ 6559:
2248
2977
  /***/ (function(module) {
2249
2978
 
@@ -2252,6 +2981,14 @@ module.exports = "
2252
2981
 
2253
2982
  /***/ }),
2254
2983
 
2984
+ /***/ 629:
2985
+ /***/ (function(module) {
2986
+
2987
+ "use strict";
2988
+ module.exports = "";
2989
+
2990
+ /***/ }),
2991
+
2255
2992
  /***/ 3906:
2256
2993
  /***/ (function(module) {
2257
2994
 
@@ -5171,7 +5908,7 @@ var iconfont = __webpack_require__(2170);
5171
5908
  /*
5172
5909
  * @Author: chenghuan.dong
5173
5910
  * @Date: 2024-11-08 17:23:47
5174
- * @LastEditTime: 2024-11-14 17:24:27
5911
+ * @LastEditTime: 2024-11-15 17:05:51
5175
5912
  * @LastEditors: chenghuan.dong
5176
5913
  * @Description: 主index.js导出全部组件
5177
5914
  * @FilePath: \nubomed-ui\packages\index.js
@@ -5199,7 +5936,7 @@ const install = function (Vue, options = {}) {
5199
5936
  if (install.installed) return;
5200
5937
  components.forEach(component => {
5201
5938
  const name = 'nb-' + camelToKebab(component.name.slice(2));
5202
- const installNames = ['nb-icon', 'nb-tag', 'nb-empty', 'nb-radio-group', 'nb-checkbox-group', 'nb-header', 'nb-summary-bar', 'nb-header', 'nb-tabs', 'nb-pagination', 'nb-progress', 'nb-fullscreen-dialog', 'nb-out-footer-dialog'];
5939
+ const installNames = ['nb-icon', 'nb-tag', 'nb-badge', 'nb-empty', 'nb-radio-group', 'nb-checkbox-group', 'nb-header', 'nb-summary-bar', 'nb-header', 'nb-tabs', 'nb-pagination', 'nb-progress', 'nb-dialog', 'nb-fullscreen-dialog', 'nb-out-footer-dialog', 'nb-message-dialog'];
5203
5940
  if (installNames.includes(name)) {
5204
5941
  console.log('%c' + '√ ' + name, 'color: #00A572;');
5205
5942
  } else {