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.
@@ -296,6 +296,90 @@ module.exports = function (i) {
296
296
 
297
297
  /***/ }),
298
298
 
299
+ /***/ 3250:
300
+ /***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
301
+
302
+ "use strict";
303
+ // ESM COMPAT FLAG
304
+ __webpack_require__.r(__webpack_exports__);
305
+
306
+ // EXPORTS
307
+ __webpack_require__.d(__webpack_exports__, {
308
+ "default": function() { return /* binding */ NBBadge; }
309
+ });
310
+
311
+ ;// ./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
312
+ 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()}
313
+ var staticRenderFns = []
314
+
315
+
316
+ ;// ./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!./packages/components/NBBadge/src/index.vue?vue&type=script&lang=js
317
+ //
318
+ //
319
+ //
320
+ //
321
+ //
322
+ //
323
+ //
324
+ //
325
+ //
326
+ //
327
+ //
328
+ //
329
+
330
+ /* harmony default export */ var srcvue_type_script_lang_js = ({
331
+ name: 'NBBadge',
332
+ props: {
333
+ // 类型,success/info/warning/danger,默认主题色状态
334
+ value: {
335
+ type: [String, Number],
336
+ default: ''
337
+ },
338
+ // 尺寸,large-大标签(高度36),默认小标签(高度32)
339
+ max: {
340
+ type: Number,
341
+ default: null
342
+ },
343
+ // 类型 primary / success / warning / danger / info
344
+ type: {
345
+ type: String,
346
+ default: 'danger'
347
+ }
348
+ }
349
+ });
350
+ ;// ./packages/components/NBBadge/src/index.vue?vue&type=script&lang=js
351
+ /* harmony default export */ var NBBadge_srcvue_type_script_lang_js = (srcvue_type_script_lang_js);
352
+ // EXTERNAL MODULE: ./node_modules/@vue/vue-loader-v15/lib/runtime/componentNormalizer.js
353
+ var componentNormalizer = __webpack_require__(1656);
354
+ ;// ./packages/components/NBBadge/src/index.vue
355
+
356
+
357
+
358
+
359
+
360
+ /* normalize component */
361
+ ;
362
+ var component = (0,componentNormalizer/* default */.A)(
363
+ NBBadge_srcvue_type_script_lang_js,
364
+ render,
365
+ staticRenderFns,
366
+ false,
367
+ null,
368
+ null,
369
+ null
370
+
371
+ )
372
+
373
+ /* harmony default export */ var src = (component.exports);
374
+ ;// ./packages/components/NBBadge/index.js
375
+
376
+ src.install = function (Vue) {
377
+ Vue.component(src.name, src);
378
+ };
379
+ /* harmony default export */ var NBBadge = (src);
380
+
381
+ /***/ }),
382
+
299
383
  /***/ 9070:
300
384
  /***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
301
385
 
@@ -452,6 +536,271 @@ src.install = function (Vue) {
452
536
 
453
537
  /***/ }),
454
538
 
