jb-mobile-ui 1.3.12 → 1.4.0

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
@@ -4703,7 +4703,7 @@ var stdin_default = defineComponent({
4703
4703
  }
4704
4704
  });
4705
4705
  const Calendar = withInstall(stdin_default);
4706
- const _sfc_main$8 = /* @__PURE__ */ defineComponent({
4706
+ const _sfc_main$9 = /* @__PURE__ */ defineComponent({
4707
4707
  __name: "JbMobileButton",
4708
4708
  setup(__props) {
4709
4709
  const attrs = useAttrs();
@@ -4725,7 +4725,7 @@ const _export_sfc = (sfc, props) => {
4725
4725
  }
4726
4726
  return target;
4727
4727
  };
4728
- const JbMobileButton = /* @__PURE__ */ _export_sfc(_sfc_main$8, [["__scopeId", "data-v-177e5e3b"]]);
4728
+ const JbMobileButton = /* @__PURE__ */ _export_sfc(_sfc_main$9, [["__scopeId", "data-v-177e5e3b"]]);
4729
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
4730
  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
4731
  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";
@@ -4738,8 +4738,8 @@ const checkHasSafeAreaInsetBottom = () => {
4738
4738
  document.body.removeChild(div);
4739
4739
  return height2 > 0;
4740
4740
  };
4741
- const _hoisted_1$7 = { class: "jb-mobile-popup__header" };
4742
- const _sfc_main$7 = /* @__PURE__ */ defineComponent({
4741
+ const _hoisted_1$8 = { class: "jb-mobile-popup__header" };
4742
+ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
4743
4743
  __name: "JbMobilePopup",
4744
4744
  props: {
4745
4745
  visible: {
@@ -4814,7 +4814,7 @@ const _sfc_main$7 = /* @__PURE__ */ defineComponent({
4814
4814
  onClosed: handleClose
4815
4815
  }), {
4816
4816
  default: withCtx(() => [
4817
- createElementVNode("div", _hoisted_1$7, [
4817
+ createElementVNode("div", _hoisted_1$8, [
4818
4818
  createElementVNode("div", null, toDisplayString(__props.title), 1),
4819
4819
  createElementVNode("div", {
4820
4820
  class: "jb-mobile-popup__close-icon",
@@ -4856,21 +4856,21 @@ const _sfc_main$7 = /* @__PURE__ */ defineComponent({
4856
4856
  };
4857
4857
  }
4858
4858
  });
4859
- const JbMobilePopup = /* @__PURE__ */ _export_sfc(_sfc_main$7, [["__scopeId", "data-v-a33d40ee"]]);
4860
- const _hoisted_1$6 = {
4859
+ const JbMobilePopup = /* @__PURE__ */ _export_sfc(_sfc_main$8, [["__scopeId", "data-v-29e15451"]]);
4860
+ const _hoisted_1$7 = {
4861
4861
  key: 0,
4862
4862
  class: "jb-mobile-date-picker"
4863
4863
  };
4864
- const _hoisted_2$5 = { class: "jb-mobile-date-picker__value" };
4865
- const _hoisted_3$3 = ["src"];
4866
- const _hoisted_4$2 = { class: "jb-mobile-time-picker__calendar__inner" };
4867
- const _hoisted_5$1 = { class: "jb-mobile-time-picker__group-wrap" };
4868
- const _hoisted_6$1 = {
4864
+ const _hoisted_2$6 = { class: "jb-mobile-date-picker__value" };
4865
+ const _hoisted_3$4 = ["src"];
4866
+ const _hoisted_4$3 = { class: "jb-mobile-time-picker__calendar__inner" };
4867
+ const _hoisted_5$2 = { class: "jb-mobile-time-picker__group-wrap" };
4868
+ const _hoisted_6$2 = {
4869
4869
  key: 0,
4870
4870
  class: "jb-mobile-time-picker__group__title"
4871
4871
  };
4872
- const _hoisted_7$1 = ["onClick"];
4873
- const _sfc_main$6 = /* @__PURE__ */ defineComponent({
4872
+ const _hoisted_7$2 = ["onClick"];
4873
+ const _sfc_main$7 = /* @__PURE__ */ defineComponent({
4874
4874
  __name: "JbMobileTimePicker",
4875
4875
  props: {
4876
4876
  visible: {
@@ -5364,7 +5364,7 @@ const _sfc_main$6 = /* @__PURE__ */ defineComponent({
5364
5364
  ref: timePickerContentRef,
5365
5365
  class: "time-picker__content"
5366
5366
  }, [
5367
- __props.withSelectTab ? (openBlock(), createElementBlock("div", _hoisted_1$6, [
5367
+ __props.withSelectTab ? (openBlock(), createElementBlock("div", _hoisted_1$7, [
5368
5368
  createVNode(_component_van_tabs, {
5369
5369
  active: timePickerType.value,
5370
5370
  "onUpdate:active": _cache[0] || (_cache[0] = ($event) => timePickerType.value = $event),
@@ -5385,7 +5385,7 @@ const _sfc_main$6 = /* @__PURE__ */ defineComponent({
5385
5385
  ]),
5386
5386
  _: 1
5387
5387
  }, 8, ["active"]),
5388
- createElementVNode("div", _hoisted_2$5, [
5388
+ createElementVNode("div", _hoisted_2$6, [
5389
5389
  timePickerType.value !== "dateRange" ? (openBlock(), createElementBlock("div", {
5390
5390
  key: 0,
5391
5391
  class: "jb-mobile-date-picker__date-arrow left",
@@ -5411,7 +5411,7 @@ const _sfc_main$6 = /* @__PURE__ */ defineComponent({
5411
5411
  createElementVNode("img", {
5412
5412
  src: forwardIcon.value,
5413
5413
  alt: "forward"
5414
- }, null, 8, _hoisted_3$3)
5414
+ }, null, 8, _hoisted_3$4)
5415
5415
  ])) : createCommentVNode("", true)
5416
5416
  ])
5417
5417
  ])) : createCommentVNode("", true),
@@ -5434,19 +5434,19 @@ const _sfc_main$6 = /* @__PURE__ */ defineComponent({
5434
5434
  onConfirm: handleFinishSelectDate
5435
5435
  }, {
5436
5436
  text: withCtx(({ text }) => [
5437
- createElementVNode("div", _hoisted_4$2, toDisplayString(text), 1)
5437
+ createElementVNode("div", _hoisted_4$3, toDisplayString(text), 1)
5438
5438
  ]),
5439
5439
  _: 1
5440
5440
  }, 8, ["type", "min-date", "max-date", "default-date"]), [
5441
5441
  [vShow, isShowCalendar.value]
5442
5442
  ]),
5443
- withDirectives(createElementVNode("div", _hoisted_5$1, [
5443
+ withDirectives(createElementVNode("div", _hoisted_5$2, [
5444
5444
  (openBlock(true), createElementBlock(Fragment, null, renderList(timePickerTypeObj.value.timeList, (item) => {
5445
5445
  return openBlock(), createElementBlock("div", {
5446
5446
  key: item.value,
5447
5447
  class: "jb-mobile-time-picker__group"
5448
5448
  }, [
5449
- item.title ? (openBlock(), createElementBlock("div", _hoisted_6$1, toDisplayString(item.title), 1)) : createCommentVNode("", true),
5449
+ item.title ? (openBlock(), createElementBlock("div", _hoisted_6$2, toDisplayString(item.title), 1)) : createCommentVNode("", true),
5450
5450
  createElementVNode("div", {
5451
5451
  class: normalizeClass$1(["jb-mobile-time-picker__group__list", { "three-in-row": timePickerType.value === "year" }])
5452
5452
  }, [
@@ -5455,7 +5455,7 @@ const _sfc_main$6 = /* @__PURE__ */ defineComponent({
5455
5455
  key: subItem.value,
5456
5456
  class: normalizeClass$1(["jb-mobile-time-picker__group__list-item", { selected: subItem.value === selectedTimeValue.value }]),
5457
5457
  onClick: ($event) => handleSelectDateItem(subItem.value)
5458
- }, toDisplayString(subItem.label), 11, _hoisted_7$1);
5458
+ }, toDisplayString(subItem.label), 11, _hoisted_7$2);
5459
5459
  }), 128))
5460
5460
  ], 2)
5461
5461
  ]);
@@ -5470,11 +5470,11 @@ const _sfc_main$6 = /* @__PURE__ */ defineComponent({
5470
5470
  };
5471
5471
  }
5472
5472
  });
5473
- const JbMobileTimePicker = /* @__PURE__ */ _export_sfc(_sfc_main$6, [["__scopeId", "data-v-eb416205"]]);
5474
- const _hoisted_1$5 = { class: "jb-mobile-date-picker" };
5475
- const _hoisted_2$4 = { class: "jb-mobile-date-picker__value" };
5476
- const _hoisted_3$2 = ["src"];
5477
- const _sfc_main$5 = /* @__PURE__ */ defineComponent({
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" };
5476
+ const _hoisted_3$3 = ["src"];
5477
+ const _sfc_main$6 = /* @__PURE__ */ defineComponent({
5478
5478
  __name: "JbMobileDatePicker",
5479
5479
  props: {
5480
5480
  datePickerType: {
@@ -5589,7 +5589,7 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5589
5589
  const _component_van_tab = Tab;
5590
5590
  const _component_van_tabs = Tabs;
5591
5591
  const _component_van_icon = Icon;
5592
- return openBlock(), createElementBlock("div", _hoisted_1$5, [
5592
+ return openBlock(), createElementBlock("div", _hoisted_1$6, [
5593
5593
  __props.showDatePickerType ? (openBlock(), createBlock(_component_van_tabs, {
5594
5594
  key: 0,
5595
5595
  active: datePickerType.value,
@@ -5611,7 +5611,7 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5611
5611
  ]),
5612
5612
  _: 1
5613
5613
  }, 8, ["active"])) : createCommentVNode("", true),
5614
- createElementVNode("div", _hoisted_2$4, [
5614
+ createElementVNode("div", _hoisted_2$5, [
5615
5615
  datePickerType.value !== "dateRange" ? (openBlock(), createElementBlock("div", {
5616
5616
  key: 0,
5617
5617
  class: "jb-mobile-date-picker__date-arrow left",
@@ -5637,7 +5637,7 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5637
5637
  createElementVNode("img", {
5638
5638
  src: forwardIcon.value,
5639
5639
  alt: "forward"
5640
- }, null, 8, _hoisted_3$2)
5640
+ }, null, 8, _hoisted_3$3)
5641
5641
  ])) : createCommentVNode("", true)
5642
5642
  ]),
5643
5643
  createVNode(JbMobileTimePicker, mergeProps({
@@ -5654,11 +5654,11 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5654
5654
  };
5655
5655
  }
5656
5656
  });
5657
- const JbMobileDatePicker = /* @__PURE__ */ _export_sfc(_sfc_main$5, [["__scopeId", "data-v-4b9c26a6"]]);
5657
+ const JbMobileDatePicker = /* @__PURE__ */ _export_sfc(_sfc_main$6, [["__scopeId", "data-v-4b9c26a6"]]);
5658
5658
  const _imports_0$4 = "";
5659
- const _hoisted_1$4 = { class: "jb-mobile-empty" };
5660
- const _hoisted_2$3 = { class: "jb-mobile-empty__tip" };
5661
- const _sfc_main$4 = /* @__PURE__ */ defineComponent({
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({
5662
5662
  __name: "JbMobileEmpty",
5663
5663
  props: {
5664
5664
  tip: {
@@ -5668,23 +5668,23 @@ const _sfc_main$4 = /* @__PURE__ */ defineComponent({
5668
5668
  },
5669
5669
  setup(__props) {
5670
5670
  return (_ctx, _cache) => {
5671
- return openBlock(), createElementBlock("div", _hoisted_1$4, [
5671
+ return openBlock(), createElementBlock("div", _hoisted_1$5, [
5672
5672
  _cache[0] || (_cache[0] = createElementVNode("img", {
5673
5673
  class: "jb-mobile-empty__img",
5674
5674
  src: _imports_0$4,
5675
5675
  alt: ""
5676
5676
  }, null, -1)),
5677
- createElementVNode("div", _hoisted_2$3, toDisplayString(__props.tip), 1),
5677
+ createElementVNode("div", _hoisted_2$4, toDisplayString(__props.tip), 1),
5678
5678
  renderSlot(_ctx.$slots, "default", {}, void 0, true)
5679
5679
  ]);
5680
5680
  };
5681
5681
  }
5682
5682
  });
5683
- const JbMobileEmpty = /* @__PURE__ */ _export_sfc(_sfc_main$4, [["__scopeId", "data-v-e1f68e36"]]);
5683
+ const JbMobileEmpty = /* @__PURE__ */ _export_sfc(_sfc_main$5, [["__scopeId", "data-v-e1f68e36"]]);
5684
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$3 = { class: "jb-mobile-search-input" };
5686
- const _hoisted_2$2 = ["placeholder"];
5687
- const _sfc_main$3 = /* @__PURE__ */ defineComponent({
5685
+ const _hoisted_1$4 = { class: "jb-mobile-search-input" };
5686
+ const _hoisted_2$3 = ["placeholder"];
5687
+ const _sfc_main$4 = /* @__PURE__ */ defineComponent({
5688
5688
  __name: "JbMobileSearchInput",
5689
5689
  props: {
5690
5690
  showBtn: {
@@ -5716,7 +5716,7 @@ const _sfc_main$3 = /* @__PURE__ */ defineComponent({
5716
5716
  }
5717
5717
  });
5718
5718
  return (_ctx, _cache) => {
5719
- return openBlock(), createElementBlock("div", _hoisted_1$3, [
5719
+ return openBlock(), createElementBlock("div", _hoisted_1$4, [
5720
5720
  _cache[2] || (_cache[2] = createElementVNode("img", {
5721
5721
  class: "jb-mobile-search-input__search-icon",
5722
5722
  src: _imports_0$3,
@@ -5725,7 +5725,7 @@ const _sfc_main$3 = /* @__PURE__ */ defineComponent({
5725
5725
  withDirectives(createElementVNode("input", mergeProps({
5726
5726
  class: "jb-mobile-search-input__inner",
5727
5727
  "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => inputValue.value = $event)
5728
- }, unref(attrs), { placeholder: placeholder.value }), null, 16, _hoisted_2$2), [
5728
+ }, unref(attrs), { placeholder: placeholder.value }), null, 16, _hoisted_2$3), [
5729
5729
  [vModelDynamic, inputValue.value]
5730
5730
  ]),
5731
5731
  showBtn.value ? (openBlock(), createBlock(JbMobileButton, {
@@ -5745,11 +5745,11 @@ const _sfc_main$3 = /* @__PURE__ */ defineComponent({
5745
5745
  };
5746
5746
  }
5747
5747
  });
5748
- const JbMobileSearchInput = /* @__PURE__ */ _export_sfc(_sfc_main$3, [["__scopeId", "data-v-5d5a1d36"]]);
5748
+ const JbMobileSearchInput = /* @__PURE__ */ _export_sfc(_sfc_main$4, [["__scopeId", "data-v-5d5a1d36"]]);
5749
5749
  const _imports_0$2 = "";
5750
5750
  const _imports_0$1 = "";
5751
- const _hoisted_1$2 = { class: "mobile-select-face" };
5752
- const _sfc_main$2 = /* @__PURE__ */ defineComponent({
5751
+ const _hoisted_1$3 = { class: "mobile-select-face" };
5752
+ const _sfc_main$3 = /* @__PURE__ */ defineComponent({
5753
5753
  __name: "JbMobileSelectFace",
5754
5754
  props: {
5755
5755
  slotClick: { type: Function }
@@ -5760,7 +5760,7 @@ const _sfc_main$2 = /* @__PURE__ */ defineComponent({
5760
5760
  props.slotClick && props.slotClick();
5761
5761
  };
5762
5762
  return (_ctx, _cache) => {
5763
- return openBlock(), createElementBlock("div", _hoisted_1$2, [
5763
+ return openBlock(), createElementBlock("div", _hoisted_1$3, [
5764
5764
  renderSlot(_ctx.$slots, "default", {
5765
5765
  onClick: withModifiers(handleClickSlot, ["stop"])
5766
5766
  }, void 0, true),
@@ -5773,18 +5773,18 @@ const _sfc_main$2 = /* @__PURE__ */ defineComponent({
5773
5773
  };
5774
5774
  }
5775
5775
  });
5776
- const JbMobileSelectFace = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["__scopeId", "data-v-11ebc006"]]);
5777
- const _hoisted_1$1 = { class: "jb-mobile-select__value" };
5778
- const _hoisted_2$1 = {
5776
+ const JbMobileSelectFace = /* @__PURE__ */ _export_sfc(_sfc_main$3, [["__scopeId", "data-v-11ebc006"]]);
5777
+ const _hoisted_1$2 = { class: "jb-mobile-select__value" };
5778
+ const _hoisted_2$2 = {
5779
5779
  key: 0,
5780
5780
  class: "jb-mobile-select__option-list"
5781
5781
  };
5782
- const _hoisted_3$1 = ["onClick"];
5783
- const _hoisted_4$1 = {
5782
+ const _hoisted_3$2 = ["onClick"];
5783
+ const _hoisted_4$2 = {
5784
5784
  key: 1,
5785
5785
  class: "jb-mobile-select__empty-wrap"
5786
5786
  };
5787
- const _sfc_main$1 = /* @__PURE__ */ defineComponent({
5787
+ const _sfc_main$2 = /* @__PURE__ */ defineComponent({
5788
5788
  __name: "JbMobileSelect",
5789
5789
  props: {
5790
5790
  // 当tabIndex == 0 时,选中第一个选项,则显示普通的select样式,如果为1,则显示/ComplaintAnalysis/dialog的样式
@@ -5863,7 +5863,7 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
5863
5863
  style: normalizeStyle$1({ width: computedWidth.value }),
5864
5864
  onClick: _cache[0] || (_cache[0] = ($event) => isShowOptionsPopup.value = true)
5865
5865
  }, [
5866
- createElementVNode("div", _hoisted_1$1, toDisplayString(selectedOptionItem.value[fieldNames.value.label] || __props.placeholder), 1),
5866
+ createElementVNode("div", _hoisted_1$2, toDisplayString(selectedOptionItem.value[fieldNames.value.label] || __props.placeholder), 1),
5867
5867
  _cache[3] || (_cache[3] = createElementVNode("img", {
5868
5868
  class: "jb-mobile-select__select-down-icon",
5869
5869
  src: _imports_0$2,
@@ -5885,18 +5885,18 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
5885
5885
  title: __props.popupTitle,
5886
5886
  "grey-bg": true,
5887
5887
  "foot-button": false,
5888
- height: 434
5888
+ "content-height": 434
5889
5889
  }), {
5890
5890
  default: withCtx(() => [
5891
- __props.options.length ? (openBlock(), createElementBlock("div", _hoisted_2$1, [
5891
+ __props.options.length ? (openBlock(), createElementBlock("div", _hoisted_2$2, [
5892
5892
  (openBlock(true), createElementBlock(Fragment, null, renderList(__props.options, (item) => {
5893
5893
  return openBlock(), createElementBlock("div", {
5894
5894
  class: normalizeClass$1(["jb-mobile-select__option-item", { selected: item[fieldNames.value.value] === modelValue.value }]),
5895
5895
  key: item[fieldNames.value.value],
5896
5896
  onClick: ($event) => handleSelectOptionItem(item)
5897
- }, toDisplayString(item[fieldNames.value.label]), 11, _hoisted_3$1);
5897
+ }, toDisplayString(item[fieldNames.value.label]), 11, _hoisted_3$2);
5898
5898
  }), 128))
5899
- ])) : (openBlock(), createElementBlock("div", _hoisted_4$1, [
5899
+ ])) : (openBlock(), createElementBlock("div", _hoisted_4$2, [
5900
5900
  createVNode(JbMobileEmpty)
5901
5901
  ]))
5902
5902
  ]),
@@ -5906,22 +5906,22 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
5906
5906
  };
5907
5907
  }
5908
5908
  });
5909
- const JbMobileSelect = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["__scopeId", "data-v-d4d431ae"]]);
5909
+ const JbMobileSelect = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["__scopeId", "data-v-9ba900fa"]]);
5910
5910
  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
- const _hoisted_1 = { class: "jb-mobile-tree-select-popup__search" };
5912
- const _hoisted_2 = { class: "jb-mobile-tree-select-popup__list" };
5913
- const _hoisted_3 = ["onClick"];
5914
- const _hoisted_4 = { class: "ellipsis" };
5915
- const _hoisted_5 = ["onClick"];
5916
- const _hoisted_6 = { class: "jb-mobile-tree-select-popup__list__right-item__value ellipsis" };
5917
- const _hoisted_7 = {
5911
+ const _hoisted_1$1 = { class: "jb-mobile-tree-select-popup__search" };
5912
+ const _hoisted_2$1 = { class: "jb-mobile-tree-select-popup__list" };
5913
+ const _hoisted_3$1 = ["onClick"];
5914
+ const _hoisted_4$1 = { class: "ellipsis" };
5915
+ const _hoisted_5$1 = ["onClick"];
5916
+ const _hoisted_6$1 = { class: "jb-mobile-tree-select-popup__list__right-item__value ellipsis" };
5917
+ const _hoisted_7$1 = {
5918
5918
  key: 0,
5919
5919
  class: "jb-mobile-tree-select-popup__list__tick-icon",
5920
5920
  src: _imports_0,
5921
5921
  alt: ""
5922
5922
  };
5923
- const _hoisted_8 = { class: "jb-mobile-tree-select-popup__bottom" };
5924
- const _sfc_main = /* @__PURE__ */ defineComponent({
5923
+ const _hoisted_8$1 = { class: "jb-mobile-tree-select-popup__bottom" };
5924
+ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
5925
5925
  __name: "JbMobileTreeSelectPopup",
5926
5926
  props: {
5927
5927
  visible: {
@@ -6103,14 +6103,14 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
6103
6103
  }, [
6104
6104
  renderSlot(_ctx.$slots, "curr-value", {}, void 0, true)
6105
6105
  ], 4),
6106
- createElementVNode("div", _hoisted_1, [
6106
+ createElementVNode("div", _hoisted_1$1, [
6107
6107
  createVNode(JbMobileSearchInput, {
6108
6108
  modelValue: searchValue.value,
6109
6109
  "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => searchValue.value = $event),
6110
6110
  placeholder: "搜索地区、项目名称"
6111
6111
  }, null, 8, ["modelValue"])
6112
6112
  ]),
6113
- createElementVNode("div", _hoisted_2, [
6113
+ createElementVNode("div", _hoisted_2$1, [
6114
6114
  createElementVNode("div", {
6115
6115
  ref_key: "leftScrollRef",
6116
6116
  ref: leftScrollRef,
@@ -6125,11 +6125,11 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
6125
6125
  _cache[2] || (_cache[2] = createElementVNode("div", { class: "arc top" }, [
6126
6126
  createElementVNode("div", { class: "inner" })
6127
6127
  ], -1)),
6128
- createElementVNode("div", _hoisted_4, toDisplayString(item[fieldNames.value.label]), 1),
6128
+ createElementVNode("div", _hoisted_4$1, toDisplayString(item[fieldNames.value.label]), 1),
6129
6129
  _cache[3] || (_cache[3] = createElementVNode("div", { class: "arc bottom" }, [
6130
6130
  createElementVNode("div", { class: "inner" })
6131
6131
  ], -1))
6132
- ], 10, _hoisted_3);
6132
+ ], 10, _hoisted_3$1);
6133
6133
  }), 128))
6134
6134
  ], 512),
6135
6135
  createElementVNode("div", {
@@ -6143,13 +6143,13 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
6143
6143
  class: normalizeClass$1(["jb-mobile-tree-select-popup__list__right-item", { selected: currentSelectedRightItem.value[fieldNames.value.value] === item[fieldNames.value.value] }]),
6144
6144
  onClick: ($event) => handleSelectRightItem(item)
6145
6145
  }, [
6146
- createElementVNode("div", _hoisted_6, toDisplayString(item[fieldNames.value.label]), 1),
6147
- props.isShowTickIcon ? (openBlock(), createElementBlock("img", _hoisted_7)) : createCommentVNode("", true)
6148
- ], 10, _hoisted_5);
6146
+ createElementVNode("div", _hoisted_6$1, toDisplayString(item[fieldNames.value.label]), 1),
6147
+ props.isShowTickIcon ? (openBlock(), createElementBlock("img", _hoisted_7$1)) : createCommentVNode("", true)
6148
+ ], 10, _hoisted_5$1);
6149
6149
  }), 128))
6150
6150
  ], 512)
6151
6151
  ]),
6152
- createElementVNode("div", _hoisted_8, [
6152
+ createElementVNode("div", _hoisted_8$1, [
6153
6153
  createVNode(JbMobileButton, {
6154
6154
  block: "",
6155
6155
  round: "",
@@ -6180,7 +6180,199 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
6180
6180
  };
6181
6181
  }
6182
6182
  });
6183
- const JbMobileTreeSelectPopup = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-a71c98bd"]]);
6183
+ const JbMobileTreeSelectPopup = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["__scopeId", "data-v-a71c98bd"]]);
6184
+ 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
+ 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
+ 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";
6187
+ const sortIconAsc = "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='%237B52FE'%20fill-rule='nonzero'%20stroke='%237B52FE'%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";
6188
+ const sortIconDesc = "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='%237B52FE'%20fill-rule='nonzero'%20stroke='%237B52FE'%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";
6189
+ const _hoisted_1 = { class: "jb-mobile-filter" };
6190
+ const _hoisted_2 = { class: "jb-mobile-filter__list" };
6191
+ const _hoisted_3 = ["onClick"];
6192
+ const _hoisted_4 = { class: "jb-mobile-filter__label ellipsis" };
6193
+ const _hoisted_5 = ["src"];
6194
+ const _hoisted_6 = ["src"];
6195
+ const _hoisted_7 = {
6196
+ key: 0,
6197
+ class: "jb-mobile-filter__select-popup__search"
6198
+ };
6199
+ const _hoisted_8 = ["onClick"];
6200
+ const _hoisted_9 = { class: "jb-mobile-filter__select-popup__list__label ellipsis" };
6201
+ const _sfc_main = /* @__PURE__ */ defineComponent({
6202
+ __name: "JbMobileFilter",
6203
+ props: {
6204
+ filterList: {
6205
+ type: Array,
6206
+ default: () => []
6207
+ },
6208
+ asyncLoadFilterList: {
6209
+ type: Function,
6210
+ default: () => []
6211
+ }
6212
+ },
6213
+ emits: ["confirm"],
6214
+ setup(__props, { emit: __emit }) {
6215
+ const emits = __emit;
6216
+ const props = __props;
6217
+ const scrollRef = ref();
6218
+ const isShowSelectPopup = ref(false);
6219
+ const currentFilterItem = ref({});
6220
+ const currentFilterListItem = ref({});
6221
+ const currentFilterListItemList = ref(new Array(props.filterList.length));
6222
+ const searchValue = ref("");
6223
+ const currentFilterList = computed(() => {
6224
+ const value = searchValue.value.trim();
6225
+ if (!value) {
6226
+ return currentFilterItem.value.list;
6227
+ }
6228
+ return currentFilterItem.value.list.filter((item) => item.label.indexOf(value) > -1);
6229
+ });
6230
+ watch(() => isShowSelectPopup.value, (newVal) => {
6231
+ if (!newVal && currentFilterItem.value.type === "select") {
6232
+ setTimeout(() => {
6233
+ currentFilterItem.value = {};
6234
+ }, 400);
6235
+ }
6236
+ });
6237
+ const setDefaultFilterListItem = () => {
6238
+ props.filterList.forEach((item, index) => {
6239
+ if (item.defaultValue) {
6240
+ currentFilterListItemList.value[index] = item.list.find((listItem) => listItem.value === item.defaultValue);
6241
+ }
6242
+ });
6243
+ };
6244
+ const handleClickFilterItem = (filterItem) => {
6245
+ if (filterItem.type === "select" && filterItem.key === currentFilterItem.value.key) {
6246
+ isShowSelectPopup.value = false;
6247
+ return;
6248
+ }
6249
+ isShowSelectPopup.value = false;
6250
+ currentFilterItem.value = filterItem;
6251
+ switch (filterItem.type) {
6252
+ case "select":
6253
+ isShowSelectPopup.value = true;
6254
+ handleSelectFilterListItem();
6255
+ break;
6256
+ case "sort":
6257
+ let filterListItem;
6258
+ const index = props.filterList.findIndex((item) => item.key === currentFilterItem.value.key);
6259
+ if (!currentFilterListItemList.value[index]) {
6260
+ filterListItem = currentFilterItem.value.list[0];
6261
+ } else {
6262
+ const listIndex = currentFilterItem.value.list.findIndex((item) => item.value === currentFilterListItemList.value[index].value);
6263
+ filterListItem = currentFilterItem.value.list[currentFilterItem.value.list.length - listIndex - 1];
6264
+ }
6265
+ handleSelectFilterListItem(filterListItem);
6266
+ break;
6267
+ }
6268
+ };
6269
+ const handleSelectFilterListItem = (filterListItem = void 0) => {
6270
+ const index = props.filterList.findIndex((item) => item.key === currentFilterItem.value.key);
6271
+ if (filterListItem) {
6272
+ currentFilterListItem.value = filterListItem;
6273
+ currentFilterListItemList.value[index] = filterListItem;
6274
+ isShowSelectPopup.value = false;
6275
+ const dataList = props.filterList.map((item, i) => {
6276
+ return {
6277
+ key: item.key,
6278
+ selectedItem: currentFilterListItemList.value[i] || {}
6279
+ };
6280
+ });
6281
+ emits("confirm", dataList);
6282
+ } else {
6283
+ if (currentFilterListItemList.value[index]) {
6284
+ currentFilterListItem.value = currentFilterListItemList.value[index];
6285
+ }
6286
+ nextTick(() => {
6287
+ var _a, _b;
6288
+ const selectedDom = (_a = scrollRef.value) == null ? void 0 : _a.querySelector(".selected");
6289
+ if (selectedDom) {
6290
+ selectedDom == null ? void 0 : selectedDom.scrollIntoView({ block: "center" });
6291
+ } else {
6292
+ (_b = scrollRef.value) == null ? void 0 : _b.scrollTo({
6293
+ top: 0
6294
+ });
6295
+ }
6296
+ });
6297
+ }
6298
+ };
6299
+ onMounted(async () => {
6300
+ if (typeof props.asyncLoadFilterList === "function") {
6301
+ await props.asyncLoadFilterList();
6302
+ }
6303
+ setDefaultFilterListItem();
6304
+ });
6305
+ return (_ctx, _cache) => {
6306
+ const _component_van_popup = Popup;
6307
+ return openBlock(), createElementBlock(Fragment, null, [
6308
+ createElementVNode("div", _hoisted_1, [
6309
+ createElementVNode("div", _hoisted_2, [
6310
+ (openBlock(true), createElementBlock(Fragment, null, renderList(__props.filterList, (item, index) => {
6311
+ var _a, _b, _c;
6312
+ return openBlock(), createElementBlock("div", {
6313
+ key: item.key,
6314
+ class: normalizeClass$1(["jb-mobile-filter__item", { selected: currentFilterItem.value.key === item.key }]),
6315
+ onClick: ($event) => handleClickFilterItem(item)
6316
+ }, [
6317
+ createElementVNode("div", _hoisted_4, toDisplayString(((_a = currentFilterListItemList.value[index]) == null ? void 0 : _a.label) || item.placeholder), 1),
6318
+ item.type === "select" ? (openBlock(), createElementBlock("img", {
6319
+ key: 0,
6320
+ class: "jb-mobile-filter__icon common-icon",
6321
+ src: currentFilterItem.value.key === item.key ? unref(dropDownIconSelected) : unref(dropDownIcon),
6322
+ alt: ""
6323
+ }, null, 8, _hoisted_5)) : item.type === "sort" ? (openBlock(), createElementBlock("img", {
6324
+ key: 1,
6325
+ class: "jb-mobile-filter__icon common-icon",
6326
+ src: ((_b = currentFilterListItemList.value[index]) == null ? void 0 : _b.value) === "asc" ? unref(sortIconAsc) : ((_c = currentFilterListItemList.value[index]) == null ? void 0 : _c.value) === "desc" ? unref(sortIconDesc) : unref(sortIconNormal),
6327
+ alt: ""
6328
+ }, null, 8, _hoisted_6)) : createCommentVNode("", true)
6329
+ ], 10, _hoisted_3);
6330
+ }), 128))
6331
+ ])
6332
+ ]),
6333
+ createVNode(_component_van_popup, {
6334
+ class: "jb-mobile-filter__select-popup",
6335
+ position: "top",
6336
+ "safe-area-inset-top": "",
6337
+ show: isShowSelectPopup.value,
6338
+ "onUpdate:show": _cache[1] || (_cache[1] = ($event) => isShowSelectPopup.value = $event)
6339
+ }, {
6340
+ default: withCtx(() => [
6341
+ currentFilterItem.value.search ? (openBlock(), createElementBlock("div", _hoisted_7, [
6342
+ createVNode(JbMobileSearchInput, {
6343
+ modelValue: searchValue.value,
6344
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => searchValue.value = $event),
6345
+ placeholder: currentFilterItem.value.searchPlaceholder
6346
+ }, null, 8, ["modelValue", "placeholder"])
6347
+ ])) : createCommentVNode("", true),
6348
+ createElementVNode("div", {
6349
+ ref_key: "scrollRef",
6350
+ ref: scrollRef,
6351
+ class: "jb-mobile-filter__select-popup__list"
6352
+ }, [
6353
+ currentFilterItem.value.type !== "sort" ? (openBlock(true), createElementBlock(Fragment, { key: 0 }, renderList(currentFilterList.value, (item) => {
6354
+ return openBlock(), createElementBlock("div", {
6355
+ key: item.value,
6356
+ class: normalizeClass$1(["jb-mobile-filter__select-popup__list-item", { selected: currentFilterListItem.value.value === item.value }]),
6357
+ onClick: ($event) => handleSelectFilterListItem(item)
6358
+ }, [
6359
+ createElementVNode("div", _hoisted_9, toDisplayString(item.label), 1),
6360
+ _cache[2] || (_cache[2] = createElementVNode("img", {
6361
+ class: "jb-mobile-filter__select-popup__list__tick-icon",
6362
+ src: _imports_0,
6363
+ alt: ""
6364
+ }, null, -1))
6365
+ ], 10, _hoisted_8);
6366
+ }), 128)) : createCommentVNode("", true)
6367
+ ], 512)
6368
+ ]),
6369
+ _: 1
6370
+ }, 8, ["show"])
6371
+ ], 64);
6372
+ };
6373
+ }
6374
+ });
6375
+ const JbMobileFilter = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-6cdc55f1"]]);
6184
6376
  var freeGlobal = typeof global == "object" && global && global.Object === Object && global;
6185
6377
  var freeSelf = typeof self == "object" && self && self.Object === Object && self;
6186
6378
  var root = freeGlobal || freeSelf || Function("return this")();
@@ -6371,6 +6563,7 @@ function useInfiniteScroll(options = {}) {
6371
6563
  bottomThreshold = 100,
6372
6564
  topThreshold = 100,
6373
6565
  throttleDelay = 300,
6566
+ scrollDirectionThreshold = 5,
6374
6567
  disabled = ref(false),
6375
6568
  onLoadMore,
6376
6569
  onLoadPrevious,
@@ -6381,12 +6574,14 @@ function useInfiniteScroll(options = {}) {
6381
6574
  const isLoadingPrevious = ref(false);
6382
6575
  const hasMoreData = ref(true);
6383
6576
  const hasPreviousData = ref(true);
6577
+ const isProcessingScroll = ref(false);
6384
6578
  let lastScrollTop = 0;
6385
6579
  const executeLoadMore = async () => {
6386
6580
  if (isLoadingMore.value || !hasMoreData.value || !onLoadMore) {
6387
6581
  return;
6388
6582
  }
6389
6583
  isLoadingMore.value = true;
6584
+ isProcessingScroll.value = true;
6390
6585
  try {
6391
6586
  await onLoadMore();
6392
6587
  if (debug) console.log("✅ 向下加载更多完成");
@@ -6394,6 +6589,7 @@ function useInfiniteScroll(options = {}) {
6394
6589
  console.error("❌ 向下加载更多失败:", error);
6395
6590
  } finally {
6396
6591
  isLoadingMore.value = false;
6592
+ isProcessingScroll.value = false;
6397
6593
  }
6398
6594
  };
6399
6595
  const executeLoadPrevious = async () => {
@@ -6401,6 +6597,7 @@ function useInfiniteScroll(options = {}) {
6401
6597
  return;
6402
6598
  }
6403
6599
  isLoadingPrevious.value = true;
6600
+ isProcessingScroll.value = true;
6404
6601
  try {
6405
6602
  await onLoadPrevious();
6406
6603
  if (debug) console.log("✅ 向上加载完成");
@@ -6408,10 +6605,11 @@ function useInfiniteScroll(options = {}) {
6408
6605
  console.error("❌ 向上加载失败:", error);
6409
6606
  } finally {
6410
6607
  isLoadingPrevious.value = false;
6608
+ isProcessingScroll.value = false;
6411
6609
  }
6412
6610
  };
6413
6611
  const handleScroll = throttle(async (event) => {
6414
- if (disabled.value) return;
6612
+ if (disabled.value || isProcessingScroll.value) return;
6415
6613
  const target = event.target;
6416
6614
  if (!target) return;
6417
6615
  const { scrollTop, scrollHeight, clientHeight } = target;
@@ -6420,12 +6618,18 @@ function useInfiniteScroll(options = {}) {
6420
6618
  const isNearBottom = distanceToBottom < bottomThreshold;
6421
6619
  const isNearTop = distanceToTop < topThreshold;
6422
6620
  let scrollDirection = "none";
6423
- if (scrollTop > lastScrollTop) {
6424
- scrollDirection = "down";
6425
- } else if (scrollTop < lastScrollTop) {
6426
- scrollDirection = "up";
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
+ }
6427
6632
  }
6428
- lastScrollTop = scrollTop;
6429
6633
  const scrollInfo = {
6430
6634
  scrollTop,
6431
6635
  scrollHeight,
@@ -6438,14 +6642,15 @@ function useInfiniteScroll(options = {}) {
6438
6642
  };
6439
6643
  if (debug) {
6440
6644
  console.log("📊 滚动信息:", scrollInfo);
6645
+ console.log(`🔄 加载状态: 向下加载=${isLoadingMore.value}, 向上加载=${isLoadingPrevious.value}, 处理中=${isProcessingScroll.value}`);
6441
6646
  }
6442
6647
  if (isNearBottom && scrollDirection === "down") {
6443
6648
  if (debug) console.log("🔽 触发向下加载");
6444
- await executeLoadMore();
6649
+ executeLoadMore();
6445
6650
  }
6446
6651
  if (isNearTop && scrollDirection === "up") {
6447
6652
  if (debug) console.log("🔼 触发向上加载");
6448
- await executeLoadPrevious();
6653
+ executeLoadPrevious();
6449
6654
  }
6450
6655
  scrollInfoRef.value = scrollInfo;
6451
6656
  }, throttleDelay);
@@ -6454,6 +6659,7 @@ function useInfiniteScroll(options = {}) {
6454
6659
  isLoadingPrevious.value = false;
6455
6660
  hasMoreData.value = true;
6456
6661
  hasPreviousData.value = true;
6662
+ isProcessingScroll.value = false;
6457
6663
  lastScrollTop = 0;
6458
6664
  };
6459
6665
  const triggerLoadMore = async () => {
@@ -6512,6 +6718,7 @@ export {
6512
6718
  JbMobileButton,
6513
6719
  JbMobileDatePicker,
6514
6720
  JbMobileEmpty,
6721
+ JbMobileFilter,
6515
6722
  JbMobilePopup,
6516
6723
  JbMobileSearchInput,
6517
6724
  JbMobileSelect,