import { normalizeStyles as normalizeStyles$1, addLeadingSlash, invokeArrayFns, parseQuery, SYSTEM_DIALOG_PAGE_PATH_STARTER, EventChannel, once, parseUrl, Emitter, ON_UNHANDLE_REJECTION, ON_PAGE_NOT_FOUND, ON_ERROR, ON_SHOW, ON_HIDE, removeLeadingSlash, getLen, ON_UNLOAD, ON_READY, ON_PAGE_SCROLL, ON_PULL_DOWN_REFRESH, ON_REACH_BOTTOM, ON_RESIZE, ON_LAUNCH, ON_BACK_PRESS, isSystemDialogPage, isSystemActionSheetDialogPage } from "@dcloudio/uni-shared"; import { extend, isString, isPlainObject, isFunction as isFunction$1, isArray, isPromise, hasOwn, remove, invokeArrayFns as invokeArrayFns$1, capitalize, toTypeString, toRawType, parseStringStyle } from "@vue/shared"; import { createVNode, render, getCurrentInstance, onMounted, onBeforeUnmount, injectHook, resolveComponent, openBlock, createElementBlock, normalizeClass, createElementVNode, normalizeStyle, toDisplayString, withDirectives, vModelText, createCommentVNode, Fragment, renderList, defineComponent, warn, isInSSRComponentSetup, ref, watchEffect, watch, computed, camelize, onUnmounted, reactive, provide, inject, nextTick } from "vue"; function get$pageByPage(page) { return page.vm.$basePage; } function getCurrentPage() { var pages2 = getCurrentPages(); var len = pages2.length; if (len) { return pages2[len - 1]; } } function getCurrentPageMeta() { var _getCurrentPage; var $page = (_getCurrentPage = getCurrentPage()) === null || _getCurrentPage === void 0 || (_getCurrentPage = _getCurrentPage.vm) === null || _getCurrentPage === void 0 ? void 0 : _getCurrentPage.$basePage; if ($page) { return $page.meta; } } function getCurrentPageVm() { var _getCurrentPage3; var page = (_getCurrentPage3 = getCurrentPage()) === null || _getCurrentPage3 === void 0 ? void 0 : _getCurrentPage3.vm; if (page) { return page.$vm; } } var PAGE_META_KEYS = ["navigationBar", "pullToRefresh"]; function initGlobalStyle() { return JSON.parse(JSON.stringify(__uniConfig.globalStyle || {})); } function initRouteMeta(pageMeta, id2) { var globalStyle = initGlobalStyle(); var res = extend({ id: id2 }, globalStyle, pageMeta); PAGE_META_KEYS.forEach((name) => { res[name] = extend({}, globalStyle[name], pageMeta[name]); }); var { navigationBar } = res; navigationBar.titleText && navigationBar.titleImage && (navigationBar.titleText = ""); return res; } function initPageInternalInstance(openType, url, pageQuery, meta, eventChannel, themeMode) { var { id: id2, route } = meta; var titleColor = normalizeStyles$1(meta.navigationBar, __uniConfig.themeConfig, themeMode).titleColor; return { id: id2, path: addLeadingSlash(route), route, fullPath: url, options: pageQuery, meta, openType, eventChannel, statusBarStyle: titleColor === "#ffffff" ? "light" : "dark" }; } function invokeHook(vm, name, args) { if (isString(vm)) { args = name; name = vm; vm = getCurrentPageVm(); } else if (typeof vm === "number") { var page = getCurrentPages().find((page2) => get$pageByPage(page2).id === vm); if (page) { vm = page.$vm; } else { vm = getCurrentPageVm(); } } if (!vm) { return; } { if (vm.__call_hook) { return vm.__call_hook(name, args); } } var hooks = vm.$[name]; return hooks && invokeArrayFns(hooks, args); } function normalizeRoute(toRoute) { if (toRoute.indexOf("/") === 0 || toRoute.indexOf("uni:") === 0) { return toRoute; } var fromRoute = ""; var pages2 = getCurrentPages(); if (pages2.length) { fromRoute = get$pageByPage(pages2[pages2.length - 1]).route; } return getRealRoute(fromRoute, toRoute); } function getRealRoute(fromRoute, toRoute) { if (toRoute.indexOf("/") === 0) { return toRoute; } if (toRoute.indexOf("./") === 0) { return getRealRoute(fromRoute, toRoute.slice(2)); } var toRouteArray = toRoute.split("/"); var toRouteLength = toRouteArray.length; var i = 0; for (; i < toRouteLength && toRouteArray[i] === ".."; i++) { } toRouteArray.splice(0, i); toRoute = toRouteArray.join("/"); var fromRouteArray = fromRoute.length > 0 ? fromRoute.split("/") : []; fromRouteArray.splice(fromRouteArray.length - i - 1, i + 1); return addLeadingSlash(fromRouteArray.concat(toRouteArray).join("/")); } function getRouteOptions(path) { var alias = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : false; if (alias) { return __uniRoutes.find((route) => route.path === path || route.alias === path); } return __uniRoutes.find((route) => route.path === path); } function getRouteMeta(path) { var routeOptions = getRouteOptions(path); if (routeOptions) { return routeOptions.meta; } } function initPageVm(pageVm, page) { pageVm.route = page.route; pageVm.$vm = pageVm; pageVm.$page = page; pageVm.$mpType = "page"; pageVm.$fontFamilySet = /* @__PURE__ */ new Set(); if (page.meta.isTabBar) { pageVm.$.__isTabBar = true; pageVm.$.__isActive = true; } } function createLaunchOptions() { return { path: "", query: {}, scene: 1001, referrerInfo: { appId: "", extraData: {} } }; } function defineGlobalData(app, defaultGlobalData) { var options = app.$options || {}; options.globalData = extend(options.globalData || {}, defaultGlobalData); Object.defineProperty(app, "globalData", { get() { return options.globalData; }, set(newGlobalData) { options.globalData = newGlobalData; } }); } function tryCatch(fn) { return function() { try { return fn.apply(fn, arguments); } catch (e) { console.error(e); } }; } var invokeCallbackId = 1; var invokeCallbacks = {}; function addInvokeCallback(id2, name, callback) { var keepAlive = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : false; invokeCallbacks[id2] = { name, keepAlive, callback }; return id2; } function invokeCallback(id2, res, extras) { if (typeof id2 === "number") { var opts = invokeCallbacks[id2]; if (opts) { if (!opts.keepAlive) { delete invokeCallbacks[id2]; } return opts.callback(res, extras); } } return res; } var API_SUCCESS = "success"; var API_FAIL = "fail"; var API_COMPLETE = "complete"; function getApiCallbacks(args) { var apiCallbacks = {}; for (var name in args) { var fn = args[name]; if (isFunction$1(fn)) { apiCallbacks[name] = tryCatch(fn); delete args[name]; } } return apiCallbacks; } function normalizeErrMsg(errMsg, name) { if (!errMsg || errMsg.indexOf(":fail") === -1) { return name + ":ok"; } return name + errMsg.substring(errMsg.indexOf(":fail")); } function createAsyncApiCallback(name) { var args = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}; var { beforeAll, beforeSuccess } = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {}; if (!isPlainObject(args)) { args = {}; } var { success, fail, complete } = getApiCallbacks(args); var hasSuccess = isFunction$1(success); var hasFail = isFunction$1(fail); var hasComplete = isFunction$1(complete); var callbackId2 = invokeCallbackId++; addInvokeCallback(callbackId2, name, (res) => { res = res || {}; res.errMsg = normalizeErrMsg(res.errMsg, name); isFunction$1(beforeAll) && beforeAll(res); if (res.errMsg === name + ":ok") { isFunction$1(beforeSuccess) && beforeSuccess(res, args); hasSuccess && success(res); } else { hasFail && fail(res); } hasComplete && complete(res); }); return callbackId2; } var HOOK_SUCCESS = "success"; var HOOK_FAIL = "fail"; var HOOK_COMPLETE = "complete"; var globalInterceptors = {}; var scopedInterceptors = {}; function wrapperHook(hook, params) { return function(data) { return hook(data, params) || data; }; } function queue(hooks, data, params) { var promise = false; for (var i = 0; i < hooks.length; i++) { var hook = hooks[i]; if (promise) { promise = Promise.resolve(wrapperHook(hook, params)); } else { var res = hook(data, params); if (isPromise(res)) { promise = Promise.resolve(res); } if (res === false) { return { then() { }, catch() { } }; } } } return promise || { then(callback) { return callback(data); }, catch() { } }; } function wrapperOptions(interceptors) { var options = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}; [HOOK_SUCCESS, HOOK_FAIL, HOOK_COMPLETE].forEach((name) => { var hooks = interceptors[name]; if (!isArray(hooks)) { return; } var oldCallback = options[name]; options[name] = function callbackInterceptor(res) { queue(hooks, res, options).then((res2) => { return isFunction$1(oldCallback) && oldCallback(res2) || res2; }); }; }); return options; } function wrapperReturnValue(method, returnValue) { var returnValueHooks = []; if (isArray(globalInterceptors.returnValue)) { returnValueHooks.push(...globalInterceptors.returnValue); } var interceptor = scopedInterceptors[method]; if (interceptor && isArray(interceptor.returnValue)) { returnValueHooks.push(...interceptor.returnValue); } returnValueHooks.forEach((hook) => { returnValue = hook(returnValue) || returnValue; }); return returnValue; } function getApiInterceptorHooks(method) { var interceptor = /* @__PURE__ */ Object.create(null); Object.keys(globalInterceptors).forEach((hook) => { if (hook !== "returnValue") { interceptor[hook] = globalInterceptors[hook].slice(); } }); var scopedInterceptor = scopedInterceptors[method]; if (scopedInterceptor) { Object.keys(scopedInterceptor).forEach((hook) => { if (hook !== "returnValue") { interceptor[hook] = (interceptor[hook] || []).concat(scopedInterceptor[hook]); } }); } return interceptor; } function invokeApi(method, api, options, params) { var interceptor = getApiInterceptorHooks(method); if (interceptor && Object.keys(interceptor).length) { if (isArray(interceptor.invoke)) { var res = queue(interceptor.invoke, options); return res.then((options2) => { return api(wrapperOptions(getApiInterceptorHooks(method), options2), ...params); }); } else { return api(wrapperOptions(interceptor, options), ...params); } } return api(options, ...params); } function hasCallback(args) { if (isPlainObject(args) && [API_SUCCESS, API_FAIL, API_COMPLETE].find((cb) => isFunction$1(args[cb]))) { return true; } return false; } function handlePromise(promise) { return promise; } function promisify(name, fn) { return function() { var args = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}; for (var _len = arguments.length, rest = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { rest[_key - 1] = arguments[_key]; } if (hasCallback(args)) { return wrapperReturnValue(name, invokeApi(name, fn, args, rest)); } return wrapperReturnValue(name, handlePromise(new Promise((resolve, reject) => { invokeApi(name, fn, extend(args, { success: resolve, fail: reject }), rest); }))); }; } function formatApiArgs(args, options) { var params = args[0]; if (!options || !options.formatArgs || !isPlainObject(options.formatArgs) && isPlainObject(params)) { return; } var formatArgs = options.formatArgs; var keys = Object.keys(formatArgs); for (var i = 0; i < keys.length; i++) { var name = keys[i]; var formatterOrDefaultValue = formatArgs[name]; if (isFunction$1(formatterOrDefaultValue)) { var errMsg = formatterOrDefaultValue(args[0][name], params); if (isString(errMsg)) { return errMsg; } } else { if (!hasOwn(params, name)) { params[name] = formatterOrDefaultValue; } } } } function invokeSuccess(id2, name, res) { var result = { errMsg: name + ":ok" }; { result.errSubject = name; } return invokeCallback(id2, extend(res || {}, result)); } function invokeFail(id2, name, errMsg) { var errRes = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : {}; var errMsgPrefix = name + ":fail"; var apiErrMsg = ""; if (!errMsg) { apiErrMsg = errMsgPrefix; } else if (errMsg.indexOf(errMsgPrefix) === 0) { apiErrMsg = errMsg; } else { apiErrMsg = errMsgPrefix + " " + errMsg; } var res = extend({ errMsg: apiErrMsg }, errRes); { if (typeof UniError !== "undefined") { res = typeof errRes.errCode !== "undefined" ? new UniError(name, errRes.errCode, apiErrMsg) : new UniError(apiErrMsg, errRes); } } return invokeCallback(id2, res); } function beforeInvokeApi(name, args, protocol, options) { if (options && options.beforeInvoke) { var errMsg2 = options.beforeInvoke(args); if (isString(errMsg2)) { return errMsg2; } } var errMsg = formatApiArgs(args, options); if (errMsg) { return errMsg; } } function parseErrMsg(errMsg) { if (!errMsg || isString(errMsg)) { return errMsg; } if (errMsg.stack) { return errMsg.message; } return errMsg; } function wrapperTaskApi(name, fn, protocol, options) { return (args) => { var id2 = createAsyncApiCallback(name, args, options); var errMsg = beforeInvokeApi(name, [args], protocol, options); if (errMsg) { return invokeFail(id2, name, errMsg); } return fn(args, { resolve: (res) => invokeSuccess(id2, name, res), reject: (errMsg2, errRes) => invokeFail(id2, name, parseErrMsg(errMsg2), errRes) }); }; } function wrapperSyncApi(name, fn, protocol, options) { return function() { for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } var errMsg = beforeInvokeApi(name, args, protocol, options); if (errMsg) { throw new Error(errMsg); } return fn.apply(null, args); }; } function wrapperAsyncApi(name, fn, protocol, options) { return wrapperTaskApi(name, fn, protocol, options); } function defineSyncApi(name, fn, protocol, options) { return wrapperSyncApi(name, fn, void 0, options); } function defineAsyncApi(name, fn, protocol, options) { return promisify(name, wrapperAsyncApi(name, fn, void 0, options)); } var vueApp; function getVueApp() { return vueApp; } function initVueApp(appVm) { var internalInstance = appVm.$; Object.defineProperty(internalInstance.ctx, "$children", { get() { return getAllPages().map((page) => page.$vm); } }); var appContext = internalInstance.appContext; vueApp = extend(appContext.app, { mountPage(pageComponent, pageProps, pageContainer) { var vnode = createVNode(pageComponent, pageProps); vnode.appContext = appContext; vnode.__page_container__ = pageContainer; render(vnode, pageContainer); var publicThis = vnode.component.proxy; publicThis.__page_container__ = pageContainer; return publicThis; }, unmountPage: (pageInstance) => { var { __page_container__ } = pageInstance; if (__page_container__) { __page_container__.isUnmounted = true; render(null, __page_container__); } } }); } function getPage$BasePage(page) { return page.$basePage; } var pages = []; function addCurrentPage(page) { var $page = getPage$BasePage(page); if (!$page.meta.isNVue) { return pages.push(page); } var index2 = pages.findIndex((p) => getPage$BasePage(p).id === $page.id); if (index2 > -1) { pages.splice(index2, 1, page); } else { pages.push(page); } } function getAllPages() { return pages; } function getCurrentPages$1() { var curPages = getCurrentBasePages(); { return curPages.map((page) => page.$page); } } function getCurrentBasePages() { var curPages = []; pages.forEach((page) => { if (page.$.__isTabBar) { if (page.$.__isActive) { curPages.push(page); } } else { curPages.push(page); } }); return curPages; } function removePage(curPage) { var index2 = pages.findIndex((page) => page === curPage); if (index2 === -1) { return; } var $basePage = getPage$BasePage(curPage); if (!$basePage.meta.isNVue) { getVueApp().unmountPage(curPage); } var removePages2 = pages.splice(index2, 1); { removePages2[0].$page = null; } } function backbuttonListener() { uni.navigateBack({ from: "backbutton", success() { } // 传入空方法,避免返回Promise,因为onBackPress可能导致fail }); } var enterOptions$1 = /* @__PURE__ */ createLaunchOptions(); var launchOptions$1 = /* @__PURE__ */ createLaunchOptions(); function getLaunchOptions() { return extend({}, launchOptions$1); } function initLaunchOptions(_ref2) { var { path, query, referrerInfo } = _ref2; extend(launchOptions$1, { path, query: query ? parseQuery(query) : {}, referrerInfo: referrerInfo || {}, // TODO uni-app x channel: void 0, launcher: void 0 }); extend(enterOptions$1, launchOptions$1); return enterOptions$1; } var ON_BACK_BUTTON = "onBackButton"; var ON_POP_GESTURE = "onPopGesture"; var OPEN_DIALOG_PAGE = "openDialogPage"; function setupPage(component) { var oldSetup = component.setup; component.inheritAttrs = false; component.setup = (props, ctx) => { var { attrs: { __pageId, __pagePath, /*__pageQuery,*/ __pageInstance } } = ctx; var instance = getCurrentInstance(); var pageVm = instance.proxy; initPageVm(pageVm, __pageInstance); { instance.$dialogPages = []; var uniPage; if (__pageInstance.openType === OPEN_DIALOG_PAGE) { var currentPage = getCurrentPage(); if (__pagePath.startsWith(SYSTEM_DIALOG_PAGE_PATH_STARTER)) { var systemDialogPages = currentPage.vm.$systemDialogPages; uniPage = systemDialogPages[systemDialogPages.length - 1]; } else { uniPage = new UniDialogPageImpl(); } } else { uniPage = new UniNormalPageImpl(); } pageVm.$basePage = pageVm.$page; pageVm.$page = uniPage; uniPage.route = pageVm.$basePage.route; uniPage.optionsByJS = pageVm.$basePage.options; Object.defineProperty(uniPage, "options", { get: function() { return new UTSJSONObject(pageVm.$basePage.options); } }); uniPage.vm = pageVm; uniPage.$vm = pageVm; uniPage.getElementById = (id2) => { var _pageVm$$el; var currentPage2 = getCurrentPage(); if (currentPage2 !== uniPage) { return null; } var bodyNode = (_pageVm$$el = pageVm.$el) === null || _pageVm$$el === void 0 ? void 0 : _pageVm$$el.parentNode; if (bodyNode == null) { console.warn("bodyNode is null"); return null; } return bodyNode.querySelector("#".concat(id2)); }; uniPage.getParentPage = () => { var parentPage = uniPage.getParentPageByJS(); return parentPage || null; }; uniPage.getPageStyle = () => { var pageStyle = uniPage.getPageStyleByJS(); return new UTSJSONObject(pageStyle); }; uniPage.$getPageStyle = () => { return uniPage.getPageStyle(); }; uniPage.setPageStyle = (styles2) => { uniPage.setPageStyleByJS(styles2); }; uniPage.$setPageStyle = (styles2) => { uniPage.setPageStyle(styles2); }; uniPage.getAndroidView = () => null; uniPage.getHTMLElement = () => null; if (getPage$BasePage(pageVm).openType !== OPEN_DIALOG_PAGE) { addCurrentPageWithInitScope(__pageId, pageVm, __pageInstance); } } { onMounted(() => { var _pageVm$$el2; var rootElement = (_pageVm$$el2 = pageVm.$el) === null || _pageVm$$el2 === void 0 ? void 0 : _pageVm$$el2._parent; if (rootElement) { rootElement._page = pageVm.$page; } }); onBeforeUnmount(() => { var _pageVm$$el3; var rootElement = (_pageVm$$el3 = pageVm.$el) === null || _pageVm$$el3 === void 0 ? void 0 : _pageVm$$el3._parent; if (rootElement) { rootElement._page = null; } }); } if (oldSetup) { return oldSetup(props, ctx); } }; return component; } function initScope(pageId, vm, pageInstance) { { Object.defineProperty(vm, "$viewToTempFilePath", { get() { return vm.$nativePage.viewToTempFilePath.bind(vm.$nativePage); } }); Object.defineProperty(vm, "$getPageStyle", { get() { return vm.$nativePage.getPageStyle.bind(vm.$nativePage); } }); Object.defineProperty(vm, "$setPageStyle", { get() { return vm.$nativePage.setPageStyle.bind(vm.$nativePage); } }); } vm.getOpenerEventChannel = () => { if (!pageInstance.eventChannel) { pageInstance.eventChannel = new EventChannel(pageId); } return pageInstance.eventChannel; }; return vm; } function addCurrentPageWithInitScope(pageId, pageVm, pageInstance) { addCurrentPage(initScope(pageId, pageVm, pageInstance)); } function isVuePageAsyncComponent(component) { return isFunction$1(component); } var pagesMap = /* @__PURE__ */ new Map(); function definePage(pagePath, asyncComponent) { pagesMap.set(pagePath, once(createFactory(asyncComponent))); } function createFactory(component) { return () => { if (isVuePageAsyncComponent(component)) { return component().then((component2) => setupPage(component2)); } return setupPage(component); }; } function initRouteOptions(path, openType) { var routeOptions = JSON.parse(JSON.stringify(getRouteOptions(path))); routeOptions.meta = initRouteMeta(routeOptions.meta); if (openType !== "preloadPage" && !__uniConfig.realEntryPagePath && (openType === "reLaunch" || getCurrentPages().length === 0)) { routeOptions.meta.isQuit = true; } else if (!routeOptions.meta.isTabBar) { routeOptions.meta.isQuit = false; } return routeOptions; } var id = 1; function getWebviewId() { return id; } function genWebviewId() { return id++; } var ANI_SHOW = "pop-in"; var ANI_DURATION = 300; var ANI_CLOSE = "pop-out"; function hasLeadingSlash(str) { return str.indexOf("/") == 0; } function getRealPath(path) { var fix = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : false; if (hasLeadingSlash(path)) { return path; } if (fix && path.indexOf(".") !== 0) { return "/" + path; } var currentPage = getCurrentPage().vm; var currentPath = !currentPage ? "/" : parseUrl(currentPage.route).path; var currentPathArray = currentPath.split("/"); var pathArray = path.split("/"); var resultArray = []; for (var index2 = 0; index2 < pathArray.length; index2++) { var element = pathArray[index2]; if (element == "..") { currentPathArray.pop(); } else if (element != ".") { resultArray.push(element); } } return addLeadingSlash(currentPathArray.concat(resultArray).join("/")); } var systemRoutes = []; function registerSystemRoute(route, page) { var meta = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {}; if (systemRoutes.includes(route)) { return; } systemRoutes.push(route); __uniRoutes.push({ path: route, meta: extend({ isQuit: false, isEntry: false, route, navigationBar: {} }, meta) }); definePage(route, page); } var API_ADD_INTERCEPTOR = "addInterceptor"; var API_REMOVE_INTERCEPTOR = "removeInterceptor"; function mergeInterceptorHook(interceptors2, interceptor) { Object.keys(interceptor).forEach((hook) => { if (isFunction$1(interceptor[hook])) { interceptors2[hook] = mergeHook(interceptors2[hook], interceptor[hook]); } }); } function removeInterceptorHook(interceptors2, interceptor) { if (!interceptors2 || !interceptor) { return; } Object.keys(interceptor).forEach((name) => { var hooks = interceptors2[name]; var hook = interceptor[name]; if (isArray(hooks) && isFunction$1(hook)) { remove(hooks, hook); } }); } function mergeHook(parentVal, childVal) { var res = childVal ? parentVal ? parentVal.concat(childVal) : isArray(childVal) ? childVal : [childVal] : parentVal; return res ? dedupeHooks(res) : res; } function dedupeHooks(hooks) { var res = []; for (var i = 0; i < hooks.length; i++) { if (res.indexOf(hooks[i]) === -1) { res.push(hooks[i]); } } return res; } var addInterceptor = /* @__PURE__ */ defineSyncApi(API_ADD_INTERCEPTOR, (method, interceptor) => { if (isString(method) && isPlainObject(interceptor)) { mergeInterceptorHook(scopedInterceptors[method] || (scopedInterceptors[method] = {}), interceptor); } else if (isPlainObject(method)) { mergeInterceptorHook(globalInterceptors, method); } }); var removeInterceptor = /* @__PURE__ */ defineSyncApi(API_REMOVE_INTERCEPTOR, (method, interceptor) => { if (isString(method)) { if (isPlainObject(interceptor)) { removeInterceptorHook(scopedInterceptors[method], interceptor); } else { delete scopedInterceptors[method]; } } else if (isPlainObject(method)) { removeInterceptorHook(globalInterceptors, method); } }); var API_ON = "$on"; var API_ONCE = "$once"; var API_OFF = "$off"; var API_EMIT = "$emit"; class EventBus { constructor() { this.$emitter = new Emitter(); } on(name, callback) { return this.$emitter.on(name, callback); } once(name, callback) { return this.$emitter.once(name, callback); } off(name, callback) { if (!name) { this.$emitter.e = {}; return; } this.$emitter.off(name, callback); } emit(name) { for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { args[_key - 1] = arguments[_key]; } this.$emitter.emit(name, ...args); } } var eventBus = new EventBus(); var $on = /* @__PURE__ */ defineSyncApi(API_ON, (name, callback) => { var id2 = eventBus.on(name, callback); { return id2; } }); var $once = /* @__PURE__ */ defineSyncApi(API_ONCE, (name, callback) => { var id2 = eventBus.once(name, callback); { return id2; } }); var $off = /* @__PURE__ */ defineSyncApi(API_OFF, (name, callback) => { if (!isArray(name)) name = name ? [name] : []; name.forEach((n) => eventBus.off(n, callback)); }); var $emit = /* @__PURE__ */ defineSyncApi(API_EMIT, function(name) { for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) { args[_key2 - 1] = arguments[_key2]; } eventBus.emit(name, ...args); }); var appHooks = { [ON_UNHANDLE_REJECTION]: [], [ON_PAGE_NOT_FOUND]: [], [ON_ERROR]: [], [ON_SHOW]: [], [ON_HIDE]: [] }; function injectAppHooks(appInstance) { Object.keys(appHooks).forEach((type) => { appHooks[type].forEach((hook) => { injectHook(type, hook, appInstance); }); }); } function encodeQueryString(url) { if (!isString(url)) { return url; } var index2 = url.indexOf("?"); if (index2 === -1) { return url; } var query = url.slice(index2 + 1).trim().replace(/^(\?|#|&)/, ""); if (!query) { return url; } url = url.slice(0, index2); var params = []; query.split("&").forEach((param) => { var parts = param.replace(/\+/g, " ").split("="); var key = parts.shift(); var val = parts.length > 0 ? parts.join("=") : ""; params.push(key + "=" + encodeURIComponent(val)); }); return params.length ? url + "?" + params.join("&") : url; } var ANIMATION_IN = ["slide-in-right", "slide-in-left", "slide-in-top", "slide-in-bottom", "fade-in", "zoom-out", "zoom-fade-out", "pop-in", "none"]; var ANIMATION_OUT = ["slide-out-right", "slide-out-left", "slide-out-top", "slide-out-bottom", "fade-out", "zoom-in", "zoom-fade-in", "pop-out", "none"]; var BaseRouteProtocol = { url: { type: String, required: true } }; var API_NAVIGATE_TO = "navigateTo"; var API_REDIRECT_TO = "redirectTo"; var API_RE_LAUNCH = "reLaunch"; var API_SWITCH_TAB = "switchTab"; var API_NAVIGATE_BACK = "navigateBack"; var API_PRELOAD_PAGE = "preloadPage"; var API_UN_PRELOAD_PAGE = "unPreloadPage"; var NavigateToProtocol = /* @__PURE__ */ extend({}, BaseRouteProtocol, createAnimationProtocol(ANIMATION_IN)); var NavigateBackProtocol = /* @__PURE__ */ extend({ delta: { type: Number } }, createAnimationProtocol(ANIMATION_OUT)); var RedirectToProtocol = BaseRouteProtocol; var ReLaunchProtocol = BaseRouteProtocol; var SwitchTabProtocol = BaseRouteProtocol; var NavigateToOptions = /* @__PURE__ */ createRouteOptions(API_NAVIGATE_TO); var RedirectToOptions = /* @__PURE__ */ createRouteOptions(API_REDIRECT_TO); var ReLaunchOptions = /* @__PURE__ */ createRouteOptions(API_RE_LAUNCH); var SwitchTabOptions = /* @__PURE__ */ createRouteOptions(API_SWITCH_TAB); var NavigateBackOptions = { formatArgs: { delta(value, params) { value = parseInt(value + "") || 1; params.delta = Math.min(getCurrentPages().length - 1, value); } } }; function createAnimationProtocol(animationTypes) { return { animationType: { type: String, validator(type) { if (type && animationTypes.indexOf(type) === -1) { return "`" + type + "` is not supported for `animationType` (supported values are: `" + animationTypes.join("`|`") + "`)"; } } }, animationDuration: { type: Number } }; } var navigatorLock; function beforeRoute() { navigatorLock = ""; } function createRouteOptions(type) { return { formatArgs: { url: createNormalizeUrl(type) }, beforeAll: beforeRoute }; } function createNormalizeUrl(type) { return function normalizeUrl(url, params) { if (!url) { return 'Missing required args: "url"'; } url = normalizeRoute(url); var pagePath = url.split("?")[0]; var routeOptions = getRouteOptions(pagePath, true); if (!routeOptions) { return "page `" + url + "` is not found"; } if (type === API_NAVIGATE_TO || type === API_REDIRECT_TO) { if (routeOptions.meta.isTabBar) { return "can not ".concat(type, " a tabbar page"); } } else if (type === API_SWITCH_TAB) { if (!routeOptions.meta.isTabBar) { return "can not switch to no-tabBar page"; } } if ((type === API_SWITCH_TAB || type === API_PRELOAD_PAGE) && routeOptions.meta.isTabBar && params.openType !== "appLaunch") { url = pagePath; } if (routeOptions.meta.isEntry) { url = url.replace(routeOptions.alias, "/"); } params.url = encodeQueryString(url); if (type === API_UN_PRELOAD_PAGE) { return; } else if (type === API_PRELOAD_PAGE) { { if (!routeOptions.meta.isNVue) { return "can not preload vue page"; } } if (routeOptions.meta.isTabBar) { var pages2 = getCurrentPages(); var tabBarPagePath = routeOptions.path.slice(1); if (pages2.find((page) => page.route === tabBarPagePath)) { return "tabBar page `" + tabBarPagePath + "` already exists"; } } return; } if (navigatorLock === url && params.openType !== "appLaunch") { return "".concat(navigatorLock, " locked"); } if (__uniConfig.ready) { navigatorLock = url; } }; } var API_LOAD_FONT_FACE = "loadFontFace"; var FRONT_COLORS = ["#ffffff", "#000000"]; var API_SET_NAVIGATION_BAR_COLOR = "setNavigationBarColor"; var SetNavigationBarColorOptions = { formatArgs: { animation(animation2, params) { if (!animation2) { animation2 = { duration: 0, timingFunc: "linear" }; } params.animation = { duration: animation2.duration || 0, timingFunc: animation2.timingFunc || "linear" }; } } }; var SetNavigationBarColorProtocol = { frontColor: { type: String, required: true, validator(frontColor) { if (FRONT_COLORS.indexOf(frontColor) === -1) { return 'invalid frontColor "'.concat(frontColor, '"'); } } }, backgroundColor: { type: String, required: true }, animation: Object }; var API_SET_NAVIGATION_BAR_TITLE = "setNavigationBarTitle"; var API_PAGE_SCROLL_TO = "pageScrollTo"; var PageScrollToProtocol = { scrollTop: Number, selector: String, duration: Number }; var PageScrollToOptions = { formatArgs: { duration: 300 } }; var API_START_PULL_DOWN_REFRESH = "startPullDownRefresh"; var API_STOP_PULL_DOWN_REFRESH = "stopPullDownRefresh"; var IndexProtocol = { index: { type: Number, required: true } }; var IndexOptions = { beforeInvoke() { var pageMeta = getCurrentPageMeta(); if (pageMeta && !pageMeta.isTabBar) { return "not TabBar page"; } }, formatArgs: { index(value) { if (!__uniConfig.tabBar.list[value]) { return "tabbar item not found"; } } } }; var API_SET_TAB_BAR_ITEM = "setTabBarItem"; var SetTabBarItemProtocol = /* @__PURE__ */ extend({ text: String, iconPath: String, selectedIconPath: String, pagePath: String }, IndexProtocol); var SetTabBarItemOptions = { beforeInvoke: IndexOptions.beforeInvoke, formatArgs: /* @__PURE__ */ extend({ pagePath(value, params) { if (value) { params.pagePath = removeLeadingSlash(value); } } }, IndexOptions.formatArgs) }; var API_SET_TAB_BAR_STYLE = "setTabBarStyle"; var SetTabBarStyleProtocol = { color: String, selectedColor: String, backgroundColor: String, backgroundImage: String, backgroundRepeat: String, borderStyle: String }; var SetTabBarStyleOptions = { beforeInvoke: IndexOptions.beforeInvoke, formatArgs: { backgroundImage(value, params) { { params.backgroundImage = value; return; } }, borderStyle(value, params) { if (value) { params.borderStyle = value === "white" ? "white" : "black"; } } } }; var API_HIDE_TAB_BAR = "hideTabBar"; var API_SHOW_TAB_BAR = "showTabBar"; var API_HIDE_TAB_BAR_RED_DOT = "hideTabBarRedDot"; var HideTabBarRedDotProtocol = IndexProtocol; var HideTabBarRedDotOptions = IndexOptions; var API_SHOW_TAB_BAR_RED_DOT = "showTabBarRedDot"; var ShowTabBarRedDotProtocol = IndexProtocol; var ShowTabBarRedDotOptions = IndexOptions; var API_REMOVE_TAB_BAR_BADGE = "removeTabBarBadge"; var RemoveTabBarBadgeProtocol = IndexProtocol; var RemoveTabBarBadgeOptions = IndexOptions; var API_SET_TAB_BAR_BADGE = "setTabBarBadge"; var SetTabBarBadgeProtocol = /* @__PURE__ */ extend({ text: { type: String, required: true } }, IndexProtocol); var SetTabBarBadgeOptions = { beforeInvoke: IndexOptions.beforeInvoke, formatArgs: /* @__PURE__ */ extend({ text(value, params) { if (getLen(value) >= 4) { params.text = "..."; } } }, IndexOptions.formatArgs) }; function showWebview(nPage, animationType, animationDuration, showCallback) { nPage.show(/* @__PURE__ */ new Map([["animationType", animationType], ["animationDuration", animationDuration]]), showCallback); } function closeWebview(nPage, animationType, animationDuration, callback) { var options = /* @__PURE__ */ new Map([["animationType", animationType]]); if (typeof animationDuration === "number") { options.set("animationDuration", animationDuration); } nPage.close(options, callback); } var nativeApp; function getNativeApp() { return nativeApp; } function setNativeApp(app) { nativeApp = app; } function getPageManager() { return nativeApp.pageManager; } var beforeRouteHooks = []; var afterRouteHooks = []; var pageReadyHooks = []; function onBeforeRoute(hook) { beforeRouteHooks.push(hook); } function onAfterRoute(hook) { afterRouteHooks.push(hook); } function onPageReady(hook) { pageReadyHooks.push(hook); } function invokeBeforeRouteHooks(type) { invokeArrayFns$1(beforeRouteHooks, type); } function invokeAfterRouteHooks(type) { invokeArrayFns$1(afterRouteHooks, type); } function invokePageReadyHooks(page) { invokeArrayFns$1(pageReadyHooks, page); } var BORDER_COLORS = /* @__PURE__ */ new Map([["white", "rgba(255, 255, 255, 0.33)"], ["black", "rgba(0, 0, 0, 0.33)"]]); function getBorderStyle(borderStyle) { var value = BORDER_COLORS.get(borderStyle); if (borderStyle && !value) { console.warn("4.23 版本起,在 pages.json 设置 tabbar borderStyle、在 uni.setTabBarStyle 设置 borderStyle 时仅支持 white/black,推荐使用 borderColor 自定义颜色。"); } return value || BORDER_COLORS.get("black"); } function fixBorderStyle(tabBarConfig) { var borderStyle = tabBarConfig.get("borderStyle"); var borderColor = tabBarConfig.get("borderColor"); var isBorderColorFilled = isString(borderColor); borderStyle = getBorderStyle(borderStyle); if (isBorderColorFilled) { borderStyle = borderColor; } tabBarConfig.set("borderStyle", borderStyle); tabBarConfig.delete("borderColor"); } var onTabBarMidButtonTapCallback = []; var tabBar0 = null; var selected0 = -1; var tabs = /* @__PURE__ */ new Map(); function getTabList() { var tabConfig = __uniConfig.tabBar ? /* @__PURE__ */ new Map() : null; if (__uniConfig.tabBar) { for (var key in __uniConfig.tabBar) { tabConfig.set(key, __uniConfig.tabBar[key]); } } if (tabConfig === null) { return null; } var list = tabConfig.get("list"); return list; } function init() { var _uniConfig$globalSty, _uniConfig$globalSty2; var list = getTabList(); var style = /* @__PURE__ */ new Map(); style.set("navigationStyle", "custom"); style.set("pageOrientation", (_uniConfig$globalSty = (_uniConfig$globalSty2 = __uniConfig.globalStyle) === null || _uniConfig$globalSty2 === void 0 ? void 0 : _uniConfig$globalSty2.pageOrientation) !== null && _uniConfig$globalSty !== void 0 ? _uniConfig$globalSty : "portrait"); var page = getPageManager().createPage( "tabBar", // id 后增加 Date.now() 保证唯一性,与 android 端统一 "tabBar_".concat(Date.now()), style ); var document = page.createDocument(new NodeData("root", "view", /* @__PURE__ */ new Map(), /* @__PURE__ */ new Map([["flex", "1"]]))); var tabParent = document.createElement(new NodeData("tabs", "tabs", /* @__PURE__ */ new Map(), /* @__PURE__ */ new Map([["overflow", "hidden"], ["flex", "1"]]))); document.appendChild(tabParent); tabBar0 = document.getRealDomNodeById("tabs"); var _tabBarConfig = extend({}, __uniConfig.tabBar); normalizeTabBarStyles(_tabBarConfig, __uniConfig.themeConfig, getAppThemeFallbackOS()); var tabBarConfig = /* @__PURE__ */ new Map(); for (var key in _tabBarConfig) { tabBarConfig.set(key, _tabBarConfig[key]); } fixBorderStyle(tabBarConfig); tabBar0.initTabBar(tabBarConfig); tabBar0.addEventListener("tabBarItemTap", function(event) { var index2 = event.index; if (index2 !== selected0) { var item = list[index2]; var path = item.pagePath; if (isString(path) && findPageRoute(getRealPath(path, true))) { uni.switchTab({ url: getRealPath(path, true) }); } else { console.error("switchTab: pagePath not found"); } } }); tabBar0.addEventListener("tabBarMidButtonTap", function(event) { onTabBarMidButtonTapCallback.forEach((callback) => { if (typeof callback === "function") { callback(); } }); }); page.startRender(); page.show(null); } function removeTabBarPage(page) { var pagePath = getRealPath(page.route, true); if (tabs.get(pagePath) === page) { tabs.delete(pagePath); if (getTabIndex(pagePath) === selected0) { selected0 = -1; } } } function getTabBar() { return tabBar0; } function getTabIndex(path) { var list = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : getTabList(); var selected = -1; if (list && list.length !== 0) { for (var index2 = 0; index2 < list.length; index2++) { var page = list[index2]; var pagePath = page.pagePath; if (isString(pagePath) && getRealPath(pagePath, true) == getRealPath(path, true)) { selected = index2; break; } } } return selected; } function findPageRoute(path) { return __uniRoutes.find((route) => route.path === path); } function createTab(path, query, callback) { registerPage({ url: path, path, query, openType: "switchTab" }); callback === null || callback === void 0 || callback(); var page = getCurrentPage().vm; tabBar0.appendItem(page.$basePage.id.toString()); return page; } function findTabPage(path) { var _tabs$get; var page = (_tabs$get = tabs.get(path)) !== null && _tabs$get !== void 0 ? _tabs$get : null; var pages2 = getAllPages(); pages2.forEach((item) => item.$.__isActive = item === page); if (page !== null) { var index2 = pages2.indexOf(page); if (index2 !== pages2.length - 1) { pages2.splice(index2, 1); pages2.push(page); } } return page; } function isTabPage(page) { var has = false; tabs.forEach((value, key) => { if (value === page) { has = true; } }); return has; } class TabPageInfo { constructor(page, isFirst) { this.page = page; this.isFirst = isFirst; } } function getTabPage(path) { var query = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}; var rebuild = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : false; var callback = arguments.length > 3 ? arguments[3] : void 0; var page = findTabPage(path); var isFirst = false; if (page === null || rebuild) { isFirst = true; page = createTab(path, query, callback); tabs.set(path, page); } return new TabPageInfo(page, isFirst); } function switchSelect(selected, path) { var _getCurrentPage; var query = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {}; var rebuild = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : false; var callback = arguments.length > 4 ? arguments[4] : void 0; var shouldShow = false; if (tabBar0 === null) { init(); } var currentPage = (_getCurrentPage = getCurrentPage()) === null || _getCurrentPage === void 0 ? void 0 : _getCurrentPage.vm; var type = currentPage == null ? "appLaunch" : "switchTab"; invokeBeforeRouteHooks(type); var pageInfo = getTabPage(getRealPath(path, true), query, rebuild, callback); var page = pageInfo.page; if (currentPage !== page) { shouldShow = true; if (currentPage && isTabPage(currentPage)) { invokeHook(currentPage, ON_HIDE); } } tabBar0.switchSelect(page.$basePage.id.toString(), selected); if (shouldShow) { invokeHook(page, ON_SHOW); } selected0 = selected; invokeAfterRouteHooks(type); } var APP_THEME_AUTO = "auto"; var THEME_KEY_PREFIX = "@"; function getAppThemeFallbackOS() { var fallbackOSTheme = "light"; try { var appTheme = uni.getAppBaseInfo().appTheme; fallbackOSTheme = appTheme; if (appTheme === APP_THEME_AUTO) { var osTheme = uni.getDeviceInfo().osTheme; fallbackOSTheme = osTheme; } return fallbackOSTheme; } catch (e) { console.error(e); return fallbackOSTheme; } } var appThemeChangeCallbackId = -1; function clearAppThemeChangeCallbackId() { appThemeChangeCallbackId = -1; } function registerThemeChange(callback) { try { if (appThemeChangeCallbackId !== -1) { uni.offAppThemeChange(appThemeChangeCallbackId); clearAppThemeChangeCallbackId(); } appThemeChangeCallbackId = uni.onAppThemeChange(function(res1) { var appThemeMode = res1["appTheme"]; callback(appThemeMode); }); } catch (e) { console.warn("监听 OS 主题变化", e); } } var onThemeChange = function(themeMode) { var handlePage = () => { var pages2 = getAllPages(); pages2.forEach((page) => { var routeOptions = initRouteOptions(page.$basePage.path, ""); var style = parsePageStyle(routeOptions); page.$page.setPageStyle(new UTSJSONObject(style)); }); }; handlePage(); var handleTabBar = () => { var tabBar = getTabBar(); if (tabBar !== null) { var tabBarConfig = __uniConfig.getTabBarConfig(); normalizeTabBarStyles(tabBarConfig, __uniConfig.themeConfig, themeMode); var tabBarStyle = /* @__PURE__ */ new Map(); var tabBarConfigKeys = Object.keys(tabBarConfig); tabBarConfigKeys.forEach((key) => { var value = tabBarConfig[key]; if (isString(value)) { tabBarStyle.set(key, value); } else if (isArray(value)) { var valueAsArray = value; var index2 = 0; valueAsArray.forEach((item) => { var tabBarItemMap = /* @__PURE__ */ new Map(); tabBarItemMap.set("index", index2); Object.keys(item).forEach((tabBarItemkey) => { if (item[tabBarItemkey] != null) { tabBarItemMap.set(tabBarItemkey, item[tabBarItemkey]); } }); tabBar.setTabBarItem(tabBarItemMap); index2++; }); } }); fixBorderStyle(tabBarStyle); tabBar.setTabBarStyle(tabBarStyle); } }; handleTabBar(); }; function normalizePageStyles(pageStyle, themeConfig, themeMode) { var themeMap = themeConfig === null || themeConfig === void 0 ? void 0 : themeConfig[themeMode]; if (!themeMap) { return; } normalizeStyles(pageStyle, themeMap); } function normalizeStyles(style, themeMap) { Object.keys(style).forEach((key) => { var value = style[key]; if (isString(value)) { var valueAsString = value; if (valueAsString.startsWith(THEME_KEY_PREFIX)) { var valueKey = valueAsString.slice(1); var configValue = themeMap[valueKey]; if (configValue != null) { style[key] = configValue; } } } else if (isArray(value)) { var valueAsArray = value; valueAsArray.forEach((item) => { normalizeStyles(item, themeMap); }); } else if (isPlainObject(value)) { normalizeStyles(value, themeMap); } }); } function normalizeTabBarStyles(tabBar, themeConfig, themeMode) { if (!themeConfig) { return; } var themeMap = themeConfig[themeMode]; if (themeMap == null) { return; } normalizeStyles(tabBar, themeMap); } function useTheme() { registerThemeChange(onThemeChange); } var homeDialogPages = []; var homeSystemDialogPages = []; function parsePageStyle(route) { var style = /* @__PURE__ */ new Map(); var routeMeta = route.meta; var routeKeys = [ "id", "route", "i18n", "isQuit", "isEntry", "isTabBar", "tabBarIndex", "tabBarText", "windowTop", "topWindow", "leftWindow", "rightWindow", "eventChannel", // 忽略 initRouteMeta产生的 navigationBar 对象 "navigationBar" ]; var navKeys = ["navigationBarTitleText", "navigationBarBackgroundColor", "navigationBarTextStyle", "navigationStyle"]; normalizePageStyles(routeMeta, __uniConfig.themeConfig, getAppThemeFallbackOS()); Object.keys(routeMeta).forEach((key) => { if (!routeKeys.includes(key) && !navKeys.includes(key)) { style.set(key, routeMeta[key]); } }); var navigationBar = {}; navKeys.forEach((key) => { if (key in routeMeta) { navigationBar[key] = routeMeta[key]; } }); if (Object.keys(navigationBar).length > 0) { if (navigationBar.navigationBarTextStyle !== "custom" && !routeMeta.isQuit && routeMeta.route !== __uniConfig.realEntryPagePath) { style.set("navigationBarAutoBackButton", true); } Object.keys(navigationBar).forEach((key) => { style.set(key, navigationBar[key]); }); } return style; } function registerPage(_ref, onCreated) { var { url, path, query, openType, webview, nvuePageVm, eventChannel } = _ref; var delay = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : 0; var id2 = genWebviewId(); var routeOptions = initRouteOptions(path, openType); var pageStyle = parsePageStyle(routeOptions); var nativePage2 = getPageManager().createPage(url, id2.toString(), pageStyle); if (onCreated) { onCreated(nativePage2); } routeOptions.meta.id = parseInt(nativePage2.pageId); var route = path.slice(1); var pageInstance = initPageInternalInstance( openType, url, query, routeOptions.meta, eventChannel, // TODO ThemeMode "light" ); function fn() { var page = createVuePage(id2, route, query, pageInstance, {}, nativePage2); var pages2 = getCurrentPages(); if (pages2.length === 1) { if (homeDialogPages.length) { var homePage = pages2[0]; homePage.vm.$.$dialogPages = homeDialogPages.map((dialogPage) => { dialogPage.getParentPage = () => homePage; return dialogPage; }); homeDialogPages.length = 0; } if (homeSystemDialogPages.length) { var _homePage = pages2[0]; _homePage.vm.$systemDialogPages = homeSystemDialogPages.map((dialogPage) => { dialogPage.getParentPage = () => _homePage; return dialogPage; }); homeDialogPages.length = 0; } } nativePage2.addPageEventListener(ON_POP_GESTURE, function(e) { uni.navigateBack({ from: "popGesture", fail(e2) { if (e2.errMsg.endsWith("cancel")) { nativePage2.show(); } } }); }); nativePage2.addPageEventListener(ON_UNLOAD, (_) => { invokeHook(page, ON_UNLOAD); }); nativePage2.addPageEventListener(ON_READY, (_) => { invokePageReadyHooks(page); invokeHook(page, ON_READY); }); nativePage2.addPageEventListener(ON_PAGE_SCROLL, (arg) => { invokeHook(page, ON_PAGE_SCROLL, { scrollTop: arg.scrollTop }); }); nativePage2.addPageEventListener(ON_PULL_DOWN_REFRESH, (_) => { invokeHook(page, ON_PULL_DOWN_REFRESH); }); nativePage2.addPageEventListener(ON_REACH_BOTTOM, (_) => { invokeHook(page, ON_REACH_BOTTOM); }); nativePage2.addPageEventListener(ON_RESIZE, (arg) => { var args = { deviceOrientation: arg.deviceOrientation, size: { windowWidth: arg.size.windowWidth, windowHeight: arg.size.windowHeight, screenWidth: arg.size.screenWidth, screenHeight: arg.size.screenHeight } }; invokeHook(page, ON_RESIZE, args); }); nativePage2.startRender(); } if (delay) { setTimeout(fn, delay); } else { fn(); } return nativePage2; } function registerDialogPage(_ref2, dialogPage, onCreated) { var { url, path, query, openType, webview, nvuePageVm, eventChannel } = _ref2; var delay = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : 0; var id2 = genWebviewId(); var routeOptions = initRouteOptions(path, openType); var pageStyle = parsePageStyle(routeOptions); pageStyle.set("navigationStyle", "custom"); pageStyle.set("backgroundColorContent", "transparent"); if (typeof pageStyle.get("disableSwipeBack") !== "boolean") { pageStyle.set("disableSwipeBack", true); } var parentPage = dialogPage.getParentPage(); var nativePage2 = getPageManager().createDialogPage( // @ts-expect-error parentPage ? parentPage.__nativePageId : "", id2.toString(), url, pageStyle ); if (onCreated) { onCreated(nativePage2); } routeOptions.meta.id = parseInt(nativePage2.pageId); var route = path.startsWith(SYSTEM_DIALOG_PAGE_PATH_STARTER) ? path : path.slice(1); var pageInstance = initPageInternalInstance( openType, url, query, routeOptions.meta, eventChannel, // TODO ThemeMode "light" ); function fn() { var page = createVuePage(id2, route, query, pageInstance, {}, nativePage2); dialogPage.vm = page; dialogPage.$vm = page; nativePage2.addPageEventListener(ON_POP_GESTURE, function(e) { closeDialogPage({ dialogPage }); }); nativePage2.addPageEventListener(ON_UNLOAD, (_) => { invokeHook(page, ON_UNLOAD); }); nativePage2.addPageEventListener(ON_READY, (_) => { invokePageReadyHooks(page); invokeHook(page, ON_READY); }); nativePage2.addPageEventListener(ON_PAGE_SCROLL, (arg) => { invokeHook(page, ON_PAGE_SCROLL, arg); }); nativePage2.addPageEventListener(ON_PULL_DOWN_REFRESH, (_) => { invokeHook(page, ON_PULL_DOWN_REFRESH); }); nativePage2.addPageEventListener(ON_REACH_BOTTOM, (_) => { invokeHook(page, ON_REACH_BOTTOM); }); nativePage2.addPageEventListener(ON_RESIZE, (arg) => { var args = { deviceOrientation: arg.deviceOrientation, size: { windowWidth: arg.size.windowWidth, windowHeight: arg.size.windowHeight, screenWidth: arg.size.screenWidth, screenHeight: arg.size.screenHeight } }; invokeHook(page, ON_RESIZE, args); }); nativePage2.startRender(); } if (delay) { setTimeout(fn, delay); } else { fn(); } return nativePage2; } function createVuePage(__pageId, __pagePath, __pageQuery, __pageInstance, pageOptions, nativePage2) { var pageNode = nativePage2.document.body; var app = getVueApp(); var component = pagesMap.get(__pagePath)(); var mountPage = (component2) => app.mountPage(component2, { __pageId, __pagePath, __pageQuery, __pageInstance }, pageNode); if (isPromise(component)) { return component.then((component2) => mountPage(component2)); } return mountPage(component); } function setStatusBarStyle() { var page = getCurrentPage().vm; if (page) { var nativePage2 = page.$nativePage; nativePage2.applyStatusBarStyle(); } } function initGlobalEvent(app) { app.addKeyEventListener(ON_BACK_BUTTON, () => { backbuttonListener(); return true; }); } function loadFontFaceByStyles(styles2, global) { styles2 = Array.isArray(styles2) ? styles2 : [styles2]; var fontFaceStyle = []; styles2.forEach((style) => { if (style["@FONT-FACE"]) { fontFaceStyle.push(...style["@FONT-FACE"]); } }); if (fontFaceStyle.length === 0) return; fontFaceStyle.forEach((style) => { var fontFamily = style["fontFamily"]; var fontWeight = style["fontWeight"]; var fontStyle = style["fontStyle"]; var fontVariant = style["fontVariant"]; var src = style["src"]; if (fontFamily != null && src != null) { loadFontFace({ global, family: fontFamily, source: src, desc: { style: fontStyle, weight: fontWeight, variant: fontVariant } }); } else { console.warn("loadFontFace: fail, font-family or src is null"); } }); } var API_GET_LAUNCH_OPTIONS_SYNC = "getLaunchOptionsSync"; var launchOptions = { path: "", appScheme: null, appLink: null }; var setLaunchOptionsSync = function(options) { launchOptions = options; }; var getLaunchOptionsSync = /* @__PURE__ */ defineSyncApi(API_GET_LAUNCH_OPTIONS_SYNC, () => { var baseInfo = getLaunchOptions(); return Object.assign({}, baseInfo, launchOptions); }); var API_GET_ENTER_OPTIONS_SYNC = "getEnterOptionsSync"; var enterOptions = { path: "", appScheme: null, appLink: null }; var setEnterOptionsSync = function(options) { enterOptions = options; }; var getEnterOptionsSync = /* @__PURE__ */ defineSyncApi(API_GET_ENTER_OPTIONS_SYNC, () => { var baseInfo = getLaunchOptions(); return Object.assign({}, baseInfo, enterOptions); }); function initAppLaunch(appVm) { injectAppHooks(appVm.$); var { entryPagePath, entryPageQuery, referrerInfo } = __uniConfig; var args = initLaunchOptions({ path: entryPagePath, query: entryPageQuery, referrerInfo }); var app = getNativeApp(); var schemaLink = app.getLaunchOptionsSync(); var launchOption = extend({}, args, schemaLink); setLaunchOptionsSync(launchOption); invokeHook(appVm, ON_LAUNCH, launchOption); var showOption = extend({}, launchOption); setEnterOptionsSync(showOption); invokeHook(appVm, ON_SHOW, showOption); var appStyle = appVm.$options.styles; if (appStyle) { loadFontFaceByStyles(appStyle, true); } useTheme(); } function initAppError(appVm, nativeApp2) { nativeApp2.addEventListener(ON_ERROR, function(errorEvent) { invokeHook(appVm, ON_ERROR, errorEvent.error); }); } var redirectTo = /* @__PURE__ */ defineAsyncApi(API_REDIRECT_TO, (_ref, _ref2) => { var { url } = _ref; var { resolve, reject } = _ref2; var { path, query } = parseUrl(url); if (!entryPageState.isReady) { redirectToPagesBeforeEntryPages.push({ args: { url, path, query }, handler: { resolve, reject } }); return; } _redirectTo({ url, path, query }).then(resolve).catch(reject); }, RedirectToProtocol, RedirectToOptions); function _redirectTo(_ref3) { var { url, path, query } = _ref3; var lastPage = getCurrentPage().vm; return new Promise((resolve) => { invokeAfterRouteHooks(API_REDIRECT_TO); showWebview(registerPage({ url, path, query, openType: isTabPage(lastPage) || getAllPages().length === 1 ? "reLaunch" : "redirectTo" }), "none", 0, () => { if (lastPage) { removePages(lastPage); } resolve(void 0); setStatusBarStyle(); }); invokeBeforeRouteHooks(API_REDIRECT_TO); }); } function removePages(currentPage) { if (isTabPage(currentPage)) { var pages2 = getAllPages().slice(0, -1); pages2.forEach((page) => { closePage(page, "none"); }); } else { closePage(currentPage, "none"); } } var $reLaunch = (_ref, _ref2) => { var { url } = _ref; var { resolve, reject } = _ref2; var { path, query } = parseUrl(url); if (!entryPageState.isReady) { reLaunchPagesBeforeEntryPages.push({ args: { url }, handler: { resolve, reject } }); return; } _reLaunch({ url, path, query }).then(resolve).catch(reject); }; function _reLaunch(_ref3) { var { url, path, query } = _ref3; return new Promise((resolve) => { var pages2 = getAllPages().slice(0); var selected = getTabIndex(path); function callback() { pages2.forEach((page) => closePage(page, "none")); resolve(void 0); setStatusBarStyle(); } if (selected === -1) { showWebview(registerPage({ url, path, query, openType: "reLaunch" }), "none", 0, callback); } else { switchSelect(selected, path, query, true, callback); } }); } var reLaunch = /* @__PURE__ */ defineAsyncApi(API_RE_LAUNCH, $reLaunch, ReLaunchProtocol, ReLaunchOptions); function closePage(page, animationType, animationDuration) { var dialogPages = page.$page.getDialogPages(); for (var i = dialogPages.length - 1; i >= 0; i--) { closeNativeDialogPage(dialogPages[i]); } var systemDialogPages = page.$systemDialogPages || []; for (var _i = 0; _i < systemDialogPages.length; _i++) { closeNativeDialogPage(systemDialogPages[_i]); } page.$systemDialogPages = []; for (var _i2 = dialogPages.length - 1; _i2 >= 0; _i2--) { closeNativeDialogPage(dialogPages[_i2]); } closeWebview(page.$nativePage, animationType, animationDuration); removePage(page); removeTabBarPage(page); } function updateEntryPageIsReady(path) { if (!getCurrentPage() && path === addLeadingSlash(__uniConfig.entryPagePath)) { entryPageState.isReady = true; } } function handleBeforeEntryPageRoutes() { if (entryPageState.handledBeforeEntryPageRoutes) { return; } entryPageState.handledBeforeEntryPageRoutes = true; var navigateToPages = [...navigateToPagesBeforeEntryPages]; navigateToPagesBeforeEntryPages.length = 0; navigateToPages.forEach((_ref) => { var { args, handler } = _ref; return $navigateTo(args, handler); }); var switchTabPages = [...switchTabPagesBeforeEntryPages]; switchTabPagesBeforeEntryPages.length = 0; switchTabPages.forEach((_ref2) => { var { args, handler } = _ref2; return $switchTab(args, handler); }); var redirectToPages = [...redirectToPagesBeforeEntryPages]; redirectToPagesBeforeEntryPages.length = 0; redirectToPages.forEach((_ref3) => { var { args, handler } = _ref3; return _redirectTo(args).then(handler.resolve).catch(handler.reject); }); var reLaunchPages = [...reLaunchPagesBeforeEntryPages]; reLaunchPagesBeforeEntryPages.length = 0; reLaunchPages.forEach((_ref4) => { var { args, handler } = _ref4; return $reLaunch(args, handler); }); } function closeNativeDialogPage(dialogPage, animationType, animationDuration, callback) { var webview = getNativeApp().pageManager.findPageById(dialogPage.$vm.$basePage.id + ""); if (webview) { closeWebview(webview, animationType || "none", animationDuration || 0, callback); } } var $switchTab = (args, _ref) => { var { resolve, reject } = _ref; var { url } = args; var { path, query } = parseUrl(url); updateEntryPageIsReady(path); if (!entryPageState.isReady) { switchTabPagesBeforeEntryPages.push({ args, handler: { resolve, reject } }); return; } _switchTab({ url, path, query }).then(resolve).catch(reject); handleBeforeEntryPageRoutes(); }; var switchTab = /* @__PURE__ */ defineAsyncApi(API_SWITCH_TAB, $switchTab, SwitchTabProtocol, SwitchTabOptions); function _switchTab(_ref2) { var { url, path, query } = _ref2; var selected = getTabIndex(path); if (selected == -1) { return Promise.reject("tab ".concat(path, " not found")); } var pages2 = getCurrentBasePages(); switchSelect(selected, path, query); for (var index2 = pages2.length - 1; index2 >= 0; index2--) { var page = pages2[index2]; if (isTabPage(page)) { break; } closePage(page, "none"); } return Promise.resolve(); } var isLaunchWebviewReady = false; function subscribeWebviewReady(_data, pageId) { if (isLaunchWebviewReady) { return; } { isLaunchWebviewReady = true; } onLaunchWebviewReady(); } function onLaunchWebviewReady() { var entryPagePath = addLeadingSlash(__uniConfig.entryPagePath); var routeOptions = getRouteOptions(entryPagePath); var args = { url: entryPagePath + (__uniConfig.entryPageQuery || ""), openType: "appLaunch" }; var handler = { resolve() { }, reject() { } }; if (routeOptions.meta.isTabBar) { return $switchTab(args, handler); } return $navigateTo(args, handler); } function initSubscribeHandlers() { subscribeWebviewReady(); } function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n2) { return void e(n2); } i.done ? t(u) : Promise.resolve(u).then(r, o); } function _asyncToGenerator(n) { return function() { var t = this, e = arguments; return new Promise(function(r, o) { var a = n.apply(t, e); function _next(n2) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n2); } function _throw(n2) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n2); } _next(void 0); }); }; } function initOn(app) { app.addEventListener(ON_SHOW, /* @__PURE__ */ function() { var _ref = _asyncToGenerator(function* (event) { var _getCurrentPage; var app2 = getNativeApp(); var MAX_TIMEOUT = 200; function getNewIntent() { return new Promise((resolve, reject) => { var handleNewIntent = (newIntent) => { var _newIntent$appScheme, _newIntent$appLink; clearTimeout(timeout); app2.removeEventListener("onNewIntent", handleNewIntent); resolve({ appScheme: (_newIntent$appScheme = newIntent.appScheme) !== null && _newIntent$appScheme !== void 0 ? _newIntent$appScheme : null, appLink: (_newIntent$appLink = newIntent.appLink) !== null && _newIntent$appLink !== void 0 ? _newIntent$appLink : null }); }; var timeout = setTimeout(() => { app2.removeEventListener("onNewIntent", handleNewIntent); var appLink = { appScheme: null, appLink: null }; resolve(appLink); }, MAX_TIMEOUT); app2.addEventListener("onNewIntent", handleNewIntent); }); } var schemaLink = yield getNewIntent(); var showOptions = extend({ path: __uniConfig.entryPagePath }, schemaLink); setEnterOptionsSync(showOptions); var page = (_getCurrentPage = getCurrentPage()) === null || _getCurrentPage === void 0 ? void 0 : _getCurrentPage.vm; invokeHook(getApp().vm, ON_SHOW, showOptions); if (page) { invokeHook(page, ON_SHOW); } }); return function(_x) { return _ref.apply(this, arguments); }; }()); app.addEventListener(ON_HIDE, function() { var _getCurrentPage2; var page = (_getCurrentPage2 = getCurrentPage()) === null || _getCurrentPage2 === void 0 ? void 0 : _getCurrentPage2.vm; invokeHook(getApp().vm, ON_HIDE); if (page) { invokeHook(page, ON_HIDE); } }); } function initService(app) { initOn(app); } function initComponentInstance(app) { app.mixin({ beforeCreate() { var vm = this; var instance = vm.$; if (instance.type.mpType === "app") { return; } var pageId = instance.root.attrs.__pageId; vm.$nativePage = getNativeApp().pageManager.findPageById(pageId + ""); if (vm.$page) { vm.$page.__nativePageId = vm.$nativePage.pageId; } }, beforeMount() { var _vm$$options$styles; var vm = this; var instance = vm.$; if (instance.type.mpType === "app") { return; } loadFontFaceByStyles((_vm$$options$styles = vm.$options.styles) !== null && _vm$$options$styles !== void 0 ? _vm$$options$styles : [], false); } }); } var appCtx; var defaultApp = { globalData: {} }; class UniAppImpl { get vm() { return appCtx; } get $vm() { return appCtx; } get globalData() { var _appCtx; return ((_appCtx = appCtx) === null || _appCtx === void 0 ? void 0 : _appCtx.globalData) || {}; } getAndroidApplication() { return null; } } var $uniApp = new UniAppImpl(); var entryPageState = { isReady: false, handledBeforeEntryPageRoutes: false }; var navigateToPagesBeforeEntryPages = []; var switchTabPagesBeforeEntryPages = []; var redirectToPagesBeforeEntryPages = []; var reLaunchPagesBeforeEntryPages = []; function initAppVm(appVm) { appVm.$vm = appVm; appVm.$mpType = "app"; } function getApp$1() { return $uniApp; } function registerApp(appVm, nativeApp2) { initEntryPagePath(nativeApp2); setNativeApp(nativeApp2); initVueApp(appVm); appCtx = appVm; initAppVm(appCtx); extend(appCtx, defaultApp); defineGlobalData(appCtx, defaultApp.globalData); initService(nativeApp2); initGlobalEvent(nativeApp2); initAppLaunch(appVm); initAppError(appVm, nativeApp2); initSubscribeHandlers(); __uniConfig.ready = true; } function initApp(app) { initComponentInstance(app); } function initEntryPagePath(app) { var redirectInfo = app.getRedirectInfo(); var debugInfo = redirectInfo.get("debug"); if (debugInfo) { var url = debugInfo.get("url"); if (url && url != __uniConfig.entryPagePath) { __uniConfig.realEntryPagePath = __uniConfig.entryPagePath; var [path, query] = url.split("?"); __uniConfig.entryPagePath = path; if (query) { __uniConfig.entryPageQuery = "?".concat(query); } return; } } if (__uniConfig.conditionUrl) { __uniConfig.realEntryPagePath = __uniConfig.entryPagePath; var conditionUrl = __uniConfig.conditionUrl; var [_path, _query] = conditionUrl.split("?"); __uniConfig.entryPagePath = _path; if (_query) { __uniConfig.entryPageQuery = "?".concat(_query); } } } var $navigateTo = (args, _ref) => { var { resolve, reject } = _ref; var { url, events, animationType, animationDuration } = args; var { path, query } = parseUrl(url); var [aniType, aniDuration] = initAnimation$1(path, animationType, animationDuration); updateEntryPageIsReady(path); if (!entryPageState.isReady) { navigateToPagesBeforeEntryPages.push({ args, handler: { resolve, reject } }); return; } _navigateTo({ url, path, query, events, aniType, aniDuration }).then(resolve).catch(reject); handleBeforeEntryPageRoutes(); }; var navigateTo = /* @__PURE__ */ defineAsyncApi(API_NAVIGATE_TO, $navigateTo, NavigateToProtocol, NavigateToOptions); function _navigateTo(_ref2) { var _getCurrentPage; var { url, path, query, events, aniType, aniDuration } = _ref2; var currentPage = (_getCurrentPage = getCurrentPage()) === null || _getCurrentPage === void 0 ? void 0 : _getCurrentPage.vm; var currentRouteType = currentPage == null ? "appLaunch" : API_NAVIGATE_TO; invokeBeforeRouteHooks(currentRouteType); invokeHook(ON_HIDE); var eventChannel = new EventChannel(getWebviewId() + 1, events); return new Promise((resolve) => { var noAnimation = aniType === "none" || aniDuration === 0; function callback(page2) { showWebview(page2, aniType, aniDuration, () => { invokeAfterRouteHooks(currentRouteType); resolve({ eventChannel }); setStatusBarStyle(); }); } var page = registerPage( { url, path, query, openType: "navigateTo", eventChannel }, noAnimation ? void 0 : callback, // 有动画时延迟创建 vm noAnimation ? 0 : 1 ); if (noAnimation) { callback(page); } }); } function initAnimation$1(path, animationType, animationDuration) { if (!getCurrentPage()) { return ["none", 0]; } var { globalStyle } = __uniConfig; var meta = getRouteMeta(path); return [animationType || meta.animationType || globalStyle.animationType || ANI_SHOW, animationDuration || meta.animationDuration || globalStyle.animationDuration || ANI_DURATION]; } function isDirectPage(page) { return !!__uniConfig.realEntryPagePath && getRealPath(page.$basePage.route, true) === getRealPath(parseUrl(__uniConfig.entryPagePath).path, true); } function reLaunchEntryPage() { var _uniConfig$entryPage; __uniConfig.entryPagePath = __uniConfig.realEntryPagePath; __uniConfig.realEntryPagePath = ""; reLaunch({ url: (_uniConfig$entryPage = __uniConfig.entryPagePath) !== null && _uniConfig$entryPage !== void 0 && _uniConfig$entryPage.startsWith("/") ? __uniConfig.entryPagePath : "/" + __uniConfig.entryPagePath }); } var navigateBack = /* @__PURE__ */ defineAsyncApi(API_NAVIGATE_BACK, (args, _ref) => { var { resolve, reject } = _ref; var page = getCurrentPage().vm; if (!page) { return reject("getCurrentPages is empty"); } if ( // popGesture 时不触发 onBackPress 事件,避免引发半屏弹窗这种冲突情况 args.from !== "popGesture" ) { var onBackPressRes = invokeHook(page, ON_BACK_PRESS, { from: args.from || "navigateBack" }); if (onBackPressRes !== true) { var dialogPages = page.$page.getDialogPages(); if (dialogPages.length > 0) { var dialogPage = dialogPages[dialogPages.length - 1]; onBackPressRes = invokeHook(dialogPage.$vm, ON_BACK_PRESS, { from: args.from || "navigateBack" }); } } if (onBackPressRes === true) { return reject("cancel"); } } try { uni.hideToast(); uni.hideLoading(); } catch (error) { console.warn(error); } if (getPage$BasePage(page).meta.isQuit) ; else { if (isDirectPage(page)) { return reLaunchEntryPage(); } else { var { delta, animationType, animationDuration } = args; back(delta, animationType, animationDuration); } } return resolve(); }, NavigateBackProtocol, NavigateBackOptions); function back(delta, animationType, animationDuration) { var pages2 = getCurrentBasePages(); var len = pages2.length; var currentPage = pages2[len - 1]; if (delta > 1) { pages2.slice(len - delta, len - 1).reverse().forEach((deltaPage) => { var dialogPages2 = deltaPage.$page.getDialogPages(); for (var i2 = dialogPages2.length - 1; i2 >= 0; i2--) { var dialogPage2 = dialogPages2[i2]; closeNativeDialogPage(dialogPage2); } closeWebview(getNativeApp().pageManager.findPageById(deltaPage.$basePage.id + ""), "none", 0); }); } var backPage = function(webview2) { if (animationType) { animationDuration = animationDuration || ANI_DURATION; } else { if (currentPage.$basePage.openType === "redirectTo") { animationType = ANI_CLOSE; animationDuration = ANI_DURATION; } else { animationType = "auto"; } } closeWebview(webview2, animationType, animationDuration, () => { pages2.slice(len - delta, len).forEach((page) => removePage(page)); invokeHook(ON_SHOW); setStatusBarStyle(); }); }; var webview = getNativeApp().pageManager.findPageById(currentPage.$basePage.id + ""); var dialogPages = currentPage.$page.getDialogPages(); for (var i = dialogPages.length - 1; i >= 0; i--) { var dialogPage = dialogPages[i]; closeNativeDialogPage(dialogPage); if (i > 0) { invokeHook(dialogPages[i - 1].$vm, ON_SHOW); } } var systemDialogPages = currentPage.$systemDialogPages || []; for (var _i = 0; _i < systemDialogPages.length; _i++) { closeNativeDialogPage(systemDialogPages[_i]); } currentPage.$systemDialogPages = []; backPage(webview); } var openDialogPage = (options) => { var _options$success, _options$complete; var { url, animationType } = options; if (!options.url) { triggerFailCallback$1(options, "url is required"); return null; } var { path, query } = parseUrl(url); var normalizeUrl = createNormalizeUrl("navigateTo"); var errMsg = normalizeUrl(path, {}); if (errMsg) { triggerFailCallback$1(options, errMsg); return null; } var parentPage = options.parentPage || null; var currentPages = getCurrentPages(); if (parentPage) { if (currentPages.indexOf(parentPage) === -1) { triggerFailCallback$1(options, "parentPage is not a valid page"); return null; } } if (currentPages.length && !parentPage) { parentPage = currentPages[currentPages.length - 1]; } var dialogPage = new UniDialogPageImpl(); dialogPage.route = path; dialogPage.optionsByJS = query; dialogPage.getParentPage = () => parentPage; dialogPage.$component = null; dialogPage.$disableEscBack = false; var systemDialog = isSystemDialogPage(dialogPage); if (!systemDialog) { if (!parentPage) { homeDialogPages.push(dialogPage); } else { var dialogPages = parentPage.getDialogPages(); if (dialogPages.length) { invokeHook(dialogPages[dialogPages.length - 1].$vm, ON_HIDE); } dialogPages.push(dialogPage); } } else { if (!parentPage) { homeSystemDialogPages.push(dialogPage); if (isSystemActionSheetDialogPage(dialogPage)) { closePreActionSheet(homeSystemDialogPages); } } else { if (!parentPage.vm.$systemDialogPages) { parentPage.vm.$systemDialogPages = []; } parentPage.vm.$systemDialogPages.push(dialogPage); if (isSystemActionSheetDialogPage(dialogPage)) { closePreActionSheet(parentPage.vm.$systemDialogPages); } } } var [aniType, aniDuration] = initAnimation(path, animationType); var noAnimation = aniType === "none" || aniDuration === 0; function callback(page2) { showWebview(page2, aniType, aniDuration, () => { beforeRoute(); }); } var page = registerDialogPage( { url, path, query, openType: OPEN_DIALOG_PAGE }, dialogPage, noAnimation ? void 0 : callback, // 有动画时延迟创建 vm noAnimation ? 0 : 1 ); if (systemDialog) { dialogPage.__nativeType = "systemDialog"; } if (noAnimation) { callback(page); } var successOptions = { errMsg: "openDialogPage:ok" }; (_options$success = options.success) === null || _options$success === void 0 || _options$success.call(options, successOptions); (_options$complete = options.complete) === null || _options$complete === void 0 || _options$complete.call(options, successOptions); return dialogPage; }; function triggerFailCallback$1(options, errMsg) { var _options$fail, _options$complete2; var failOptions = new UniError("uni-openDialogPage", 4, "openDialogPage: fail, ".concat(errMsg)); (_options$fail = options.fail) === null || _options$fail === void 0 || _options$fail.call(options, failOptions); (_options$complete2 = options.complete) === null || _options$complete2 === void 0 || _options$complete2.call(options, failOptions); } function initAnimation(path, animationType) { if (!getCurrentPage()) { return ["none", 0]; } var { globalStyle } = __uniConfig; var meta = getRouteMeta(path); var _animationType = animationType || meta.animationType || globalStyle.animationType || ANI_SHOW; if (_animationType == "pop-in") { _animationType = "none"; } return [_animationType, meta.animationDuration || globalStyle.animationDuration || ANI_DURATION]; } function closePreActionSheet(dialogPages) { var actionSheets = dialogPages.filter((page) => isSystemActionSheetDialogPage(page)); if (actionSheets.length > 1) { setTimeout(() => { closeNativeDialogPage(actionSheets[0]); dialogPages.splice(dialogPages.indexOf(actionSheets[0]), 1); }, 150); } } var closeDialogPage = (options) => { var _options$success, _options$complete; var currentPages = getCurrentPages(); var currentPage = currentPages[currentPages.length - 1]; if (!currentPage) { triggerFailCallback(options, "currentPage is null"); return; } if ((options === null || options === void 0 ? void 0 : options.animationType) === "pop-out") { options.animationType = "none"; } if (options !== null && options !== void 0 && options.dialogPage) { var dialogPage = options === null || options === void 0 ? void 0 : options.dialogPage; if (!(dialogPage instanceof UniDialogPageImpl)) { triggerFailCallback(options, "dialogPage is not a valid page"); return; } var parentPage = dialogPage.getParentPage(); if (!isSystemDialogPage(dialogPage)) { if (parentPage && currentPages.indexOf(parentPage) !== -1) { var parentDialogPages = parentPage.getDialogPages(); var index2 = parentDialogPages.indexOf(dialogPage); parentDialogPages.splice(index2, 1); closeNativeDialogPage(dialogPage, (options === null || options === void 0 ? void 0 : options.animationType) || "none", (options === null || options === void 0 ? void 0 : options.animationDuration) || ANI_DURATION); if (index2 > 0 && index2 === parentDialogPages.length) { invokeHook(parentDialogPages[parentDialogPages.length - 1].$vm, ON_SHOW); } } else { triggerFailCallback(options, "dialogPage is not a valid page"); return; } } else { var systemDialogPages = parentPage.vm.$systemDialogPages; var _index = systemDialogPages.indexOf(dialogPage); systemDialogPages.splice(_index, 1); closeNativeDialogPage(dialogPage); return; } } else { var dialogPages = currentPage.getDialogPages(); for (var i = dialogPages.length - 1; i >= 0; i--) { closeNativeDialogPage(dialogPages[i], (options === null || options === void 0 ? void 0 : options.animationType) || "none", (options === null || options === void 0 ? void 0 : options.animationDuration) || ANI_DURATION); if (i > 0) { invokeHook(dialogPages[i - 1].$vm, ON_SHOW); } dialogPages[i] = null; } dialogPages.length = 0; } var successOptions = { errMsg: "closeDialogPage: ok" }; options === null || options === void 0 || (_options$success = options.success) === null || _options$success === void 0 || _options$success.call(options, successOptions); options === null || options === void 0 || (_options$complete = options.complete) === null || _options$complete === void 0 || _options$complete.call(options, successOptions); }; function triggerFailCallback(options, errMsg) { var _options$fail, _options$complete2; var failOptions = new UniError("uni-openDialogPage", 4, "openDialogPage: fail, ".concat(errMsg)); options === null || options === void 0 || (_options$fail = options.fail) === null || _options$fail === void 0 || _options$fail.call(options, failOptions); options === null || options === void 0 || (_options$complete2 = options.complete) === null || _options$complete2 === void 0 || _options$complete2.call(options, failOptions); } var setTabBarBadge = /* @__PURE__ */ defineAsyncApi(API_SET_TAB_BAR_BADGE, (_ref, _ref2) => { var { index: index2, text } = _ref; var { resolve, reject } = _ref2; var tabBar = getTabBar(); if (tabBar === null) { reject("tabBar is not exist"); return; } tabBar.setTabBarBadge(/* @__PURE__ */ new Map([["index", index2], ["text", text]])); resolve(); }, SetTabBarBadgeProtocol, SetTabBarBadgeOptions); var removeTabBarBadge = /* @__PURE__ */ defineAsyncApi(API_REMOVE_TAB_BAR_BADGE, (_ref, _ref2) => { var { index: index2 } = _ref; var { resolve, reject } = _ref2; var tabBar = getTabBar(); if (tabBar === null) { reject("tabBar is not exist"); return; } tabBar.removeTabBarBadge(/* @__PURE__ */ new Map([["index", index2]])); resolve(); }, RemoveTabBarBadgeProtocol, RemoveTabBarBadgeOptions); var setTabBarItem = /* @__PURE__ */ defineAsyncApi(API_SET_TAB_BAR_ITEM, (_ref, _ref2) => { var { index: index2, text, iconPath, selectedIconPath, pagePath, visible, iconfont } = _ref; var { resolve, reject } = _ref2; var tabBar = getTabBar(); if (tabBar === null) { reject("tabBar is not exist"); return; } var item = /* @__PURE__ */ new Map([["index", index2], ["text", text], ["iconPath", iconPath], ["selectedIconPath", selectedIconPath], ["pagePath", pagePath], ["visible", visible]]); if (!!iconfont) { var iconfontOptions = iconfont; var _iconfont = /* @__PURE__ */ new Map([["text", iconfontOptions.text], ["selectedText", iconfontOptions.selectedText], ["fontSize", iconfontOptions.fontSize], ["color", iconfontOptions.color], ["selectedColor", iconfontOptions.selectedColor]]); item.set("iconfont", _iconfont); } tabBar.setTabBarItem(item); resolve(); }, SetTabBarItemProtocol, SetTabBarItemOptions); var setTabBarStyle = /* @__PURE__ */ defineAsyncApi(API_SET_TAB_BAR_STYLE, (options, _ref) => { var { resolve, reject } = _ref; var tabBar = getTabBar(); if (tabBar === null) { reject("tabBar is not exist"); return; } var style = /* @__PURE__ */ new Map([["color", options.color], ["selectedColor", options.selectedColor], ["backgroundColor", options.backgroundColor], ["backgroundImage", options.backgroundImage], ["backgroundRepeat", options.backgroundRepeat], ["borderStyle", options.borderStyle], ["borderColor", options.borderColor]]); if (!!options.midButton) { var midButtonOptions = options.midButton; var midButton = /* @__PURE__ */ new Map([["width", midButtonOptions.width], ["height", midButtonOptions.height], ["iconPath", midButtonOptions.iconPath], ["text", midButtonOptions.text], ["iconPath", midButtonOptions.iconPath], ["iconWidth", midButtonOptions.iconWidth], ["backgroundImage", midButtonOptions.backgroundImage]]); if (!!midButtonOptions.iconfont) { var iconfontOptions = midButtonOptions.iconfont; var iconfont = /* @__PURE__ */ new Map([["text", iconfontOptions.text], ["selectedText", iconfontOptions.selectedText], ["fontSize", iconfontOptions.fontSize], ["color", iconfontOptions.color], ["selectedColor", iconfontOptions.selectedColor]]); midButton.set("iconfont", iconfont); } style.set("midButton", midButton); } fixBorderStyle(style); tabBar.setTabBarStyle(style); resolve(); }, SetTabBarStyleProtocol, SetTabBarStyleOptions); var hideTabBar = /* @__PURE__ */ defineAsyncApi(API_HIDE_TAB_BAR, (options, _ref) => { var { resolve, reject } = _ref; var tabBar = getTabBar(); if (tabBar === null) { reject("tabBar is not exist"); return; } tabBar.hideTabBar(/* @__PURE__ */ new Map([["animation", options === null || options === void 0 ? void 0 : options.animation]])); resolve(); }); var showTabBar = /* @__PURE__ */ defineAsyncApi(API_SHOW_TAB_BAR, (args, _ref) => { var { resolve, reject } = _ref; var tabBar = getTabBar(); var animation2 = args && args.animation; if (tabBar === null) { reject("tabBar is not exist"); return; } tabBar.showTabBar(/* @__PURE__ */ new Map([["animation", animation2]])); resolve(); }); var showTabBarRedDot = /* @__PURE__ */ defineAsyncApi(API_SHOW_TAB_BAR_RED_DOT, (_ref, _ref2) => { var { index: index2 } = _ref; var { resolve, reject } = _ref2; var tabBar = getTabBar(); if (tabBar === null) { reject("tabBar is not exist"); return; } tabBar.showTabBarRedDot(/* @__PURE__ */ new Map([["index", index2]])); resolve(); }, ShowTabBarRedDotProtocol, ShowTabBarRedDotOptions); var hideTabBarRedDot = /* @__PURE__ */ defineAsyncApi(API_HIDE_TAB_BAR_RED_DOT, (_ref, _ref2) => { var { index: index2 } = _ref; var { resolve, reject } = _ref2; var tabBar = getTabBar(); if (tabBar === null) { reject("tabBar is not exist"); return; } tabBar.hideTabBarRedDot(/* @__PURE__ */ new Map([["index", index2]])); resolve(); }, HideTabBarRedDotProtocol, HideTabBarRedDotOptions); var onTabBarMidButtonTap = (cb) => { onTabBarMidButtonTapCallback.push(cb); }; var setNavigationBarColor = /* @__PURE__ */ defineAsyncApi(API_SET_NAVIGATION_BAR_COLOR, (_ref, _ref2) => { var { frontColor, backgroundColor } = _ref; var { resolve, reject } = _ref2; var page = getCurrentPage(); if (!page) { return reject("getCurrentPages is empty"); } var appPage = page.vm.$nativePage; appPage.updateStyle(/* @__PURE__ */ new Map([["navigationBarTextStyle", frontColor == "#000000" ? "black" : "white"], ["navigationBarBackgroundColor", backgroundColor]])); resolve(); }, SetNavigationBarColorProtocol, SetNavigationBarColorOptions); var setNavigationBarTitle = /* @__PURE__ */ defineAsyncApi(API_SET_NAVIGATION_BAR_TITLE, (options, _ref) => { var { resolve, reject } = _ref; var page = getCurrentPage().vm; if (page == null) { reject("page is not ready"); return; } var appPage = page.$nativePage; appPage.updateStyle(/* @__PURE__ */ new Map([["navigationBarTitleText", options.title]])); resolve(); }); var getElementById = /* @__PURE__ */ defineSyncApi("getElementById", (id2) => { var _page$$el; var page = getCurrentPage().vm; if (page == null) { return null; } var bodyNode = (_page$$el = page.$el) === null || _page$$el === void 0 ? void 0 : _page$$el.parentNode; if (bodyNode == null) { console.warn("bodyNode is null"); return null; } return bodyNode.querySelector("#".concat(id2)); }); function isVueComponent(comp) { var has$instance = typeof comp.$ === "object"; var has$el = typeof comp.$el === "object"; return has$instance && has$el; } var isFunction = (val) => typeof val === "function"; class NodesRefImpl { constructor(selectorQuery, component, selector, single) { this._selectorQuery = selectorQuery; this._component = component; this._selector = selector; this._single = single; } boundingClientRect(callback) { var hasArg = callback === null || typeof callback === "function"; if (hasArg) { this._selectorQuery._push(this._selector, this._component, this._single, { id: true, dataset: true, rect: true, size: true }, callback); return this._selectorQuery; } else { return this.boundingClientRect(null); } } fields(fields, callback) { this._selectorQuery._push(this._selector, this._component, this._single, fields, callback); return this._selectorQuery; } scrollOffset(callback) { this._selectorQuery._push(this._selector, this._component, this._single, { id: true, dataset: true, scrollOffset: true }, callback); return this._selectorQuery; } context(callback) { this._selectorQuery._push(this._selector, this._component, this._single, { context: true }, callback); return this._selectorQuery; } /** * fields({node:true}) */ node(_callback) { this._selectorQuery._push(this._selector, this._component, this._single, { node: true }, _callback); return this._selectorQuery; } } class SelectorQueryImpl { constructor(component) { this._component = null; this._component = component; this._queue = []; this._queueCb = []; } exec(callback) { var _this$_component; (_this$_component = this._component) === null || _this$_component === void 0 || (_this$_component = _this$_component.$) === null || _this$_component === void 0 || _this$_component.$waitNativeRender(() => { requestComponentInfo(this._component, this._queue, (res) => { var queueCbs = this._queueCb; res.forEach((info, _index) => { var queueCb = queueCbs[_index]; if (isFunction(queueCb)) { queueCb(info); } }); if (callback && isFunction(callback)) { callback(res); } }); }); return this._nodesRef; } in(component) { if (isVueComponent(component)) { this._component = component; } return this; } select(selector) { this._nodesRef = new NodesRefImpl(this, this._component, selector, true); return this._nodesRef; } selectAll(selector) { this._nodesRef = new NodesRefImpl(this, this._component, selector, false); return this._nodesRef; } selectViewport() { this._nodesRef = new NodesRefImpl(this, null, "", true); return this._nodesRef; } _push(selector, component, single, fields, callback) { this._queue.push({ component, selector, single, fields }); this._queueCb.push(callback); } } class QuerySelectorHelper { constructor(element, vnode, fields) { this._element = element; this._commentStartVNode = vnode; this._fields = fields; } /** * entry */ static queryElement(element, selector, all, vnode, fields) { return new QuerySelectorHelper(element, vnode, fields).query(selector, all); } /** * 执行查询 * @param selector 选择器 * @param all 是否查询所有 selectAll * @returns */ query(selector, all) { if (this._element.nodeName == "#comment") { return this.queryFragment(this._element, selector, all); } else { return all ? this.querySelectorAll(this._element, selector) : this.querySelector(this._element, selector); } } queryFragment(el, selector, all) { var current = el.nextSibling; if (current == null) { return null; } if (all) { var result1 = []; while (true) { var queryResult = this.querySelectorAll(current, selector); if (queryResult != null) { result1.push(...queryResult); } current = current.nextSibling; if (current == null || this._commentStartVNode.anchor == current) { break; } } return result1; } else { var result2 = null; while (true) { result2 = this.querySelector(current, selector); current = current.nextSibling; if (result2 != null || current == null || this._commentStartVNode.anchor == current) { break; } } return result2; } } querySelector(element, selector) { var element2 = this.querySelf(element, selector); if (element2 == null) { element2 = element.querySelector(selector); } if (element2 != null) { return this.getNodeInfo(element2); } return null; } querySelectorAll(element, selector) { var nodesInfoArray = []; var element2 = this.querySelf(element, selector); if (element2 != null) { nodesInfoArray.push(this.getNodeInfo(element)); } var findNodes = element.querySelectorAll(selector); findNodes === null || findNodes === void 0 || findNodes.forEach((el) => { nodesInfoArray.push(this.getNodeInfo(el)); }); return nodesInfoArray; } querySelf(element, selector) { if (element == null || selector.length < 2) { return null; } var selectorType = selector.charAt(0); var selectorName = selector.slice(1); if (selectorType == "." && element.classList.includes(selectorName)) { return element; } if (selectorType == "#" && element.getAttribute("id") == selectorName) { return element; } if (selector.toUpperCase() == element.nodeName.toUpperCase()) { return element; } return null; } /** * 查询元素信息 * @param element * @returns */ getNodeInfo(element) { var _element$getAttribute; if (this._fields.node == true) { var nodeInfo2 = { node: element }; if (this._fields.size == true) { var rect2 = element.getBoundingClientRect(); nodeInfo2.width = rect2.width; nodeInfo2.height = rect2.height; } return nodeInfo2; } var rect = element.getBoundingClientRect(); var nodeInfo = { id: (_element$getAttribute = element.getAttribute("id")) === null || _element$getAttribute === void 0 ? void 0 : _element$getAttribute.toString(), dataset: null, left: rect.left, top: rect.top, right: rect.right, bottom: rect.bottom, width: rect.width, height: rect.height }; return nodeInfo; } } function requestComponentInfo(vueComponent, queue2, callback) { var result = []; var el = vueComponent === null || vueComponent === void 0 ? void 0 : vueComponent.$el; if (el != null) { queue2.forEach((item) => { var queryResult = QuerySelectorHelper.queryElement(el, item.selector, !item.single, vueComponent === null || vueComponent === void 0 ? void 0 : vueComponent.$.subTree, item.fields); if (queryResult != null) { result.push(queryResult); } }); } callback(result); } var createSelectorQuery = function() { var instance = getCurrentPage().vm; return new SelectorQueryImpl(instance); }; class CanvasContextImpl { constructor(element) { this._element = element; } // @ts-expect-error 类型不匹配 getContext(contextType) { return this._element.getContext(contextType); } toBlob(callback, type, quality) { throw new Error("Method not implemented."); } toDataURL(type, quality) { return this._element.toDataURL(type, quality); } createImage() { return new Image(); } createPath2D() { return new Path2D(); } requestAnimationFrame(callback) { return requestAnimationFrame(callback); } cancelAnimationFrame(taskId) { cancelAnimationFrame(taskId); } } var createCanvasContextAsync = /* @__PURE__ */ defineAsyncApi("createCanvasContextAsync", (options, _ref) => { var _options$component; var { resolve, reject } = _ref; var page = getCurrentPage().vm; if (page == null) { return null; } createSelectorQuery().in((_options$component = options.component) !== null && _options$component !== void 0 ? _options$component : null).select("#" + options.id).fields({ node: true }, (ret) => { var node = ret.node; if (node != null) { resolve(new CanvasContextImpl(node)); } else { var uniError = new UniError("uni-createCanvasContextAsync", -1, "canvas id invalid."); reject(uniError.errMsg); } }).exec(); }); function queryElementTop(component, selector) { var _component$$el; var scrollNode = (_component$$el = component.$el) === null || _component$$el === void 0 ? void 0 : _component$$el.querySelector(selector); if (scrollNode != null) { return scrollNode.getBoundingClientRect().top; } return null; } var pageScrollTo = /* @__PURE__ */ defineAsyncApi(API_PAGE_SCROLL_TO, (options, res) => { var currentPage = getCurrentPage().vm; var scrollViewNode = currentPage === null || currentPage === void 0 ? void 0 : currentPage.$el; if (scrollViewNode == null || scrollViewNode.tagName != "SCROLL-VIEW") { res.reject("selector invalid"); return; } var top = options.scrollTop; if (!!options.selector) { top = queryElementTop(currentPage, options.selector); if (top != null) { var currentScrollTop = scrollViewNode.scrollTop; top += currentScrollTop; } } if (top == null || top < 0) { res.reject("top or selector invalid"); return; } if (options.offsetTop != null) { top += options.offsetTop; } scrollViewNode.scrollTop = top; res.resolve(); }, PageScrollToProtocol, PageScrollToOptions); var SOURCE_REG = /(.+\.((ttf)|(otf)|(woff2?))$)|(^(http|https):\/\/.+)|(^(data:font).+)/; function removeUrlWrap(source) { if (source.startsWith("url(")) { if (source.split("format(").length > 1) { source = source.split("format(")[0].trim(); } source = source.substring(4, source.length - 1); } if (source.startsWith('"') || source.startsWith("'")) { source = source.substring(1, source.length - 1); } return source; } function checkOptionSource(options, res) { options.source = removeUrlWrap(options.source); if (!SOURCE_REG.test(options.source)) { res.reject("loadFontFace:fail, source is invalid.", 101); return false; } return true; } function getLoadFontFaceOptions(options, res) { return { family: options.family, source: options.source, success: (_) => { res.resolve(null); }, fail: (error) => { res.reject( // new LoadFontFaceErrorImpl( error.errMsg, error.errCode // ) ); } }; } var loadFontFace = /* @__PURE__ */ defineAsyncApi(API_LOAD_FONT_FACE, (options, res) => { if (options.global === true) { if (checkOptionSource(options, res)) { var app = getNativeApp(); var fontInfo = getLoadFontFaceOptions(options, res); app.loadFontFace(fontInfo); } } else { var page = getCurrentPage().vm; if (!page) { res.reject("page is not ready", 99); return; } if (page.$fontFamilySet.has(options.family)) { return; } if (checkOptionSource(options, res)) { page.$fontFamilySet.add(options.family); var _fontInfo = getLoadFontFaceOptions(options, res); page.$nativePage.loadFontFace(_fontInfo); } } }); var startPullDownRefresh = /* @__PURE__ */ defineAsyncApi(API_START_PULL_DOWN_REFRESH, (_options, res) => { var page = getCurrentPage().vm; if (page === null) { res.reject("page is not ready"); return; } page.$nativePage.startPullDownRefresh({ success: res.resolve, fail: res.reject }); }); var stopPullDownRefresh = /* @__PURE__ */ defineAsyncApi(API_STOP_PULL_DOWN_REFRESH, (_args, res) => { var page = getCurrentPage().vm; if (page === null) { res.reject("page is not ready"); return; } page.$nativePage.stopPullDownRefresh(); res.resolve(); }); var defaultPoi = { latitude: 39.908823, longitude: 116.39747 }; var languageData = { "en": { "back": "cancel", "ok": "ok", "cancel": "cancel", "loading": "loading...", "locationLoading": "positioning...", "search": "Search location", "current-location": "current location" }, "zh-Hans": { "back": "取消", "ok": "确定", "cancel": "取消", "loading": "请求中...", "locationLoading": "获取定位中...", "search": "搜索地点", "current-location": "当前位置" }, "zh-Hant": { "back": "取消", "ok": "確定", "cancel": "取消", "loading": "請求中...", "locationLoading": "獲取定位中...", "search": "蒐索地點", "current-location": "當前位置" } }; var loadingPath = ""; const _sfc_main = { data() { var id1 = "UniMap1_".concat((Math.random() * 1e6).toString(36)); var id2 = "UniMap2_".concat((Math.random() * 1e6).toString(36)); var id3 = "UniMap3_".concat((Math.random() * 1e6).toString(36)); return { readyEventName: "", optionsEventName: "", successEventName: "", failEventName: "", mapId: id1, mapTargetId: id2, scrollId: id3, isFocus: false, latitude: 0, longitude: 0, locationComplete: false, locationLoading: false, chooseLocationOptions: {}, pageIndex: 1, pageSize: 20, pois: [], selected: -1, searchValue: "", safeArea: { top: 0, bottom: 0, left: 0, right: 0 }, icon: { target: "", success: "", position: "", search: "" }, lastTime: 0, searchLoading: false, language: "zh-Hans", scrollTop: 0, isLandscape: false, theme: "light", searchValueChangeTimer: -1, lastPoi: { latitude: null, longitude: null, selected: -1, pois: [], scrollTop: 0 }, errMsg: "", callUniMapCoErr: false, useUniCloud: true, loadingPath, mapHeight: 350 }; }, onLoad(options) { this.checkUniCloud(); this.initPageOptions(options); this.getSystemInfo(); this.getLocation(); }, onReady() { }, onUnload() { uni.$off(this.optionsEventName, null); uni.$off(this.readyEventName, null); uni.$off(this.successEventName, null); uni.$off(this.failEventName, null); }, onResize() { this.getSystemInfo(); }, methods: { checkUniCloud() { if (typeof uniCloud == "undefined") { this.errMsg = "uni.chooseLocation 依赖 uniCloud 的 uni-map-common 插件,请先关联服务空间,并安装 uni-map-common 插件,插件地址:https://ext.dcloud.net.cn/plugin?id=13872"; this.useUniCloud = false; console.error(this.errMsg); } }, initPageOptions(options) { this.readyEventName = options["readyEventName"]; this.optionsEventName = options["optionsEventName"]; this.successEventName = options["successEventName"]; this.failEventName = options["failEventName"]; uni.$on(this.optionsEventName, (data) => { if (data["latitude"] != null) { this.chooseLocationOptions.latitude = data["latitude"]; } if (data["longitude"] != null) { this.chooseLocationOptions.longitude = data["longitude"]; } if (data["keyword"] != null) { var keyword = data["keyword"]; this.chooseLocationOptions.keyword = keyword; this.searchValue = keyword; } else { this.chooseLocationOptions.keyword = ""; } if (data["payload"] != null) { this.chooseLocationOptions.payload = data["payload"]; } }); uni.$emit(this.readyEventName, {}); }, getLocation() { if (this.chooseLocationOptions.latitude != null && this.chooseLocationOptions.longitude != null) { this.latitude = this.chooseLocationOptions.latitude; this.longitude = this.chooseLocationOptions.longitude; this.locationComplete = true; this.getPoi("getLocation"); } else { this.locationLoading = true; uni.getLocation({ type: "gcj02", success: (res) => { this.latitude = res.latitude; this.longitude = res.longitude; this.locationComplete = true; this.locationLoading = false; this.getPoi("getLocation"); }, fail: (err) => { console.error("getLocationErr: ", err); this.latitude = defaultPoi.latitude; this.longitude = defaultPoi.longitude; this.locationComplete = true; this.locationLoading = false; this.getPoi("getLocation"); } }); } }, distanceHandle(distance) { if (distance < 1e3) { return distance + "m"; } else { return parseFloat((distance / 1e3).toFixed(2)) + "km"; } }, poiHandle(pois) { var list = pois.map((item, index2) => { var location = item["location"]; var distance = item["distance"]; var latitude = location["lat"]; var longitude = location["lng"]; if (distance == 0) { latitude = this.latitude; longitude = this.longitude; } return { title: item["title"], address: item["address"], distance, distanceStr: this.distanceHandle(distance), location: { latitude, longitude } }; }); var pageIndex = this.pageIndex; if (pageIndex == 1) { this.pois = list; this.updateScrollTop(0); } else { this.pois = this.pois.concat(list); } }, callUniMapCo(action, data) { var promise = new Promise((resolve, reject) => { if (this.useUniCloud == false) { reject(this.errMsg); return; } this.errMsg = ""; var uniMapCo = uniCloud.importObject("uni-map-co", { customUI: true }); var chooseLocationData = { action, data }; if (this.chooseLocationOptions.payload != null) { chooseLocationData["payload"] = this.chooseLocationOptions.payload; } uniMapCo.chooseLocation(chooseLocationData).then((res) => { resolve(res); }).catch((err) => { if (err instanceof UniCloudError) { var cloudError = err; var errCode = cloudError.errCode; var errMsg = cloudError.errMsg; var errSubject = cloudError.errSubject; if (errMsg.indexOf("在云端不存在") > -1 || errMsg.indexOf("未匹配") > -1) { this.errMsg = "uni.chooseLocation 依赖 uniCloud 的 uni-map-common 插件,请安装 uni-map-common 插件,插件地址:https://ext.dcloud.net.cn/plugin?id=13872"; console.error(this.errMsg); } else { this.errMsg = errMsg; console.error("获取POI信息失败," + JSON.stringify({ errCode, errMsg, errSubject })); } } reject(err); }); }); promise.then((res) => { this.callUniMapCoErr = false; }).catch((err) => { this.callUniMapCoErr = true; }); return promise; }, getPoi(type) { var searchValue = this.searchValue; var latitude = this.latitude; var longitude = this.longitude; var pageIndex = this.pageIndex; var pageSize = this.pageSize; if (["searchValueChange"].indexOf(type) == -1) { this.searchLoading = true; } if (searchValue != "" && searchValue.length > 0) { this.callUniMapCo("search", { keyword: searchValue, location: { lat: latitude, lng: longitude }, radius: 5e3, auto_extend: 1, orderby: "weight", page_index: pageIndex, page_size: pageSize }).then((res) => { var _res$getJSON; var pois = (_res$getJSON = res.getJSON("result")) === null || _res$getJSON === void 0 || (_res$getJSON = _res$getJSON.getJSON("result")) === null || _res$getJSON === void 0 ? void 0 : _res$getJSON.getArray("data"); this.poiHandle(pois); this.searchLoading = false; }).catch((err) => { this.searchLoading = false; }); } else { this.callUniMapCo("location2address", { location: "".concat(latitude, ",").concat(longitude), get_poi: 1, poi_options: { radius: 3e3, policy: pageIndex == 1 ? 3 : 4, roadlevel: 1, homeorcorp: 1, page_index: pageIndex, page_size: pageSize } }).then((res) => { var _res$getJSON2; var pois = (_res$getJSON2 = res.getJSON("result")) === null || _res$getJSON2 === void 0 || (_res$getJSON2 = _res$getJSON2.getJSON("result")) === null || _res$getJSON2 === void 0 ? void 0 : _res$getJSON2.getArray("pois"); this.poiHandle(pois); if (this.pois.length > 0 && pageIndex == 1) { var poi = this.pois[0]; if (poi.distance > 0) { var poi1 = poi.location; var poi2 = { latitude: this.latitude, longitude: this.longitude }; var distance = poi.distance; var direction = this.calcDirection(poi1, poi2); if (poi.address.indexOf("米") == -1) { var suffix = "向".concat(direction).concat(distance, "米"); var newPoi = { title: "".concat(poi.title).concat(suffix), address: "".concat(poi.address).concat(suffix), distance: 0, distanceStr: this.distanceHandle(distance), location: poi2 }; this.pois.unshift(newPoi); } } if (this.selected == -1) { this.selected = 0; this.lastPoi.latitude = this.latitude; this.lastPoi.longitude = this.longitude; this.lastPoi.selected = this.selected; this.lastPoi.pois = this.pois; } } this.searchLoading = false; }).catch((err) => { this.searchLoading = false; }); } }, calcDirection(poi1, poi2) { var toRadians = (angle2) => angle2 * (Math.PI / 180); var toDegrees = (angle2) => angle2 * (180 / Math.PI); var lat1 = toRadians(poi1.latitude); var lon1 = toRadians(poi1.longitude); var lat2 = toRadians(poi2.latitude); var lon2 = toRadians(poi2.longitude); var dLon = lon2 - lon1; var y = Math.sin(dLon) * Math.cos(lat2); var x = Math.cos(lat1) * Math.sin(lat2) - Math.sin(lat1) * Math.cos(lat2) * Math.cos(dLon); var angleRadians = Math.atan2(y, x); var angle = toDegrees(angleRadians); angle = (angle + 360) % 360; if (angle < 22.5 || angle >= 337.5) { return "北"; } else if (angle >= 22.5 && angle < 67.5) { return "东北"; } else if (angle >= 67.5 && angle < 112.5) { return "东"; } else if (angle >= 112.5 && angle < 157.5) { return "东南"; } else if (angle >= 157.5 && angle < 202.5) { return "南"; } else if (angle >= 202.5 && angle < 247.5) { return "西南"; } else if (angle >= 247.5 && angle < 292.5) { return "西"; } else { return "西北"; } }, getSystemInfo() { var info = uni.getWindowInfo(); this.safeArea.top = info.safeAreaInsets.top; this.safeArea.bottom = info.safeAreaInsets.bottom; this.safeArea.left = info.safeAreaInsets.left; this.safeArea.right = info.safeAreaInsets.right; var screenHeight = info.screenHeight; this.mapHeight = (screenHeight - this.safeArea.top - this.safeArea.bottom) * 0.6; var systemInfo = uni.getSystemInfoSync(); var appLanguage = systemInfo.appLanguage; this.language = appLanguage; var osTheme = systemInfo.osTheme; var appTheme = systemInfo.appTheme; if (appTheme != null && appTheme != "auto") { this.theme = appTheme; } else if (osTheme != null) { this.theme = osTheme; } this.isLandscape = systemInfo.deviceOrientation == "landscape"; }, getMapContext() { return uni.createMapContext(this.mapId, this); }, regionchange(e) { var causedBy = e.causedBy; if (e.type !== "end" || causedBy != "drag" || this.locationComplete == false) { return; } var mapContext = this.getMapContext(); if (mapContext != null) { mapContext.getCenterLocation({ success: (res) => { var latitudeDiff = Math.abs(res.latitude - this.latitude); var longitudeDiff = Math.abs(res.longitude - this.longitude); if (latitudeDiff > 1e-6 || longitudeDiff > 1e-6) { this.latitude = parseFloat(res.latitude.toFixed(6)); this.longitude = parseFloat(res.longitude.toFixed(6)); this.searchValue = ""; this.selected = -1; this.pageIndex = 1; this.getPoi("regionchange"); var element = this.$refs[this.mapTargetId]; if (element != null) { var duration = 250; element.style.setProperty("transition-duration", "".concat(duration, "ms")); element.style.setProperty("transform", "translateY(0px)"); element.style.setProperty("transform", "translateY(-15px)"); setTimeout(() => { element.style.setProperty("transform", "translateY(0px)"); }, duration); } } } }); } }, clearSearchValueChangeTimer() { if (this.searchValueChangeTimer != -1) { clearTimeout(this.searchValueChangeTimer); this.searchValueChangeTimer = -1; } }, searchValueChange(e) { this.clearSearchValueChangeTimer(); this.searchValueChangeTimer = setTimeout(() => { this.poiSearch("searchValueChange"); }, 200); }, poiSearch(type) { this.clearSearchValueChangeTimer(); this.pageIndex = 1; this.selected = -1; this.getPoi(type); }, cancelSearch() { this.isFocus = false; this.searchValue = ""; if (this.lastPoi.latitude != null) { this.latitude = this.lastPoi.latitude; } if (this.lastPoi.longitude != null) { this.longitude = this.lastPoi.longitude; } if (this.lastPoi.pois.length - 1 > this.lastPoi.selected) { this.pois = this.lastPoi.pois; this.selected = this.lastPoi.selected; this.updateScrollTop(this.lastPoi.scrollTop); } else { this.poiSearch("cancelSearch"); } }, updateScrollTop(scrollTop) { setTimeout(() => { this.scrollTop = scrollTop; }, 10); }, selectPoi(item, index2) { this.isFocus = false; this.selected = index2; this.latitude = item.location.latitude; this.longitude = item.location.longitude; if (this.searchValue == this.chooseLocationOptions.keyword) { this.lastPoi.latitude = this.latitude; this.lastPoi.longitude = this.longitude; this.lastPoi.selected = this.selected; this.lastPoi.pois = this.pois; var scrollElement = this.$refs[this.scrollId]; if (scrollElement != null) { var scrollTop = scrollElement.scrollTop; this.lastPoi.scrollTop = scrollTop; this.scrollTop = scrollTop; } } }, scrolltolower() { this.pageIndex++; this.getPoi("scrolltolower"); }, mapReset() { this.isFocus = false; this.pageIndex = 1; this.getLocation(); }, closeDialogPage() { uni.closeDialogPage({ dialogPage: this.$page }); }, back() { uni.$emit(this.failEventName, 1); this.closeDialogPage(); }, confirm() { if (this.selected < 0) { if (this.callUniMapCoErr) { uni.$emit(this.successEventName, { name: "", address: "", latitude: parseFloat(this.latitude.toFixed(6)), longitude: parseFloat(this.longitude.toFixed(6)) }); this.closeDialogPage(); } return; } var item = this.pois[this.selected]; var res = { name: item.title, address: item.address, latitude: item.location.latitude, longitude: item.location.longitude }; uni.$emit(this.successEventName, res); this.closeDialogPage(); } }, computed: { languageCom() { var textInfo = languageData[this.language] != null ? languageData[this.language] : languageData["zh-Hans"]; return textInfo; }, uniChooseLocationClassCom() { var list = []; if (this.theme == "dark") { list.push("uni-choose-location-dark"); } else { list.push("uni-choose-location-light"); } return list.join(" "); }, landscapeClassCom() { return this.isLandscape ? "uni-choose-location-landscape" : "uni-choose-location-vertical"; }, mapBoxStyleCom() { var list = []; if (!this.useUniCloud) { list.push("flex: 1;"); } if (!this.isLandscape) { var top = this.isFocus ? (300 - this.mapHeight) / 2 : 0; list.push("transform:translateY(".concat(top, "px);")); list.push("height:".concat(this.mapHeight, "px;")); } return list.join(""); }, poiBoxStyleCom() { var list = []; if (!this.isLandscape) { var top = this.isFocus ? 300 : this.mapHeight; list.push("top:".concat(top, "px;")); } return list.join(""); }, resetStyleCom() { var list = []; if (!this.isLandscape) { var bottom = this.isFocus ? (this.mapHeight - 300) / 2 + 300 - this.mapHeight : 0; list.push("transform:translateY(".concat(bottom, "px);")); } return list.join(""); } } }; const _style_0 = { "uni-choose-location-icons": { "": { "fontFamily": "UniChooseLocationFontFamily", "fontSize": 16, "fontStyle": "normal" } }, "uni-choose-location": { "": { "position": "relative", "left": 0, "top": 0, "width": "100%", "height": "100%", "backgroundImage": "none", "backgroundColor": "#f8f8f8", "zIndex": 999 } }, "uni-choose-location-map-box": { "": { "position": "relative", "width": "100%", "height": 350 }, ".uni-choose-location-vertical": { "transitionProperty": "transform", "transitionDuration": "0.25s", "transitionTimingFunction": "ease-out" }, ".uni-choose-location .uni-choose-location-landscape": { "height": "100%" } }, "uni-choose-location-map": { "": { "width": "100%", "height": "100%" } }, "uni-choose-location-map-target": { "": { "position": "absolute", "left": "50%", "bottom": "50%", "width": 50, "height": 50, "marginLeft": -25, "transitionProperty": "transform", "transitionDuration": "0.25s", "transitionTimingFunction": "ease-out" } }, "uni-choose-location-map-target-icon": { "": { "fontSize": 50, "color": "#f0493e" } }, "uni-choose-location-map-reset": { "": { "position": "absolute", "left": 20, "bottom": 40, "width": 40, "height": 40, "boxSizing": "border-box", "backgroundColor": "#ffffff", "borderRadius": 20, "pointerEvents": "auto", "boxShadow": "0px 0px 20px 2px rgba(0, 0, 0, .3)", "zIndex": 9, "display": "flex", "justifyContent": "center", "alignItems": "center" }, ".uni-choose-location-vertical": { "transitionProperty": "transform", "transitionDuration": "0.25s", "transitionTimingFunction": "ease-out" }, ".uni-choose-location .uni-choose-location-landscape": { "left": 40, "bottom": 40 }, ".uni-choose-location-dark ": { "backgroundColor": "#111111", "boxShadow": "0px 0px 5px 1px rgba(0, 0, 0, .3)" } }, "uni-choose-location-map-reset-icon": { "": { "fontSize": 26, "textAlign": "center", "lineHeight": "40px" }, ".uni-choose-location-dark ": { "color": "#d1d1d1" } }, "uni-choose-location-nav": { "": { "position": "absolute", "top": 0, "left": 0, "width": "100%", "height": 60, "backgroundColor": "rgba(0,0,0,0)", "backgroundImage": "linear-gradient(to bottom, rgba(0, 0, 0, .6), rgba(0, 0, 0, 0))" } }, "uni-choose-location-nav-btn": { "": { "position": "absolute", "top": 5, "left": 5, "width": 64, "height": 44, "paddingTop": 5, "paddingRight": 5, "paddingBottom": 5, "paddingLeft": 5 }, ".uni-choose-location-nav-confirm-btn": { "left": "auto", "right": 5 }, ".uni-choose-location-nav-confirm-btn.active:active": { "opacity": 0.7 }, ".uni-choose-location-nav-confirm-btn.disable": { "opacity": 0.4 }, ".uni-choose-location .uni-choose-location-landscape": { "top": 10, "left": 20 }, ".uni-choose-location .uni-choose-location-nav-confirm-btn.uni-choose-location-landscape": { "left": "auto", "right": 20 } }, "uni-choose-location-nav-confirm-text": { ".uni-choose-location-nav-btn.uni-choose-location-nav-confirm-btn ": { "backgroundColor": "#007aff", "borderRadius": 5 } }, "uni-choose-location-nav-back-text": { ".uni-choose-location-nav-btn.uni-choose-location-nav-back-btn ": { "color": "#ffffff" } }, "uni-choose-location-nav-text": { "": { "paddingTop": 8, "paddingRight": 0, "paddingBottom": 8, "paddingLeft": 0, "fontSize": 14, "textAlign": "center", "color": "#ffffff" } }, "uni-choose-location-poi": { "": { "position": "absolute", "top": 350, "width": "100%", "bottom": 0, "backgroundColor": "#ffffff", "zIndex": 10 }, ".uni-choose-location-vertical": { "transitionProperty": "top", "transitionDuration": "0.25s", "transitionTimingFunction": "ease-out" }, ".uni-choose-location .uni-choose-location-landscape": { "position": "absolute", "top": 80, "right": 25, "width": 300, "bottom": 20, "maxHeight": 600, "boxShadow": "0px 0px 20px 2px rgba(0, 0, 0, .3)", "borderRadius": 5 }, ".uni-choose-location-dark ": { "backgroundColor": "#181818" } }, "uni-choose-location-poi-search": { "": { "display": "flex", "flexDirection": "row", "alignItems": "center", "justifyContent": "center", "height": 50, "paddingTop": 8, "paddingRight": 8, "paddingBottom": 8, "paddingLeft": 8, "backgroundColor": "#ffffff" }, ".uni-choose-location-dark ": { "backgroundColor": "#181818" } }, "uni-choose-location-poi-search-box": { "": { "display": "flex", "flexDirection": "row", "alignItems": "center", "justifyContent": "center", "height": 32, "flex": 1, "borderRadius": 5, "paddingTop": 0, "paddingRight": 15, "paddingBottom": 0, "paddingLeft": 15, "backgroundColor": "#ededed" }, ".uni-choose-location-dark ": { "backgroundColor": "#111111" } }, "uni-choose-location-poi-search-input": { "": { "flex": 1, "height": "100%", "borderRadius": 5, "paddingTop": 0, "paddingRight": 5, "paddingBottom": 0, "paddingLeft": 5, "backgroundImage": "none", "backgroundColor": "#ededed" }, ".uni-choose-location-dark ": { "backgroundImage": "none", "backgroundColor": "#111111", "color": "#d1d1d1" } }, "uni-choose-location-poi-search-cancel": { "": { "marginLeft": 5, "color": "#007aff", "fontSize": 15, "textAlign": "center" } }, "uni-choose-location-poi-list": { "": { "flex": 1 } }, "uni-choose-location-poi-search-loading": { "": { "display": "flex", "alignItems": "center", "paddingTop": 10, "paddingRight": 0, "paddingBottom": 10, "paddingLeft": 0 } }, "uni-choose-location-poi-search-loading-text": { "": { "color": "#191919" }, ".uni-choose-location-dark ": { "color": "#d1d1d1" } }, "uni-choose-location-poi-search-error": { "": { "display": "flex", "alignItems": "center", "paddingTop": 10, "paddingRight": 10, "paddingBottom": 10, "paddingLeft": 10 } }, "uni-choose-location-poi-search-error-text": { "": { "color": "#191919", "fontSize": 14 } }, "uni-choose-location-poi-item": { "": { "position": "relative", "paddingTop": 15, "paddingRight": 40, "paddingBottom": 15, "paddingLeft": 10 }, ".uni-choose-location .uni-choose-location-landscape": { "paddingTop": 10, "paddingRight": 10, "paddingBottom": 10, "paddingLeft": 10 } }, "uni-choose-location-poi-item-title-text": { "": { "fontSize": 14, "overflow": "hidden", "whiteSpace": "nowrap", "textOverflow": "ellipsis", "color": "#191919" }, ".uni-choose-location-dark ": { "color": "#d1d1d1" } }, "uni-choose-location-poi-item-detail-text": { "": { "fontSize": 12, "marginTop": 5, "color": "#b2b2b2", "overflow": "hidden", "whiteSpace": "nowrap", "textOverflow": "ellipsis" }, ".uni-choose-location-dark ": { "color": "#595959" } }, "uni-choose-location-poi-item-selected-icon": { "": { "position": "absolute", "top": "50%", "right": 10, "width": 26, "height": 26, "marginTop": -13, "color": "#007aff", "fontSize": 24 } }, "uni-choose-location-poi-item-after": { "": { "position": "absolute", "height": 1, "left": 10, "bottom": 0, "right": 10, "width": "auto", "borderBottomWidth": 1, "borderBottomStyle": "solid", "borderBottomColor": "#f8f8f8" }, ".uni-choose-location-dark ": { "borderBottomWidth": 1, "borderBottomStyle": "solid", "borderBottomColor": "#1e1e1e" } }, "uni-choose-location-search-icon": { "": { "color": "#808080", "paddingLeft": 5 }, ".uni-choose-location-dark ": { "color": "#d1d1d1" } }, "uni-choose-location-poi-search-loading-image": { "": { "width": 30, "height": 30 } }, "@FONT-FACE": [{ "fontFamily": "UniChooseLocationFontFamily", "src": "url('data:font/ttf;charset=utf-8;base64,AAEAAAALAIAAAwAwR1NVQiCLJXoAAAE4AAAAVE9TLzI8Rkp9AAABjAAAAGBjbWFw0euemwAAAgAAAAGyZ2x5ZuUB/iAAAAPAAAACsGhlYWQp23fyAAAA4AAAADZoaGVhB94DhgAAALwAAAAkaG10eBQAAAAAAAHsAAAAFGxvY2EBUAG+AAADtAAAAAxtYXhwARIAfQAAARgAAAAgbmFtZUTMSfwAAAZwAAADS3Bvc3RLRtf0AAAJvAAAAFIAAQAAA4D/gABcBAAAAAAABAAAAQAAAAAAAAAAAAAAAAAAAAUAAQAAAAEAAIZo1N5fDzz1AAsEAAAAAADjXhn6AAAAAONeGfoAAP+ABAADgQAAAAgAAgAAAAAAAAABAAAABQBxAAMAAAAAAAIAAAAKAAoAAAD/AAAAAAAAAAEAAAAKADAAPgACREZMVAAObGF0bgAaAAQAAAAAAAAAAQAAAAQAAAAAAAAAAQAAAAFsaWdhAAgAAAABAAAAAQAEAAQAAAABAAgAAQAGAAAAAQAAAAQEAAGQAAUAAAKJAswAAACPAokCzAAAAesAMgEIAAACAAUDAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFBmRWQAwOYx560DgP+AAAAD3ACAAAAAAQAAAAAAAAAAAAAAAAACBAAAAAQAAAAEAAAABAAAAAQAAAAAAAAFAAAAAwAAACwAAAAEAAABcgABAAAAAABsAAMAAQAAACwAAwAKAAABcgAEAEAAAAAKAAgAAgAC5jHmU+aD563//wAA5jHmU+aD563//wAAAAAAAAAAAAEACgAKAAoACgAAAAIAAwAEAAEAAAEGAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAwAAAAAAEAAAAAAAAAABAAA5jEAAOYxAAAAAgAA5lMAAOZTAAAAAwAA5oMAAOaDAAAABAAA560AAOetAAAAAQAAAAAAAABIAGYBCAFYAAIAAP/SA4cDNgAdACoAACUGBwYnLgEnJjc+ATc2Fx4BFxYHBgcXHgEOAiYnJTI+ATQuASIOARQeAQJlSFdVT1FsDQwdHodWU1JTeBQUFhc+7AUFBAsPEAX+T0uASkqAln9LS3/MMwkIICKLV1RQUnMQEBoagVZTUlU+7AYPDwsEBAbrSoCWf0tLf5aASgAAAAEAAAAAA8ACyAANAAATNwU3Njc2NxcHBgcGB0A5AQdAVGaPnxdXbWuWfAGPN986TFl8hTpVbG6aiQAAAAMAAP+ABAADgQAzAGcAcAAAAQYHBgcGBxUUBi4BPQEmJyYnJicjIiY+ATsBNjc2NzY3NTQ2MhYdARYXFhcWFzM2HgEGKwIiJj4BOwEmJyYnJicVFAYiJj0BBgcGBwYHMzYeAQYrARYXFhcWFzU0Nh4BHQE2NzY3NiUiJjQ2MhYUBgOyBjk3WlxtDxUPbF1aNzgGNAsPAQ4LNAY4N1pdbA8VD21cWjc5BjMLDwEPC2eaCg8BDgqaBjIwT1BfDxUPXlFOMTEGmAsPAQ8LmQYxMU5RXhAVDl9QTzAy/ocWHR0rHh4BZmxdWjc4BzMLDwEOCzMHODdaXWwQFA9tXFo3OQY0ChAOCzUGOTdaXG0BDxUQEBQPX1BPMDEHmQsODwqZBzEwT1BfAQ8VEF5RTjExBpgLDwEOC5gGMTFOUUUdKx4eKx0AAAMAAP+BAyoDfgAIACYAMwAABRQWMjY0JiIGExEUBisBIiY1ES4BJyY1NDc2NzYyFxYXFhUUBw4BAwYeAj4BNC4CDgEBwCU1JiY1JWoGBEAEB0d1ISIpJ0RFokVEJykiIXX9AiRATEImJT9KQCdUEhkZIxkZAXH+iAQGBgQBeApTP0FJUUVEJykpJ0RFUUlBP1MBIiZDJwImQks/JQEjPQAAABIA3gABAAAAAAAAABMAAAABAAAAAAABABsAEwABAAAAAAACAAcALgABAAAAAAADABsANQABAAAAAAAEABsAUAABAAAAAAAFAAsAawABAAAAAAAGABsAdgABAAAAAAAKACsAkQABAAAAAAALABMAvAADAAEECQAAACYAzwADAAEECQABADYA9QADAAEECQACAA4BKwADAAEECQADADYBOQADAAEECQAEADYBbwADAAEECQAFABYBpQADAAEECQAGADYBuwADAAEECQAKAFYB8QADAAEECQALACYCR0NyZWF0ZWQgYnkgaWNvbmZvbnRVbmlDaG9vc2VMb2NhdGlvbkZvbnRGYW1pbHlSZWd1bGFyVW5pQ2hvb3NlTG9jYXRpb25Gb250RmFtaWx5VW5pQ2hvb3NlTG9jYXRpb25Gb250RmFtaWx5VmVyc2lvbiAxLjBVbmlDaG9vc2VMb2NhdGlvbkZvbnRGYW1pbHlHZW5lcmF0ZWQgYnkgc3ZnMnR0ZiBmcm9tIEZvbnRlbGxvIHByb2plY3QuaHR0cDovL2ZvbnRlbGxvLmNvbQBDAHIAZQBhAHQAZQBkACAAYgB5ACAAaQBjAG8AbgBmAG8AbgB0AFUAbgBpAEMAaABvAG8AcwBlAEwAbwBjAGEAdABpAG8AbgBGAG8AbgB0AEYAYQBtAGkAbAB5AFIAZQBnAHUAbABhAHIAVQBuAGkAQwBoAG8AbwBzAGUATABvAGMAYQB0AGkAbwBuAEYAbwBuAHQARgBhAG0AaQBsAHkAVQBuAGkAQwBoAG8AbwBzAGUATABvAGMAYQB0AGkAbwBuAEYAbwBuAHQARgBhAG0AaQBsAHkAVgBlAHIAcwBpAG8AbgAgADEALgAwAFUAbgBpAEMAaABvAG8AcwBlAEwAbwBjAGEAdABpAG8AbgBGAG8AbgB0AEYAYQBtAGkAbAB5AEcAZQBuAGUAcgBhAHQAZQBkACAAYgB5ACAAcwB2AGcAMgB0AHQAZgAgAGYAcgBvAG0AIABGAG8AbgB0AGUAbABsAG8AIABwAHIAbwBqAGUAYwB0AC4AaAB0AHQAcAA6AC8ALwBmAG8AbgB0AGUAbABsAG8ALgBjAG8AbQAAAgAAAAAAAAAKAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAQIBAwEEAQUBBgAGc291c3VvB2dvdXh1YW4HZGluZ3dlaQtkaXR1LXR1ZGluZwAAAAA=') format('truetype')" }], "@TRANSITION": { "uni-choose-location-map-box": { "property": "transform", "duration": "0.25s", "timingFunction": "ease-out" }, "uni-choose-location-map-target": { "property": "transform", "duration": "0.25s", "timingFunction": "ease-out" }, "uni-choose-location-map-reset": { "property": "transform", "duration": "0.25s", "timingFunction": "ease-out" }, "uni-choose-location-poi": { "property": "top", "duration": "0.25s", "timingFunction": "ease-out" } } }; const _export_sfc = (sfc, props) => { const target = sfc.__vccOpts || sfc; for (const [key, val] of props) { target[key] = val; } return target; }; var _hoisted_1 = ["id"]; var _hoisted_2 = { class: "uni-choose-location-icons uni-choose-location-map-target-icon" }; var _hoisted_3 = { class: "uni-choose-location-icons uni-choose-location-map-reset-icon" }; var _hoisted_4 = { class: "uni-choose-location-nav-text uni-choose-location-nav-confirm-text" }; var _hoisted_5 = { class: "uni-choose-location-poi-search" }; var _hoisted_6 = { class: "uni-choose-location-poi-search-box" }; var _hoisted_7 = { class: "uni-choose-location-icons uni-choose-location-search-icon" }; var _hoisted_8 = ["placeholder"]; var _hoisted_9 = ["id", "scroll-top"]; var _hoisted_10 = { key: 0, class: "uni-choose-location-poi-search-error" }; var _hoisted_11 = { class: "uni-choose-location-poi-search-error-text" }; var _hoisted_12 = { key: 1, class: "uni-choose-location-poi-search-loading" }; var _hoisted_13 = { class: "uni-choose-location-poi-search-loading-text" }; var _hoisted_14 = { key: 2, class: "uni-choose-location-poi-search-loading" }; var _hoisted_15 = ["src"]; var _hoisted_16 = ["onClick"]; var _hoisted_17 = { class: "uni-choose-location-poi-item-title-text" }; var _hoisted_18 = { class: "uni-choose-location-poi-item-detail-text" }; var _hoisted_19 = { key: 0, class: "uni-choose-location-icons uni-choose-location-poi-item-selected-icon" }; var _hoisted_20 = /* @__PURE__ */ createElementVNode("view", { class: "uni-choose-location-poi-item-after" }, null, -1); var _hoisted_21 = { key: 4, class: "uni-choose-location-poi-search-loading" }; var _hoisted_22 = ["src"]; function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) { var _component_map = resolveComponent("map"); return openBlock(), createElementBlock("view", { class: normalizeClass(["uni-choose-location", $options.uniChooseLocationClassCom]) }, [createElementVNode("view", { class: normalizeClass(["uni-choose-location-map-box", [$options.landscapeClassCom]]), style: normalizeStyle($options.mapBoxStyleCom) }, [createVNode(_component_map, { class: "uni-choose-location-map", id: $data.mapId, ref: $data.mapId, latitude: $data.latitude, longitude: $data.longitude, "layer-style": $data.theme == "dark" ? "2" : "1", "show-compass": false, "enable-zoom": true, "enable-scroll": true, "enable-rotate": false, "enable-poi": true, "show-location": true, onRegionchange: $options.regionchange }, null, 8, ["id", "latitude", "longitude", "layer-style", "onRegionchange"]), createElementVNode("view", { class: "uni-choose-location-map-target", ref: $data.mapTargetId, id: $data.mapTargetId }, [createElementVNode("text", _hoisted_2, toDisplayString($data.icon.target), 1)], 8, _hoisted_1), createElementVNode("view", { class: normalizeClass(["uni-choose-location-map-reset", [$options.landscapeClassCom]]), onClick: _cache[0] || (_cache[0] = function() { return $options.mapReset && $options.mapReset(...arguments); }), style: normalizeStyle($options.resetStyleCom) }, [createElementVNode("text", _hoisted_3, toDisplayString($data.icon.position), 1)], 6)], 6), createElementVNode("view", { class: "uni-choose-location-nav", style: normalizeStyle("height:" + (60 + $data.safeArea.top) + "px;") }, [createElementVNode("view", { class: normalizeClass(["uni-choose-location-nav-btn uni-choose-location-nav-back-btn", [$options.landscapeClassCom]]), style: normalizeStyle($data.safeArea.top > 0 ? "top: " + $data.safeArea.top + "px;" : "") }, [createElementVNode("text", { class: "uni-choose-location-nav-text uni-choose-location-nav-back-text", onClick: _cache[1] || (_cache[1] = function() { return $options.back && $options.back(...arguments); }) }, toDisplayString($options.languageCom["back"]), 1)], 6), createElementVNode("view", { class: normalizeClass(["uni-choose-location-nav-btn uni-choose-location-nav-confirm-btn", [$options.landscapeClassCom, $data.selected < 0 && !$data.callUniMapCoErr ? "disable" : "active"]]), style: normalizeStyle($data.safeArea.top > 0 ? "top: " + $data.safeArea.top + "px;" : ""), onClick: _cache[2] || (_cache[2] = function() { return $options.confirm && $options.confirm(...arguments); }) }, [createElementVNode("text", _hoisted_4, toDisplayString($options.languageCom["ok"]), 1)], 6)], 4), $data.useUniCloud ? (openBlock(), createElementBlock("view", { key: 0, class: normalizeClass(["uni-choose-location-poi", [$options.landscapeClassCom]]), style: normalizeStyle($options.poiBoxStyleCom) }, [createElementVNode("view", _hoisted_5, [createElementVNode("view", _hoisted_6, [createElementVNode("text", _hoisted_7, toDisplayString($data.icon.search), 1), withDirectives(createElementVNode("input", { "onUpdate:modelValue": _cache[3] || (_cache[3] = ($event) => $data.searchValue = $event), type: "text", placeholder: $options.languageCom["search"], class: "uni-choose-location-poi-search-input uni-choose-location-icons", onFocus: _cache[4] || (_cache[4] = ($event) => $data.isFocus = true), onConfirm: _cache[5] || (_cache[5] = ($event) => $options.poiSearch("poiSearch")), onInput: _cache[6] || (_cache[6] = function() { return $options.searchValueChange && $options.searchValueChange(...arguments); }) }, null, 40, _hoisted_8), [[vModelText, $data.searchValue]])]), $data.isFocus || $data.searchValue != "" ? (openBlock(), createElementBlock("text", { key: 0, class: "uni-choose-location-poi-search-cancel", onClick: _cache[7] || (_cache[7] = function() { return $options.cancelSearch && $options.cancelSearch(...arguments); }) }, toDisplayString($options.languageCom["cancel"]), 1)) : createCommentVNode("", true)]), createElementVNode("scroll-view", { id: $data.scrollId, ref: $data.scrollId, "scroll-with-animation": false, direction: "vertical", "scroll-top": $data.scrollTop, "lower-threshold": 50, onScrolltolower: _cache[8] || (_cache[8] = function() { return $options.scrolltolower && $options.scrolltolower(...arguments); }), class: "uni-choose-location-poi-list" }, [$data.errMsg != "" ? (openBlock(), createElementBlock("view", _hoisted_10, [createElementVNode("text", _hoisted_11, toDisplayString($data.errMsg), 1)])) : $data.locationLoading ? (openBlock(), createElementBlock("view", _hoisted_12, [createElementVNode("text", _hoisted_13, toDisplayString($options.languageCom["locationLoading"]), 1)])) : $data.searchLoading && $data.pageIndex == 1 ? (openBlock(), createElementBlock("view", _hoisted_14, [createElementVNode("image", { src: $data.loadingPath, class: "uni-choose-location-poi-search-loading-image", mode: "widthFix" }, null, 8, _hoisted_15)])) : (openBlock(true), createElementBlock(Fragment, { key: 3 }, renderList($data.pois, (item, index2) => { return openBlock(), createElementBlock("view", { key: index2, class: normalizeClass(["uni-choose-location-poi-item", [$options.landscapeClassCom]]), onClick: ($event) => $options.selectPoi(item, index2) }, [createElementVNode("view", null, [createElementVNode("view", null, [createElementVNode("text", _hoisted_17, toDisplayString(item.title), 1)]), createElementVNode("view", null, [createElementVNode("text", _hoisted_18, toDisplayString(item.distance > 0 ? item.distanceStr + " | " : "") + toDisplayString(item.address), 1)])]), $data.selected == index2 ? (openBlock(), createElementBlock("text", _hoisted_19, toDisplayString($data.icon.success), 1)) : createCommentVNode("", true), _hoisted_20], 10, _hoisted_16); }), 128)), $data.searchLoading && $data.pageIndex > 1 ? (openBlock(), createElementBlock("view", _hoisted_21, [createElementVNode("image", { src: $data.loadingPath, class: "uni-choose-location-poi-search-loading-image", mode: "widthFix" }, null, 8, _hoisted_22)])) : createCommentVNode("", true)], 40, _hoisted_9)], 6)) : createCommentVNode("", true)], 2); } const uniChooseLocationPage = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render], ["styles", [_style_0]]]); var chooseLocation = /* @__PURE__ */ defineAsyncApi("chooseLocation", (options, _ref) => { var { resolve, reject } = _ref; registerSystemRoute("uni:chooseLocation", uniChooseLocationPage, { disableSwipeBack: false }); var uuid = Date.now() + "" + Math.floor(Math.random() * 1e7); var baseEventName = "uni_choose_location_".concat(uuid); var readyEventName = "".concat(baseEventName, "_ready"); var optionsEventName = "".concat(baseEventName, "_options"); var successEventName = "".concat(baseEventName, "_success"); var failEventName = "".concat(baseEventName, "_fail"); uni.$on(readyEventName, () => { uni.$emit(optionsEventName, JSON.parse(JSON.stringify(options))); }); uni.$on(successEventName, (result) => { resolve(result); }); uni.$on(failEventName, () => { reject("cancel", { errCode: 1 }); }); uni.openDialogPage({ url: "uni:chooseLocation?readyEventName=".concat(readyEventName, "&optionsEventName=").concat(optionsEventName, "&successEventName=").concat(successEventName, "&failEventName=").concat(failEventName), fail(err) { var _options$fail; (_options$fail = options.fail) === null || _options$fail === void 0 || _options$fail.call(options, { errMsg: "chooseLocation:fail ".concat(err.errMsg), errCode: 4 }); uni.$off(readyEventName); uni.$off(successEventName); uni.$off(failEventName); } }); }); var env = { USER_DATA_PATH: "unifile://usr/", CACHE_PATH: "unifile://cache/", SANDBOX_PATH: "unifile://sandbox/" }; var _PerformanceEntryStatus; var APP_LAUNCH = "appLaunch"; var PERFORMANCE_BUFFER_SIZE = 30; var ENTRY_TYPE_RENDER = "render"; var ENTRY_TYPE_NAVIGATION = "navigation"; var RENDER_TYPE_FIRST_LAYOUT = "firstLayout"; var RENDER_TYPE_FIRST_RENDER = "firstRender"; var AppStartDuration = 1; var PageFirstPageRenderDuration = 7; var PageFirstPageLayoutDuration = 8; class PerformanceEntryStatus { constructor(entryType, name) { this._state = PerformanceEntryStatus.STATE_EMPTY; this._entryData = { entryType, name, duration: 0, startTime: 0 }; } get state() { return this._state; } set state(state) { this._state = state; if (this._state == PerformanceEntryStatus.STATE_BEFORE) { this.executeBefore(); } else if (this._state == PerformanceEntryStatus.STATE_AFTER) { this.executeAfter(); } else if (this._state == PerformanceEntryStatus.STATE_READY) { this.executeReady(); } } get entryData() { return this._entryData; } executeBefore() { var _getCurrentPage; var page = (_getCurrentPage = getCurrentPage()) === null || _getCurrentPage === void 0 ? void 0 : _getCurrentPage.vm; if (page != null) { this._entryData.referrerPath = page.route; } } executeAfter() { var page = getCurrentPage().vm; if (page != null) { this._entryData.pageId = parseInt(page.$nativePage.pageId); this._entryData.path = page.route; } } executeReady() { } getCurrentInnerPage() { var currentPage = getCurrentPage().vm; if (currentPage == null) { return null; } return currentPage.$nativePage; } } _PerformanceEntryStatus = PerformanceEntryStatus; _PerformanceEntryStatus.STATE_EMPTY = 0; _PerformanceEntryStatus.STATE_BEFORE = 1; _PerformanceEntryStatus.STATE_AFTER = 2; _PerformanceEntryStatus.STATE_READY = 3; class PerformanceEntryStatusLayout extends PerformanceEntryStatus { constructor() { super(ENTRY_TYPE_RENDER, RENDER_TYPE_FIRST_LAYOUT); } executeAfter() { super.executeAfter(); this._entryData.startTime = Date.now(); } executeReady() { super.executeReady(); var innerPage = super.getCurrentInnerPage(); if (innerPage != null) { this._entryData.duration = nativePage.getDuration(innerPage.pageId, PageFirstPageLayoutDuration); } } } class PerformanceEntryStatusRender extends PerformanceEntryStatus { constructor() { super(ENTRY_TYPE_RENDER, RENDER_TYPE_FIRST_RENDER); } executeAfter() { super.executeAfter(); this._entryData.startTime = Date.now(); } executeReady() { super.executeReady(); var innerPage = super.getCurrentInnerPage(); if (innerPage != null) { this._entryData.duration = nativePage.getDuration(innerPage.pageId, PageFirstPageRenderDuration); } } } class PerformanceEntryStatusNavigation extends PerformanceEntryStatus { constructor(name, navigationType) { super(ENTRY_TYPE_NAVIGATION, name); this._entryData.navigationType = navigationType; } executeBefore() { super.executeBefore(); this._entryData.startTime = Date.now(); } executeReady() { var innerPage = super.getCurrentInnerPage(); if (innerPage != null) { this._entryData.duration = Date.now() - this._entryData.startTime; if (this._entryData.name == APP_LAUNCH) { this._entryData.duration += nativePage.getDuration(AppStartDuration); } } } } class PerformanceEntryQueue extends Array { constructor() { super(...arguments); this._queueSize = PERFORMANCE_BUFFER_SIZE; } get queueSize() { return this._queueSize; } set queueSize(value) { this._queueSize = value; if (this.length > value) { this.dequeue(this.length - value); } } push() { return this.enqueue(...arguments); } enqueue() { if (this.length > this._queueSize - 1) { this.shift(); } return super.push(...arguments); } dequeue() { var count = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : 1; this.splice(0, count); } } class PerformanceObserverEntryListImpl { constructor() { this._queue = new PerformanceEntryQueue(); } push() { this._queue.push(...arguments); } getEntries() { return this._queue; } getEntriesByType(entryType) { return this._queue.filter((entry) => entry.entryType == entryType); } getEntriesByName(name, entryType) { return this._queue.filter((entry) => entry.entryType == entryType && entry.name == name); } clear() { this._queue.length = 0; } get bufferSize() { return this._queue.queueSize; } set bufferSize(size) { this._queue.queueSize = size; } } class PerformanceObserverImpl { constructor(performance, callback) { this._entryTypes = []; this._callback = null; this._entryList = new PerformanceObserverEntryListImpl(); this._owner = performance; this._callback = callback; } observe(options) { if ((options === null || options === void 0 ? void 0 : options.entryTypes) != null) { this._entryTypes.length = 0; this._entryTypes.push(...options.entryTypes); } if (this._entryTypes.length > 0) { this._owner.connect(this); } else { this.disconnect(); } } disconnect() { this._entryList.clear(); this._owner.disconnect(this); } dispatchCallback() { var _this$_callback; (_this$_callback = this._callback) === null || _this$_callback === void 0 || _this$_callback.call(this, this._entryList); } get entryTypes() { return this._entryTypes; } get entryList() { return this._entryList; } } class PerformanceProvider { constructor() { this._entryStatus = []; } get entryStatus() { return this._entryStatus; } onBefore(type) { if (type == APP_LAUNCH || type == API_SWITCH_TAB || type == API_NAVIGATE_TO || type == API_REDIRECT_TO || type == API_NAVIGATE_BACK) { this._pushEntryStatus(ENTRY_TYPE_NAVIGATION, this._navigationToName(type), type); } if (type == APP_LAUNCH || type == API_NAVIGATE_TO || type == API_REDIRECT_TO) { this._pushEntryStatus(ENTRY_TYPE_RENDER, RENDER_TYPE_FIRST_LAYOUT, type); this._pushEntryStatus(ENTRY_TYPE_RENDER, RENDER_TYPE_FIRST_RENDER, type); } this._forwardState(); } onAfter(type) { this._forwardState(); } onReady() { this._forwardState(); } removeAllStatus() { this._entryStatus.length = 0; } _pushEntryStatus(entryType, name, navigationType) { var entry = null; if (entryType == ENTRY_TYPE_NAVIGATION) { entry = new PerformanceEntryStatusNavigation(name, navigationType); } else if (entryType == ENTRY_TYPE_RENDER) { if (name == RENDER_TYPE_FIRST_LAYOUT) { entry = new PerformanceEntryStatusLayout(); } else if (name == RENDER_TYPE_FIRST_RENDER) { entry = new PerformanceEntryStatusRender(); } } if (entry != null) { this._entryStatus.push(entry); } } _forwardState() { this._entryStatus.forEach((entry) => { entry.state += 1; }); } _navigationToName(type) { if (type == APP_LAUNCH) { return APP_LAUNCH; } return "route"; } } class PerformanceAllocate { constructor(allEntryList, observerList) { this._allEntryList = allEntryList; this._observerList = observerList; } pushEntryStatus(status) { this.pushAllEntryData(status); this.pushObserverList(status); } pushAllEntryData(status) { status.forEach((entryStatus) => { this._allEntryList.push(entryStatus.entryData); }); } pushObserverList(status) { this._observerList.forEach((observer) => { var entryList = observer.entryList; entryList.clear(); status.forEach((entryStatus) => { var entryData = entryStatus.entryData; if (observer.entryTypes.includes(entryData.entryType)) { entryList.push(entryData); } }); observer.dispatchCallback(); }); } } class PerformanceImpl { constructor() { this._allEntryList = new PerformanceObserverEntryListImpl(); this._observerList = []; this._provider = new PerformanceProvider(); this._allocate = new PerformanceAllocate(this._allEntryList, this._observerList); onBeforeRoute((type) => { this._provider.onBefore(type); }); onAfterRoute((type) => { this._provider.onAfter(type); if (type == API_NAVIGATE_BACK) { this.dispatchObserver(); } }); onPageReady((page) => { this.dispatchObserver(); }); } dispatchObserver() { this._provider.onReady(); this._allocate.pushEntryStatus(this._provider.entryStatus); this._provider.removeAllStatus(); } createObserver(callback) { return new PerformanceObserverImpl(this, callback); } connect(observer) { var index2 = this._observerList.indexOf(observer); if (index2 < 0) { this._observerList.push(observer); } } disconnect(observer) { var index2 = this._observerList.indexOf(observer); if (index2 >= 0) { this._observerList.splice(index2, 1); } } getEntries() { return this._allEntryList.getEntries(); } getEntriesByType(entryType) { return this._allEntryList.getEntriesByType(entryType); } getEntriesByName(name, entryType) { return this._allEntryList.getEntriesByName(name, entryType); } setBufferSize(size) { this._allEntryList.bufferSize = size; } } var getPerformance = function() { return new PerformanceImpl(); }; var callbackId = 1; var proxy; var keepAliveCallbacks = {}; function isUniElement(obj) { return obj && typeof obj.getNodeId === "function" && obj.pageId; } function isComponentPublicInstance(instance) { return instance && instance.$ && instance.$.proxy === instance; } function parseElement(obj) { if (isUniElement(obj)) { return obj; } } function parseComponentPublicInstance(obj) { if (isComponentPublicInstance(obj)) { return obj.$el; } } function serialize(el, type) { var nodeId = ""; var pageId = ""; if (el && el.getNodeId) { pageId = el.pageId; nodeId = el.getNodeId(); } return { pageId, nodeId, __type__: type }; } function toRaw(observed) { var raw = observed && observed.__v_raw; return raw ? toRaw(raw) : observed; } function normalizeArg(arg, callbacks, keepAlive) { arg = toRaw(arg); if (typeof arg === "function") { var id2; if (keepAlive) { var oldId = Object.keys(callbacks).find((id22) => callbacks[id22] === arg); id2 = oldId ? parseInt(oldId) : callbackId++; callbacks[id2] = arg; } else { id2 = callbackId++; callbacks[id2] = arg; } return id2; } else if (isPlainObject(arg) || isUniElement(arg)) { var uniElement = parseElement(arg); var componentPublicInstanceUniElement = !uniElement ? parseComponentPublicInstance(arg) : void 0; var el = uniElement || componentPublicInstanceUniElement; if (el) { return serialize(el, uniElement ? "UniElement" : "ComponentPublicInstance"); } else { var newArg = {}; Object.keys(arg).forEach((name) => { newArg[name] = normalizeArg(arg[name], callbacks, keepAlive); }); return newArg; } } return arg; } function initUTSInstanceMethod(async, opts, instanceId, proxy2) { return initProxyFunction("method", async, opts, instanceId, proxy2); } function getProxy() { if (!proxy) { { proxy = { invokeSync(args, callback) { return nativeChannel.invokeSync("APP-SERVICE", args, callback); }, invokeAsync(args, callback) { return nativeChannel.invokeAsync("APP-SERVICE", args, callback); } }; } } return proxy; } function resolveSyncResult(args, res, returnOptions, instanceId, proxy2) { if (!res) { throw new Error("返回值为:" + JSON.stringify(res) + ";请求参数为:" + JSON.stringify(args)); } if (isString(res)) { try { res = JSON.parse(res); } catch (e) { throw new Error("JSON.parse(".concat(res, "): ") + e); } } if (res.errMsg) { throw new Error(res.errMsg); } if (returnOptions) { if (returnOptions.type === "interface" && typeof res.params === "number") { if (!res.params) { return null; } if (res.params === instanceId && proxy2) { return proxy2; } if (interfaceDefines[returnOptions.options]) { var ProxyClass = initUTSProxyClass(extend({ instanceId: res.params }, interfaceDefines[returnOptions.options])); return new ProxyClass(); } } } return res.params; } function invokePropGetter(args) { if (args.errMsg) { throw new Error(args.errMsg); } delete args.errMsg; return resolveSyncResult(args, getProxy().invokeSync(args, () => { })); } function initProxyFunction(type, async, _ref, instanceId, proxy2) { var { moduleName, moduleType, package: pkg, class: cls, name: methodName, method, companion, keepAlive, params: methodParams, return: returnOptions, errMsg } = _ref; if (!keepAlive) { keepAlive = methodName.indexOf("on") === 0 && methodParams.length === 1 && methodParams[0].type === "UTSCallback"; } var baseArgs = instanceId ? { moduleName, moduleType, id: instanceId, type, name: methodName, method: methodParams, keepAlive } : { moduleName, moduleType, package: pkg, class: cls, name: method || methodName, type, companion, method: methodParams, keepAlive }; return function() { if (errMsg) { throw new Error(errMsg); } var callbacks = keepAlive ? keepAliveCallbacks : {}; var invokeCallback2 = (_ref2) => { var { id: id2, name, params } = _ref2; var callback = callbacks[id2]; if (callback) { callback(...params); if (!keepAlive) { delete callbacks[id2]; } } else { console.error("uts插件[".concat(moduleName, "] ").concat(pkg).concat(cls, ".").concat(methodName.replace("ByJs", ""), " ").concat(name, "回调函数已释放,不能再次执行,参考文档:https://doc.dcloud.net.cn/uni-app-x/plugin/uts-plugin.html#keepalive")); } }; for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } var invokeArgs = extend({}, baseArgs, { params: args.map((arg) => normalizeArg(arg, callbacks, keepAlive)) }); if (async) { return new Promise((resolve, reject) => { getProxy().invokeAsync(invokeArgs, (res) => { if (res.type !== "return") { invokeCallback2(res); } else { if (res.errMsg) { reject(res.errMsg); } else { resolve(res.params); } } }); }); } return resolveSyncResult(invokeArgs, getProxy().invokeSync(invokeArgs, invokeCallback2), returnOptions, instanceId, proxy2); }; } function initUTSStaticMethod(async, opts) { if (opts.main && !opts.method) { if (isUTSiOS()) { opts.method = "s_" + opts.name; } } return initProxyFunction("method", async, opts, 0); } var initUTSProxyFunction = initUTSStaticMethod; function parseClassMethodName(name, methods) { if (typeof name === "string" && hasOwn(methods, name + "ByJs")) { return name + "ByJs"; } return name; } function isUndefined(value) { return typeof value === "undefined"; } function isProxyInterfaceOptions(options) { return !isUndefined(options.instanceId); } function parseClassPropertySetter(name) { return "__$set" + capitalize(name); } function initUTSProxyClass(options) { var { moduleName, moduleType, package: pkg, class: cls, methods, props, setters, errMsg } = options; var baseOptions = { moduleName, moduleType, package: pkg, class: cls, errMsg }; var instanceId; var constructorParams = []; var staticMethods = {}; var staticProps = []; var staticSetters = {}; var isProxyInterface = false; if (isProxyInterfaceOptions(options)) { isProxyInterface = true; instanceId = options.instanceId; } else { constructorParams = options.constructor.params; staticMethods = options.staticMethods; staticProps = options.staticProps; staticSetters = options.staticSetters; } if (isUTSiOS()) { if (constructorParams.find((p) => p.type === "UTSCallback" || p.type.indexOf("JSONObject") > 0)) { constructorParams.push({ name: "_byJs", type: "boolean" }); } } var ProxyClass = class UTSClass { constructor() { this.__instanceId = 0; if (errMsg) { throw new Error(errMsg); } var target = {}; if (!isProxyInterface) { for (var _len2 = arguments.length, params = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { params[_key2] = arguments[_key2]; } this.__instanceId = initProxyFunction("constructor", false, extend({ name: "constructor", keepAlive: false, params: constructorParams }, baseOptions), 0).apply(null, params); } else if (typeof instanceId === "number") { this.__instanceId = instanceId; } if (!this.__instanceId) { throw new Error("new ".concat(cls, " is failed")); } var instance = this; var proxy2 = new Proxy(instance, { get(_, name) { if (name === "__v_skip") { return true; } if (!target[name]) { name = parseClassMethodName(name, methods); if (hasOwn(methods, name)) { var { async, keepAlive, params: params2, return: returnOptions } = methods[name]; target[name] = initUTSInstanceMethod(!!async, extend({ name, keepAlive, params: params2, return: returnOptions }, baseOptions), instance.__instanceId, proxy2); } else if (props.includes(name)) { return invokePropGetter({ moduleName, moduleType, id: instance.__instanceId, type: "getter", keepAlive: false, name, errMsg }); } } return target[name]; }, set(_, name, newValue) { if (props.includes(name)) { var setter = parseClassPropertySetter(name); if (!target[setter]) { var param = setters[name]; if (param) { target[setter] = initProxyFunction("setter", false, extend({ name, keepAlive: false, params: [param] }, baseOptions), instance.__instanceId, proxy2); } } target[parseClassPropertySetter(name)](newValue); return true; } return false; } }); return proxy2; } }; var staticPropSetterCache = {}; var staticMethodCache = {}; return new Proxy(ProxyClass, { get(target, name, receiver) { name = parseClassMethodName(name, staticMethods); if (hasOwn(staticMethods, name)) { if (!staticMethodCache[name]) { var { async, keepAlive, params, return: returnOptions } = staticMethods[name]; staticMethodCache[name] = initUTSStaticMethod(!!async, extend({ name, companion: true, keepAlive, params, return: returnOptions }, baseOptions)); } return staticMethodCache[name]; } if (staticProps.includes(name)) { return invokePropGetter(extend({ name, companion: true, type: "getter" }, baseOptions)); } return Reflect.get(target, name, receiver); }, set(_, name, newValue) { if (staticProps.includes(name)) { var setter = parseClassPropertySetter(name); if (!staticPropSetterCache[setter]) { var param = staticSetters[name]; if (param) { staticPropSetterCache[setter] = initProxyFunction("setter", false, extend({ name, keepAlive: false, params: [param] }, baseOptions), 0); } } staticPropSetterCache[parseClassPropertySetter(name)](newValue); return true; } return false; } }); } function isUTSAndroid() { { return false; } } function isUTSiOS() { return !isUTSAndroid(); } function initUTSPackageName(name, is_uni_modules) { if (isUTSAndroid()) { return "uts.sdk." + (is_uni_modules ? "modules." : "") + name; } return ""; } function initUTSIndexClassName(moduleName, is_uni_modules) { return initUTSClassName(moduleName, isUTSAndroid() ? "IndexKt" : "IndexSwift", is_uni_modules); } function initUTSClassName(moduleName, className, is_uni_modules) { if (isUTSAndroid()) { return className; } return "UTSSDK" + (is_uni_modules ? "Modules" : "") + capitalize(moduleName) + capitalize(className); } var interfaceDefines = {}; function registerUTSInterface(name, define) { interfaceDefines[name] = define; } var pluginDefines = {}; function registerUTSPlugin(name, define) { pluginDefines[name] = define; } function requireUTSPlugin(name) { var define = pluginDefines[name]; if (!define) { console.error("".concat(name, " is not found")); } return define; } function __log__(type, filename) { for (var _len = arguments.length, args = new Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) { args[_key - 2] = arguments[_key]; } var res = normalizeLog(type, filename, args); res && console[type](res); } function isDebugMode() { return typeof __channelId__ === "string" && __channelId__; } function jsonStringifyReplacer(k, p) { switch (toRawType(p)) { case "Function": return "function() { [native code] }"; default: return p; } } function normalizeLog(type, filename, args) { if (isDebugMode()) { args.push(filename.replace("at ", "uni-app:///")); return console[type].apply(console, args); } var msgs = args.map(function(v) { var type2 = toTypeString(v).toLowerCase(); if (["[object object]", "[object array]", "[object module]"].indexOf(type2) !== -1) { try { v = "---BEGIN:JSON---" + JSON.stringify(v, jsonStringifyReplacer) + "---END:JSON---"; } catch (e) { v = type2; } } else { if (v === null) { v = "---NULL---"; } else if (v === void 0) { v = "---UNDEFINED---"; } else { var vType = toRawType(v).toUpperCase(); if (vType === "NUMBER" || vType === "BOOLEAN") { v = "---BEGIN:" + vType + "---" + v + "---END:" + vType + "---"; } else { v = String(v); } } } return v; }); return msgs.join("---COMMA---") + " " + filename; } const uni$1 = /* @__PURE__ */ Object.defineProperty({ __proto__: null, $emit, $off, $on, $once, __log__, addInterceptor, chooseLocation, closeDialogPage, closeNativeDialogPage, createCanvasContextAsync, createSelectorQuery, env, getElementById, getEnterOptionsSync, getLaunchOptionsSync, getPerformance, hideTabBar, hideTabBarRedDot, initUTSClassName, initUTSIndexClassName, initUTSPackageName, initUTSProxyClass, initUTSProxyFunction, loadFontFace, navigateBack, navigateTo, onTabBarMidButtonTap, openDialogPage, pageScrollTo, reLaunch, redirectTo, registerUTSInterface, registerUTSPlugin, removeInterceptor, removeTabBarBadge, requireUTSPlugin, setNavigationBarColor, setNavigationBarTitle, setTabBarBadge, setTabBarItem, setTabBarStyle, showTabBar, showTabBarRedDot, startPullDownRefresh, stopPullDownRefresh, switchTab }, Symbol.toStringTag, { value: "Module" }); function converPx(value) { if (/^-?\d+[ur]px$/i.test(value)) { return value.replace(/(^-?\d+)[ur]px$/i, (text, num) => { return "".concat(uni.upx2px(parseFloat(num)), "px"); }); } else if (/^-?[\d\.]+$/.test(value)) { return "".concat(value, "px"); } return value || ""; } function converType(type) { return type.replace(/[A-Z]/g, (text) => { return "-".concat(text.toLowerCase()); }).replace("webkit", "-webkit"); } function getStyle(action) { var animateTypes1 = ["matrix", "matrix3d", "scale", "scale3d", "rotate3d", "skew", "translate", "translate3d"]; var animateTypes2 = ["scaleX", "scaleY", "scaleZ", "rotate", "rotateX", "rotateY", "rotateZ", "skewX", "skewY", "translateX", "translateY", "translateZ"]; var animateTypes3 = ["opacity", "background-color"]; var animateTypes4 = ["width", "height", "left", "right", "top", "bottom"]; var animates = action.animates; var option = action.option; var transition = option.transition; var style = {}; var transform = []; animates.forEach((animate) => { var type = animate.type; var args = [...animate.args]; if (animateTypes1.concat(animateTypes2).includes(type)) { if (type.startsWith("rotate") || type.startsWith("skew")) { args = args.map((value2) => parseFloat(value2) + "deg"); } else if (type.startsWith("translate")) { args = args.map(converPx); } if (animateTypes2.indexOf(type) >= 0) { args.length = 1; } transform.push("".concat(type, "(").concat(args.join(","), ")")); } else if (animateTypes3.concat(animateTypes4).includes(args[0])) { type = args[0]; var value = args[1]; style[type] = animateTypes4.includes(type) ? converPx(value) : value; } }); style.transform = style.webkitTransform = transform.join(" "); style.transition = style.webkitTransition = Object.keys(style).map((type) => "".concat(converType(type), " ").concat(transition.duration, "ms ").concat(transition.timingFunction, " ").concat(transition.delay, "ms")).join(","); style.transformOrigin = style.webkitTransformOrigin = option.transformOrigin; return style; } function startAnimation(context) { var animation2 = context.animation; if (!animation2 || !animation2.actions || !animation2.actions.length) { return; } var index2 = 0; var actions = animation2.actions; var length = animation2.actions.length; function animate() { var action = actions[index2]; var transition = action.option.transition; var style = getStyle(action); Object.keys(style).forEach((key) => { context.$el.style[key] = style[key]; }); index2 += 1; if (index2 < length) { setTimeout(animate, transition.duration + transition.delay); } } setTimeout(() => { animate(); }, 0); } const animation = { props: ["animation"], watch: { animation: { deep: true, handler() { startAnimation(this); } } }, mounted() { startAnimation(this); } }; var defineBuiltInComponent = (options) => { options.__reserved = true; var { props, mixins } = options; if (!props || !props.animation) { (mixins || (options.mixins = [])).push(animation); } { var rootElement = options.rootElement; if (rootElement) { customElements.define(rootElement.name, rootElement.class, rootElement.options); } } return defineSystemComponent(options); }; var defineSystemComponent = (options) => { options.__reserved = true; options.compatConfig = { MODE: 3 // 标记为vue3 }; return defineComponent(options); }; function $dispatch(context, componentName, eventName) { var _parent; var parent = context.$parent; var name = (_parent = parent) === null || _parent === void 0 || (_parent = _parent.$options) === null || _parent === void 0 ? void 0 : _parent.name; while (parent != null && (name == null || componentName != name)) { parent = parent.$parent; if (parent != null) { var _parent2; name = (_parent2 = parent) === null || _parent2 === void 0 || (_parent2 = _parent2.$options) === null || _parent2 === void 0 ? void 0 : _parent2.name; } } if (parent != null) { if (typeof parent[eventName] === "function") { for (var _len = arguments.length, do_not_transform_spread = new Array(_len > 3 ? _len - 3 : 0), _key = 3; _key < _len; _key++) { do_not_transform_spread[_key - 3] = arguments[_key]; } parent[eventName](...do_not_transform_spread); } else { warn("dispatch: ".concat(componentName, " has no method ").concat(eventName)); } } } function $dispatchParent(context, componentName, eventName) { var _parent$$options; var parent = context.$parent; var name = parent === null || parent === void 0 || (_parent$$options = parent.$options) === null || _parent$$options === void 0 ? void 0 : _parent$$options.name; if (parent !== null && (name === null || componentName === name)) { if (typeof parent[eventName] === "function") { for (var _len2 = arguments.length, do_not_transform_spread = new Array(_len2 > 3 ? _len2 - 3 : 0), _key2 = 3; _key2 < _len2; _key2++) { do_not_transform_spread[_key2 - 3] = arguments[_key2]; } return parent[eventName](...do_not_transform_spread); } else { warn("dispatchParent: ".concat(componentName, " has no method ").concat(eventName)); } } } function initUniCustomEvent(element, e) { e.target = element; e.currentTarget = element; return e; } var CHECKBOX_NAME = "Checkbox"; var CHECKBOX_ROOT_ELEMENT = "uni-checkbox-element"; class UniCheckboxElement extends UniElementImpl { constructor(data, pageNode) { super(data, pageNode); this.tagName = "CHECKBOX"; this.nodeName = this.tagName; this._getAttribute = (key) => { return null; }; } getAnyAttribute(key) { var value = this._getAttribute(key); if (value != null) { return value; } return super.getAnyAttribute(key); } } var checkboxProps = { checked: { type: Boolean, default: false }, disabled: { type: Boolean, default: false }, value: { type: [Object, String], default: "" }, // 图标颜色 color: { type: String, default: "#007aff" }, // 默认的背景颜色 backgroundColor: { type: String, default: "#ffffff" }, // 默认的边框颜色 borderColor: { type: String, default: "#d1d1d1" }, // 选中时的背景颜色 activeBackgroundColor: { type: String, default: "#ffffff" }, // 选中时的边框颜色 activeBorderColor: { type: String, default: "#d1d1d1" }, // 图标颜色,同color,优先级大于color iconColor: { type: String, default: "" }, // 图标颜色,同color,优先级大于iconColor foreColor: { type: String, default: "" } }; var styles = { ["uni-checkbox"]: { "flex-direction": "row", "align-items": "center" }, ["uni-checkbox-input"]: { "justify-content": "center", "align-items": "center", position: "relative", "border-top-width": "1px", "border-right-width": "1px", "border-bottom-width": "1px", "border-left-width": "1px", "border-top-style": "solid", "border-right-style": "solid", "border-bottom-style": "solid", "border-left-style": "solid", "border-top-left-radius": "3px", "border-top-right-radius": "3px", "border-bottom-right-radius": "3px", "border-bottom-left-radius": "3px", width: "22px", height: "22px", "margin-right": "5px", "box-sizing": "content-box" }, ["uni-icon"]: { "font-family": "uni-icon", "font-size": "16px", width: "16px", height: "16px" } }; var createHook = (lifecycle) => function(hook) { var target = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : getCurrentInstance(); !isInSSRComponentSetup && injectHook(lifecycle, hook, target); }; var onUnload = /* @__PURE__ */ createHook(ON_UNLOAD); const checkbox = /* @__PURE__ */ defineBuiltInComponent({ name: CHECKBOX_NAME, rootElement: { name: CHECKBOX_ROOT_ELEMENT, // @ts-expect-error not web element class: UniCheckboxElement }, props: checkboxProps, emits: ["click"], setup(props, _ref) { var { emit, slots } = _ref; var icon = ""; var instance = getCurrentInstance(); var elementRef = ref(); var checkboxChecked = ref(props.checked); var checkboxValue = ref(""); var setCheckboxChecked = (checked) => { checkboxChecked.value = checked; }; watchEffect(() => { checkboxChecked.value = props.checked; }); watch(() => checkboxChecked.value, (val) => { var ctx = instance === null || instance === void 0 ? void 0 : instance.proxy; if (!ctx) return; $dispatch(ctx, "CheckboxGroup", "_changeHandler", { name: checkboxValue.value, checked: checkboxChecked.value, setCheckboxChecked }); }); watchEffect(() => { checkboxValue.value = props.value.toString(); }); var iconStyle = computed(() => { if (props.disabled) { return Object.assign({}, styles["uni-icon"]); } var color = ""; if (props.foreColor.length > 0) { color = props.foreColor; } else if (props.iconColor.length > 0) { color = props.iconColor; } else { color = props.color; } return Object.assign({}, styles["uni-icon"], { color }); }); var checkInputStyle = computed(() => { var style = checkboxChecked.value ? checkedStyle.value : uncheckedStyle.value; return Object.assign({}, styles["uni-checkbox-input"], style); }); var checkedStyle = computed(() => { if (props.disabled) { return { backgroundColor: "#e1e1e1", borderColor: "#d1d1d1" }; } return { backgroundColor: props.activeBackgroundColor, borderColor: props.activeBorderColor }; }); var uncheckedStyle = computed(() => { if (props.disabled) { return { backgroundColor: "#e1e1e1", borderColor: "#d1d1d1" }; } return { backgroundColor: props.backgroundColor, borderColor: props.borderColor }; }); onMounted(() => { var ctx = instance === null || instance === void 0 ? void 0 : instance.proxy; $dispatch(ctx, "CheckboxGroup", "_checkboxGroupUpdateHandler", { setCheckboxChecked, name: checkboxValue.value, checked: checkboxChecked.value }, "add"); instance === null || instance === void 0 || instance.$waitNativeRender(() => { var _instance$proxy; if (!instance) return; elementRef.value = (_instance$proxy = instance.proxy) === null || _instance$proxy === void 0 ? void 0 : _instance$proxy.$el; elementRef.value._getAttribute = (key) => { var _props$keyString$toSt, _props$keyString; var keyString = camelize(key); return props[keyString] !== null ? (_props$keyString$toSt = (_props$keyString = props[keyString]) === null || _props$keyString === void 0 ? void 0 : _props$keyString.toString()) !== null && _props$keyString$toSt !== void 0 ? _props$keyString$toSt : null : null; }; }); }); onUnload(() => { var ctx = instance === null || instance === void 0 ? void 0 : instance.proxy; $dispatch(ctx, "CheckboxGroup", "_checkboxGroupUpdateHandler", { setCheckboxChecked, name: checkboxValue.value, checked: checkboxChecked.value }, "remove"); }); var _onClick = ($event) => { if (props.disabled) return; emit("click", $event); checkboxChecked.value = !checkboxChecked.value; }; return () => { var _slots$default; return createVNode("uni-checkbox-element", { "dataUncType": "uni-checkbox", "onClick": _onClick, "class": "uni-checkbox", "style": styles["uni-checkbox"] }, [createVNode("view", { "class": "uni-checkbox-input", "style": checkInputStyle.value }, [createVNode("text", { "class": "uni-icon", "style": iconStyle.value }, [checkboxChecked.value ? icon : ""], 4)], 4), (_slots$default = slots.default) === null || _slots$default === void 0 ? void 0 : _slots$default.call(slots)], 12, ["onClick"]); }; } }); const checkbox$1 = /* @__PURE__ */ Object.defineProperty({ __proto__: null, UniCheckboxElement, default: checkbox }, Symbol.toStringTag, { value: "Module" }); var CHECKBOX_GROUP_NAME = "CheckboxGroup"; var CHECKBOX_GROUP_ROOT_ELEMENT = "uni-checkbox-group-element"; var checkboxGroupProps = { name: { type: String, default: "" } }; class UniCheckboxGroupElement extends UniFormControlElement { constructor(data, pageNode) { super(data, pageNode); this._initialValue = []; this.tagName = "CHECKBOX-GROUP"; this.nodeName = this.tagName; this._getAttribute = (key) => { return null; }; this._getValue = () => { return this._initialValue; }; this._setValue = (value) => { }; } get value() { return this._getValue(); } set value(value) { this._setValue(value); } getAnyAttribute(key) { var value = this._getAttribute(key); if (value != null) { return value; } return super.getAnyAttribute(key); } reset() { this.value = this._initialValue.slice(0); } } class UniCheckboxGroupChangeEventDetail { constructor(value) { this.value = value; } } class UniCheckboxGroupChangeEvent extends UniCustomEvent { constructor(value) { super("change", { detail: new UniCheckboxGroupChangeEventDetail(value) }); } } const checkboxGroup = /* @__PURE__ */ defineBuiltInComponent({ name: CHECKBOX_GROUP_NAME, rootElement: { name: CHECKBOX_GROUP_ROOT_ELEMENT, // @ts-expect-error not web element class: UniCheckboxGroupElement }, props: checkboxGroupProps, emits: ["change"], setup(props, _ref) { var { emit, expose, slots } = _ref; var $checkboxList = ref([]); var uniCheckboxGroupElementRef = ref(); var instance = getCurrentInstance(); var _checkboxGroupUpdateHandler = (info, type) => { if (type == "add") { $checkboxList.value.push(info); } else { var index2 = $checkboxList.value.findIndex((i) => i.name === info.name); if (index2 !== -1) { $checkboxList.value.splice(index2, 1); } } }; var _changeHandler = (info) => { $checkboxList.value.forEach((i) => { if (i.name === info.name) { i.checked = info.checked; } }); emit("change", initUniCustomEvent(uniCheckboxGroupElementRef.value, new UniCheckboxGroupChangeEvent(_getValue()))); }; var _getValue = () => { var valueArray = []; $checkboxList.value.forEach((info) => { if (info.checked) { valueArray.push(info.name); } }); return valueArray; }; var _setValue = (valueArray) => { $checkboxList.value.forEach((info) => { info.setCheckboxChecked(valueArray.includes(info.name)); }); }; onMounted(() => { instance === null || instance === void 0 || instance.$waitNativeRender(() => { if (!instance) return; if (!uniCheckboxGroupElementRef.value) return; uniCheckboxGroupElementRef.value._getValue = _getValue; uniCheckboxGroupElementRef.value._setValue = _setValue; uniCheckboxGroupElementRef.value._initialValue = _getValue(); uniCheckboxGroupElementRef.value._getAttribute = (key) => { var _props$keyString$toSt, _props$keyString; var keyString = camelize(key); return props[keyString] !== null ? (_props$keyString$toSt = (_props$keyString = props[keyString]) === null || _props$keyString === void 0 ? void 0 : _props$keyString.toString()) !== null && _props$keyString$toSt !== void 0 ? _props$keyString$toSt : null : null; }; }); }); expose({ _checkboxGroupUpdateHandler, _changeHandler, _getValue, _setValue }); return () => { var _slots$default; return createVNode("uni-checkbox-group-element", { "ref": uniCheckboxGroupElementRef }, [(_slots$default = slots.default) === null || _slots$default === void 0 ? void 0 : _slots$default.call(slots)], 512); }; } }); const checkboxGroup$1 = /* @__PURE__ */ Object.defineProperty({ __proto__: null, UniCheckboxGroupChangeEvent, UniCheckboxGroupElement, default: checkboxGroup }, Symbol.toStringTag, { value: "Module" }); var RADIO_NAME = "Radio"; var RADIO_ROOT_ELEMENT = "uni-radio-element"; class UniRadioElement extends UniElementImpl { constructor(data, pageNode) { super(data, pageNode); this.tagName = "RADIO"; this.nodeName = this.tagName; this._getAttribute = (key) => { return null; }; } getAnyAttribute(key) { var value = this._getAttribute(key); if (value != null) { return value; } return super.getAnyAttribute(key); } } var radioProps = { checked: { type: Boolean, default: false }, disabled: { type: Boolean, default: false }, value: { type: [Object, String], default: "" }, // 选中时的背景颜色 color: { type: String, default: "#007AFF" }, // 默认的背景颜色 backgroundColor: { type: String, default: "#ffffff" }, // 默认的边框颜色 borderColor: { type: String, default: "#d1d1d1" }, // 选中时的背景颜色,同color,优先级大于color activeBackgroundColor: { type: String, default: "" }, // 选中时的边框颜色,默认为选中时的背景颜色 activeBorderColor: { type: String, default: "" }, // 图标颜色 iconColor: { type: String, default: "#ffffff" }, // 高于 iconColor 和 color foreColor: { type: String, default: "" } }; var _style_0$1 = { "uni-radio": { "": { flexDirection: "row", alignItems: "center" } }, "uni-radio-input": { "": { position: "relative", alignItems: "center", justifyContent: "center", marginRight: "5px", borderStyle: "solid", borderWidth: "1px", borderRadius: "50px", width: "22px", height: "22px", boxSizing: "content-box" } }, "uni-radio-input-icon": { "": { fontFamily: "uni-icon", fontSize: "14px", width: "14px", height: "14px" } } }; var styleList = _style_0$1; const radio = /* @__PURE__ */ defineBuiltInComponent({ name: RADIO_NAME, rootElement: { name: RADIO_ROOT_ELEMENT, // @ts-expect-error not web element class: UniRadioElement }, props: radioProps, setup(props, _ref) { var { slots, expose } = _ref; var uniRadioElementRef = ref(); var styleUniRadio = computed(() => styleList["uni-radio"][""]); var styleUniRadioInput = computed(() => { return Object.assign({}, styleList["uni-radio-input"][""], radioChecked.value ? checkedStyle.value : uncheckedStyle.value); }); var styleUniRadioInputIcon = computed(() => { return Object.assign({}, styleList["uni-radio-input-icon"][""], iconStyle.value); }); var checkedStyle = computed(() => { if (props.disabled) { return { backgroundColor: "#e1e1e1", borderColor: "#d1d1d1" }; } var backgroundColor = props.activeBackgroundColor.length > 0 ? props.activeBackgroundColor : props.color; var borderColor = props.activeBorderColor.length > 0 ? props.activeBorderColor : backgroundColor; return { backgroundColor, borderColor }; }); var uncheckedStyle = computed(() => { if (props.disabled) { return { backgroundColor: "#e1e1e1", borderColor: "#d1d1d1" }; } return { backgroundColor: props.backgroundColor, borderColor: props.borderColor }; }); var iconStyle = computed(() => { var color = ""; if (props.foreColor.length > 0) { color = props.foreColor; } else if (props.iconColor.length > 0) { color = props.iconColor; } return { color: props.disabled ? "#adadad" : color }; }); var icon = ""; var radioChecked = ref(props.checked); var radioValue = ref(props.value.toString()); watchEffect(() => { radioChecked.value = props.checked; }); var setRadioChecked = (value) => { radioChecked.value = value; }; watchEffect(() => { radioValue.value = props.value.toString(); }); watch(() => radioChecked.value, (val) => { var ctx = instance === null || instance === void 0 ? void 0 : instance.proxy; if (!ctx) return; if (val) { $dispatch(ctx, "RadioGroup", "_changeHandler", { name: radioValue.value, checked: radioChecked.value, setRadioChecked }); } }); expose({ radioValue }); var instance = getCurrentInstance(); onMounted(() => { instance === null || instance === void 0 || instance.$waitNativeRender(() => { if (instance === null) return; uniRadioElementRef.value._getAttribute = (key) => { var _props$keyString$toSt, _props$keyString; var keyString = camelize(key); return props[keyString] !== null ? (_props$keyString$toSt = (_props$keyString = props[keyString]) === null || _props$keyString === void 0 ? void 0 : _props$keyString.toString()) !== null && _props$keyString$toSt !== void 0 ? _props$keyString$toSt : null : null; }; }); var ctx = instance === null || instance === void 0 ? void 0 : instance.proxy; $dispatch(ctx, "RadioGroup", "_radioGroupUpdateHandler", { name: radioValue.value, checked: radioChecked.value, setRadioChecked }, "add"); }); onUnmounted(() => { var ctx = instance === null || instance === void 0 ? void 0 : instance.proxy; $dispatch(ctx, "RadioGroup", "_radioGroupUpdateHandler", { name: radioValue.value, checked: radioChecked.value, setRadioChecked }, "remove"); }); var _onClick = () => { if (props.disabled || radioChecked.value) return; radioChecked.value = !radioChecked.value; }; return () => { var _slots$default; return createVNode("uni-radio-element", { "dataUncType": "uni-radio", "class": "uni-radio", "style": styleUniRadio.value, "ref": uniRadioElementRef, "onClick": _onClick }, [createVNode("view", { "class": "uni-radio-input", "style": styleUniRadioInput.value }, [createVNode("text", { "class": "uni-radio-input-icon", "style": styleUniRadioInputIcon.value }, [radioChecked.value ? icon : ""], 4)], 4), (_slots$default = slots.default) === null || _slots$default === void 0 ? void 0 : _slots$default.call(slots)], 12, ["onClick"]); }; } }); const radio$1 = /* @__PURE__ */ Object.defineProperty({ __proto__: null, UniRadioElement, default: radio }, Symbol.toStringTag, { value: "Module" }); var RADIOGROUP_NAME = "RadioGroup"; var RADIOGROUP_ROOT_ELEMENT = "uni-radio-group-element"; var RadioProps = { name: { type: String, default: "" } }; class UniRadioGroupElement extends UniFormControlElement { constructor(data, pageNode) { super(data, pageNode); this._initialValue = ""; this.tagName = "RADIO-GROUP"; this.nodeName = this.tagName; this._getAttribute = (key) => { return null; }; this._getValue = () => { return this._initialValue; }; this._setValue = (value) => { }; } getAnyAttribute(key) { var value = this._getAttribute(key); if (value != null) { return value; } return super.getAnyAttribute(key); } get value() { return this._getValue(); } set value(value) { this._setValue(value); } reset() { this.value = this._initialValue; } } class UniRadioGroupChangeEventDetail { constructor(value) { this.value = value; } } class UniRadioGroupChangeEvent extends UniCustomEvent { constructor(value) { super("change", { detail: new UniRadioGroupChangeEventDetail(value) }); } } const radioGroup = /* @__PURE__ */ defineBuiltInComponent({ name: RADIOGROUP_NAME, rootElement: { name: RADIOGROUP_ROOT_ELEMENT, // @ts-expect-error not web element class: UniRadioGroupElement }, props: RadioProps, emits: ["change"], setup(props, _ref) { var { emit, slots, expose } = _ref; var $radioList = ref([]); var uniRadioGroupElementRef = ref(); var instance = getCurrentInstance(); var _radioGroupUpdateHandler = (info, type) => { if (type == "add") { $radioList.value.push(info); } else { var index2 = $radioList.value.findIndex((i) => i.name == info.name); if (index2 !== -1) { $radioList.value.splice(index2, 1); } } }; var _changeHandler = (data) => { _setValue(data.name); emit("change", initUniCustomEvent(uniRadioGroupElementRef.value, new UniRadioGroupChangeEvent(data.name))); }; var _getValue = () => { var value = ""; $radioList.value.forEach((info) => { if (info.checked) { value = info.name; } }); return value; }; var _setValue = (name) => { $radioList.value.forEach((info) => { if (info.name == name) { info.checked = true; info.setRadioChecked(true); } else { info.checked = false; info.setRadioChecked(false); } }); }; onMounted(() => { instance === null || instance === void 0 || instance.$waitNativeRender(() => { if (!instance) return; if (!uniRadioGroupElementRef.value) return; uniRadioGroupElementRef.value._getValue = _getValue; uniRadioGroupElementRef.value._setValue = _setValue; uniRadioGroupElementRef.value._initialValue = _getValue(); uniRadioGroupElementRef.value._getAttribute = (key) => { var _props$keyString$toSt, _props$keyString; var keyString = camelize(key); return props[keyString] !== null ? (_props$keyString$toSt = (_props$keyString = props[keyString]) === null || _props$keyString === void 0 ? void 0 : _props$keyString.toString()) !== null && _props$keyString$toSt !== void 0 ? _props$keyString$toSt : null : null; }; }); }); expose({ _radioGroupUpdateHandler, _getValue, _setValue, _changeHandler }); return () => { var _slots$default; return createVNode("uni-radio-group-element", { "ref": uniRadioGroupElementRef }, [(_slots$default = slots.default) === null || _slots$default === void 0 ? void 0 : _slots$default.call(slots)], 512); }; } }); const radioGroup$1 = /* @__PURE__ */ Object.defineProperty({ __proto__: null, UniRadioGroupChangeEvent, UniRadioGroupElement, default: radioGroup }, Symbol.toStringTag, { value: "Module" }); class UniNavigatorElement extends UniElementImpl { constructor(data, pageNode) { super(data, pageNode); this.tagName = "NAVIGATOR"; this.nodeName = this.tagName; this._getAttribute = (key) => { return null; }; } getAnyAttribute(key) { var value = this._getAttribute(key); if (value != null) { return value; } return super.getAnyAttribute(key); } } var navigatorProps = { url: { type: String, default: "" }, openType: { type: String, default: "navigate" }, delta: { type: Number, default: 1 }, animationType: { type: String, default: "" }, animationDuration: { type: Number, default: 300 }, hoverClass: { type: String, default: "navigator-hover" }, hoverStopPropagation: { type: Boolean, default: false }, hoverStartTime: { type: Number, default: 50 }, hoverStayTime: { type: Number, default: 600 } }; const navigator = /* @__PURE__ */ defineBuiltInComponent({ name: "Navigator", rootElement: { name: "uni-navigator-element", // @ts-expect-error not web element class: UniNavigatorElement }, props: navigatorProps, emits: ["click"], setup(props, _ref) { var { emit, slots } = _ref; var $uniNavigatorElement = ref(); var instance = getCurrentInstance(); onMounted(() => { instance === null || instance === void 0 || instance.$waitNativeRender(() => { if (!instance) return; $uniNavigatorElement.value._getAttribute = (key) => { var _props$keyString$toSt, _props$keyString; var keyString = camelize(key); return props[keyString] !== null ? (_props$keyString$toSt = (_props$keyString = props[keyString]) === null || _props$keyString === void 0 ? void 0 : _props$keyString.toString()) !== null && _props$keyString$toSt !== void 0 ? _props$keyString$toSt : null : null; }; }); }); var _onClick = ($event) => { var url = props.url; emit("click", $event); var animationDuration = props.animationDuration; switch (props.openType) { case "navigate": uni.navigateTo({ url, animationType: props.animationType.length > 0 ? props.animationType : "pop-in", animationDuration }); break; case "redirect": uni.redirectTo({ url }); break; case "switchTab": uni.switchTab({ url }); break; case "reLaunch": uni.reLaunch({ url }); break; case "navigateBack": uni.navigateBack({ delta: props.delta, animationType: props.animationType.length > 0 ? props.animationType : "pop-out", animationDuration }); break; default: console.log(" openType attribute invalid"); break; } }; return () => { var _slots$default; return createVNode("uni-navigator-element", { "ref": $uniNavigatorElement, "onClick": _onClick, "hoverClass": props.hoverClass, "hoverStopPropagation": props.hoverStopPropagation, "hoverStartTime": props.hoverStartTime, "hoverStayTime": props.hoverStayTime }, [(_slots$default = slots.default) === null || _slots$default === void 0 ? void 0 : _slots$default.call(slots)], 8, ["onClick", "hoverClass", "hoverStopPropagation", "hoverStartTime", "hoverStayTime"]); }; } }); const navigator$1 = /* @__PURE__ */ Object.defineProperty({ __proto__: null, UniNavigatorElement, default: navigator }, Symbol.toStringTag, { value: "Module" }); var BACKGROUND_COLOR = "#EBEBEB"; var PRIMARY_COLOR = "#007AFF"; var ANIMATE_INTERVAL_DEFAULT = 30; var FONT_SIZE = 16; var STROKE_WIDTH = 6; class UniProgressActiveendEventDetail { constructor(value) { this.curPercent = value; } } class UniProgressActiveendEvent extends UniCustomEvent { constructor(value) { super("activeend", { detail: new UniProgressActiveendEventDetail(value) }); } } class UniProgressElement extends UniElementImpl { constructor(data, pageNode) { super(data, pageNode); this.tagName = "PROGRESS"; this.nodeName = this.tagName; this._getAttribute = (key) => { return null; }; } getAnyAttribute(key) { var value = this._getAttribute(key); if (value != null) { return value; } return super.getAnyAttribute(key); } } var progressProps = { percent: { type: Number, default: 0 }, showInfo: { type: Boolean, default: false }, borderRadius: { type: Number, default: 0 }, fontSize: { type: Number, default: FONT_SIZE }, strokeWidth: { type: Number, default: STROKE_WIDTH }, active: { type: Boolean, default: false }, activeColor: { type: String, default: PRIMARY_COLOR }, activeMode: { type: String, default: "backwards" }, backgroundColor: { type: String, default: BACKGROUND_COLOR }, duration: { type: Number, default: ANIMATE_INTERVAL_DEFAULT } }; var _style = { "uni-progress": { "": { flexDirection: "row", alignItems: "center" } }, "uni-progress-bar": { "": { flex: "1", overflow: "hidden" } }, "uni-progress-info": { "": { marginLeft: "15px" } } }; const progress = /* @__PURE__ */ defineBuiltInComponent({ name: "Progress", rootElement: { name: "uni-progress-element", // @ts-expect-error not web element class: UniProgressElement }, emit: ["activeend"], props: progressProps, setup(props, _ref) { var { emit } = _ref; var data = reactive({ $uniProgressElement: null, curPercent: 0, _timerId: 0, _lastPercent: 0 }); var textStr = computed(() => { return "".concat(data.curPercent, "%"); }); var instance = getCurrentInstance(); var styleUniProgress = computed(() => _style["uni-progress"][""]); var styleUniProgressBar = computed(() => _style["uni-progress-bar"][""]); var barStyle = computed(() => { var style = { height: "".concat(props.strokeWidth, "px"), borderRadius: "".concat(props.borderRadius, "px"), backgroundColor: props.backgroundColor }; return Object.assign({}, styleUniProgressBar.value, style); }); var innerBarStyle = computed(() => { var style = { width: "".concat(data.curPercent, "%"), height: "".concat(props.strokeWidth, "px"), backgroundColor: "".concat(props.activeColor) }; return Object.assign({}, style); }); var textStyle = computed(() => { var fontSize = props.fontSize; var style = { fontSize: "".concat(fontSize, "px"), minWidth: "".concat(fontSize * 2, "px") }; return Object.assign({}, _style["uni-progress-info"][""], style); }); var finalPercent = computed(() => { var percent = props.percent; if (percent > 100) percent = 100; if (percent < 0) percent = 0; return percent; }); watch(() => finalPercent.value, (_, oldVal) => { data._lastPercent = oldVal; clearTimer(); _animate(); }); var _animate = () => { var percent = finalPercent.value; if (!props.active) { data.curPercent = percent; return; } data.curPercent = props.activeMode === "forwards" ? data._lastPercent : 0; data._timerId = setInterval(() => { if (percent <= data.curPercent + 1) { clearTimer(); data.curPercent = percent; emit("activeend", initUniCustomEvent(data.$uniProgressElement, new UniProgressActiveendEvent(percent))); } else { ++data.curPercent; } }, props.duration); }; var clearTimer = () => { clearInterval(data._timerId); }; onMounted(() => { instance === null || instance === void 0 || instance.$waitNativeRender(() => { var _instance$proxy; if (!instance) return; data.$uniProgressElement = (_instance$proxy = instance.proxy) === null || _instance$proxy === void 0 ? void 0 : _instance$proxy.$el; data.$uniProgressElement._getAttribute = (key) => { var _props$keyString$toSt, _props$keyString; var keyString = camelize(key); return props[keyString] !== null ? (_props$keyString$toSt = (_props$keyString = props[keyString]) === null || _props$keyString === void 0 ? void 0 : _props$keyString.toString()) !== null && _props$keyString$toSt !== void 0 ? _props$keyString$toSt : null : null; }; _animate(); }); }); onUnmounted(() => { clearTimer(); }); return () => { return createVNode("uni-progress-element", { "class": "uni-progress", "style": styleUniProgress.value }, [createVNode("view", { "class": "uni-progress-bar", "style": barStyle.value }, [createVNode("view", { "class": "uni-progress-inner-bar", "style": innerBarStyle.value }, null, 4)], 4), props.showInfo ? createVNode("view", { "class": "uni-progress-info", "style": textStyle.value }, [textStr.value], 4) : null], 4); }; } }); const progress$1 = /* @__PURE__ */ Object.defineProperty({ __proto__: null, UniProgressActiveendEvent, UniProgressElement, default: progress }, Symbol.toStringTag, { value: "Module" }); var _style_picker_view = { "uni-picker-view": { "": { position: "relative" } }, "uni-picker-view-wrapper": { "": { display: "flex", flexDirection: "row", position: "absolute", top: "0", left: "0", right: "0", bottom: "0", overflow: "hidden" } } }; var _style_picker_column = { "uni-picker-view-column": { "": { flex: "1", position: "relative", alignItems: "stretch", overflow: "hidden" } }, "uni-picker-view-mask": { "": { position: "absolute", top: "0", left: "0", right: "0", bottom: "0", pointerEvents: "none" } }, "uni-picker-view-mask-top": { "": { bottom: "0", backgroundImage: "linear-gradient(to bottom,rgba(255, 255, 255, 0.95),rgba(255, 255, 255, 0.6))" } }, "uni-picker-view-mask-bottom": { "": { top: "0", backgroundImage: "linear-gradient(to top,rgba(255, 255, 255, 0.95),rgba(255, 255, 255, 0.6))" } }, "uni-picker-view-group": { "": { flexDirection: "column", position: "absolute", top: "0", left: "0", right: "0", bottom: "0" } }, "uni-picker-view-content": { "": { flexDirection: "column", paddingTop: "0", paddingRight: "0", paddingBottom: "0", paddingLeft: "0" } }, "uni-picker-view-indicator": { "": { position: "absolute", left: "0", right: "0", top: "0", height: "34px", borderColor: "#e5e5e5", borderTopWidth: "1px", borderBottomWidth: "1px", pointerEvents: "none" } } }; class UniPickerViewColumnElement extends UniElementImpl { constructor(data, pageNode) { super(data, pageNode); this.tagName = "PICKER-VIEW-COLUMN"; this.nodeName = this.tagName; this._getAttribute = (key) => { return null; }; } getAnyAttribute(key) { var value = this._getAttribute(key); if (value != null) { return value; } return super.getAnyAttribute(key); } } class UniPickerViewChangeEventDetail { constructor(value) { this.value = value; } } class UniPickerViewChangeEvent extends UniCustomEvent { constructor(value) { super("change", { detail: new UniPickerViewChangeEventDetail(value) }); } } class UniPickerViewElement extends UniElementImpl { constructor(data, pageNode) { super(data, pageNode); this.tagName = "PICKER-VIEW"; this.nodeName = this.tagName; this._getAttribute = (key) => { return null; }; } getAnyAttribute(key) { var value = this._getAttribute(key); if (value != null) { return value; } return super.getAnyAttribute(key); } } const pickerView = /* @__PURE__ */ defineBuiltInComponent({ name: "PickerView", rootElement: { name: "uni-picker-view-element", // @ts-expect-error not web element class: UniPickerViewElement }, props: { value: { type: Array, default: [] }, indicatorStyle: { type: String, default: "" }, maskTopStyle: { type: String, default: "" }, maskBottomStyle: { type: String, default: "" } }, emits: ["change"], setup(props, _ref) { var { emit, expose, slots } = _ref; var data = reactive({ $uniPickerViewElement: null, $items: [], valueSync: [] }); watch(() => props.value, (val) => { val.forEach((_val, index2) => { if (data.$items.length > index2) { var _data$$items$index$$$; var fn = (_data$$items$index$$$ = data.$items[index2].$.exposed) === null || _data$$items$index$$$ === void 0 ? void 0 : _data$$items$index$$$.setCurrent; fn(_val); } }); data.valueSync = [...val]; }, { immediate: true }); provide("pickerViewProps", props); var pickerViewElementRef = ref(); var instance = getCurrentInstance(); var _pickerViewUpdateHandler = (vm, type) => { if (type == "add") { data.$items.push(vm); if (data.$items.length > data.valueSync.length) { data.valueSync.push(0); } } else { var index2 = data.$items.indexOf(vm); if (index2 != -1) { data.$items.splice(index2, 1); data.valueSync.splice(index2, 1); } } }; var getItemValue = (vm) => { var index2 = data.$items.indexOf(vm); if (index2 != -1) { if (props.value.length > index2) { return props.value[index2]; } } return 0; }; var setItemValue = (vm, val) => { var index2 = data.$items.indexOf(vm); if (index2 != -1) { if (data.valueSync.length > index2) { data.valueSync[index2] = val; } emit("change", initUniCustomEvent(pickerViewElementRef.value, new UniPickerViewChangeEvent([...data.valueSync]))); } }; expose({ _pickerViewUpdateHandler, getItemValue, setItemValue }); onMounted(() => { instance === null || instance === void 0 || instance.$waitNativeRender(() => { if (!instance || !pickerViewElementRef.value) return; pickerViewElementRef.value._getAttribute = (key) => { var _props$keyString$toSt, _props$keyString; var keyString = camelize(key); return props[keyString] !== null ? (_props$keyString$toSt = (_props$keyString = props[keyString]) === null || _props$keyString === void 0 ? void 0 : _props$keyString.toString()) !== null && _props$keyString$toSt !== void 0 ? _props$keyString$toSt : null : null; }; }); }); var styleUniPickerView = _style_picker_view["uni-picker-view"][""]; var styleUniPickerViewWrapper = _style_picker_view["uni-picker-view-wrapper"][""]; return () => { var _slots$default; return createVNode("uni-picker-view-element", { "ref": pickerViewElementRef, "class": "uni-picker-view", "style": styleUniPickerView }, [createVNode("view", { "class": "uni-picker-view-wrapper", "style": styleUniPickerViewWrapper }, [(_slots$default = slots.default) === null || _slots$default === void 0 ? void 0 : _slots$default.call(slots)], 4)], 4); }; } }); const pickerView$1 = /* @__PURE__ */ Object.defineProperty({ __proto__: null, UniPickerViewChangeEvent, UniPickerViewElement, default: pickerView }, Symbol.toStringTag, { value: "Module" }); const pickerViewColumn = /* @__PURE__ */ defineBuiltInComponent({ name: "PickerViewColumn", rootElement: { name: "uni-picker-view-column-element", // @ts-expect-error class: UniPickerViewColumnElement }, setup(_props, _ref) { var { slots, expose } = _ref; var instance = getCurrentInstance(); var pickerColumnRef = ref(); var indicator = ref(); var scrollViewRef = ref(); var contentRef = ref(); var pickerViewProps = inject("pickerViewProps"); var data = reactive({ height: 0, indicatorHeight: 0, current: 0, scrollToElementTime: 0, maskTopStyle: "", maskBottomStyle: "", indicatorStyle: "", contentStyle: "", _isMounted: false }); var formatUserStyle = (styleStr) => { var formatUserStyle2 = parseStringStyle(styleStr); if (isString(formatUserStyle2["background-color"]) || isString(formatUserStyle2["background"])) { formatUserStyle2 = Object.assign({}, formatUserStyle2, { backgroundImage: "", background: formatUserStyle2["background-color"] || formatUserStyle2["background"] }); } return formatUserStyle2; }; var contentStyle = computed(() => { return Object.assign({}, _style_picker_column["uni-picker-view-content"][""], parseStringStyle(data.contentStyle)); }); var maskTopStyle = computed(() => { var userStyle = formatUserStyle(pickerViewProps.maskTopStyle); var style = Object.assign({}, _style_picker_column["uni-picker-view-mask"][""], _style_picker_column["uni-picker-view-mask-top"][""], parseStringStyle(data.maskTopStyle), userStyle); return style; }); var maskBottomStyle = computed(() => { var userStyle = formatUserStyle(pickerViewProps.maskBottomStyle); return Object.assign({}, _style_picker_column["uni-picker-view-mask"][""], _style_picker_column["uni-picker-view-mask-bottom"][""], parseStringStyle(data.maskBottomStyle), userStyle); }); var indicatorStyle = computed(() => { var val = Object.assign({}, _style_picker_column["uni-picker-view-indicator"][""], parseStringStyle(pickerViewProps.indicatorStyle), parseStringStyle(data.indicatorStyle)); return val; }); var styleUniPickerViewColumn = computed(() => { return Object.assign({}, _style_picker_column["uni-picker-view-column"][""]); }); var styleUniPickerViewGroup = computed(() => { return Object.assign({}, _style_picker_column["uni-picker-view-group"][""]); }); var styleViewMask = computed(() => { return Object.assign({}, _style_picker_column["uni-picker-view-mask"][""]); }); var init2 = () => { data.height = pickerColumnRef.value.offsetHeight; data.indicatorHeight = indicator.value.offsetHeight; var padding = (data.height - data.indicatorHeight) / 2; var maskPosition = "".concat(data.height - padding, "px"); data.maskTopStyle += ";bottom:".concat(maskPosition); data.maskBottomStyle += ";top:".concat(maskPosition); data.indicatorStyle = ";top:".concat(padding, "px"); data.contentStyle = "padding-top:".concat(padding, "px;padding-bottom:").concat(padding, "px"); nextTick(() => { if (data.current != 0) { setCurrent(data.current); } }); }; var onScrollend = (e) => { if (Date.now() - data.scrollToElementTime < 200) { return; } var y = e.detail.scrollTop; var current = Math.round(y / data.indicatorHeight); if (y % data.indicatorHeight != 0) { setCurrent(current); } else { data.current = current; } }; var setCurrent = (current) => { var scrollTop = current * data.indicatorHeight; scrollViewRef.value.setAnyAttribute("scroll-top", scrollTop); data.current = current; data.scrollToElementTime = Date.now(); }; var uniResizeObserver = new UniResizeObserver((entries) => { init2(); }); var created = () => { var _instance$parent; var $parent = (instance === null || instance === void 0 || (_instance$parent = instance.parent) === null || _instance$parent === void 0 ? void 0 : _instance$parent.type.name) === "PickerView" ? instance === null || instance === void 0 ? void 0 : instance.parent : null; if ($parent !== null) { $dispatchParent(instance === null || instance === void 0 ? void 0 : instance.proxy, "PickerView", "_pickerViewUpdateHandler", instance === null || instance === void 0 ? void 0 : instance.proxy, "add"); data.current = $dispatchParent(instance === null || instance === void 0 ? void 0 : instance.proxy, "PickerView", "getItemValue", instance === null || instance === void 0 ? void 0 : instance.proxy); } }; created(); expose({ setCurrent }); onMounted(() => { instance === null || instance === void 0 || instance.$waitNativeRender(() => { if (!instance || !pickerColumnRef.value) return; init2(); setTimeout(() => { data._isMounted = true; }, 1e3); uniResizeObserver.observe(pickerColumnRef.value); }); }); onUnmounted(() => { var ctx = instance === null || instance === void 0 ? void 0 : instance.proxy; uniResizeObserver.disconnect(); $dispatch(ctx, "PickerView", "_pickerViewUpdateHandler", ctx, "remove"); }); watch(() => data.current, (val, oldVal) => { if (data._isMounted && val != oldVal) { var ctx = instance === null || instance === void 0 ? void 0 : instance.proxy; $dispatch(ctx, "PickerView", "setItemValue", ctx, val); } }); return () => { var _slots$default; return createVNode("uni-picker-view-column-element", { "class": "uni-picker-view-column", "style": styleUniPickerViewColumn.value, "ref": pickerColumnRef }, [createVNode("scroll-view", { "deceleration-rate": 0.3, "onScrollend": onScrollend, "class": "uni-picker-view-group", "style": styleUniPickerViewGroup.value, "scroll-with-animation": data._isMounted, "direction": "vertical", "show-scrollbar": false, "ref": scrollViewRef }, [createVNode("view", { "class": "uni-picker-view-content", "style": contentStyle.value, "ref": contentRef }, [(_slots$default = slots.default) === null || _slots$default === void 0 ? void 0 : _slots$default.call(slots)], 4)], 44, ["onScrollend", "scroll-with-animation"]), createVNode("view", { "userInteractionEnabled": false, "class": "uni-picker-view-mask", "style": styleViewMask.value }, [createVNode("view", { "class": "uni-picker-view-mask uni-picker-view-mask-top", "style": maskTopStyle.value }, null, 4), createVNode("view", { "class": "uni-picker-view-mask uni-picker-view-mask-bottom", "style": maskBottomStyle.value }, null, 4)], 4), createVNode("view", { "ref": indicator, "userInteractionEnabled": false, "class": "uni-picker-view-indicator", "style": indicatorStyle.value }, null, 4)], 4); }; } }); const pickerViewColumn$1 = /* @__PURE__ */ Object.defineProperty({ __proto__: null, UniPickerViewColumnElement, default: pickerViewColumn }, Symbol.toStringTag, { value: "Module" }); const components = /* @__PURE__ */ Object.defineProperty({ __proto__: null, Checkbox: checkbox$1, CheckboxGroup: checkboxGroup$1, Navigator: navigator$1, PickerView: pickerView$1, PickerViewColumn: pickerViewColumn$1, Progress: progress$1, Radio: radio$1, RadioGroup: radioGroup$1 }, Symbol.toStringTag, { value: "Module" }); const index = { uni: uni$1, getApp: getApp$1, getCurrentPages: getCurrentPages$1, __definePage: definePage, __registerApp: registerApp, initApp, components }; export { index as default };