jb-mobile-ui 1.0.5 → 1.0.7

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, createTextVNode, renderList, normalizeClass as normalizeClass$1, vModelDynamic } 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, withModifiers, 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";
@@ -7,10 +7,10 @@ function noop() {
7
7
  }
8
8
  const extend = Object.assign;
9
9
  const inBrowser$1 = typeof window !== "undefined";
10
- const isObject$1 = (val) => val !== null && typeof val === "object";
10
+ const isObject$2 = (val) => val !== null && typeof val === "object";
11
11
  const isDef = (val) => val !== void 0 && val !== null;
12
12
  const isFunction = (val) => typeof val === "function";
13
- const isPromise = (val) => isObject$1(val) && isFunction(val.then) && isFunction(val.catch);
13
+ const isPromise = (val) => isObject$2(val) && isFunction(val.then) && isFunction(val.catch);
14
14
  const isDate = (val) => Object.prototype.toString.call(val) === "[object Date]" && !Number.isNaN(val.getTime());
15
15
  const isNumeric = (val) => typeof val === "number" || /^\d+(\.\d+)?$/.test(val);
16
16
  const isIOS = () => inBrowser$1 ? /ios|iphone|ipad|ipod/.test(navigator.userAgent.toLowerCase()) : false;
@@ -19,7 +19,7 @@ function get(object, path) {
19
19
  let result = object;
20
20
  keys.forEach((key) => {
21
21
  var _a;
22
- result = isObject$1(result) ? (_a = result[key]) != null ? _a : "" : "";
22
+ result = isObject$2(result) ? (_a = result[key]) != null ? _a : "" : "";
23
23
  });
24
24
  return result;
25
25
  }
@@ -282,22 +282,22 @@ function isElement(node) {
282
282
  const ELEMENT_NODE_TYPE = 1;
283
283
  return node.tagName !== "HTML" && node.tagName !== "BODY" && node.nodeType === ELEMENT_NODE_TYPE;
284
284
  }
