jb-mobile-ui 1.4.1 → 1.4.3

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/dist/index.es.js CHANGED
@@ -1,4 +1,4 @@
1
- import { ref, onMounted, reactive, getCurrentInstance, nextTick, onActivated, onUnmounted, onDeactivated, isRef, watch, inject, computed, provide, unref, isVNode, defineComponent, createVNode, onBeforeUnmount, watchEffect, mergeProps, Transition, Teleport, withDirectives, vShow, Fragment, onBeforeUpdate, Comment, createApp, useAttrs, createBlock, openBlock, withCtx, renderSlot, createElementVNode, createElementBlock, createCommentVNode, toDisplayString, normalizeStyle as normalizeStyle$1, normalizeClass as normalizeClass$1, createTextVNode, renderList, vModelDynamic, withModifiers, customRef } from "vue";
1
+ import { ref, onMounted, reactive, getCurrentInstance, nextTick, onActivated, onUnmounted, onDeactivated, isRef, watch, inject, computed, provide, unref, isVNode, defineComponent, createVNode, onBeforeUnmount, watchEffect, mergeProps, Transition, Teleport, withDirectives, vShow, Fragment, onBeforeUpdate, Comment, createApp, useAttrs, createBlock, openBlock, withCtx, renderSlot, createElementVNode, createElementBlock, createCommentVNode, toDisplayString, normalizeStyle as normalizeStyle$1, normalizeClass as normalizeClass$1, createTextVNode, renderList, vModelDynamic, useSlots, customRef } from "vue";
2
2
  import { showToast as showToast$1 } from "vant";
3
3
  import dayjs from "dayjs";
4
4
  import weekOfYear from "dayjs/plugin/weekOfYear";
@@ -4703,7 +4703,7 @@ var stdin_default = defineComponent({
4703
4703
  }
4704
4704
  });
4705
4705
  const Calendar = withInstall(stdin_default);
