nubomed-ui 2.0.178 → 2.0.180

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.
package/nubomed-ui.umd.js CHANGED
@@ -4577,7 +4577,7 @@ src.install = function (Vue) {
4577
4577
 
4578
4578
  /***/ }),
4579
4579
 
4580
- /***/ 4134:
4580
+ /***/ 4125:
4581
4581
  /***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
4582
4582
 
4583
4583
  "use strict";
@@ -4589,8 +4589,8 @@ __webpack_require__.d(__webpack_exports__, {
4589
4589
  "default": function() { return /* binding */ NBInputFilter; }
4590
4590
  });
4591
4591
 
4592
- ;// ./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/@vue/cli-service/lib/config/vue-loader-v15-resolve-compat/vue-loader.js??vue-loader-options!./packages/components/NBInputFilter/src/index.vue?vue&type=template&id=07ebb246&scoped=true
4593
- var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{directives:[{name:"loading",rawName:"v-loading",value:(_vm.loading),expression:"loading"}],staticClass:"nb-input-filter",class:[_vm.isFocus ? 'is-focus' : '', _vm.size]},[_c('el-input',{ref:"input",attrs:{"size":_vm.size,"clearable":_vm.clearable,"disabled":_vm.disabled,"placeholder":_vm.placeholder},on:{"input":_vm.onInput,"focus":_vm.onInputFocus,"blur":_vm.onInputBlur,"clear":_vm.onInputClear},model:{value:(_vm.inputValue),callback:function ($$v) {_vm.inputValue=$$v},expression:"inputValue"}}),_c('el-popover',{attrs:{"placement":"bottom-start","trigger":"manual","popper-class":("nb-select-filter-popover nb-select-filter-popover--" + _vm.size)},model:{value:(_vm.visible),callback:function ($$v) {_vm.visible=$$v},expression:"visible"}},[(_vm.isRemote)?_c('ul',{staticClass:"nb-select-filter-options"},[(_vm.options.length === 0)?_c('li',{staticClass:"null"},[_vm._v(_vm._s(_vm.t('nb.msg.noData')))]):_vm._e(),_vm._l((_vm.options),function(item,index){return _c('li',{key:index,class:_vm.optionClass(item),on:{"click":function($event){$event.stopPropagation();return _vm.onChecked(item)}}},[_vm._v(" "+_vm._s(item[_vm.optionProps.label])+" ")])})],2):_c('ul',{staticClass:"nb-select-filter-options"},[(_vm.showOptions.length === 0)?_c('li',{staticClass:"null"},[_vm._v(_vm._s(_vm.t('nb.msg.noData')))]):_vm._e(),_vm._l((_vm.showOptions),function(item,index){return _c('li',{key:index,class:_vm.optionClass(item),on:{"click":function($event){$event.stopPropagation();return _vm.onChecked(item)}}},[_vm._v(" "+_vm._s(item[_vm.optionProps.label])+" ")])})],2)])],1)}
4592
+ ;// ./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/@vue/cli-service/lib/config/vue-loader-v15-resolve-compat/vue-loader.js??vue-loader-options!./packages/components/NBInputFilter/src/index.vue?vue&type=template&id=3067983c&scoped=true
4593
+ var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{directives:[{name:"loading",rawName:"v-loading",value:(_vm.loading),expression:"loading"}],staticClass:"nb-input-filter",class:[_vm.isFocus ? 'is-focus' : '', _vm.size]},[_c('el-input',{ref:"input",attrs:{"size":_vm.size,"clearable":_vm.clearable,"disabled":_vm.disabled,"placeholder":_vm.placeholder},on:{"input":_vm.onInput,"focus":_vm.onInputFocus,"blur":_vm.onInputBlur,"clear":_vm.onInputClear},model:{value:(_vm.inputValue),callback:function ($$v) {_vm.inputValue=$$v},expression:"inputValue"}}),_c('el-popover',{attrs:{"placement":"bottom-start","trigger":"manual","popper-class":("nb-select-filter-popover nb-select-filter-popover--" + _vm.size)},model:{value:(_vm.visible),callback:function ($$v) {_vm.visible=$$v},expression:"visible"}},[(_vm.isRemote)?_c('ul',{staticClass:"nb-select-filter-options"},[(_vm.options.length === 0)?_c('li',{staticClass:"null"},[_vm._v(_vm._s(_vm.emptyText))]):_vm._e(),_vm._l((_vm.options),function(item,index){return _c('li',{key:index,class:_vm.optionClass(item),on:{"click":function($event){$event.stopPropagation();return _vm.onChecked(item)}}},[_vm._v(" "+_vm._s(item[_vm.optionProps.label])+" ")])})],2):_c('ul',{staticClass:"nb-select-filter-options"},[(_vm.showOptions.length === 0)?_c('li',{staticClass:"null"},[_vm._v(_vm._s(_vm.emptyText))]):_vm._e(),_vm._l((_vm.showOptions),function(item,index){return _c('li',{key:index,class:_vm.optionClass(item),on:{"click":function($event){$event.stopPropagation();return _vm.onChecked(item)}}},[_vm._v(" "+_vm._s(item[_vm.optionProps.label])+" ")])})],2)])],1)}
4594
4594
  var staticRenderFns = []