285
- function getScrollParent(el, root = defaultRoot) {
285
+ function getScrollParent(el, root2 = defaultRoot) {
286
286
  let node = el;
287
- while (node && node !== root && isElement(node)) {
287
+ while (node && node !== root2 && isElement(node)) {
288
288
  const { overflowY } = window.getComputedStyle(node);
289
289
  if (overflowScrollReg.test(overflowY)) {
290
290
  return node;
291
291
  }
292
292
  node = node.parentNode;
293
293
  }
294
- return root;
294
+ return root2;
295
295
  }
296
- function useScrollParent(el, root = defaultRoot) {
296
+ function useScrollParent(el, root2 = defaultRoot) {
297
297
  const scrollParent = ref();
298
298
  onMounted(() => {
299
299
  if (el.value) {
300
- scrollParent.value = getScrollParent(el.value, root);
300
+ scrollParent.value = getScrollParent(el.value, root2);
301
301
  }
302
302
  });
303
303
  return scrollParent;
@@ -432,13 +432,13 @@ const camelizeRE = /-(\w)/g;
432
432
  const camelize = (str) => str.replace(camelizeRE, (_, c) => c.toUpperCase());
433
433
  const kebabCase = (str) => str.replace(/([A-Z])/g, "-$1").toLowerCase().replace(/^-/, "");
434
434
  const clamp = (num, min, max) => Math.min(Math.max(num, min), max);
435
- const { hasOwnProperty } = Object.prototype;
435
+ const { hasOwnProperty: hasOwnProperty$1 } = Object.prototype;
436
436
  function assignKey(to, from, key) {
437
437
  const val = from[key];
438
438
  if (!isDef(val)) {
439
439
  return;
440
440
  }
441
- if (!hasOwnProperty.call(to, key) || !isObject$1(val)) {
441
+ if (!hasOwnProperty$1.call(to, key) || !isObject$2(val)) {
442
442
  to[key] = val;
443
443
  } else {
444
444
  to[key] = deepAssign(Object(to[key]), val);
@@ -1296,7 +1296,7 @@ var stdin_default$e = defineComponent({
1296
1296
  attrs,
1297
1297
  slots
1298
1298
  }) {
1299
- const root = ref();
1299
+ const root2 = ref();
1300
1300
  const lazyRender = useLazyRender(() => props.show || !props.lazyRender);
1301
1301
  const onTouchMove = (event) => {
1302
1302
  if (props.lockScroll) {
@@ -1310,13 +1310,13 @@ var stdin_default$e = defineComponent({
1310
1310
  style.animationDuration = `${props.duration}s`;
1311
1311
  }
1312
1312
  return withDirectives(createVNode("div", mergeProps({
1313
- "ref": root,
1313
+ "ref": root2,
1314
1314
  "style": style,
1315
1315
  "class": [bem$d(), props.className]
1316
1316
  }, attrs), [(_a = slots.default) == null ? void 0 : _a.call(slots)]), [[vShow, props.show]]);
1317
1317
  });
1318
1318
  useEventListener("touchmove", onTouchMove, {
1319
- target: root
1319
+ target: root2
1320
1320
  });
1321
1321
  return () => {
1322
1322
  const Content = createVNode(Transition, {
@@ -1633,7 +1633,7 @@ var stdin_default$c = defineComponent({
1633
1633
  let touchStartTime;
1634
1634
  let momentumOffset;
1635
1635
  let transitionEndTrigger;
1636
- const root = ref();
1636
+ const root2 = ref();
1637
1637
  const wrapper = ref();
1638
1638
  const currentOffset = ref(0);
1639
1639
  const currentDuration = ref(0);
@@ -1716,9 +1716,9 @@ var stdin_default$c = defineComponent({
1716
1716
  emit("scrollInto", props.options[newIndex]);
1717
1717
  }
1718
1718
  currentOffset.value = newOffset;
1719
- const now = Date.now();
1720
- if (now - touchStartTime > MOMENTUM_TIME) {
1721
- touchStartTime = now;
1719
+ const now2 = Date.now();
1720
+ if (now2 - touchStartTime > MOMENTUM_TIME) {
1721
+ touchStartTime = now2;
1722
1722
  momentumOffset = newOffset;
1723
1723
  }
1724
1724
  };
@@ -1779,10 +1779,10 @@ var stdin_default$c = defineComponent({
1779
1779
  currentOffset.value = offset;
1780
1780
  });
1781
1781
  useEventListener("touchmove", onTouchMove, {
1782
- target: root
1782
+ target: root2
1783
1783
  });
1784
1784
  return () => createVNode("div", {
1785
- "ref": root,
1785
+ "ref": root2,
1786
1786
  "class": bem$a(),
1787
1787
  "onTouchstartPassive": onTouchStart,
1788
1788
  "onTouchend": onTouchEnd,
@@ -1879,7 +1879,7 @@ const useSyncPropRef = (getProp, setProp) => {
1879
1879
  !!(process.env.NODE_ENV !== "production") ? Object.freeze([]) : [];
1880
1880
  const isArray = Array.isArray;
1881
1881
  const isString = (val) => typeof val === "string";
1882
- const isObject = (val) => val !== null && typeof val === "object";
1882
+ const isObject$1 = (val) => val !== null && typeof val === "object";
1883
1883
  const cacheStringFunction = (fn) => {
1884
1884
  const cache = /* @__PURE__ */ Object.create(null);
1885
1885
  return (str) => {
@@ -1904,7 +1904,7 @@ function normalizeStyle(value) {
1904
1904
  }
1905
1905
  }
1906
1906
  return res;
1907
- } else if (isString(value) || isObject(value)) {
1907
+ } else if (isString(value) || isObject$1(value)) {
1908
1908
  return value;
1909
1909
  }
1910
1910
  }
@@ -1945,7 +1945,7 @@ function normalizeClass(value) {
1945
1945
  res += normalized + " ";
1946
1946
  }
1947
1947
  }
1948
- } else if (isObject(value)) {
1948
+ } else if (isObject$1(value)) {
1949
1949
  for (const name2 in value) {
1950
1950
  if (value[name2]) {
1951
1951
  res += name2 + " ";
@@ -2062,8 +2062,8 @@ var stdin_default$a = defineComponent({
2062
2062
  emit,
2063
2063
  slots
2064
2064
  }) {
2065
- const root = ref();
2066
- const scrollParent = useScrollParent(root);
2065
+ const root2 = ref();
2066
+ const scrollParent = useScrollParent(root2);
2067
2067
  const state = reactive({
2068
2068
  fixed: false,
2069
2069
  width: 0,
@@ -2109,14 +2109,14 @@ var stdin_default$a = defineComponent({
2109
2109
  isFixed: state.fixed
2110
2110
  });
2111
2111
  const onScroll = () => {
2112
- if (!root.value || isHidden(root)) {
2112
+ if (!root2.value || isHidden(root2)) {
2113
2113
  return;
2114
2114
  }
2115
2115
  const {
2116
2116
  container,
2117
2117
  position
2118
2118
  } = props;
2119
- const rootRect = useRect(root);
2119
+ const rootRect = useRect(root2);
2120
2120
  const scrollTop = getScrollTop(window);
2121
2121
  state.width = rootRect.width;
2122
2122
  state.height = rootRect.height;
@@ -2149,14 +2149,14 @@ var stdin_default$a = defineComponent({
2149
2149
  target: scrollParent,
2150
2150
  passive: true
2151
2151
  });
2152
- useVisibilityChange(root, onScroll);
2152
+ useVisibilityChange(root2, onScroll);
2153
2153
  watch([windowWidth, windowHeight], () => {
2154
- if (!root.value || isHidden(root) || !state.fixed) {
2154
+ if (!root2.value || isHidden(root2) || !state.fixed) {
2155
2155
  return;
2156
2156
  }
2157
2157
  isReset.value = true;
2158
2158
  nextTick(() => {
2159
- const rootRect = useRect(root);
2159
+ const rootRect = useRect(root2);
2160
2160
  state.width = rootRect.width;
2161
2161
  state.height = rootRect.height;
2162
2162
  isReset.value = false;
@@ -2165,7 +2165,7 @@ var stdin_default$a = defineComponent({
2165
2165
  return () => {
2166
2166
  var _a;
2167
2167
  return createVNode("div", {
2168
- "ref": root,
2168
+ "ref": root2,
2169
2169
  "style": rootStyle.value
2170
2170
  }, [createVNode("div", {
2171
2171
  "class": bem$9({
@@ -2201,7 +2201,7 @@ var stdin_default$9 = defineComponent({
2201
2201
  emit,
2202
2202
  slots
2203
2203
  }) {
2204
- const root = ref();
2204
+ const root2 = ref();
2205
2205
  const track = ref();
2206
2206
  const state = reactive({
2207
2207
  rect: null,
@@ -2345,15 +2345,15 @@ var stdin_default$9 = defineComponent({
2345
2345
  }
2346
2346
  };
2347
2347
  const initialize = (active = +props.initialSwipe) => {
2348
- if (!root.value) {
2348
+ if (!root2.value) {
2349
2349
  return;
2350
2350
  }
2351
2351
  const cb = () => {
2352
2352
  var _a, _b;
2353
- if (!isHidden(root)) {
2353
+ if (!isHidden(root2)) {
2354
2354
  const rect = {
2355
- width: root.value.offsetWidth,
2356
- height: root.value.offsetHeight
2355
+ width: root2.value.offsetWidth,
2356
+ height: root2.value.offsetHeight
2357
2357
  };
2358
2358
  state.rect = rect;
2359
2359
  state.width = +((_a = props.width) != null ? _a : rect.width);
@@ -2373,7 +2373,7 @@ var stdin_default$9 = defineComponent({
2373
2373
  });
2374
2374
  autoplay();
2375
2375
  };
2376
- if (isHidden(root)) {
2376
+ if (isHidden(root2)) {
2377
2377
  nextTick().then(cb);
2378
2378
  } else {
2379
2379
  cb();
@@ -2526,7 +2526,7 @@ var stdin_default$9 = defineComponent({
2526
2526
  return () => {
2527
2527
  var _a;
2528
2528
  return createVNode("div", {
2529
- "ref": root,
2529
+ "ref": root2,
2530
2530
  "class": bem$8()
2531
2531
  }, [createVNode("div", {
2532
2532
  "ref": track,
@@ -2640,12 +2640,12 @@ var stdin_default$7 = defineComponent({
2640
2640
  let stickyFixed;
2641
2641
  let cancelScrollLeftToRaf;
2642
2642
  let cancelScrollTopToRaf;
2643
- const root = ref();
2643
+ const root2 = ref();
2644
2644
  const navRef = ref();
2645
2645
  const wrapRef = ref();
2646
2646
  const contentRef = ref();
2647
2647
  const id = useId();
2648
- const scroller = useScrollParent(root);
2648
+ const scroller = useScrollParent(root2);
2649
2649
  const [titleRefs, setTitleRefs] = useRefs();
2650
2650
  const {
2651
2651
  children,
@@ -2694,7 +2694,7 @@ var stdin_default$7 = defineComponent({
2694
2694
  const shouldAnimate = state.inited;
2695
2695
  nextTick(() => {
2696
2696
  const titles = titleRefs.value;
2697
- if (!titles || !titles[state.currentIndex] || props.type !== "line" || isHidden(root.value)) {
2697
+ if (!titles || !titles[state.currentIndex] || props.type !== "line" || isHidden(root2.value)) {
2698
2698
  return;
2699
2699
  }
2700
2700
  const title = titles[state.currentIndex].$el;
@@ -2750,7 +2750,7 @@ var stdin_default$7 = defineComponent({
2750
2750
  }
2751
2751
  }
2752
2752
  if (stickyFixed && !props.scrollspy) {
2753
- setRootScrollTop(Math.ceil(getElementTop(root.value) - offsetTopPx.value));
2753
+ setRootScrollTop(Math.ceil(getElementTop(root2.value) - offsetTopPx.value));
2754
2754
  }
2755
2755
  };
2756
2756
  const setCurrentIndexByName = (name2, skipScrollIntoView) => {
@@ -2899,7 +2899,7 @@ var stdin_default$7 = defineComponent({
2899
2899
  onActivated(setLine);
2900
2900
  onPopupReopen(setLine);
2901
2901
  onMountedOrActivated(init);
2902
- useVisibilityChange(root, setLine);
2902
+ useVisibilityChange(root2, setLine);
2903
2903
  useEventListener("scroll", onScroll, {
2904
2904
  target: scroller,
2905
2905
  passive: true
@@ -2915,10 +2915,10 @@ var stdin_default$7 = defineComponent({
2915
2915
  scrollIntoView
2916
2916
  });
2917
2917
  return () => createVNode("div", {
2918
- "ref": root,
2918
+ "ref": root2,
2919
2919
  "class": bem$6([props.type])
2920
2920
  }, [props.showHeader ? props.sticky ? createVNode(Sticky, {
2921
- "container": root.value,
2921
+ "container": root2.value,
2922
2922
  "offsetTop": offsetTopPx.value,
2923
2923
  "onScroll": onStickyScroll
2924
2924
  }, {
@@ -3664,13 +3664,13 @@ function usePopupState() {
3664
3664
  }
3665
3665
  function mountComponent(RootComponent) {
3666
3666
  const app = createApp(RootComponent);
3667
- const root = document.createElement("div");
3668
- document.body.appendChild(root);
3667
+ const root2 = document.createElement("div");
3668
+ document.body.appendChild(root2);
3669
3669
  return {
3670
- instance: app.mount(root),
3670
+ instance: app.mount(root2),
3671
3671
  unmount() {
3672
3672
  app.unmount();
3673
- document.body.removeChild(root);
3673
+ document.body.removeChild(root2);
3674
3674
  }
3675
3675
  };
3676
3676
  }
@@ -3700,7 +3700,7 @@ let allowMultiple = false;
3700
3700
  let currentOptions = extend({}, defaultOptions);
3701
3701
  const defaultOptionsMap = /* @__PURE__ */ new Map();
3702
3702
  function parseOptions(message) {
3703
- if (isObject$1(message)) {
3703
+ if (isObject$2(message)) {
3704
3704
  return message;
3705
3705
  }
3706
3706
  return {
@@ -4347,28 +4347,28 @@ var stdin_default = defineComponent({
4347
4347
  if (defaultDate === null) {
4348
4348
  return defaultDate;
4349
4349
  }
4350
- const now = getToday();
4350
+ const now2 = getToday();
4351
4351
  if (type === "range") {
4352
4352
  if (!Array.isArray(defaultDate)) {
4353
4353
  defaultDate = [];
4354
4354
  }
4355
- if (defaultDate.length === 1 && compareDay(defaultDate[0], now) === 1) {
4355
+ if (defaultDate.length === 1 && compareDay(defaultDate[0], now2) === 1) {
4356
4356
  defaultDate = [];
4357
4357
  }
4358
4358
  const min = minDate.value;
4359
4359
  const max = maxDate.value;
4360
- const start = limitDateRange(defaultDate[0] || now, min, max ? allowSameDay ? max : getPrevDay(max) : void 0);
4361
- const end = limitDateRange(defaultDate[1] || (allowSameDay ? now : getNextDay(now)), min ? allowSameDay ? min : getNextDay(min) : void 0);
4360
+ const start = limitDateRange(defaultDate[0] || now2, min, max ? allowSameDay ? max : getPrevDay(max) : void 0);
4361
+ const end = limitDateRange(defaultDate[1] || (allowSameDay ? now2 : getNextDay(now2)), min ? allowSameDay ? min : getNextDay(min) : void 0);
4362
4362
  return [start, end];
4363
4363
  }
4364
4364
  if (type === "multiple") {
4365
4365
  if (Array.isArray(defaultDate)) {
4366
4366
  return defaultDate.map((date) => limitDateRange(date));
4367
4367
  }
4368
- return [limitDateRange(now)];
4368
+ return [limitDateRange(now2)];
4369
4369
  }
4370
4370
  if (!defaultDate || Array.isArray(defaultDate)) {
4371
- defaultDate = now;
4371
+ defaultDate = now2;
4372
4372
  }
4373
4373
  return limitDateRange(defaultDate);
4374
4374
  };
@@ -4703,7 +4703,7 @@ var stdin_default = defineComponent({
4703
4703
  }
4704
4704
  });
4705
4705
  const Calendar = withInstall(stdin_default);
4706
- const _sfc_main$7 = /* @__PURE__ */ defineComponent({
4706
+ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
4707
4707
  __name: "JbMobileButton",
4708
4708
  setup(__props) {
4709
4709
  const attrs = useAttrs();
@@ -4725,17 +4725,17 @@ const _export_sfc = (sfc, props) => {
4725
4725
  }
4726
4726
  return target;
4727
4727
  };
4728
- const JbMobileButton = /* @__PURE__ */ _export_sfc(_sfc_main$7, [["__scopeId", "data-v-177e5e3b"]]);
4729
- 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";
4728
+ const JbMobileButton = /* @__PURE__ */ _export_sfc(_sfc_main$8, [["__scopeId", "data-v-1588f7ed"]]);
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";
4732
- 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
- const _hoisted_1$6 = { class: "jb-mobile-popup__header" };
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";
4733
+ const _hoisted_1$7 = { class: "jb-mobile-popup__header" };
4734
4734
  const _hoisted_2$5 = {
4735
4735
  key: 0,
4736
4736
  class: "jb-mobile-popup__bottom"
4737
4737
  };
4738
- const _sfc_main$6 = /* @__PURE__ */ defineComponent({
4738
+ const _sfc_main$7 = /* @__PURE__ */ defineComponent({
4739
4739
  __name: "JbMobilePopup",
4740
4740
  props: {
4741
4741
  visible: {
@@ -4808,7 +4808,7 @@ const _sfc_main$6 = /* @__PURE__ */ defineComponent({
4808
4808
  onClosed: handleClose
4809
4809
  }), {
4810
4810
  default: withCtx(() => [
4811
- createElementVNode("div", _hoisted_1$6, [
4811
+ createElementVNode("div", _hoisted_1$7, [
4812
4812
  createElementVNode("div", null, toDisplayString(__props.title), 1),
4813
4813
  createElementVNode("div", {
4814
4814
  class: "jb-mobile-popup__close-icon",
@@ -4816,17 +4816,17 @@ const _sfc_main$6 = /* @__PURE__ */ defineComponent({
4816
4816
  }, _cache[1] || (_cache[1] = [
4817
4817
  createElementVNode("img", {
4818
4818
  class: "jb-mobile-popup__close-icon__inner",
4819
- src: _imports_0$4,
4819
+ src: _imports_0$5,
4820
4820
  alt: ""
4821
4821
  }, null, -1)
4822
4822
  ]))
4823
4823
  ]),
4824
4824
  createElementVNode("div", {
4825
- class: "jb-mobile-popup__content",
4825
+ class: normalizeClass$1(["jb-mobile-popup__content", { "safe-area-inset-bottom": !__props.footButton }]),
4826
4826
  style: normalizeStyle$1({ height: contentHeightComputed.value })
4827
4827
  }, [
4828
4828
  renderSlot(_ctx.$slots, "default", {}, void 0, true)
4829
- ], 4),
4829
+ ], 6),
4830
4830
  __props.footButton ? (openBlock(), createElementBlock("div", _hoisted_2$5, [
4831
4831
  createVNode(JbMobileButton, {
4832
4832
  type: "primary",
@@ -4847,14 +4847,18 @@ const _sfc_main$6 = /* @__PURE__ */ defineComponent({
4847
4847
  };
4848
4848
  }
4849
4849
  });
4850
- const JbMobilePopup = /* @__PURE__ */ _export_sfc(_sfc_main$6, [["__scopeId", "data-v-d97904a0"]]);
4851
- const _hoisted_1$5 = { class: "jb-mobile-time-picker__calendar__inner" };
4852
- const _hoisted_2$4 = {
4850
+ const JbMobilePopup = /* @__PURE__ */ _export_sfc(_sfc_main$7, [["__scopeId", "data-v-f9a73fb1"]]);
4851
+ const _hoisted_1$6 = { class: "jb-mobile-date-picker" };
4852
+ const _hoisted_2$4 = { class: "jb-mobile-date-picker__value" };
4853
+ const _hoisted_3$3 = ["src"];
4854
+ const _hoisted_4$2 = { class: "jb-mobile-time-picker__calendar__inner" };
4855
+ const _hoisted_5$1 = { class: "jb-mobile-time-picker__group-wrap" };
4856
+ const _hoisted_6$1 = {
4853
4857
  key: 0,
4854
4858
  class: "jb-mobile-time-picker__group__title"
4855
4859
  };
4856
- const _hoisted_3$3 = ["onClick"];
4857
- const _sfc_main$5 = /* @__PURE__ */ defineComponent({
4860
+ const _hoisted_7$1 = ["onClick"];
4861
+ const _sfc_main$6 = /* @__PURE__ */ defineComponent({
4858
4862
  __name: "JbMobileTimePicker",
4859
4863
  props: {
4860
4864
  visible: {
@@ -4881,9 +4885,26 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
4881
4885
  valueFormat: {
4882
4886
  type: String,
4883
4887
  default: "YYYY-MM-DD HH:mm:ss"
4888
+ },
4889
+ withSelectTab: {
4890
+ type: Boolean,
4891
+ default: false
4892
+ },
4893
+ datePickerTypeList: {
4894
+ type: Array,
4895
+ default: () => ["dateRange", "week", "month", "quarter", "year"]
4896
+ },
4897
+ disabledTab: {
4898
+ type: Boolean,
4899
+ default: false
4884
4900
  }
4885
4901
  },
4886
- emits: ["update:visible", "confirm"],
4902
+ emits: [
4903
+ "update:visible",
4904
+ "update:timePickerType",
4905
+ "confirm",
4906
+ "changeDateFail"
4907
+ ],
4887
4908
  setup(__props, { expose: __expose, emit: __emit }) {
4888
4909
  dayjs.extend(weekOfYear);
4889
4910
  dayjs.extend(quarterOfYear);
@@ -4898,6 +4919,74 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
4898
4919
  emits("update:visible", val);
4899
4920
  }
4900
4921
  });
4922
+ const isLatestDate = ref(false);
4923
+ const dateFormatValue = ref("");
4924
+ const isShowTimePicker = ref(false);
4925
+ const dateFilterTypeListDefault = computed(() => {
4926
+ return [
4927
+ {
4928
+ label: "天",
4929
+ value: "dateRange"
4930
+ },
4931
+ {
4932
+ label: "周",
4933
+ value: "week"
4934
+ },
4935
+ {
4936
+ label: "月",
4937
+ value: "month"
4938
+ },
4939
+ {
4940
+ label: "季",
4941
+ value: "quarter"
4942
+ },
4943
+ {
4944
+ label: "年",
4945
+ value: "year"
4946
+ }
4947
+ ];
4948
+ });
4949
+ const timePickerType = computed({
4950
+ get() {
4951
+ return props.timePickerType;
4952
+ },
4953
+ set(val) {
4954
+ emits("update:timePickerType", val);
4955
+ }
4956
+ });
4957
+ const dateFilterTypeList = computed(
4958
+ () => dateFilterTypeListDefault.value.filter(
4959
+ (item) => props.datePickerTypeList.includes(item.value)
4960
+ )
4961
+ );
4962
+ const forwardIcon = computed(() => {
4963
+ return isLatestDate.value ? forwardDisabledSvg : forwardSvg;
4964
+ });
4965
+ const changeDatePrev = () => {
4966
+ console.log("props.disabledTab", props.disabledTab);
4967
+ if (props.disabledTab) {
4968
+ emits("changeDateFail");
4969
+ return;
4970
+ }
4971
+ toPrevDate();
4972
+ };
4973
+ const changeDateNext = () => {
4974
+ if (isLatestDate.value) {
4975
+ return;
4976
+ }
4977
+ if (props.disabledTab) {
4978
+ emits("changeDateFail");
4979
+ return;
4980
+ }
4981
+ toNextDate();
4982
+ };
4983
+ const handleTabsBeforeChange = () => {
4984
+ if (props.disabledTab) {
4985
+ emits("changeDateFail");
4986
+ return false;
4987
+ }
4988
+ return true;
4989
+ };
4901
4990
  let isFinishSelect = true;
4902
4991
  let weekStartDate = /* @__PURE__ */ new Date();
4903
4992
  let weekEndDate = /* @__PURE__ */ new Date();
@@ -4906,15 +4995,19 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
4906
4995
  let dateValueFormat = "";
4907
4996
  let confirmSelectedCalendarValue = [];
4908
4997
  let confirmSelectedTimeValue = "";
4909
- const isShowCalendar = computed(() => ["dateRange", "week"].includes(props.timePickerType));
4998
+ const isShowCalendar = computed(
4999
+ () => ["dateRange", "week"].includes(props.timePickerType)
5000
+ );
4910
5001
  const minDate = computed(() => dayjs(props.minDate).toDate());
4911
5002
  const maxDate = computed(() => dayjs(props.maxDate).toDate());
4912
5003
  const timeKey = computed(() => timeKeyMap[props.timePickerType]);
5004
+ const defaultValueFirst = ref(props.defaultValue);
5005
+ const defaultValueSecond = ref(props.defaultValue);
4913
5006
  const defaultDate = computed(() => {
4914
5007
  return props.timePickerType === "dateRange" ? [
4915
- dayjs(props.defaultValue).startOf(timeKey.value).toDate(),
4916
- dayjs(props.defaultValue).endOf(timeKey.value).toDate()
4917
- ] : dayjs(props.defaultValue).startOf(timeKey.value).toDate();
5008
+ dayjs(defaultValueFirst.value).startOf(timeKey.value).toDate(),
5009
+ dayjs(defaultValueSecond.value).endOf(timeKey.value).toDate()
5010
+ ] : dayjs(defaultValueFirst.value).startOf(timeKey.value).toDate();
4918
5011
  });
4919
5012
  const startYear = dayjs(minDate.value).year();
4920
5013
  const endYear = dayjs(maxDate.value).year();
@@ -4966,7 +5059,9 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
4966
5059
  const timeItem = {};
4967
5060
  timeItem.title = `${currentYear}年`;
4968
5061
  timeItem.value = currentYear + "";
4969
- timeItem.children = [...new Array(currentYear < endYear ? 12 : endMonth).keys()].map((item) => {
5062
+ timeItem.children = [
5063
+ ...new Array(currentYear < endYear ? 12 : endMonth).keys()
5064
+ ].map((item) => {
4970
5065
  const month = item + 1;
4971
5066
  return {
4972
5067
  label: `${month}月`,
@@ -4987,7 +5082,9 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
4987
5082
  const timeItem = {};
4988
5083
  timeItem.title = `${currentYear}年`;
4989
5084
  timeItem.value = currentYear + "";
4990
- timeItem.children = [...new Array(currentYear < endYear ? 4 : endQuarter).keys()].map((item) => {
5085
+ timeItem.children = [
5086
+ ...new Array(currentYear < endYear ? 4 : endQuarter).keys()
5087
+ ].map((item) => {
4991
5088
  return {
4992
5089
  label: `${numberToChinese[item + 1]}季度`,
4993
5090
  value: `${currentYear}-${fillZero(1 + 3 * item)}-01`
@@ -5002,11 +5099,13 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5002
5099
  };
5003
5100
  },
5004
5101
  year() {
5005
- const timeList = [{
5006
- title: "",
5007
- value: "year",
5008
- children: []
5009
- }];
5102
+ const timeList = [
5103
+ {
5104
+ title: "",
5105
+ value: "year",
5106
+ children: []
5107
+ }
5108
+ ];
5010
5109
  for (let currentYear = startYear; currentYear <= endYear; currentYear++) {
5011
5110
  timeList[0].children.push({
5012
5111
  label: `${currentYear}年`,
@@ -5023,22 +5122,29 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5023
5122
  const calendarRef = ref();
5024
5123
  const timePickerContentRef = ref();
5025
5124
  const selectedTimeValue = ref("");
5026
- const timePickerTypeObj = computed(() => timePickerTypeMap[props.timePickerType]());
5027
- watch(() => visible.value, (newVal) => {
5028
- if (newVal) {
5029
- selectedTimeValue.value = confirmSelectedTimeValue || dayjs(defaultDate.value).format("YYYY-MM-DD");
5030
- nextTick(() => {
5031
- setSelectedScrollIntoView();
5032
- });
5125
+ const timePickerTypeObj = computed(
5126
+ () => timePickerTypeMap[props.timePickerType]()
5127
+ );
5128
+ watch(
5129
+ () => visible.value,
5130
+ (newVal) => {
5131
+ if (newVal) {
5132
+ selectedTimeValue.value = confirmSelectedTimeValue || dayjs(defaultDate.value).format("YYYY-MM-DD");
5133
+ nextTick(() => {
5134
+ setSelectedScrollIntoView();
5135
+ });
5136
+ }
5033
5137
  }
5034
- });
5138
+ );
5035
5139
  const setDateValueFormat = (value, format) => {
5036
5140
  const year = dayjs(value[0]).year();
5037
5141
  if (props.timePickerType === "dateRange") {
5038
5142
  if (dayjs(value[0]).isSame(dayjs(value[1]), "day")) {
5039
5143
  dateValueFormat = `${dayjs(value[0]).format(format)}`;
5040
5144
  } else {
5041
- dateValueFormat = `${dayjs(value[0]).format(format)} ~ ${dayjs(value[1]).format(format)}`;
5145
+ dateValueFormat = `${dayjs(value[0]).format(format)} ~ ${dayjs(
5146
+ value[1]
5147
+ ).format(format)}`;
5042
5148
  }
5043
5149
  } else if (props.timePickerType === "week") {
5044
5150
  const week = dayjs(value[0]).week();
@@ -5053,7 +5159,9 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5053
5159
  const setSelectedScrollIntoView = () => {
5054
5160
  var _a, _b;
5055
5161
  if (["dateRange", "week"].includes(props.timePickerType)) {
5056
- (_a = calendarRef.value) == null ? void 0 : _a.scrollToDate(Array.isArray(defaultDate.value) ? defaultDate.value[0] : defaultDate.value);
5162
+ (_a = calendarRef.value) == null ? void 0 : _a.scrollToDate(
5163
+ Array.isArray(defaultDate.value) ? defaultDate.value[0] : defaultDate.value
5164
+ );
5057
5165
  } else {
5058
5166
  const selectedItem = (_b = timePickerContentRef.value) == null ? void 0 : _b.querySelector(".selected");
5059
5167
  selectedItem == null ? void 0 : selectedItem.scrollIntoView({
@@ -5098,6 +5206,8 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5098
5206
  } else {
5099
5207
  startTime = dayjs(value).startOf(timeKey.value).format(props.valueFormat);
5100
5208
  endTime = dayjs(value).endOf(timeKey.value).format(props.valueFormat);
5209
+ defaultValueFirst.value = startTime;
5210
+ defaultValueSecond.value = endTime;
5101
5211
  }
5102
5212
  };
5103
5213
  const handleSelectDateItem = (value) => {
@@ -5109,22 +5219,34 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5109
5219
  return dayjs(endTime).isSame(dayjs(), timeKey.value);
5110
5220
  };
5111
5221
  const toPrevDate = () => {
5112
- handleFinishSelectDate(dayjs(endTime).subtract(1, timeKey.value).toDate());
5222
+ handleFinishSelectDate(
5223
+ dayjs(endTime).subtract(1, timeKey.value).toDate()
5224
+ );
5113
5225
  selectedTimeValue.value = dayjs(startTime).format("YYYY-MM-DD");
5114
5226
  handleConfirm();
5115
5227
  };
5116
5228
  const toNextDate = () => {
5117
- handleFinishSelectDate(dayjs(endTime).add(1, timeKey.value).toDate());
5118
- selectedTimeValue.value = dayjs(startTime).format("YYYY-MM-DD");
5119
- handleConfirm();
5229
+ nextTick(() => {
5230
+ handleFinishSelectDate(
5231
+ dayjs(endTime).add(1, timeKey.value).toDate()
5232
+ );
5233
+ selectedTimeValue.value = dayjs(startTime).format("YYYY-MM-DD");
5234
+ handleConfirm();
5235
+ });
5120
5236
  };
5121
5237
  const confirmSelectDate = () => {
5122
5238
  setDateValueFormat([startTime, endTime], timePickerTypeObj.value.format);
5123
- emits("confirm", {
5124
- dateValueFormat,
5125
- value: [startTime, endTime],
5126
- isLatestDate: getIsLatestDate()
5127
- });
5239
+ if (props.withSelectTab) {
5240
+ isLatestDate.value = getIsLatestDate();
5241
+ dateFormatValue.value = dateValueFormat;
5242
+ emits("confirm", [startTime, endTime]);
5243
+ } else {
5244
+ emits("confirm", {
5245
+ dateValueFormat,
5246
+ value: [startTime, endTime],
5247
+ isLatestDate: getIsLatestDate()
5248
+ });
5249
+ }
5128
5250
  };
5129
5251
  const handleBeforeConfirm = () => {
5130
5252
  if (!startTime || !endTime) {
@@ -5137,35 +5259,60 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5137
5259
  return true;
5138
5260
  };
5139
5261
  const handleConfirm = () => {
5140
- confirmSelectedCalendarValue = [dayjs(startTime).toDate(), dayjs(endTime).toDate()];
5262
+ confirmSelectedCalendarValue = [
5263
+ dayjs(startTime).toDate(),
5264
+ dayjs(endTime).toDate()
5265
+ ];
5141
5266
  confirmSelectedTimeValue = selectedTimeValue.value;
5142
5267
  confirmSelectDate();
5143
- handleClose();
5268
+ if (!props.withSelectTab) {
5269
+ handleClose();
5270
+ }
5144
5271
  };
5145
5272
  const handleClose = () => {
5146
5273
  var _a;
5147
5274
  visible.value = false;
5148
- (_a = calendarRef.value) == null ? void 0 : _a.reset(confirmSelectedCalendarValue.length ? confirmSelectedCalendarValue : void 0);
5275
+ (_a = calendarRef.value) == null ? void 0 : _a.reset(
5276
+ confirmSelectedCalendarValue.length ? confirmSelectedCalendarValue : void 0
5277
+ );
5149
5278
  setWeekStartAndEndDate(confirmSelectedCalendarValue[0] || defaultDate.value);
5150
5279
  };
5151
- watch(() => timePickerTypeObj.value, () => {
5152
- confirmSelectedCalendarValue = [];
5153
- confirmSelectedTimeValue = "";
5154
- handleFinishSelectDate(defaultDate.value);
5155
- confirmSelectDate();
5156
- }, { immediate: true });
5280
+ watch(
5281
+ () => timePickerTypeObj.value,
5282
+ () => {
5283
+ confirmSelectedCalendarValue = [];
5284
+ confirmSelectedTimeValue = "";
5285
+ console.log("defaultDate.value", defaultDate.value);
5286
+ handleFinishSelectDate(defaultDate.value);
5287
+ confirmSelectDate();
5288
+ if (props.withSelectTab) {
5289
+ selectedTimeValue.value = confirmSelectedTimeValue || dayjs(defaultDate.value).format("YYYY-MM-DD");
5290
+ nextTick(() => {
5291
+ setSelectedScrollIntoView();
5292
+ });
5293
+ }
5294
+ },
5295
+ { immediate: true }
5296
+ );
5297
+ watch(timePickerType, (val) => {
5298
+ console.log("val", val);
5299
+ emits("update:timePickerType", val);
5300
+ });
5157
5301
  __expose({
5158
5302
  toPrevDate,
5159
5303
  toNextDate
5160
5304
  });
5161
5305
  return (_ctx, _cache) => {
5306
+ const _component_van_tab = Tab;
5307
+ const _component_van_tabs = Tabs;
5308
+ const _component_van_icon = Icon;
5162
5309
  const _component_van_calendar = Calendar;
5163
5310
  return openBlock(), createBlock(JbMobilePopup, mergeProps({
5164
5311
  visible: visible.value,
5165
- "onUpdate:visible": _cache[0] || (_cache[0] = ($event) => visible.value = $event)
5312
+ "onUpdate:visible": _cache[2] || (_cache[2] = ($event) => visible.value = $event)
5166
5313
  }, unref(attrs), {
5167
5314
  title: timePickerTypeObj.value.title,
5168
- "grey-bg": !isShowCalendar.value,
5315
+ "grey-bg": !isShowCalendar.value && !__props.withSelectTab,
5169
5316
  "before-confirm": handleBeforeConfirm,
5170
5317
  onConfirm: handleConfirm,
5171
5318
  onClose: handleClose
@@ -5173,8 +5320,60 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5173
5320
  default: withCtx(() => [
5174
5321
  createElementVNode("div", {
5175
5322
  ref_key: "timePickerContentRef",
5176
- ref: timePickerContentRef
5323
+ ref: timePickerContentRef,
5324
+ class: "time-picker__content"
5177
5325
  }, [
5326
+ createElementVNode("div", _hoisted_1$6, [
5327
+ createVNode(_component_van_tabs, {
5328
+ active: timePickerType.value,
5329
+ "onUpdate:active": _cache[0] || (_cache[0] = ($event) => timePickerType.value = $event),
5330
+ "title-inactive-color": "#323233",
5331
+ "title-active-color": "#000",
5332
+ background: "transparent",
5333
+ color: "transparent",
5334
+ "before-change": handleTabsBeforeChange
5335
+ }, {
5336
+ default: withCtx(() => [
5337
+ (openBlock(true), createElementBlock(Fragment, null, renderList(dateFilterTypeList.value, (item) => {
5338
+ return openBlock(), createBlock(_component_van_tab, {
5339
+ key: item.value,
5340
+ title: item.label,
5341
+ name: item.value
5342
+ }, null, 8, ["title", "name"]);
5343
+ }), 128))
5344
+ ]),
5345
+ _: 1
5346
+ }, 8, ["active"]),
5347
+ createElementVNode("div", _hoisted_2$4, [
5348
+ timePickerType.value !== "dateRange" ? (openBlock(), createElementBlock("div", {
5349
+ key: 0,
5350
+ class: "jb-mobile-date-picker__date-arrow left",
5351
+ onClick: changeDatePrev
5352
+ }, _cache[3] || (_cache[3] = [
5353
+ createElementVNode("img", {
5354
+ src: _imports_0$6,
5355
+ alt: "back"
5356
+ }, null, -1)
5357
+ ]))) : createCommentVNode("", true),
5358
+ createElementVNode("div", {
5359
+ class: "jb-mobile-date-picker__date-text",
5360
+ onClick: _cache[1] || (_cache[1] = ($event) => isShowTimePicker.value = true)
5361
+ }, [
5362
+ createTextVNode(toDisplayString(dateFormatValue.value) + " ", 1),
5363
+ createVNode(_component_van_icon, { name: "arrow-down" })
5364
+ ]),
5365
+ timePickerType.value !== "dateRange" ? (openBlock(), createElementBlock("div", {
5366
+ key: 1,
5367
+ class: "jb-mobile-date-picker__date-arrow right",
5368
+ onClick: changeDateNext
5369
+ }, [
5370
+ createElementVNode("img", {
5371
+ src: forwardIcon.value,
5372
+ alt: "forward"
5373
+ }, null, 8, _hoisted_3$3)
5374
+ ])) : createCommentVNode("", true)
5375
+ ])
5376
+ ]),
5178
5377
  withDirectives(createVNode(_component_van_calendar, {
5179
5378
  ref_key: "calendarRef",
5180
5379
  ref: calendarRef,
@@ -5194,28 +5393,28 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5194
5393
  onConfirm: handleFinishSelectDate
5195
5394
  }, {
5196
5395
  text: withCtx(({ text }) => [
5197
- createElementVNode("div", _hoisted_1$5, toDisplayString(text), 1)
5396
+ createElementVNode("div", _hoisted_4$2, toDisplayString(text), 1)
5198
5397
  ]),
5199
5398
  _: 1
5200
5399
  }, 8, ["type", "min-date", "max-date", "default-date"]), [
5201
5400
  [vShow, isShowCalendar.value]
5202
5401
  ]),
5203
- withDirectives(createElementVNode("div", null, [
5402
+ withDirectives(createElementVNode("div", _hoisted_5$1, [
5204
5403
  (openBlock(true), createElementBlock(Fragment, null, renderList(timePickerTypeObj.value.timeList, (item) => {
5205
5404
  return openBlock(), createElementBlock("div", {
5206
5405
  key: item.value,
5207
5406
  class: "jb-mobile-time-picker__group"
5208
5407
  }, [
5209
- item.title ? (openBlock(), createElementBlock("div", _hoisted_2$4, toDisplayString(item.title), 1)) : createCommentVNode("", true),
5408
+ item.title ? (openBlock(), createElementBlock("div", _hoisted_6$1, toDisplayString(item.title), 1)) : createCommentVNode("", true),
5210
5409
  createElementVNode("div", {
5211
- class: normalizeClass$1(["jb-mobile-time-picker__group__list", { "three-in-row": __props.timePickerType === "year" }])
5410
+ class: normalizeClass$1(["jb-mobile-time-picker__group__list", { "three-in-row": timePickerType.value === "year" }])
5212
5411
  }, [
5213
5412
  (openBlock(true), createElementBlock(Fragment, null, renderList(item.children, (subItem) => {
5214
5413
  return openBlock(), createElementBlock("div", {
5215
5414
  key: subItem.value,
5216
5415
  class: normalizeClass$1(["jb-mobile-time-picker__group__list-item", { selected: subItem.value === selectedTimeValue.value }]),
5217
5416
  onClick: ($event) => handleSelectDateItem(subItem.value)
5218
- }, toDisplayString(subItem.label), 11, _hoisted_3$3);
5417
+ }, toDisplayString(subItem.label), 11, _hoisted_7$1);
5219
5418
  }), 128))
5220
5419
  ], 2)
5221
5420
  ]);
@@ -5230,11 +5429,11 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5230
5429
  };
5231
5430
  }
5232
5431
  });
5233
- const JbMobileTimePicker = /* @__PURE__ */ _export_sfc(_sfc_main$5, [["__scopeId", "data-v-660dd083"]]);
5234
- const _hoisted_1$4 = { class: "jb-mobile-date-picker" };
5432
+ const JbMobileTimePicker = /* @__PURE__ */ _export_sfc(_sfc_main$6, [["__scopeId", "data-v-265b0b23"]]);
5433
+ const _hoisted_1$5 = { class: "jb-mobile-date-picker" };
5235
5434
  const _hoisted_2$3 = { class: "jb-mobile-date-picker__value" };
5236
5435
  const _hoisted_3$2 = ["src"];
5237
- const _sfc_main$4 = /* @__PURE__ */ defineComponent({
5436
+ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5238
5437
  __name: "JbMobileDatePicker",
5239
5438
  props: {
5240
5439
  datePickerType: {
@@ -5345,7 +5544,7 @@ const _sfc_main$4 = /* @__PURE__ */ defineComponent({
5345
5544
  const _component_van_tab = Tab;
5346
5545
  const _component_van_tabs = Tabs;
5347
5546
  const _component_van_icon = Icon;
5348
- return openBlock(), createElementBlock("div", _hoisted_1$4, [
5547
+ return openBlock(), createElementBlock("div", _hoisted_1$5, [
5349
5548
  createVNode(_component_van_tabs, {
5350
5549
  active: datePickerType.value,
5351
5550
  "onUpdate:active": _cache[0] || (_cache[0] = ($event) => datePickerType.value = $event),
@@ -5373,7 +5572,7 @@ const _sfc_main$4 = /* @__PURE__ */ defineComponent({
5373
5572
  onClick: changeDatePrev
5374
5573
  }, _cache[3] || (_cache[3] = [
5375
5574
  createElementVNode("img", {
5376
- src: _imports_0$5,
5575
+ src: _imports_0$6,
5377
5576
  alt: "back"
5378
5577
  }, null, -1)
5379
5578
  ]))) : createCommentVNode("", true),
@@ -5409,11 +5608,11 @@ const _sfc_main$4 = /* @__PURE__ */ defineComponent({
5409
5608
  };
5410
5609
  }
5411
5610
  });
5412
- const JbMobileDatePicker = /* @__PURE__ */ _export_sfc(_sfc_main$4, [["__scopeId", "data-v-0db0b60f"]]);
5413
- const _imports_0$3 = "";
5414
- const _hoisted_1$3 = { class: "jb-mobile-empty" };
5611
+ const JbMobileDatePicker = /* @__PURE__ */ _export_sfc(_sfc_main$5, [["__scopeId", "data-v-54d3d818"]]);
5612
+ const _imports_0$4 = "";
5613
+ const _hoisted_1$4 = { class: "jb-mobile-empty" };
5415
5614
  const _hoisted_2$2 = { class: "jb-mobile-empty__tip" };
5416
- const _sfc_main$3 = /* @__PURE__ */ defineComponent({
5615
+ const _sfc_main$4 = /* @__PURE__ */ defineComponent({
5417
5616
  __name: "JbMobileEmpty",
5418
5617
  props: {
5419
5618
  tip: {
@@ -5423,10 +5622,10 @@ const _sfc_main$3 = /* @__PURE__ */ defineComponent({
5423
5622
  },
5424
5623
  setup(__props) {
5425
5624
  return (_ctx, _cache) => {
5426
- return openBlock(), createElementBlock("div", _hoisted_1$3, [
5625
+ return openBlock(), createElementBlock("div", _hoisted_1$4, [
5427
5626
  _cache[0] || (_cache[0] = createElementVNode("img", {
5428
5627
  class: "jb-mobile-empty__img",
5429
- src: _imports_0$3,
5628
+ src: _imports_0$4,
5430
5629
  alt: ""
5431
5630
  }, null, -1)),
5432
5631
  createElementVNode("div", _hoisted_2$2, toDisplayString(__props.tip), 1),
@@ -5435,10 +5634,10 @@ const _sfc_main$3 = /* @__PURE__ */ defineComponent({
5435
5634
  };
5436
5635
  }
5437
5636
  });
5438
- const JbMobileEmpty = /* @__PURE__ */ _export_sfc(_sfc_main$3, [["__scopeId", "data-v-e1f68e36"]]);
5439
- 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";
5440
- const _hoisted_1$2 = { class: "jb-mobile-search-input" };
5441
- const _sfc_main$2 = /* @__PURE__ */ defineComponent({
5637
+ const JbMobileEmpty = /* @__PURE__ */ _export_sfc(_sfc_main$4, [["__scopeId", "data-v-d9fe44ac"]]);
5638
+ 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";
5639
+ const _hoisted_1$3 = { class: "jb-mobile-search-input" };
5640
+ const _sfc_main$3 = /* @__PURE__ */ defineComponent({
5442
5641
  __name: "JbMobileSearchInput",
5443
5642
  props: {
5444
5643
  modelValue: {
@@ -5460,10 +5659,10 @@ const _sfc_main$2 = /* @__PURE__ */ defineComponent({
5460
5659
  }
5461
5660
  });
5462
5661
  return (_ctx, _cache) => {
5463
- return openBlock(), createElementBlock("div", _hoisted_1$2, [
5662
+ return openBlock(), createElementBlock("div", _hoisted_1$3, [
5464
5663
  _cache[2] || (_cache[2] = createElementVNode("img", {
5465
5664
  class: "jb-mobile-search-input__search-icon",
5466
- src: _imports_0$2,
5665
+ src: _imports_0$3,
5467
5666
  alt: ""
5468
5667
  }, null, -1)),
5469
5668
  withDirectives(createElementVNode("input", mergeProps({
@@ -5488,8 +5687,35 @@ const _sfc_main$2 = /* @__PURE__ */ defineComponent({
5488
5687
  };
5489
5688
  }
5490
5689
  });
5491
- const JbMobileSearchInput = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["__scopeId", "data-v-ef3bf05c"]]);
5492
- const _imports_0$1 = "";
5690
+ const JbMobileSearchInput = /* @__PURE__ */ _export_sfc(_sfc_main$3, [["__scopeId", "data-v-84b3e7a1"]]);
5691
+ const _imports_0$2 = "";
5692
+ const _imports_0$1 = "";
5693
+ const _hoisted_1$2 = { class: "mobile-select-face" };
5694
+ const _sfc_main$2 = /* @__PURE__ */ defineComponent({
5695
+ __name: "JbMobileSelectFace",
5696
+ props: {
5697
+ slotClick: { type: Function }
5698
+ },
5699
+ setup(__props) {
5700
+ const props = __props;
5701
+ const handleClickSlot = () => {
5702
+ props.slotClick && props.slotClick();
5703
+ };
5704
+ return (_ctx, _cache) => {
5705
+ return openBlock(), createElementBlock("div", _hoisted_1$2, [
5706
+ renderSlot(_ctx.$slots, "default", {
5707
+ onClick: withModifiers(handleClickSlot, ["stop"])
5708
+ }, void 0, true),
5709
+ _cache[0] || (_cache[0] = createElementVNode("img", {
5710
+ src: _imports_0$1,
5711
+ alt: "",
5712
+ class: "pull-down"
5713
+ }, null, -1))
5714
+ ]);
5715
+ };
5716
+ }
5717
+ });
5718
+ const JbMobileSelectFace = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["__scopeId", "data-v-942028c6"]]);
5493
5719
  const _hoisted_1$1 = { class: "jb-mobile-select__value" };
5494
5720
  const _hoisted_2$1 = {
5495
5721
  key: 0,
@@ -5503,6 +5729,11 @@ const _hoisted_4$1 = {
5503
5729
  const _sfc_main$1 = /* @__PURE__ */ defineComponent({
5504
5730
  __name: "JbMobileSelect",
5505
5731
  props: {
5732
+ // 当tabIndex == 0 时,选中第一个选项,则显示普通的select样式,如果为1,则显示/ComplaintAnalysis/dialog的样式
5733
+ tabIndex: {
5734
+ type: Number,
5735
+ default: 0
5736
+ },
5506
5737
  width: {
5507
5738
  type: Number,
5508
5739
  default: 92
@@ -5517,7 +5748,7 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
5517
5748
  },
5518
5749
  popupTitle: {
5519
5750
  type: String,
5520
- default: "请选择"
5751
+ default: "请选择事件类型"
5521
5752
  },
5522
5753
  options: {
5523
5754
  type: Array,
@@ -5529,10 +5760,11 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
5529
5760
  }
5530
5761
  },
5531
5762
  emits: ["update:modelValue", "change"],
5532
- setup(__props, { emit: __emit }) {
5763
+ setup(__props, { expose: __expose, emit: __emit }) {
5533
5764
  const attrs = useAttrs();
5534
5765
  const emits = __emit;
5535
5766
  const props = __props;
5767
+ const tabIndex = computed(() => props.tabIndex);
5536
5768
  const isShowOptionsPopup = ref(false);
5537
5769
  const selectedOptionItem = ref({});
5538
5770
  const computedWidth = computed(() => `${props.width}px`);
@@ -5556,30 +5788,43 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
5556
5788
  }
5557
5789
  });
5558
5790
  const handleSelectOptionItem = (item) => {
5791
+ console.log("item", item);
5559
5792
  selectedOptionItem.value = item;
5560
5793
  isShowOptionsPopup.value = false;
5561
5794
  modelValue.value = item[fieldNames.value.value];
5562
5795
  emits("change", item[fieldNames.value.label]);
5563
5796
  };
5797
+ __expose({
5798
+ handleSelectOptionItem
5799
+ });
5564
5800
  return (_ctx, _cache) => {
5565
5801
  return openBlock(), createElementBlock(Fragment, null, [
5566
- createElementVNode("div", {
5802
+ tabIndex.value === 0 ? (openBlock(), createElementBlock("div", {
5803
+ key: 0,
5567
5804
  class: "jb-mobile-select",
5568
5805
  style: normalizeStyle$1({ width: computedWidth.value }),
5569
5806
  onClick: _cache[0] || (_cache[0] = ($event) => isShowOptionsPopup.value = true)
5570
5807
  }, [
5571
5808
  createElementVNode("div", _hoisted_1$1, toDisplayString(selectedOptionItem.value[fieldNames.value.label] || __props.placeholder), 1),
5572
- _cache[2] || (_cache[2] = createElementVNode("img", {
5809
+ _cache[3] || (_cache[3] = createElementVNode("img", {
5573
5810
  class: "jb-mobile-select__select-down-icon",
5574
- src: _imports_0$1,
5811
+ src: _imports_0$2,
5575
5812
  alt: ""
5576
5813
  }, null, -1))
5577
- ], 4),
5814
+ ], 4)) : tabIndex.value === 1 ? (openBlock(), createBlock(JbMobileSelectFace, {
5815
+ key: 1,
5816
+ onClick: _cache[1] || (_cache[1] = ($event) => isShowOptionsPopup.value = true)
5817
+ }, {
5818
+ default: withCtx(() => [
5819
+ createTextVNode(toDisplayString(selectedOptionItem.value[fieldNames.value.label] || __props.placeholder), 1)
5820
+ ]),
5821
+ _: 1
5822
+ })) : createCommentVNode("", true),
5578
5823
  createVNode(JbMobilePopup, mergeProps({
5579
5824
  visible: isShowOptionsPopup.value,
5580
- "onUpdate:visible": _cache[1] || (_cache[1] = ($event) => isShowOptionsPopup.value = $event)
5825
+ "onUpdate:visible": _cache[2] || (_cache[2] = ($event) => isShowOptionsPopup.value = $event)
5581
5826
  }, unref(attrs), {
5582
- title: "请选择事件类型",
5827
+ title: __props.popupTitle,
5583
5828
  "grey-bg": true,
5584
5829
  "foot-button": false,
5585
5830
  height: 434
@@ -5598,12 +5843,12 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
5598
5843
  ]))
5599
5844
  ]),
5600
5845
  _: 1
5601
- }, 16, ["visible"])
5846
+ }, 16, ["visible", "title"])
5602
5847
  ], 64);
5603
5848
  };
5604
5849
  }
5605
5850
  });
5606
- const JbMobileSelect = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["__scopeId", "data-v-434af3f2"]]);
5851
+ const JbMobileSelect = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["__scopeId", "data-v-05b6eda0"]]);
5607
5852
  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";
5608
5853
  const _hoisted_1 = { class: "jb-mobile-tree-select-popup__search" };
5609
5854
  const _hoisted_2 = { class: "jb-mobile-tree-select-popup__list" };
@@ -5862,7 +6107,331 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
5862
6107
  };
5863
6108
  }
5864
6109
  });
5865
- const JbMobileTreeSelectPopup = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-9e0ae446"]]);
6110
+ const JbMobileTreeSelectPopup = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-5d589597"]]);
6111
+ var freeGlobal = typeof global == "object" && global && global.Object === Object && global;
6112
+ var freeSelf = typeof self == "object" && self && self.Object === Object && self;
6113
+ var root = freeGlobal || freeSelf || Function("return this")();
6114
+ var Symbol$1 = root.Symbol;
6115
+ var objectProto$1 = Object.prototype;
6116
+ var hasOwnProperty = objectProto$1.hasOwnProperty;
6117
+ var nativeObjectToString$1 = objectProto$1.toString;
6118
+ var symToStringTag$1 = Symbol$1 ? Symbol$1.toStringTag : void 0;
6119
+ function getRawTag(value) {
6120
+ var isOwn = hasOwnProperty.call(value, symToStringTag$1), tag = value[symToStringTag$1];
6121
+ try {
6122
+ value[symToStringTag$1] = void 0;
6123
+ var unmasked = true;
6124
+ } catch (e) {
6125
+ }
6126
+ var result = nativeObjectToString$1.call(value);
6127
+ if (unmasked) {
6128
+ if (isOwn) {
6129
+ value[symToStringTag$1] = tag;
6130
+ } else {
6131
+ delete value[symToStringTag$1];
6132
+ }
6133
+ }
6134
+ return result;
6135
+ }
6136
+ var objectProto = Object.prototype;
6137
+ var nativeObjectToString = objectProto.toString;
6138
+ function objectToString(value) {
6139
+ return nativeObjectToString.call(value);
6140
+ }
6141
+ var nullTag = "[object Null]", undefinedTag = "[object Undefined]";
6142
+ var symToStringTag = Symbol$1 ? Symbol$1.toStringTag : void 0;
6143
+ function baseGetTag(value) {
6144
+ if (value == null) {
6145
+ return value === void 0 ? undefinedTag : nullTag;
6146
+ }
6147
+ return symToStringTag && symToStringTag in Object(value) ? getRawTag(value) : objectToString(value);
6148
+ }
6149
+ function isObjectLike(value) {
6150
+ return value != null && typeof value == "object";
6151
+ }
6152
+ var symbolTag = "[object Symbol]";
6153
+ function isSymbol(value) {
6154
+ return typeof value == "symbol" || isObjectLike(value) && baseGetTag(value) == symbolTag;
6155
+ }
6156
+ var reWhitespace = /\s/;
6157
+ function trimmedEndIndex(string) {
6158
+ var index = string.length;
6159
+ while (index-- && reWhitespace.test(string.charAt(index))) {
6160
+ }
6161
+ return index;
6162
+ }
6163
+ var reTrimStart = /^\s+/;
6164
+ function baseTrim(string) {
6165
+ return string ? string.slice(0, trimmedEndIndex(string) + 1).replace(reTrimStart, "") : string;
6166
+ }
6167
+ function isObject(value) {
6168
+ var type = typeof value;
6169
+ return value != null && (type == "object" || type == "function");
6170
+ }
6171
+ var NAN = 0 / 0;
6172
+ var reIsBadHex = /^[-+]0x[0-9a-f]+$/i;
6173
+ var reIsBinary = /^0b[01]+$/i;
6174
+ var reIsOctal = /^0o[0-7]+$/i;
6175
+ var freeParseInt = parseInt;
6176
+ function toNumber(value) {
6177
+ if (typeof value == "number") {
6178
+ return value;
6179
+ }
6180
+ if (isSymbol(value)) {
6181
+ return NAN;
6182
+ }
6183
+ if (isObject(value)) {
6184
+ var other = typeof value.valueOf == "function" ? value.valueOf() : value;
6185
+ value = isObject(other) ? other + "" : other;
6186
+ }
6187
+ if (typeof value != "string") {
6188
+ return value === 0 ? value : +value;
6189
+ }
6190
+ value = baseTrim(value);
6191
+ var isBinary = reIsBinary.test(value);
6192
+ return isBinary || reIsOctal.test(value) ? freeParseInt(value.slice(2), isBinary ? 2 : 8) : reIsBadHex.test(value) ? NAN : +value;
6193
+ }
6194
+ var now = function() {
6195
+ return root.Date.now();
6196
+ };
6197
+ var FUNC_ERROR_TEXT$1 = "Expected a function";
6198
+ var nativeMax = Math.max, nativeMin = Math.min;
6199
+ function debounce(func, wait, options) {
6200
+ var lastArgs, lastThis, maxWait, result, timerId, lastCallTime, lastInvokeTime = 0, leading = false, maxing = false, trailing = true;
6201
+ if (typeof func != "function") {
6202
+ throw new TypeError(FUNC_ERROR_TEXT$1);
6203
+ }
6204
+ wait = toNumber(wait) || 0;
6205
+ if (isObject(options)) {
6206
+ leading = !!options.leading;
6207
+ maxing = "maxWait" in options;
6208
+ maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;
6209
+ trailing = "trailing" in options ? !!options.trailing : trailing;
6210
+ }
6211
+ function invokeFunc(time) {
6212
+ var args = lastArgs, thisArg = lastThis;
6213
+ lastArgs = lastThis = void 0;
6214
+ lastInvokeTime = time;
6215
+ result = func.apply(thisArg, args);
6216
+ return result;
6217
+ }
6218
+ function leadingEdge(time) {
6219
+ lastInvokeTime = time;
6220
+ timerId = setTimeout(timerExpired, wait);
6221
+ return leading ? invokeFunc(time) : result;
6222
+ }
6223
+ function remainingWait(time) {
6224
+ var timeSinceLastCall = time - lastCallTime, timeSinceLastInvoke = time - lastInvokeTime, timeWaiting = wait - timeSinceLastCall;
6225
+ return maxing ? nativeMin(timeWaiting, maxWait - timeSinceLastInvoke) : timeWaiting;
6226
+ }
6227
+ function shouldInvoke(time) {
6228
+ var timeSinceLastCall = time - lastCallTime, timeSinceLastInvoke = time - lastInvokeTime;
6229
+ return lastCallTime === void 0 || timeSinceLastCall >= wait || timeSinceLastCall < 0 || maxing && timeSinceLastInvoke >= maxWait;
6230
+ }
6231
+ function timerExpired() {
6232
+ var time = now();
6233
+ if (shouldInvoke(time)) {
6234
+ return trailingEdge(time);
6235
+ }
6236
+ timerId = setTimeout(timerExpired, remainingWait(time));
6237
+ }
6238
+ function trailingEdge(time) {
6239
+ timerId = void 0;
6240
+ if (trailing && lastArgs) {
6241
+ return invokeFunc(time);
6242
+ }
6243
+ lastArgs = lastThis = void 0;
6244
+ return result;
6245
+ }
6246
+ function cancel() {
6247
+ if (timerId !== void 0) {
6248
+ clearTimeout(timerId);
6249
+ }
6250
+ lastInvokeTime = 0;
6251
+ lastArgs = lastCallTime = lastThis = timerId = void 0;
6252
+ }
6253
+ function flush() {
6254
+ return timerId === void 0 ? result : trailingEdge(now());
6255
+ }
6256
+ function debounced() {
6257
+ var time = now(), isInvoking = shouldInvoke(time);
6258
+ lastArgs = arguments;
6259
+ lastThis = this;
6260
+ lastCallTime = time;
6261
+ if (isInvoking) {
6262
+ if (timerId === void 0) {
6263
+ return leadingEdge(lastCallTime);
6264
+ }
6265
+ if (maxing) {
6266
+ clearTimeout(timerId);
6267
+ timerId = setTimeout(timerExpired, wait);
6268
+ return invokeFunc(lastCallTime);
6269
+ }
6270
+ }
6271
+ if (timerId === void 0) {
6272
+ timerId = setTimeout(timerExpired, wait);
6273
+ }
6274
+ return result;
6275
+ }
6276
+ debounced.cancel = cancel;
6277
+ debounced.flush = flush;
6278
+ return debounced;
6279
+ }
6280
+ var FUNC_ERROR_TEXT = "Expected a function";
6281
+ function throttle(func, wait, options) {
6282
+ var leading = true, trailing = true;
6283
+ if (typeof func != "function") {
6284
+ throw new TypeError(FUNC_ERROR_TEXT);
6285
+ }
6286
+ if (isObject(options)) {
6287
+ leading = "leading" in options ? !!options.leading : leading;
6288
+ trailing = "trailing" in options ? !!options.trailing : trailing;
6289
+ }
6290
+ return debounce(func, wait, {
6291
+ "leading": leading,
6292
+ "maxWait": wait,
6293
+ "trailing": trailing
6294
+ });
6295
+ }
6296
+ function useInfiniteScroll(options = {}) {
6297
+ const {
6298
+ bottomThreshold = 100,
6299
+ topThreshold = 100,
6300
+ throttleDelay = 300,
6301
+ disabled = ref(false),
6302
+ onLoadMore,
6303
+ onLoadPrevious,
6304
+ debug = false
6305
+ } = options;
6306
+ const isLoadingMore = ref(false);
6307
+ const isLoadingPrevious = ref(false);
6308
+ const hasMoreData = ref(true);
6309
+ const hasPreviousData = ref(true);
6310
+ let lastScrollTop = 0;
6311
+ const executeLoadMore = async () => {
6312
+ if (isLoadingMore.value || !hasMoreData.value || !onLoadMore) {
6313
+ return;
6314
+ }
6315
+ isLoadingMore.value = true;
6316
+ try {
6317
+ await onLoadMore();
6318
+ if (debug) console.log("✅ 向下加载更多完成");
6319
+ } catch (error) {
6320
+ console.error("❌ 向下加载更多失败:", error);
6321
+ } finally {
6322
+ isLoadingMore.value = false;
6323
+ }
6324
+ };
6325
+ const executeLoadPrevious = async () => {
6326
+ if (isLoadingPrevious.value || !hasPreviousData.value || !onLoadPrevious) {
6327
+ return;
6328
+ }
6329
+ isLoadingPrevious.value = true;
6330
+ try {
6331
+ await onLoadPrevious();
6332
+ if (debug) console.log("✅ 向上加载完成");
6333
+ } catch (error) {
6334
+ console.error("❌ 向上加载失败:", error);
6335
+ } finally {
6336
+ isLoadingPrevious.value = false;
6337
+ }
6338
+ };
6339
+ const handleScroll = throttle(async (event) => {
6340
+ if (disabled.value) return;
6341
+ const target = event.target;
6342
+ if (!target) return;
6343
+ const { scrollTop, scrollHeight, clientHeight } = target;
6344
+ const distanceToBottom = scrollHeight - scrollTop - clientHeight;
6345
+ const distanceToTop = scrollTop;
6346
+ const isNearBottom = distanceToBottom < bottomThreshold;
6347
+ const isNearTop = distanceToTop < topThreshold;
6348
+ let scrollDirection = "none";
6349
+ if (scrollTop > lastScrollTop) {
6350
+ scrollDirection = "down";
6351
+ } else if (scrollTop < lastScrollTop) {
6352
+ scrollDirection = "up";
6353
+ }
6354
+ lastScrollTop = scrollTop;
6355
+ const scrollInfo = {
6356
+ scrollTop,
6357
+ scrollHeight,
6358
+ clientHeight,
6359
+ distanceToBottom,
6360
+ distanceToTop,
6361
+ isNearBottom,
6362
+ isNearTop,
6363
+ scrollDirection
6364
+ };
6365
+ if (debug) {
6366
+ console.log("📊 滚动信息:", scrollInfo);
6367
+ }
6368
+ if (isNearBottom && scrollDirection === "down") {
6369
+ if (debug) console.log("🔽 触发向下加载");
6370
+ await executeLoadMore();
6371
+ }
6372
+ if (isNearTop && scrollDirection === "up") {
6373
+ if (debug) console.log("🔼 触发向上加载");
6374
+ await executeLoadPrevious();
6375
+ }
6376
+ }, throttleDelay);
6377
+ const reset = () => {
6378
+ isLoadingMore.value = false;
6379
+ isLoadingPrevious.value = false;
6380
+ hasMoreData.value = true;
6381
+ hasPreviousData.value = true;
6382
+ lastScrollTop = 0;
6383
+ };
6384
+ const triggerLoadMore = async () => {
6385
+ await executeLoadMore();
6386
+ };
6387
+ const triggerLoadPrevious = async () => {
6388
+ await executeLoadPrevious();
6389
+ };
6390
+ const setDataState = (options2) => {
6391
+ if (options2.hasMore !== void 0) {
6392
+ hasMoreData.value = options2.hasMore;
6393
+ }
6394
+ if (options2.hasPrevious !== void 0) {
6395
+ hasPreviousData.value = options2.hasPrevious;
6396
+ }
6397
+ };
6398
+ const state = {
6399
+ isLoadingMore,
6400
+ isLoadingPrevious,
6401
+ hasMoreData,
6402
+ hasPreviousData
6403
+ };
6404
+ return {
6405
+ // 状态
6406
+ ...state,
6407
+ // 方法
6408
+ handleScroll,
6409
+ reset,
6410
+ triggerLoadMore,
6411
+ triggerLoadPrevious,
6412
+ setDataState
6413
+ };
6414
+ }
6415
+ const useGlobalLoading = () => {
6416
+ return customRef((track, trigger) => {
6417
+ let loadingCount = 0;
6418
+ return {
6419
+ get() {
6420
+ track();
6421
+ return loadingCount > 0;
6422
+ },
6423
+ set(value) {
6424
+ if (value) {
6425
+ loadingCount += 1;
6426
+ } else {
6427
+ loadingCount -= 1;
6428
+ }
6429
+ loadingCount = Math.max(0, loadingCount);
6430
+ trigger();
6431
+ }
6432
+ };
6433
+ });
6434
+ };
5866
6435
  export {
5867
6436
  JbMobileButton,
5868
6437
  JbMobileDatePicker,
@@ -5871,5 +6440,7 @@ export {
5871
6440
  JbMobileSearchInput,
5872
6441
  JbMobileSelect,
5873
6442
  JbMobileTimePicker,
5874
- JbMobileTreeSelectPopup
6443
+ JbMobileTreeSelectPopup,
6444
+ useGlobalLoading,
6445
+ useInfiniteScroll
5875
6446
  };