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/README.md +61 -61
- package/dist/App.vue.d.ts +1 -1
- package/dist/components/JbMobileDatePicker.vue.d.ts +39 -3
- package/dist/components/JbMobileSelect.vue.d.ts +12 -1
- package/dist/components/JbMobileSelectFace.vue.d.ts +22 -0
- package/dist/components/JbMobileTimePicker.vue.d.ts +31 -0
- package/dist/hooks/useGlobalLoading.d.ts +1 -0
- package/dist/hooks/useInfiniteScroll.d.ts +37 -0
- package/dist/index.cjs.js +2 -2
- package/dist/index.css +1 -1
- package/dist/index.d.ts +2 -0
- package/dist/index.es.js +721 -150
- package/package.json +97 -95
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,
|
|
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$
|
|
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$
|
|
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$
|
|
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,
|
|
285
|
+
function getScrollParent(el, root2 = defaultRoot) {
|
|
286
286
|
let node = el;
|
|
287
|
-
while (node && 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
|
|
294
|
+
return root2;
|
|
295
295
|
}
|
|
296
|
-
function useScrollParent(el,
|
|
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,
|
|
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$
|
|
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
|
|
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":
|
|
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:
|
|
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
|
|
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
|
|
1720
|
-
if (
|
|
1721
|
-
touchStartTime =
|
|
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:
|
|
1782
|
+
target: root2
|
|
1783
1783
|
});
|
|
1784
1784
|
return () => createVNode("div", {
|
|
1785
|
-
"ref":
|
|
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
|
|
2066
|
-
const scrollParent = useScrollParent(
|
|
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 (!
|
|
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(
|
|
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(
|
|
2152
|
+
useVisibilityChange(root2, onScroll);
|
|
2153
2153
|
watch([windowWidth, windowHeight], () => {
|
|
2154
|
-
if (!
|
|
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(
|
|
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":
|
|
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
|
|
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 (!
|
|
2348
|
+
if (!root2.value) {
|
|
2349
2349
|
return;
|
|
2350
2350
|
}
|
|
2351
2351
|
const cb = () => {
|
|
2352
2352
|
var _a, _b;
|
|
2353
|
-
if (!isHidden(
|
|
2353
|
+
if (!isHidden(root2)) {
|
|
2354
2354
|
const rect = {
|
|
2355
|
-
width:
|
|
2356
|
-
height:
|
|
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(
|
|
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":
|
|
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
|
|
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(
|
|
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(
|
|
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(
|
|
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(
|
|
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":
|
|
2918
|
+
"ref": root2,
|
|
2919
2919
|
"class": bem$6([props.type])
|
|
2920
2920
|
}, [props.showHeader ? props.sticky ? createVNode(Sticky, {
|
|
2921
|
-
"container":
|
|
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
|
|
3668
|
-
document.body.appendChild(
|
|
3667
|
+
const root2 = document.createElement("div");
|
|
3668
|
+
document.body.appendChild(root2);
|
|
3669
3669
|
return {
|
|
3670
|
-
instance: app.mount(
|
|
3670
|
+
instance: app.mount(root2),
|
|
3671
3671
|
unmount() {
|
|
3672
3672
|
app.unmount();
|
|
3673
|
-
document.body.removeChild(
|
|
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$
|
|
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
|
|
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],
|
|
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] ||
|
|
4361
|
-
const end = limitDateRange(defaultDate[1] || (allowSameDay ?
|
|
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(
|
|
4368
|
+
return [limitDateRange(now2)];
|
|
4369
4369
|
}
|
|
4370
4370
|
if (!defaultDate || Array.isArray(defaultDate)) {
|
|
4371
|
-
defaultDate =
|
|
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$
|
|
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$
|
|
4729
|
-
const _imports_0$
|
|
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$
|
|
4733
|
-
const _hoisted_1$
|
|
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$
|
|
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$
|
|
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$
|
|
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
|
-
],
|
|
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$
|
|
4851
|
-
const _hoisted_1$
|
|
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
|
|
4857
|
-
const _sfc_main$
|
|
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: [
|
|
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(
|
|
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(
|
|
4916
|
-
dayjs(
|
|
4917
|
-
] : dayjs(
|
|
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 = [
|
|
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 = [
|
|
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
|
-
|
|
5007
|
-
|
|
5008
|
-
|
|
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(
|
|
5027
|
-
|
|
5028
|
-
|
|
5029
|
-
|
|
5030
|
-
|
|
5031
|
-
|
|
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(
|
|
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(
|
|
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(
|
|
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
|
-
|
|
5118
|
-
|
|
5119
|
-
|
|
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
|
-
|
|
5124
|
-
|
|
5125
|
-
value
|
|
5126
|
-
|
|
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 = [
|
|
5262
|
+
confirmSelectedCalendarValue = [
|
|
5263
|
+
dayjs(startTime).toDate(),
|
|
5264
|
+
dayjs(endTime).toDate()
|
|
5265
|
+
];
|
|
5141
5266
|
confirmSelectedTimeValue = selectedTimeValue.value;
|
|
5142
5267
|
confirmSelectDate();
|
|
5143
|
-
|
|
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(
|
|
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(
|
|
5152
|
-
|
|
5153
|
-
|
|
5154
|
-
|
|
5155
|
-
|
|
5156
|
-
|
|
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[
|
|
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",
|
|
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",
|
|
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",
|
|
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":
|
|
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,
|
|
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$
|
|
5234
|
-
const _hoisted_1$
|
|
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$
|
|
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$
|
|
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$
|
|
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$
|
|
5413
|
-
const _imports_0$3 = "";
|
|
5414
|
-
const _hoisted_1$
|
|
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$
|
|
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$
|
|
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$
|
|
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$
|
|
5439
|
-
const _imports_0$
|
|
5440
|
-
const _hoisted_1$
|
|
5441
|
-
const _sfc_main$
|
|
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$
|
|
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$
|
|
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$
|
|
5492
|
-
const _imports_0$
|
|
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
|
-
|
|
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[
|
|
5809
|
+
_cache[3] || (_cache[3] = createElementVNode("img", {
|
|
5573
5810
|
class: "jb-mobile-select__select-down-icon",
|
|
5574
|
-
src: _imports_0$
|
|
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[
|
|
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-
|
|
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-
|
|
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
|
};
|