4595
4595
 
4596
4596
 
@@ -4598,8 +4598,6 @@ var staticRenderFns = []
4598
4598
  var esnext_iterator_constructor = __webpack_require__(8992);
4599
4599
  // EXTERNAL MODULE: ./node_modules/core-js/modules/esnext.iterator.filter.js
4600
4600
  var esnext_iterator_filter = __webpack_require__(4520);
4601
- // EXTERNAL MODULE: ./packages/mixins/index.js
4602
- var mixins = __webpack_require__(869);
4603
4601
  // EXTERNAL MODULE: ./packages/utils/util.js
4604
4602
  var util = __webpack_require__(5594);
4605
4603
  ;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/@vue/cli-plugin-babel/node_modules/babel-loader/lib/index.js??clonedRuleSet-80.use[1]!./node_modules/@vue/cli-service/lib/config/vue-loader-v15-resolve-compat/vue-loader.js??vue-loader-options!./packages/components/NBInputFilter/src/index.vue?vue&type=script&lang=js
@@ -4653,10 +4651,8 @@ var util = __webpack_require__(5594);
4653
4651
  //
4654
4652
 
4655
4653
 
4656
-
4657
4654
  /* harmony default export */ var srcvue_type_script_lang_js = ({
4658
4655
  name: 'NBInputFilter',
4659
- mixins: [mixins/* default */.A],
4660
4656
  model: {
4661
4657
  prop: 'modelValue',
4662
4658
  event: 'input'
@@ -4686,6 +4682,11 @@ var util = __webpack_require__(5594);
4686
4682
  return {};
4687
4683
  }
4688
4684
  },
4685
+ // 无数据时显示的文字
4686
+ emptyText: {
4687
+ type: String,
4688
+ default: ''
4689
+ },
4689
4690
  // 大小:不指定:400*72px | mini: 184*48px | small:240*56px | medium:280*64px | large: 480*80px
4690
4691
  size: {
4691
4692
  type: String,
@@ -4828,7 +4829,7 @@ var component = (0,componentNormalizer/* default */.A)(
4828
4829
  staticRenderFns,
4829
4830
  false,
4830
4831
  null,
4831
- "07ebb246",
4832
+ "3067983c",
4832
4833
  null
4833
4834
 
4834
4835
  )
@@ -18989,7 +18990,7 @@ src.install = function (Vue) {
18989
18990
 
18990
18991
  /***/ }),
18991
18992
 
18992
- /***/ 3663:
18993
+ /***/ 7108:
18993
18994
  /***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
18994
18995
 
18995
18996
  "use strict";
@@ -19001,15 +19002,19 @@ __webpack_require__.d(__webpack_exports__, {
19001
19002
  "default": function() { return /* binding */ NBNoticeMarquee; }