539
+ /***/ 6368:
540
+ /***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
541
+
542
+ "use strict";
543
+ // ESM COMPAT FLAG
544
+ __webpack_require__.r(__webpack_exports__);
545
+
546
+ // EXPORTS
547
+ __webpack_require__.d(__webpack_exports__, {
548
+ "default": function() { return /* binding */ NBDialog; }
549
+ });
550
+
551
+ ;// ./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
552
+ 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)}
553
+ var staticRenderFns = []
554
+
555
+
556
+ ;// ./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!./packages/components/NBDialog/src/index.vue?vue&type=script&lang=js
557
+ //
558
+ //
559
+ //
560
+ //
561
+ //
562
+ //
563
+ //
564
+ //
565
+ //
566
+ //
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
+ /* harmony default export */ var srcvue_type_script_lang_js = ({
599
+ name: 'NBDialog',
600
+ // 使用v-model即可
601
+ model: {
602
+ prop: 'visible',
603
+ event: 'update'
604
+ },
605
+ props: {
606
+ // 是否显示弹框
607
+ visible: {
608
+ type: Boolean,
609
+ default: false
610
+ },
611
+ // 大小:'' 表示自定义尺寸 / small / medium / large
612
+ size: {
613
+ type: String,
614
+ default: '',
615
+ validator(value) {
616
+ return ['', 'small', 'medium', 'large'].includes(value);
617
+ }
618
+ },
619
+ // 弹框标题
620
+ title: {
621
+ type: String,
622
+ default: ''
623
+ },
624
+ // 是否显示关闭按钮
625
+ showClose: {
626
+ type: Boolean,
627
+ default: false
628
+ },
629
+ // 是否居中显示
630
+ center: {
631
+ type: Boolean,
632
+ default: false
633
+ },
634
+ // 弹框是否居中
635
+ dialogCenter: {
636
+ type: Boolean,
637
+ default: true
638
+ },
639
+ // 自定义样式
640
+ customClass: {
641
+ type: String,
642
+ default: ''
643
+ },
644
+ // 是否显示取消按钮
645
+ showCancelButton: {
646
+ type: Boolean,
647
+ default: true
648
+ },
649
+ // 取消按钮的文本内容,默认取消
650
+ cancelButtonText: {
651
+ type: String,
652
+ default: ''
653
+ },
654
+ // 取消按钮倒计时时间
655
+ cancelButtonTime: {
656
+ type: Number,
657
+ default: -1
658
+ },
659
+ // 是否显示确定按钮
660
+ showConfirmButton: {
661
+ type: Boolean,
662
+ default: true
663
+ },
664
+ // 确定按钮的文本内容,默认确定
665
+ confirmButtonText: {
666
+ type: String,
667
+ default: ''
668
+ },
669
+ // 确定按钮倒计时时间
670
+ confirmButtonTime: {
671
+ type: Number,
672
+ default: -1
673
+ },
674
+ // 内容是表单
675
+ form: {
676
+ type: [Boolean, String],
677
+ default: false
678
+ }
679
+ },
680
+ data() {
681
+ return {
682
+ cancelAutoTimer: null,
683
+ cancelAutoTime: this.cancelButtonTime,
684
+ confirmAutoTimer: null,
685
+ confirmAutoTime: this.confirmButtonTime
686
+ };
687
+ },
688
+ computed: {
689
+ // 如果只显示确定按钮,那么确定按钮plain显示镂空
690
+ confirmButtonPlain() {
691
+ if (!this.showCancelButton && this.showConfirmButton) {
692
+ return true;
693
+ }
694
+ return false;
695
+ },
696
+ // 表单自定义样式
697
+ dialogCustomClass() {
698
+ let cls = 'nb-dialog';
699
+ if (this.form) {
700
+ cls += ` nb-form-dialog`;
701
+ }
702
+ if (this.customClass) {
703
+ cls += this.customClass;
704
+ }
705
+ return cls;
706
+ }
707
+ },
708
+ watch: {
709
+ visible(val) {
710
+ if (val && this.cancelButtonTime > -1) {
711
+ this.startCancelButtonAutoTimer();
712
+ }
713
+ if (val && this.confirmButtonTime > -1) {
714
+ this.startConfirmButtonAutoTimer();
715
+ }
716
+ }
717
+ },
718
+ beforeDestroy() {
719
+ clearInterval(this.cancelAutoTimer);
720
+ clearInterval(this.confirmAutoTimer);
721
+ },
722
+ methods: {
723
+ startCancelButtonAutoTimer() {
724
+ clearInterval(this.cancelAutoTimer);
725
+ this.cancelAutoTime = this.cancelButtonTime;
726
+ this.cancelAutoTimer = setInterval(() => {
727
+ this.cancelAutoTime--;
728
+ if (this.cancelAutoTime <= 0) {
729
+ clearInterval(this.cancelAutoTimer);
730
+ this.handleCancel();
731
+ }
732
+ }, 1000);
733
+ },
734
+ startConfirmButtonAutoTimer() {
735
+ clearInterval(this.confirmAutoTimer);
736
+ this.confirmAutoTime = this.confirmButtonTime;
737
+ this.confirmAutoTimer = setInterval(() => {
738
+ this.confirmAutoTime--;
739
+ if (this.confirmAutoTime <= 0) {
740
+ clearInterval(this.confirmAutoTimer);
741
+ this.handleConfirm();
742
+ }
743
+ }, 1000);
744
+ },
745
+ // 取消
746
+ handleCancel() {
747
+ if (!this.$listeners['cancel']) {
748
+ this.$emit('update', false);
749
+ }
750
+ this.$emit('cancel');
751
+ },
752
+ // 确定
753
+ handleConfirm() {
754
+ if (!this.$listeners['confirm']) {
755
+ this.$emit('update', false);
756
+ }
757
+ this.$emit('confirm');
758
+ },
759
+ // 点击右上角关闭按钮
760
+ handleClose() {
761
+ this.$emit('update', false);
762
+ },
763
+ // 关闭弹框
764
+ closedDialog() {
765
+ clearInterval(this.cancelAutoTimer);
766
+ clearInterval(this.confirmAutoTimer);
767
+ this.$emit('closed');
768
+ }
769
+ }
770
+ });
771
+ ;// ./packages/components/NBDialog/src/index.vue?vue&type=script&lang=js
772
+ /* harmony default export */ var NBDialog_srcvue_type_script_lang_js = (srcvue_type_script_lang_js);
773
+ // EXTERNAL MODULE: ./node_modules/@vue/vue-loader-v15/lib/runtime/componentNormalizer.js
774
+ var componentNormalizer = __webpack_require__(1656);
775
+ ;// ./packages/components/NBDialog/src/index.vue
776
+
777
+
778
+
779
+
780
+
781
+ /* normalize component */
782
+ ;
783
+ var component = (0,componentNormalizer/* default */.A)(
784
+ NBDialog_srcvue_type_script_lang_js,
785
+ render,
786
+ staticRenderFns,
787
+ false,
788
+ null,
789
+ "d8856578",
790
+ null
791
+
792
+ )
793
+
794
+ /* harmony default export */ var src = (component.exports);
795
+ ;// ./packages/components/NBDialog/index.js
796
+
797
+ src.install = function (Vue) {
798
+ Vue.component(src.name, src);
799
+ };
800
+ /* harmony default export */ var NBDialog = (src);
801
+
802
+ /***/ }),
803
+
455
804
  /***/ 4400:
