EASYAIuniappNewUI/node_modules/@dcloudio/uni-app-plus/dist/uni.x.runtime.esm.js
2025-02-08 18:50:38 +08:00

7129 lines
254 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

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("<navigator/> 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
};