19002
19003
  });
19003
19004
 
19004
- ;// ./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/@vue/cli-service/lib/config/vue-loader-v15-resolve-compat/vue-loader.js??vue-loader-options!./packages/components/NBNoticeMarquee/src/index.vue?vue&type=template&id=7642bdfe&scoped=true
19005
- var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"nb-notice-marquee"},[_c('nb-icon',{attrs:{"icon":"voice-filled"}}),_c('div',{staticClass:"nb-notice-marquee__wrapper"},[_vm._t("default",[_c('div',{staticClass:"nb-notice-marquee__text",class:_vm.animationDuration === 0 ? 'hide-animation' : '',style:(("animation-duration: " + _vm.animationDuration + "s")),domProps:{"innerHTML":_vm._s(_vm.textHtml)},on:{"click":function($event){$event.stopPropagation();return _vm.onClick($event)}}})])],2)],1)}
19005
+ ;// ./node_modules/@vue/vue-loader-v15/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/@vue/cli-service/lib/config/vue-loader-v15-resolve-compat/vue-loader.js??vue-loader-options!./packages/components/NBNoticeMarquee/src/index.vue?vue&type=template&id=80ce6306&scoped=true
19006
+ var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"nb-notice-marquee"},[_c('nb-icon',{attrs:{"icon":"voice-filled"}}),_c('div',{ref:"container",staticClass:"nb-notice-marquee__wrapper"},[_c('div',{ref:"content",staticClass:"nb-notice-marquee__text",style:(_vm.contentStyle),on:{"mouseenter":_vm.pauseScroll,"mouseleave":_vm.resumeScroll}},[_vm._l((_vm.list),function(item,index){return [_c('span',{key:index,staticClass:"nb-notice-marquee__item",on:{"click":function($event){$event.stopPropagation();return _vm.clickItem(item)}}},[_vm._v(" "+_vm._s(item.msg)+" ")])]}),(_vm.shouldScroll)?[_vm._l((_vm.list),function(item,index){return [_c('span',{key:index + '_copy',staticClass:"nb-notice-marquee__item",on:{"click":function($event){$event.stopPropagation();return _vm.clickItem(item)}}},[_vm._v(" "+_vm._s(item.msg)+" ")])]})]:_vm._e()],2)])],1)}
19006
19007
  var staticRenderFns = []
19007
19008
 
19008
19009
 
19009
- // EXTERNAL MODULE: ./node_modules/core-js/modules/esnext.iterator.map.js
19010
- var esnext_iterator_map = __webpack_require__(1454);
19011
19010
  ;// ./node_modules/thread-loader/dist/cjs.js!./node_modules/@vue/cli-plugin-babel/node_modules/babel-loader/lib/index.js??clonedRuleSet-80.use[1]!./node_modules/@vue/cli-service/lib/config/vue-loader-v15-resolve-compat/vue-loader.js??vue-loader-options!./packages/components/NBNoticeMarquee/src/index.vue?vue&type=script&lang=js
19012
-
19011
+ //
19012
+ //
19013
+ //
19014
+ //
19015
+ //
19016
+ //
19017
+ //
19013
19018
  //
19014
19019
  //
19015
19020
  //