4706
- const _sfc_main$9 = /* @__PURE__ */ defineComponent({
4706
+ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
4707
4707
  __name: "JbMobileButton",
4708
4708
  setup(__props) {
4709
4709
  const attrs = useAttrs();
@@ -4711,7 +4711,9 @@ const _sfc_main$9 = /* @__PURE__ */ defineComponent({
4711
4711
  const _component_van_button = Button;
4712
4712
  return openBlock(), createBlock(_component_van_button, mergeProps({ class: "jb-mobile-button" }, unref(attrs)), {
4713
4713
  default: withCtx(() => [
4714
- renderSlot(_ctx.$slots, "default", {}, void 0, true)
4714
+ renderSlot(_ctx.$slots, "default", {}, void 0, true),
4715
+ renderSlot(_ctx.$slots, "icon", {}, void 0, true),
4716
+ renderSlot(_ctx.$slots, "loading", {}, void 0, true)
4715
4717
  ]),
4716
4718
  _: 3
4717
4719
  }, 16);
@@ -4725,11 +4727,11 @@ const _export_sfc = (sfc, props) => {
4725
4727
  }
4726
4728
  return target;
4727
4729
  };
4728
- const JbMobileButton = /* @__PURE__ */ _export_sfc(_sfc_main$9, [["__scopeId", "data-v-177e5e3b"]]);
4729
- const _imports_0$6 = "data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20width='24px'%20height='24px'%20viewBox='0%200%2024%2024'%20version='1.1'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3ctitle%3e编组%2017%3c/title%3e%3cg%20id='页面-1'%20stroke='none'%20stroke-width='1'%20fill='none'%20fill-rule='evenodd'%3e%3cg%20id='按地区'%20transform='translate(-26,%20-254)'%3e%3cg%20id='编组-17'%20transform='translate(26,%20254)'%3e%3ccircle%20id='椭圆形'%20fill='%23F4F4F4'%20cx='12'%20cy='12'%20r='12'%3e%3c/circle%3e%3cpolyline%20id='路径'%20stroke='%23000000'%20stroke-width='1.33333333'%20stroke-linecap='round'%20stroke-linejoin='round'%20points='14%2016%2010%2012%2014%208'%3e%3c/polyline%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/svg%3e";
4730
+ const JbMobileButton = /* @__PURE__ */ _export_sfc(_sfc_main$8, [["__scopeId", "data-v-3768c8dc"]]);
4731
+ const _imports_0$5 = "data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20width='24px'%20height='24px'%20viewBox='0%200%2024%2024'%20version='1.1'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3ctitle%3e编组%2017%3c/title%3e%3cg%20id='页面-1'%20stroke='none'%20stroke-width='1'%20fill='none'%20fill-rule='evenodd'%3e%3cg%20id='按地区'%20transform='translate(-26,%20-254)'%3e%3cg%20id='编组-17'%20transform='translate(26,%20254)'%3e%3ccircle%20id='椭圆形'%20fill='%23F4F4F4'%20cx='12'%20cy='12'%20r='12'%3e%3c/circle%3e%3cpolyline%20id='路径'%20stroke='%23000000'%20stroke-width='1.33333333'%20stroke-linecap='round'%20stroke-linejoin='round'%20points='14%2016%2010%2012%2014%208'%3e%3c/polyline%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/svg%3e";
4730
4732
  const forwardDisabledSvg = "data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20width='24px'%20height='24px'%20viewBox='0%200%2024%2024'%20version='1.1'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3ctitle%3e编组%2017备份%3c/title%3e%3cg%20id='页面-1'%20stroke='none'%20stroke-width='1'%20fill='none'%20fill-rule='evenodd'%3e%3cg%20id='总部'%20transform='translate(-325,%20-254)'%3e%3cg%20id='编组-11'%20transform='translate(26,%20254)'%3e%3cg%20id='编组-17备份'%20transform='translate(299,%200)'%3e%3ccircle%20id='椭圆形'%20fill='%23F4F4F4'%20cx='12'%20cy='12'%20r='12'%3e%3c/circle%3e%3cpolyline%20id='路径'%20stroke='%23C9C9C9'%20stroke-width='1.33333333'%20stroke-linecap='round'%20stroke-linejoin='round'%20transform='translate(12,%2012)%20scale(-1,%201)%20translate(-12,%20-12)'%20points='14%2016%2010%2012%2014%208'%3e%3c/polyline%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/svg%3e";
4731
4733
  const forwardSvg = "data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20width='24px'%20height='24px'%20viewBox='0%200%2024%2024'%20version='1.1'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3ctitle%3e编组%2017备份%3c/title%3e%3cg%20id='页面-1'%20stroke='none'%20stroke-width='1'%20fill='none'%20fill-rule='evenodd'%3e%3cg%20id='按地区'%20transform='translate(-325,%20-254)'%3e%3cg%20id='编组-11'%20transform='translate(26,%20254)'%3e%3cg%20id='编组-17备份'%20transform='translate(299,%200)'%3e%3ccircle%20id='椭圆形'%20fill='%23F4F4F4'%20cx='12'%20cy='12'%20r='12'%3e%3c/circle%3e%3cpolyline%20id='路径'%20stroke='%23000000'%20stroke-width='1.33333333'%20stroke-linecap='round'%20stroke-linejoin='round'%20transform='translate(12,%2012)%20scale(-1,%201)%20translate(-12,%20-12)'%20points='14%2016%2010%2012%2014%208'%3e%3c/polyline%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/svg%3e";
4732
- const _imports_0$5 = "data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20width='24px'%20height='24px'%20viewBox='0%200%2024%2024'%20version='1.1'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3ctitle%3e图标(24)/关闭%3c/title%3e%3cg%20id='页面-1'%20stroke='none'%20stroke-width='1'%20fill='none'%20fill-rule='evenodd'%3e%3cg%20id='我的服务备份-15'%20transform='translate(-339,%20-343)'%3e%3cg%20id='编组-4'%20transform='translate(0,%20331)'%3e%3cg%20id='图标(24)/关闭'%20transform='translate(339,%2012)'%3e%3crect%20id='矩形'%20x='0'%20y='0'%20width='24'%20height='24'%3e%3c/rect%3e%3cg%20id='编组-18'%20transform='translate(6,%206)'%20stroke='%23D2D6DA'%20stroke-linecap='round'%20stroke-width='1.5'%3e%3cline%20x1='-2.16636906'%20y1='5.83363094'%20x2='13.8336309'%20y2='5.83363094'%20id='路径-6'%20transform='translate(5.8336,%205.8336)%20rotate(-315)%20translate(-5.8336,%20-5.8336)'%3e%3c/line%3e%3cline%20x1='5.83363094'%20y1='13.8336309'%20x2='5.83363094'%20y2='-2.16636906'%20id='路径-6'%20transform='translate(5.8336,%205.8336)%20rotate(-315)%20translate(-5.8336,%20-5.8336)'%3e%3c/line%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/svg%3e";
4734
+ const _imports_0$4 = "data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20width='24px'%20height='24px'%20viewBox='0%200%2024%2024'%20version='1.1'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3ctitle%3e图标(24)/关闭%3c/title%3e%3cg%20id='页面-1'%20stroke='none'%20stroke-width='1'%20fill='none'%20fill-rule='evenodd'%3e%3cg%20id='我的服务备份-15'%20transform='translate(-339,%20-343)'%3e%3cg%20id='编组-4'%20transform='translate(0,%20331)'%3e%3cg%20id='图标(24)/关闭'%20transform='translate(339,%2012)'%3e%3crect%20id='矩形'%20x='0'%20y='0'%20width='24'%20height='24'%3e%3c/rect%3e%3cg%20id='编组-18'%20transform='translate(6,%206)'%20stroke='%23D2D6DA'%20stroke-linecap='round'%20stroke-width='1.5'%3e%3cline%20x1='-2.16636906'%20y1='5.83363094'%20x2='13.8336309'%20y2='5.83363094'%20id='路径-6'%20transform='translate(5.8336,%205.8336)%20rotate(-315)%20translate(-5.8336,%20-5.8336)'%3e%3c/line%3e%3cline%20x1='5.83363094'%20y1='13.8336309'%20x2='5.83363094'%20y2='-2.16636906'%20id='路径-6'%20transform='translate(5.8336,%205.8336)%20rotate(-315)%20translate(-5.8336,%20-5.8336)'%3e%3c/line%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/svg%3e";
4733
4735
  const checkHasSafeAreaInsetBottom = () => {
4734
4736
  const div = document.createElement("div");
4735
4737
  div.style.height = "env(safe-area-inset-bottom)";
@@ -4738,38 +4740,67 @@ const checkHasSafeAreaInsetBottom = () => {
4738
4740
  document.body.removeChild(div);
4739
4741
  return height2 > 0;
4740
4742
  };
4741
- const _hoisted_1$8 = { class: "jb-mobile-popup__header" };
4742
- const _sfc_main$8 = /* @__PURE__ */ defineComponent({
4743
+ const _hoisted_1$7 = { class: "jb-mobile-popup__header" };
4744
+ const _sfc_main$7 = /* @__PURE__ */ defineComponent({
4743
4745
  __name: "JbMobilePopup",
4744
4746
  props: {
4747
+ /**
4748
+ * 是否显示弹出层,可通过 v-model 进行双向数据绑定
4749
+ */
4745
4750
  visible: {
4746
4751
  type: Boolean,
4747
4752
  default: false
4748
4753
  },
4749
- contentHeight: {
4750
- type: [Number, String],
4751
- default: "auto"
4752
- },
4754
+ /**
4755
+ * 弹出层的标题
4756
+ */
4753
4757
  title: {
4754
4758
  type: String,
4755
4759
  default: ""
4756
4760
  },
4761
+ /**
4762
+ * 弹出层内容的高度
4763
+ */
4764
+ contentHeight: {
4765
+ type: [Number, String],
4766
+ default: "auto"
4767
+ },
4768
+ /**
4769
+ * 弹出层是否为灰色背景
4770
+ */
4757
4771
  greyBg: {
4758
4772
  type: Boolean,
4759
4773
  default: false
4760
4774
  },
4775
+ /**
4776
+ * 是否显示弹出层的底部按钮
4777
+ */
4761
4778
  footButton: {
4762
4779
  type: Boolean,
4763
4780
  default: true
4764
4781
  },
4782
+ /**
4783
+ * 点击确认按钮前的回调函数,返回值为 true 时才会触发确认按钮的 confirm 事件,为 false 时则不会触发
4784
+ */
4765
4785
  beforeConfirm: {
4766
4786
  type: Function,
4767
- default: () => {
4768
- return true;
4769
- }
4787
+ default: () => true
4770
4788
  }
4771
4789
  },
4772
- emits: ["update:visible", "confirm", "close"],
4790
+ emits: [
4791
+ /**
4792
+ * 更新弹出层的显示状态
4793
+ */
4794
+ "update:visible",
4795
+ /**
4796
+ * 确定按钮被点击并且 beforeConfirm 回调函数返回为 true 时触发
4797
+ */
4798
+ "confirm",
4799
+ /**
4800
+ * 关闭弹出层时触发
4801
+ */
4802
+ "close"
4803
+ ],
4773
4804
  setup(__props, { emit: __emit }) {
4774
4805
  const attrs = useAttrs();
4775
4806
  const emits = __emit;
@@ -4787,7 +4818,7 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
4787
4818
  return Number(props.contentHeight) ? `${props.contentHeight}px` : props.contentHeight;
4788
4819
  });
4789
4820
  const handleConfirm = () => {
4790
- if (typeof props.beforeConfirm === "function") {
4821
+ if (props.footButton && typeof props.beforeConfirm === "function") {
4791
4822
  const result = props.beforeConfirm();
4792
4823
  if (!result) return;
4793
4824
  }
@@ -4814,7 +4845,7 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
4814
4845
  onClosed: handleClose
4815
4846
  }), {
4816
4847
  default: withCtx(() => [
4817
- createElementVNode("div", _hoisted_1$8, [
4848
+ createElementVNode("div", _hoisted_1$7, [
4818
4849
  createElementVNode("div", null, toDisplayString(__props.title), 1),
4819
4850
  createElementVNode("div", {
4820
4851
  class: "jb-mobile-popup__close-icon",
@@ -4822,7 +4853,7 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
4822
4853
  }, _cache[1] || (_cache[1] = [
4823
4854
  createElementVNode("img", {
4824
4855
  class: "jb-mobile-popup__close-icon__inner",
4825
- src: _imports_0$5,
4856
+ src: _imports_0$4,
4826
4857
  alt: ""
4827
4858
  }, null, -1)
4828
4859
  ]))
@@ -4856,12 +4887,12 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
4856
4887
  };
4857
4888
  }
4858
4889
  });
4859
- const JbMobilePopup = /* @__PURE__ */ _export_sfc(_sfc_main$8, [["__scopeId", "data-v-29e15451"]]);
4860
- const _hoisted_1$7 = {
4890
+ const JbMobilePopup = /* @__PURE__ */ _export_sfc(_sfc_main$7, [["__scopeId", "data-v-2c28244d"]]);
4891
+ const _hoisted_1$6 = {
4861
4892
  key: 0,
4862
4893
  class: "jb-mobile-date-picker"
4863
4894
  };
4864
- const _hoisted_2$6 = { class: "jb-mobile-date-picker__value" };
4895
+ const _hoisted_2$5 = { class: "jb-mobile-date-picker__value" };
4865
4896
  const _hoisted_3$4 = ["src"];
4866
4897
  const _hoisted_4$3 = { class: "jb-mobile-time-picker__calendar__inner" };
4867
4898
  const _hoisted_5$2 = { class: "jb-mobile-time-picker__group-wrap" };
@@ -4870,55 +4901,96 @@ const _hoisted_6$2 = {
4870
4901
  class: "jb-mobile-time-picker__group__title"
4871
4902
  };
4872
4903
  const _hoisted_7$2 = ["onClick"];
4873
- const _sfc_main$7 = /* @__PURE__ */ defineComponent({
4904
+ const _sfc_main$6 = /* @__PURE__ */ defineComponent({
4874
4905
  __name: "JbMobileTimePicker",
4875
4906
  props: {
4907
+ /**
4908
+ * 是否显示弹出层,可通过 v-model 进行双向数据绑定
4909
+ */
4876
4910
  visible: {
4877
4911
  type: Boolean,
4878
4912
  default: false
4879
4913
  },
4914
+ /**
4915
+ * 时间选择弹出层组件当前默认的时间维度,可通过 v-model 进行双向数据绑定,可选值为:dateRange - 按日、week - 按周、month - 按月、quarter - 按季度、year - 按年
4916
+ */
4880
4917
  timePickerType: {
4881
4918
  type: String,
4882
4919
  default: "dateRange"
4883
- // dateRange - 选择日期(范围), week - 选择周, month - 选择月, quarter - 选择季度, year - 选择年
4884
4920
  },
4921
+ /**
4922
+ * 时间选择弹出层组件当前默认选中的日期值,当为 Date 类型的数组时,数组的值分别表示开始日期和结束日期
4923
+ */
4885
4924
  defaultValue: {
4886
4925
  type: [Date, Array],
4887
4926
  default: /* @__PURE__ */ new Date()
4888
4927
  },
4928
+ /**
4929
+ * 时间选择弹出层组件可选择的最小日期
4930
+ */
4889
4931
  minDate: {
4890
4932
  type: [Date, String, Number],
4891
4933
  default: /* @__PURE__ */ new Date("2020-01-01")
4892
4934
  },
4935
+ /**
4936
+ * 时间选择弹出层组件可选择的最大日期
4937
+ */
4893
4938
  maxDate: {
4894
4939
  type: [Date, String, Number],
4895
4940
  default: /* @__PURE__ */ new Date()
4896
4941
  },
4942
+ /**
4943
+ * 时间选择弹出层组件选择的日期值的格式化字符串
4944
+ */
4897
4945
  valueFormat: {
4898
4946
  type: String,
4899
4947
  default: "YYYY-MM-DD HH:mm:ss"
4900
4948
  },
4949
+ /**
4950
+ * 时间选择弹出层组件选择按日维度时所选择日期的显示值的格式化字符串
4951
+ */
4901
4952
  dateRangeFormat: {
4902
4953
  type: String,
4903
4954
  default: "YYYY年M月D日"
4904
4955
  },
4956
+ /**
4957
+ * 时间选择弹出层组件是否显示切换时间维度的 tab
4958
+ */
4905
4959
  withSelectTab: {
4906
4960
  type: Boolean,
4907
4961
  default: false
4908
4962
  },
4963
+ /**
4964
+ * 时间选择弹出层组件可切换的时间维度列表,可在 dateRange、week、month、quarter、year 中选择一个或多个
4965
+ */
4909
4966
  datePickerTypeList: {
4910
4967
  type: Array,
4911
4968
  default: () => ["dateRange", "week", "month", "quarter", "year"]
4912
4969
  },
4970
+ /**
4971
+ * 时间选择弹出层组件是否禁止切换时间维度和上/下一个时间
4972
+ */
4913
4973
  disabledTab: {
4914
4974
  type: Boolean,
4915
4975
  default: false
4916
4976
  }
4917
4977
  },
4918
4978
  emits: [
4979
+ /**
4980
+ * 更新弹出层的显示状态
4981
+ */
4919
4982
  "update:visible",
4983
+ /**
4984
+ * 更新当前选中的时间维度
4985
+ */
4920
4986
  "update:timePickerType",
4987
+ /**
4988
+ * 确认选择某个日期时间时触发,返回值为一个对象,其属性有:dateValueFormat - 所选择日期值被格式化后的字符串,value - 所选择日期值的开始时间和结束时间所组成的数组,isLatestDate - 所选择日期值是否为最新日期
4989
+ */
4921
4990
  "confirm",
4991
+ /**
4992
+ * 切换时间维度和上/下一个时间失败时触发
4993
+ */
4922
4994
  "changeDateFail"
4923
4995
  ],
4924
4996
  setup(__props, { expose: __expose, emit: __emit }) {
@@ -5364,7 +5436,7 @@ const _sfc_main$7 = /* @__PURE__ */ defineComponent({
5364
5436
  ref: timePickerContentRef,
5365
5437
  class: "time-picker__content"
5366
5438
  }, [
5367
- __props.withSelectTab ? (openBlock(), createElementBlock("div", _hoisted_1$7, [
5439
+ __props.withSelectTab ? (openBlock(), createElementBlock("div", _hoisted_1$6, [
5368
5440
  createVNode(_component_van_tabs, {
5369
5441
  active: timePickerType.value,
5370
5442
  "onUpdate:active": _cache[0] || (_cache[0] = ($event) => timePickerType.value = $event),
@@ -5385,14 +5457,14 @@ const _sfc_main$7 = /* @__PURE__ */ defineComponent({
5385
5457
  ]),
5386
5458
  _: 1
5387
5459
  }, 8, ["active"]),
5388
- createElementVNode("div", _hoisted_2$6, [
5460
+ createElementVNode("div", _hoisted_2$5, [
5389
5461
  timePickerType.value !== "dateRange" ? (openBlock(), createElementBlock("div", {
5390
5462
  key: 0,
5391
5463
  class: "jb-mobile-date-picker__date-arrow left",
5392
5464
  onClick: changeDatePrev
5393
5465
  }, _cache[3] || (_cache[3] = [
5394
5466
  createElementVNode("img", {
5395
- src: _imports_0$6,
5467
+ src: _imports_0$5,
5396
5468
  alt: "back"
5397
5469
  }, null, -1)
5398
5470
  ]))) : createCommentVNode("", true),
@@ -5430,6 +5502,7 @@ const _sfc_main$7 = /* @__PURE__ */ defineComponent({
5430
5502
  "max-date": maxDate.value,
5431
5503
  "default-date": defaultDate.value,
5432
5504
  formatter,
5505
+ "lazy-render": false,
5433
5506
  onSelect: handleSelectDate,
5434
5507
  onConfirm: handleFinishSelectDate
5435
5508
  }, {
@@ -5470,39 +5543,74 @@ const _sfc_main$7 = /* @__PURE__ */ defineComponent({
5470
5543
  };
5471
5544
  }
5472
5545
  });
5473
- const JbMobileTimePicker = /* @__PURE__ */ _export_sfc(_sfc_main$7, [["__scopeId", "data-v-eb416205"]]);
5474
- const _hoisted_1$6 = { class: "jb-mobile-date-picker" };
5475
- const _hoisted_2$5 = { class: "jb-mobile-date-picker__value" };
5546
+ const JbMobileTimePicker = /* @__PURE__ */ _export_sfc(_sfc_main$6, [["__scopeId", "data-v-87a0b52f"]]);
5547
+ const _hoisted_1$5 = { class: "jb-mobile-date-picker" };
5548
+ const _hoisted_2$4 = { class: "jb-mobile-date-picker__value" };
5476
5549
  const _hoisted_3$3 = ["src"];
5477
- const _sfc_main$6 = /* @__PURE__ */ defineComponent({
5550
+ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5478
5551
  __name: "JbMobileDatePicker",
5479
5552
  props: {
5553
+ /**
5554
+ * 日期选择组件当前默认的时间维度,可通过 v-model 进行双向数据绑定,可选值为:dateRange - 按日、week - 按周、month - 按月、quarter - 按季度、year - 按年
5555
+ */
5480
5556
  datePickerType: {
5481
5557
  type: String,
5482
5558
  default: "dateRange"
5483
5559
  },
5560
+ /**
5561
+ * 日期选择组件可切换的时间维度列表,可在 dateRange、week、month、quarter、year 中选择一个或多个
5562
+ */
5484
5563
  datePickerTypeList: {
5485
5564
  type: Array,
5486
5565
  default: () => ["dateRange", "week", "month", "quarter", "year"]
5487
5566
  },
5567
+ /**
5568
+ * 日期选择组件当前默认选中的日期值,当为 Date 类型的数组时,数组的值分别表示开始日期和结束日期
5569
+ */
5488
5570
  defaultValue: {
5489
5571
  type: [Date, Array],
5490
5572
  default: /* @__PURE__ */ new Date()
5491
5573
  },
5574
+ /**
5575
+ * 日期选择组件当前选中的日期值被格式化之后所显示的值,可通过 v-model 进行双向数据绑定
5576
+ */
5492
5577
  dateFormatValue: {
5493
5578
  type: String,
5494
5579
  default: ""
5495
5580
  },
5581
+ /**
5582
+ * 日期选择组件是否禁止切换时间维度和上/下一个时间
5583
+ */
5496
5584
  disabled: {
5497
5585
  type: Boolean,
5498
5586
  default: false
5499
5587
  },
5588
+ /**
5589
+ * 日期选择组件是否显示切换时间维度的 tab
5590
+ */
5500
5591
  showDatePickerType: {
5501
5592
  type: Boolean,
5502
5593
  default: true
5503
5594
  }
5504
5595
  },
5505
- emits: ["update:datePickerType", "update:dateFormatValue", "confirm", "changeDateFail"],
5596
+ emits: [
5597
+ /**
5598
+ * 更新当前选中的时间维度
5599
+ */
5600
+ "update:datePickerType",
5601
+ /**
5602
+ * 更新当前选中的日期值被格式化之后所显示的值
5603
+ */
5604
+ "update:dateFormatValue",
5605
+ /**
5606
+ * 确认选择某个日期时间时触发,返回值为所选择的日期值
5607
+ */
5608
+ "confirm",
5609
+ /**
5610
+ * 切换时间维度和上/下一个时间失败时触发
5611
+ */
5612
+ "changeDateFail"
5613
+ ],
5506
5614
  setup(__props, { emit: __emit }) {
5507
5615
  const attrs = useAttrs();
5508
5616
  const emits = __emit;
@@ -5589,7 +5697,7 @@ const _sfc_main$6 = /* @__PURE__ */ defineComponent({
5589
5697
  const _component_van_tab = Tab;
5590
5698
  const _component_van_tabs = Tabs;
5591
5699
  const _component_van_icon = Icon;
5592
- return openBlock(), createElementBlock("div", _hoisted_1$6, [
5700
+ return openBlock(), createElementBlock("div", _hoisted_1$5, [
5593
5701
  __props.showDatePickerType ? (openBlock(), createBlock(_component_van_tabs, {
5594
5702
  key: 0,
5595
5703
  active: datePickerType.value,
@@ -5611,14 +5719,14 @@ const _sfc_main$6 = /* @__PURE__ */ defineComponent({
5611
5719
  ]),
5612
5720
  _: 1
5613
5721
  }, 8, ["active"])) : createCommentVNode("", true),
5614
- createElementVNode("div", _hoisted_2$5, [
5722
+ createElementVNode("div", _hoisted_2$4, [
5615
5723
  datePickerType.value !== "dateRange" ? (openBlock(), createElementBlock("div", {
5616
5724
  key: 0,
5617
5725
  class: "jb-mobile-date-picker__date-arrow left",
5618
5726
  onClick: changeDatePrev
5619
5727
  }, _cache[3] || (_cache[3] = [
5620
5728
  createElementVNode("img", {
5621
- src: _imports_0$6,
5729
+ src: _imports_0$5,
5622
5730
  alt: "back"
5623
5731
  }, null, -1)
5624
5732
  ]))) : createCommentVNode("", true),
@@ -5654,13 +5762,16 @@ const _sfc_main$6 = /* @__PURE__ */ defineComponent({
5654
5762
  };
5655
5763
  }
5656
5764
  });
5657
- const JbMobileDatePicker = /* @__PURE__ */ _export_sfc(_sfc_main$6, [["__scopeId", "data-v-4b9c26a6"]]);
5658
- const _imports_0$4 = "";
5659
- const _hoisted_1$5 = { class: "jb-mobile-empty" };
5660
- const _hoisted_2$4 = { class: "jb-mobile-empty__tip" };
5661
- const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5765
+ const JbMobileDatePicker = /* @__PURE__ */ _export_sfc(_sfc_main$5, [["__scopeId", "data-v-59f7ea97"]]);
5766
+ const _imports_0$3 = "";
5767
+ const _hoisted_1$4 = { class: "jb-mobile-empty" };
5768
+ const _hoisted_2$3 = { class: "jb-mobile-empty__tip" };
5769
+ const _sfc_main$4 = /* @__PURE__ */ defineComponent({
5662
5770
  __name: "JbMobileEmpty",
5663
5771
  props: {
5772
+ /**
5773
+ * 提示文案
5774
+ */
5664
5775
  tip: {
5665
5776
  type: String,
5666
5777
  default: "暂无内容"
@@ -5668,39 +5779,59 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5668
5779
  },
5669
5780
  setup(__props) {
5670
5781
  return (_ctx, _cache) => {
5671
- return openBlock(), createElementBlock("div", _hoisted_1$5, [
5782
+ return openBlock(), createElementBlock("div", _hoisted_1$4, [
5672
5783
  _cache[0] || (_cache[0] = createElementVNode("img", {
5673
5784
  class: "jb-mobile-empty__img",
5674
- src: _imports_0$4,
5785
+ src: _imports_0$3,
5675
5786
  alt: ""
5676
5787
  }, null, -1)),
5677
- createElementVNode("div", _hoisted_2$4, toDisplayString(__props.tip), 1),
5788
+ createElementVNode("div", _hoisted_2$3, toDisplayString(__props.tip), 1),
5678
5789
  renderSlot(_ctx.$slots, "default", {}, void 0, true)
5679
5790
  ]);
5680
5791
  };
5681
5792
  }
5682
5793
  });
5683
- const JbMobileEmpty = /* @__PURE__ */ _export_sfc(_sfc_main$5, [["__scopeId", "data-v-e1f68e36"]]);
5684
- const _imports_0$3 = "data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20width='16px'%20height='17px'%20viewBox='0%200%2016%2017'%20version='1.1'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3ctitle%3e编组%203%3c/title%3e%3cg%20id='页面-1'%20stroke='none'%20stroke-width='1'%20fill='none'%20fill-rule='evenodd'%3e%3cg%20id='我的服务备份-14'%20transform='translate(-22,%20-143)'%3e%3cg%20id='编组-28'%20transform='translate(0,%20134)'%3e%3cg%20id='编组-13备份'%20transform='translate(10,%200)'%3e%3cg%20id='编组-3'%20transform='translate(12,%209.5)'%3e%3crect%20id='矩形'%20fill='%23006FFE'%20opacity='0'%20x='0'%20y='0'%20width='16'%20height='16'%3e%3c/rect%3e%3cg%20id='编组'%20transform='translate(1.5,%200.5)'%3e%3ccircle%20id='椭圆形'%20stroke='%23666666'%20stroke-width='1.5'%20cx='6.5'%20cy='6.5'%20r='5.75'%3e%3c/circle%3e%3cpath%20d='M11.1363636,9.95454545%20C11.5631291,9.95454545%2011.9090909,10.3005072%2011.9090909,10.7272727%20L11.9090909,14.5909091%20C11.9090909,15.0176746%2011.5631291,15.3636364%2011.1363636,15.3636364%20C10.7095981,15.3636364%2010.3636364,15.0176746%2010.3636364,14.5909091%20L10.3636364,10.7272727%20C10.3636364,10.3005072%2010.7095981,9.95454545%2011.1363636,9.95454545%20Z'%20id='矩形'%20fill='%23666666'%20transform='translate(11.1364,%2012.6591)%20rotate(-45)%20translate(-11.1364,%20-12.6591)'%3e%3c/path%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/svg%3e";
5685
- const _hoisted_1$4 = { class: "jb-mobile-search-input" };
5686
- const _hoisted_2$3 = ["placeholder"];
5687
- const _sfc_main$4 = /* @__PURE__ */ defineComponent({
5794
+ const JbMobileEmpty = /* @__PURE__ */ _export_sfc(_sfc_main$4, [["__scopeId", "data-v-7dfe6077"]]);
5795
+ const _imports_0$2 = "data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20width='16px'%20height='17px'%20viewBox='0%200%2016%2017'%20version='1.1'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3ctitle%3e编组%203%3c/title%3e%3cg%20id='页面-1'%20stroke='none'%20stroke-width='1'%20fill='none'%20fill-rule='evenodd'%3e%3cg%20id='我的服务备份-14'%20transform='translate(-22,%20-143)'%3e%3cg%20id='编组-28'%20transform='translate(0,%20134)'%3e%3cg%20id='编组-13备份'%20transform='translate(10,%200)'%3e%3cg%20id='编组-3'%20transform='translate(12,%209.5)'%3e%3crect%20id='矩形'%20fill='%23006FFE'%20opacity='0'%20x='0'%20y='0'%20width='16'%20height='16'%3e%3c/rect%3e%3cg%20id='编组'%20transform='translate(1.5,%200.5)'%3e%3ccircle%20id='椭圆形'%20stroke='%23666666'%20stroke-width='1.5'%20cx='6.5'%20cy='6.5'%20r='5.75'%3e%3c/circle%3e%3cpath%20d='M11.1363636,9.95454545%20C11.5631291,9.95454545%2011.9090909,10.3005072%2011.9090909,10.7272727%20L11.9090909,14.5909091%20C11.9090909,15.0176746%2011.5631291,15.3636364%2011.1363636,15.3636364%20C10.7095981,15.3636364%2010.3636364,15.0176746%2010.3636364,14.5909091%20L10.3636364,10.7272727%20C10.3636364,10.3005072%2010.7095981,9.95454545%2011.1363636,9.95454545%20Z'%20id='矩形'%20fill='%23666666'%20transform='translate(11.1364,%2012.6591)%20rotate(-45)%20translate(-11.1364,%20-12.6591)'%3e%3c/path%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/svg%3e";
5796
+ const _hoisted_1$3 = ["placeholder"];
5797
+ const _sfc_main$3 = /* @__PURE__ */ defineComponent({
5688
5798
  __name: "JbMobileSearchInput",
5689
5799
  props: {
5800
+ /**
5801
+ * 是否显示搜索按钮
5802
+ */
5690
5803
  showBtn: {
5691
5804
  type: Boolean,
5692
5805
  default: true
5693
5806
  },
5807
+ /**
5808
+ * 搜索框的输入值,可通过 v-model 进行双向数据绑定
5809
+ */
5694
5810
  modelValue: {
5695
5811
  type: [String, Number],
5696
5812
  default: ""
5697
5813
  },
5814
+ /**
5815
+ * 搜索框的提示文案
5816
+ */
5698
5817
  placeholder: {
5699
5818
  type: String,
5700
5819
  default: ""
5820
+ },
5821
+ /**
5822
+ * 搜索框是否为灰色背景
5823
+ */
5824
+ greyBg: {
5825
+ type: Boolean,
5826
+ default: true
5701
5827
  }
5702
5828
  },
5703
- emits: ["update:modelValue"],
5829
+ emits: [
5830
+ /**
5831
+ * 更新搜索框输入的值
5832
+ */
5833
+ "update:modelValue"
5834
+ ],
5704
5835
  setup(__props, { emit: __emit }) {
5705
5836
  const attrs = useAttrs();
5706
5837
  const emit = __emit;
@@ -5716,16 +5847,18 @@ const _sfc_main$4 = /* @__PURE__ */ defineComponent({
5716
5847
  }
5717
5848
  });
5718
5849
  return (_ctx, _cache) => {
5719
- return openBlock(), createElementBlock("div", _hoisted_1$4, [
5850
+ return openBlock(), createElementBlock("div", {
5851
+ class: normalizeClass$1(["jb-mobile-search-input", { "grey-bg": __props.greyBg }])
5852
+ }, [
5720
5853
  _cache[2] || (_cache[2] = createElementVNode("img", {
5721
5854
  class: "jb-mobile-search-input__search-icon",
5722
- src: _imports_0$3,
5855
+ src: _imports_0$2,
5723
5856
  alt: ""
5724
5857
  }, null, -1)),
5725
5858
  withDirectives(createElementVNode("input", mergeProps({
5726
5859
  class: "jb-mobile-search-input__inner",
5727
5860
  "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => inputValue.value = $event)
5728
- }, unref(attrs), { placeholder: placeholder.value }), null, 16, _hoisted_2$3), [
5861
+ }, unref(attrs), { placeholder: placeholder.value }), null, 16, _hoisted_1$3), [
5729
5862
  [vModelDynamic, inputValue.value]
5730
5863
  ]),
5731
5864
  showBtn.value ? (openBlock(), createBlock(JbMobileButton, {
@@ -5741,39 +5874,12 @@ const _sfc_main$4 = /* @__PURE__ */ defineComponent({
5741
5874
  _: 1,
5742
5875
  __: [1]
5743
5876
  })) : createCommentVNode("", true)
5744
- ]);
5745
- };
5746
- }
5747
- });
5748
- const JbMobileSearchInput = /* @__PURE__ */ _export_sfc(_sfc_main$4, [["__scopeId", "data-v-5d5a1d36"]]);
5749
- const _imports_0$2 = "";
5750
- const _imports_0$1 = "";
5751
- const _hoisted_1$3 = { class: "mobile-select-face" };
5752
- const _sfc_main$3 = /* @__PURE__ */ defineComponent({
5753
- __name: "JbMobileSelectFace",
5754
- props: {
5755
- slotClick: { type: Function }
5756
- },
5757
- setup(__props) {
5758
- const props = __props;
5759
- const handleClickSlot = () => {
5760
- props.slotClick && props.slotClick();
5761
- };
5762
- return (_ctx, _cache) => {
5763
- return openBlock(), createElementBlock("div", _hoisted_1$3, [
5764
- renderSlot(_ctx.$slots, "default", {
5765
- onClick: withModifiers(handleClickSlot, ["stop"])
5766
- }, void 0, true),
5767
- _cache[0] || (_cache[0] = createElementVNode("img", {
5768
- src: _imports_0$1,
5769
- alt: "",
5770
- class: "pull-down"
5771
- }, null, -1))
5772
- ]);
5877
+ ], 2);
5773
5878
  };
5774
5879
  }
5775
5880
  });
5776
- const JbMobileSelectFace = /* @__PURE__ */ _export_sfc(_sfc_main$3, [["__scopeId", "data-v-11ebc006"]]);
5881
+ const JbMobileSearchInput = /* @__PURE__ */ _export_sfc(_sfc_main$3, [["__scopeId", "data-v-40dc019e"]]);
5882
+ const _imports_0$1 = "";
5777
5883
  const _hoisted_1$2 = { class: "jb-mobile-select__value" };
5778
5884
  const _hoisted_2$2 = {
5779
5885
  key: 0,
@@ -5787,42 +5893,64 @@ const _hoisted_4$2 = {
5787
5893
  const _sfc_main$2 = /* @__PURE__ */ defineComponent({
5788
5894
  __name: "JbMobileSelect",
5789
5895
  props: {
5790
- // 当tabIndex == 0 时,选中第一个选项,则显示普通的select样式,如果为1,则显示/ComplaintAnalysis/dialog的样式
5791
- tabIndex: {
5792
- type: Number,
5793
- default: 0
5794
- },
5896
+ /**
5897
+ * 选择器的宽度
5898
+ */
5795
5899
  width: {
5796
5900
  type: Number,
5797
5901
  default: 92
5798
5902
  },
5903
+ /**
5904
+ * 选择器所选择的值,可通过 v-model 进行双向数据绑定
5905
+ */
5799
5906
  modelValue: {
5800
5907
  type: [Number, String],
5801
5908
  default: ""
5802
5909
  },
5910
+ /**
5911
+ * 选择器未选择时的提示文案
5912
+ */
5803
5913
  placeholder: {
5804
5914
  type: String,
5805
5915
  default: "请选择"
5806
5916
  },
5917
+ /**
5918
+ * 选项列表弹出层的标题
5919
+ */
5807
5920
  popupTitle: {
5808
5921
  type: String,
5809
- default: "请选择事件类型"
5922
+ default: "请选择"
5810
5923
  },
5924
+ /**
5925
+ * 选项列表
5926
+ */
5811
5927
  options: {
5812
5928
  type: Array,
5813
- default: () => []
5929
+ default: []
5814
5930
  },
5931
+ /**
5932
+ * 选项的自定义字段,可修改的字段有 label 和 value
5933
+ */
5815
5934
  fieldNames: {
5816
5935
  type: Object,
5817
5936
  default: () => ({})
5818
5937
  }
5819
5938
  },
5820
- emits: ["update:modelValue", "change"],
5939
+ emits: [
5940
+ /**
5941
+ * 更新选择器所选择的值
5942
+ */
5943
+ "update:modelValue",
5944
+ /**
5945
+ * 选择某个选项时触发,返回值为所选择的选项
5946
+ */
5947
+ "change"
5948
+ ],
5821
5949
  setup(__props, { expose: __expose, emit: __emit }) {
5822
5950
  const attrs = useAttrs();
5951
+ const slots = useSlots();
5823
5952
  const emits = __emit;
5824
5953
  const props = __props;
5825
- const tabIndex = computed(() => props.tabIndex);
5826
5954
  const isShowOptionsPopup = ref(false);
5827
5955
  const selectedOptionItem = ref({});
5828
5956
  const computedWidth = computed(() => `${props.width}px`);
@@ -5846,38 +5974,34 @@ const _sfc_main$2 = /* @__PURE__ */ defineComponent({
5846
5974
  }
5847
5975
  });
5848
5976
  const handleSelectOptionItem = (item) => {
5849
- console.log("item", item);
5850
5977
  selectedOptionItem.value = item;
5851
5978
  isShowOptionsPopup.value = false;
5852
5979
  modelValue.value = item[fieldNames.value.value];
5853
- emits("change", item[fieldNames.value.label]);
5980
+ emits("change", item);
5854
5981
  };
5855
5982
  __expose({
5856
5983
  handleSelectOptionItem
5857
5984
  });
5858
5985
  return (_ctx, _cache) => {
5859
5986
  return openBlock(), createElementBlock(Fragment, null, [
5860
- tabIndex.value === 0 ? (openBlock(), createElementBlock("div", {
5987
+ unref(slots).reference ? (openBlock(), createElementBlock("div", {
5861
5988
  key: 0,
5989
+ onClick: _cache[0] || (_cache[0] = ($event) => isShowOptionsPopup.value = true)
5990
+ }, [
5991
+ renderSlot(_ctx.$slots, "reference", {}, void 0, true)
5992
+ ])) : (openBlock(), createElementBlock("div", {
5993
+ key: 1,
5862
5994
  class: "jb-mobile-select",
5863
5995
  style: normalizeStyle$1({ width: computedWidth.value }),
5864
- onClick: _cache[0] || (_cache[0] = ($event) => isShowOptionsPopup.value = true)
5996
+ onClick: _cache[1] || (_cache[1] = ($event) => isShowOptionsPopup.value = true)
5865
5997
  }, [
5866
5998
  createElementVNode("div", _hoisted_1$2, toDisplayString(selectedOptionItem.value[fieldNames.value.label] || __props.placeholder), 1),
5867
5999
  _cache[3] || (_cache[3] = createElementVNode("img", {
5868
6000
  class: "jb-mobile-select__select-down-icon",
5869
- src: _imports_0$2,
6001
+ src: _imports_0$1,
5870
6002
  alt: ""
5871
6003
  }, null, -1))
5872
- ], 4)) : tabIndex.value === 1 ? (openBlock(), createBlock(JbMobileSelectFace, {
5873
- key: 1,
5874
- onClick: _cache[1] || (_cache[1] = ($event) => isShowOptionsPopup.value = true)
5875
- }, {
5876
- default: withCtx(() => [
5877
- createTextVNode(toDisplayString(selectedOptionItem.value[fieldNames.value.label] || __props.placeholder), 1)
5878
- ]),
5879
- _: 1
5880
- })) : createCommentVNode("", true),
6004
+ ], 4)),
5881
6005
  createVNode(JbMobilePopup, mergeProps({
5882
6006
  visible: isShowOptionsPopup.value,
5883
6007
  "onUpdate:visible": _cache[2] || (_cache[2] = ($event) => isShowOptionsPopup.value = $event)
@@ -5885,7 +6009,7 @@ const _sfc_main$2 = /* @__PURE__ */ defineComponent({
5885
6009
  title: __props.popupTitle,
5886
6010
  "grey-bg": true,
5887
6011
  "foot-button": false,
5888
- "content-height": 434
6012
+ height: 434
5889
6013
  }), {
5890
6014
  default: withCtx(() => [
5891
6015
  __props.options.length ? (openBlock(), createElementBlock("div", _hoisted_2$2, [
@@ -5906,7 +6030,7 @@ const _sfc_main$2 = /* @__PURE__ */ defineComponent({
5906
6030
  };
5907
6031
  }
5908
6032
  });
5909
- const JbMobileSelect = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["__scopeId", "data-v-9ba900fa"]]);
6033
+ const JbMobileSelect = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["__scopeId", "data-v-a148a345"]]);
5910
6034
  const _imports_0 = "data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20width='24px'%20height='24px'%20viewBox='0%200%2024%2024'%20version='1.1'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3ctitle%3e图标(24)/巡检%3c/title%3e%3cg%20id='页面-1'%20stroke='none'%20stroke-width='1'%20fill='none'%20fill-rule='evenodd'%3e%3cg%20id='我的服务备份-14'%20transform='translate(-339,%20-371)'%20fill='%237B52FE'%20fill-rule='nonzero'%3e%3cg%20id='编组-28'%20transform='translate(0,%20134)'%3e%3cg%20id='编组-28备份'%20transform='translate(0,%2051)'%3e%3cg%20id='编组-32备份-4'%20transform='translate(0,%20176)'%3e%3cg%20id='编组-27'%20transform='translate(132,%200)'%3e%3cg%20id='编组'%20transform='translate(211.3571,%2016)'%3e%3cpath%20d='M0.127476811,5.43301045%20L5.51144105,11.8129903%20C5.70234462,12.0384575%206.03582177,12.0632342%206.25572336,11.8699765%20C6.27022237,11.8575882%206.28472138,11.8427223%206.29680387,11.8278563%20L16.146462,0.901366518%20C16.3325325,0.695720566%2016.3325325,0.37610216%2016.1440455,0.170456209%20C15.9555584,-0.0351897433%2015.6438297,-0.0574886986%2015.4287612,0.118425301%20L6.19289432,7.77687878%20C6.01407325,7.92553851%205.76275714,7.93792683%205.57185357,7.80908838%20L0.813763084,4.63520326%20C0.593861494,4.4890212%200.303881373,4.52866379%200.12989331,4.72935442%20C-0.0416782539,4.93004505%20-0.0440947695,5.22984216%200.127476811,5.43301045%20Z'%20id='路径'%3e%3c/path%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/svg%3e";
5911
6035
  const _hoisted_1$1 = { class: "jb-mobile-tree-select-popup__search" };
5912
6036
  const _hoisted_2$1 = { class: "jb-mobile-tree-select-popup__list" };
@@ -5924,50 +6048,91 @@ const _hoisted_8$1 = { class: "jb-mobile-tree-select-popup__bottom" };
5924
6048
  const _sfc_main$1 = /* @__PURE__ */ defineComponent({
5925
6049
  __name: "JbMobileTreeSelectPopup",
5926
6050
  props: {
6051
+ /**
6052
+ * 是否显示弹出层,可通过 v-model 进行双向数据绑定
6053
+ */
5927
6054
  visible: {
5928
6055
  type: Boolean,
5929
6056
  default: false
5930
6057
  },
6058
+ /**
6059
+ * 弹出层的高度
6060
+ */
5931
6061
  height: {
5932
6062
  type: Number,
5933
6063
  default: 554
5934
6064
  },
6065
+ /**
6066
+ * 弹出层的上边距
6067
+ */
5935
6068
  paddingTop: {
5936
6069
  type: Number,
5937
6070
  default: 0
5938
6071
  },
6072
+ /**
6073
+ * 树结构的数据
6074
+ */
5939
6075
  dataList: {
5940
- // 树结构的数据
5941
6076
  type: Array,
5942
- default: () => []
6077
+ default: []
5943
6078
  },
6079
+ /**
6080
+ * 搜索框的输入值,可通过 v-model 进行双向数据绑定
6081
+ */
5944
6082
  searchValue: {
5945
6083
  type: String,
5946
6084
  default: ""
5947
6085
  },
6086
+ /**
6087
+ * 搜索框的提示文案
6088
+ */
6089
+ searchInputPlaceholder: {
6090
+ type: String,
6091
+ default: "请输入"
6092
+ },
6093
+ /**
6094
+ * 树结构的自定义字段,可修改的字段有 label 、 value 和 child
6095
+ */
5948
6096
  fieldNames: {
5949
- // 自定义数据中 label、value、child 的字段
5950
6097
  type: Object,
5951
6098
  default: () => ({})
5952
6099
  },
6100
+ /**
6101
+ * 默认选择的树结构的值
6102
+ */
5953
6103
  defaultSelectedValue: {
5954
6104
  type: [Number, String],
5955
6105
  default: 0
5956
6106
  },
6107
+ /**
6108
+ * 树结构在选择父节点时,是否默认选择其第一个子节点
6109
+ */
5957
6110
  isAutoSelectFirstChildren: {
5958
6111
  type: Boolean,
5959
6112
  default: false
5960
6113
  },
5961
- placeholder: {
5962
- type: String,
5963
- default: "请输入搜索内容"
5964
- },
6114
+ /**
6115
+ * 是否显示选中状态的图标
6116
+ */
5965
6117
  isShowTickIcon: {
5966
6118
  type: Boolean,
5967
6119
  default: true
5968
6120
  }
5969
6121
  },
5970
- emits: ["update:visible", "update:searchValue", "confirm"],
6122
+ emits: [
6123
+ /**
6124
+ * 更新弹出层的显示状态
6125
+ */
6126
+ "update:visible",
6127
+ /**
6128
+ * 更新搜索框的输入值
6129
+ */
6130
+ "update:searchValue",
6131
+ /**
6132
+ * 点击确定按钮时触发,返回值为树结构当前选中的父节点数据及其对应选中的子节点数据
6133
+ */
6134
+ "confirm"
6135
+ ],
5971
6136
  setup(__props, { emit: __emit }) {
5972
6137
  const attrs = useAttrs();
5973
6138
  const emits = __emit;
@@ -6093,8 +6258,7 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
6093
6258
  show: visible.value,
6094
6259
  "onUpdate:show": _cache[1] || (_cache[1] = ($event) => visible.value = $event),
6095
6260
  style: {
6096
- height: `${__props.height}px`,
6097
- paddingTop: "0 !important"
6261
+ height: `${__props.height}px`
6098
6262
  }
6099
6263
  }), {
6100
6264
  default: withCtx(() => [
@@ -6107,8 +6271,8 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
6107
6271
  createVNode(JbMobileSearchInput, {
6108
6272
  modelValue: searchValue.value,
6109
6273
  "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => searchValue.value = $event),
6110
- placeholder: "搜索地区、项目名称"
6111
- }, null, 8, ["modelValue"])
6274
+ placeholder: __props.searchInputPlaceholder
6275
+ }, null, 8, ["modelValue", "placeholder"])
6112
6276
  ]),
6113
6277
  createElementVNode("div", _hoisted_2$1, [
6114
6278
  createElementVNode("div", {
@@ -6180,7 +6344,7 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
6180
6344
  };
6181
6345
  }
6182
6346
  });
6183
- const JbMobileTreeSelectPopup = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["__scopeId", "data-v-a71c98bd"]]);
6347
+ const JbMobileTreeSelectPopup = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["__scopeId", "data-v-91350e16"]]);
6184
6348
  const dropDownIcon = "data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20width='16px'%20height='16px'%20viewBox='0%200%2016%2016'%20version='1.1'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3ctitle%3e图标(16)/下拉%3c/title%3e%3cg%20id='页面-1'%20stroke='none'%20stroke-width='1'%20fill='none'%20fill-rule='evenodd'%3e%3cg%20id='选择得分'%20transform='translate(-96,%20-106)'%3e%3cg%20id='编组-5'%20transform='translate(0,%2092)'%3e%3cg%20id='编组-3'%20transform='translate(13,%2012)'%3e%3cg%20id='图标(16)/下拉'%20transform='translate(83,%202)'%3e%3crect%20id='矩形'%20x='0'%20y='0'%20width='16'%20height='16'%3e%3c/rect%3e%3cg%20id='编组'%20transform='translate(8,%208)%20scale(-1,%20-1)%20rotate(-270)%20translate(-8,%20-8)translate(6.5,%205)'%20fill='%23666666'%20fill-rule='nonzero'%20stroke='%23666666'%20stroke-linejoin='round'%3e%3cpolygon%20id='路径'%20points='3%206%200%203%203%200'%3e%3c/polygon%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/svg%3e";
6185
6349
  const dropDownIconSelected = "data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20width='16px'%20height='16px'%20viewBox='0%200%2016%2016'%20version='1.1'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3ctitle%3e图标(16)/下拉%3c/title%3e%3cg%20id='页面-1'%20stroke='none'%20stroke-width='1'%20fill='none'%20fill-rule='evenodd'%3e%3cg%20id='选择得分'%20transform='translate(-226,%20-106)'%3e%3cg%20id='编组-6'%20transform='translate(127,%2092)'%3e%3cg%20id='编组-3备份'%20transform='translate(11,%2012)'%3e%3cg%20id='图标(16)/下拉'%20transform='translate(88,%202)'%3e%3crect%20id='矩形'%20x='0'%20y='0'%20width='16'%20height='16'%3e%3c/rect%3e%3cg%20id='编组'%20transform='translate(8,%208)%20scale(-1,%20-1)%20rotate(-270)%20translate(-8,%20-8)translate(6.5,%205)'%20fill='%237B52FE'%20fill-rule='nonzero'%20stroke='%237B52FE'%20stroke-linejoin='round'%3e%3cpolygon%20id='路径'%20transform='translate(1.5,%203)%20scale(-1,%201)%20translate(-1.5,%20-3)'%20points='3%206%200%203%203%200'%3e%3c/polygon%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/svg%3e";
6186
6350
  const sortIconNormal = "data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20width='16px'%20height='16px'%20viewBox='0%200%2016%2016'%20version='1.1'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3ctitle%3e图标(16)/下拉%3c/title%3e%3cg%20id='页面-1'%20stroke='none'%20stroke-width='1'%20fill='none'%20fill-rule='evenodd'%3e%3cg%20id='选择地区'%20transform='translate(-321,%20-106)'%3e%3cg%20id='编组-7'%20transform='translate(250,%2092)'%3e%3cg%20id='编组-3备份-2'%20transform='translate(39,%2012)'%3e%3cg%20id='图标(16)/下拉'%20transform='translate(32,%202)'%3e%3crect%20id='矩形'%20x='0'%20y='0'%20width='16'%20height='16'%3e%3c/rect%3e%3cg%20id='编组'%20transform='translate(8,%2011)%20scale(-1,%20-1)%20rotate(-270)%20translate(-8,%20-11)translate(6.5,%208)'%20fill='%23666666'%20fill-rule='nonzero'%20stroke='%23666666'%20stroke-linejoin='round'%3e%3cpolygon%20id='路径'%20points='3%206%200%203%203%200'%3e%3c/polygon%3e%3c/g%3e%3cg%20id='编组'%20transform='translate(8,%205)%20rotate(-270)%20translate(-8,%20-5)translate(6.5,%202)'%20fill='%23666666'%20fill-rule='nonzero'%20stroke='%23666666'%20stroke-linejoin='round'%3e%3cpolygon%20id='路径'%20points='3%206%200%203%203%200'%3e%3c/polygon%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/svg%3e";
@@ -6201,16 +6365,27 @@ const _hoisted_9 = { class: "jb-mobile-filter__select-popup__list__label ellipsi
6201
6365
  const _sfc_main = /* @__PURE__ */ defineComponent({
6202
6366
  __name: "JbMobileFilter",
6203
6367
  props: {
6368
+ /**
6369
+ * 筛选项列表
6370
+ */
6204
6371
  filterList: {
6205
6372
  type: Array,
6206
- default: () => []
6373
+ default: []
6207
6374
  },
6375
+ /**
6376
+ * 异步加载筛选项下拉列表数据的回调函数,在组件挂载后并设置默认选择的筛选项前会调用该函数
6377
+ */
6208
6378
  asyncLoadFilterList: {
6209
6379
  type: Function,
6210
- default: () => []
6380
+ default: () => void 0
6211
6381
  }
6212
6382
  },
6213
- emits: ["confirm"],
6383
+ emits: [
6384
+ /**
6385
+ * 选择某个筛选项的值时触发,返回值为当前每一个筛选项选中值按筛选项列表顺序所组成的数组
6386
+ */
6387
+ "confirm"
6388
+ ],
6214
6389
  setup(__props, { emit: __emit }) {
6215
6390
  const emits = __emit;
6216
6391
  const props = __props;
@@ -6372,7 +6547,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
6372
6547
  };
6373
6548
  }
6374
6549
  });
6375
- const JbMobileFilter = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-e81f4e7e"]]);
6550
+ const JbMobileFilter = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-7f018b18"]]);
6376
6551
  var freeGlobal = typeof global == "object" && global && global.Object === Object && global;
6377
6552
  var freeSelf = typeof self == "object" && self && self.Object === Object && self;
6378
6553
  var root = freeGlobal || freeSelf || Function("return this")();
@@ -6563,7 +6738,6 @@ function useInfiniteScroll(options = {}) {
6563
6738
  bottomThreshold = 100,
6564
6739
  topThreshold = 100,
6565
6740
  throttleDelay = 300,
6566
- scrollDirectionThreshold = 5,
6567
6741
  disabled = ref(false),
6568
6742
  onLoadMore,
6569
6743
  onLoadPrevious,
@@ -6574,14 +6748,12 @@ function useInfiniteScroll(options = {}) {
6574
6748
  const isLoadingPrevious = ref(false);
6575
6749
  const hasMoreData = ref(true);
6576
6750
  const hasPreviousData = ref(true);
6577
- const isProcessingScroll = ref(false);
6578
6751
  let lastScrollTop = 0;
6579
6752
  const executeLoadMore = async () => {
6580
6753
  if (isLoadingMore.value || !hasMoreData.value || !onLoadMore) {
6581
6754
  return;
6582
6755
  }
6583
6756
  isLoadingMore.value = true;
6584
- isProcessingScroll.value = true;
6585
6757
  try {
6586
6758
  await onLoadMore();
6587
6759
  if (debug) console.log("✅ 向下加载更多完成");
@@ -6589,7 +6761,6 @@ function useInfiniteScroll(options = {}) {
6589
6761
  console.error("❌ 向下加载更多失败:", error);
6590
6762
  } finally {
6591
6763
  isLoadingMore.value = false;
6592
- isProcessingScroll.value = false;
6593
6764
  }
6594
6765
  };
6595
6766
  const executeLoadPrevious = async () => {
@@ -6597,7 +6768,6 @@ function useInfiniteScroll(options = {}) {
6597
6768
  return;
6598
6769
  }
6599
6770
  isLoadingPrevious.value = true;
6600
- isProcessingScroll.value = true;
6601
6771
  try {
6602
6772
  await onLoadPrevious();
6603
6773
  if (debug) console.log("✅ 向上加载完成");
@@ -6605,11 +6775,10 @@ function useInfiniteScroll(options = {}) {
6605
6775
  console.error("❌ 向上加载失败:", error);
6606
6776
  } finally {
6607
6777
  isLoadingPrevious.value = false;
6608
- isProcessingScroll.value = false;
6609
6778
  }
6610
6779
  };
6611
6780
  const handleScroll = throttle(async (event) => {
6612
- if (disabled.value || isProcessingScroll.value) return;
6781
+ if (disabled.value) return;
6613
6782
  const target = event.target;
6614
6783
  if (!target) return;
6615
6784
  const { scrollTop, scrollHeight, clientHeight } = target;
@@ -6618,18 +6787,12 @@ function useInfiniteScroll(options = {}) {
6618
6787
  const isNearBottom = distanceToBottom < bottomThreshold;
6619
6788
  const isNearTop = distanceToTop < topThreshold;
6620
6789
  let scrollDirection = "none";
6621
- const scrollDelta = scrollTop - lastScrollTop;
6622
- if (Math.abs(scrollDelta) > scrollDirectionThreshold) {
6623
- if (scrollDelta > 0) {
6624
- scrollDirection = "down";
6625
- } else {
6626
- scrollDirection = "up";
6627
- }
6628
- lastScrollTop = scrollTop;
6629
- if (debug) {
6630
- console.log(`🔄 滚动方向变化: ${scrollDirection}, 滚动距离: ${scrollDelta}px`);
6631
- }
6790
+ if (scrollTop > lastScrollTop) {
6791
+ scrollDirection = "down";
6792
+ } else if (scrollTop < lastScrollTop) {
6793
+ scrollDirection = "up";
6632
6794
  }
6795
+ lastScrollTop = scrollTop;
6633
6796
  const scrollInfo = {
6634
6797
  scrollTop,
6635
6798
  scrollHeight,
@@ -6642,15 +6805,14 @@ function useInfiniteScroll(options = {}) {
6642
6805
  };
6643
6806
  if (debug) {
6644
6807
  console.log("📊 滚动信息:", scrollInfo);
6645
- console.log(`🔄 加载状态: 向下加载=${isLoadingMore.value}, 向上加载=${isLoadingPrevious.value}, 处理中=${isProcessingScroll.value}`);
6646
6808
  }
6647
6809
  if (isNearBottom && scrollDirection === "down") {
6648
6810
  if (debug) console.log("🔽 触发向下加载");
6649
- executeLoadMore();
6811
+ await executeLoadMore();
6650
6812
  }
6651
6813
  if (isNearTop && scrollDirection === "up") {
6652
6814
  if (debug) console.log("🔼 触发向上加载");
6653
- executeLoadPrevious();
6815
+ await executeLoadPrevious();
6654
6816
  }
6655
6817
  scrollInfoRef.value = scrollInfo;
6656
6818
  }, throttleDelay);
@@ -6659,7 +6821,6 @@ function useInfiniteScroll(options = {}) {
6659
6821
  isLoadingPrevious.value = false;
6660
6822
  hasMoreData.value = true;
6661
6823
  hasPreviousData.value = true;
6662
- isProcessingScroll.value = false;
6663
6824
  lastScrollTop = 0;
6664
6825
  };
6665
6826
  const triggerLoadMore = async () => {
@@ -6714,6 +6875,17 @@ const useGlobalLoading = () => {
6714
6875
  };
6715
6876
  });
6716
6877
  };
6878
+ const install = (app) => {
6879
+ app.component("JbMobileButton", JbMobileButton);
6880
+ app.component("JbMobileDatePicker", JbMobileDatePicker);
6881
+ app.component("JbMobileEmpty", JbMobileEmpty);
6882
+ app.component("JbMobilePopup", JbMobilePopup);
6883
+ app.component("JbMobileSearchInput", JbMobileSearchInput);
6884
+ app.component("JbMobileSelect", JbMobileSelect);
6885
+ app.component("JbMobileTimePicker", JbMobileTimePicker);
6886
+ app.component("JbMobileTreeSelectPopup", JbMobileTreeSelectPopup);
6887
+ app.component("JbMobileFilter", JbMobileFilter);
6888
+ };
6717
6889
  export {
6718
6890
  JbMobileButton,
6719
6891
  JbMobileDatePicker,
@@ -6725,6 +6897,7 @@ export {
6725
6897
  JbMobileTimePicker,
6726
6898
  JbMobileTreeSelectPopup,
6727
6899
  checkHasSafeAreaInsetBottom,
6900
+ install as default,
6728
6901
  useGlobalLoading,
6729
6902
  useInfiniteScroll
6730
6903
  };