jb-mobile-ui 1.0.6 → 1.0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.es.js CHANGED
@@ -1,4 +1,4 @@
1
- import { ref, onMounted, reactive, getCurrentInstance, nextTick, onActivated, onUnmounted, onDeactivated, isRef, watch, inject, computed, provide, unref, isVNode, defineComponent, createVNode, onBeforeUnmount, watchEffect, mergeProps, Transition, Teleport, withDirectives, vShow, Fragment, onBeforeUpdate, Comment, createApp, useAttrs, createBlock, openBlock, withCtx, renderSlot, createElementVNode, createElementBlock, createCommentVNode, toDisplayString, normalizeStyle as normalizeStyle$1, normalizeClass as normalizeClass$1, createTextVNode, renderList, vModelDynamic } 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-177e5e3b"]]);
4729
+ const _imports_0$6 = "data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20width='24px'%20height='24px'%20viewBox='0%200%2024%2024'%20version='1.1'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3ctitle%3e编组%2017%3c/title%3e%3cg%20id='页面-1'%20stroke='none'%20stroke-width='1'%20fill='none'%20fill-rule='evenodd'%3e%3cg%20id='按地区'%20transform='translate(-26,%20-254)'%3e%3cg%20id='编组-17'%20transform='translate(26,%20254)'%3e%3ccircle%20id='椭圆形'%20fill='%23F4F4F4'%20cx='12'%20cy='12'%20r='12'%3e%3c/circle%3e%3cpolyline%20id='路径'%20stroke='%23000000'%20stroke-width='1.33333333'%20stroke-linecap='round'%20stroke-linejoin='round'%20points='14%2016%2010%2012%2014%208'%3e%3c/polyline%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/svg%3e";
4730
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,7 +4816,7 @@ 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
  ]))
@@ -4847,14 +4847,21 @@ const _sfc_main$6 = /* @__PURE__ */ defineComponent({
4847
4847
  };
4848
4848
  }
4849
4849
  });
4850
- const JbMobilePopup = /* @__PURE__ */ _export_sfc(_sfc_main$6, [["__scopeId", "data-v-a6ccf1e5"]]);
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-ea246c2f"]]);
4851
+ const _hoisted_1$6 = {
4852
+ key: 0,
4853
+ class: "jb-mobile-date-picker"
4854
+ };
4855
+ const _hoisted_2$4 = { class: "jb-mobile-date-picker__value" };
4856
+ const _hoisted_3$3 = ["src"];
4857
+ const _hoisted_4$2 = { class: "jb-mobile-time-picker__calendar__inner" };
4858
+ const _hoisted_5$1 = { class: "jb-mobile-time-picker__group-wrap" };
4859
+ const _hoisted_6$1 = {
4853
4860
  key: 0,
4854
4861
  class: "jb-mobile-time-picker__group__title"
4855
4862
  };