@@ -19039,71 +19044,123 @@ var esnext_iterator_map = __webpack_require__(1454);
19039
19044
  /* harmony default export */ var srcvue_type_script_lang_js = ({
19040
19045
  name: 'NBNoticeMarquee',
19041
19046
  props: {
19042
- // 显示的文本
19043
- text: {
19044
- type: String,
19045
- default: ''
19046
- },
19047
- // 消息列表
19048
- // path 消息中心路径
19049
- // msg 消息内容
19047
+ // 消息列表: path 消息中心路径,msg 消息内容
19050
19048
  list: {
19051
19049
  type: Array,
19052
19050
  default: () => {
19053
19051
  return [];
19054
19052
  }
19055
19053
  },
19054
+ // 鼠标移入是否需要暂停
19055
+ needPause: {
19056
+ type: Boolean,
19057
+ default: false
19058
+ },
19056
19059
  // 每一帧滚动距离
19057
- split: {
19060
+ scrollSpeed: {
19058
19061
  type: Number,
19059
- default: 4.5
19062
+ default: 50,
19063
+ // 像素/秒
19064
+ validator: value => value > 0
19060
19065
  }
19061
19066
  },
19062
19067
  data() {
19063
19068
  return {
19064
- animationDuration: 0
19069
+ shouldScroll: false,
19070
+ contentWidth: 0,
19071
+ containerWidth: 0,
19072
+ animationDuration: 0,
19073
+ isPaused: false
19065
19074
  };
19066
19075
  },
19067
19076
  computed: {
19068
19077
  len() {
19069
19078
  return this.list.length;
19070
19079
  },
19071
- textHtml() {
19072
- return this.text || this.list.map(v => {
19073
- return `<span path="${v.path}">${v.msg}</span>`;
19074
- }).join(' ');
19080
+ contentStyle() {
19081
+ if (!this.shouldScroll) return {};
19082
+ return {
19083
+ animation: `scroll ${this.animationDuration}s linear infinite`,
19084
+ animationPlayState: this.isPaused ? 'paused' : 'running'
19085
+ };
19075
19086
  }
19076
19087
  },
19077
19088
  watch: {
19078
19089
  len() {
19079
19090
  // 计算动画时间
19080
- this.calcAnimationDuration();
19091
+ this.checkScroll();
19081
19092
  }
19082
19093
  },
19083
19094
  mounted() {
19084
19095
  // 计算动画时间
19085
- this.calcAnimationDuration();
19096
+ this.checkScroll();
19097
+ window.addEventListener('resize', this.handleResize);
19098
+ },
19099
+ beforeDestroy() {
19100
+ this.cancelAnimationFrame();
19101
+ window.removeEventListener('resize', this.handleResize);
19086
19102
  },
19087
19103
  methods: {
19104
+ clickItem(item) {
19105
+ this.$emit('click-menu', item.path, item);
19106
+ },
19088
19107
  // 计算动画时间
19089
- calcAnimationDuration() {
19108
+ checkScroll() {
19090
19109
  this.$nextTick(() => {
19091
- if (document.querySelector('.nb-notice-marquee__wrapper') && document.querySelector('.nb-notice-marquee__wrapper .nb-notice-marquee__text')) {
19092
- const wrapWidth = document.querySelector('.nb-notice-marquee__wrapper').offsetWidth;
19093
- const msgWidth = document.querySelector('.nb-notice-marquee__wrapper .nb-notice-marquee__text').offsetWidth;
19094
- // 如果当前文字溢出则开启滚动
19095
- if (wrapWidth < msgWidth) {
19096
- // 溢出
19097
- this.animationDuration = this.list.length * this.split;
19098
- } else {
19099
- this.animationDuration = 0;
19100
- }
19110
+ this.containerWidth = this.$refs.container.offsetWidth; // 容器宽度
19111
+ this.contentWidth = this.$refs.content.scrollWidth / (this.shouldScroll ? 2 : 1); // 滚动内容宽度
19112
+
19113
+ // 当前文字溢出则开启滚动
19114
+ this.shouldScroll = this.contentWidth > this.containerWidth;
19115
+ if (this.shouldScroll) {
19116
+ this.animationDuration = this.contentWidth / this.scrollSpeed;
19117
+ this.addAnimationStyle();
19101
19118
  }
19102
19119
  });
19103
19120
  },
19104
- onClick(e) {
19105
- const path = e && e.target && e.target.getAttribute('path');
19106
- this.$emit('click-menu', path, e);
19121
+ addAnimationStyle() {
19122
+ // 移除旧的样式
19123
+ const oldStyle = document.getElementById('news-scroller-style');
19124
+ if (oldStyle) oldStyle.remove();
19125
+
19126
+ // 添加新的样式
19127
+ const style = document.createElement('style');
19128
+ style.id = 'news-scroller-style';
19129
+ style.innerHTML = `
19130
+ @keyframes scroll {
19131
+ 0% { transform: translateX(0); }
19132
+ 100% { transform: translateX(-${this.contentWidth}px); }
19133
+ }
19134
+ `;
19135
+ document.head.appendChild(style);
19136
+ },
19137
+ // 暂停滚动
19138
+ pauseScroll() {
19139
+ if (this.shouldScroll && this.needPause) {
19140
+ this.isPaused = true;
19141
+ }
19142
+ },
19143
+ // 恢复滚动
19144
+ resumeScroll() {
19145
+ if (this.shouldScroll && this.needPause) {
19146
+ this.isPaused = false;
19147
+ }
19148
+ },
19149
+ // 处理窗口大小变化
19150
+ handleResize() {
19151
+ // 1. 先取消之前未执行的动画帧
19152
+ this.cancelAnimationFrame();
19153
+ // 2. 请求新的动画帧
19154
+ this.requestId = requestAnimationFrame(() => {
19155
+ // 3. 在浏览器准备好绘制下一帧时执行检测
19156
+ this.checkScroll();
19157
+ });
19158
+ },
19159
+ // 取消动画帧
19160
+ cancelAnimationFrame() {
19161
+ if (this.requestId) {
19162
+ cancelAnimationFrame(this.requestId);
19163
+ }
19107
19164
  }
19108
19165
  }
19109
19166
  });
@@ -19125,7 +19182,7 @@ var component = (0,componentNormalizer/* default */.A)(
19125
19182
  staticRenderFns,
19126
19183
  false,
19127
19184
  null,
19128
- "7642bdfe",
19185
+ "80ce6306",
19129
19186
  null
19130
19187
 
19131
19188
  )
@@ -23695,7 +23752,7 @@ var map = {
23695
23752
  "./NBGroupListItem/index.js": 8696,
23696
23753
  "./NBHeader/index.js": 8140,
23697
23754
  "./NBIcon/index.js": 4865,
23698
- "./NBInputFilter/index.js": 4134,
23755
+ "./NBInputFilter/index.js": 4125,
23699
23756
  "./NBInputGroup/index.js": 38,
23700
23757
  "./NBInputNumber/index.js": 7698,
23701
23758
  "./NBInputTime/index.js": 640,
@@ -23708,7 +23765,7 @@ var map = {
23708
23765
  "./NBMessageDialog/index.js": 2133,
23709
23766
  "./NBNameSpecCard/index.js": 7245,
23710
23767
  "./NBNameToggleCard/index.js": 7764,
23711
- "./NBNoticeMarquee/index.js": 3663,
23768
+ "./NBNoticeMarquee/index.js": 7108,
23712
23769
  "./NBOutFooterDialog/index.js": 7056,
23713
23770
  "./NBPagination/index.js": 8863,
23714
23771
  "./NBPatientCard/index.js": 3874,
@@ -26699,7 +26756,7 @@ var esnext_iterator_constructor = __webpack_require__(8992);
26699
26756
  // EXTERNAL MODULE: ./node_modules/core-js/modules/esnext.iterator.for-each.js
26700
26757
  var esnext_iterator_for_each = __webpack_require__(3949);
26701
26758
  ;// ./package.json
26702
- var package_namespaceObject = {"rE":"2.0.178"};
26759
+ var package_namespaceObject = {"rE":"2.0.180"};
26703
26760
  ;// ./packages/utils/convert.js
26704
26761
  /**
26705
26762
  * 将大驼峰(camelCase)字符串转换为小写且带有空格分隔的形式(kebab-case)