456
805
  /***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
457
806
 
@@ -676,7 +1025,7 @@ src.install = function (Vue) {
676
1025
 
677
1026
  /***/ }),
678
1027
 
679
- /***/ 1221:
1028
+ /***/ 1001:
680
1029
  /***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
681
1030
 
682
1031
  "use strict";
@@ -688,14 +1037,84 @@ __webpack_require__.d(__webpack_exports__, {
688
1037
  "default": function() { return /* binding */ NBHeader; }
689
1038
  });
690
1039
 
691
- ;// ./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
692
- 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()])}
1040
+ ;// ./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
1041
+ 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()])}
693
1042
  var staticRenderFns = []
694
1043
 
695
1044
 
1045
+ // EXTERNAL MODULE: ./node_modules/core-js/modules/esnext.iterator.constructor.js
1046
+ var esnext_iterator_constructor = __webpack_require__(8992);
1047
+ // EXTERNAL MODULE: ./node_modules/core-js/modules/esnext.iterator.for-each.js
1048
+ var esnext_iterator_for_each = __webpack_require__(3949);
696
1049
  // EXTERNAL MODULE: ./packages/components/NBIcon/index.js + 4 modules
697
1050
  var NBIcon = __webpack_require__(79);
1051
+ // EXTERNAL MODULE: ./packages/components/NBBadge/index.js + 4 modules
1052
+ var NBBadge = __webpack_require__(3250);
1053
+ ;// ./packages/utils/dom.js
1054
+ /*
1055
+ * @Author: chenghuan.dong
1056
+ * @Date: 2024-11-14 14:48:30
1057
+ * @LastEditTime: 2024-11-14 14:50:14
1058
+ * @LastEditors: chenghuan.dong
1059
+ * @Description:
1060
+ * @FilePath: \nubomed-ui\packages\utils\dom.js
1061
+ */
1062
+ /* istanbul ignore next */
1063
+ function addClass(el, cls) {
1064
+ if (!el) return;
1065
+ var curClass = el.className;
1066
+ var classes = (cls || '').split(' ');
1067
+ for (var i = 0, j = classes.length; i < j; i++) {
1068
+ var clsName = classes[i];
1069
+ if (!clsName) continue;
1070
+ if (el.classList) {
1071
+ el.classList.add(clsName);
1072
+ } else if (!hasClass(el, clsName)) {
1073
+ curClass += ' ' + clsName;
1074
+ }
1075
+ }
1076
+ if (!el.classList) {
1077
+ el.setAttribute('class', curClass);
1078
+ }
1079
+ }
1080
+
1081
+ /* istanbul ignore next */
1082
+ function removeClass(el, cls) {
1083
+ if (!el || !cls) return;
1084
+ var classes = cls.split(' ');
1085
+ var curClass = ' ' + el.className + ' ';
1086
+ for (var i = 0, j = classes.length; i < j; i++) {
1087
+ var clsName = classes[i];
1088
+ if (!clsName) continue;
1089
+ if (el.classList) {
1090
+ el.classList.remove(clsName);
1091
+ } else if (hasClass(el, clsName)) {
1092
+ curClass = curClass.replace(' ' + clsName + ' ', ' ');
1093
+ }
1094
+ }
1095
+ if (!el.classList) {
1096
+ el.setAttribute('class', trim(curClass));
1097
+ }
1098
+ }
1099
+
1100
+ /* istanbul ignore next */
1101
+ function hasClass(el, cls) {
1102
+ if (!el || !cls) return false;
1103
+ if (cls.indexOf(' ') !== -1) throw new Error('className should not contain space.');
1104
+ if (el.classList) {
1105
+ return el.classList.contains(cls);
1106
+ } else {
1107
+ return (' ' + el.className + ' ').indexOf(' ' + cls + ' ') > -1;
1108
+ }
1109
+ }
1110
+
1111
+ /* istanbul ignore next */
1112
+ const trim = function (string) {
1113
+ return (string || '').replace(/^[\s\uFEFF]+|[\s\uFEFF]+$/g, '');
1114
+ };
698
1115
  ;// ./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!./packages/components/NBHeader/src/index.vue?vue&type=script&lang=js