4856
- const _hoisted_3$3 = ["onClick"];
4857
- const _sfc_main$5 = /* @__PURE__ */ defineComponent({
4863
+ const _hoisted_7$1 = ["onClick"];
4864
+ const _sfc_main$6 = /* @__PURE__ */ defineComponent({
4858
4865
  __name: "JbMobileTimePicker",
4859
4866
  props: {
4860
4867
  visible: {
@@ -4881,9 +4888,26 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
4881
4888
  valueFormat: {
4882
4889
  type: String,
4883
4890
  default: "YYYY-MM-DD HH:mm:ss"
4891
+ },
4892
+ withSelectTab: {
4893
+ type: Boolean,
4894
+ default: false
4895
+ },
4896
+ datePickerTypeList: {
4897
+ type: Array,
4898
+ default: () => ["dateRange", "week", "month", "quarter", "year"]
4899
+ },
4900
+ disabledTab: {
4901
+ type: Boolean,
4902
+ default: false
4884
4903
  }
4885
4904
  },
4886
- emits: ["update:visible", "confirm"],
4905
+ emits: [
4906
+ "update:visible",
4907
+ "update:timePickerType",
4908
+ "confirm",
4909
+ "changeDateFail"
4910
+ ],
4887
4911
  setup(__props, { expose: __expose, emit: __emit }) {
4888
4912
  dayjs.extend(weekOfYear);
4889
4913
  dayjs.extend(quarterOfYear);
@@ -4898,6 +4922,74 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
4898
4922
  emits("update:visible", val);
4899
4923
  }
4900
4924
  });
4925
+ const isLatestDate = ref(false);
4926
+ const dateFormatValue = ref("");
4927
+ const isShowTimePicker = ref(false);
4928
+ const dateFilterTypeListDefault = computed(() => {
4929
+ return [
4930
+ {
4931
+ label: "天",
4932
+ value: "dateRange"
4933
+ },
4934
+ {
4935
+ label: "周",
4936
+ value: "week"
4937
+ },
4938
+ {
4939
+ label: "月",
4940
+ value: "month"
4941
+ },
4942
+ {
4943
+ label: "季",
4944
+ value: "quarter"
4945
+ },
4946
+ {
4947
+ label: "年",
4948
+ value: "year"
4949
+ }
4950
+ ];
4951
+ });
4952
+ const timePickerType = computed({
4953
+ get() {
4954
+ return props.timePickerType;
4955
+ },
4956
+ set(val) {
4957
+ emits("update:timePickerType", val);
4958
+ }
4959
+ });
4960
+ const dateFilterTypeList = computed(
4961
+ () => dateFilterTypeListDefault.value.filter(
4962
+ (item) => props.datePickerTypeList.includes(item.value)
4963
+ )
4964
+ );
4965
+ const forwardIcon = computed(() => {
4966
+ return isLatestDate.value ? forwardDisabledSvg : forwardSvg;
4967
+ });
4968
+ const changeDatePrev = () => {
4969
+ console.log("props.disabledTab", props.disabledTab);
4970
+ if (props.disabledTab) {
4971
+ emits("changeDateFail");
4972
+ return;
4973
+ }
4974
+ toPrevDate();
4975
+ };
4976
+ const changeDateNext = () => {
4977
+ if (isLatestDate.value) {
4978
+ return;
4979
+ }
4980
+ if (props.disabledTab) {
4981
+ emits("changeDateFail");
4982
+ return;
4983
+ }
4984
+ toNextDate();
4985
+ };
4986
+ const handleTabsBeforeChange = () => {
4987
+ if (props.disabledTab) {
4988
+ emits("changeDateFail");
4989
+ return false;
4990
+ }
4991
+ return true;
4992
+ };
4901
4993
  let isFinishSelect = true;
4902
4994
  let weekStartDate = /* @__PURE__ */ new Date();
4903
4995
  let weekEndDate = /* @__PURE__ */ new Date();
@@ -4906,15 +4998,19 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
4906
4998
  let dateValueFormat = "";
4907
4999
  let confirmSelectedCalendarValue = [];
4908
5000
  let confirmSelectedTimeValue = "";
4909
- const isShowCalendar = computed(() => ["dateRange", "week"].includes(props.timePickerType));
5001
+ const isShowCalendar = computed(
5002
+ () => ["dateRange", "week"].includes(props.timePickerType)
5003
+ );
4910
5004
  const minDate = computed(() => dayjs(props.minDate).toDate());
4911
5005
  const maxDate = computed(() => dayjs(props.maxDate).toDate());
4912
5006
  const timeKey = computed(() => timeKeyMap[props.timePickerType]);
5007
+ const defaultValueFirst = ref(props.defaultValue);
5008
+ const defaultValueSecond = ref(props.defaultValue);
4913
5009
  const defaultDate = computed(() => {
4914
5010
  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();
5011
+ dayjs(defaultValueFirst.value).startOf(timeKey.value).toDate(),
5012
+ dayjs(defaultValueSecond.value).endOf(timeKey.value).toDate()
5013
+ ] : dayjs(defaultValueFirst.value).startOf(timeKey.value).toDate();
4918
5014
  });
4919
5015
  const startYear = dayjs(minDate.value).year();
4920
5016
  const endYear = dayjs(maxDate.value).year();
@@ -4966,7 +5062,9 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
4966
5062
  const timeItem = {};
4967
5063
  timeItem.title = `${currentYear}年`;
4968
5064
  timeItem.value = currentYear + "";
4969
- timeItem.children = [...new Array(currentYear < endYear ? 12 : endMonth).keys()].map((item) => {
5065
+ timeItem.children = [
5066
+ ...new Array(currentYear < endYear ? 12 : endMonth).keys()
5067
+ ].map((item) => {
4970
5068
  const month = item + 1;
4971
5069
  return {
4972
5070
  label: `${month}月`,
@@ -4987,7 +5085,9 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
4987
5085
  const timeItem = {};
4988
5086
  timeItem.title = `${currentYear}年`;
4989
5087
  timeItem.value = currentYear + "";
4990
- timeItem.children = [...new Array(currentYear < endYear ? 4 : endQuarter).keys()].map((item) => {
5088
+ timeItem.children = [
5089
+ ...new Array(currentYear < endYear ? 4 : endQuarter).keys()
5090
+ ].map((item) => {
4991
5091
  return {
4992
5092
  label: `${numberToChinese[item + 1]}季度`,
4993
5093
  value: `${currentYear}-${fillZero(1 + 3 * item)}-01`
@@ -5002,11 +5102,13 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5002
5102
  };
5003
5103
  },
5004
5104
  year() {
5005
- const timeList = [{
5006
- title: "",
5007
- value: "year",
5008
- children: []
5009
- }];
5105
+ const timeList = [
5106
+ {
5107
+ title: "",
5108
+ value: "year",
5109
+ children: []
5110
+ }
5111
+ ];
5010
5112
  for (let currentYear = startYear; currentYear <= endYear; currentYear++) {
5011
5113
  timeList[0].children.push({
5012
5114
  label: `${currentYear}年`,
@@ -5023,22 +5125,29 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5023
5125
  const calendarRef = ref();
5024
5126
  const timePickerContentRef = ref();
5025
5127
  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
- });
5128
+ const timePickerTypeObj = computed(
5129
+ () => timePickerTypeMap[props.timePickerType]()
5130
+ );
5131
+ watch(
5132
+ () => visible.value,
5133
+ (newVal) => {
5134
+ if (newVal) {
5135
+ selectedTimeValue.value = confirmSelectedTimeValue || dayjs(defaultDate.value).format("YYYY-MM-DD");
5136
+ nextTick(() => {
5137
+ setSelectedScrollIntoView();
5138
+ });
5139
+ }
5033
5140
  }
5034
- });
5141
+ );
5035
5142
  const setDateValueFormat = (value, format) => {
5036
5143
  const year = dayjs(value[0]).year();
5037
5144
  if (props.timePickerType === "dateRange") {
5038
5145
  if (dayjs(value[0]).isSame(dayjs(value[1]), "day")) {
5039
5146
  dateValueFormat = `${dayjs(value[0]).format(format)}`;
5040
5147
  } else {
5041
- dateValueFormat = `${dayjs(value[0]).format(format)} ~ ${dayjs(value[1]).format(format)}`;
5148
+ dateValueFormat = `${dayjs(value[0]).format(format)} ~ ${dayjs(
5149
+ value[1]
5150
+ ).format(format)}`;
5042
5151
  }
5043
5152
  } else if (props.timePickerType === "week") {
5044
5153
  const week = dayjs(value[0]).week();
@@ -5053,7 +5162,9 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5053
5162
  const setSelectedScrollIntoView = () => {
5054
5163
  var _a, _b;
5055
5164
  if (["dateRange", "week"].includes(props.timePickerType)) {
5056
- (_a = calendarRef.value) == null ? void 0 : _a.scrollToDate(Array.isArray(defaultDate.value) ? defaultDate.value[0] : defaultDate.value);
5165
+ (_a = calendarRef.value) == null ? void 0 : _a.scrollToDate(
5166
+ Array.isArray(defaultDate.value) ? defaultDate.value[0] : defaultDate.value
5167
+ );
5057
5168
  } else {
5058
5169
  const selectedItem = (_b = timePickerContentRef.value) == null ? void 0 : _b.querySelector(".selected");
5059
5170
  selectedItem == null ? void 0 : selectedItem.scrollIntoView({
@@ -5098,6 +5209,8 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5098
5209
  } else {
5099
5210
  startTime = dayjs(value).startOf(timeKey.value).format(props.valueFormat);
5100
5211
  endTime = dayjs(value).endOf(timeKey.value).format(props.valueFormat);
5212
+ defaultValueFirst.value = startTime;
5213
+ defaultValueSecond.value = endTime;
5101
5214
  }
5102
5215
  };
5103
5216
  const handleSelectDateItem = (value) => {
@@ -5109,22 +5222,34 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5109
5222
  return dayjs(endTime).isSame(dayjs(), timeKey.value);
5110
5223
  };
5111
5224
  const toPrevDate = () => {
5112
- handleFinishSelectDate(dayjs(endTime).subtract(1, timeKey.value).toDate());
5225
+ handleFinishSelectDate(
5226
+ dayjs(endTime).subtract(1, timeKey.value).toDate()
5227
+ );
5113
5228
  selectedTimeValue.value = dayjs(startTime).format("YYYY-MM-DD");
5114
5229
  handleConfirm();
5115
5230
  };
5116
5231
  const toNextDate = () => {
5117
- handleFinishSelectDate(dayjs(endTime).add(1, timeKey.value).toDate());
5118
- selectedTimeValue.value = dayjs(startTime).format("YYYY-MM-DD");
5119
- handleConfirm();
5232
+ nextTick(() => {
5233
+ handleFinishSelectDate(
5234
+ dayjs(endTime).add(1, timeKey.value).toDate()
5235
+ );
5236
+ selectedTimeValue.value = dayjs(startTime).format("YYYY-MM-DD");
5237
+ handleConfirm();
5238
+ });
5120
5239
  };
5121
5240
  const confirmSelectDate = () => {
5122
5241
  setDateValueFormat([startTime, endTime], timePickerTypeObj.value.format);
5123
- emits("confirm", {
5124
- dateValueFormat,
5125
- value: [startTime, endTime],
5126
- isLatestDate: getIsLatestDate()
5127
- });
5242
+ if (props.withSelectTab) {
5243
+ isLatestDate.value = getIsLatestDate();
5244
+ dateFormatValue.value = dateValueFormat;
5245
+ emits("confirm", [startTime, endTime]);
5246
+ } else {
5247
+ emits("confirm", {
5248
+ dateValueFormat,
5249
+ value: [startTime, endTime],
5250
+ isLatestDate: getIsLatestDate()
5251
+ });
5252
+ }
5128
5253
  };
5129
5254
  const handleBeforeConfirm = () => {
5130
5255
  if (!startTime || !endTime) {
@@ -5137,35 +5262,60 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5137
5262
  return true;
5138
5263
  };
5139
5264
  const handleConfirm = () => {
5140
- confirmSelectedCalendarValue = [dayjs(startTime).toDate(), dayjs(endTime).toDate()];
5265
+ confirmSelectedCalendarValue = [
5266
+ dayjs(startTime).toDate(),
5267
+ dayjs(endTime).toDate()
5268
+ ];
5141
5269
  confirmSelectedTimeValue = selectedTimeValue.value;
5142
5270
  confirmSelectDate();
5143
- handleClose();
5271
+ if (!props.withSelectTab) {
5272
+ handleClose();
5273
+ }
5144
5274
  };
5145
5275
  const handleClose = () => {
5146
5276
  var _a;
5147
5277
  visible.value = false;
5148
- (_a = calendarRef.value) == null ? void 0 : _a.reset(confirmSelectedCalendarValue.length ? confirmSelectedCalendarValue : void 0);
5278
+ (_a = calendarRef.value) == null ? void 0 : _a.reset(
5279
+ confirmSelectedCalendarValue.length ? confirmSelectedCalendarValue : void 0
5280
+ );
5149
5281
  setWeekStartAndEndDate(confirmSelectedCalendarValue[0] || defaultDate.value);
5150
5282
  };
5151
- watch(() => timePickerTypeObj.value, () => {
5152
- confirmSelectedCalendarValue = [];
5153
- confirmSelectedTimeValue = "";
5154
- handleFinishSelectDate(defaultDate.value);
5155
- confirmSelectDate();
5156
- }, { immediate: true });
5283
+ watch(
5284
+ () => timePickerTypeObj.value,
5285
+ () => {
5286
+ confirmSelectedCalendarValue = [];
5287
+ confirmSelectedTimeValue = "";
5288
+ console.log("defaultDate.value", defaultDate.value);
5289
+ handleFinishSelectDate(defaultDate.value);
5290
+ confirmSelectDate();
5291
+ if (props.withSelectTab) {
5292
+ selectedTimeValue.value = confirmSelectedTimeValue || dayjs(defaultDate.value).format("YYYY-MM-DD");
5293
+ nextTick(() => {
5294
+ setSelectedScrollIntoView();
5295
+ });
5296
+ }
5297
+ },
5298
+ { immediate: true }
5299
+ );
5300
+ watch(timePickerType, (val) => {
5301
+ console.log("val", val);
5302
+ emits("update:timePickerType", val);
5303
+ });
5157
5304
  __expose({
5158
5305
  toPrevDate,
5159
5306
  toNextDate
5160
5307
  });
5161
5308
  return (_ctx, _cache) => {
5309
+ const _component_van_tab = Tab;
5310
+ const _component_van_tabs = Tabs;
5311
+ const _component_van_icon = Icon;
5162
5312
  const _component_van_calendar = Calendar;
5163
5313
  return openBlock(), createBlock(JbMobilePopup, mergeProps({
5164
5314
  visible: visible.value,
5165
- "onUpdate:visible": _cache[0] || (_cache[0] = ($event) => visible.value = $event)
5315
+ "onUpdate:visible": _cache[2] || (_cache[2] = ($event) => visible.value = $event)
5166
5316
  }, unref(attrs), {
5167
5317
  title: timePickerTypeObj.value.title,
5168
- "grey-bg": !isShowCalendar.value,
5318
+ "grey-bg": !isShowCalendar.value && !__props.withSelectTab,
5169
5319
  "before-confirm": handleBeforeConfirm,
5170
5320
  onConfirm: handleConfirm,
5171
5321
  onClose: handleClose
@@ -5173,8 +5323,60 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5173
5323
  default: withCtx(() => [
5174
5324
  createElementVNode("div", {
5175
5325
  ref_key: "timePickerContentRef",
5176
- ref: timePickerContentRef
5326
+ ref: timePickerContentRef,
5327
+ class: "time-picker__content"
5177
5328
  }, [
5329
+ __props.withSelectTab ? (openBlock(), createElementBlock("div", _hoisted_1$6, [
5330
+ createVNode(_component_van_tabs, {
5331
+ active: timePickerType.value,
5332
+ "onUpdate:active": _cache[0] || (_cache[0] = ($event) => timePickerType.value = $event),
5333
+ "title-inactive-color": "#323233",
5334
+ "title-active-color": "#000",
5335
+ background: "transparent",
5336
+ color: "transparent",
5337
+ "before-change": handleTabsBeforeChange
5338
+ }, {
5339
+ default: withCtx(() => [
5340
+ (openBlock(true), createElementBlock(Fragment, null, renderList(dateFilterTypeList.value, (item) => {
5341
+ return openBlock(), createBlock(_component_van_tab, {
5342
+ key: item.value,
5343
+ title: item.label,
5344
+ name: item.value
5345
+ }, null, 8, ["title", "name"]);
5346
+ }), 128))
5347
+ ]),
5348
+ _: 1
5349
+ }, 8, ["active"]),
5350
+ createElementVNode("div", _hoisted_2$4, [
5351
+ timePickerType.value !== "dateRange" ? (openBlock(), createElementBlock("div", {
5352
+ key: 0,
5353
+ class: "jb-mobile-date-picker__date-arrow left",
5354
+ onClick: changeDatePrev
5355
+ }, _cache[3] || (_cache[3] = [
5356
+ createElementVNode("img", {
5357
+ src: _imports_0$6,
5358
+ alt: "back"
5359
+ }, null, -1)
5360
+ ]))) : createCommentVNode("", true),
5361
+ createElementVNode("div", {
5362
+ class: "jb-mobile-date-picker__date-text",
5363
+ onClick: _cache[1] || (_cache[1] = ($event) => isShowTimePicker.value = true)
5364
+ }, [
5365
+ createTextVNode(toDisplayString(dateFormatValue.value) + " ", 1),
5366
+ createVNode(_component_van_icon, { name: "arrow-down" })
5367
+ ]),
5368
+ timePickerType.value !== "dateRange" ? (openBlock(), createElementBlock("div", {
5369
+ key: 1,
5370
+ class: "jb-mobile-date-picker__date-arrow right",
5371
+ onClick: changeDateNext
5372
+ }, [
5373
+ createElementVNode("img", {
5374
+ src: forwardIcon.value,
5375
+ alt: "forward"
5376
+ }, null, 8, _hoisted_3$3)
5377
+ ])) : createCommentVNode("", true)
5378
+ ])
5379
+ ])) : createCommentVNode("", true),
5178
5380
  withDirectives(createVNode(_component_van_calendar, {
5179
5381
  ref_key: "calendarRef",
5180
5382
  ref: calendarRef,
@@ -5194,28 +5396,28 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5194
5396
  onConfirm: handleFinishSelectDate
5195
5397
  }, {
5196
5398
  text: withCtx(({ text }) => [
5197
- createElementVNode("div", _hoisted_1$5, toDisplayString(text), 1)
5399
+ createElementVNode("div", _hoisted_4$2, toDisplayString(text), 1)
5198
5400
  ]),
5199
5401
  _: 1
5200
5402
  }, 8, ["type", "min-date", "max-date", "default-date"]), [
5201
5403
  [vShow, isShowCalendar.value]
5202
5404
  ]),
5203
- withDirectives(createElementVNode("div", null, [
5405
+ withDirectives(createElementVNode("div", _hoisted_5$1, [
5204
5406
  (openBlock(true), createElementBlock(Fragment, null, renderList(timePickerTypeObj.value.timeList, (item) => {
5205
5407
  return openBlock(), createElementBlock("div", {
5206
5408
  key: item.value,
5207
5409
  class: "jb-mobile-time-picker__group"
5208
5410
  }, [
5209
- item.title ? (openBlock(), createElementBlock("div", _hoisted_2$4, toDisplayString(item.title), 1)) : createCommentVNode("", true),
5411
+ item.title ? (openBlock(), createElementBlock("div", _hoisted_6$1, toDisplayString(item.title), 1)) : createCommentVNode("", true),
5210
5412
  createElementVNode("div", {
5211
- class: normalizeClass$1(["jb-mobile-time-picker__group__list", { "three-in-row": __props.timePickerType === "year" }])
5413
+ class: normalizeClass$1(["jb-mobile-time-picker__group__list", { "three-in-row": timePickerType.value === "year" }])
5212
5414
  }, [
5213
5415
  (openBlock(true), createElementBlock(Fragment, null, renderList(item.children, (subItem) => {
5214
5416
  return openBlock(), createElementBlock("div", {
5215
5417
  key: subItem.value,
5216
5418
  class: normalizeClass$1(["jb-mobile-time-picker__group__list-item", { selected: subItem.value === selectedTimeValue.value }]),
5217
5419
  onClick: ($event) => handleSelectDateItem(subItem.value)
5218
- }, toDisplayString(subItem.label), 11, _hoisted_3$3);
5420
+ }, toDisplayString(subItem.label), 11, _hoisted_7$1);
5219
5421
  }), 128))
5220
5422
  ], 2)
5221
5423
  ]);
@@ -5230,11 +5432,11 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5230
5432
  };
5231
5433
  }
5232
5434
  });
5233
- const JbMobileTimePicker = /* @__PURE__ */ _export_sfc(_sfc_main$5, [["__scopeId", "data-v-660dd083"]]);
5234
- const _hoisted_1$4 = { class: "jb-mobile-date-picker" };
5435
+ const JbMobileTimePicker = /* @__PURE__ */ _export_sfc(_sfc_main$6, [["__scopeId", "data-v-4948099e"]]);
5436
+ const _hoisted_1$5 = { class: "jb-mobile-date-picker" };
5235
5437
  const _hoisted_2$3 = { class: "jb-mobile-date-picker__value" };
5236
5438
  const _hoisted_3$2 = ["src"];
5237
- const _sfc_main$4 = /* @__PURE__ */ defineComponent({
5439
+ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
5238
5440
  __name: "JbMobileDatePicker",
5239
5441
  props: {
5240
5442
  datePickerType: {
@@ -5345,7 +5547,7 @@ const _sfc_main$4 = /* @__PURE__ */ defineComponent({
5345
5547
  const _component_van_tab = Tab;
5346
5548
  const _component_van_tabs = Tabs;
5347
5549
  const _component_van_icon = Icon;
5348
- return openBlock(), createElementBlock("div", _hoisted_1$4, [
5550
+ return openBlock(), createElementBlock("div", _hoisted_1$5, [
5349
5551
  createVNode(_component_van_tabs, {
5350
5552
  active: datePickerType.value,
5351
5553
  "onUpdate:active": _cache[0] || (_cache[0] = ($event) => datePickerType.value = $event),
@@ -5373,7 +5575,7 @@ const _sfc_main$4 = /* @__PURE__ */ defineComponent({
5373
5575
  onClick: changeDatePrev
5374
5576
  }, _cache[3] || (_cache[3] = [
5375
5577
  createElementVNode("img", {
5376
- src: _imports_0$5,
5578
+ src: _imports_0$6,
5377
5579
  alt: "back"
5378
5580
  }, null, -1)
5379
5581
  ]))) : createCommentVNode("", true),
@@ -5409,11 +5611,11 @@ const _sfc_main$4 = /* @__PURE__ */ defineComponent({
5409
5611
  };
5410
5612
  }
5411
5613
  });
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" };
5614
+ const JbMobileDatePicker = /* @__PURE__ */ _export_sfc(_sfc_main$5, [["__scopeId", "data-v-0db0b60f"]]);
5615
+ const _imports_0$4 = "";
5616
+ const _hoisted_1$4 = { class: "jb-mobile-empty" };
5415
5617
  const _hoisted_2$2 = { class: "jb-mobile-empty__tip" };
5416
- const _sfc_main$3 = /* @__PURE__ */ defineComponent({
5618
+ const _sfc_main$4 = /* @__PURE__ */ defineComponent({
5417
5619
  __name: "JbMobileEmpty",
5418
5620
  props: {
5419
5621
  tip: {
@@ -5423,10 +5625,10 @@ const _sfc_main$3 = /* @__PURE__ */ defineComponent({
5423
5625
  },
5424
5626
  setup(__props) {
5425
5627
  return (_ctx, _cache) => {
5426
- return openBlock(), createElementBlock("div", _hoisted_1$3, [
5628
+ return openBlock(), createElementBlock("div", _hoisted_1$4, [
5427
5629
  _cache[0] || (_cache[0] = createElementVNode("img", {
5428
5630
  class: "jb-mobile-empty__img",
5429
- src: _imports_0$3,
5631
+ src: _imports_0$4,
5430
5632
  alt: ""
5431
5633
  }, null, -1)),
5432
5634
  createElementVNode("div", _hoisted_2$2, toDisplayString(__props.tip), 1),
@@ -5435,10 +5637,10 @@ const _sfc_main$3 = /* @__PURE__ */ defineComponent({
5435
5637
  };
5436
5638
  }
5437
5639
  });
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({
5640
+ const JbMobileEmpty = /* @__PURE__ */ _export_sfc(_sfc_main$4, [["__scopeId", "data-v-e1f68e36"]]);
5641
+ 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";
5642
+ const _hoisted_1$3 = { class: "jb-mobile-search-input" };
5643
+ const _sfc_main$3 = /* @__PURE__ */ defineComponent({
5442
5644
  __name: "JbMobileSearchInput",
5443
5645
  props: {
5444
5646
  modelValue: {
@@ -5460,10 +5662,10 @@ const _sfc_main$2 = /* @__PURE__ */ defineComponent({
5460
5662
  }
5461
5663
  });
5462
5664
  return (_ctx, _cache) => {
5463
- return openBlock(), createElementBlock("div", _hoisted_1$2, [
5665
+ return openBlock(), createElementBlock("div", _hoisted_1$3, [
5464
5666
  _cache[2] || (_cache[2] = createElementVNode("img", {
5465
5667
  class: "jb-mobile-search-input__search-icon",
5466
- src: _imports_0$2,
5668
+ src: _imports_0$3,
5467
5669
  alt: ""
5468
5670
  }, null, -1)),
5469
5671
  withDirectives(createElementVNode("input", mergeProps({
@@ -5488,8 +5690,35 @@ const _sfc_main$2 = /* @__PURE__ */ defineComponent({
5488
5690
  };
5489
5691
  }
5490
5692
  });
5491
- const JbMobileSearchInput = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["__scopeId", "data-v-ef3bf05c"]]);
5492
- const _imports_0$1 = "";
5693
+ const JbMobileSearchInput = /* @__PURE__ */ _export_sfc(_sfc_main$3, [["__scopeId", "data-v-ef3bf05c"]]);
5694
+ const _imports_0$2 = "";
5695
+ const _imports_0$1 = "";
5696
+ const _hoisted_1$2 = { class: "mobile-select-face" };
5697
+ const _sfc_main$2 = /* @__PURE__ */ defineComponent({
5698
+ __name: "JbMobileSelectFace",
5699
+ props: {
5700
+ slotClick: { type: Function }
5701
+ },
5702
+ setup(__props) {
5703
+ const props = __props;
5704
+ const handleClickSlot = () => {
5705
+ props.slotClick && props.slotClick();
5706
+ };
5707
+ return (_ctx, _cache) => {
5708
+ return openBlock(), createElementBlock("div", _hoisted_1$2, [
5709
+ renderSlot(_ctx.$slots, "default", {
5710
+ onClick: withModifiers(handleClickSlot, ["stop"])
5711
+ }, void 0, true),
5712
+ _cache[0] || (_cache[0] = createElementVNode("img", {
5713
+ src: _imports_0$1,
5714
+ alt: "",
5715
+ class: "pull-down"
5716
+ }, null, -1))
5717
+ ]);
5718
+ };
5719
+ }
5720
+ });
5721
+ const JbMobileSelectFace = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["__scopeId", "data-v-11ebc006"]]);
5493
5722
  const _hoisted_1$1 = { class: "jb-mobile-select__value" };
5494
5723
  const _hoisted_2$1 = {
5495
5724
  key: 0,
@@ -5503,6 +5732,11 @@ const _hoisted_4$1 = {
5503
5732
  const _sfc_main$1 = /* @__PURE__ */ defineComponent({
5504
5733
  __name: "JbMobileSelect",
5505
5734
  props: {
5735
+ // 当tabIndex == 0 时,选中第一个选项,则显示普通的select样式,如果为1,则显示/ComplaintAnalysis/dialog的样式
5736
+ tabIndex: {
5737
+ type: Number,
5738
+ default: 0
5739
+ },
5506
5740
  width: {
5507
5741
  type: Number,
5508
5742
  default: 92
@@ -5517,7 +5751,7 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
5517
5751
  },
5518
5752
  popupTitle: {
5519
5753
  type: String,
5520
- default: "请选择"
5754
+ default: "请选择事件类型"
5521
5755
  },
5522
5756
  options: {
5523
5757
  type: Array,
@@ -5529,10 +5763,11 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
5529
5763
  }
5530
5764
  },
5531
5765
  emits: ["update:modelValue", "change"],
5532
- setup(__props, { emit: __emit }) {
5766
+ setup(__props, { expose: __expose, emit: __emit }) {
5533
5767
  const attrs = useAttrs();
5534
5768
  const emits = __emit;
5535
5769
  const props = __props;
5770
+ const tabIndex = computed(() => props.tabIndex);
5536
5771
  const isShowOptionsPopup = ref(false);
5537
5772
  const selectedOptionItem = ref({});
5538
5773
  const computedWidth = computed(() => `${props.width}px`);
@@ -5556,30 +5791,43 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
5556
5791
  }
5557
5792
  });
5558
5793
  const handleSelectOptionItem = (item) => {
5794
+ console.log("item", item);
5559
5795
  selectedOptionItem.value = item;
5560
5796
  isShowOptionsPopup.value = false;
5561
5797
  modelValue.value = item[fieldNames.value.value];
5562
5798
  emits("change", item[fieldNames.value.label]);
5563
5799
  };
5800
+ __expose({
5801
+ handleSelectOptionItem
5802
+ });
5564
5803
  return (_ctx, _cache) => {
5565
5804
  return openBlock(), createElementBlock(Fragment, null, [
5566
- createElementVNode("div", {
5805
+ tabIndex.value === 0 ? (openBlock(), createElementBlock("div", {
5806
+ key: 0,
5567
5807
  class: "jb-mobile-select",
5568
5808
  style: normalizeStyle$1({ width: computedWidth.value }),
5569
5809
  onClick: _cache[0] || (_cache[0] = ($event) => isShowOptionsPopup.value = true)
5570
5810
  }, [
5571
5811
  createElementVNode("div", _hoisted_1$1, toDisplayString(selectedOptionItem.value[fieldNames.value.label] || __props.placeholder), 1),
5572
- _cache[2] || (_cache[2] = createElementVNode("img", {
5812
+ _cache[3] || (_cache[3] = createElementVNode("img", {
5573
5813
  class: "jb-mobile-select__select-down-icon",
5574
- src: _imports_0$1,
5814
+ src: _imports_0$2,
5575
5815
  alt: ""
5576
5816
  }, null, -1))
5577
- ], 4),
5817
+ ], 4)) : tabIndex.value === 1 ? (openBlock(), createBlock(JbMobileSelectFace, {
5818
+ key: 1,
5819
+ onClick: _cache[1] || (_cache[1] = ($event) => isShowOptionsPopup.value = true)
5820
+ }, {
5821
+ default: withCtx(() => [
5822
+ createTextVNode(toDisplayString(selectedOptionItem.value[fieldNames.value.label] || __props.placeholder), 1)
5823
+ ]),
5824
+ _: 1
5825
+ })) : createCommentVNode("", true),
5578
5826
  createVNode(JbMobilePopup, mergeProps({
5579
5827
  visible: isShowOptionsPopup.value,
5580
- "onUpdate:visible": _cache[1] || (_cache[1] = ($event) => isShowOptionsPopup.value = $event)
5828
+ "onUpdate:visible": _cache[2] || (_cache[2] = ($event) => isShowOptionsPopup.value = $event)
5581
5829
  }, unref(attrs), {
5582
- title: "请选择事件类型",
5830
+ title: __props.popupTitle,
5583
5831
  "grey-bg": true,
5584
5832
  "foot-button": false,
5585
5833
  height: 434
@@ -5598,12 +5846,12 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
5598
5846
  ]))
5599
5847
  ]),
5600
5848
  _: 1
5601
- }, 16, ["visible"])
5849
+ }, 16, ["visible", "title"])
5602
5850
  ], 64);
5603
5851
  };
5604
5852
  }
5605
5853
  });
5606
- const JbMobileSelect = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["__scopeId", "data-v-29ad33f7"]]);
5854
+ const JbMobileSelect = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["__scopeId", "data-v-d4d431ae"]]);
5607
5855
  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
5856
  const _hoisted_1 = { class: "jb-mobile-tree-select-popup__search" };
5609
5857
  const _hoisted_2 = { class: "jb-mobile-tree-select-popup__list" };
@@ -5863,6 +6111,330 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
5863
6111
  }
5864
6112
  });
5865
6113
  const JbMobileTreeSelectPopup = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-9e0ae446"]]);
6114
+ var freeGlobal = typeof global == "object" && global && global.Object === Object && global;
6115
+ var freeSelf = typeof self == "object" && self && self.Object === Object && self;
6116
+ var root = freeGlobal || freeSelf || Function("return this")();
6117
+ var Symbol$1 = root.Symbol;
6118
+ var objectProto$1 = Object.prototype;
6119
+ var hasOwnProperty = objectProto$1.hasOwnProperty;
6120
+ var nativeObjectToString$1 = objectProto$1.toString;
6121
+ var symToStringTag$1 = Symbol$1 ? Symbol$1.toStringTag : void 0;
6122
+ function getRawTag(value) {
6123
+ var isOwn = hasOwnProperty.call(value, symToStringTag$1), tag = value[symToStringTag$1];
6124
+ try {
6125
+ value[symToStringTag$1] = void 0;
6126
+ var unmasked = true;
6127
+ } catch (e) {
6128
+ }
6129
+ var result = nativeObjectToString$1.call(value);
6130
+ if (unmasked) {
6131
+ if (isOwn) {
6132
+ value[symToStringTag$1] = tag;
6133
+ } else {
6134
+ delete value[symToStringTag$1];
6135
+ }
6136
+ }
6137
+ return result;
6138
+ }
6139
+ var objectProto = Object.prototype;
6140
+ var nativeObjectToString = objectProto.toString;
6141
+ function objectToString(value) {
6142
+ return nativeObjectToString.call(value);
6143
+ }
6144
+ var nullTag = "[object Null]", undefinedTag = "[object Undefined]";
6145
+ var symToStringTag = Symbol$1 ? Symbol$1.toStringTag : void 0;
6146
+ function baseGetTag(value) {
6147
+ if (value == null) {
6148
+ return value === void 0 ? undefinedTag : nullTag;
6149
+ }
6150
+ return symToStringTag && symToStringTag in Object(value) ? getRawTag(value) : objectToString(value);
6151
+ }
6152
+ function isObjectLike(value) {
6153
+ return value != null && typeof value == "object";
6154
+ }
6155
+ var symbolTag = "[object Symbol]";
6156
+ function isSymbol(value) {
6157
+ return typeof value == "symbol" || isObjectLike(value) && baseGetTag(value) == symbolTag;
6158
+ }
6159
+ var reWhitespace = /\s/;
6160
+ function trimmedEndIndex(string) {
6161
+ var index = string.length;
6162
+ while (index-- && reWhitespace.test(string.charAt(index))) {
6163
+ }
6164
+ return index;
6165
+ }
6166
+ var reTrimStart = /^\s+/;
6167
+ function baseTrim(string) {
6168
+ return string ? string.slice(0, trimmedEndIndex(string) + 1).replace(reTrimStart, "") : string;
6169
+ }
6170
+ function isObject(value) {
6171
+ var type = typeof value;
6172
+ return value != null && (type == "object" || type == "function");
6173
+ }
6174
+ var NAN = 0 / 0;
6175
+ var reIsBadHex = /^[-+]0x[0-9a-f]+$/i;
6176
+ var reIsBinary = /^0b[01]+$/i;
6177
+ var reIsOctal = /^0o[0-7]+$/i;
6178
+ var freeParseInt = parseInt;
6179
+ function toNumber(value) {
6180
+ if (typeof value == "number") {
6181
+ return value;
6182
+ }
6183
+ if (isSymbol(value)) {
6184
+ return NAN;
6185
+ }
6186
+ if (isObject(value)) {
6187
+ var other = typeof value.valueOf == "function" ? value.valueOf() : value;
6188
+ value = isObject(other) ? other + "" : other;
6189
+ }
6190
+ if (typeof value != "string") {
6191
+ return value === 0 ? value : +value;
6192
+ }
6193
+ value = baseTrim(value);
6194
+ var isBinary = reIsBinary.test(value);
6195
+ return isBinary || reIsOctal.test(value) ? freeParseInt(value.slice(2), isBinary ? 2 : 8) : reIsBadHex.test(value) ? NAN : +value;
6196
+ }
6197
+ var now = function() {
6198
+ return root.Date.now();
6199
+ };
6200
+ var FUNC_ERROR_TEXT$1 = "Expected a function";
6201
+ var nativeMax = Math.max, nativeMin = Math.min;
6202
+ function debounce(func, wait, options) {
6203
+ var lastArgs, lastThis, maxWait, result, timerId, lastCallTime, lastInvokeTime = 0, leading = false, maxing = false, trailing = true;
6204
+ if (typeof func != "function") {
6205
+ throw new TypeError(FUNC_ERROR_TEXT$1);
6206
+ }
6207
+ wait = toNumber(wait) || 0;
6208
+ if (isObject(options)) {
6209
+ leading = !!options.leading;
6210
+ maxing = "maxWait" in options;
6211
+ maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;
6212
+ trailing = "trailing" in options ? !!options.trailing : trailing;
6213
+ }
6214
+ function invokeFunc(time) {
6215
+ var args = lastArgs, thisArg = lastThis;
6216
+ lastArgs = lastThis = void 0;
6217
+ lastInvokeTime = time;
6218
+ result = func.apply(thisArg, args);
6219
+ return result;
6220
+ }
6221
+ function leadingEdge(time) {
6222
+ lastInvokeTime = time;
6223
+ timerId = setTimeout(timerExpired, wait);
6224
+ return leading ? invokeFunc(time) : result;
6225
+ }
6226
+ function remainingWait(time) {
6227
+ var timeSinceLastCall = time - lastCallTime, timeSinceLastInvoke = time - lastInvokeTime, timeWaiting = wait - timeSinceLastCall;
6228
+ return maxing ? nativeMin(timeWaiting, maxWait - timeSinceLastInvoke) : timeWaiting;
6229
+ }
6230
+ function shouldInvoke(time) {
6231
+ var timeSinceLastCall = time - lastCallTime, timeSinceLastInvoke = time - lastInvokeTime;
6232
+ return lastCallTime === void 0 || timeSinceLastCall >= wait || timeSinceLastCall < 0 || maxing && timeSinceLastInvoke >= maxWait;
6233
+ }
6234
+ function timerExpired() {
6235
+ var time = now();
6236
+ if (shouldInvoke(time)) {
6237
+ return trailingEdge(time);
6238
+ }
6239
+ timerId = setTimeout(timerExpired, remainingWait(time));
6240
+ }
6241
+ function trailingEdge(time) {
6242
+ timerId = void 0;
6243
+ if (trailing && lastArgs) {
6244
+ return invokeFunc(time);
6245
+ }
6246
+ lastArgs = lastThis = void 0;
6247
+ return result;
6248
+ }
6249
+ function cancel() {
6250
+ if (timerId !== void 0) {
6251
+ clearTimeout(timerId);
6252
+ }
6253
+ lastInvokeTime = 0;
6254
+ lastArgs = lastCallTime = lastThis = timerId = void 0;
6255
+ }
6256
+ function flush() {
6257
+ return timerId === void 0 ? result : trailingEdge(now());
6258
+ }
6259
+ function debounced() {
6260
+ var time = now(), isInvoking = shouldInvoke(time);
6261
+ lastArgs = arguments;
6262
+ lastThis = this;
6263
+ lastCallTime = time;
6264
+ if (isInvoking) {
6265
+ if (timerId === void 0) {
6266
+ return leadingEdge(lastCallTime);
6267
+ }
6268
+ if (maxing) {
6269
+ clearTimeout(timerId);
6270
+ timerId = setTimeout(timerExpired, wait);
6271
+ return invokeFunc(lastCallTime);
6272
+ }
6273
+ }
6274
+ if (timerId === void 0) {
6275
+ timerId = setTimeout(timerExpired, wait);
6276
+ }
6277
+ return result;
6278
+ }
6279
+ debounced.cancel = cancel;
6280
+ debounced.flush = flush;
6281
+ return debounced;
6282
+ }
6283
+ var FUNC_ERROR_TEXT = "Expected a function";
6284
+ function throttle(func, wait, options) {
6285
+ var leading = true, trailing = true;
6286
+ if (typeof func != "function") {
6287
+ throw new TypeError(FUNC_ERROR_TEXT);
6288
+ }
6289
+ if (isObject(options)) {
6290
+ leading = "leading" in options ? !!options.leading : leading;
6291
+ trailing = "trailing" in options ? !!options.trailing : trailing;
6292
+ }
6293
+ return debounce(func, wait, {
6294
+ "leading": leading,
6295
+ "maxWait": wait,
6296
+ "trailing": trailing
6297
+ });
6298
+ }
6299
+ function useInfiniteScroll(options = {}) {
6300
+ const {
6301
+ bottomThreshold = 100,
6302
+ topThreshold = 100,
6303
+ throttleDelay = 300,
6304
+ disabled = ref(false),
6305
+ onLoadMore,
6306
+ onLoadPrevious,
6307
+ debug = false
6308
+ } = options;
6309
+ const isLoadingMore = ref(false);
6310
+ const isLoadingPrevious = ref(false);
6311
+ const hasMoreData = ref(true);
6312
+ const hasPreviousData = ref(true);
6313
+ let lastScrollTop = 0;
6314
+ const executeLoadMore = async () => {
6315
+ if (isLoadingMore.value || !hasMoreData.value || !onLoadMore) {
6316
+ return;
6317
+ }
6318
+ isLoadingMore.value = true;
6319
+ try {
6320
+ await onLoadMore();
6321
+ if (debug) console.log("✅ 向下加载更多完成");
6322
+ } catch (error) {
6323
+ console.error("❌ 向下加载更多失败:", error);
6324
+ } finally {
6325
+ isLoadingMore.value = false;
6326
+ }
6327
+ };
6328
+ const executeLoadPrevious = async () => {
6329
+ if (isLoadingPrevious.value || !hasPreviousData.value || !onLoadPrevious) {
6330
+ return;
6331
+ }
6332
+ isLoadingPrevious.value = true;
6333
+ try {
6334
+ await onLoadPrevious();
6335
+ if (debug) console.log("✅ 向上加载完成");
6336
+ } catch (error) {
6337
+ console.error("❌ 向上加载失败:", error);
6338
+ } finally {
6339
+ isLoadingPrevious.value = false;
6340
+ }
6341
+ };
6342
+ const handleScroll = throttle(async (event) => {
6343
+ if (disabled.value) return;
6344
+ const target = event.target;
6345
+ if (!target) return;
6346
+ const { scrollTop, scrollHeight, clientHeight } = target;
6347
+ const distanceToBottom = scrollHeight - scrollTop - clientHeight;
6348
+ const distanceToTop = scrollTop;
6349
+ const isNearBottom = distanceToBottom < bottomThreshold;
6350
+ const isNearTop = distanceToTop < topThreshold;
6351
+ let scrollDirection = "none";
6352
+ if (scrollTop > lastScrollTop) {
6353
+ scrollDirection = "down";
6354
+ } else if (scrollTop < lastScrollTop) {
6355
+ scrollDirection = "up";
6356
+ }
6357
+ lastScrollTop = scrollTop;
6358
+ const scrollInfo = {
6359
+ scrollTop,
6360
+ scrollHeight,
6361
+ clientHeight,
6362
+ distanceToBottom,
6363
+ distanceToTop,
6364
+ isNearBottom,
6365
+ isNearTop,
6366
+ scrollDirection
6367
+ };
6368
+ if (debug) {
6369
+ console.log("📊 滚动信息:", scrollInfo);
6370
+ }
6371
+ if (isNearBottom && scrollDirection === "down") {
6372
+ if (debug) console.log("🔽 触发向下加载");
6373
+ await executeLoadMore();
6374
+ }
6375
+ if (isNearTop && scrollDirection === "up") {
6376
+ if (debug) console.log("🔼 触发向上加载");
6377
+ await executeLoadPrevious();
6378
+ }
6379
+ }, throttleDelay);
6380
+ const reset = () => {
6381
+ isLoadingMore.value = false;
6382
+ isLoadingPrevious.value = false;
6383
+ hasMoreData.value = true;
6384
+ hasPreviousData.value = true;
6385
+ lastScrollTop = 0;
6386
+ };
6387
+ const triggerLoadMore = async () => {
6388
+ await executeLoadMore();
6389
+ };
6390
+ const triggerLoadPrevious = async () => {
6391
+ await executeLoadPrevious();
6392
+ };
6393
+ const setDataState = (options2) => {
6394
+ if (options2.hasMore !== void 0) {
6395
+ hasMoreData.value = options2.hasMore;
6396
+ }
6397
+ if (options2.hasPrevious !== void 0) {
6398
+ hasPreviousData.value = options2.hasPrevious;
6399
+ }
6400
+ };
6401
+ const state = {
6402
+ isLoadingMore,
6403
+ isLoadingPrevious,
6404
+ hasMoreData,
6405
+ hasPreviousData
6406
+ };
6407
+ return {
6408
+ // 状态
6409
+ ...state,
6410
+ // 方法
6411
+ handleScroll,
6412
+ reset,
6413
+ triggerLoadMore,
6414
+ triggerLoadPrevious,
6415
+ setDataState
6416
+ };
6417
+ }
6418
+ const useGlobalLoading = () => {
6419
+ return customRef((track, trigger) => {
6420
+ let loadingCount = 0;
6421
+ return {
6422
+ get() {
6423
+ track();
6424
+ return loadingCount > 0;
6425
+ },
6426
+ set(value) {
6427
+ if (value) {
6428
+ loadingCount += 1;
6429
+ } else {
6430
+ loadingCount -= 1;
6431
+ }
6432
+ loadingCount = Math.max(0, loadingCount);
6433
+ trigger();
6434
+ }
6435
+ };
6436
+ });
6437
+ };
5866
6438
  export {
5867
6439
  JbMobileButton,
5868
6440
  JbMobileDatePicker,
@@ -5871,5 +6443,7 @@ export {
5871
6443
  JbMobileSearchInput,
5872
6444
  JbMobileSelect,
5873
6445
  JbMobileTimePicker,
5874
- JbMobileTreeSelectPopup
6446
+ JbMobileTreeSelectPopup,
6447
+ useGlobalLoading,
6448
+ useInfiniteScroll
5875
6449
  };