1116
+
1117
+
699
1118
  //
700
1119
  //
701
1120
  //
@@ -747,13 +1166,15 @@ var NBIcon = __webpack_require__(79);
747
1166
  //
748
1167
  //
749
1168
  //
750
- //
1169
+
1170
+
751
1171
 
752
1172
 
753
1173
  /* harmony default export */ var srcvue_type_script_lang_js = ({
754
1174
  name: 'NBHeader',
755
1175
  components: {
756
- NBIcon: NBIcon["default"]
1176
+ NBIcon: NBIcon["default"],
1177
+ NBBadge: NBBadge["default"]
757
1178
  },
758
1179
  props: {
759
1180
  // 是否显示返回
@@ -819,7 +1240,28 @@ var NBIcon = __webpack_require__(79);
819
1240
  data() {
820
1241
  return {};
821
1242
  },
822
- computed: {},
1243
+ mounted() {
1244
+ // 缩小tab的字体
1245
+ if (this.$refs.refNBHeaderTabs) {
1246
+ const tabs = this.$refs.refNBHeaderTabs.querySelectorAll('.nb-header__tab');
1247
+ tabs.forEach(x => {
1248
+ const el = x.querySelector('.nb-header__tab__text>span');
1249
+ if (el) {
1250
+ addClass(x.querySelector('.nb-header__tab__text'), `nb-header__tab__text--${parseInt(el.clientHeight / 42)}`);
1251
+ }
1252
+ });
1253
+ }
1254
+
1255
+ // 缩小右侧按钮大小
1256
+ if (this.$refs.refNBHeaderRight && this.$refs.refNBHeaderTabs) {
1257
+ const rightButton = this.$refs.refNBHeaderRight.querySelectorAll('.nb-header__btn');
1258
+ rightButton.forEach(x => {
1259
+ if (x && x.clientWidth > 220) {
1260
+ addClass(x, 'nb-header__btn--small');
1261
+ }
1262
+ });
1263
+ }
1264
+ },
823
1265
  methods: {
824
1266
  // 返回
825
1267
  handleBack() {
@@ -870,7 +1312,7 @@ var component = (0,componentNormalizer/* default */.A)(
870
1312
  staticRenderFns,
871
1313
  false,
872
1314
  null,
873
- "e09e670c",
1315
+ "8de13f1a",
874
1316
  null
875
1317
 
876
1318
  )
@@ -967,6 +1409,282 @@ src.install = function (Vue) {
967
1409
 
968
1410
  /***/ }),
969
1411
 
1412
+ /***/ 9820:
1413
+ /***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
1414
+
1415
+ "use strict";
1416
+ // ESM COMPAT FLAG
1417
+ __webpack_require__.r(__webpack_exports__);
1418
+
1419
+ // EXPORTS
1420
+ __webpack_require__.d(__webpack_exports__, {
1421
+ "default": function() { return /* binding */ NBMessageDialog; }
1422
+ });
1423
+
1424
+ ;// ./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
1425
+ 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)}
1426
+ var staticRenderFns = []
1427
+
1428
+
1429
+ ;// ./packages/components/NBMessageDialog/src/index.vue?vue&type=template&id=abd09ece&scoped=true
1430
+
1431
+ // EXTERNAL MODULE: ./packages/components/NBProgress/index.js + 5 modules
1432
+ var NBProgress = __webpack_require__(2639);
1433
+ ;// ./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!./packages/components/NBMessageDialog/src/index.vue?vue&type=script&lang=js
1434
+ //
1435
+ //
1436
+ //
1437
+ //
1438
+ //
1439
+ //
1440
+ //
1441
+ //
1442
+ //
1443
+ //
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
+ /* harmony default export */ var srcvue_type_script_lang_js = ({
1474
+ name: 'NBMessageDialog',
1475
+ components: {
1476
+ NBProgress: NBProgress["default"]
1477
+ },
1478
+ // 使用v-model即可
1479
+ model: {
1480
+ prop: 'visible',
1481
+ event: 'update'
1482
+ },
1483
+ props: {
1484
+ // 是否显示弹框
1485
+ visible: {
1486
+ type: Boolean,
1487
+ default: false
1488
+ },
1489
+ // 类型:info 提示,不显示图标 / success 成功 / warning 警告 / abnormal 异常 / error 失败 / progress 进度条
1490
+ type: {
1491
+ type: String,
1492
+ default: 'info',
1493
+ validator(value) {
1494
+ return ['info', 'success', 'warning', 'abnormal', 'error', 'progress'].includes(value);
1495
+ }
1496
+ },
1497
+ // 大小:small / medium
1498
+ size: {
1499
+ type: String,
1500
+ default: 'small',
1501
+ validator(value) {
1502
+ return ['small', 'medium'].includes(value);
1503
+ }
1504
+ },
1505
+ // 弹框是否居中
1506
+ dialogCenter: {
1507
+ type: Boolean,
1508
+ default: true
1509
+ },
1510
+ // 弹框标题
1511
+ title: {
1512
+ type: String,
1513
+ default: ''
1514
+ },
1515
+ // 消息正文内容(灰色字体)
1516
+ message: {
1517
+ type: String,
1518
+ default: ''
1519
+ },
1520
+ // 提示(绿色字体)
1521
+ tips: {
1522
+ type: String,
1523
+ default: ''
1524
+ },
1525
+ // 是否显示取消按钮
1526
+ showCancelButton: {
1527
+ type: Boolean,
1528
+ default: true
1529
+ },
1530
+ // 取消按钮的文本内容,默认取消
1531
+ cancelButtonText: {
1532
+ type: String,
1533
+ default: ''
1534
+ },
1535
+ // 取消按钮倒计时时间
1536
+ cancelButtonTime: {
1537
+ type: Number,
1538
+ default: -1
1539
+ },
1540
+ // 是否显示确定按钮
1541
+ showConfirmButton: {
1542
+ type: Boolean,
1543
+ default: true
1544
+ },
1545
+ // 确定按钮的文本内容,默认确定
1546
+ confirmButtonText: {
1547
+ type: String,
1548
+ default: ''
1549
+ },
1550
+ // 确定按钮倒计时时间
1551
+ confirmButtonTime: {
1552
+ type: Number,
1553
+ default: -1
1554
+ },
1555
+ // 确定按钮loading
1556
+ confirmButtonLoading: {
1557
+ type: Boolean,
1558
+ default: false
1559
+ },
1560
+ // 进度条完成时间,单位秒
1561
+ finishTime: {
1562
+ type: Number,
1563
+ default: 10
1564
+ },
1565
+ // 进度条百分比
1566
+ percentage: {
1567
+ type: Number,
1568
+ default: 0
1569
+ }
1570
+ },
1571
+ data() {
1572
+ return {
1573
+ cancelAutoTimer: null,
1574
+ cancelAutoTime: this.cancelButtonTime,
1575
+ confirmAutoTimer: null,
1576
+ confirmAutoTime: this.confirmButtonTime
1577
+ };
1578
+ },
1579
+ computed: {
1580
+ // 如果只显示确定按钮,那么确定按钮为朴素按钮
1581
+ confirmButtonPlain() {
1582
+ if (!this.showCancelButton && this.showConfirmButton) {
1583
+ return true;
1584
+ }
1585
+ return false;
1586
+ },
1587
+ // 有图标+标题+提示语
1588
+ isReduce() {
1589
+ return ['success', 'warning', 'abnormal', 'error'].includes(this.type) && this.title && (this.message || this.tips) ? 'nb-message-diaolog--reduce' : '';
1590
+ }
1591
+ },
1592
+ watch: {
1593
+ visible(val) {
1594
+ if (val && this.cancelButtonTime > -1) {
1595
+ this.startCancelButtonAutoTimer();
1596
+ }
1597
+ if (val && this.confirmButtonTime > -1) {
1598
+ this.startConfirmButtonAutoTimer();
1599
+ }
1600
+ }
1601
+ },
1602
+ beforeDestroy() {
1603
+ clearInterval(this.cancelAutoTimer);
1604
+ clearInterval(this.confirmAutoTimer);
1605
+ },
1606
+ methods: {
1607
+ startCancelButtonAutoTimer() {
1608
+ clearInterval(this.cancelAutoTimer);
1609
+ this.cancelAutoTime = this.cancelButtonTime;
1610
+ this.cancelAutoTimer = setInterval(() => {
1611
+ this.cancelAutoTime--;
1612
+ if (this.cancelAutoTime <= 0) {
1613
+ clearInterval(this.cancelAutoTimer);
1614
+ this.handleCancel();
1615
+ }
1616
+ }, 1000);
1617
+ },
1618
+ startConfirmButtonAutoTimer() {
1619
+ clearInterval(this.confirmAutoTimer);
1620
+ this.confirmAutoTime = this.confirmButtonTime;
1621
+ this.confirmAutoTimer = setInterval(() => {
1622
+ this.confirmAutoTime--;
1623
+ if (this.confirmAutoTime <= 0) {
1624
+ clearInterval(this.confirmAutoTimer);
1625
+ this.handleConfirm();
1626
+ }
1627
+ }, 1000);
1628
+ },
1629
+ // 取消
1630
+ handleCancel() {
1631
+ this.$emit('update', false);
1632
+ this.$emit('cancel');
1633
+ },
1634
+ // 确定
1635
+ handleConfirm() {
1636
+ this.$emit('update', false);
1637
+ this.$emit('confirm');
1638
+ },
1639
+ // 关闭弹框
1640
+ closedDialog() {
1641
+ clearInterval(this.cancelAutoTimer);
1642
+ clearInterval(this.confirmAutoTimer);
1643
+ this.$emit('closed');
1644
+ }
1645
+ }
1646
+ });
1647
+ ;// ./packages/components/NBMessageDialog/src/index.vue?vue&type=script&lang=js
1648
+ /* harmony default export */ var NBMessageDialog_srcvue_type_script_lang_js = (srcvue_type_script_lang_js);
1649
+ // EXTERNAL MODULE: ./node_modules/@vue/vue-loader-v15/lib/runtime/componentNormalizer.js
1650
+ var componentNormalizer = __webpack_require__(1656);
1651
+ ;// ./packages/components/NBMessageDialog/src/index.vue
1652
+
1653
+
1654
+
1655
+
1656
+
1657
+ /* normalize component */
1658
+ ;
1659
+ var component = (0,componentNormalizer/* default */.A)(
1660
+ NBMessageDialog_srcvue_type_script_lang_js,
1661
+ render,
1662
+ staticRenderFns,
1663
+ false,
1664
+ null,
1665
+ "abd09ece",
1666
+ null
1667
+
1668
+ )
1669
+
1670
+ /* harmony default export */ var src = (component.exports);
1671
+ ;// ./packages/components/NBMessageDialog/index.js
1672
+ /*
1673
+ * @Author: chenghuan.dong
1674
+ * @Date: 2024-11-12 11:27:05
1675
+ * @LastEditTime: 2024-11-12 14:38:34
1676
+ * @LastEditors: chenghuan.dong
1677
+ * @Description:
1678
+ * @FilePath: \nubomed-ui\packages\components\NBIcon\index.js
1679
+ */
1680
+
1681
+ src.install = function (Vue) {
1682
+ Vue.component(src.name, src);
1683
+ };
1684
+ /* harmony default export */ var NBMessageDialog = (src);
1685
+
1686
+ /***/ }),
1687
+
970
1688
  /***/ 5592:
971
1689
  /***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
972
1690
 
@@ -2150,11 +2868,14 @@ webpackContext.id = 1603;
2150
2868
  /***/ (function(module, __unused_webpack_exports, __webpack_require__) {
2151
2869
 
2152
2870
  var map = {
2871
+ "./NBBadge/index.js": 3250,
2153
2872
  "./NBCheckboxGroup/index.js": 9070,
2873
+ "./NBDialog/index.js": 6368,
2154
2874
  "./NBEmpty/index.js": 4400,
2155
2875
  "./NBFullscreenDialog/index.js": 4531,
2156
- "./NBHeader/index.js": 1221,
2876
+ "./NBHeader/index.js": 1001,
2157
2877
  "./NBIcon/index.js": 79,
2878
+ "./NBMessageDialog/index.js": 9820,
2158
2879
  "./NBOutFooterDialog/index.js": 5592,
2159
2880
  "./NBPagination/index.js": 8369,
2160
2881
  "./NBProgress/index.js": 2639,
@@ -2234,6 +2955,14 @@ module.exports = "
2234
2955
 
2235
2956
  /***/ }),
2236
2957
 
2958
+ /***/ 8508:
2959
+ /***/ (function(module) {
2960
+
2961
+ "use strict";
2962
+ module.exports = "";
2963
+
2964
+ /***/ }),
2965
+
2237
2966
  /***/ 6559:
2238
2967
  /***/ (function(module) {
2239
2968
 
@@ -2242,6 +2971,14 @@ module.exports = "
2242
2971
 
2243
2972
  /***/ }),
2244
2973
 
2974
+ /***/ 629:
2975
+ /***/ (function(module) {
2976
+
2977
+ "use strict";
2978
+ module.exports = "";
2979
+
2980
+ /***/ }),
2981
+
2245
2982
  /***/ 3906:
2246
2983
  /***/ (function(module) {
2247
2984
 
@@ -5161,7 +5898,7 @@ var iconfont = __webpack_require__(1970);
5161
5898
  /*
5162
5899
  * @Author: chenghuan.dong
5163
5900
  * @Date: 2024-11-08 17:23:47
5164
- * @LastEditTime: 2024-11-14 17:24:27
5901
+ * @LastEditTime: 2024-11-15 17:05:51
5165
5902
  * @LastEditors: chenghuan.dong
5166
5903
  * @Description: 主index.js导出全部组件
5167
5904
  * @FilePath: \nubomed-ui\packages\index.js
@@ -5189,7 +5926,7 @@ const install = function (Vue, options = {}) {
5189
5926
  if (install.installed) return;
5190
5927
  components.forEach(component => {
5191
5928
  const name = 'nb-' + camelToKebab(component.name.slice(2));
5192
- 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'];
5929
+ 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'];
5193
5930
  if (installNames.includes(name)) {
5194
5931
  console.log('%c' + '√ ' + name, 'color: #00A572;');
5195
5932
  } else {