import { withModifiers, createVNode, getCurrentInstance, ref, defineComponent, openBlock, createElementBlock, provide, computed, watch, onUnmounted, inject, onBeforeUnmount, mergeProps, injectHook, reactive, onActivated, onMounted, nextTick, onBeforeMount, withDirectives, vModelDynamic, vShow, shallowRef, watchEffect, isVNode, Fragment, markRaw, Comment, h, createTextVNode, createBlock, onBeforeActivate, onBeforeDeactivate, renderList, onDeactivated, createApp, isReactive, Transition, effectScope, withCtx, KeepAlive, resolveDynamicComponent, createElementVNode, normalizeStyle, renderSlot } from "vue"; import { isArray, isString, extend, remove, stringifyStyle, parseStringStyle, isPlainObject, isFunction, capitalize, camelize, hasOwn, isObject, toRawType, makeMap as makeMap$1, isPromise, hyphenate, invokeArrayFns as invokeArrayFns$1 } from "@vue/shared"; import { once, UNI_STORAGE_LOCALE, I18N_JSON_DELIMITERS, Emitter, passive, initCustomDatasetOnce, resolveComponentInstance, normalizeStyles, addLeadingSlash, invokeArrayFns, removeLeadingSlash, resolveOwnerVm, resolveOwnerEl, ON_WXS_INVOKE_CALL_METHOD, normalizeTarget, ON_RESIZE, ON_APP_ENTER_FOREGROUND, ON_APP_ENTER_BACKGROUND, ON_SHOW, ON_HIDE, ON_PAGE_SCROLL, ON_REACH_BOTTOM, EventChannel, SCHEME_RE, DATA_RE, getCustomDataset, LINEFEED, ON_ERROR, callOptions, ON_UNHANDLE_REJECTION, ON_PAGE_NOT_FOUND, PRIMARY_COLOR, getLen, debounce, isUniLifecycleHook, ON_LOAD, UniLifecycleHooks, invokeCreateErrorHandler, invokeCreateVueAppHook, parseQuery, NAVBAR_HEIGHT, ON_UNLOAD, ON_REACH_BOTTOM_DISTANCE, decodedQuery, WEB_INVOKE_APPSERVICE, ON_WEB_INVOKE_APP_SERVICE, ON_THEME_CHANGE, updateElementStyle, sortObject, OFF_THEME_CHANGE, ON_BACK_PRESS, parseUrl, addFont, ON_NAVIGATION_BAR_CHANGE, scrollTo, RESPONSIVE_MIN_WIDTH, onCreateVueApp, formatDateTime, ON_NAVIGATION_BAR_BUTTON_TAP, ON_NAVIGATION_BAR_SEARCH_INPUT_CLICKED, ON_NAVIGATION_BAR_SEARCH_INPUT_FOCUS_CHANGED, ON_NAVIGATION_BAR_SEARCH_INPUT_CHANGED, ON_NAVIGATION_BAR_SEARCH_INPUT_CONFIRMED, ON_PULL_DOWN_REFRESH } from "@dcloudio/uni-shared"; import { onCreateVueApp as onCreateVueApp2 } from "@dcloudio/uni-shared"; import { initVueI18n, isI18nStr, LOCALE_EN, LOCALE_ES, LOCALE_FR, LOCALE_ZH_HANS, LOCALE_ZH_HANT } from "@dcloudio/uni-i18n"; import { useRoute, createRouter, createWebHistory, createWebHashHistory, useRouter, isNavigationFailure, RouterView } from "vue-router"; const isEnableLocale = /* @__PURE__ */ once( () => typeof __uniConfig !== "undefined" && __uniConfig.locales && !!Object.keys(__uniConfig.locales).length ); let i18n; function getLocaleMessage() { const locale = uni.getLocale(); const locales = __uniConfig.locales; return locales[locale] || locales[__uniConfig.fallbackLocale] || locales.en || {}; } function formatI18n(message) { if (isI18nStr(message, I18N_JSON_DELIMITERS)) { return useI18n().f(message, getLocaleMessage(), I18N_JSON_DELIMITERS); } return message; } function resolveJsonObj(jsonObj, names) { if (names.length === 1) { if (jsonObj) { const _isI18nStr = (value2) => isString(value2) && isI18nStr(value2, I18N_JSON_DELIMITERS); const _name = names[0]; let filterJsonObj = []; if (isArray(jsonObj) && (filterJsonObj = jsonObj.filter((item) => _isI18nStr(item[_name]))).length) { return filterJsonObj; } const value = jsonObj[names[0]]; if (_isI18nStr(value)) { return jsonObj; } } return; } const name = names.shift(); return resolveJsonObj(jsonObj && jsonObj[name], names); } function defineI18nProperties(obj, names) { return names.map((name) => defineI18nProperty(obj, name)); } function defineI18nProperty(obj, names) { const jsonObj = resolveJsonObj(obj, names); if (!jsonObj) { return false; } const prop = names[names.length - 1]; if (isArray(jsonObj)) { jsonObj.forEach((item) => defineI18nProperty(item, [prop])); } else { let value = jsonObj[prop]; Object.defineProperty(jsonObj, prop, { get() { return formatI18n(value); }, set(v2) { value = v2; } }); } return true; } function useI18n() { if (!i18n) { let locale; { { locale = navigator.cookieEnabled && window.localStorage && localStorage[UNI_STORAGE_LOCALE] || __uniConfig.locale || navigator.language; } } i18n = initVueI18n(locale); if (isEnableLocale()) { const localeKeys = Object.keys(__uniConfig.locales || {}); if (localeKeys.length) { localeKeys.forEach( (locale2) => i18n.add(locale2, __uniConfig.locales[locale2]) ); } i18n.setLocale(locale); } } return i18n; } function normalizeMessages(module, keys, values) { return keys.reduce((res, name, index2) => { res[module + name] = values[index2]; return res; }, {}); } const initI18nAsyncMsgsOnce = /* @__PURE__ */ once(() => { const name = "uni.async."; const keys = ["error"]; if (__UNI_FEATURE_I18N_EN__) { useI18n().add( LOCALE_EN, normalizeMessages(name, keys, [ "The connection timed out, click the screen to try again." ]), false ); } if (__UNI_FEATURE_I18N_ES__) { useI18n().add( LOCALE_ES, normalizeMessages(name, keys, [ "Se agotó el tiempo de conexión, haga clic en la pantalla para volver a intentarlo." ]), false ); } if (__UNI_FEATURE_I18N_FR__) { useI18n().add( LOCALE_FR, normalizeMessages(name, keys, [ "La connexion a expiré, cliquez sur l'écran pour réessayer." ]), false ); } if (__UNI_FEATURE_I18N_ZH_HANS__) { useI18n().add( LOCALE_ZH_HANS, normalizeMessages(name, keys, ["连接服务器超时,点击屏幕重试"]), false ); } if (__UNI_FEATURE_I18N_ZH_HANT__) { useI18n().add( LOCALE_ZH_HANT, normalizeMessages(name, keys, ["連接服務器超時,點擊屏幕重試"]), false ); } }); const initI18nShowActionSheetMsgsOnce = /* @__PURE__ */ once(() => { const name = "uni.showActionSheet."; const keys = ["cancel"]; if (__UNI_FEATURE_I18N_EN__) { useI18n().add(LOCALE_EN, normalizeMessages(name, keys, ["Cancel"]), false); } if (__UNI_FEATURE_I18N_ES__) { useI18n().add(LOCALE_ES, normalizeMessages(name, keys, ["Cancelar"]), false); } if (__UNI_FEATURE_I18N_FR__) { useI18n().add(LOCALE_FR, normalizeMessages(name, keys, ["Annuler"]), false); } if (__UNI_FEATURE_I18N_ZH_HANS__) { useI18n().add( LOCALE_ZH_HANS, normalizeMessages(name, keys, ["取消"]), false ); } if (__UNI_FEATURE_I18N_ZH_HANT__) { useI18n().add( LOCALE_ZH_HANT, normalizeMessages(name, keys, ["取消"]), false ); } }); const initI18nShowToastMsgsOnce = /* @__PURE__ */ once(() => { const name = "uni.showToast."; const keys = ["unpaired"]; if (__UNI_FEATURE_I18N_EN__) { useI18n().add( LOCALE_EN, normalizeMessages(name, keys, [ "Please note showToast must be paired with hideToast" ]), false ); } if (__UNI_FEATURE_I18N_ES__) { useI18n().add( LOCALE_ES, normalizeMessages(name, keys, [ "Tenga en cuenta que showToast debe estar emparejado con hideToast" ]), false ); } if (__UNI_FEATURE_I18N_FR__) { useI18n().add( LOCALE_FR, normalizeMessages(name, keys, [ "Veuillez noter que showToast doit être associé à hideToast" ]), false ); } if (__UNI_FEATURE_I18N_ZH_HANS__) { useI18n().add( LOCALE_ZH_HANS, normalizeMessages(name, keys, [ "请注意 showToast 与 hideToast 必须配对使用" ]), false ); } if (__UNI_FEATURE_I18N_ZH_HANT__) { useI18n().add( LOCALE_ZH_HANT, normalizeMessages(name, keys, [ "請注意 showToast 與 hideToast 必須配對使用" ]), false ); } }); const initI18nShowLoadingMsgsOnce = /* @__PURE__ */ once(() => { const name = "uni.showLoading."; const keys = ["unpaired"]; if (__UNI_FEATURE_I18N_EN__) { useI18n().add( LOCALE_EN, normalizeMessages(name, keys, [ "Please note showLoading must be paired with hideLoading" ]), false ); } if (__UNI_FEATURE_I18N_ES__) { useI18n().add( LOCALE_ES, normalizeMessages(name, keys, [ "Tenga en cuenta que showLoading debe estar emparejado con hideLoading" ]), false ); } if (__UNI_FEATURE_I18N_FR__) { useI18n().add( LOCALE_FR, normalizeMessages(name, keys, [ "Veuillez noter que showLoading doit être associé à hideLoading" ]), false ); } if (__UNI_FEATURE_I18N_ZH_HANS__) { useI18n().add( LOCALE_ZH_HANS, normalizeMessages(name, keys, [ "请注意 showLoading 与 hideLoading 必须配对使用" ]), false ); } if (__UNI_FEATURE_I18N_ZH_HANT__) { useI18n().add( LOCALE_ZH_HANT, normalizeMessages(name, keys, [ "請注意 showLoading 與 hideLoading 必須配對使用" ]), false ); } }); const initI18nShowModalMsgsOnce = /* @__PURE__ */ once(() => { const name = "uni.showModal."; const keys = ["cancel", "confirm"]; if (__UNI_FEATURE_I18N_EN__) { useI18n().add( LOCALE_EN, normalizeMessages(name, keys, ["Cancel", "OK"]), false ); } if (__UNI_FEATURE_I18N_ES__) { useI18n().add( LOCALE_ES, normalizeMessages(name, keys, ["Cancelar", "OK"]), false ); } if (__UNI_FEATURE_I18N_FR__) { useI18n().add( LOCALE_FR, normalizeMessages(name, keys, ["Annuler", "OK"]), false ); } if (__UNI_FEATURE_I18N_ZH_HANS__) { useI18n().add( LOCALE_ZH_HANS, normalizeMessages(name, keys, ["取消", "确定"]), false ); } if (__UNI_FEATURE_I18N_ZH_HANT__) { useI18n().add( LOCALE_ZH_HANT, normalizeMessages(name, keys, ["取消", "確定"]), false ); } }); const initI18nChooseFileMsgsOnce = /* @__PURE__ */ once(() => { const name = "uni.chooseFile."; const keys = ["notUserActivation"]; if (__UNI_FEATURE_I18N_EN__) { useI18n().add( LOCALE_EN, normalizeMessages(name, keys, [ "File chooser dialog can only be shown with a user activation" ]), false ); } if (__UNI_FEATURE_I18N_ES__) { useI18n().add( LOCALE_ES, normalizeMessages(name, keys, [ "El cuadro de diálogo del selector de archivos solo se puede mostrar con la activación del usuario" ]), false ); } if (__UNI_FEATURE_I18N_FR__) { useI18n().add( LOCALE_FR, normalizeMessages(name, keys, [ "La boîte de dialogue du sélecteur de fichier ne peut être affichée qu'avec une activation par l'utilisateur" ]), false ); } if (__UNI_FEATURE_I18N_ZH_HANS__) { useI18n().add( LOCALE_ZH_HANS, normalizeMessages(name, keys, ["文件选择器对话框只能在由用户激活时显示"]), false ); } if (__UNI_FEATURE_I18N_ZH_HANT__) { useI18n().add( LOCALE_ZH_HANT, normalizeMessages(name, keys, ["文件選擇器對話框只能在由用戶激活時顯示"]), false ); } }); const initI18nSetClipboardDataMsgsOnce = /* @__PURE__ */ once(() => { const name = "uni.setClipboardData."; const keys = ["success", "fail"]; if (__UNI_FEATURE_I18N_EN__) { useI18n().add( LOCALE_EN, normalizeMessages(name, keys, [ "Content copied", "Copy failed, please copy manually" ]), false ); } if (__UNI_FEATURE_I18N_ES__) { useI18n().add( LOCALE_ES, normalizeMessages(name, keys, [ "Contenido copiado", "Error al copiar, copie manualmente" ]), false ); } if (__UNI_FEATURE_I18N_FR__) { useI18n().add( LOCALE_FR, normalizeMessages(name, keys, [ "Contenu copié", "Échec de la copie, copiez manuellement" ]), false ); } if (__UNI_FEATURE_I18N_ZH_HANS__) { useI18n().add( LOCALE_ZH_HANS, normalizeMessages(name, keys, ["内容已复制", "复制失败,请手动复制"]), false ); } if (__UNI_FEATURE_I18N_ZH_HANT__) { useI18n().add( LOCALE_ZH_HANT, normalizeMessages(name, keys, ["內容已復制", "復制失敗,請手動復製"]), false ); } }); const initI18nGetClipboardDataMsgsOnce = /* @__PURE__ */ once(() => { const name = "uni.getClipboardData."; const keys = ["fail"]; if (__UNI_FEATURE_I18N_EN__) { useI18n().add( LOCALE_EN, normalizeMessages(name, keys, ["Reading failed, please paste manually"]), false ); } if (__UNI_FEATURE_I18N_ES__) { useI18n().add( LOCALE_ES, normalizeMessages(name, keys, ["Error de lectura, pegue manualmente"]), false ); } if (__UNI_FEATURE_I18N_FR__) { useI18n().add( LOCALE_FR, normalizeMessages(name, keys, [ "Échec de la lecture, veuillez coller manuellement" ]), false ); } if (__UNI_FEATURE_I18N_ZH_HANS__) { useI18n().add( LOCALE_ZH_HANS, normalizeMessages(name, keys, ["读取失败,请手动粘贴"]), false ); } if (__UNI_FEATURE_I18N_ZH_HANT__) { useI18n().add( LOCALE_ZH_HANT, normalizeMessages(name, keys, ["讀取失敗,請手動粘貼"]), false ); } }); const initI18nPickerMsgsOnce = /* @__PURE__ */ once(() => { const name = "uni.picker."; const keys = ["done", "cancel"]; if (__UNI_FEATURE_I18N_EN__) { useI18n().add( LOCALE_EN, normalizeMessages(name, keys, ["Done", "Cancel"]), false ); } if (__UNI_FEATURE_I18N_ES__) { useI18n().add( LOCALE_ES, normalizeMessages(name, keys, ["OK", "Cancelar"]), false ); } if (__UNI_FEATURE_I18N_FR__) { useI18n().add( LOCALE_FR, normalizeMessages(name, keys, ["OK", "Annuler"]), false ); } if (__UNI_FEATURE_I18N_ZH_HANS__) { useI18n().add( LOCALE_ZH_HANS, normalizeMessages(name, keys, ["完成", "取消"]), false ); } if (__UNI_FEATURE_I18N_ZH_HANT__) { useI18n().add( LOCALE_ZH_HANT, normalizeMessages(name, keys, ["完成", "取消"]), false ); } }); const initI18nVideoMsgsOnce = /* @__PURE__ */ once(() => { const name = "uni.video."; const keys = ["danmu", "volume"]; if (__UNI_FEATURE_I18N_EN__) { useI18n().add( LOCALE_EN, normalizeMessages(name, keys, ["Danmu", "Volume"]), false ); } if (__UNI_FEATURE_I18N_ES__) { useI18n().add( LOCALE_ES, normalizeMessages(name, keys, ["Danmu", "Volumen"]), false ); } if (__UNI_FEATURE_I18N_FR__) { useI18n().add( LOCALE_FR, normalizeMessages(name, keys, ["Danmu", "Le Volume"]), false ); } if (__UNI_FEATURE_I18N_ZH_HANS__) { useI18n().add( LOCALE_ZH_HANS, normalizeMessages(name, keys, ["弹幕", "音量"]), false ); } if (__UNI_FEATURE_I18N_ZH_HANT__) { useI18n().add( LOCALE_ZH_HANT, normalizeMessages(name, keys, ["彈幕", "音量"]), false ); } }); const initI18nChooseLocationMsgsOnce = /* @__PURE__ */ once(() => { const name = "uni.chooseLocation."; const keys = ["search", "cancel"]; if (__UNI_FEATURE_I18N_EN__) { useI18n().add( LOCALE_EN, normalizeMessages(name, keys, ["Find Place", "Cancel"]), false ); } if (__UNI_FEATURE_I18N_ES__) { useI18n().add( LOCALE_ES, normalizeMessages(name, keys, ["Encontrar", "Cancelar"]), false ); } if (__UNI_FEATURE_I18N_FR__) { useI18n().add( LOCALE_FR, normalizeMessages(name, keys, ["Trouve", "Annuler"]), false ); } if (__UNI_FEATURE_I18N_ZH_HANS__) { useI18n().add( LOCALE_ZH_HANS, normalizeMessages(name, keys, ["搜索地点", "取消"]), false ); } if (__UNI_FEATURE_I18N_ZH_HANT__) { useI18n().add( LOCALE_ZH_HANT, normalizeMessages(name, keys, ["搜索地點", "取消"]), false ); } }); function initNavigationBarI18n(navigationBar) { if (isEnableLocale()) { return defineI18nProperties(navigationBar, [ ["titleText"], ["searchInput", "placeholder"], ["buttons", "text"] ]); } } function initTabBarI18n(tabBar2) { if (isEnableLocale() && tabBar2.list) { tabBar2.list.forEach((item) => { defineI18nProperty(item, ["text"]); }); } return tabBar2; } function initBridge(subscribeNamespace) { const emitter2 = new Emitter(); return { on(event, callback) { return emitter2.on(event, callback); }, once(event, callback) { return emitter2.once(event, callback); }, off(event, callback) { return emitter2.off(event, callback); }, emit(event, ...args) { return emitter2.emit(event, ...args); }, subscribe(event, callback, once2 = false) { emitter2[once2 ? "once" : "on"](`${subscribeNamespace}.${event}`, callback); }, unsubscribe(event, callback) { emitter2.off(`${subscribeNamespace}.${event}`, callback); }, subscribeHandler(event, args, pageId) { emitter2.emit(`${subscribeNamespace}.${event}`, args, pageId); } }; } const INVOKE_VIEW_API = "invokeViewApi"; const INVOKE_SERVICE_API = "invokeServiceApi"; let invokeServiceMethodId = 1; const invokeServiceMethod = (name, args, callback) => { const { subscribe, publishHandler } = UniViewJSBridge; const id2 = callback ? invokeServiceMethodId++ : 0; callback && subscribe(INVOKE_SERVICE_API + "." + id2, callback, true); publishHandler(INVOKE_SERVICE_API, { id: id2, name, args }); }; const viewMethods = /* @__PURE__ */ Object.create(null); function normalizeViewMethodName(pageId, name) { return pageId + "." + name; } function subscribeViewMethod(pageId, wrapper2) { UniViewJSBridge.subscribe( normalizeViewMethodName(pageId, INVOKE_VIEW_API), wrapper2 ? wrapper2(onInvokeViewMethod) : onInvokeViewMethod ); } function unsubscribeViewMethod(pageId) { UniViewJSBridge.unsubscribe(normalizeViewMethodName(pageId, INVOKE_VIEW_API)); Object.keys(viewMethods).forEach((name) => { if (name.indexOf(pageId + ".") === 0) { delete viewMethods[name]; } }); } function registerViewMethod(pageId, name, fn) { name = normalizeViewMethodName(pageId, name); if (!viewMethods[name]) { viewMethods[name] = fn; } } function unregisterViewMethod(pageId, name) { name = normalizeViewMethodName(pageId, name); delete viewMethods[name]; } function onInvokeViewMethod({ id: id2, name, args }, pageId) { name = normalizeViewMethodName(pageId, name); const publish = (res) => { id2 && UniViewJSBridge.publishHandler(INVOKE_VIEW_API + "." + id2, res); }; const handler = viewMethods[name]; if (handler) { handler(args, publish); } else { publish({}); } } const ViewJSBridge = /* @__PURE__ */ extend( /* @__PURE__ */ initBridge("service"), { invokeServiceMethod } ); const LONGPRESS_TIMEOUT = 350; const LONGPRESS_THRESHOLD = 10; const passiveOptions$2 = /* @__PURE__ */ passive(true); let longPressTimer; function clearLongPressTimer() { if (longPressTimer) { clearTimeout(longPressTimer); longPressTimer = null; } } let startPageX = 0; let startPageY = 0; function touchstart(evt) { clearLongPressTimer(); if (evt.touches.length !== 1) { return; } const { pageX, pageY } = evt.touches[0]; startPageX = pageX; startPageY = pageY; longPressTimer = setTimeout(function() { const customEvent = new CustomEvent("longpress", { bubbles: true, cancelable: true, // @ts-ignore target: evt.target, currentTarget: evt.currentTarget }); customEvent.touches = evt.touches; customEvent.changedTouches = evt.changedTouches; evt.target.dispatchEvent(customEvent); }, LONGPRESS_TIMEOUT); } function touchmove(evt) { if (!longPressTimer) { return; } if (evt.touches.length !== 1) { return clearLongPressTimer(); } const { pageX, pageY } = evt.touches[0]; if (Math.abs(pageX - startPageX) > LONGPRESS_THRESHOLD || Math.abs(pageY - startPageY) > LONGPRESS_THRESHOLD) { return clearLongPressTimer(); } } function initLongPress() { window.addEventListener("touchstart", touchstart, passiveOptions$2); window.addEventListener("touchmove", touchmove, passiveOptions$2); window.addEventListener("touchend", clearLongPressTimer, passiveOptions$2); window.addEventListener("touchcancel", clearLongPressTimer, passiveOptions$2); } function checkValue$1(value, defaultValue) { const newValue = Number(value); return isNaN(newValue) ? defaultValue : newValue; } function getWindowWidth$1() { const screenFix = /^Apple/.test(navigator.vendor) && typeof window.orientation === "number"; const landscape = screenFix && Math.abs(window.orientation) === 90; var screenWidth = screenFix ? Math[landscape ? "max" : "min"](screen.width, screen.height) : screen.width; var windowWidth = Math.min( window.innerWidth, document.documentElement.clientWidth, screenWidth ) || screenWidth; return windowWidth; } function useRem() { const config = __uniConfig.globalStyle || {}; const maxWidth2 = checkValue$1(config.rpxCalcMaxDeviceWidth, 960); const baseWidth2 = checkValue$1(config.rpxCalcBaseDeviceWidth, 375); function updateRem() { let width = getWindowWidth$1(); width = width <= maxWidth2 ? width : baseWidth2; document.documentElement.style.fontSize = width / 23.4375 + "px"; } updateRem(); document.addEventListener("DOMContentLoaded", updateRem); window.addEventListener("load", updateRem); window.addEventListener("resize", updateRem); } function initView() { useRem(); initCustomDatasetOnce(); if (__UNI_FEATURE_LONGPRESS__) { initLongPress(); } } function getDefaultExportFromCjs(x) { return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, "default") ? x["default"] : x; } var attrs = ["top", "left", "right", "bottom"]; var inited$1; var elementComputedStyle = {}; var support; function getSupport() { if (!("CSS" in window) || typeof CSS.supports != "function") { support = ""; } else if (CSS.supports("top: env(safe-area-inset-top)")) { support = "env"; } else if (CSS.supports("top: constant(safe-area-inset-top)")) { support = "constant"; } else { support = ""; } return support; } function init() { support = typeof support === "string" ? support : getSupport(); if (!support) { attrs.forEach(function(attr2) { elementComputedStyle[attr2] = 0; }); return; } function setStyle(el, style) { var elStyle = el.style; Object.keys(style).forEach(function(key) { var val = style[key]; elStyle[key] = val; }); } var cbs = []; function parentReady(callback) { if (callback) { cbs.push(callback); } else { cbs.forEach(function(cb) { cb(); }); } } var passiveEvents = false; try { var opts = Object.defineProperty({}, "passive", { get: function() { passiveEvents = { passive: true }; } }); window.addEventListener("test", null, opts); } catch (e2) { } function addChild(parent, attr2) { var a1 = document.createElement("div"); var a2 = document.createElement("div"); var a1Children = document.createElement("div"); var a2Children = document.createElement("div"); var W = 100; var MAX = 1e4; var aStyle = { position: "absolute", width: W + "px", height: "200px", boxSizing: "border-box", overflow: "hidden", paddingBottom: support + "(safe-area-inset-" + attr2 + ")" }; setStyle(a1, aStyle); setStyle(a2, aStyle); setStyle(a1Children, { transition: "0s", animation: "none", width: "400px", height: "400px" }); setStyle(a2Children, { transition: "0s", animation: "none", width: "250%", height: "250%" }); a1.appendChild(a1Children); a2.appendChild(a2Children); parent.appendChild(a1); parent.appendChild(a2); parentReady(function() { a1.scrollTop = a2.scrollTop = MAX; var a1LastScrollTop = a1.scrollTop; var a2LastScrollTop = a2.scrollTop; function onScroll() { if (this.scrollTop === (this === a1 ? a1LastScrollTop : a2LastScrollTop)) { return; } a1.scrollTop = a2.scrollTop = MAX; a1LastScrollTop = a1.scrollTop; a2LastScrollTop = a2.scrollTop; attrChange(attr2); } a1.addEventListener("scroll", onScroll, passiveEvents); a2.addEventListener("scroll", onScroll, passiveEvents); }); var computedStyle = getComputedStyle(a1); Object.defineProperty(elementComputedStyle, attr2, { configurable: true, get: function() { return parseFloat(computedStyle.paddingBottom); } }); } var parentDiv = document.createElement("div"); setStyle(parentDiv, { position: "absolute", left: "0", top: "0", width: "0", height: "0", zIndex: "-1", overflow: "hidden", visibility: "hidden" }); attrs.forEach(function(key) { addChild(parentDiv, key); }); document.body.appendChild(parentDiv); parentReady(); inited$1 = true; } function getAttr(attr2) { if (!inited$1) { init(); } return elementComputedStyle[attr2]; } var changeAttrs = []; function attrChange(attr2) { if (!changeAttrs.length) { setTimeout(function() { var style = {}; changeAttrs.forEach(function(attr3) { style[attr3] = elementComputedStyle[attr3]; }); changeAttrs.length = 0; callbacks.forEach(function(callback) { callback(style); }); }, 0); } changeAttrs.push(attr2); } var callbacks = []; function onChange(callback) { if (!getSupport()) { return; } if (!inited$1) { init(); } if (typeof callback === "function") { callbacks.push(callback); } } function offChange(callback) { var index2 = callbacks.indexOf(callback); if (index2 >= 0) { callbacks.splice(index2, 1); } } var safeAreaInsets = { get support() { return (typeof support === "string" ? support : getSupport()).length != 0; }, get top() { return getAttr("top"); }, get left() { return getAttr("left"); }, get right() { return getAttr("right"); }, get bottom() { return getAttr("bottom"); }, onChange, offChange }; var out = safeAreaInsets; const safeAreaInsets$1 = /* @__PURE__ */ getDefaultExportFromCjs(out); const onEventPrevent = /* @__PURE__ */ withModifiers(() => { }, ["prevent"]); const onEventStop = /* @__PURE__ */ withModifiers(() => { }, ["stop"]); function getWindowOffsetCssVar(style, name) { return parseInt((style.getPropertyValue(name).match(/\d+/) || ["0"])[0]); } function getWindowTop() { const style = document.documentElement.style; const top = getWindowOffsetCssVar(style, "--window-top"); return top ? top + safeAreaInsets$1.top : 0; } function getWindowOffset() { const style = document.documentElement.style; const top = getWindowTop(); const bottom = getWindowOffsetCssVar(style, "--window-bottom"); const left = getWindowOffsetCssVar(style, "--window-left"); const right = getWindowOffsetCssVar(style, "--window-right"); const topWindowHeight = getWindowOffsetCssVar(style, "--top-window-height"); return { top, bottom: bottom ? bottom + safeAreaInsets$1.bottom : 0, left: left ? left + safeAreaInsets$1.left : 0, right: right ? right + safeAreaInsets$1.right : 0, topWindowHeight: topWindowHeight || 0 }; } function updateCssVar(cssVars) { const style = document.documentElement.style; Object.keys(cssVars).forEach((name) => { style.setProperty(name, cssVars[name]); }); } function updatePageCssVar(cssVars) { return updateCssVar(cssVars); } const sheetsMap = /* @__PURE__ */ new Map(); function updateStyle(id2, content) { let style = sheetsMap.get(id2); if (style && !(style instanceof HTMLStyleElement)) { removeStyle(id2); style = void 0; } if (!style) { style = document.createElement("style"); style.setAttribute("type", "text/css"); style.innerHTML = content; document.head.appendChild(style); } else { style.innerHTML = content; } sheetsMap.set(id2, style); } function removeStyle(id2) { let style = sheetsMap.get(id2); if (style) { if (style instanceof CSSStyleSheet) { document.adoptedStyleSheets.indexOf(style); document.adoptedStyleSheets = document.adoptedStyleSheets.filter( (s) => s !== style ); } else { document.head.removeChild(style); } sheetsMap.delete(id2); } } function PolySymbol(name) { return Symbol(process.env.NODE_ENV !== "production" ? "[uni-app]: " + name : name); } function hasRpx(str) { str = str + ""; return str.indexOf("rpx") !== -1 || str.indexOf("upx") !== -1; } function rpx2px(str, replace = false) { if (replace) { return rpx2pxWithReplace(str); } if (isString(str)) { const res = parseInt(str) || 0; if (hasRpx(str)) { return uni.upx2px(res); } return res; } return str; } function rpx2pxWithReplace(str) { if (!hasRpx(str)) { return str; } return str.replace(/(\d+(\.\d+)?)[ru]px/g, (_a, b) => { return uni.upx2px(parseFloat(b)) + "px"; }); } const ICON_PATH_CANCEL = "M20.928 10.176l-4.928 4.928-4.928-4.928-0.896 0.896 4.928 4.928-4.928 4.928 0.896 0.896 4.928-4.928 4.928 4.928 0.896-0.896-4.928-4.928 4.928-4.928-0.896-0.896zM16 2.080q-3.776 0-7.040 1.888-3.136 1.856-4.992 4.992-1.888 3.264-1.888 7.040t1.888 7.040q1.856 3.136 4.992 4.992 3.264 1.888 7.040 1.888t7.040-1.888q3.136-1.856 4.992-4.992 1.888-3.264 1.888-7.040t-1.888-7.040q-1.856-3.136-4.992-4.992-3.264-1.888-7.040-1.888zM16 28.64q-3.424 0-6.4-1.728-2.848-1.664-4.512-4.512-1.728-2.976-1.728-6.4t1.728-6.4q1.664-2.848 4.512-4.512 2.976-1.728 6.4-1.728t6.4 1.728q2.848 1.664 4.512 4.512 1.728 2.976 1.728 6.4t-1.728 6.4q-1.664 2.848-4.512 4.512-2.976 1.728-6.4 1.728z"; const ICON_PATH_CLEAR = "M16 0q-4.352 0-8.064 2.176-3.616 2.144-5.76 5.76-2.176 3.712-2.176 8.064t2.176 8.064q2.144 3.616 5.76 5.76 3.712 2.176 8.064 2.176t8.064-2.176q3.616-2.144 5.76-5.76 2.176-3.712 2.176-8.064t-2.176-8.064q-2.144-3.616-5.76-5.76-3.712-2.176-8.064-2.176zM22.688 21.408q0.32 0.32 0.304 0.752t-0.336 0.736-0.752 0.304-0.752-0.32l-5.184-5.376-5.376 5.184q-0.32 0.32-0.752 0.304t-0.736-0.336-0.304-0.752 0.32-0.752l5.376-5.184-5.184-5.376q-0.32-0.32-0.304-0.752t0.336-0.752 0.752-0.304 0.752 0.336l5.184 5.376 5.376-5.184q0.32-0.32 0.752-0.304t0.752 0.336 0.304 0.752-0.336 0.752l-5.376 5.184 5.184 5.376z"; const ICON_PATH_DOWNLOAD = "M15.808 1.696q-3.776 0-7.072 1.984-3.2 1.888-5.088 5.152-1.952 3.392-1.952 7.36 0 3.776 1.952 7.072 1.888 3.2 5.088 5.088 3.296 1.952 7.072 1.952 3.968 0 7.36-1.952 3.264-1.888 5.152-5.088 1.984-3.296 1.984-7.072 0-4-1.984-7.36-1.888-3.264-5.152-5.152-3.36-1.984-7.36-1.984zM20.864 18.592l-3.776 4.928q-0.448 0.576-1.088 0.576t-1.088-0.576l-3.776-4.928q-0.448-0.576-0.24-0.992t0.944-0.416h2.976v-8.928q0-0.256 0.176-0.432t0.4-0.176h1.216q0.224 0 0.4 0.176t0.176 0.432v8.928h2.976q0.736 0 0.944 0.416t-0.24 0.992z"; const ICON_PATH_INFO = "M15.808 0.128q-4.224 0-7.872 2.176-3.552 2.112-5.632 5.728-2.176 3.776-2.176 8.16 0 4.224 2.176 7.872 2.080 3.552 5.632 5.632 3.648 2.176 7.872 2.176 4.384 0 8.16-2.176 3.616-2.080 5.728-5.632 2.176-3.648 2.176-7.872 0-4.416-2.176-8.16-2.112-3.616-5.728-5.728-3.744-2.176-8.16-2.176zM16.864 23.776q0 0.064-0.064 0.064h-1.568q-0.096 0-0.096-0.064l-0.256-11.328q0-0.064 0.064-0.064h2.112q0.096 0 0.064 0.064l-0.256 11.328zM16 10.88q-0.576 0-0.976-0.4t-0.4-0.96 0.4-0.96 0.976-0.4 0.976 0.4 0.4 0.96-0.4 0.96-0.976 0.4z"; const ICON_PATH_SEARCH = "M20.928 22.688q-1.696 1.376-3.744 2.112-2.112 0.768-4.384 0.768-3.488 0-6.464-1.728-2.88-1.696-4.576-4.608-1.76-2.976-1.76-6.464t1.76-6.464q1.696-2.88 4.576-4.576 2.976-1.76 6.464-1.76t6.464 1.76q2.912 1.696 4.608 4.576 1.728 2.976 1.728 6.464 0 2.272-0.768 4.384-0.736 2.048-2.112 3.744l9.312 9.28-1.824 1.824-9.28-9.312zM12.8 23.008q2.784 0 5.184-1.376 2.304-1.376 3.68-3.68 1.376-2.4 1.376-5.184t-1.376-5.152q-1.376-2.336-3.68-3.68-2.4-1.408-5.184-1.408t-5.152 1.408q-2.336 1.344-3.68 3.68-1.408 2.368-1.408 5.152t1.408 5.184q1.344 2.304 3.68 3.68 2.368 1.376 5.152 1.376zM12.8 23.008v0z"; const ICON_PATH_SUCCESS_NO_CIRCLE = "M1.952 18.080q-0.32-0.352-0.416-0.88t0.128-0.976l0.16-0.352q0.224-0.416 0.64-0.528t0.8 0.176l6.496 4.704q0.384 0.288 0.912 0.272t0.88-0.336l17.312-14.272q0.352-0.288 0.848-0.256t0.848 0.352l-0.416-0.416q0.32 0.352 0.32 0.816t-0.32 0.816l-18.656 18.912q-0.32 0.352-0.8 0.352t-0.8-0.32l-7.936-8.064z"; const ICON_PATH_SUCCESS = "M15.808 0.16q-4.224 0-7.872 2.176-3.552 2.112-5.632 5.728-2.144 3.744-2.144 8.128 0 4.192 2.144 7.872 2.112 3.52 5.632 5.632 3.68 2.144 7.872 2.144 4.384 0 8.128-2.144 3.616-2.080 5.728-5.632 2.176-3.648 2.176-7.872 0-4.384-2.176-8.128-2.112-3.616-5.728-5.728-3.744-2.176-8.128-2.176zM24.832 11.328l-11.264 11.104q-0.032 0.032-0.112 0.032t-0.112-0.032l-5.216-5.376q-0.096-0.128 0-0.288l0.704-0.96q0.032-0.064 0.112-0.064t0.112 0.032l4.256 3.264q0.064 0.032 0.144 0.032t0.112-0.032l10.336-8.608q0.064-0.064 0.144-0.064t0.112 0.064l0.672 0.672q0.128 0.128 0 0.224z"; const ICON_PATH_WAITING = "M15.84 0.096q-4.224 0-7.872 2.176-3.552 2.112-5.632 5.728-2.144 3.744-2.144 8.128 0 4.192 2.144 7.872 2.112 3.52 5.632 5.632 3.68 2.144 7.872 2.144 4.384 0 8.128-2.144 3.616-2.080 5.728-5.632 2.176-3.648 2.176-7.872 0-4.384-2.176-8.128-2.112-3.616-5.728-5.728-3.744-2.176-8.128-2.176zM23.008 21.92l-0.512 0.896q-0.096 0.128-0.224 0.064l-8-3.808q-0.096-0.064-0.16-0.128-0.128-0.096-0.128-0.288l0.512-12.096q0-0.064 0.048-0.112t0.112-0.048h1.376q0.064 0 0.112 0.048t0.048 0.112l0.448 10.848 6.304 4.256q0.064 0.064 0.080 0.128t-0.016 0.128z"; const ICON_PATH_WARN = "M15.808 0.16q-4.224 0-7.872 2.176-3.552 2.112-5.632 5.728-2.144 3.744-2.144 8.128 0 4.192 2.144 7.872 2.112 3.52 5.632 5.632 3.68 2.144 7.872 2.144 4.384 0 8.128-2.144 3.616-2.080 5.728-5.632 2.176-3.648 2.176-7.872 0-4.384-2.176-8.128-2.112-3.616-5.728-5.728-3.744-2.176-8.128-2.176zM15.136 8.672h1.728q0.128 0 0.224 0.096t0.096 0.256l-0.384 10.24q0 0.064-0.048 0.112t-0.112 0.048h-1.248q-0.096 0-0.144-0.048t-0.048-0.112l-0.384-10.24q0-0.16 0.096-0.256t0.224-0.096zM16 23.328q-0.48 0-0.832-0.352t-0.352-0.848 0.352-0.848 0.832-0.352 0.832 0.352 0.352 0.848-0.352 0.848-0.832 0.352z"; const ICON_PATH_BACK = "M21.781 7.844l-9.063 8.594 9.063 8.594q0.25 0.25 0.25 0.609t-0.25 0.578q-0.25 0.25-0.578 0.25t-0.578-0.25l-9.625-9.125q-0.156-0.125-0.203-0.297t-0.047-0.359q0-0.156 0.047-0.328t0.203-0.297l9.625-9.125q0.25-0.25 0.578-0.25t0.578 0.25q0.25 0.219 0.25 0.578t-0.25 0.578z"; const ICON_PATH_CLOSE = "M17.25 16.156l7.375-7.313q0.281-0.281 0.281-0.641t-0.281-0.641q-0.25-0.25-0.625-0.25t-0.625 0.25l-7.375 7.344-7.313-7.344q-0.25-0.25-0.625-0.25t-0.625 0.25q-0.281 0.25-0.281 0.625t0.281 0.625l7.313 7.344-7.375 7.344q-0.281 0.25-0.281 0.625t0.281 0.625q0.125 0.125 0.281 0.188t0.344 0.063q0.156 0 0.328-0.063t0.297-0.188l7.375-7.344 7.375 7.406q0.125 0.156 0.297 0.219t0.328 0.063q0.188 0 0.344-0.078t0.281-0.203q0.281-0.25 0.281-0.609t-0.281-0.641l-7.375-7.406z"; const ICON_PATH_CONFIRM = "M31.562 4.9966666659375q0.435 0.399 0.435 0.87 0.036 0.58-0.399 0.98l-18.61 19.917q-0.145 0.145-0.327 0.217-0.073 0.037-0.145 0.11-0.254 0.035-0.472 0.035-0.29 0-0.544-0.036l-0.145-0.072q-0.109-0.073-0.217-0.182l-0.11-0.072L0.363 16.2786666659375q-0.327-0.399-0.363-0.907 0-0.544 0.363-1.016 0.435-0.326 0.961-0.362 0.527-0.036 0.962 0.362l9.722 9.542L29.712 5.0326666659375q0.399-0.363 0.943-0.363 0.544-0.036 0.907 0.327z"; function createSvgIconVNode(path, color = "#000", size = 27) { return createVNode( "svg", { width: size, height: size, viewBox: "0 0 32 32" }, [ createVNode( "path", { d: path, fill: color }, null, 8, ["d", "fill"] ) ], 8, ["width", "height"] ); } function useCurrentPageId() { { const { $pageInstance } = getCurrentInstance(); return $pageInstance && $pageInstance.proxy.$page.id; } } function getPageIdByVm(instance2) { const vm = resolveComponentInstance(instance2); if (vm.$page) { return vm.$page.id; } if (!vm.$) { return; } { const { $pageInstance } = vm.$; return $pageInstance && $pageInstance.proxy.$page.id; } } function getCurrentPage() { const pages = getCurrentPages(); const len = pages.length; if (len) { return pages[len - 1]; } } function getCurrentPageMeta() { const page = getCurrentPage(); if (page) { return page.$page.meta; } } function getCurrentPageId() { const meta = getCurrentPageMeta(); if (meta) { return meta.id; } return -1; } function getCurrentPageVm() { const page = getCurrentPage(); if (page) { return page.$vm; } } const PAGE_META_KEYS = ["navigationBar", "pullToRefresh"]; function initGlobalStyle() { return JSON.parse(JSON.stringify(__uniConfig.globalStyle || {})); } function initRouteMeta(pageMeta, id2) { const globalStyle = initGlobalStyle(); const res = extend({ id: id2 }, globalStyle, pageMeta); PAGE_META_KEYS.forEach((name) => { res[name] = extend({}, globalStyle[name], pageMeta[name]); }); const { navigationBar } = res; navigationBar.titleText && navigationBar.titleImage && (navigationBar.titleText = ""); return res; } function normalizePullToRefreshRpx(pullToRefresh) { if (pullToRefresh.offset) { pullToRefresh.offset = rpx2px(pullToRefresh.offset); } if (pullToRefresh.height) { pullToRefresh.height = rpx2px(pullToRefresh.height); } if (pullToRefresh.range) { pullToRefresh.range = rpx2px(pullToRefresh.range); } return pullToRefresh; } function initPageInternalInstance(openType, url, pageQuery, meta, eventChannel, themeMode) { const { id: id2, route } = meta; const titleColor = normalizeStyles( 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 removeHook(vm, name, hook) { const hooks = vm.$[name]; if (!isArray(hooks)) { return; } if (hook.__weh) { remove(hooks, hook.__weh); } } function invokeHook(vm, name, args) { if (isString(vm)) { args = name; name = vm; vm = getCurrentPageVm(); } else if (typeof vm === "number") { const page = getCurrentPages().find((page2) => page2.$page.id === vm); if (page) { vm = page.$vm; } else { vm = getCurrentPageVm(); } } if (!vm) { return; } const hooks = vm.$[name]; return hooks && invokeArrayFns(hooks, args); } function disableScrollListener(evt) { evt.preventDefault(); } let testReachBottomTimer; let lastScrollHeight = 0; function createScrollListener({ onPageScroll, onReachBottom, onReachBottomDistance }) { let ticking = false; let hasReachBottom = false; let reachBottomLocking = true; const isReachBottom = () => { const { scrollHeight } = document.documentElement; const windowHeight = window.innerHeight; const scrollY = window.scrollY; const isBottom = scrollY > 0 && scrollHeight > windowHeight && scrollY + windowHeight + onReachBottomDistance >= scrollHeight; const heightChanged = Math.abs(scrollHeight - lastScrollHeight) > onReachBottomDistance; if (isBottom && (!hasReachBottom || heightChanged)) { lastScrollHeight = scrollHeight; hasReachBottom = true; return true; } if (!isBottom && hasReachBottom) { hasReachBottom = false; } return false; }; const trigger = () => { onPageScroll && onPageScroll(window.pageYOffset); function testReachBottom() { if (isReachBottom()) { onReachBottom && onReachBottom(); reachBottomLocking = false; setTimeout(function() { reachBottomLocking = true; }, 350); return true; } } if (onReachBottom && reachBottomLocking) { if (testReachBottom()) ; else { testReachBottomTimer = setTimeout(testReachBottom, 300); } } ticking = false; }; return function onScroll() { clearTimeout(testReachBottomTimer); if (!ticking) { requestAnimationFrame(trigger); } ticking = true; }; } function normalizeRoute(toRoute) { if (toRoute.indexOf("/") === 0) { return toRoute; } let fromRoute = ""; const pages = getCurrentPages(); if (pages.length) { fromRoute = pages[pages.length - 1].$page.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)); } const toRouteArray = toRoute.split("/"); const toRouteLength = toRouteArray.length; let i = 0; for (; i < toRouteLength && toRouteArray[i] === ".."; i++) { } toRouteArray.splice(0, i); toRoute = toRouteArray.join("/"); const fromRouteArray = fromRoute.length > 0 ? fromRoute.split("/") : []; fromRouteArray.splice(fromRouteArray.length - i - 1, i + 1); return addLeadingSlash(fromRouteArray.concat(toRouteArray).join("/")); } function getRouteOptions(path, alias = false) { if (alias) { return __uniRoutes.find( (route) => route.path === path || route.alias === path ); } return __uniRoutes.find((route) => route.path === path); } function normalizeTabBarRoute(index2, oldPagePath, newPagePath) { const oldTabBarRoute = getRouteOptions(addLeadingSlash(oldPagePath)); if (oldTabBarRoute) { const { meta } = oldTabBarRoute; delete meta.tabBarIndex; meta.isQuit = meta.isTabBar = false; } const newTabBarRoute = getRouteOptions(addLeadingSlash(newPagePath)); if (newTabBarRoute) { const { meta } = newTabBarRoute; meta.tabBarIndex = index2; meta.isQuit = meta.isTabBar = true; const tabBar2 = __uniConfig.tabBar; if (tabBar2 && tabBar2.list && tabBar2.list[index2]) { tabBar2.list[index2].pagePath = removeLeadingSlash(newPagePath); } } } class ComponentDescriptor { constructor(vm) { this.$bindClass = false; this.$bindStyle = false; this.$vm = vm; { this.$el = resolveOwnerEl(vm.$); } if (this.$el.getAttribute) { this.$bindClass = !!this.$el.getAttribute("class"); this.$bindStyle = !!this.$el.getAttribute("style"); } } selectComponent(selector) { if (!this.$el || !selector) { return; } const wxsVm = getWxsVm(this.$el.querySelector(selector)); if (!wxsVm) { return; } return createComponentDescriptor(wxsVm, false); } selectAllComponents(selector) { if (!this.$el || !selector) { return []; } const descriptors = []; const els = this.$el.querySelectorAll(selector); for (let i = 0; i < els.length; i++) { const wxsVm = getWxsVm(els[i]); if (wxsVm) { descriptors.push(createComponentDescriptor(wxsVm, false)); } } return descriptors; } forceUpdate(type) { if (type === "class") { if (this.$bindClass) { this.$el.__wxsClassChanged = true; this.$vm.$forceUpdate(); } else { this.updateWxsClass(); } } else if (type === "style") { if (this.$bindStyle) { this.$el.__wxsStyleChanged = true; this.$vm.$forceUpdate(); } else { this.updateWxsStyle(); } } } updateWxsClass() { const { __wxsAddClass } = this.$el; if (__wxsAddClass.length) { this.$el.className = __wxsAddClass.join(" "); } } updateWxsStyle() { const { __wxsStyle } = this.$el; if (__wxsStyle) { this.$el.setAttribute("style", stringifyStyle(__wxsStyle)); } } setStyle(style) { if (!this.$el || !style) { return this; } if (isString(style)) { style = parseStringStyle(style); } if (isPlainObject(style)) { this.$el.__wxsStyle = style; this.forceUpdate("style"); } return this; } addClass(clazz2) { if (!this.$el || !clazz2) { return this; } const __wxsAddClass = this.$el.__wxsAddClass || (this.$el.__wxsAddClass = []); if (__wxsAddClass.indexOf(clazz2) === -1) { __wxsAddClass.push(clazz2); this.forceUpdate("class"); } return this; } removeClass(clazz2) { if (!this.$el || !clazz2) { return this; } const { __wxsAddClass } = this.$el; if (__wxsAddClass) { const index2 = __wxsAddClass.indexOf(clazz2); if (index2 > -1) { __wxsAddClass.splice(index2, 1); } } const __wxsRemoveClass = this.$el.__wxsRemoveClass || (this.$el.__wxsRemoveClass = []); if (__wxsRemoveClass.indexOf(clazz2) === -1) { __wxsRemoveClass.push(clazz2); this.forceUpdate("class"); } return this; } hasClass(cls) { return this.$el && this.$el.classList.contains(cls); } getDataset() { return this.$el && this.$el.dataset; } callMethod(funcName, args = {}) { const func = this.$vm[funcName]; if (isFunction(func)) { func(JSON.parse(JSON.stringify(args))); } else if (this.$vm.ownerId) { UniViewJSBridge.publishHandler(ON_WXS_INVOKE_CALL_METHOD, { nodeId: this.$el.__id, ownerId: this.$vm.ownerId, method: funcName, args }); } } requestAnimationFrame(callback) { return window.requestAnimationFrame(callback); } getState() { return this.$el && (this.$el.__wxsState || (this.$el.__wxsState = {})); } triggerEvent(eventName, detail = {}) { return this.$vm.$emit(eventName, detail), this; } getComputedStyle(names) { if (this.$el) { const styles = window.getComputedStyle(this.$el); if (names && names.length) { return names.reduce((res, n) => { res[n] = styles[n]; return res; }, {}); } return styles; } return {}; } setTimeout(handler, timeout) { return window.setTimeout(handler, timeout); } clearTimeout(handle) { return window.clearTimeout(handle); } getBoundingClientRect() { return this.$el.getBoundingClientRect(); } } function createComponentDescriptor(vm, isOwnerInstance = true) { { if (isOwnerInstance && vm) { vm = resolveOwnerVm(vm.$); } } if (vm && vm.$el) { if (!vm.$el.__wxsComponentDescriptor) { vm.$el.__wxsComponentDescriptor = new ComponentDescriptor(vm); } return vm.$el.__wxsComponentDescriptor; } } function getComponentDescriptor(instance2, isOwnerInstance) { return createComponentDescriptor(instance2, isOwnerInstance); } function resolveOwnerComponentPublicInstance(eventValue, instance2, checkArgsLength = true) { if (!instance2) { return false; } if (checkArgsLength && eventValue.length < 2) { return false; } const ownerVm = resolveOwnerVm(instance2); if (!ownerVm) { return false; } const type = ownerVm.$.type; if (!type.$wxs && !type.$renderjs) { return false; } return ownerVm; } function wrapperH5WxsEvent(event, eventValue, instance2, checkArgsLength = true) { if (eventValue) { if (!event.__instance) { event.__instance = true; Object.defineProperty(event, "instance", { get() { return getComponentDescriptor(instance2.proxy, false); } }); } const ownerVm = resolveOwnerComponentPublicInstance( eventValue, instance2, checkArgsLength ); if (ownerVm) { return [event, getComponentDescriptor(ownerVm, false)]; } } } function getWxsVm(el) { if (!el) { return; } { return el.__vueParentComponent && el.__vueParentComponent.proxy; } } const isKeyboardEvent = (val) => !val.type.indexOf("key") && val instanceof KeyboardEvent; const isClickEvent = (val) => val.type === "click"; const isMouseEvent = (val) => val.type.indexOf("mouse") === 0 || ["contextmenu"].includes(val.type); const isTouchEvent = (val) => typeof TouchEvent !== "undefined" && val instanceof TouchEvent || val.type.indexOf("touch") === 0 || ["longpress"].indexOf(val.type) >= 0; function $nne(evt, eventValue, instance2) { const { currentTarget } = evt; if (!(evt instanceof Event) || !(currentTarget instanceof HTMLElement)) { return [evt]; } const isHTMLTarget = currentTarget.tagName.indexOf("UNI-") !== 0; { if (isHTMLTarget) { return wrapperH5WxsEvent( evt, eventValue, instance2, false // 原生标签事件可能被cache,参数长度不准确,故默认不校验 ) || [evt]; } } const res = createNativeEvent(evt, isHTMLTarget); if (isClickEvent(evt)) { normalizeClickEvent(res, evt); } else if (isMouseEvent(evt)) { normalizeMouseEvent(res, evt); } else if (isTouchEvent(evt)) { const top = getWindowTop(); res.touches = normalizeTouchEvent(evt.touches, top); res.changedTouches = normalizeTouchEvent(evt.changedTouches, top); } else if (isKeyboardEvent(evt)) { const proxyKeys = ["key", "code"]; proxyKeys.forEach((key) => { Object.defineProperty(res, key, { get() { return evt[key]; } }); }); } { return wrapperH5WxsEvent( res, eventValue, instance2 ) || [res]; } } function findUniTarget(target) { while (target && target.tagName.indexOf("UNI-") !== 0) { target = target.parentElement; } return target; } function createNativeEvent(evt, htmlElement = false) { const { type, timeStamp, target, currentTarget } = evt; const event = { type, timeStamp, target: normalizeTarget( htmlElement ? target : findUniTarget(target) ), detail: {}, currentTarget: normalizeTarget(currentTarget) }; if (evt._stopped) { event._stopped = true; } if (evt.type.startsWith("touch")) { event.touches = evt.touches; event.changedTouches = evt.changedTouches; } { wrapperEvent(event, evt); } return event; } function wrapperEvent(event, evt) { extend(event, { preventDefault() { return evt.preventDefault(); }, stopPropagation() { return evt.stopPropagation(); } }); } function normalizeClickEvent(evt, mouseEvt) { const { x, y } = mouseEvt; const top = getWindowTop(); evt.detail = { x, y: y - top }; evt.touches = evt.changedTouches = [createTouchEvent(mouseEvt, top)]; } function normalizeMouseEvent(evt, mouseEvt) { const top = getWindowTop(); evt.pageX = mouseEvt.pageX; evt.pageY = mouseEvt.pageY - top; evt.clientX = mouseEvt.clientX; evt.clientY = mouseEvt.clientY - top; evt.touches = evt.changedTouches = [createTouchEvent(mouseEvt, top)]; } function createTouchEvent(evt, top) { return { force: 1, identifier: 0, clientX: evt.clientX, clientY: evt.clientY - top, pageX: evt.pageX, pageY: evt.pageY - top }; } function normalizeTouchEvent(touches, top) { const res = []; for (let i = 0; i < touches.length; i++) { const { identifier, pageX, pageY, clientX, clientY, force } = touches[i]; res.push({ identifier, pageX, pageY: pageY - top, clientX, clientY: clientY - top, force: force || 0 }); } return res; } const instance = /* @__PURE__ */ Object.defineProperty({ __proto__: null, $nne, createNativeEvent }, Symbol.toStringTag, { value: "Module" }); function initAppConfig$1(appConfig) { const globalProperties = appConfig.globalProperties; extend(globalProperties, instance); if (__UNI_FEATURE_WXS__) { globalProperties.$gcd = getComponentDescriptor; } } function initViewPlugin(app) { initAppConfig$1(app._context.config); } const invokeOnCallback = (name, res) => UniServiceJSBridge.emit("api." + name, res); let invokeViewMethodId = 1; function publishViewMethodName(pageId) { return (pageId || getCurrentPageId()) + "." + INVOKE_VIEW_API; } const invokeViewMethod = (name, args, pageId, callback) => { const { subscribe, publishHandler } = UniServiceJSBridge; const id2 = callback ? invokeViewMethodId++ : 0; callback && subscribe(INVOKE_VIEW_API + "." + id2, callback, true); publishHandler(publishViewMethodName(pageId), { id: id2, name, args }, pageId); }; const invokeViewMethodKeepAlive = (name, args, callback, pageId) => { const { subscribe, unsubscribe, publishHandler } = UniServiceJSBridge; const id2 = invokeViewMethodId++; const subscribeName = INVOKE_VIEW_API + "." + id2; subscribe(subscribeName, callback); publishHandler(publishViewMethodName(pageId), { id: id2, name, args }, pageId); return () => { unsubscribe(subscribeName); }; }; const ServiceJSBridge = /* @__PURE__ */ extend( /* @__PURE__ */ initBridge( "view" /* view 指的是 service 层订阅的是 view 层事件 */ ), { invokeOnCallback, invokeViewMethod, invokeViewMethodKeepAlive } ); function initOn() { const { on: on2 } = UniServiceJSBridge; on2(ON_RESIZE, onResize$1); on2(ON_APP_ENTER_FOREGROUND, onAppEnterForeground); on2(ON_APP_ENTER_BACKGROUND, onAppEnterBackground); } function onResize$1(res) { invokeHook(getCurrentPage(), ON_RESIZE, res); UniServiceJSBridge.invokeOnCallback("onWindowResize", res); } function onAppEnterForeground(enterOptions2) { const page = getCurrentPage(); invokeHook(getApp(), ON_SHOW, enterOptions2); invokeHook(page, ON_SHOW); } function onAppEnterBackground() { invokeHook(getApp(), ON_HIDE); invokeHook(getCurrentPage(), ON_HIDE); } const SUBSCRIBE_LIFECYCLE_HOOKS = [ON_PAGE_SCROLL, ON_REACH_BOTTOM]; function initSubscribe() { SUBSCRIBE_LIFECYCLE_HOOKS.forEach( (name) => UniServiceJSBridge.subscribe(name, createPageEvent(name)) ); } function createPageEvent(name) { return (args, pageId) => { invokeHook(parseInt(pageId), name, args); }; } function initService() { { initOn(); initSubscribe(); } } function initAppVm(appVm2) { appVm2.$vm = appVm2; appVm2.$mpType = "app"; const locale = ref(useI18n().getLocale()); Object.defineProperty(appVm2, "$locale", { get() { return locale.value; }, set(v2) { locale.value = v2; } }); } function initPageVm(pageVm, page) { pageVm.route = page.route; pageVm.$vm = pageVm; pageVm.$page = page; pageVm.$mpType = "page"; if (page.meta.isTabBar) { pageVm.$.__isTabBar = true; pageVm.$.__isActive = true; } } function querySelector(vm, selector) { const el = vm.$el.querySelector(selector); return el && el.__vue__; } function querySelectorAll(vm, selector) { const nodeList = vm.$el.querySelectorAll(selector); if (nodeList) { return [...nodeList].map((node) => node.__vue__).filter(Boolean); } return []; } function createSelectorQuery$1() { return uni.createSelectorQuery().in(this); } function createMediaQueryObserver$1() { return uni.createMediaQueryObserver(this); } function createIntersectionObserver$1(options) { return uni.createIntersectionObserver(this, options); } function selectComponent(selector) { return querySelector(this, selector); } function selectAllComponents(selector) { return querySelectorAll(this, selector); } const wxInstance = /* @__PURE__ */ Object.defineProperty({ __proto__: null, createIntersectionObserver: createIntersectionObserver$1, createMediaQueryObserver: createMediaQueryObserver$1, createSelectorQuery: createSelectorQuery$1, selectAllComponents, selectComponent }, Symbol.toStringTag, { value: "Module" }); function getOpenerEventChannel() { { if (this.$route) { const meta = this.$route.meta; if (!meta.eventChannel) { meta.eventChannel = new EventChannel(this.$page.id); } return meta.eventChannel; } } } function initAppConfig(appConfig) { const globalProperties = appConfig.globalProperties; globalProperties.getOpenerEventChannel = getOpenerEventChannel; if (__UNI_FEATURE_WX__) { extend(globalProperties, wxInstance); } } function initServicePlugin(app) { initAppConfig(app._context.config); } function createLaunchOptions() { return { path: "", query: {}, scene: 1001, referrerInfo: { appId: "", extraData: {} } }; } function defineGlobalData(app, defaultGlobalData) { const options = app.$options || {}; options.globalData = extend(options.globalData || {}, defaultGlobalData); Object.defineProperty(app, "globalData", { get() { return options.globalData; }, set(newGlobalData) { options.globalData = newGlobalData; } }); } function converPx(value) { if (/^-?\d+[ur]px$/i.test(value)) { return value.replace(/(^-?\d+)[ur]px$/i, (text2, num) => { return `${uni.upx2px(parseFloat(num))}px`; }); } else if (/^-?[\d\.]+$/.test(value)) { return `${value}px`; } return value || ""; } function converType(type) { return type.replace(/[A-Z]/g, (text2) => { return `-${text2.toLowerCase()}`; }).replace("webkit", "-webkit"); } function getStyle(action) { const animateTypes1 = [ "matrix", "matrix3d", "scale", "scale3d", "rotate3d", "skew", "translate", "translate3d" ]; const animateTypes2 = [ "scaleX", "scaleY", "scaleZ", "rotate", "rotateX", "rotateY", "rotateZ", "skewX", "skewY", "translateX", "translateY", "translateZ" ]; const animateTypes3 = ["opacity", "background-color"]; const animateTypes4 = ["width", "height", "left", "right", "top", "bottom"]; const animates = action.animates; const option = action.option; const transition = option.transition; const style = {}; const transform = []; animates.forEach((animate) => { let type = animate.type; let args = [...animate.args]; if (animateTypes1.concat(animateTypes2).includes(type)) { if (type.startsWith("rotate") || type.startsWith("skew")) { args = args.map((value) => parseFloat(value) + "deg"); } else if (type.startsWith("translate")) { args = args.map(converPx); } if (animateTypes2.indexOf(type) >= 0) { args.length = 1; } transform.push(`${type}(${args.join(",")})`); } else if (animateTypes3.concat(animateTypes4).includes(args[0])) { type = args[0]; const 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) => `${converType(type)} ${transition.duration}ms ${transition.timingFunction} ${transition.delay}ms` ).join(","); style.transformOrigin = style.webkitTransformOrigin = option.transformOrigin; return style; } function startAnimation(context) { const animation2 = context.animation; if (!animation2 || !animation2.actions || !animation2.actions.length) { return; } let index2 = 0; const actions = animation2.actions; const length = animation2.actions.length; function animate() { const action = actions[index2]; const transition = action.option.transition; const 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); } }; const defineBuiltInComponent = (options) => { options.__reserved = true; const { props: props2, mixins } = options; if (!props2 || !props2.animation) { (mixins || (options.mixins = [])).push(animation); } { const rootElement = options.rootElement; if (rootElement) { customElements.define( rootElement.name, rootElement.class, rootElement.options ); } } return defineSystemComponent(options); }; const defineSystemComponent = (options) => { options.__reserved = true; options.compatConfig = { MODE: 3 // 标记为vue3 }; return defineComponent(options); }; const defineUnsupportedComponent = (name) => { return defineBuiltInComponent({ name: capitalize(camelize(name)), setup() { return () => (openBlock(), createElementBlock("uni-" + name, null, name + " is unsupported")); } }); }; const hoverProps = { hoverClass: { type: String, default: "none" }, hoverStopPropagation: { type: Boolean, default: false }, hoverStartTime: { type: [Number, String], default: 50 }, hoverStayTime: { type: [Number, String], default: 400 } }; function useHover(props2) { const hovering = ref(false); let hoverTouch = false; let hoverStartTimer; let hoverStayTimer; function hoverReset() { requestAnimationFrame(() => { clearTimeout(hoverStayTimer); hoverStayTimer = setTimeout(() => { hovering.value = false; }, parseInt(props2.hoverStayTime)); }); } function onTouchstartPassive(evt) { if (evt.touches.length > 1) { return; } handleHoverStart(evt); } function onMousedown(evt) { if (hoverTouch) { return; } handleHoverStart(evt); window.addEventListener("mouseup", handlePCHoverEnd); } function handleHoverStart(evt) { if (evt._hoverPropagationStopped) { return; } if (!props2.hoverClass || props2.hoverClass === "none" || props2.disabled) { return; } if (props2.hoverStopPropagation) { evt._hoverPropagationStopped = true; } hoverTouch = true; hoverStartTimer = setTimeout(() => { hovering.value = true; if (!hoverTouch) { hoverReset(); } }, parseInt(props2.hoverStartTime)); } function onTouchend() { handleHoverEnd(); } function onMouseup() { if (!hoverTouch) { return; } handlePCHoverEnd(); } function handleHoverEnd() { hoverTouch = false; if (hovering.value) { hoverReset(); } } function handlePCHoverEnd() { handleHoverEnd(); window.removeEventListener("mouseup", handlePCHoverEnd); } function onTouchcancel() { hoverTouch = false; hovering.value = false; clearTimeout(hoverStartTimer); } return { hovering, binding: { onTouchstartPassive, onMousedown, onTouchend, onMouseup, onTouchcancel } }; } function useBooleanAttr(props2, keys) { if (isString(keys)) { keys = [keys]; } return keys.reduce((res, key) => { if (props2[key]) { res[key] = true; } return res; }, /* @__PURE__ */ Object.create(null)); } function withWebEvent(fn) { return fn.__wwe = true, fn; } function useCustomEvent(ref2, emit2) { return (name, evt, detail) => { if (ref2.value) { emit2(name, normalizeCustomEvent(name, evt, ref2.value, detail || {})); } }; } function useNativeEvent(emit2) { return (name, evt) => { emit2(name, createNativeEvent(evt)); }; } function normalizeCustomEvent(name, domEvt, el, detail) { const target = normalizeTarget(el); return { type: detail.type || name, timeStamp: domEvt.timeStamp || 0, target, currentTarget: target, detail }; } const uniFormKey = PolySymbol(process.env.NODE_ENV !== "production" ? "uniForm" : "uf"); const index$z = /* @__PURE__ */ defineBuiltInComponent({ name: "Form", emits: ["submit", "reset"], setup(_props, { slots, emit: emit2 }) { const rootRef = ref(null); provideForm(useCustomEvent(rootRef, emit2)); return () => createVNode("uni-form", { "ref": rootRef }, [createVNode("span", null, [slots.default && slots.default()])], 512); } }); function provideForm(trigger) { const fields2 = []; provide(uniFormKey, { addField(field) { fields2.push(field); }, removeField(field) { fields2.splice(fields2.indexOf(field), 1); }, submit(evt) { trigger("submit", evt, { value: fields2.reduce((res, field) => { if (field.submit) { const [name, value] = field.submit(); name && (res[name] = value); } return res; }, /* @__PURE__ */ Object.create(null)) }); }, reset(evt) { fields2.forEach((field) => field.reset && field.reset()); trigger("reset", evt); } }); return fields2; } const labelProps = { for: { type: String, default: "" } }; const uniLabelKey = PolySymbol(process.env.NODE_ENV !== "production" ? "uniLabel" : "ul"); function useProvideLabel() { const handlers = []; provide(uniLabelKey, { addHandler(handler) { handlers.push(handler); }, removeHandler(handler) { handlers.splice(handlers.indexOf(handler), 1); } }); return handlers; } const index$y = /* @__PURE__ */ defineBuiltInComponent({ name: "Label", props: labelProps, setup(props2, { slots }) { const pageId = useCurrentPageId(); const handlers = useProvideLabel(); const pointer = computed(() => props2.for || slots.default && slots.default.length); const _onClick = withWebEvent(($event) => { const EventTarget = $event.target; let stopPropagation = /^uni-(checkbox|radio|switch)-/.test(EventTarget.className); if (!stopPropagation) { stopPropagation = /^uni-(checkbox|radio|switch|button)$|^(svg|path)$/i.test(EventTarget.tagName); } if (stopPropagation) { return; } if (props2.for) { UniViewJSBridge.emit("uni-label-click-" + pageId + "-" + props2.for, $event, true); } else { handlers.length && handlers[0]($event, true); } }); return () => createVNode("uni-label", { "class": { "uni-label-pointer": pointer }, "onClick": _onClick }, [slots.default && slots.default()], 10, ["onClick"]); } }); function useListeners$1(props2, listeners2) { _addListeners(props2.id, listeners2); watch( () => props2.id, (newId, oldId) => { _removeListeners(oldId, listeners2, true); _addListeners(newId, listeners2, true); } ); onUnmounted(() => { _removeListeners(props2.id, listeners2); }); } function _addListeners(id2, listeners2, watch2) { const pageId = useCurrentPageId(); if (watch2 && !id2) { return; } if (!isPlainObject(listeners2)) { return; } Object.keys(listeners2).forEach((name) => { if (watch2) { if (name.indexOf("@") !== 0 && name.indexOf("uni-") !== 0) { UniViewJSBridge.on(`uni-${name}-${pageId}-${id2}`, listeners2[name]); } } else { if (name.indexOf("uni-") === 0) { UniViewJSBridge.on(name, listeners2[name]); } else if (id2) { UniViewJSBridge.on(`uni-${name}-${pageId}-${id2}`, listeners2[name]); } } }); } function _removeListeners(id2, listeners2, watch2) { const pageId = useCurrentPageId(); if (watch2 && !id2) { return; } if (!isPlainObject(listeners2)) { return; } Object.keys(listeners2).forEach((name) => { if (watch2) { if (name.indexOf("@") !== 0 && name.indexOf("uni-") !== 0) { UniViewJSBridge.off(`uni-${name}-${pageId}-${id2}`, listeners2[name]); } } else { if (name.indexOf("uni-") === 0) { UniViewJSBridge.off(name, listeners2[name]); } else if (id2) { UniViewJSBridge.off(`uni-${name}-${pageId}-${id2}`, listeners2[name]); } } }); } const buttonProps = { id: { type: String, default: "" }, hoverClass: { type: String, default: "button-hover" }, hoverStartTime: { type: [Number, String], default: 20 }, hoverStayTime: { type: [Number, String], default: 70 }, hoverStopPropagation: { type: Boolean, default: false }, disabled: { type: [Boolean, String], default: false }, formType: { type: String, default: "" }, openType: { type: String, default: "" }, loading: { type: [Boolean, String], default: false }, plain: { type: [Boolean, String], default: false } }; const index$x = /* @__PURE__ */ defineBuiltInComponent({ name: "Button", props: buttonProps, setup(props2, { slots }) { const rootRef = ref(null); const uniForm = inject(uniFormKey, false); const { hovering, binding } = useHover(props2); useI18n(); const onClick = withWebEvent((e2, isLabelClick) => { if (props2.disabled) { return e2.stopImmediatePropagation(); } if (isLabelClick) { rootRef.value.click(); } const formType = props2.formType; if (formType) { if (!uniForm) { return; } if (formType === "submit") { uniForm.submit(e2); } else if (formType === "reset") { uniForm.reset(e2); } return; } }); const uniLabel = inject(uniLabelKey, false); if (uniLabel) { uniLabel.addHandler(onClick); onBeforeUnmount(() => { uniLabel.removeHandler(onClick); }); } useListeners$1(props2, { "label-click": onClick }); return () => { const hoverClass = props2.hoverClass; const booleanAttrs = useBooleanAttr(props2, "disabled"); const loadingAttrs = useBooleanAttr(props2, "loading"); const plainAttrs = useBooleanAttr(props2, "plain"); const hasHoverClass = hoverClass && hoverClass !== "none"; return createVNode("uni-button", mergeProps({ "ref": rootRef, "onClick": onClick, "class": hasHoverClass && hovering.value ? hoverClass : "" }, hasHoverClass && binding, booleanAttrs, loadingAttrs, plainAttrs), [slots.default && slots.default()], 16, ["onClick"]); }; } }); function findElem(vm) { return vm.$el; } function addBase(filePath) { const { base: baseUrl } = __uniConfig.router; if (addLeadingSlash(filePath).indexOf(baseUrl) === 0) { return addLeadingSlash(filePath); } return baseUrl + filePath; } function getRealPath(filePath) { const { base, assets } = __uniConfig.router; if (base === "./") { if (filePath.indexOf("./static/") === 0 || assets && filePath.indexOf("./" + assets + "/") === 0) { filePath = filePath.slice(1); } } if (filePath.indexOf("/") === 0) { if (filePath.indexOf("//") === 0) { filePath = "https:" + filePath; } else { return addBase(filePath.slice(1)); } } if (SCHEME_RE.test(filePath) || DATA_RE.test(filePath) || filePath.indexOf("blob:") === 0) { return filePath; } const pages = getCurrentPages(); if (pages.length) { return addBase( getRealRoute(pages[pages.length - 1].$page.route, filePath).slice(1) ); } return filePath; } const ua = navigator.userAgent; const isAndroid = /* @__PURE__ */ /android/i.test(ua); const isIOS$1 = /* @__PURE__ */ /iphone|ipad|ipod/i.test(ua); const isWindows = /* @__PURE__ */ ua.match(/Windows NT ([\d|\d.\d]*)/i); const isMac = /* @__PURE__ */ /Macintosh|Mac/i.test(ua); const isLinux = /* @__PURE__ */ /Linux|X11/i.test(ua); const isIPadOS = isMac && navigator.maxTouchPoints > 0; function getScreenFix() { return /^Apple/.test(navigator.vendor) && typeof window.orientation === "number"; } function isLandscape(screenFix) { return screenFix && Math.abs(window.orientation) === 90; } function getScreenWidth(screenFix, landscape) { return screenFix ? Math[landscape ? "max" : "min"](screen.width, screen.height) : screen.width; } function getScreenHeight(screenFix, landscape) { return screenFix ? Math[landscape ? "min" : "max"](screen.height, screen.width) : screen.height; } function getWindowWidth(screenWidth) { return Math.min( window.innerWidth, document.documentElement.clientWidth, screenWidth ) || screenWidth; } function getBaseSystemInfo() { const screenFix = getScreenFix(); const windowWidth = getWindowWidth( getScreenWidth(screenFix, isLandscape(screenFix)) ); return { platform: isIOS$1 ? "ios" : "other", pixelRatio: window.devicePixelRatio, windowWidth }; } function operateVideoPlayer(videoId, pageId, type, data) { UniServiceJSBridge.invokeViewMethod( "video." + videoId, { videoId, type, data }, pageId ); } function operateMap(id2, pageId, type, data, operateMapCallback2) { UniServiceJSBridge.invokeViewMethod( "map." + id2, { type, data }, pageId, operateMapCallback2 ); } function getRootInfo(fields2) { const info = {}; if (fields2.id) { info.id = ""; } if (fields2.dataset) { info.dataset = {}; } if (fields2.rect) { info.left = 0; info.right = 0; info.top = 0; info.bottom = 0; } if (fields2.size) { info.width = document.documentElement.clientWidth; info.height = document.documentElement.clientHeight; } if (fields2.scrollOffset) { const documentElement2 = document.documentElement; const body = document.body; info.scrollLeft = documentElement2.scrollLeft || body.scrollLeft || 0; info.scrollTop = documentElement2.scrollTop || body.scrollTop || 0; info.scrollHeight = documentElement2.scrollHeight || body.scrollHeight || 0; info.scrollWidth = documentElement2.scrollWidth || body.scrollWidth || 0; } return info; } function getNodeInfo(el, fields2) { const info = {}; const { top, topWindowHeight } = getWindowOffset(); if (fields2.id) { info.id = el.id; } if (fields2.dataset) { info.dataset = getCustomDataset(el); } if (fields2.rect || fields2.size) { const rect = el.getBoundingClientRect(); if (fields2.rect) { info.left = rect.left; info.right = rect.right; info.top = rect.top - top - topWindowHeight; info.bottom = rect.bottom - top - topWindowHeight; } if (fields2.size) { info.width = rect.width; info.height = rect.height; } } if (isArray(fields2.properties)) { fields2.properties.forEach((prop) => { prop = prop.replace(/-([a-z])/g, function(e2, t2) { return t2.toUpperCase(); }); }); } if (fields2.scrollOffset) { if (el.tagName === "UNI-SCROLL-VIEW") { const scroll = el.children[0].children[0]; info.scrollLeft = scroll.scrollLeft; info.scrollTop = scroll.scrollTop; info.scrollHeight = scroll.scrollHeight; info.scrollWidth = scroll.scrollWidth; } else { info.scrollLeft = 0; info.scrollTop = 0; info.scrollHeight = 0; info.scrollWidth = 0; } } if (isArray(fields2.computedStyle)) { const sytle = getComputedStyle(el); fields2.computedStyle.forEach((name) => { info[name] = sytle[name]; }); } if (fields2.context) { info.contextInfo = getContextInfo(el); } return info; } function findElm(component, pageVm) { if (!component) { return pageVm.$el; } return component.$el; } function matches(element, selectors) { const matches2 = element.matches || element.matchesSelector || element.mozMatchesSelector || element.msMatchesSelector || element.oMatchesSelector || element.webkitMatchesSelector || function(selectors2) { const matches3 = this.parentElement.querySelectorAll( selectors2 ); let i = matches3.length; while (--i >= 0 && matches3.item(i) !== this) { } return i > -1; }; return matches2.call(element, selectors); } function getNodesInfo(pageVm, component, selector, single, fields2) { const selfElement = findElm(component, pageVm); const parentElement = selfElement.parentElement; if (!parentElement) { return single ? null : []; } const { nodeType } = selfElement; const maybeFragment = nodeType === 3 || nodeType === 8; if (single) { const node = maybeFragment ? parentElement.querySelector(selector) : matches(selfElement, selector) ? selfElement : selfElement.querySelector(selector); if (node) { return getNodeInfo(node, fields2); } return null; } else { let infos = []; const nodeList = (maybeFragment ? parentElement : selfElement).querySelectorAll(selector); if (nodeList && nodeList.length) { [].forEach.call(nodeList, (node) => { infos.push(getNodeInfo(node, fields2)); }); } if (!maybeFragment && matches(selfElement, selector)) { infos.unshift(getNodeInfo(selfElement, fields2)); } return infos; } } function requestComponentInfo(page, reqs, callback) { const result = []; reqs.forEach(({ component, selector, single, fields: fields2 }) => { if (component === null) { result.push(getRootInfo(fields2)); } else { result.push(getNodesInfo(page, component, selector, single, fields2)); } }); callback(result); } function setCurrentPageMeta(_page, { pageStyle, rootFontSize }) { if (pageStyle) { const pageElm = document.querySelector("uni-page-body") || document.body; pageElm.setAttribute("style", pageStyle); } if (rootFontSize && document.documentElement.style.fontSize !== rootFontSize) { document.documentElement.style.fontSize = rootFontSize; } } var chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; var lookup = /* @__PURE__ */ function() { const lookup2 = new Uint8Array(256); for (var i = 0; i < chars.length; i++) { lookup2[chars.charCodeAt(i)] = i; } return lookup2; }(); function encode$1(arraybuffer) { var bytes = new Uint8Array(arraybuffer), i, len = bytes.length, base64 = ""; for (i = 0; i < len; i += 3) { base64 += chars[bytes[i] >> 2]; base64 += chars[(bytes[i] & 3) << 4 | bytes[i + 1] >> 4]; base64 += chars[(bytes[i + 1] & 15) << 2 | bytes[i + 2] >> 6]; base64 += chars[bytes[i + 2] & 63]; } if (len % 3 === 2) { base64 = base64.substring(0, base64.length - 1) + "="; } else if (len % 3 === 1) { base64 = base64.substring(0, base64.length - 2) + "=="; } return base64; } function decode(base64) { var bufferLength = base64.length * 0.75, len = base64.length, i, p2 = 0, encoded1, encoded2, encoded3, encoded4; if (base64[base64.length - 1] === "=") { bufferLength--; if (base64[base64.length - 2] === "=") { bufferLength--; } } var arraybuffer = new ArrayBuffer(bufferLength), bytes = new Uint8Array(arraybuffer); for (i = 0; i < len; i += 4) { encoded1 = lookup[base64.charCodeAt(i)]; encoded2 = lookup[base64.charCodeAt(i + 1)]; encoded3 = lookup[base64.charCodeAt(i + 2)]; encoded4 = lookup[base64.charCodeAt(i + 3)]; bytes[p2++] = encoded1 << 2 | encoded2 >> 4; bytes[p2++] = (encoded2 & 15) << 4 | encoded3 >> 2; bytes[p2++] = (encoded3 & 3) << 6 | encoded4 & 63; } return arraybuffer; } const CHOOSE_SIZE_TYPES = ["original", "compressed"]; const CHOOSE_SOURCE_TYPES = ["album", "camera"]; const HTTP_METHODS = [ "GET", "OPTIONS", "HEAD", "POST", "PUT", "DELETE", "TRACE", "CONNECT", "PATCH" ]; function elemInArray(str, arr) { if (!str || arr.indexOf(str) === -1) { return arr[0]; } return str; } function elemsInArray(strArr, optionalVal) { if (!isArray(strArr) || strArr.length === 0 || strArr.find((val) => optionalVal.indexOf(val) === -1)) { return optionalVal; } return strArr; } function validateProtocolFail(name, msg) { console.warn(`${name}: ${msg}`); } function validateProtocol(name, data, protocol, onFail) { if (!onFail) { onFail = validateProtocolFail; } for (const key in protocol) { const errMsg = validateProp( key, data[key], protocol[key], !hasOwn(data, key) ); if (isString(errMsg)) { onFail(name, errMsg); } } } function validateProtocols(name, args, protocol, onFail) { if (!protocol) { return; } if (!isArray(protocol)) { return validateProtocol( name, args[0] || /* @__PURE__ */ Object.create(null), protocol, onFail ); } const len = protocol.length; const argsLen = args.length; for (let i = 0; i < len; i++) { const opts = protocol[i]; const data = /* @__PURE__ */ Object.create(null); if (argsLen > i) { data[opts.name] = args[i]; } validateProtocol(name, data, { [opts.name]: opts }, onFail); } } function validateProp(name, value, prop, isAbsent) { if (!isPlainObject(prop)) { prop = { type: prop }; } const { type, required, validator: validator2 } = prop; if (required && isAbsent) { return 'Missing required args: "' + name + '"'; } if (value == null && !required) { return; } if (type != null) { let isValid = false; const types = isArray(type) ? type : [type]; const expectedTypes = []; for (let i = 0; i < types.length && !isValid; i++) { const { valid, expectedType } = assertType(value, types[i]); expectedTypes.push(expectedType || ""); isValid = valid; } if (!isValid) { return getInvalidTypeMessage(name, value, expectedTypes); } } if (validator2) { return validator2(value); } } const isSimpleType = /* @__PURE__ */ makeMap$1( "String,Number,Boolean,Function,Symbol" ); function assertType(value, type) { let valid; const expectedType = getType(type); if (isSimpleType(expectedType)) { const t2 = typeof value; valid = t2 === expectedType.toLowerCase(); if (!valid && t2 === "object") { valid = value instanceof type; } } else if (expectedType === "Object") { valid = isObject(value); } else if (expectedType === "Array") { valid = isArray(value); } else { { valid = value instanceof type; } } return { valid, expectedType }; } function getInvalidTypeMessage(name, value, expectedTypes) { let message = `Invalid args: type check failed for args "${name}". Expected ${expectedTypes.map(capitalize).join(", ")}`; const expectedType = expectedTypes[0]; const receivedType = toRawType(value); const expectedValue = styleValue(value, expectedType); const receivedValue = styleValue(value, receivedType); if (expectedTypes.length === 1 && isExplicable(expectedType) && !isBoolean(expectedType, receivedType)) { message += ` with value ${expectedValue}`; } message += `, got ${receivedType} `; if (isExplicable(receivedType)) { message += `with value ${receivedValue}.`; } return message; } function getType(ctor) { const match = ctor && ctor.toString().match(/^\s*function (\w+)/); return match ? match[1] : ""; } function styleValue(value, type) { if (type === "String") { return `"${value}"`; } else if (type === "Number") { return `${Number(value)}`; } else { return `${value}`; } } function isExplicable(type) { const explicitTypes = ["string", "number", "boolean"]; return explicitTypes.some((elem) => type.toLowerCase() === elem); } function isBoolean(...args) { return args.some((elem) => elem.toLowerCase() === "boolean"); } function tryCatch(fn) { return function() { try { return fn.apply(fn, arguments); } catch (e2) { console.error(e2); } }; } let invokeCallbackId = 1; const invokeCallbacks = {}; function addInvokeCallback(id2, name, callback, keepAlive = false) { invokeCallbacks[id2] = { name, keepAlive, callback }; return id2; } function invokeCallback(id2, res, extras) { if (typeof id2 === "number") { const opts = invokeCallbacks[id2]; if (opts) { if (!opts.keepAlive) { delete invokeCallbacks[id2]; } return opts.callback(res, extras); } } return res; } function findInvokeCallbackByName(name) { for (const key in invokeCallbacks) { if (invokeCallbacks[key].name === name) { return true; } } return false; } function removeKeepAliveApiCallback(name, callback) { for (const key in invokeCallbacks) { const item = invokeCallbacks[key]; if (item.callback === callback && item.name === name) { delete invokeCallbacks[key]; } } } function offKeepAliveApiCallback(name) { UniServiceJSBridge.off("api." + name); } function onKeepAliveApiCallback(name) { UniServiceJSBridge.on("api." + name, (res) => { for (const key in invokeCallbacks) { const opts = invokeCallbacks[key]; if (opts.name === name) { opts.callback(res); } } }); } function createKeepAliveApiCallback(name, callback) { return addInvokeCallback(invokeCallbackId++, name, callback, true); } const API_SUCCESS = "success"; const API_FAIL = "fail"; const API_COMPLETE = "complete"; function getApiCallbacks(args) { const apiCallbacks = {}; for (const name in args) { const fn = args[name]; if (isFunction(fn)) { apiCallbacks[name] = tryCatch(fn); delete args[name]; } } return apiCallbacks; } function normalizeErrMsg$1(errMsg, name) { if (!errMsg || errMsg.indexOf(":fail") === -1) { return name + ":ok"; } return name + errMsg.substring(errMsg.indexOf(":fail")); } function createAsyncApiCallback(name, args = {}, { beforeAll, beforeSuccess } = {}) { if (!isPlainObject(args)) { args = {}; } const { success, fail, complete } = getApiCallbacks(args); const hasSuccess = isFunction(success); const hasFail = isFunction(fail); const hasComplete = isFunction(complete); const callbackId = invokeCallbackId++; addInvokeCallback(callbackId, name, (res) => { res = res || {}; res.errMsg = normalizeErrMsg$1(res.errMsg, name); isFunction(beforeAll) && beforeAll(res); if (res.errMsg === name + ":ok") { isFunction(beforeSuccess) && beforeSuccess(res, args); hasSuccess && success(res); } else { hasFail && fail(res); } hasComplete && complete(res); }); return callbackId; } const HOOK_SUCCESS = "success"; const HOOK_FAIL = "fail"; const HOOK_COMPLETE = "complete"; const globalInterceptors = {}; const scopedInterceptors = {}; function wrapperHook(hook, params) { return function(data) { return hook(data, params) || data; }; } function queue(hooks, data, params) { let promise = false; for (let i = 0; i < hooks.length; i++) { const hook = hooks[i]; if (promise) { promise = Promise.resolve(wrapperHook(hook, params)); } else { const 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(interceptors2, options = {}) { [HOOK_SUCCESS, HOOK_FAIL, HOOK_COMPLETE].forEach((name) => { const hooks = interceptors2[name]; if (!isArray(hooks)) { return; } const oldCallback = options[name]; options[name] = function callbackInterceptor(res) { queue(hooks, res, options).then((res2) => { return isFunction(oldCallback) && oldCallback(res2) || res2; }); }; }); return options; } function wrapperReturnValue(method, returnValue) { const returnValueHooks = []; if (isArray(globalInterceptors.returnValue)) { returnValueHooks.push(...globalInterceptors.returnValue); } const interceptor = scopedInterceptors[method]; if (interceptor && isArray(interceptor.returnValue)) { returnValueHooks.push(...interceptor.returnValue); } returnValueHooks.forEach((hook) => { returnValue = hook(returnValue) || returnValue; }); return returnValue; } function getApiInterceptorHooks(method) { const interceptor = /* @__PURE__ */ Object.create(null); Object.keys(globalInterceptors).forEach((hook) => { if (hook !== "returnValue") { interceptor[hook] = globalInterceptors[hook].slice(); } }); const 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, api2, options, params) { const interceptor = getApiInterceptorHooks(method); if (interceptor && Object.keys(interceptor).length) { if (isArray(interceptor.invoke)) { const res = queue(interceptor.invoke, options); return res.then((options2) => { return api2( wrapperOptions(getApiInterceptorHooks(method), options2), ...params ); }); } else { return api2(wrapperOptions(interceptor, options), ...params); } } return api2(options, ...params); } function hasCallback(args) { if (isPlainObject(args) && [API_SUCCESS, API_FAIL, API_COMPLETE].find( (cb) => isFunction(args[cb]) )) { return true; } return false; } function handlePromise(promise) { return promise; } function promisify(name, fn) { return (args = {}, ...rest) => { 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) { const params = args[0]; if (!options || !isPlainObject(options.formatArgs) && isPlainObject(params)) { return; } const formatArgs = options.formatArgs; const keys = Object.keys(formatArgs); for (let i = 0; i < keys.length; i++) { const name = keys[i]; const formatterOrDefaultValue = formatArgs[name]; if (isFunction(formatterOrDefaultValue)) { const errMsg = formatterOrDefaultValue(args[0][name], params); if (isString(errMsg)) { return errMsg; } } else { if (!hasOwn(params, name)) { params[name] = formatterOrDefaultValue; } } } } function invokeSuccess(id2, name, res) { return invokeCallback( id2, extend(res || {}, { errMsg: name + ":ok" }) ); } function invokeFail(id2, name, errMsg, errRes) { return invokeCallback( id2, extend({ errMsg: name + ":fail" + (errMsg ? " " + errMsg : "") }, errRes) ); } function beforeInvokeApi(name, args, protocol, options) { if (process.env.NODE_ENV !== "production") { validateProtocols(name, args, protocol); } if (options && options.beforeInvoke) { const errMsg2 = options.beforeInvoke(args); if (isString(errMsg2)) { return errMsg2; } } const errMsg = formatApiArgs(args, options); if (errMsg) { return errMsg; } } function checkCallback(callback) { if (!isFunction(callback)) { throw new Error( 'Invalid args: type check failed for args "callback". Expected Function' ); } } function wrapperOnApi(name, fn, options) { return (callback) => { checkCallback(callback); const errMsg = beforeInvokeApi(name, [callback], void 0, options); if (errMsg) { throw new Error(errMsg); } const isFirstInvokeOnApi = !findInvokeCallbackByName(name); createKeepAliveApiCallback(name, callback); if (isFirstInvokeOnApi) { onKeepAliveApiCallback(name); fn(); } }; } function wrapperOffApi(name, fn, options) { return (callback) => { checkCallback(callback); const errMsg = beforeInvokeApi(name, [callback], void 0, options); if (errMsg) { throw new Error(errMsg); } name = name.replace("off", "on"); removeKeepAliveApiCallback(name, callback); const hasInvokeOnApi = findInvokeCallbackByName(name); if (!hasInvokeOnApi) { offKeepAliveApiCallback(name); fn(); } }; } function normalizeErrMsg(errMsg) { if (!errMsg || isString(errMsg)) { return errMsg; } if (errMsg.stack) { console.error(errMsg.message + LINEFEED + errMsg.stack); return errMsg.message; } return errMsg; } function wrapperTaskApi(name, fn, protocol, options) { return (args) => { const id2 = createAsyncApiCallback(name, args, options); const 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, normalizeErrMsg(errMsg2), errRes) }); }; } function wrapperSyncApi(name, fn, protocol, options) { return (...args) => { const 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 defineOnApi(name, fn, options) { return wrapperOnApi(name, fn, options); } function defineOffApi(name, fn, options) { return wrapperOffApi(name, fn, options); } function defineTaskApi(name, fn, protocol, options) { return promisify( name, wrapperTaskApi(name, fn, process.env.NODE_ENV !== "production" ? protocol : void 0, options) ); } function defineSyncApi(name, fn, protocol, options) { return wrapperSyncApi( name, fn, process.env.NODE_ENV !== "production" ? protocol : void 0, options ); } function defineAsyncApi(name, fn, protocol, options) { return promisify( name, wrapperAsyncApi(name, fn, process.env.NODE_ENV !== "production" ? protocol : void 0, options) ); } function createUnsupportedMsg(name) { return `method 'uni.${name}' not supported`; } function createUnsupportedSyncApi(name) { return () => { console.error(createUnsupportedMsg(name)); }; } const createUnsupportedOnApi = createUnsupportedSyncApi; function createUnsupportedAsyncApi(name) { return (_args, { reject }) => { return reject(createUnsupportedMsg(name)); }; } const API_BASE64_TO_ARRAY_BUFFER = "base64ToArrayBuffer"; const Base64ToArrayBufferProtocol = [ { name: "base64", type: String, required: true } ]; const API_ARRAY_BUFFER_TO_BASE64 = "arrayBufferToBase64"; const ArrayBufferToBase64Protocol = [ { name: "arrayBuffer", type: [ArrayBuffer, Uint8Array], required: true } ]; const base64ToArrayBuffer = /* @__PURE__ */ defineSyncApi( API_BASE64_TO_ARRAY_BUFFER, (base64) => { return decode(base64); }, Base64ToArrayBufferProtocol ); const arrayBufferToBase64 = /* @__PURE__ */ defineSyncApi( API_ARRAY_BUFFER_TO_BASE64, (arrayBuffer) => { return encode$1(arrayBuffer); }, ArrayBufferToBase64Protocol ); const API_UPX2PX = "upx2px"; const Upx2pxProtocol = [ { name: "upx", type: [Number, String], required: true } ]; const EPS = 1e-4; const BASE_DEVICE_WIDTH = 750; let isIOS = false; let deviceWidth = 0; let deviceDPR = 0; let maxWidth = 960; let baseWidth = 375; let includeWidth = 750; function checkDeviceWidth() { const { platform, pixelRatio: pixelRatio2, windowWidth } = getBaseSystemInfo(); deviceWidth = windowWidth; deviceDPR = pixelRatio2; isIOS = platform === "ios"; } function checkValue(value, defaultValue) { const newValue = Number(value); return isNaN(newValue) ? defaultValue : newValue; } function checkMaxWidth() { const config = __uniConfig.globalStyle || {}; maxWidth = checkValue(config.rpxCalcMaxDeviceWidth, 960); baseWidth = checkValue(config.rpxCalcBaseDeviceWidth, 375); includeWidth = checkValue(config.rpxCalcBaseDeviceWidth, 750); } const upx2px = /* @__PURE__ */ defineSyncApi( API_UPX2PX, (number, newDeviceWidth) => { if (deviceWidth === 0) { checkDeviceWidth(); { checkMaxWidth(); } } number = Number(number); if (number === 0) { return 0; } let width = newDeviceWidth || deviceWidth; { width = number === includeWidth || width <= maxWidth ? width : baseWidth; } let result = number / BASE_DEVICE_WIDTH * width; if (result < 0) { result = -result; } result = Math.floor(result + EPS); if (result === 0) { if (deviceDPR === 1 || !isIOS) { result = 1; } else { result = 0.5; } } return number < 0 ? -result : result; }, Upx2pxProtocol ); const API_ADD_INTERCEPTOR = "addInterceptor"; const API_REMOVE_INTERCEPTOR = "removeInterceptor"; const AddInterceptorProtocol = [ { name: "method", type: [String, Object], required: true } ]; const RemoveInterceptorProtocol = AddInterceptorProtocol; function mergeInterceptorHook(interceptors2, interceptor) { Object.keys(interceptor).forEach((hook) => { if (isFunction(interceptor[hook])) { interceptors2[hook] = mergeHook( interceptors2[hook], interceptor[hook] ); } }); } function removeInterceptorHook(interceptors2, interceptor) { if (!interceptors2 || !interceptor) { return; } Object.keys(interceptor).forEach((name) => { const hooks = interceptors2[name]; const hook = interceptor[name]; if (isArray(hooks) && isFunction(hook)) { remove(hooks, hook); } }); } function mergeHook(parentVal, childVal) { const res = childVal ? parentVal ? parentVal.concat(childVal) : isArray(childVal) ? childVal : [childVal] : parentVal; return res ? dedupeHooks(res) : res; } function dedupeHooks(hooks) { const res = []; for (let i = 0; i < hooks.length; i++) { if (res.indexOf(hooks[i]) === -1) { res.push(hooks[i]); } } return res; } const 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); } }, AddInterceptorProtocol ); const 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); } }, RemoveInterceptorProtocol ); const interceptors = {}; const API_ON = "$on"; const OnProtocol = [ { name: "event", type: String, required: true }, { name: "callback", type: Function, required: true } ]; const API_ONCE = "$once"; const OnceProtocol = OnProtocol; const API_OFF = "$off"; const OffProtocol = [ { name: "event", type: [String, Array] }, { name: "callback", type: Function } ]; const API_EMIT = "$emit"; const EmitProtocol = [ { name: "event", type: String, required: true } ]; const emitter = new Emitter(); const $on = /* @__PURE__ */ defineSyncApi( API_ON, (name, callback) => { emitter.on(name, callback); return () => emitter.off(name, callback); }, OnProtocol ); const $once = /* @__PURE__ */ defineSyncApi( API_ONCE, (name, callback) => { emitter.once(name, callback); return () => emitter.off(name, callback); }, OnceProtocol ); const $off = /* @__PURE__ */ defineSyncApi( API_OFF, (name, callback) => { if (!name) { emitter.e = {}; return; } if (!isArray(name)) name = [name]; name.forEach((n) => emitter.off(n, callback)); }, OffProtocol ); const $emit = /* @__PURE__ */ defineSyncApi( API_EMIT, (name, ...args) => { emitter.emit(name, ...args); }, EmitProtocol ); const validator = [ { name: "id", type: String, required: true } ]; const API_CREATE_VIDEO_CONTEXT = "createVideoContext"; const API_CREATE_MAP_CONTEXT = "createMapContext"; const CreateMapContextProtocol = validator; const API_CREATE_CANVAS_CONTEXT = "createCanvasContext"; const CreateCanvasContextProtocol = [ { name: "canvasId", type: String, required: true }, { name: "componentInstance", type: Object } ]; const API_CREATE_INNER_AUDIO_CONTEXT = "createInnerAudioContext"; validator.concat({ name: "componentInstance", type: Object }); const RATES = [0.5, 0.8, 1, 1.25, 1.5, 2]; class VideoContext { constructor(id2, pageId) { this.id = id2; this.pageId = pageId; } play() { operateVideoPlayer(this.id, this.pageId, "play"); } pause() { operateVideoPlayer(this.id, this.pageId, "pause"); } stop() { operateVideoPlayer(this.id, this.pageId, "stop"); } seek(position) { operateVideoPlayer(this.id, this.pageId, "seek", { position }); } sendDanmu(args) { operateVideoPlayer(this.id, this.pageId, "sendDanmu", args); } playbackRate(rate) { if (!~RATES.indexOf(rate)) { rate = 1; } operateVideoPlayer(this.id, this.pageId, "playbackRate", { rate }); } requestFullScreen(args = {}) { operateVideoPlayer(this.id, this.pageId, "requestFullScreen", args); } exitFullScreen() { operateVideoPlayer(this.id, this.pageId, "exitFullScreen"); } showStatusBar() { operateVideoPlayer(this.id, this.pageId, "showStatusBar"); } hideStatusBar() { operateVideoPlayer(this.id, this.pageId, "hideStatusBar"); } } const createVideoContext = /* @__PURE__ */ defineSyncApi( API_CREATE_VIDEO_CONTEXT, (id2, context) => { if (context) { return new VideoContext(id2, getPageIdByVm(context)); } return new VideoContext(id2, getPageIdByVm(getCurrentPageVm())); } ); const operateMapCallback = (options, res) => { const errMsg = res.errMsg || ""; if (new RegExp("\\:\\s*fail").test(errMsg)) { options.fail && options.fail(res); } else { options.success && options.success(res); } options.complete && options.complete(res); }; const operateMapWrap = (id2, pageId, type, options) => { operateMap(id2, pageId, type, options, (res) => { options && operateMapCallback(options, res); }); }; class MapContext { constructor(id2, pageId) { this.id = id2; this.pageId = pageId; } getCenterLocation(options) { operateMapWrap(this.id, this.pageId, "getCenterLocation", options); } moveToLocation(options) { operateMapWrap(this.id, this.pageId, "moveToLocation", options); } getScale(options) { operateMapWrap(this.id, this.pageId, "getScale", options); } getRegion(options) { operateMapWrap(this.id, this.pageId, "getRegion", options); } includePoints(options) { operateMapWrap(this.id, this.pageId, "includePoints", options); } translateMarker(options) { operateMapWrap(this.id, this.pageId, "translateMarker", options); } $getAppMap() { } addCustomLayer(options) { operateMapWrap(this.id, this.pageId, "addCustomLayer", options); } removeCustomLayer(options) { operateMapWrap(this.id, this.pageId, "removeCustomLayer", options); } addGroundOverlay(options) { operateMapWrap(this.id, this.pageId, "addGroundOverlay", options); } removeGroundOverlay(options) { operateMapWrap(this.id, this.pageId, "removeGroundOverlay", options); } updateGroundOverlay(options) { operateMapWrap(this.id, this.pageId, "updateGroundOverlay", options); } initMarkerCluster(options) { operateMapWrap(this.id, this.pageId, "initMarkerCluster", options); } addMarkers(options) { operateMapWrap(this.id, this.pageId, "addMarkers", options); } removeMarkers(options) { operateMapWrap(this.id, this.pageId, "removeMarkers", options); } moveAlong(options) { operateMapWrap(this.id, this.pageId, "moveAlong", options); } setLocMarkerIcon(options) { operateMapWrap(this.id, this.pageId, "setLocMarkerIcon", options); } openMapApp(options) { operateMapWrap(this.id, this.pageId, "openMapApp", options); } on(name, callback) { operateMapWrap(this.id, this.pageId, "on", { name, callback }); } } const createMapContext = /* @__PURE__ */ defineSyncApi( API_CREATE_MAP_CONTEXT, (id2, context) => { if (context) { return new MapContext(id2, getPageIdByVm(context)); } return new MapContext(id2, getPageIdByVm(getCurrentPageVm())); }, CreateMapContextProtocol ); function getInt(name, defaultValue) { return function(value, params) { if (value) { params[name] = Math.round(value); } else if (typeof defaultValue !== "undefined") { params[name] = defaultValue; } }; } const formatWidth = getInt("width"); const formatHeight = getInt("height"); const API_CANVAS_GET_IMAGE_DATA = "canvasGetImageData"; const CanvasGetImageDataOptions = { formatArgs: { x: getInt("x"), y: getInt("y"), width: formatWidth, height: formatHeight } }; const CanvasGetImageDataProtocol = { canvasId: { type: String, required: true }, x: { type: Number, required: true }, y: { type: Number, required: true }, width: { type: Number, required: true }, height: { type: Number, required: true } }; const API_CANVAS_PUT_IMAGE_DATA = "canvasPutImageData"; const CanvasPutImageDataOptions = CanvasGetImageDataOptions; const CanvasPutImageDataProtocol = /* @__PURE__ */ extend( { data: { type: Uint8ClampedArray, required: true } }, CanvasGetImageDataProtocol, { height: { type: Number } } ); const fileTypes = { PNG: "png", JPG: "jpg", JPEG: "jpg" }; const API_CANVAS_TO_TEMP_FILE_PATH = "canvasToTempFilePath"; const CanvasToTempFilePathOptions = { formatArgs: { x: getInt("x", 0), y: getInt("y", 0), width: formatWidth, height: formatHeight, destWidth: getInt("destWidth"), destHeight: getInt("destHeight"), fileType(value, params) { value = (value || "").toUpperCase(); let type = fileTypes[value]; if (!type) { type = fileTypes.PNG; } params.fileType = type; }, quality(value, params) { params.quality = value && value > 0 && value < 1 ? value : 1; } } }; const CanvasToTempFilePathProtocol = { x: Number, y: Number, width: Number, height: Number, destWidth: Number, destHeight: Number, canvasId: { type: String, required: true }, fileType: String, quality: Number }; function operateCanvas(canvasId, pageId, type, data, callback) { UniServiceJSBridge.invokeViewMethod( `canvas.${canvasId}`, { type, data }, pageId, (data2) => { if (callback) callback(data2); } ); } var methods1 = ["scale", "rotate", "translate", "setTransform", "transform"]; var methods2 = [ "drawImage", "fillText", "fill", "stroke", "fillRect", "strokeRect", "clearRect", "strokeText" ]; var methods3 = [ "setFillStyle", "setTextAlign", "setStrokeStyle", "setGlobalAlpha", "setShadow", "setFontSize", "setLineCap", "setLineJoin", "setLineWidth", "setMiterLimit", "setTextBaseline", "setLineDash" ]; function measureText(text2, font2) { const canvas = document.createElement("canvas"); const c2d = canvas.getContext("2d"); c2d.font = font2; return c2d.measureText(text2).width || 0; } const predefinedColor = { aliceblue: "#f0f8ff", antiquewhite: "#faebd7", aqua: "#00ffff", aquamarine: "#7fffd4", azure: "#f0ffff", beige: "#f5f5dc", bisque: "#ffe4c4", black: "#000000", blanchedalmond: "#ffebcd", blue: "#0000ff", blueviolet: "#8a2be2", brown: "#a52a2a", burlywood: "#deb887", cadetblue: "#5f9ea0", chartreuse: "#7fff00", chocolate: "#d2691e", coral: "#ff7f50", cornflowerblue: "#6495ed", cornsilk: "#fff8dc", crimson: "#dc143c", cyan: "#00ffff", darkblue: "#00008b", darkcyan: "#008b8b", darkgoldenrod: "#b8860b", darkgray: "#a9a9a9", darkgrey: "#a9a9a9", darkgreen: "#006400", darkkhaki: "#bdb76b", darkmagenta: "#8b008b", darkolivegreen: "#556b2f", darkorange: "#ff8c00", darkorchid: "#9932cc", darkred: "#8b0000", darksalmon: "#e9967a", darkseagreen: "#8fbc8f", darkslateblue: "#483d8b", darkslategray: "#2f4f4f", darkslategrey: "#2f4f4f", darkturquoise: "#00ced1", darkviolet: "#9400d3", deeppink: "#ff1493", deepskyblue: "#00bfff", dimgray: "#696969", dimgrey: "#696969", dodgerblue: "#1e90ff", firebrick: "#b22222", floralwhite: "#fffaf0", forestgreen: "#228b22", fuchsia: "#ff00ff", gainsboro: "#dcdcdc", ghostwhite: "#f8f8ff", gold: "#ffd700", goldenrod: "#daa520", gray: "#808080", grey: "#808080", green: "#008000", greenyellow: "#adff2f", honeydew: "#f0fff0", hotpink: "#ff69b4", indianred: "#cd5c5c", indigo: "#4b0082", ivory: "#fffff0", khaki: "#f0e68c", lavender: "#e6e6fa", lavenderblush: "#fff0f5", lawngreen: "#7cfc00", lemonchiffon: "#fffacd", lightblue: "#add8e6", lightcoral: "#f08080", lightcyan: "#e0ffff", lightgoldenrodyellow: "#fafad2", lightgray: "#d3d3d3", lightgrey: "#d3d3d3", lightgreen: "#90ee90", lightpink: "#ffb6c1", lightsalmon: "#ffa07a", lightseagreen: "#20b2aa", lightskyblue: "#87cefa", lightslategray: "#778899", lightslategrey: "#778899", lightsteelblue: "#b0c4de", lightyellow: "#ffffe0", lime: "#00ff00", limegreen: "#32cd32", linen: "#faf0e6", magenta: "#ff00ff", maroon: "#800000", mediumaquamarine: "#66cdaa", mediumblue: "#0000cd", mediumorchid: "#ba55d3", mediumpurple: "#9370db", mediumseagreen: "#3cb371", mediumslateblue: "#7b68ee", mediumspringgreen: "#00fa9a", mediumturquoise: "#48d1cc", mediumvioletred: "#c71585", midnightblue: "#191970", mintcream: "#f5fffa", mistyrose: "#ffe4e1", moccasin: "#ffe4b5", navajowhite: "#ffdead", navy: "#000080", oldlace: "#fdf5e6", olive: "#808000", olivedrab: "#6b8e23", orange: "#ffa500", orangered: "#ff4500", orchid: "#da70d6", palegoldenrod: "#eee8aa", palegreen: "#98fb98", paleturquoise: "#afeeee", palevioletred: "#db7093", papayawhip: "#ffefd5", peachpuff: "#ffdab9", peru: "#cd853f", pink: "#ffc0cb", plum: "#dda0dd", powderblue: "#b0e0e6", purple: "#800080", rebeccapurple: "#663399", red: "#ff0000", rosybrown: "#bc8f8f", royalblue: "#4169e1", saddlebrown: "#8b4513", salmon: "#fa8072", sandybrown: "#f4a460", seagreen: "#2e8b57", seashell: "#fff5ee", sienna: "#a0522d", silver: "#c0c0c0", skyblue: "#87ceeb", slateblue: "#6a5acd", slategray: "#708090", slategrey: "#708090", snow: "#fffafa", springgreen: "#00ff7f", steelblue: "#4682b4", tan: "#d2b48c", teal: "#008080", thistle: "#d8bfd8", tomato: "#ff6347", turquoise: "#40e0d0", violet: "#ee82ee", wheat: "#f5deb3", white: "#ffffff", whitesmoke: "#f5f5f5", yellow: "#ffff00", yellowgreen: "#9acd32", transparent: "#00000000" }; function checkColor(e2) { e2 = e2 || "#000000"; var t2 = null; if ((t2 = /^#([0-9|A-F|a-f]{6})$/.exec(e2)) != null) { const n = parseInt(t2[1].slice(0, 2), 16); const o2 = parseInt(t2[1].slice(2, 4), 16); const r = parseInt(t2[1].slice(4), 16); return [n, o2, r, 255]; } if ((t2 = /^#([0-9|A-F|a-f]{3})$/.exec(e2)) != null) { let n = t2[1].slice(0, 1); let o2 = t2[1].slice(1, 2); let r = t2[1].slice(2, 3); n = parseInt(n + n, 16); o2 = parseInt(o2 + o2, 16); r = parseInt(r + r, 16); return [n, o2, r, 255]; } if ((t2 = /^rgb\((.+)\)$/.exec(e2)) != null) { return t2[1].split(",").map(function(e22) { return Math.min(255, parseInt(e22.trim())); }).concat(255); } if ((t2 = /^rgba\((.+)\)$/.exec(e2)) != null) { return t2[1].split(",").map(function(e22, t22) { return t22 === 3 ? Math.floor(255 * parseFloat(e22.trim())) : Math.min(255, parseInt(e22.trim())); }); } var i = e2.toLowerCase(); if (hasOwn(predefinedColor, i)) { t2 = /^#([0-9|A-F|a-f]{6,8})$/.exec(predefinedColor[i]); const n = parseInt(t2[1].slice(0, 2), 16); const o2 = parseInt(t2[1].slice(2, 4), 16); const r = parseInt(t2[1].slice(4, 6), 16); let a2 = parseInt(t2[1].slice(6, 8), 16); a2 = a2 >= 0 ? a2 : 255; return [n, o2, r, a2]; } console.error("unsupported color:" + e2); return [0, 0, 0, 255]; } class CanvasGradient { constructor(type, data) { this.type = type; this.data = data; this.colorStop = []; } addColorStop(position, color) { this.colorStop.push([position, checkColor(color)]); } } class Pattern { constructor(image2, repetition) { this.type = "pattern"; this.data = image2; this.colorStop = repetition; } } class TextMetrics { constructor(width) { this.width = width; } } class CanvasContext { constructor(id2, pageId) { this.id = id2; this.pageId = pageId; this.actions = []; this.path = []; this.subpath = []; this.drawingState = []; this.state = { lineDash: [0, 0], shadowOffsetX: 0, shadowOffsetY: 0, shadowBlur: 0, shadowColor: [0, 0, 0, 0], font: "10px sans-serif", fontSize: 10, fontWeight: "normal", fontStyle: "normal", fontFamily: "sans-serif" }; } draw(reserve = false, callback) { var actions = [...this.actions]; this.actions = []; this.path = []; operateCanvas( this.id, this.pageId, "actionsChanged", { actions, reserve }, callback ); } createLinearGradient(x0, y0, x1, y1) { return new CanvasGradient("linear", [x0, y0, x1, y1]); } createCircularGradient(x, y, r) { return new CanvasGradient("radial", [x, y, r]); } createPattern(image2, repetition) { if (void 0 === repetition) { console.error( "Failed to execute 'createPattern' on 'CanvasContext': 2 arguments required, but only 1 present." ); } else if (["repeat", "repeat-x", "repeat-y", "no-repeat"].indexOf(repetition) < 0) { console.error( "Failed to execute 'createPattern' on 'CanvasContext': The provided type ('" + repetition + "') is not one of 'repeat', 'no-repeat', 'repeat-x', or 'repeat-y'." ); } else { return new Pattern(image2, repetition); } } measureText(text2) { const font2 = this.state.font; let width = 0; { width = measureText(text2, font2); } return new TextMetrics(width); } save() { this.actions.push({ method: "save", data: [] }); this.drawingState.push(this.state); } restore() { this.actions.push({ method: "restore", data: [] }); this.state = this.drawingState.pop() || { lineDash: [0, 0], shadowOffsetX: 0, shadowOffsetY: 0, shadowBlur: 0, shadowColor: [0, 0, 0, 0], font: "10px sans-serif", fontSize: 10, fontWeight: "normal", fontStyle: "normal", fontFamily: "sans-serif" }; } beginPath() { this.path = []; this.subpath = []; this.path.push({ method: "beginPath", data: [] }); } moveTo(x, y) { this.path.push({ method: "moveTo", data: [x, y] }); this.subpath = [[x, y]]; } lineTo(x, y) { if (this.path.length === 0 && this.subpath.length === 0) { this.path.push({ method: "moveTo", data: [x, y] }); } else { this.path.push({ method: "lineTo", data: [x, y] }); } this.subpath.push([x, y]); } quadraticCurveTo(cpx, cpy, x, y) { this.path.push({ method: "quadraticCurveTo", data: [cpx, cpy, x, y] }); this.subpath.push([x, y]); } bezierCurveTo(cp1x, cp1y, cp2x, cp2y, x, y) { this.path.push({ method: "bezierCurveTo", data: [cp1x, cp1y, cp2x, cp2y, x, y] }); this.subpath.push([x, y]); } arc(x, y, r, sAngle, eAngle, counterclockwise = false) { this.path.push({ method: "arc", data: [x, y, r, sAngle, eAngle, counterclockwise] }); this.subpath.push([x, y]); } rect(x, y, width, height) { this.path.push({ method: "rect", data: [x, y, width, height] }); this.subpath = [[x, y]]; } arcTo(x1, y1, x2, y2, radius) { this.path.push({ method: "arcTo", data: [x1, y1, x2, y2, radius] }); this.subpath.push([x2, y2]); } clip() { this.actions.push({ method: "clip", data: [...this.path] }); } closePath() { this.path.push({ method: "closePath", data: [] }); if (this.subpath.length) { this.subpath = [this.subpath.shift()]; } } clearActions() { this.actions = []; this.path = []; this.subpath = []; } getActions() { var actions = [...this.actions]; this.clearActions(); return actions; } set lineDashOffset(value) { this.actions.push({ method: "setLineDashOffset", data: [value] }); } set globalCompositeOperation(type) { this.actions.push({ method: "setGlobalCompositeOperation", data: [type] }); } set shadowBlur(level) { this.actions.push({ method: "setShadowBlur", data: [level] }); } set shadowColor(color) { this.actions.push({ method: "setShadowColor", data: [color] }); } set shadowOffsetX(x) { this.actions.push({ method: "setShadowOffsetX", data: [x] }); } set shadowOffsetY(y) { this.actions.push({ method: "setShadowOffsetY", data: [y] }); } set font(value) { var self = this; this.state.font = value; var fontFormat = value.match( /^(([\w\-]+\s)*)(\d+r?px)(\/(\d+\.?\d*(r?px)?))?\s+(.*)/ ); if (fontFormat) { var style = fontFormat[1].trim().split(/\s/); var fontSize = parseFloat(fontFormat[3]); var fontFamily = fontFormat[7]; var actions = []; style.forEach(function(value2, index2) { if (["italic", "oblique", "normal"].indexOf(value2) > -1) { actions.push({ method: "setFontStyle", data: [value2] }); self.state.fontStyle = value2; } else if (["bold", "normal"].indexOf(value2) > -1) { actions.push({ method: "setFontWeight", data: [value2] }); self.state.fontWeight = value2; } else if (index2 === 0) { actions.push({ method: "setFontStyle", data: ["normal"] }); self.state.fontStyle = "normal"; } else if (index2 === 1) { pushAction(); } }); if (style.length === 1) { pushAction(); } style = actions.map(function(action) { return action.data[0]; }).join(" "); this.state.fontSize = fontSize; this.state.fontFamily = fontFamily; this.actions.push({ method: "setFont", data: [`${style} ${fontSize}px ${fontFamily}`] }); } else { console.warn("Failed to set 'font' on 'CanvasContext': invalid format."); } function pushAction() { actions.push({ method: "setFontWeight", data: ["normal"] }); self.state.fontWeight = "normal"; } } get font() { return this.state.font; } set fillStyle(color) { this.setFillStyle(color); } set strokeStyle(color) { this.setStrokeStyle(color); } set globalAlpha(value) { value = Math.floor(255 * parseFloat(value)); this.actions.push({ method: "setGlobalAlpha", data: [value] }); } set textAlign(align2) { this.actions.push({ method: "setTextAlign", data: [align2] }); } set lineCap(type) { this.actions.push({ method: "setLineCap", data: [type] }); } set lineJoin(type) { this.actions.push({ method: "setLineJoin", data: [type] }); } set lineWidth(value) { this.actions.push({ method: "setLineWidth", data: [value] }); } set miterLimit(value) { this.actions.push({ method: "setMiterLimit", data: [value] }); } set textBaseline(type) { this.actions.push({ method: "setTextBaseline", data: [type] }); } } const initCanvasContextProperty = /* @__PURE__ */ once(() => { [...methods1, ...methods2].forEach(function(method) { function get(method2) { switch (method2) { case "fill": case "stroke": return function() { this.actions.push({ method: method2 + "Path", // @ts-ignore data: [...this.path] }); }; case "fillRect": return function(x, y, width, height) { this.actions.push({ method: "fillPath", data: [ { method: "rect", data: [x, y, width, height] } ] }); }; case "strokeRect": return function(x, y, width, height) { this.actions.push({ method: "strokePath", data: [ { method: "rect", data: [x, y, width, height] } ] }); }; case "fillText": case "strokeText": return function(text2, x, y, maxWidth2) { var data = [text2.toString(), x, y]; if (typeof maxWidth2 === "number") { data.push(maxWidth2); } this.actions.push({ method: method2, data }); }; case "drawImage": return function(imageResource, dx, dy, dWidth, dHeight, sx, sy, sWidth, sHeight) { if (sHeight === void 0) { sx = dx; sy = dy; sWidth = dWidth; sHeight = dHeight; dx = void 0; dy = void 0; dWidth = void 0; dHeight = void 0; } var data; function isNumber(e2) { return typeof e2 === "number"; } data = isNumber(dx) && isNumber(dy) && isNumber(dWidth) && isNumber(dHeight) ? [ imageResource, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight ] : isNumber(sWidth) && isNumber(sHeight) ? [imageResource, sx, sy, sWidth, sHeight] : [imageResource, sx, sy]; this.actions.push({ method: method2, data }); }; default: return function(...data) { this.actions.push({ method: method2, data }); }; } } CanvasContext.prototype[method] = get(method); }); methods3.forEach(function(method) { function get(method2) { switch (method2) { case "setFillStyle": case "setStrokeStyle": return function(color) { if (typeof color !== "object") { this.actions.push({ method: method2, data: ["normal", checkColor(color)] }); } else { this.actions.push({ method: method2, data: [color.type, color.data, color.colorStop] }); } }; case "setGlobalAlpha": return function(alpha) { alpha = Math.floor(255 * parseFloat(alpha)); this.actions.push({ method: method2, data: [alpha] }); }; case "setShadow": return function(offsetX, offsetY, blur, color) { color = checkColor(color); this.actions.push({ method: method2, data: [offsetX, offsetY, blur, color] }); this.state.shadowBlur = blur; this.state.shadowColor = color; this.state.shadowOffsetX = offsetX; this.state.shadowOffsetY = offsetY; }; case "setLineDash": return function(pattern, offset) { pattern = pattern || [0, 0]; offset = offset || 0; this.actions.push({ method: method2, data: [pattern, offset] }); this.state.lineDash = pattern; }; case "setFontSize": return function(fontSize) { this.state.font = this.state.font.replace( /\d+\.?\d*px/, fontSize + "px" ); this.state.fontSize = fontSize; this.actions.push({ method: method2, data: [fontSize] }); }; default: return function(...data) { this.actions.push({ method: method2, data }); }; } } CanvasContext.prototype[method] = get(method); }); }); const createCanvasContext = /* @__PURE__ */ defineSyncApi( API_CREATE_CANVAS_CONTEXT, (canvasId, componentInstance) => { initCanvasContextProperty(); if (componentInstance) { return new CanvasContext(canvasId, getPageIdByVm(componentInstance)); } const pageId = getPageIdByVm(getCurrentPageVm()); if (pageId) { return new CanvasContext(canvasId, pageId); } else { UniServiceJSBridge.emit(ON_ERROR, "createCanvasContext:fail"); } }, CreateCanvasContextProtocol ); const canvasGetImageData = /* @__PURE__ */ defineAsyncApi( API_CANVAS_GET_IMAGE_DATA, ({ canvasId, x, y, width, height }, { resolve, reject }) => { const pageId = getPageIdByVm(getCurrentPageVm()); if (!pageId) { reject(); return; } function callback(data) { if (data.errMsg && data.errMsg.indexOf("fail") !== -1) { reject("", data); return; } let imgData = data.data; if (imgData && imgData.length) { data.data = new Uint8ClampedArray(imgData); } delete data.compressed; resolve(data); } operateCanvas( canvasId, pageId, "getImageData", { x, y, width, height }, callback ); }, CanvasGetImageDataProtocol, CanvasGetImageDataOptions ); const canvasPutImageData = /* @__PURE__ */ defineAsyncApi( API_CANVAS_PUT_IMAGE_DATA, ({ canvasId, data, x, y, width, height }, { resolve, reject }) => { var pageId = getPageIdByVm(getCurrentPageVm()); if (!pageId) { reject(); return; } let compressed; const operate = () => { operateCanvas( canvasId, pageId, "putImageData", { data, x, y, width, height, compressed }, (data2) => { if (data2.errMsg && data2.errMsg.indexOf("fail") !== -1) { reject(); return; } resolve(data2); } ); }; { data = Array.prototype.slice.call(data); } operate(); }, CanvasPutImageDataProtocol, CanvasPutImageDataOptions ); const canvasToTempFilePath = /* @__PURE__ */ defineAsyncApi( API_CANVAS_TO_TEMP_FILE_PATH, ({ x = 0, y = 0, width, height, destWidth, destHeight, canvasId, fileType, quality }, { resolve, reject }) => { var pageId = getPageIdByVm(getCurrentPageVm()); if (!pageId) { reject(); return; } const dirname = `${TEMP_PATH}/canvas`; operateCanvas( canvasId, pageId, "toTempFilePath", { x, y, width, height, destWidth, destHeight, fileType, quality, dirname }, (res) => { if (res.errMsg && res.errMsg.indexOf("fail") !== -1) { reject("", res); return; } resolve(res); } ); }, CanvasToTempFilePathProtocol, CanvasToTempFilePathOptions ); const innerAudioContextEventNames = [ "onCanplay", "onPlay", "onPause", "onStop", "onEnded", "onTimeUpdate", "onError", "onWaiting", "onSeeking", "onSeeked" ]; const innerAudioContextOffEventNames = [ "offCanplay", "offPlay", "offPause", "offStop", "offEnded", "offTimeUpdate", "offError", "offWaiting", "offSeeking", "offSeeked" ]; const defaultOptions = { thresholds: [0], initialRatio: 0, observeAll: false }; const MARGINS = ["top", "right", "bottom", "left"]; let reqComponentObserverId$1 = 1; function normalizeRootMargin(margins = {}) { return MARGINS.map( (name) => `${Number(margins[name]) || 0}px` ).join(" "); } class ServiceIntersectionObserver { constructor(component, options) { this._pageId = getPageIdByVm(component); this._component = component; this._options = extend({}, defaultOptions, options); } relativeTo(selector, margins) { this._options.relativeToSelector = selector; this._options.rootMargin = normalizeRootMargin(margins); return this; } relativeToViewport(margins) { this._options.relativeToSelector = void 0; this._options.rootMargin = normalizeRootMargin(margins); return this; } observe(selector, callback) { if (!isFunction(callback)) { return; } this._options.selector = selector; this._reqId = reqComponentObserverId$1++; addIntersectionObserver( { reqId: this._reqId, component: this._component, options: this._options, callback }, this._pageId ); } disconnect() { this._reqId && removeIntersectionObserver( { reqId: this._reqId, component: this._component }, this._pageId ); } } const createIntersectionObserver = /* @__PURE__ */ defineSyncApi("createIntersectionObserver", (context, options) => { context = resolveComponentInstance(context); if (context && !getPageIdByVm(context)) { options = context; context = null; } if (context) { return new ServiceIntersectionObserver(context, options); } return new ServiceIntersectionObserver(getCurrentPageVm(), options); }); let reqComponentObserverId = 1; class ServiceMediaQueryObserver { constructor(component) { this._pageId = component.$page && component.$page.id; this._component = component; } observe(options, callback) { if (!isFunction(callback)) { return; } this._reqId = reqComponentObserverId++; addMediaQueryObserver( { reqId: this._reqId, component: this._component, options, callback }, this._pageId ); } disconnect() { this._reqId && removeMediaQueryObserver( { reqId: this._reqId, component: this._component }, this._pageId ); } } const createMediaQueryObserver = /* @__PURE__ */ defineSyncApi("createMediaQueryObserver", (context) => { context = resolveComponentInstance(context); if (context && !getPageIdByVm(context)) { context = null; } if (context) { return new ServiceMediaQueryObserver(context); } return new ServiceMediaQueryObserver(getCurrentPageVm()); }); let index$w = 0; let optionsCache = {}; function operateEditor(componentId, pageId, type, options) { const data = { options }; const needCallOptions = options && ("success" in options || "fail" in options || "complete" in options); if (needCallOptions) { const callbackId = String(index$w++); data.callbackId = callbackId; optionsCache[callbackId] = options; } UniServiceJSBridge.invokeViewMethod( `editor.${componentId}`, { type, data }, pageId, ({ callbackId, data: data2 }) => { if (needCallOptions) { callOptions(optionsCache[callbackId], data2); delete optionsCache[callbackId]; } } ); } class EditorContext { constructor(id2, pageId) { this.id = id2; this.pageId = pageId; } format(name, value) { this._exec("format", { name, value }); } insertDivider() { this._exec("insertDivider"); } insertImage(options) { this._exec("insertImage", options); } insertText(options) { this._exec("insertText", options); } setContents(options) { this._exec("setContents", options); } getContents(options) { this._exec("getContents", options); } clear(options) { this._exec("clear", options); } removeFormat(options) { this._exec("removeFormat", options); } undo(options) { this._exec("undo", options); } redo(options) { this._exec("redo", options); } blur(options) { this._exec("blur", options); } getSelectionText(options) { this._exec("getSelectionText", options); } scrollIntoView(options) { this._exec("scrollIntoView", options); } _exec(method, options) { operateEditor(this.id, this.pageId, method, options); } } const ContextClasss = { canvas: CanvasContext, map: MapContext, video: VideoContext, editor: EditorContext }; function convertContext(result) { if (result && result.contextInfo) { const { id: id2, type, page } = result.contextInfo; const ContextClass = ContextClasss[type]; result.context = new ContextClass(id2, page); delete result.contextInfo; } } class NodesRef { constructor(selectorQuery, component, selector, single) { this._selectorQuery = selectorQuery; this._component = component; this._selector = selector; this._single = single; } boundingClientRect(callback) { this._selectorQuery._push( this._selector, this._component, this._single, { id: true, dataset: true, rect: true, size: true }, callback ); return this._selectorQuery; } fields(fields2, callback) { this._selectorQuery._push( this._selector, this._component, this._single, fields2, 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; } node(_callback) { return this._selectorQuery; } } class SelectorQuery { constructor(page) { this._component = void 0; this._page = page; this._queue = []; this._queueCb = []; } exec(callback) { requestComponentInfo( this._page, this._queue, (res) => { const queueCbs = this._queueCb; res.forEach((result, index2) => { if (isArray(result)) { result.forEach(convertContext); } else { convertContext(result); } const queueCb = queueCbs[index2]; if (isFunction(queueCb)) { queueCb.call(this, result); } }); if (isFunction(callback)) { callback.call(this, res); } } ); return this._nodesRef; } in(component) { this._component = resolveComponentInstance(component); return this; } select(selector) { return this._nodesRef = new NodesRef( this, this._component, selector, true ); } selectAll(selector) { return this._nodesRef = new NodesRef( this, this._component, selector, false ); } selectViewport() { return this._nodesRef = new NodesRef(this, null, "", true); } _push(selector, component, single, fields2, callback) { this._queue.push({ component, selector, single, fields: fields2 }); this._queueCb.push(callback); } } const createSelectorQuery = /* @__PURE__ */ defineSyncApi("createSelectorQuery", (context) => { context = resolveComponentInstance(context); if (context && !getPageIdByVm(context)) { context = null; } return new SelectorQuery(context || getCurrentPageVm()); }); const API_CREATE_ANIMATION = "createAnimation"; const CreateAnimationOptions = { // 目前参数校验不支持此api校验 formatArgs: { /* duration: 400, timingFunction(timingFunction, params) { params.timingFunction = elemInArray(timingFunction, timingFunctions) }, delay: 0, transformOrigin: '50% 50% 0', */ } }; const CreateAnimationProtocol = { duration: Number, timingFunction: String, delay: Number, transformOrigin: String }; const defaultOption = { duration: 400, timingFunction: "linear", delay: 0, transformOrigin: "50% 50% 0" }; class MPAnimation { constructor(option) { this.actions = []; this.currentTransform = {}; this.currentStepAnimates = []; this.option = extend({}, defaultOption, option); } _getOption(option) { const _option = { transition: extend({}, this.option, option), transformOrigin: "" }; _option.transformOrigin = _option.transition.transformOrigin; delete _option.transition.transformOrigin; return _option; } _pushAnimates(type, args) { this.currentStepAnimates.push({ type, args }); } _converType(type) { return type.replace(/[A-Z]/g, (text2) => { return `-${text2.toLowerCase()}`; }); } _getValue(value) { return typeof value === "number" ? `${value}px` : value; } export() { const actions = this.actions; this.actions = []; return { actions }; } step(option) { this.currentStepAnimates.forEach((animate) => { if (animate.type !== "style") { this.currentTransform[animate.type] = animate; } else { this.currentTransform[`${animate.type}.${animate.args[0]}`] = animate; } }); this.actions.push({ animates: Object.values( this.currentTransform ), option: this._getOption(option) }); this.currentStepAnimates = []; return this; } } const initAnimationProperty = /* @__PURE__ */ once(() => { const animateTypes1 = [ "matrix", "matrix3d", "rotate", "rotate3d", "rotateX", "rotateY", "rotateZ", "scale", "scale3d", "scaleX", "scaleY", "scaleZ", "skew", "skewX", "skewY", "translate", "translate3d", "translateX", "translateY", "translateZ" ]; const animateTypes2 = ["opacity", "backgroundColor"]; const animateTypes3 = ["width", "height", "left", "right", "top", "bottom"]; animateTypes1.concat(animateTypes2, animateTypes3).forEach((type) => { MPAnimation.prototype[type] = function(...args) { if (animateTypes2.concat(animateTypes3).includes(type)) { this._pushAnimates("style", [ this._converType(type), animateTypes3.includes(type) ? this._getValue(args[0]) : args[0] ]); } else { this._pushAnimates(type, args); } return this; }; }); }); const createAnimation$1 = /* @__PURE__ */ defineSyncApi( API_CREATE_ANIMATION, (option) => { initAnimationProperty(); return new MPAnimation(option); }, CreateAnimationProtocol, CreateAnimationOptions ); const API_ON_TAB_BAR_MID_BUTTON_TAP = "onTabBarMidButtonTap"; const onTabBarMidButtonTap = /* @__PURE__ */ defineOnApi( API_ON_TAB_BAR_MID_BUTTON_TAP, () => { } ); const API_ON_WINDOW_RESIZE = "onWindowResize"; const API_OFF_WINDOW_RESIZE = "offWindowResize"; const onWindowResize = /* @__PURE__ */ defineOnApi( API_ON_WINDOW_RESIZE, () => { } ); const offWindowResize = /* @__PURE__ */ defineOffApi( API_OFF_WINDOW_RESIZE, () => { } ); const API_SET_LOCALE = "setLocale"; const API_GET_LOCALE = "getLocale"; const API_ON_LOCALE_CHANGE = "onLocaleChange"; const getLocale = /* @__PURE__ */ defineSyncApi( API_GET_LOCALE, () => { const app = getApp({ allowDefault: true }); if (app && app.$vm) { return app.$vm.$locale; } return useI18n().getLocale(); } ); const onLocaleChange = /* @__PURE__ */ defineOnApi( API_ON_LOCALE_CHANGE, () => { } ); const setLocale = /* @__PURE__ */ defineSyncApi( API_SET_LOCALE, (locale) => { const app = getApp(); if (!app) { return false; } const oldLocale = app.$vm.$locale; if (oldLocale !== locale) { app.$vm.$locale = locale; { navigator.cookieEnabled && window.localStorage && (localStorage[UNI_STORAGE_LOCALE] = locale); } UniServiceJSBridge.invokeOnCallback(API_ON_LOCALE_CHANGE, { locale }); return true; } return false; } ); const API_SET_PAGE_META = "setPageMeta"; const setPageMeta = /* @__PURE__ */ defineAsyncApi( API_SET_PAGE_META, (options, { resolve }) => { resolve(setCurrentPageMeta(getCurrentPageVm(), options)); } ); const API_GET_SELECTED_TEXT_RANGE = "getSelectedTextRange"; const getSelectedTextRange$1 = /* @__PURE__ */ defineAsyncApi( API_GET_SELECTED_TEXT_RANGE, (_, { resolve, reject }) => { UniServiceJSBridge.invokeViewMethod(API_GET_SELECTED_TEXT_RANGE, {}, getCurrentPageId(), (res) => { if (typeof res.end === "undefined" && typeof res.start === "undefined") { reject("no focused"); } else { resolve(res); } }); } ); const appHooks = { [ON_UNHANDLE_REJECTION]: [], [ON_PAGE_NOT_FOUND]: [], [ON_ERROR]: [], [ON_SHOW]: [], [ON_HIDE]: [] }; function onAppHook(type, hook) { const app = getApp({ allowDefault: true }); if (app && app.$vm) { return injectHook(type, hook, app.$vm.$); } appHooks[type].push(hook); } function injectAppHooks(appInstance) { Object.keys(appHooks).forEach((type) => { appHooks[type].forEach((hook) => { injectHook(type, hook, appInstance); }); }); } function offAppHook(type, hook) { const app = getApp({ allowDefault: true }); if (app && app.$vm) { return removeHook(app.$vm, type, hook); } remove(appHooks[type], hook); } function onUnhandledRejection(hook) { onAppHook(ON_UNHANDLE_REJECTION, hook); } function offUnhandledRejection(hook) { offAppHook(ON_UNHANDLE_REJECTION, hook); } function onPageNotFound(hook) { onAppHook(ON_PAGE_NOT_FOUND, hook); } function offPageNotFound(hook) { offAppHook(ON_PAGE_NOT_FOUND, hook); } function onError(hook) { onAppHook(ON_ERROR, hook); } function offError(hook) { offAppHook(ON_ERROR, hook); } function onAppShow(hook) { onAppHook(ON_SHOW, hook); } function offAppShow(hook) { offAppHook(ON_SHOW, hook); } function onAppHide(hook) { onAppHook(ON_HIDE, hook); } function offAppHide(hook) { offAppHook(ON_HIDE, hook); } const API_GET_ENTER_OPTIONS_SYNC = "getEnterOptionsSync"; const getEnterOptionsSync = /* @__PURE__ */ defineSyncApi( API_GET_ENTER_OPTIONS_SYNC, () => { return getEnterOptions(); } ); const API_GET_LAUNCH_OPTIONS_SYNC = "getLaunchOptionsSync"; const getLaunchOptionsSync = /* @__PURE__ */ defineSyncApi( API_GET_LAUNCH_OPTIONS_SYNC, () => { return getLaunchOptions(); } ); let cid; let cidErrMsg; let enabled; function normalizePushMessage(message) { try { return JSON.parse(message); } catch (e2) { } return message; } function invokePushCallback(args) { if (args.type === "enabled") { enabled = true; } else if (args.type === "clientId") { cid = args.cid; cidErrMsg = args.errMsg; invokeGetPushCidCallbacks(cid, args.errMsg); } else if (args.type === "pushMsg") { const message = { type: "receive", data: normalizePushMessage(args.message) }; for (let i = 0; i < onPushMessageCallbacks.length; i++) { const callback = onPushMessageCallbacks[i]; callback(message); if (message.stopped) { break; } } } else if (args.type === "click") { onPushMessageCallbacks.forEach((callback) => { callback({ type: "click", data: normalizePushMessage(args.message) }); }); } } const getPushCidCallbacks = []; function invokeGetPushCidCallbacks(cid2, errMsg) { getPushCidCallbacks.forEach((callback) => { callback(cid2, errMsg); }); getPushCidCallbacks.length = 0; } const API_GET_PUSH_CLIENT_ID = "getPushClientId"; const getPushClientId = /* @__PURE__ */ defineAsyncApi( API_GET_PUSH_CLIENT_ID, (_, { resolve, reject }) => { Promise.resolve().then(() => { if (typeof enabled === "undefined") { enabled = false; cid = ""; cidErrMsg = "uniPush is not enabled"; } getPushCidCallbacks.push((cid2, errMsg) => { if (cid2) { resolve({ cid: cid2 }); } else { reject(errMsg); } }); if (typeof cid !== "undefined") { invokeGetPushCidCallbacks(cid, cidErrMsg); } }); } ); const onPushMessageCallbacks = []; const onPushMessage = (fn) => { if (onPushMessageCallbacks.indexOf(fn) === -1) { onPushMessageCallbacks.push(fn); } }; const offPushMessage = (fn) => { if (!fn) { onPushMessageCallbacks.length = 0; } else { const index2 = onPushMessageCallbacks.indexOf(fn); if (index2 > -1) { onPushMessageCallbacks.splice(index2, 1); } } }; const API_CAN_I_USE = "canIUse"; const CanIUseProtocol = [ { name: "schema", type: String, required: true } ]; const API_MAKE_PHONE_CALL = "makePhoneCall"; const MakePhoneCallProtocol = { phoneNumber: String }; const API_GET_CLIPBOARD_DATA = "getClipboardData"; const API_SET_CLIPBOARD_DATA = "setClipboardData"; const SetClipboardDataOptions = { formatArgs: { showToast: true }, beforeInvoke() { initI18nSetClipboardDataMsgsOnce(); }, beforeSuccess(res, params) { if (!params.showToast) return; const { t: t2 } = useI18n(); const title = t2("uni.setClipboardData.success"); if (title) { uni.showToast({ title, icon: "success", mask: false }); } } }; const SetClipboardDataProtocol = { data: { type: String, required: true }, showToast: { type: Boolean } }; const API_ON_ACCELEROMETER = "onAccelerometer"; const API_OFF_ACCELEROMETER = "offAccelerometer"; const API_START_ACCELEROMETER = "startAccelerometer"; const API_STOP_ACCELEROMETER = "stopAccelerometer"; const API_ON_COMPASS = "onCompass"; const API_OFF_COMPASS = "offCompass"; const API_START_COMPASS = "startCompass"; const API_STOP_COMPASS = "stopCompass"; const API_VIBRATE_SHORT = "vibrateShort"; const API_VIBRATE_LONG = "vibrateLong"; const API_GET_STORAGE = "getStorage"; const GetStorageProtocol = { key: { type: String, required: true } }; const API_GET_STORAGE_SYNC = "getStorageSync"; const GetStorageSyncProtocol = [ { name: "key", type: String, required: true } ]; const API_SET_STORAGE = "setStorage"; const SetStorageProtocol = { key: { type: String, required: true }, data: { required: true } }; const API_SET_STORAGE_SYNC = "setStorageSync"; const SetStorageSyncProtocol = [ { name: "key", type: String, required: true }, { name: "data", required: true } ]; const API_REMOVE_STORAGE = "removeStorage"; const RemoveStorageProtocol = GetStorageProtocol; const RemoveStorageSyncProtocol = GetStorageSyncProtocol; const API_GET_FILE_INFO = "getFileInfo"; const GetFileInfoOptions = { formatArgs: { filePath(filePath, params) { params.filePath = getRealPath(filePath); } } }; const GetFileInfoProtocol = { filePath: { type: String, required: true } }; const API_OPEN_DOCUMENT = "openDocument"; const OpenDocumentOptions = { formatArgs: { filePath(filePath, params) { params.filePath = getRealPath(filePath); } } }; const OpenDocumentProtocol = { filePath: { type: String, required: true }, fileType: String }; const API_HIDE_KEYBOARD = "hideKeyboard"; const API_CHOOSE_LOCATION = "chooseLocation"; const ChooseLocationProtocol = { keyword: String, latitude: Number, longitude: Number }; const API_GET_LOCATION = "getLocation"; const coordTypes$1 = ["wgs84", "gcj02"]; const GetLocationOptions = { formatArgs: { type(value, params) { value = (value || "").toLowerCase(); if (coordTypes$1.indexOf(value) === -1) { params.type = coordTypes$1[0]; } else { params.type = value; } }, altitude(value, params) { params.altitude = value ? value : false; } } }; const GetLocationProtocol = { type: String, altitude: Boolean }; const API_OPEN_LOCATION = "openLocation"; const checkProps = (key, value) => { if (value === void 0) { return `${key} should not be empty.`; } if (typeof value !== "number") { let receivedType = typeof value; receivedType = receivedType[0].toUpperCase() + receivedType.substring(1); return `Expected Number, got ${receivedType} with value ${JSON.stringify( value )}.`; } }; const OpenLocationOptions = { formatArgs: { latitude(value, params) { const checkedInfo = checkProps("latitude", value); if (checkedInfo) { return checkedInfo; } params.latitude = value; }, longitude(value, params) { const checkedInfo = checkProps("longitude", value); if (checkedInfo) { return checkedInfo; } params.longitude = value; }, scale(value, params) { value = Math.floor(value); params.scale = value >= 5 && value <= 18 ? value : 18; } } }; const OpenLocationProtocol = { latitude: Number, longitude: Number, scale: Number, name: String, address: String }; const API_CHOOSE_IMAGE = "chooseImage"; const ChooseImageOptions = { formatArgs: { count(value, params) { if (!value || value <= 0) { params.count = 9; } }, sizeType(sizeType, params) { params.sizeType = elemsInArray(sizeType, CHOOSE_SIZE_TYPES); }, sourceType(sourceType, params) { params.sourceType = elemsInArray(sourceType, CHOOSE_SOURCE_TYPES); }, extension(extension, params) { if (extension instanceof Array && extension.length === 0) { return "param extension should not be empty."; } if (!extension) params.extension = ["*"]; } } }; const ChooseImageProtocol = { count: Number, sizeType: [Array, String], sourceType: Array, extension: Array }; const API_CHOOSE_VIDEO = "chooseVideo"; const ChooseVideoOptions = { formatArgs: { sourceType(sourceType, params) { params.sourceType = elemsInArray(sourceType, CHOOSE_SOURCE_TYPES); }, compressed: true, maxDuration: 60, camera: "back", extension(extension, params) { if (extension instanceof Array && extension.length === 0) { return "param extension should not be empty."; } if (!extension) params.extension = ["*"]; } } }; const ChooseVideoProtocol = { sourceType: Array, compressed: Boolean, maxDuration: Number, camera: String, extension: Array }; const API_CHOOSE_FILE = "chooseFile"; const CHOOSE_MEDIA_TYPE = [ "all", "image", "video" ]; const ChooseFileOptions = { formatArgs: { count(count, params) { if (!count || count <= 0) { params.count = 100; } }, sourceType(sourceType, params) { params.sourceType = elemsInArray(sourceType, CHOOSE_SOURCE_TYPES); }, type(type, params) { params.type = elemInArray(type, CHOOSE_MEDIA_TYPE); }, extension(extension, params) { if (extension instanceof Array && extension.length === 0) { return "param extension should not be empty."; } if (!extension) params.extension = [""]; } } }; const ChooseFileProtocol = { count: Number, sourceType: Array, type: String, extension: Array }; const API_GET_IMAGE_INFO = "getImageInfo"; const GetImageInfoOptions = { formatArgs: { src(src, params) { params.src = getRealPath(src); } } }; const GetImageInfoProtocol = { src: { type: String, required: true } }; const API_PREVIEW_IMAGE = "previewImage"; const PreviewImageOptions = { formatArgs: { urls(urls, params) { params.urls = urls.map( (url) => isString(url) && url ? getRealPath(url) : "" ); }, current(current, params) { if (typeof current === "number") { params.current = current > 0 && current < params.urls.length ? current : 0; } else if (isString(current) && current) { params.current = getRealPath(current); } } } }; const PreviewImageProtocol = { urls: { type: Array, required: true }, current: { type: [Number, String] } }; const API_CLOSE_PREVIEW_IMAGE = "closePreviewImage"; const API_GET_VIDEO_INFO = "getVideoInfo"; const GetVideoInfoOptions = { formatArgs: { src(src, params) { params.src = getRealPath(src); } } }; const GetVideoInfoProtocol = { src: { type: String, required: true } }; const API_SAVE_IMAGE_TO_PHOTOS_ALBUM = "saveImageToPhotosAlbum"; const API_SAVE_VIDEO_TO_PHOTOS_ALBUM = "saveVideoToPhotosAlbum"; const API_REQUEST = "request"; const dataType = { JSON: "json" }; const RESPONSE_TYPE = ["text", "arraybuffer"]; const DEFAULT_RESPONSE_TYPE = "text"; const encode = encodeURIComponent; function stringifyQuery(url, data) { let str = url.split("#"); const hash = str[1] || ""; str = str[0].split("?"); let query = str[1] || ""; url = str[0]; const search = query.split("&").filter((item) => item); const params = {}; search.forEach((item) => { const part = item.split("="); params[part[0]] = part[1]; }); for (const key in data) { if (hasOwn(data, key)) { let v2 = data[key]; if (typeof v2 === "undefined" || v2 === null) { v2 = ""; } else if (isPlainObject(v2)) { v2 = JSON.stringify(v2); } params[encode(key)] = encode(v2); } } query = Object.keys(params).map((item) => `${item}=${params[item]}`).join("&"); return url + (query ? "?" + query : "") + (hash ? "#" + hash : ""); } const RequestProtocol = { method: String, data: [Object, String, Array, ArrayBuffer], url: { type: String, required: true }, header: Object, dataType: String, responseType: String, withCredentials: Boolean }; const RequestOptions = { formatArgs: { method(value, params) { params.method = elemInArray( (value || "").toUpperCase(), HTTP_METHODS ); }, data(value, params) { params.data = value || ""; }, url(value, params) { if (params.method === HTTP_METHODS[0] && isPlainObject(params.data) && Object.keys(params.data).length) { params.url = stringifyQuery(value, params.data); } }, header(value, params) { const header = params.header = value || {}; if (params.method !== HTTP_METHODS[0]) { if (!Object.keys(header).find( (key) => key.toLowerCase() === "content-type" )) { header["Content-Type"] = "application/json"; } } }, dataType(value, params) { params.dataType = (value || dataType.JSON).toLowerCase(); }, responseType(value, params) { params.responseType = (value || "").toLowerCase(); if (RESPONSE_TYPE.indexOf(params.responseType) === -1) { params.responseType = DEFAULT_RESPONSE_TYPE; } } } }; const API_DOWNLOAD_FILE = "downloadFile"; const DownloadFileOptions = { formatArgs: { header(value, params) { params.header = value || {}; } } }; const DownloadFileProtocol = { url: { type: String, required: true }, header: Object, timeout: Number }; const API_UPLOAD_FILE = "uploadFile"; const UploadFileOptions = { formatArgs: { filePath(filePath, params) { if (filePath) { params.filePath = getRealPath(filePath); } }, header(value, params) { params.header = value || {}; }, formData(value, params) { params.formData = value || {}; } } }; const UploadFileProtocol = { url: { type: String, required: true }, files: Array, filePath: String, name: String, header: Object, formData: Object, timeout: Number }; const API_CONNECT_SOCKET = "connectSocket"; const ConnectSocketOptions = { formatArgs: { header(value, params) { params.header = value || {}; }, method(value, params) { params.method = elemInArray( (value || "").toUpperCase(), HTTP_METHODS ); }, protocols(protocols, params) { if (isString(protocols)) { params.protocols = [protocols]; } } } }; const ConnectSocketProtocol = { url: { type: String, required: true }, header: { type: Object }, method: String, protocols: [Array, String] }; const API_SEND_SOCKET_MESSAGE = "sendSocketMessage"; const SendSocketMessageProtocol = { data: [String, ArrayBuffer] }; const API_CLOSE_SOCKET = "closeSocket"; const CloseSocketProtocol = { code: Number, reason: String }; const API_START_LOCATION_UPDATE = "startLocationUpdate"; const API_ON_LOCATION_CHANGE = "onLocationChange"; const API_STOP_LOCATION_UPDATE = "stopLocationUpdate"; const API_OFF_LOCATION_CHANGE = "offLocationChange"; const API_OFF_LOCATION_CHANGE_ERROR = "offLocationChangeError"; const API_ON_LOCATION_CHANGE_ERROR = "onLocationChangeError"; const coordTypes = ["wgs84", "gcj02"]; const StartLocationUpdateProtocol = { type: String }; const StartLocationUpdateOptions = { formatArgs: { type(value, params) { value = (value || "").toLowerCase(); if (coordTypes.indexOf(value) === -1) { params.type = coordTypes[1]; } else { params.type = value; } } } }; function encodeQueryString(url) { if (!isString(url)) { return url; } const index2 = url.indexOf("?"); if (index2 === -1) { return url; } const query = url.slice(index2 + 1).trim().replace(/^(\?|#|&)/, ""); if (!query) { return url; } url = url.slice(0, index2); const params = []; query.split("&").forEach((param) => { const parts = param.replace(/\+/g, " ").split("="); const key = parts.shift(); const val = parts.length > 0 ? parts.join("=") : ""; params.push(key + "=" + encodeURIComponent(val)); }); return params.length ? url + "?" + params.join("&") : url; } const ANIMATION_IN$1 = [ "slide-in-right", "slide-in-left", "slide-in-top", "slide-in-bottom", "fade-in", "zoom-out", "zoom-fade-out", "pop-in", "none" ]; const ANIMATION_OUT$1 = [ "slide-out-right", "slide-out-left", "slide-out-top", "slide-out-bottom", "fade-out", "zoom-in", "zoom-fade-in", "pop-out", "none" ]; const BaseRouteProtocol = { url: { type: String, required: true } }; const API_NAVIGATE_TO = "navigateTo"; const API_REDIRECT_TO = "redirectTo"; const API_RE_LAUNCH = "reLaunch"; const API_SWITCH_TAB = "switchTab"; const API_NAVIGATE_BACK = "navigateBack"; const API_PRELOAD_PAGE = "preloadPage"; const API_UN_PRELOAD_PAGE = "unPreloadPage"; const NavigateToProtocol = /* @__PURE__ */ extend( {}, BaseRouteProtocol, createAnimationProtocol(ANIMATION_IN$1) ); const NavigateBackProtocol = /* @__PURE__ */ extend( { delta: { type: Number } }, createAnimationProtocol(ANIMATION_OUT$1) ); const RedirectToProtocol = BaseRouteProtocol; const ReLaunchProtocol = BaseRouteProtocol; const SwitchTabProtocol = BaseRouteProtocol; const PreloadPageProtocol = BaseRouteProtocol; const NavigateToOptions = /* @__PURE__ */ createRouteOptions(API_NAVIGATE_TO); const RedirectToOptions = /* @__PURE__ */ createRouteOptions(API_REDIRECT_TO); const ReLaunchOptions = /* @__PURE__ */ createRouteOptions(API_RE_LAUNCH); const SwitchTabOptions = /* @__PURE__ */ createRouteOptions(API_SWITCH_TAB); const 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 } }; } let 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); const pagePath = url.split("?")[0]; const 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 ${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.isTabBar) { const pages = getCurrentPages(); const tabBarPagePath = routeOptions.path.slice(1); if (pages.find((page) => page.route === tabBarPagePath)) { return "tabBar page `" + tabBarPagePath + "` already exists"; } } return; } if (navigatorLock === url && params.openType !== "appLaunch") { return `${navigatorLock} locked`; } if (__uniConfig.ready) { navigatorLock = url; } }; } const API_HIDE_LOADING = "hideLoading"; const API_HIDE_TOAST = "hideToast"; const API_LOAD_FONT_FACE = "loadFontFace"; const LoadFontFaceProtocol = { family: { type: String, required: true }, source: { type: String, required: true }, desc: Object }; const FRONT_COLORS = ["#ffffff", "#000000"]; const API_SET_NAVIGATION_BAR_COLOR = "setNavigationBarColor"; const SetNavigationBarColorOptions = { formatArgs: { animation(animation2, params) { if (!animation2) { animation2 = { duration: 0, timingFunc: "linear" }; } params.animation = { duration: animation2.duration || 0, timingFunc: animation2.timingFunc || "linear" }; } } }; const SetNavigationBarColorProtocol = { frontColor: { type: String, required: true, validator(frontColor) { if (FRONT_COLORS.indexOf(frontColor) === -1) { return `invalid frontColor "${frontColor}"`; } } }, backgroundColor: { type: String, required: true }, animation: Object }; const API_SET_NAVIGATION_BAR_TITLE = "setNavigationBarTitle"; const SetNavigationBarTitleProtocol = { title: { type: String, required: true } }; const API_SHOW_NAVIGATION_BAR_LOADING = "showNavigationBarLoading"; const API_HIDE_NAVIGATION_BAR_LOADING = "hideNavigationBarLoading"; const API_PAGE_SCROLL_TO = "pageScrollTo"; const PageScrollToProtocol = { scrollTop: Number, selector: String, duration: Number }; const PageScrollToOptions = { formatArgs: { duration: 300 } }; const API_SHOW_ACTION_SHEET = "showActionSheet"; const ShowActionSheetProtocol = { itemList: { type: Array, required: true }, title: String, itemColor: String, popover: Object }; const ShowActionSheetOptions = { formatArgs: { itemColor: "#000" } }; const API_SHOW_LOADING = "showLoading"; const ShowLoadingProtocol = { title: String, mask: Boolean }; const ShowLoadingOptions = { formatArgs: { title: "", mask: false } }; const API_SHOW_MODAL = "showModal"; const ShowModalProtocol = { title: String, content: String, showCancel: Boolean, cancelText: String, cancelColor: String, confirmText: String, confirmColor: String }; const ShowModalOptions = { beforeInvoke() { initI18nShowModalMsgsOnce(); }, formatArgs: { title: "", content: "", placeholderText: "", showCancel: true, editable: false, cancelText(_value, params) { if (!hasOwn(params, "cancelText")) { const { t: t2 } = useI18n(); params.cancelText = t2("uni.showModal.cancel"); } }, cancelColor: "#000", confirmText(_value, params) { if (!hasOwn(params, "confirmText")) { const { t: t2 } = useI18n(); params.confirmText = t2("uni.showModal.confirm"); } }, confirmColor: PRIMARY_COLOR } }; const API_SHOW_TOAST = "showToast"; const SHOW_TOAST_ICON = [ "success", "loading", "none", "error" ]; const ShowToastProtocol = { title: String, icon: String, image: String, duration: Number, mask: Boolean }; const ShowToastOptions = { formatArgs: { title: "", icon(type, params) { params.icon = elemInArray(type, SHOW_TOAST_ICON); }, image(value, params) { if (value) { params.image = getRealPath(value); } else { params.image = ""; } }, duration: 1500, mask: false } }; const API_START_PULL_DOWN_REFRESH = "startPullDownRefresh"; const API_STOP_PULL_DOWN_REFRESH = "stopPullDownRefresh"; const IndexProtocol = { index: { type: Number, required: true } }; const IndexOptions = { beforeInvoke() { const pageMeta = getCurrentPageMeta(); if (pageMeta && !pageMeta.isTabBar) { return "not TabBar page"; } }, formatArgs: { index(value) { if (!__uniConfig.tabBar.list[value]) { return "tabbar item not found"; } } } }; const API_SET_TAB_BAR_ITEM = "setTabBarItem"; const SetTabBarItemProtocol = /* @__PURE__ */ extend( { text: String, iconPath: String, selectedIconPath: String, pagePath: String }, IndexProtocol ); const SetTabBarItemOptions = { beforeInvoke: IndexOptions.beforeInvoke, formatArgs: /* @__PURE__ */ extend( { pagePath(value, params) { if (value) { params.pagePath = removeLeadingSlash(value); } } }, IndexOptions.formatArgs ) }; const API_SET_TAB_BAR_STYLE = "setTabBarStyle"; const SetTabBarStyleProtocol = { color: String, selectedColor: String, backgroundColor: String, backgroundImage: String, backgroundRepeat: String, borderStyle: String }; const GRADIENT_RE = /^(linear|radial)-gradient\(.+?\);?$/; const SetTabBarStyleOptions = { beforeInvoke: IndexOptions.beforeInvoke, formatArgs: { backgroundImage(value, params) { if (value && !GRADIENT_RE.test(value)) { params.backgroundImage = getRealPath(value); } }, borderStyle(value, params) { if (value) { params.borderStyle = value === "white" ? "white" : "black"; } } } }; const API_HIDE_TAB_BAR = "hideTabBar"; const HideTabBarProtocol = { animation: Boolean }; const API_SHOW_TAB_BAR = "showTabBar"; const ShowTabBarProtocol = HideTabBarProtocol; const API_HIDE_TAB_BAR_RED_DOT = "hideTabBarRedDot"; const HideTabBarRedDotProtocol = IndexProtocol; const HideTabBarRedDotOptions = IndexOptions; const API_SHOW_TAB_BAR_RED_DOT = "showTabBarRedDot"; const ShowTabBarRedDotProtocol = IndexProtocol; const ShowTabBarRedDotOptions = IndexOptions; const API_REMOVE_TAB_BAR_BADGE = "removeTabBarBadge"; const RemoveTabBarBadgeProtocol = IndexProtocol; const RemoveTabBarBadgeOptions = IndexOptions; const API_SET_TAB_BAR_BADGE = "setTabBarBadge"; const SetTabBarBadgeProtocol = /* @__PURE__ */ extend( { text: { type: String, required: true } }, IndexProtocol ); const SetTabBarBadgeOptions = { beforeInvoke: IndexOptions.beforeInvoke, formatArgs: /* @__PURE__ */ extend( { text(value, params) { if (getLen(value) >= 4) { params.text = "..."; } } }, IndexOptions.formatArgs ) }; const initIntersectionObserverPolyfill = function() { if (typeof window !== "object") { return; } if ("IntersectionObserver" in window && "IntersectionObserverEntry" in window && "intersectionRatio" in window.IntersectionObserverEntry.prototype) { if (!("isIntersecting" in window.IntersectionObserverEntry.prototype)) { Object.defineProperty( window.IntersectionObserverEntry.prototype, "isIntersecting", { get: function() { return this.intersectionRatio > 0; } } ); } return; } function getFrameElement(doc) { try { return doc.defaultView && doc.defaultView.frameElement || null; } catch (e2) { return null; } } var document2 = function(startDoc) { var doc = startDoc; var frame = getFrameElement(doc); while (frame) { doc = frame.ownerDocument; frame = getFrameElement(doc); } return doc; }(window.document); var registry = []; var crossOriginUpdater = null; var crossOriginRect = null; function IntersectionObserverEntry(entry) { this.time = entry.time; this.target = entry.target; this.rootBounds = ensureDOMRect(entry.rootBounds); this.boundingClientRect = ensureDOMRect(entry.boundingClientRect); this.intersectionRect = ensureDOMRect( entry.intersectionRect || getEmptyRect() ); this.isIntersecting = !!entry.intersectionRect; var targetRect = this.boundingClientRect; var targetArea = targetRect.width * targetRect.height; var intersectionRect = this.intersectionRect; var intersectionArea = intersectionRect.width * intersectionRect.height; if (targetArea) { this.intersectionRatio = Number( (intersectionArea / targetArea).toFixed(4) ); } else { this.intersectionRatio = this.isIntersecting ? 1 : 0; } } function IntersectionObserver2(callback, opt_options) { var options = opt_options || {}; if (typeof callback != "function") { throw new Error("callback must be a function"); } if (options.root && options.root.nodeType != 1 && options.root.nodeType != 9) { throw new Error("root must be a Document or Element"); } this._checkForIntersections = throttle2( this._checkForIntersections.bind(this), this.THROTTLE_TIMEOUT ); this._callback = callback; this._observationTargets = []; this._queuedEntries = []; this._rootMarginValues = this._parseRootMargin(options.rootMargin); this.thresholds = this._initThresholds(options.threshold); this.root = options.root || null; this.rootMargin = this._rootMarginValues.map(function(margin) { return margin.value + margin.unit; }).join(" "); this._monitoringDocuments = []; this._monitoringUnsubscribes = []; } IntersectionObserver2.prototype.THROTTLE_TIMEOUT = 100; IntersectionObserver2.prototype.POLL_INTERVAL = null; IntersectionObserver2.prototype.USE_MUTATION_OBSERVER = true; IntersectionObserver2._setupCrossOriginUpdater = function() { if (!crossOriginUpdater) { crossOriginUpdater = function(boundingClientRect, intersectionRect) { if (!boundingClientRect || !intersectionRect) { crossOriginRect = getEmptyRect(); } else { crossOriginRect = convertFromParentRect( boundingClientRect, intersectionRect ); } registry.forEach(function(observer) { observer._checkForIntersections(); }); }; } return crossOriginUpdater; }; IntersectionObserver2._resetCrossOriginUpdater = function() { crossOriginUpdater = null; crossOriginRect = null; }; IntersectionObserver2.prototype.observe = function(target) { var isTargetAlreadyObserved = this._observationTargets.some(function(item) { return item.element == target; }); if (isTargetAlreadyObserved) { return; } if (!(target && target.nodeType == 1)) { throw new Error("target must be an Element"); } this._registerInstance(); this._observationTargets.push({ element: target, entry: null }); this._monitorIntersections(target.ownerDocument); this._checkForIntersections(); }; IntersectionObserver2.prototype.unobserve = function(target) { this._observationTargets = this._observationTargets.filter(function(item) { return item.element != target; }); this._unmonitorIntersections(target.ownerDocument); if (this._observationTargets.length == 0) { this._unregisterInstance(); } }; IntersectionObserver2.prototype.disconnect = function() { this._observationTargets = []; this._unmonitorAllIntersections(); this._unregisterInstance(); }; IntersectionObserver2.prototype.takeRecords = function() { var records = this._queuedEntries.slice(); this._queuedEntries = []; return records; }; IntersectionObserver2.prototype._initThresholds = function(opt_threshold) { var threshold = opt_threshold || [0]; if (!Array.isArray(threshold)) threshold = [threshold]; return threshold.sort().filter(function(t2, i, a2) { if (typeof t2 != "number" || isNaN(t2) || t2 < 0 || t2 > 1) { throw new Error( "threshold must be a number between 0 and 1 inclusively" ); } return t2 !== a2[i - 1]; }); }; IntersectionObserver2.prototype._parseRootMargin = function(opt_rootMargin) { var marginString = opt_rootMargin || "0px"; var margins = marginString.split(/\s+/).map(function(margin) { var parts = /^(-?\d*\.?\d+)(px|%)$/.exec(margin); if (!parts) { throw new Error("rootMargin must be specified in pixels or percent"); } return { value: parseFloat(parts[1]), unit: parts[2] }; }); margins[1] = margins[1] || margins[0]; margins[2] = margins[2] || margins[0]; margins[3] = margins[3] || margins[1]; return margins; }; IntersectionObserver2.prototype._monitorIntersections = function(doc) { var win = doc.defaultView; if (!win) { return; } if (this._monitoringDocuments.indexOf(doc) != -1) { return; } var callback = this._checkForIntersections; var monitoringInterval = null; var domObserver = null; if (this.POLL_INTERVAL) { monitoringInterval = win.setInterval(callback, this.POLL_INTERVAL); } else { addEvent(win, "resize", callback, true); addEvent(doc, "scroll", callback, true); if (this.USE_MUTATION_OBSERVER && "MutationObserver" in win) { domObserver = new win.MutationObserver(callback); domObserver.observe(doc, { attributes: true, childList: true, characterData: true, subtree: true }); } } this._monitoringDocuments.push(doc); this._monitoringUnsubscribes.push(function() { var win2 = doc.defaultView; if (win2) { if (monitoringInterval) { win2.clearInterval(monitoringInterval); } removeEvent(win2, "resize", callback, true); } removeEvent(doc, "scroll", callback, true); if (domObserver) { domObserver.disconnect(); } }); var rootDoc = this.root && (this.root.ownerDocument || this.root) || document2; if (doc != rootDoc) { var frame = getFrameElement(doc); if (frame) { this._monitorIntersections(frame.ownerDocument); } } }; IntersectionObserver2.prototype._unmonitorIntersections = function(doc) { var index2 = this._monitoringDocuments.indexOf(doc); if (index2 == -1) { return; } var rootDoc = this.root && (this.root.ownerDocument || this.root) || document2; var hasDependentTargets = this._observationTargets.some(function(item) { var itemDoc = item.element.ownerDocument; if (itemDoc == doc) { return true; } while (itemDoc && itemDoc != rootDoc) { var frame2 = getFrameElement(itemDoc); itemDoc = frame2 && frame2.ownerDocument; if (itemDoc == doc) { return true; } } return false; }); if (hasDependentTargets) { return; } var unsubscribe = this._monitoringUnsubscribes[index2]; this._monitoringDocuments.splice(index2, 1); this._monitoringUnsubscribes.splice(index2, 1); unsubscribe(); if (doc != rootDoc) { var frame = getFrameElement(doc); if (frame) { this._unmonitorIntersections(frame.ownerDocument); } } }; IntersectionObserver2.prototype._unmonitorAllIntersections = function() { var unsubscribes = this._monitoringUnsubscribes.slice(0); this._monitoringDocuments.length = 0; this._monitoringUnsubscribes.length = 0; for (var i = 0; i < unsubscribes.length; i++) { unsubscribes[i](); } }; IntersectionObserver2.prototype._checkForIntersections = function() { if (!this.root && crossOriginUpdater && !crossOriginRect) { return; } var rootIsInDom = this._rootIsInDom(); var rootRect = rootIsInDom ? this._getRootRect() : getEmptyRect(); this._observationTargets.forEach(function(item) { var target = item.element; var targetRect = getBoundingClientRect(target); var rootContainsTarget = this._rootContainsTarget(target); var oldEntry = item.entry; var intersectionRect = rootIsInDom && rootContainsTarget && this._computeTargetAndRootIntersection(target, targetRect, rootRect); var rootBounds = null; if (!this._rootContainsTarget(target)) { rootBounds = getEmptyRect(); } else if (!crossOriginUpdater || this.root) { rootBounds = rootRect; } var newEntry = item.entry = new IntersectionObserverEntry({ time: now(), target, boundingClientRect: targetRect, rootBounds, intersectionRect }); if (!oldEntry) { this._queuedEntries.push(newEntry); } else if (rootIsInDom && rootContainsTarget) { if (this._hasCrossedThreshold(oldEntry, newEntry)) { this._queuedEntries.push(newEntry); } } else { if (oldEntry && oldEntry.isIntersecting) { this._queuedEntries.push(newEntry); } } }, this); if (this._queuedEntries.length) { this._callback(this.takeRecords(), this); } }; IntersectionObserver2.prototype._computeTargetAndRootIntersection = function(target, targetRect, rootRect) { if (window.getComputedStyle(target).display == "none") return; var intersectionRect = targetRect; var parent = getParentNode(target); var atRoot = false; while (!atRoot && parent) { var parentRect = null; var parentComputedStyle = parent.nodeType == 1 ? window.getComputedStyle(parent) : {}; if (parentComputedStyle.display == "none") return null; if (parent == this.root || parent.nodeType == /* DOCUMENT */ 9) { atRoot = true; if (parent == this.root || parent == document2) { if (crossOriginUpdater && !this.root) { if (!crossOriginRect || crossOriginRect.width == 0 && crossOriginRect.height == 0) { parent = null; parentRect = null; intersectionRect = null; } else { parentRect = crossOriginRect; } } else { parentRect = rootRect; } } else { var frame = getParentNode(parent); var frameRect = frame && getBoundingClientRect(frame); var frameIntersect = frame && this._computeTargetAndRootIntersection(frame, frameRect, rootRect); if (frameRect && frameIntersect) { parent = frame; parentRect = convertFromParentRect(frameRect, frameIntersect); } else { parent = null; intersectionRect = null; } } } else { var doc = parent.ownerDocument; if (parent != doc.body && parent != doc.documentElement && parentComputedStyle.overflow != "visible") { parentRect = getBoundingClientRect(parent); } } if (parentRect) { intersectionRect = computeRectIntersection(parentRect, intersectionRect); } if (!intersectionRect) break; parent = parent && getParentNode(parent); } return intersectionRect; }; IntersectionObserver2.prototype._getRootRect = function() { var rootRect; if (this.root && !isDoc(this.root)) { rootRect = getBoundingClientRect(this.root); } else { var doc = isDoc(this.root) ? this.root : document2; var html = doc.documentElement; var body = doc.body; rootRect = { top: 0, left: 0, right: html.clientWidth || body.clientWidth, width: html.clientWidth || body.clientWidth, bottom: html.clientHeight || body.clientHeight, height: html.clientHeight || body.clientHeight }; } return this._expandRectByRootMargin(rootRect); }; IntersectionObserver2.prototype._expandRectByRootMargin = function(rect) { var margins = this._rootMarginValues.map(function(margin, i) { return margin.unit == "px" ? margin.value : margin.value * (i % 2 ? rect.width : rect.height) / 100; }); var newRect = { top: rect.top - margins[0], right: rect.right + margins[1], bottom: rect.bottom + margins[2], left: rect.left - margins[3] }; newRect.width = newRect.right - newRect.left; newRect.height = newRect.bottom - newRect.top; return newRect; }; IntersectionObserver2.prototype._hasCrossedThreshold = function(oldEntry, newEntry) { var oldRatio = oldEntry && oldEntry.isIntersecting ? oldEntry.intersectionRatio || 0 : -1; var newRatio = newEntry.isIntersecting ? newEntry.intersectionRatio || 0 : -1; if (oldRatio === newRatio) return; for (var i = 0; i < this.thresholds.length; i++) { var threshold = this.thresholds[i]; if (threshold == oldRatio || threshold == newRatio || threshold < oldRatio !== threshold < newRatio) { return true; } } }; IntersectionObserver2.prototype._rootIsInDom = function() { return !this.root || containsDeep(document2, this.root); }; IntersectionObserver2.prototype._rootContainsTarget = function(target) { var rootDoc = this.root && (this.root.ownerDocument || this.root) || document2; return containsDeep(rootDoc, target) && (!this.root || rootDoc == target.ownerDocument); }; IntersectionObserver2.prototype._registerInstance = function() { if (registry.indexOf(this) < 0) { registry.push(this); } }; IntersectionObserver2.prototype._unregisterInstance = function() { var index2 = registry.indexOf(this); if (index2 != -1) registry.splice(index2, 1); }; function now() { return window.performance && performance.now && performance.now(); } function throttle2(fn, timeout) { var timer = null; return function() { if (!timer) { timer = setTimeout(function() { fn(); timer = null; }, timeout); } }; } function addEvent(node, event, fn, opt_useCapture) { if (typeof node.addEventListener == "function") { node.addEventListener(event, fn, opt_useCapture || false); } else if (typeof node.attachEvent == "function") { node.attachEvent("on" + event, fn); } } function removeEvent(node, event, fn, opt_useCapture) { if (typeof node.removeEventListener == "function") { node.removeEventListener(event, fn, opt_useCapture || false); } else if (typeof node.detatchEvent == "function") { node.detatchEvent("on" + event, fn); } } function computeRectIntersection(rect1, rect2) { var top = Math.max(rect1.top, rect2.top); var bottom = Math.min(rect1.bottom, rect2.bottom); var left = Math.max(rect1.left, rect2.left); var right = Math.min(rect1.right, rect2.right); var width = right - left; var height = bottom - top; return width >= 0 && height >= 0 && { top, bottom, left, right, width, height } || null; } function getBoundingClientRect(el) { var rect; try { rect = el.getBoundingClientRect(); } catch (err) { } if (!rect) return getEmptyRect(); if (!(rect.width && rect.height)) { rect = { top: rect.top, right: rect.right, bottom: rect.bottom, left: rect.left, width: rect.right - rect.left, height: rect.bottom - rect.top }; } return rect; } function getEmptyRect() { return { top: 0, bottom: 0, left: 0, right: 0, width: 0, height: 0 }; } function ensureDOMRect(rect) { if (!rect || "x" in rect) { return rect; } return { top: rect.top, y: rect.top, bottom: rect.bottom, left: rect.left, x: rect.left, right: rect.right, width: rect.width, height: rect.height }; } function convertFromParentRect(parentBoundingRect, parentIntersectionRect) { var top = parentIntersectionRect.top - parentBoundingRect.top; var left = parentIntersectionRect.left - parentBoundingRect.left; return { top, left, height: parentIntersectionRect.height, width: parentIntersectionRect.width, bottom: top + parentIntersectionRect.height, right: left + parentIntersectionRect.width }; } function containsDeep(parent, child) { var node = child; while (node) { if (node == parent) return true; node = getParentNode(node); } return false; } function getParentNode(node) { var parent = node.parentNode; if (node.nodeType == /* DOCUMENT */ 9 && node != document2) { return getFrameElement(node); } if (parent && parent.assignedSlot) { parent = parent.assignedSlot.parentNode; } if (parent && parent.nodeType == 11 && parent.host) { return parent.host; } return parent; } function isDoc(node) { return node && node.nodeType === 9; } window.IntersectionObserver = IntersectionObserver2; window.IntersectionObserverEntry = IntersectionObserverEntry; }; function normalizeRect(rect) { const { bottom, height, left, right, top, width } = rect || {}; return { bottom, height, left, right, top, width }; } function rectifyIntersectionRatio(entrie) { const { intersectionRatio, boundingClientRect: { height: overAllHeight, width: overAllWidth }, intersectionRect: { height: intersectionHeight, width: intersectionWidth } } = entrie; if (intersectionRatio !== 0) return intersectionRatio; return intersectionHeight === overAllHeight ? intersectionWidth / overAllWidth : intersectionHeight / overAllHeight; } function requestComponentObserver($el, options, callback) { initIntersectionObserverPolyfill(); const root = options.relativeToSelector ? $el.querySelector(options.relativeToSelector) : null; const intersectionObserver = new IntersectionObserver( (entries2) => { entries2.forEach((entrie) => { callback({ intersectionRatio: rectifyIntersectionRatio(entrie), intersectionRect: normalizeRect(entrie.intersectionRect), boundingClientRect: normalizeRect(entrie.boundingClientRect), relativeRect: normalizeRect(entrie.rootBounds), time: Date.now(), dataset: getCustomDataset(entrie.target), id: entrie.target.id }); }); }, { root, rootMargin: options.rootMargin, threshold: options.thresholds } ); if (options.observeAll) { intersectionObserver.USE_MUTATION_OBSERVER = true; const nodeList = $el.querySelectorAll(options.selector); for (let i = 0; i < nodeList.length; i++) { intersectionObserver.observe(nodeList[i]); } } else { intersectionObserver.USE_MUTATION_OBSERVER = false; const el = $el.querySelector(options.selector); if (!el) { console.warn( `Node ${options.selector} is not found. Intersection observer will not trigger.` ); } else { intersectionObserver.observe(el); } } return intersectionObserver; } function addIntersectionObserver({ reqId, component, options, callback }, _pageId) { const $el = findElem(component); ($el.__io || ($el.__io = {}))[reqId] = requestComponentObserver( $el, options, callback ); } function removeIntersectionObserver({ reqId, component }, _pageId) { const $el = findElem(component); const intersectionObserver = $el.__io && $el.__io[reqId]; if (intersectionObserver) { intersectionObserver.disconnect(); delete $el.__io[reqId]; } } let mediaQueryObservers = {}; let listeners = {}; function handleMediaQueryStr($props) { const mediaQueryArr = []; const propsMenu = [ "width", "minWidth", "maxWidth", "height", "minHeight", "maxHeight", "orientation" ]; for (const item of propsMenu) { if (item !== "orientation" && $props[item] && Number($props[item] >= 0)) { mediaQueryArr.push( `(${humpToLine(item)}: ${Number( $props[item] )}px)` ); } if (item === "orientation" && $props[item]) { mediaQueryArr.push(`(${humpToLine(item)}: ${$props[item]})`); } } const mediaQueryStr = mediaQueryArr.join(" and "); return mediaQueryStr; } function humpToLine(name) { return name.replace(/([A-Z])/g, "-$1").toLowerCase(); } function addMediaQueryObserver({ reqId, component, options, callback }, _pageId) { const mediaQueryObserver = mediaQueryObservers[reqId] = window.matchMedia( handleMediaQueryStr(options) ); const listener2 = listeners[reqId] = (observer) => callback(observer.matches); listener2(mediaQueryObserver); mediaQueryObserver.addListener(listener2); } function removeMediaQueryObserver({ reqId, component }, _pageId) { const listener2 = listeners[reqId]; const mediaQueryObserver = mediaQueryObservers[reqId]; if (mediaQueryObserver) { mediaQueryObserver.removeListener(listener2); delete listeners[reqId]; delete mediaQueryObservers[reqId]; } } function saveImage(base64, dirname, callback) { callback(null, base64); } const TEMP_PATH = ""; const files = {}; function urlToFile(url, local) { const file = files[url]; if (file) { return Promise.resolve(file); } if (/^data:[a-z-]+\/[a-z-]+;base64,/.test(url)) { return Promise.resolve(base64ToFile(url)); } if (local) { return Promise.reject(new Error("not find")); } return new Promise((resolve, reject) => { const xhr = new XMLHttpRequest(); xhr.open("GET", url, true); xhr.responseType = "blob"; xhr.onload = function() { resolve(this.response); }; xhr.onerror = reject; xhr.send(); }); } function base64ToFile(base64) { const base64Array = base64.split(","); const res = base64Array[0].match(/:(.*?);/); const type = res ? res[1] : ""; const str = atob(base64Array[1]); let n = str.length; const array = new Uint8Array(n); while (n--) { array[n] = str.charCodeAt(n); } return blobToFile(array, type); } function getExtname(type) { const extname = type.split("/")[1]; return extname ? `.${extname}` : ""; } function getFileName(url) { url = url.split("#")[0].split("?")[0]; const array = url.split("/"); return array[array.length - 1]; } function blobToFile(blob, type) { let file; if (blob instanceof File) { file = blob; } else { type = type || blob.type || ""; const filename = `${Date.now()}${getExtname(type)}`; try { file = new File([blob], filename, { type }); } catch (error) { blob = blob instanceof Blob ? blob : new Blob([blob], { type }); file = blob; file.name = file.name || filename; } } return file; } function fileToUrl(file) { for (const key in files) { if (hasOwn(files, key)) { const oldFile = files[key]; if (oldFile === file) { return key; } } } var url = (window.URL || window.webkitURL).createObjectURL(file); files[url] = file; return url; } function getSameOriginUrl(url) { const a2 = document.createElement("a"); a2.href = url; if (a2.origin === location.origin) { return Promise.resolve(url); } return urlToFile(url).then(fileToUrl); } function revokeObjectURL(url) { const URL = window.URL || window.webkitURL; URL.revokeObjectURL(url); delete files[url]; } const launchOptions = /* @__PURE__ */ createLaunchOptions(); const enterOptions = /* @__PURE__ */ createLaunchOptions(); function getEnterOptions() { return extend({}, enterOptions); } function getLaunchOptions() { return extend({}, launchOptions); } function initLaunchOptions({ path, query }) { extend(launchOptions, { path, query }); extend(enterOptions, launchOptions); return extend({}, launchOptions); } const inflateRaw = (...args) => { }; const deflateRaw = (...args) => { }; const ResizeSensor = /* @__PURE__ */ defineBuiltInComponent({ name: "ResizeSensor", props: { initial: { type: Boolean, default: false } }, emits: ["resize"], setup(props2, { emit: emit2 }) { const rootRef = ref(null); const reset = useResizeSensorReset(rootRef); const update = useResizeSensorUpdate(rootRef, emit2, reset); useResizeSensorLifecycle(rootRef, props2, update, reset); return () => createVNode("uni-resize-sensor", { "ref": rootRef, "onAnimationstartOnce": update }, [createVNode("div", { "onScroll": update }, [createVNode("div", null, null)], 40, ["onScroll"]), createVNode("div", { "onScroll": update }, [createVNode("div", null, null)], 40, ["onScroll"])], 40, ["onAnimationstartOnce"]); } }); function useResizeSensorUpdate(rootRef, emit2, reset) { const size = reactive({ width: -1, height: -1 }); watch(() => extend({}, size), (value) => emit2("resize", value)); return () => { const rootEl = rootRef.value; size.width = rootEl.offsetWidth; size.height = rootEl.offsetHeight; reset(); }; } function useResizeSensorReset(rootRef) { return () => { const { firstElementChild, lastElementChild } = rootRef.value; firstElementChild.scrollLeft = 1e5; firstElementChild.scrollTop = 1e5; lastElementChild.scrollLeft = 1e5; lastElementChild.scrollTop = 1e5; }; } function useResizeSensorLifecycle(rootRef, props2, update, reset) { onActivated(reset); onMounted(() => { if (props2.initial) { nextTick(update); } const rootEl = rootRef.value; if (rootEl.offsetParent !== rootEl.parentElement) { rootEl.parentElement.style.position = "relative"; } if (!("AnimationEvent" in window)) { reset(); } }); } const pixelRatio = /* @__PURE__ */ function() { if (navigator.userAgent.includes("jsdom")) { return 1; } const canvas = document.createElement("canvas"); canvas.height = canvas.width = 0; const context = canvas.getContext("2d"); const backingStore = context.backingStorePixelRatio || context.webkitBackingStorePixelRatio || context.mozBackingStorePixelRatio || context.msBackingStorePixelRatio || context.oBackingStorePixelRatio || context.backingStorePixelRatio || 1; return (window.devicePixelRatio || 1) / backingStore; }(); function wrapper(canvas, hidpi = true) { canvas.width = canvas.offsetWidth * (hidpi ? pixelRatio : 1); canvas.height = canvas.offsetHeight * (hidpi ? pixelRatio : 1); canvas.getContext("2d").__hidpi__ = hidpi; } let isHidpi = false; function initHidpi() { if (isHidpi) { return; } isHidpi = true; const forEach = function(obj, func) { for (const key in obj) { if (hasOwn(obj, key)) { func(obj[key], key); } } }; const ratioArgs = { fillRect: "all", clearRect: "all", strokeRect: "all", moveTo: "all", lineTo: "all", arc: [0, 1, 2], arcTo: "all", bezierCurveTo: "all", isPointinPath: "all", isPointinStroke: "all", quadraticCurveTo: "all", rect: "all", translate: "all", createRadialGradient: "all", createLinearGradient: "all", transform: [4, 5], setTransform: [4, 5] }; const proto = CanvasRenderingContext2D.prototype; proto.drawImageByCanvas = function(_super) { return function(canvas, srcx, srcy, srcw, srch, desx, desy, desw, desh, isScale) { if (!this.__hidpi__) { return _super.apply(this, arguments); } srcx *= pixelRatio; srcy *= pixelRatio; srcw *= pixelRatio; srch *= pixelRatio; desx *= pixelRatio; desy *= pixelRatio; desw = isScale ? desw * pixelRatio : desw; desh = isScale ? desh * pixelRatio : desh; _super.call(this, canvas, srcx, srcy, srcw, srch, desx, desy, desw, desh); }; }(proto.drawImage); if (pixelRatio !== 1) { forEach(ratioArgs, function(value, key) { proto[key] = function(_super) { return function() { if (!this.__hidpi__) { return _super.apply(this, arguments); } let args = Array.prototype.slice.call(arguments); if (value === "all") { args = args.map(function(a2) { return a2 * pixelRatio; }); } else if (Array.isArray(value)) { for (let i = 0; i < value.length; i++) { args[value[i]] *= pixelRatio; } } return _super.apply(this, args); }; }(proto[key]); }); proto.stroke = function(_super) { return function() { if (!this.__hidpi__) { return _super.apply(this, arguments); } this.lineWidth *= pixelRatio; _super.apply(this, arguments); this.lineWidth /= pixelRatio; }; }(proto.stroke); proto.fillText = function(_super) { return function() { if (!this.__hidpi__) { return _super.apply(this, arguments); } const args = Array.prototype.slice.call(arguments); args[1] *= pixelRatio; args[2] *= pixelRatio; if (args[3] && typeof args[3] === "number") { args[3] *= pixelRatio; } var font2 = this.font; this.font = font2.replace( /(\d+\.?\d*)(px|em|rem|pt)/g, function(w, m, u) { return m * pixelRatio + u; } ); _super.apply(this, args); this.font = font2; }; }(proto.fillText); proto.strokeText = function(_super) { return function() { if (!this.__hidpi__) { return _super.apply(this, arguments); } var args = Array.prototype.slice.call(arguments); args[1] *= pixelRatio; args[2] *= pixelRatio; if (args[3] && typeof args[3] === "number") { args[3] *= pixelRatio; } var font2 = this.font; this.font = font2.replace( /(\d+\.?\d*)(px|em|rem|pt)/g, function(w, m, u) { return m * pixelRatio + u; } ); _super.apply(this, args); this.font = font2; }; }(proto.strokeText); proto.drawImage = function(_super) { return function() { if (!this.__hidpi__) { return _super.apply(this, arguments); } this.scale(pixelRatio, pixelRatio); _super.apply(this, arguments); this.scale(1 / pixelRatio, 1 / pixelRatio); }; }(proto.drawImage); } } const initHidpiOnce = /* @__PURE__ */ once(() => { return initHidpi(); }); function $getRealPath(src) { return src ? getRealPath(src) : src; } function resolveColor(color) { color = color.slice(0); color[3] = color[3] / 255; return "rgba(" + color.join(",") + ")"; } function processTouches(rect, touches) { Array.from(touches).forEach((touch) => { touch.x = touch.clientX - rect.left; touch.y = touch.clientY - rect.top; }); } let tempCanvas; function getTempCanvas(width = 0, height = 0) { if (!tempCanvas) { tempCanvas = document.createElement("canvas"); } tempCanvas.width = width; tempCanvas.height = height; return tempCanvas; } const props$x = { canvasId: { type: String, default: "" }, disableScroll: { type: [Boolean, String], default: false }, hidpi: { type: Boolean, default: true } }; const index$v = /* @__PURE__ */ defineBuiltInComponent({ inheritAttrs: false, name: "Canvas", compatConfig: { MODE: 3 }, props: props$x, computed: { id() { return this.canvasId; } }, setup(props2, { emit: emit2, slots }) { initHidpiOnce(); const canvas = ref(null); const sensor = ref(null); const actionsWaiting = ref(false); const trigger = useNativeEvent(emit2); const { $attrs, $excludeAttrs, $listeners } = useAttrs({ excludeListeners: true }); const { _listeners } = useListeners(props2, $listeners, trigger); const { _handleSubscribe, _resize } = useMethods(props2, canvas, actionsWaiting); useSubscribe(_handleSubscribe, useContextInfo(props2.canvasId), true); onMounted(() => { _resize(); }); return () => { const { canvasId, disableScroll } = props2; return createVNode("uni-canvas", mergeProps({ "canvas-id": canvasId, "disable-scroll": disableScroll }, $attrs.value, $excludeAttrs.value, _listeners.value), [createVNode("canvas", { "ref": canvas, "class": "uni-canvas-canvas", "width": "300", "height": "150" }, null, 512), createVNode("div", { "style": "position: absolute;top: 0;left: 0;width: 100%;height: 100%;overflow: hidden;" }, [slots.default && slots.default()]), createVNode(ResizeSensor, { "ref": sensor, "onResize": _resize }, null, 8, ["onResize"])], 16, ["canvas-id", "disable-scroll"]); }; } }); function useListeners(props2, Listeners, trigger) { const _listeners = computed(() => { let events = ["onTouchstart", "onTouchmove", "onTouchend"]; let _$listeners = Listeners.value; let $listeners = extend({}, (() => { let obj = {}; for (const key in _$listeners) { if (hasOwn(_$listeners, key)) { const event = _$listeners[key]; obj[key] = event; } } return obj; })()); events.forEach((event) => { let existing = $listeners[event]; let eventHandler = []; if (existing) { eventHandler.push(withWebEvent(($event) => { const rect = $event.currentTarget.getBoundingClientRect(); processTouches(rect, $event.touches); processTouches(rect, $event.changedTouches); trigger(event.replace("on", "").toLocaleLowerCase(), $event); })); } if (props2.disableScroll && event === "onTouchmove") { eventHandler.push(onEventPrevent); } $listeners[event] = eventHandler; }); return $listeners; }); return { _listeners }; } function useMethods(props2, canvasRef, actionsWaiting) { let _actionsDefer = []; let _images = {}; const _pixelRatio = computed(() => props2.hidpi ? pixelRatio : 1); function _resize(size) { let canvas = canvasRef.value; var hasChanged = !size || canvas.width !== Math.floor(size.width * _pixelRatio.value) || canvas.height !== Math.floor(size.height * _pixelRatio.value); if (!hasChanged) return; if (canvas.width > 0 && canvas.height > 0) { let context = canvas.getContext("2d"); let imageData = context.getImageData(0, 0, canvas.width, canvas.height); wrapper(canvas, props2.hidpi); context.putImageData(imageData, 0, 0); } else { wrapper(canvas, props2.hidpi); } } function actionsChanged({ actions, reserve }, resolve) { if (!actions) { return; } if (actionsWaiting.value) { _actionsDefer.push([actions, reserve]); return; } let canvas = canvasRef.value; let c2d = canvas.getContext("2d"); if (!reserve) { c2d.fillStyle = "#000000"; c2d.strokeStyle = "#000000"; c2d.shadowColor = "#000000"; c2d.shadowBlur = 0; c2d.shadowOffsetX = 0; c2d.shadowOffsetY = 0; c2d.setTransform(1, 0, 0, 1, 0, 0); c2d.clearRect(0, 0, canvas.width, canvas.height); } preloadImage(actions); for (let index2 = 0; index2 < actions.length; index2++) { const action = actions[index2]; let method = action.method; const data = action.data; const actionType = data[0]; if (/^set/.test(method) && method !== "setTransform") { const method1 = method[3].toLowerCase() + method.slice(4); let color; if (method1 === "fillStyle" || method1 === "strokeStyle") { if (actionType === "normal") { color = resolveColor(data[1]); } else if (actionType === "linear") { const LinearGradient = c2d.createLinearGradient(...data[1]); data[2].forEach(function(data2) { const offset = data2[0]; const color2 = resolveColor(data2[1]); LinearGradient.addColorStop(offset, color2); }); color = LinearGradient; } else if (actionType === "radial") { let _data = data[1]; const x = _data[0]; const y = _data[1]; const r = _data[2]; const LinearGradient = c2d.createRadialGradient(x, y, 0, x, y, r); data[2].forEach(function(data2) { const offset = data2[0]; const color2 = resolveColor(data2[1]); LinearGradient.addColorStop(offset, color2); }); color = LinearGradient; } else if (actionType === "pattern") { const loaded = checkImageLoaded(data[1], actions.slice(index2 + 1), resolve, function(image2) { if (image2) { c2d[method1] = c2d.createPattern(image2, data[2]); } }); if (!loaded) { break; } continue; } c2d[method1] = color; } else if (method1 === "globalAlpha") { c2d[method1] = Number(actionType) / 255; } else if (method1 === "shadow") { let shadowArray = ["shadowOffsetX", "shadowOffsetY", "shadowBlur", "shadowColor"]; data.forEach(function(color_, method_) { c2d[shadowArray[method_]] = shadowArray[method_] === "shadowColor" ? resolveColor(color_) : color_; }); } else if (method1 === "fontSize") { const font2 = c2d.__font__ || c2d.font; c2d.__font__ = c2d.font = font2.replace(/\d+\.?\d*px/, actionType + "px"); } else if (method1 === "lineDash") { c2d.setLineDash(actionType); c2d.lineDashOffset = data[1] || 0; } else if (method1 === "textBaseline") { if (actionType === "normal") { data[0] = "alphabetic"; } c2d[method1] = actionType; } else if (method1 === "font") { c2d.__font__ = c2d.font = actionType; } else { c2d[method1] = actionType; } } else if (method === "fillPath" || method === "strokePath") { method = method.replace(/Path/, ""); c2d.beginPath(); data.forEach(function(data_) { c2d[data_.method].apply(c2d, data_.data); }); c2d[method](); } else if (method === "fillText") { c2d.fillText.apply(c2d, data); } else if (method === "drawImage") { let drawImage = function() { let dataArray = [...data]; let url = dataArray[0]; let otherData = dataArray.slice(1); _images = _images || {}; if (!checkImageLoaded(url, actions.slice(index2 + 1), resolve, function(image2) { if (image2) { c2d.drawImage.apply( c2d, // @ts-ignore [image2].concat( // @ts-ignore [...otherData.slice(4, 8)], [...otherData.slice(0, 4)] ) ); } })) return "break"; }(); if (drawImage === "break") { break; } } else { if (method === "clip") { data.forEach(function(data_) { c2d[data_.method].apply(c2d, data_.data); }); c2d.clip(); } else { c2d[method].apply(c2d, data); } } } if (!actionsWaiting.value) { resolve({ errMsg: "drawCanvas:ok" }); } } function preloadImage(actions) { actions.forEach(function(action) { let method = action.method; let data = action.data; let src = ""; if (method === "drawImage") { src = data[0]; src = $getRealPath(src); data[0] = src; } else if (method === "setFillStyle" && data[0] === "pattern") { src = data[1]; src = $getRealPath(src); data[1] = src; } if (src && !_images[src]) { loadImage(); } function loadImage() { const image2 = _images[src] = new Image(); image2.onload = function() { image2.ready = true; }; getSameOriginUrl(src).then((src2) => { image2.src = src2; }).catch(() => { image2.src = src; }); } }); } function checkImageLoaded(src, actions, resolve, fn) { let image2 = _images[src]; if (image2.ready) { fn(image2); return true; } else { _actionsDefer.unshift([actions, true]); actionsWaiting.value = true; image2.onload = function() { image2.ready = true; fn(image2); actionsWaiting.value = false; let actions2 = _actionsDefer.slice(0); _actionsDefer = []; for (let action = actions2.shift(); action; ) { actionsChanged({ actions: action[0], reserve: action[1] }, resolve); action = actions2.shift(); } }; return false; } } function getImageData({ x = 0, y = 0, width, height, destWidth, destHeight, hidpi = true, dataType: dataType2, quality = 1, type = "png" }, resolve) { const canvas = canvasRef.value; let data; const maxWidth2 = canvas.offsetWidth - x; width = width ? Math.min(width, maxWidth2) : maxWidth2; const maxHeight = canvas.offsetHeight - y; height = height ? Math.min(height, maxHeight) : maxHeight; if (!hidpi) { if (!destWidth && !destHeight) { destWidth = Math.round(width * _pixelRatio.value); destHeight = Math.round(height * _pixelRatio.value); } else if (!destWidth) { destWidth = Math.round(width / height * destHeight); } else if (!destHeight) { destHeight = Math.round(height / width * destWidth); } } else { destWidth = width; destHeight = height; } const newCanvas = getTempCanvas(destWidth, destHeight); const context = newCanvas.getContext("2d"); if (type === "jpeg" || type === "jpg") { type = "jpeg"; context.fillStyle = "#fff"; context.fillRect(0, 0, destWidth, destHeight); } context.__hidpi__ = true; context.drawImageByCanvas(canvas, x, y, width, height, 0, 0, destWidth, destHeight, false); let result; try { let compressed; if (dataType2 === "base64") { data = newCanvas.toDataURL(`image/${type}`, quality); } else { const imgData = context.getImageData(0, 0, destWidth, destHeight); if (false) ; else { data = Array.prototype.slice.call(imgData.data); } } result = { data, compressed, width: destWidth, height: destHeight }; } catch (error) { result = { errMsg: `canvasGetImageData:fail ${error}` }; } newCanvas.height = newCanvas.width = 0; context.__hidpi__ = false; if (!resolve) { return result; } else { resolve(result); } } function putImageData({ data, x, y, width, height, compressed }, resolve) { try { if (false) ; if (!height) { height = Math.round(data.length / 4 / width); } const canvas = getTempCanvas(width, height); const context = canvas.getContext("2d"); context.putImageData(new ImageData(new Uint8ClampedArray(data), width, height), 0, 0); canvasRef.value.getContext("2d").drawImage(canvas, x, y, width, height); canvas.height = canvas.width = 0; } catch (error) { resolve({ errMsg: "canvasPutImageData:fail" }); return; } resolve({ errMsg: "canvasPutImageData:ok" }); } function toTempFilePath({ x = 0, y = 0, width, height, destWidth, destHeight, fileType, quality, dirname }, resolve) { const res = getImageData({ x, y, width, height, destWidth, destHeight, hidpi: false, dataType: "base64", type: fileType, quality }); if (!res.data || !res.data.length) { resolve({ errMsg: res.errMsg.replace("canvasPutImageData", "toTempFilePath") }); return; } saveImage(res.data, dirname, (error, tempFilePath) => { let errMsg = `toTempFilePath:${error ? "fail" : "ok"}`; if (error) { errMsg += ` ${error.message}`; } resolve({ errMsg, tempFilePath }); }); } const methods = { actionsChanged, getImageData, putImageData, toTempFilePath }; function _handleSubscribe(type, data, resolve) { let method = methods[type]; if (type.indexOf("_") !== 0 && isFunction(method)) { method(data, resolve); } } return extend(methods, { _resize, _handleSubscribe }); } const uniCheckGroupKey = PolySymbol(process.env.NODE_ENV !== "production" ? "uniCheckGroup" : "ucg"); const props$w = { name: { type: String, default: "" } }; const index$u = /* @__PURE__ */ defineBuiltInComponent({ name: "CheckboxGroup", props: props$w, emits: ["change"], setup(props2, { emit: emit2, slots }) { const rootRef = ref(null); const trigger = useCustomEvent(rootRef, emit2); useProvideCheckGroup(props2, trigger); return () => { return createVNode("uni-checkbox-group", { "ref": rootRef }, [slots.default && slots.default()], 512); }; } }); function useProvideCheckGroup(props2, trigger) { const fields2 = []; const getFieldsValue = () => fields2.reduce((res, field) => { if (field.value.checkboxChecked) { res.push(field.value.value); } return res; }, new Array()); provide(uniCheckGroupKey, { addField(field) { fields2.push(field); }, removeField(field) { fields2.splice(fields2.indexOf(field), 1); }, checkboxChange($event) { trigger("change", $event, { value: getFieldsValue() }); } }); const uniForm = inject(uniFormKey, false); if (uniForm) { uniForm.addField({ submit: () => { let data = ["", null]; if (props2.name !== "") { data[0] = props2.name; data[1] = getFieldsValue(); } return data; } }); } return getFieldsValue; } const props$v = { checked: { type: [Boolean, String], default: false }, id: { type: String, default: "" }, disabled: { type: [Boolean, String], default: false }, value: { type: String, default: "" }, color: { type: String, default: "#007aff" }, backgroundColor: { type: String, default: "" }, borderColor: { type: String, default: "" }, activeBackgroundColor: { type: String, default: "" }, activeBorderColor: { type: String, default: "" }, iconColor: { type: String, default: "" } }; const index$t = /* @__PURE__ */ defineBuiltInComponent({ name: "Checkbox", props: props$v, setup(props2, { slots }) { const checkboxChecked = ref(props2.checked); const checkboxValue = ref(props2.value); const checkboxStyle = computed(() => { if (props2.disabled) { return { backgroundColor: "#E1E1E1", borderColor: "#D1D1D1" }; } const style = {}; if (checkboxChecked.value) { if (props2.activeBorderColor) style.borderColor = props2.activeBorderColor; if (props2.activeBackgroundColor) style.backgroundColor = props2.activeBackgroundColor; } else { if (props2.borderColor) style.borderColor = props2.borderColor; if (props2.backgroundColor) style.backgroundColor = props2.backgroundColor; } return style; }); watch([() => props2.checked, () => props2.value], ([newChecked, newModelValue]) => { checkboxChecked.value = newChecked; checkboxValue.value = newModelValue; }); const reset = () => { checkboxChecked.value = false; }; const { uniCheckGroup, uniLabel } = useCheckboxInject(checkboxChecked, checkboxValue, reset); const _onClick = ($event) => { if (props2.disabled) { return; } checkboxChecked.value = !checkboxChecked.value; uniCheckGroup && uniCheckGroup.checkboxChange($event); $event.stopPropagation(); }; if (!!uniLabel) { uniLabel.addHandler(_onClick); onBeforeUnmount(() => { uniLabel.removeHandler(_onClick); }); } useListeners$1(props2, { "label-click": _onClick }); return () => { const booleanAttrs = useBooleanAttr(props2, "disabled"); return createVNode("uni-checkbox", mergeProps(booleanAttrs, { "onClick": _onClick }), [createVNode("div", { "class": "uni-checkbox-wrapper", "style": { "--HOVER-BD-COLOR": props2.activeBorderColor } }, [createVNode("div", { "class": ["uni-checkbox-input", { "uni-checkbox-input-disabled": props2.disabled }], "style": checkboxStyle.value }, [checkboxChecked.value ? createSvgIconVNode(ICON_PATH_SUCCESS_NO_CIRCLE, props2.disabled ? "#ADADAD" : props2.iconColor || props2.color, 22) : ""], 6), slots.default && slots.default()], 4)], 16, ["onClick"]); }; } }); function useCheckboxInject(checkboxChecked, checkboxValue, reset) { const field = computed(() => ({ checkboxChecked: Boolean(checkboxChecked.value), value: checkboxValue.value })); const formField = { reset }; const uniCheckGroup = inject(uniCheckGroupKey, false); if (!!uniCheckGroup) { uniCheckGroup.addField(field); } const uniForm = inject(uniFormKey, false); if (!!uniForm) { uniForm.addField(formField); } const uniLabel = inject(uniLabelKey, false); onBeforeUnmount(() => { uniCheckGroup && uniCheckGroup.removeField(field); uniForm && uniForm.removeField(formField); }); return { uniCheckGroup, uniForm, uniLabel }; } let resetTimer; function iosHideKeyboard() { } const props$u = { cursorSpacing: { type: [Number, String], default: 0 }, showConfirmBar: { type: [Boolean, String], default: "auto" }, adjustPosition: { type: [Boolean, String], default: true }, autoBlur: { type: [Boolean, String], default: false } }; const emit$1 = ["keyboardheightchange"]; function useKeyboard$1(props2, elRef, trigger) { function initKeyboard(el) { const isApple = computed( () => String(navigator.vendor).indexOf("Apple") === 0 ); el.addEventListener("focus", () => { clearTimeout(resetTimer); document.addEventListener("click", iosHideKeyboard, false); }); const onKeyboardHide = () => { document.removeEventListener("click", iosHideKeyboard, false); if (isApple.value) { document.documentElement.scrollTo( document.documentElement.scrollLeft, document.documentElement.scrollTop ); } }; el.addEventListener("blur", () => { if (isApple.value) { el.blur(); } onKeyboardHide(); }); } watch( () => elRef.value, (el) => el && initKeyboard(el) ); } var startTag = /^<([-A-Za-z0-9_]+)((?:\s+[a-zA-Z_:][-a-zA-Z0-9_:.]*(?:\s*=\s*(?:(?:"[^"]*")|(?:'[^']*')|[^>\s]+))?)*)\s*(\/?)>/; var endTag = /^<\/([-A-Za-z0-9_]+)[^>]*>/; var attr = /([a-zA-Z_:][-a-zA-Z0-9_:.]*)(?:\s*=\s*(?:(?:"((?:\\.|[^"])*)")|(?:'((?:\\.|[^'])*)')|([^>\s]+)))?/g; var empty = /* @__PURE__ */ makeMap( "area,base,basefont,br,col,frame,hr,img,input,link,meta,param,embed,command,keygen,source,track,wbr" ); var block = /* @__PURE__ */ makeMap( "a,address,article,applet,aside,audio,blockquote,button,canvas,center,dd,del,dir,div,dl,dt,fieldset,figcaption,figure,footer,form,frameset,h1,h2,h3,h4,h5,h6,header,hgroup,hr,iframe,isindex,li,map,menu,noframes,noscript,object,ol,output,p,pre,section,script,table,tbody,td,tfoot,th,thead,tr,ul,video" ); var inline = /* @__PURE__ */ makeMap( "abbr,acronym,applet,b,basefont,bdo,big,br,button,cite,code,del,dfn,em,font,i,iframe,img,input,ins,kbd,label,map,object,q,s,samp,script,select,small,span,strike,strong,sub,sup,textarea,tt,u,var" ); var closeSelf = /* @__PURE__ */ makeMap( "colgroup,dd,dt,li,options,p,td,tfoot,th,thead,tr" ); var fillAttrs = /* @__PURE__ */ makeMap( "checked,compact,declare,defer,disabled,ismap,multiple,nohref,noresize,noshade,nowrap,readonly,selected" ); var special = /* @__PURE__ */ makeMap("script,style"); function HTMLParser(html, handler) { var index2; var chars2; var match; var stack = []; var last = html; stack.last = function() { return this[this.length - 1]; }; while (html) { chars2 = true; if (!stack.last() || !special[stack.last()]) { if (html.indexOf(""); if (index2 >= 0) { if (handler.comment) { handler.comment(html.substring(4, index2)); } html = html.substring(index2 + 3); chars2 = false; } } else if (html.indexOf("]*>"), function(all, text3) { text3 = text3.replace( /|/g, "$1$2" ); if (handler.chars) { handler.chars(text3); } return ""; } ); parseEndTag("", stack.last()); } if (html == last) { throw "Parse Error: " + html; } last = html; } parseEndTag(); function parseStartTag(tag, tagName, rest, unary) { tagName = tagName.toLowerCase(); if (block[tagName]) { while (stack.last() && inline[stack.last()]) { parseEndTag("", stack.last()); } } if (closeSelf[tagName] && stack.last() == tagName) { parseEndTag("", tagName); } unary = empty[tagName] || !!unary; if (!unary) { stack.push(tagName); } if (handler.start) { var attrs2 = []; rest.replace(attr, function(match2, name) { var value = arguments[2] ? arguments[2] : arguments[3] ? arguments[3] : arguments[4] ? arguments[4] : fillAttrs[name] ? name : ""; attrs2.push({ name, value, escaped: value.replace(/(^|[^\\])"/g, '$1\\"') // " }); }); if (handler.start) { handler.start(tagName, attrs2, unary); } } } function parseEndTag(tag, tagName) { if (!tagName) { var pos = 0; } else { for (var pos = stack.length - 1; pos >= 0; pos--) { if (stack[pos] == tagName) { break; } } } if (pos >= 0) { for (var i = stack.length - 1; i >= pos; i--) { if (handler.end) { handler.end(stack[i]); } } stack.length = pos; } } } function makeMap(str) { var obj = {}; var items = str.split(","); for (var i = 0; i < items.length; i++) { obj[items[i]] = true; } return obj; } const scripts = {}; function loadScript(globalName, src, callback) { const globalObject = isString(globalName) ? window[globalName] : globalName; if (globalObject) { callback(); return; } let callbacks2 = scripts[src]; if (!callbacks2) { callbacks2 = scripts[src] = []; const script = document.createElement("script"); script.src = src; document.body.appendChild(script); script.onload = function() { callbacks2.forEach((callback2) => callback2()); delete scripts[src]; }; } callbacks2.push(callback); } function divider(Quill) { const BlockEmbed = Quill.import("blots/block/embed"); class Divider extends BlockEmbed { } Divider.blotName = "divider"; Divider.tagName = "HR"; return { "formats/divider": Divider }; } function ins(Quill) { const Inline = Quill.import("blots/inline"); class Ins extends Inline { } Ins.blotName = "ins"; Ins.tagName = "INS"; return { "formats/ins": Ins }; } function align(Quill) { const { Scope, Attributor } = Quill.import("parchment"); const config = { scope: Scope.BLOCK, whitelist: ["left", "right", "center", "justify"] }; const AlignStyle = new Attributor.Style("align", "text-align", config); return { "formats/align": AlignStyle }; } function direction(Quill) { const { Scope, Attributor } = Quill.import("parchment"); const config = { scope: Scope.BLOCK, whitelist: ["rtl"] }; const DirectionStyle = new Attributor.Style("direction", "direction", config); return { "formats/direction": DirectionStyle }; } function list(Quill) { const Parchment = Quill.import("parchment"); const Container = Quill.import("blots/container"); const ListItem = Quill.import("formats/list/item"); class List extends Container { static create(value) { const tagName = value === "ordered" ? "OL" : "UL"; const node = super.create(tagName); if (value === "checked" || value === "unchecked") { node.setAttribute("data-checked", value === "checked"); } return node; } static formats(domNode) { if (domNode.tagName === "OL") return "ordered"; if (domNode.tagName === "UL") { if (domNode.hasAttribute("data-checked")) { return domNode.getAttribute("data-checked") === "true" ? "checked" : "unchecked"; } else { return "bullet"; } } return void 0; } constructor(domNode) { super(domNode); const listEventHandler = (e2) => { if (e2.target.parentNode !== domNode) return; const format = this.statics.formats(domNode); const blot = Parchment.find(e2.target); if (format === "checked") { blot.format("list", "unchecked"); } else if (format === "unchecked") { blot.format("list", "checked"); } }; domNode.addEventListener("click", listEventHandler); } format(name, value) { if (this.children.length > 0) { this.children.tail.format(name, value); } } formats() { return { [this.statics.blotName]: this.statics.formats(this.domNode) }; } insertBefore(blot, ref2) { if (blot instanceof ListItem) { super.insertBefore(blot, ref2); } else { const index2 = ref2 == null ? this.length() : ref2.offset(this); const after = this.split(index2); after.parent.insertBefore(blot, after); } } optimize(context) { super.optimize(context); const next = this.next; if (next != null && next.prev === this && next.statics.blotName === this.statics.blotName && next.domNode.tagName === this.domNode.tagName && next.domNode.getAttribute("data-checked") === this.domNode.getAttribute("data-checked")) { next.moveChildren(this); next.remove(); } } replace(target) { if (target.statics.blotName !== this.statics.blotName) { const item = Parchment.create(this.statics.defaultChild); target.moveChildren(item); this.appendChild(item); } super.replace(target); } } List.blotName = "list"; List.scope = Parchment.Scope.BLOCK_BLOT; List.tagName = ["OL", "UL"]; List.defaultChild = "list-item"; List.allowedChildren = [ListItem]; return { "formats/list": List }; } function background(Quill) { const { Scope } = Quill.import("parchment"); const BackgroundStyle = Quill.import("formats/background"); const BackgroundColorStyle = new BackgroundStyle.constructor( "backgroundColor", "background-color", { scope: Scope.INLINE } ); return { "formats/backgroundColor": BackgroundColorStyle }; } function box(Quill) { const { Scope, Attributor } = Quill.import("parchment"); const config = { scope: Scope.BLOCK }; const margin = [ "margin", "marginTop", "marginBottom", "marginLeft", "marginRight" ]; const padding = [ "padding", "paddingTop", "paddingBottom", "paddingLeft", "paddingRight" ]; const result = {}; margin.concat(padding).forEach((name) => { result[`formats/${name}`] = new Attributor.Style( name, hyphenate(name), config ); }); return result; } function font(Quill) { const { Scope, Attributor } = Quill.import("parchment"); const config = { scope: Scope.INLINE }; const font2 = [ "font", "fontSize", "fontStyle", "fontVariant", "fontWeight", "fontFamily" ]; const result = {}; font2.forEach((name) => { result[`formats/${name}`] = new Attributor.Style( name, hyphenate(name), config ); }); return result; } function text(Quill) { const { Scope, Attributor } = Quill.import("parchment"); const text2 = [ { name: "lineHeight", scope: Scope.BLOCK }, { name: "letterSpacing", scope: Scope.INLINE }, { name: "textDecoration", scope: Scope.INLINE }, { name: "textIndent", scope: Scope.BLOCK } ]; const result = {}; text2.forEach(({ name, scope: scope2 }) => { result[`formats/${name}`] = new Attributor.Style(name, hyphenate(name), { scope: scope2 }); }); return result; } function image(Quill) { const Image2 = Quill.import("formats/image"); const ATTRIBUTES = [ "alt", "height", "width", "data-custom", "class", "data-local" ]; Image2.sanitize = (url) => url ? getRealPath(url) : url; Image2.formats = function formats(domNode) { return ATTRIBUTES.reduce( function(formats2, attribute) { if (domNode.hasAttribute(attribute)) { formats2[attribute] = domNode.getAttribute(attribute); } return formats2; }, {} ); }; const format = Image2.prototype.format; Image2.prototype.format = function(name, value) { if (ATTRIBUTES.indexOf(name) > -1) { if (value) { this.domNode.setAttribute(name, value); } else { this.domNode.removeAttribute(name); } } else { format.call(this, name, value); } }; } function link(Quill) { const Link = Quill.import("formats/link"); Link.sanitize = (url) => { const anchor = document.createElement("a"); anchor.href = url; const protocol = anchor.href.slice(0, anchor.href.indexOf(":")); return Link.PROTOCOL_WHITELIST.concat("file").indexOf(protocol) > -1 ? url : Link.SANITIZED_URL; }; } function register(Quill) { const formats = { divider, ins, align, direction, list, background, box, font, text, image, link }; const options = {}; Object.values(formats).forEach((value) => extend(options, value(Quill))); Quill.register(options, true); } function useQuill(props2, rootRef, trigger) { let quillReady; let skipMatcher; let quill; watch( () => props2.readOnly, (value) => { if (quillReady) { quill.enable(!value); if (!value) { quill.blur(); } } } ); watch( () => props2.placeholder, (value) => { if (quillReady) { setPlaceHolder(value); } } ); function html2delta(html) { const tags = [ "span", "strong", "b", "ins", "em", "i", "u", "a", "del", "s", "sub", "sup", "img", "div", "p", "h1", "h2", "h3", "h4", "h5", "h6", "hr", "ol", "ul", "li", "br" ]; let content = ""; let disable; HTMLParser(html, { start: function(tag, attrs2, unary) { if (!tags.includes(tag)) { disable = !unary; return; } disable = false; const arrts = attrs2.map(({ name, value }) => `${name}="${value}"`).join(" "); const start = `<${tag} ${arrts} ${unary ? "/" : ""}>`; content += start; }, end: function(tag) { if (!disable) { content += ``; } }, chars: function(text2) { if (!disable) { content += text2; } } }); skipMatcher = true; const delta = quill.clipboard.convert(content); skipMatcher = false; return delta; } function getContents() { const html = quill.root.innerHTML; const text2 = quill.getText(); const delta = quill.getContents(); return { html, text: text2, delta }; } function setPlaceHolder(placeholder) { const placeHolderAttrName = "data-placeholder"; const QuillRoot = quill.root; QuillRoot.getAttribute(placeHolderAttrName) !== placeholder && QuillRoot.setAttribute(placeHolderAttrName, placeholder); } let oldStatus = {}; function updateStatus(range) { const status = range ? quill.getFormat(range) : {}; const keys = Object.keys(status); if (keys.length !== Object.keys(oldStatus).length || keys.find((key) => status[key] !== oldStatus[key])) { oldStatus = status; trigger("statuschange", {}, status); } } function textChangeHandler() { trigger("input", {}, getContents()); } function initQuill(imageResizeModules) { const Quill = window.Quill; register(Quill); const options = { toolbar: false, readOnly: props2.readOnly, placeholder: props2.placeholder }; if (imageResizeModules.length) { Quill.register( "modules/ImageResize", window.ImageResize.default ); options.modules = { ImageResize: { modules: imageResizeModules } }; } const rootEl = rootRef.value; quill = new Quill(rootEl, options); const $el = quill.root; const events = ["focus", "blur", "input"]; events.forEach((name) => { $el.addEventListener(name, ($event) => { const contents = getContents(); if (name === "input") { if (getBaseSystemInfo().platform === "ios") { const regExpContent = (contents.html.match( /([\s\S]*)<\/span>/ ) || [])[1]; const placeholder = regExpContent && regExpContent.replace(/\s/g, "") ? "" : props2.placeholder; setPlaceHolder(placeholder); } $event.stopPropagation(); } else { trigger(name, $event, contents); } }); }); quill.on("text-change", textChangeHandler); quill.on("selection-change", updateStatus); quill.on("scroll-optimize", () => { const range = quill.selection.getRange()[0]; updateStatus(range); }); quill.clipboard.addMatcher(Node.ELEMENT_NODE, (node, delta) => { if (skipMatcher) { return delta; } if (delta.ops) { delta.ops = delta.ops.filter(({ insert }) => isString(insert)).map(({ insert }) => ({ insert })); } return delta; }); quillReady = true; trigger("ready", {}, {}); } const id2 = useContextInfo(); useSubscribe( (type, data, resolve) => { const { options, callbackId } = data; let res; let range; let errMsg; if (quillReady) { const Quill = window.Quill; switch (type) { case "format": { let { name = "", value = false } = options; range = quill.getSelection(true); let format = quill.getFormat(range)[name] || false; if (["bold", "italic", "underline", "strike", "ins"].includes(name)) { value = !format; } else if (name === "direction") { value = value === "rtl" && format ? false : value; const align2 = quill.getFormat(range).align; if (value === "rtl" && !align2) { quill.format("align", "right", "user"); } else if (!value && align2 === "right") { quill.format("align", false, "user"); } } else if (name === "indent") { const rtl = quill.getFormat(range).direction === "rtl"; value = value === "+1"; if (rtl) { value = !value; } value = value ? "+1" : "-1"; } else { if (name === "list") { value = value === "check" ? "unchecked" : value; format = format === "checked" ? "unchecked" : format; } value = format && format !== (value || false) || !format && value ? value : !format; } quill.format(name, value, "user"); } break; case "insertDivider": range = quill.getSelection(true); quill.insertText(range.index, LINEFEED, "user"); quill.insertEmbed(range.index + 1, "divider", true, "user"); quill.setSelection(range.index + 2, 0, "silent"); break; case "insertImage": { range = quill.getSelection(true); const { src = "", alt = "", width = "", height = "", extClass = "", data: data2 = {} } = options; const path = getRealPath(src); quill.insertEmbed(range.index, "image", path, "silent"); const local = /^(file|blob):/.test(path) ? path : false; quill.formatText(range.index, 1, "data-local", local, "silent"); quill.formatText(range.index, 1, "alt", alt, "silent"); quill.formatText(range.index, 1, "width", width, "silent"); quill.formatText(range.index, 1, "height", height, "silent"); quill.formatText(range.index, 1, "class", extClass, "silent"); quill.formatText( range.index, 1, "data-custom", Object.keys(data2).map((key) => `${key}=${data2[key]}`).join("&"), "silent" ); quill.setSelection(range.index + 1, 0, "silent"); quill.scrollIntoView(); setTimeout(() => { textChangeHandler(); }, 1e3); } break; case "insertText": { range = quill.getSelection(true); const { text: text2 = "" } = options; quill.insertText(range.index, text2, "user"); quill.setSelection(range.index + text2.length, 0, "silent"); } break; case "setContents": { const { delta, html } = options; if (typeof delta === "object") { quill.setContents(delta, "silent"); } else if (isString(html)) { quill.setContents(html2delta(html), "silent"); } else { errMsg = "contents is missing"; } } break; case "getContents": res = getContents(); break; case "clear": quill.setText(""); break; case "removeFormat": { range = quill.getSelection(true); const parchment = Quill.import("parchment"); if (range.length) { quill.removeFormat(range.index, range.length, "user"); } else { Object.keys(quill.getFormat(range)).forEach((key) => { if (parchment.query(key, parchment.Scope.INLINE)) { quill.format(key, false); } }); } } break; case "undo": quill.history.undo(); break; case "redo": quill.history.redo(); break; case "blur": quill.blur(); break; case "getSelectionText": range = quill.selection.savedRange; res = { text: "" }; if (range && range.length !== 0) { res.text = quill.getText(range.index, range.length); } break; case "scrollIntoView": quill.scrollIntoView(); break; } updateStatus(range); } else { errMsg = "not ready"; } if (callbackId) { resolve({ callbackId, data: extend({}, res, { errMsg: `${type}:${errMsg ? "fail " + errMsg : "ok"}` }) }); } }, id2, true ); onMounted(() => { const imageResizeModules = []; if (props2.showImgSize) { imageResizeModules.push("DisplaySize"); } if (props2.showImgToolbar) { imageResizeModules.push("Toolbar"); } if (props2.showImgResize) { imageResizeModules.push("Resize"); } const quillSrc = "https://unpkg.com/quill@1.3.7/dist/quill.min.js"; loadScript(window.Quill, quillSrc, () => { if (imageResizeModules.length) { const imageResizeSrc = "https://unpkg.com/quill-image-resize-mp@3.0.1/image-resize.min.js"; loadScript(window.ImageResize, imageResizeSrc, () => { initQuill(imageResizeModules); }); } else { initQuill(imageResizeModules); } }); }); } const props$t = /* @__PURE__ */ extend({}, props$u, { id: { type: String, default: "" }, readOnly: { type: [Boolean, String], default: false }, placeholder: { type: String, default: "" }, showImgSize: { type: [Boolean, String], default: false }, showImgToolbar: { type: [Boolean, String], default: false }, showImgResize: { type: [Boolean, String], default: false } }); const index$s = /* @__PURE__ */ defineBuiltInComponent({ name: "Editor", props: props$t, emit: ["ready", "focus", "blur", "input", "statuschange", ...emit$1], setup(props2, { emit: emit2 }) { const rootRef = ref(null); const trigger = useCustomEvent(rootRef, emit2); useQuill(props2, rootRef, trigger); useKeyboard$1(props2, rootRef); return () => { return createVNode("uni-editor", { "ref": rootRef, "id": props2.id, "class": "ql-container" }, null, 8, ["id"]); }; } }); const INFO_COLOR = "#10aeff"; const WARN_COLOR = "#f76260"; const GREY_COLOR = "#b2b2b2"; const CANCEL_COLOR = "#f43530"; const ICONS = { success: { d: ICON_PATH_SUCCESS, c: PRIMARY_COLOR }, success_no_circle: { d: ICON_PATH_SUCCESS_NO_CIRCLE, c: PRIMARY_COLOR }, info: { d: ICON_PATH_INFO, c: INFO_COLOR }, warn: { d: ICON_PATH_WARN, c: WARN_COLOR }, waiting: { d: ICON_PATH_WAITING, c: INFO_COLOR }, cancel: { d: ICON_PATH_CANCEL, c: CANCEL_COLOR }, download: { d: ICON_PATH_DOWNLOAD, c: PRIMARY_COLOR }, search: { d: ICON_PATH_SEARCH, c: GREY_COLOR }, clear: { d: ICON_PATH_CLEAR, c: GREY_COLOR } }; const index$r = /* @__PURE__ */ defineBuiltInComponent({ name: "Icon", props: { type: { type: String, required: true, default: "" }, size: { type: [String, Number], default: 23 }, color: { type: String, default: "" } }, setup(props2) { const path = computed(() => ICONS[props2.type]); return () => { const { value } = path; return createVNode("uni-icon", null, [value && value.d && createSvgIconVNode(value.d, props2.color || value.c, rpx2px(props2.size))]); }; } }); const props$s = { src: { type: String, default: "" }, mode: { type: String, default: "scaleToFill" }, lazyLoad: { type: [Boolean, String], default: false }, draggable: { type: Boolean, default: false } }; const FIX_MODES = { widthFix: ["offsetWidth", "height", (value, ratio) => value / ratio], heightFix: ["offsetHeight", "width", (value, ratio) => value * ratio] }; const IMAGE_MODES = { aspectFit: ["center center", "contain"], aspectFill: ["center center", "cover"], widthFix: [, "100% 100%"], heightFix: [, "100% 100%"], top: ["center top"], bottom: ["center bottom"], center: ["center center"], left: ["left center"], right: ["right center"], "top left": ["left top"], "top right": ["right top"], "bottom left": ["left bottom"], "bottom right": ["right bottom"] }; const index$q = /* @__PURE__ */ defineBuiltInComponent({ name: "Image", props: props$s, setup(props2, { emit: emit2 }) { const rootRef = ref(null); const state2 = useImageState(rootRef, props2); const trigger = useCustomEvent(rootRef, emit2); const { fixSize } = useImageSize(rootRef, props2, state2); useImageLoader(state2, props2, rootRef, fixSize, trigger); return () => { return createVNode("uni-image", { "ref": rootRef }, [createVNode("div", { "style": state2.modeStyle }, null, 4), FIX_MODES[props2.mode] ? ( // @ts-ignore createVNode(ResizeSensor, { "onResize": fixSize }, null, 8, ["onResize"]) ) : createVNode("span", null, null)], 512); }; } }); function useImageState(rootRef, props2) { const imgSrc = ref(""); const modeStyleRef = computed(() => { let size = "auto"; let position = ""; const opts = IMAGE_MODES[props2.mode]; if (!opts) { position = "0% 0%"; size = "100% 100%"; } else { opts[0] && (position = opts[0]); opts[1] && (size = opts[1]); } return `background-image:${imgSrc.value ? 'url("' + imgSrc.value + '")' : "none"};background-position:${position};background-size:${size};`; }); const state2 = reactive({ rootEl: rootRef, src: computed(() => props2.src ? getRealPath(props2.src) : ""), origWidth: 0, origHeight: 0, origStyle: { width: "", height: "" }, modeStyle: modeStyleRef, imgSrc }); onMounted(() => { const rootEl = rootRef.value; const style = rootEl.style; state2.origWidth = Number(style.width) || 0; state2.origHeight = Number(style.height) || 0; }); return state2; } function useImageLoader(state2, props2, rootRef, fixSize, trigger) { let img; let draggableImg; const setState = (width = 0, height = 0, imgSrc = "") => { state2.origWidth = width; state2.origHeight = height; state2.imgSrc = imgSrc; }; const loadImage = (src) => { if (!src) { resetImage(); setState(); return; } img = img || new Image(); img.onload = (evt) => { const { width, height } = img; setState(width, height, src); fixSize(); img.draggable = props2.draggable; if (draggableImg) { draggableImg.remove(); } draggableImg = img; rootRef.value.appendChild(img); resetImage(); trigger("load", evt, { width, height }); }; img.onerror = (evt) => { setState(); resetImage(); trigger("error", evt, { errMsg: `GET ${state2.src} 404 (Not Found)` }); }; img.src = src; }; const resetImage = () => { if (img) { img.onload = null; img.onerror = null; img = null; } }; watch(() => state2.src, (value) => loadImage(value)); watch(() => state2.imgSrc, (value) => { if (!value && draggableImg) { draggableImg.remove(); draggableImg = null; } }); onMounted(() => loadImage(state2.src)); onBeforeUnmount(() => resetImage()); } const isChrome = navigator.vendor === "Google Inc."; function fixNumber(num) { if (isChrome && num > 10) { num = Math.round(num / 2) * 2; } return num; } function useImageSize(rootRef, props2, state2) { const fixSize = () => { const { mode: mode2 } = props2; const names = FIX_MODES[mode2]; if (!names) { return; } const { origWidth, origHeight } = state2; const ratio = origWidth && origHeight ? origWidth / origHeight : 0; if (!ratio) { return; } const rootEl = rootRef.value; const value = rootEl[names[0]]; if (value) { rootEl.style[names[1]] = fixNumber(names[2](value, ratio)) + "px"; } }; const resetSize = () => { const { style } = rootRef.value; const { origStyle: { width, height } } = state2; style.width = width; style.height = height; }; watch(() => props2.mode, (value, oldValue) => { if (FIX_MODES[oldValue]) { resetSize(); } if (FIX_MODES[value]) { fixSize(); } }); return { fixSize, resetSize }; } function throttle(fn, wait) { let last = 0; let timeout; let waitCallback; const newFn = function(...arg) { const now = Date.now(); clearTimeout(timeout); waitCallback = () => { waitCallback = null; last = now; fn.apply(this, arg); }; if (now - last < wait) { timeout = setTimeout(waitCallback, wait - (now - last)); return; } waitCallback(); }; newFn.cancel = function() { clearTimeout(timeout); waitCallback = null; }; newFn.flush = function() { clearTimeout(timeout); waitCallback && waitCallback(); }; return newFn; } const passiveOptions$1 = /* @__PURE__ */ passive(true); const states = []; let userInteract = 0; let inited; const setUserAction = (userAction) => states.forEach((vm) => vm.userAction = userAction); function addInteractListener(vm = { userAction: false }) { if (!inited) { const eventNames = [ "touchstart", "touchmove", "touchend", "mousedown", "mouseup" ]; eventNames.forEach((eventName) => { document.addEventListener( eventName, function() { !userInteract && setUserAction(true); userInteract++; setTimeout(() => { !--userInteract && setUserAction(false); }, 0); }, passiveOptions$1 ); }); inited = true; } states.push(vm); } function removeInteractListener(vm) { const index2 = states.indexOf(vm); if (index2 >= 0) { states.splice(index2, 1); } } const getInteractStatus = () => !!userInteract; function useUserAction() { const state2 = reactive({ /** * 是否用户激活 */ userAction: false }); onMounted(() => { addInteractListener(state2); }); onBeforeUnmount(() => { removeInteractListener(state2); }); return { state: state2 }; } function useScopedAttrs() { const state2 = reactive({ attrs: {} }); onMounted(() => { let instance2 = getCurrentInstance(); while (instance2) { const scopeId = instance2.type.__scopeId; if (scopeId) { state2.attrs[scopeId] = ""; } instance2 = instance2.proxy && instance2.proxy.$mpType === "page" ? null : instance2.parent; } }); return { state: state2 }; } function useFormField(nameKey, value) { const uniForm = inject( uniFormKey, false // remove warning ); if (!uniForm) { return; } const instance2 = getCurrentInstance(); const ctx = { submit() { const proxy = instance2.proxy; return [ proxy[nameKey], isString(value) ? proxy[value] : value.value ]; }, reset() { if (isString(value)) { instance2.proxy[value] = ""; } else { value.value = ""; } } }; uniForm.addField(ctx); onBeforeUnmount(() => { uniForm.removeField(ctx); }); } function getSelectedTextRange(_, resolve) { const activeElement = document.activeElement; if (!activeElement) { return resolve({}); } const data = {}; if (["input", "textarea"].includes(activeElement.tagName.toLowerCase())) { data.start = activeElement.selectionStart; data.end = activeElement.selectionEnd; } resolve(data); } const UniViewJSBridgeSubscribe = function() { registerViewMethod( getCurrentPageId(), "getSelectedTextRange", getSelectedTextRange ); }; function getValueString(value, type) { if (type === "number" && isNaN(Number(value))) { value = ""; } return value === null ? "" : String(value); } const INPUT_MODES = [ "none", "text", "decimal", "numeric", "tel", "search", "email", "url" ]; const props$r = /* @__PURE__ */ extend( {}, { name: { type: String, default: "" }, modelValue: { type: [String, Number], default: "" }, value: { type: [String, Number], default: "" }, disabled: { type: [Boolean, String], default: false }, /** * 已废弃属性,用于历史兼容 */ autoFocus: { type: [Boolean, String], default: false }, focus: { type: [Boolean, String], default: false }, cursor: { type: [Number, String], default: -1 }, selectionStart: { type: [Number, String], default: -1 }, selectionEnd: { type: [Number, String], default: -1 }, type: { type: String, default: "text" }, password: { type: [Boolean, String], default: false }, placeholder: { type: String, default: "" }, placeholderStyle: { type: String, default: "" }, placeholderClass: { type: String, default: "" }, maxlength: { type: [Number, String], default: 140 }, confirmType: { type: String, default: "done" }, confirmHold: { type: Boolean, default: false }, ignoreCompositionEvent: { type: Boolean, default: true }, step: { type: String, default: "0.000000000000000001" }, inputmode: { type: String, default: void 0, validator: (value) => !!~INPUT_MODES.indexOf(value) } }, props$u ); const emit = [ "input", "focus", "blur", "update:value", "update:modelValue", "update:focus", "compositionstart", "compositionupdate", "compositionend", ...emit$1 ]; function useBase(props2, rootRef, emit2) { const fieldRef = ref(null); const trigger = useCustomEvent(rootRef, emit2); const selectionStart = computed(() => { const selectionStart2 = Number(props2.selectionStart); return isNaN(selectionStart2) ? -1 : selectionStart2; }); const selectionEnd = computed(() => { const selectionEnd2 = Number(props2.selectionEnd); return isNaN(selectionEnd2) ? -1 : selectionEnd2; }); const cursor = computed(() => { const cursor2 = Number(props2.cursor); return isNaN(cursor2) ? -1 : cursor2; }); const maxlength = computed(() => { var maxlength2 = Number(props2.maxlength); return isNaN(maxlength2) ? 140 : maxlength2; }); const value = getValueString(props2.modelValue, props2.type) || getValueString(props2.value, props2.type); const state2 = reactive({ value, valueOrigin: value, maxlength, focus: props2.focus, composing: false, selectionStart, selectionEnd, cursor }); watch( () => state2.focus, (val) => emit2("update:focus", val) ); watch( () => state2.maxlength, (val) => state2.value = state2.value.slice(0, val) ); return { fieldRef, state: state2, trigger }; } function useValueSync(props2, state2, emit2, trigger) { const valueChangeFn = debounce( (val) => { state2.value = getValueString(val, props2.type); }, 100, { setTimeout, clearTimeout } ); watch(() => props2.modelValue, valueChangeFn); watch(() => props2.value, valueChangeFn); const triggerInputFn = throttle((event, detail) => { valueChangeFn.cancel(); emit2("update:modelValue", detail.value); emit2("update:value", detail.value); trigger("input", event, detail); }, 100); const triggerInput = (event, detail, force) => { valueChangeFn.cancel(); triggerInputFn(event, detail); if (force) { triggerInputFn.flush(); } }; onBeforeMount(() => { valueChangeFn.cancel(); triggerInputFn.cancel(); }); return { trigger, triggerInput }; } function useAutoFocus(props2, fieldRef) { useUserAction(); const needFocus = computed(() => props2.autoFocus || props2.focus); function focus() { if (!needFocus.value) { return; } const field = fieldRef.value; if (!field || false) { setTimeout(focus, 100); return; } { field.focus(); } } function blur() { const field = fieldRef.value; if (field) { field.blur(); } } watch( () => props2.focus, (value) => { if (value) { focus(); } else { blur(); } } ); onMounted(() => { if (needFocus.value) { nextTick(focus); } }); } function useEvent(fieldRef, state2, props2, trigger, triggerInput, beforeInput) { function checkSelection() { const field = fieldRef.value; if (field && state2.focus && state2.selectionStart > -1 && state2.selectionEnd > -1 && field.type !== "number") { field.selectionStart = state2.selectionStart; field.selectionEnd = state2.selectionEnd; } } function checkCursor() { const field = fieldRef.value; if (field && state2.focus && state2.selectionStart < 0 && state2.selectionEnd < 0 && state2.cursor > -1 && field.type !== "number") { field.selectionEnd = field.selectionStart = state2.cursor; } } function getFieldSelectionEnd(field) { if (field.type === "number") { return null; } else { return field.selectionEnd; } } function initField() { const field = fieldRef.value; if (!field) return; const onFocus = function(event) { state2.focus = true; trigger("focus", event, { value: state2.value }); checkSelection(); checkCursor(); }; const onInput = function(event, force) { event.stopPropagation(); if (isFunction(beforeInput) && beforeInput(event, state2) === false) { return; } state2.value = field.value; if (!state2.composing || !props2.ignoreCompositionEvent) { triggerInput( event, { value: field.value, cursor: getFieldSelectionEnd(field) }, force ); } }; const onBlur = function(event) { if (state2.composing) { state2.composing = false; onInput(event, true); } state2.focus = false; trigger("blur", event, { value: state2.value, cursor: getFieldSelectionEnd(event.target) }); }; field.addEventListener("change", (event) => event.stopPropagation()); field.addEventListener("focus", onFocus); field.addEventListener("blur", onBlur); field.addEventListener("input", onInput); field.addEventListener("compositionstart", (event) => { event.stopPropagation(); state2.composing = true; _onComposition(event); }); field.addEventListener("compositionend", (event) => { event.stopPropagation(); if (state2.composing) { state2.composing = false; onInput(event); } _onComposition(event); }); field.addEventListener("compositionupdate", _onComposition); function _onComposition(event) { if (!props2.ignoreCompositionEvent) { trigger(event.type, event, { value: event.data }); } } } watch([() => state2.selectionStart, () => state2.selectionEnd], checkSelection); watch(() => state2.cursor, checkCursor); watch(() => fieldRef.value, initField); } function useField(props2, rootRef, emit2, beforeInput) { UniViewJSBridgeSubscribe(); const { fieldRef, state: state2, trigger } = useBase(props2, rootRef, emit2); const { triggerInput } = useValueSync(props2, state2, emit2, trigger); useAutoFocus(props2, fieldRef); useKeyboard$1(props2, fieldRef); const { state: scopedAttrsState } = useScopedAttrs(); useFormField("name", state2); useEvent(fieldRef, state2, props2, trigger, triggerInput, beforeInput); const fixDisabledColor = String(navigator.vendor).indexOf("Apple") === 0 && CSS.supports("image-orientation:from-image"); return { fieldRef, state: state2, scopedAttrsState, fixDisabledColor, trigger }; } const props$q = /* @__PURE__ */ extend({}, props$r, { placeholderClass: { type: String, default: "input-placeholder" }, textContentType: { type: String, default: "" } }); const Input = /* @__PURE__ */ defineBuiltInComponent({ name: "Input", props: props$q, emits: ["confirm", ...emit], setup(props2, { emit: emit2 }) { const INPUT_TYPES = ["text", "number", "idcard", "digit", "password", "tel"]; const AUTOCOMPLETES = ["off", "one-time-code"]; const type = computed(() => { let type2 = ""; switch (props2.type) { case "text": if (props2.confirmType === "search") { type2 = "search"; } break; case "idcard": type2 = "text"; break; case "digit": type2 = "number"; break; default: type2 = ~INPUT_TYPES.includes(props2.type) ? props2.type : "text"; break; } return props2.password ? "password" : type2; }); const autocomplete = computed(() => { const camelizeIndex = AUTOCOMPLETES.indexOf(props2.textContentType); const kebabCaseIndex = AUTOCOMPLETES.indexOf(hyphenate(props2.textContentType)); const index2 = camelizeIndex !== -1 ? camelizeIndex : kebabCaseIndex !== -1 ? kebabCaseIndex : 0; return AUTOCOMPLETES[index2]; }); let cache = ref(""); let resetCache; const rootRef = ref(null); const { fieldRef, state: state2, scopedAttrsState, fixDisabledColor, trigger } = useField(props2, rootRef, emit2, (event, state3) => { const input = event.target; if (type.value === "number") { if (resetCache) { input.removeEventListener("blur", resetCache); resetCache = null; } if (input.validity && !input.validity.valid) { if ((!cache.value || !input.value) && event.data === "-" || cache.value[0] === "-" && event.inputType === "deleteContentBackward") { cache.value = "-"; state3.value = ""; resetCache = () => { cache.value = input.value = ""; }; input.addEventListener("blur", resetCache); return false; } if (cache.value) { if (cache.value.indexOf(".") !== -1) { if (event.data !== "." && event.inputType === "deleteContentBackward") { const dotIndex = cache.value.indexOf("."); cache.value = input.value = state3.value = cache.value.slice(0, dotIndex); return true; } } else if (event.data === ".") { cache.value += "."; resetCache = () => { cache.value = input.value = cache.value.slice(0, -1); }; input.addEventListener("blur", resetCache); return false; } } cache.value = state3.value = input.value = cache.value === "-" ? "" : cache.value; return false; } else { cache.value = input.value; } const maxlength = state3.maxlength; if (maxlength > 0 && input.value.length > maxlength) { input.value = input.value.slice(0, maxlength); state3.value = input.value; return false; } } }); watch(() => state2.value, (value) => { if (props2.type === "number" && !(cache.value === "-" && value === "")) { cache.value = value; } }); const NUMBER_TYPES = ["number", "digit"]; const step = computed(() => NUMBER_TYPES.includes(props2.type) ? props2.step : ""); function onKeyUpEnter(event) { if (event.key !== "Enter") { return; } const input = event.target; event.stopPropagation(); trigger("confirm", event, { value: input.value }); !props2.confirmHold && input.blur(); } return () => { let inputNode = props2.disabled && fixDisabledColor ? createVNode("input", { "key": "disabled-input", "ref": fieldRef, "value": state2.value, "tabindex": "-1", "readonly": !!props2.disabled, "type": type.value, "maxlength": state2.maxlength, "step": step.value, "class": "uni-input-input", "onFocus": (event) => event.target.blur() }, null, 40, ["value", "readonly", "type", "maxlength", "step", "onFocus"]) : withDirectives(createVNode("input", { "key": "input", "ref": fieldRef, "onUpdate:modelValue": ($event) => state2.value = $event, "disabled": !!props2.disabled, "type": type.value, "maxlength": state2.maxlength, "step": step.value, "enterkeyhint": props2.confirmType, "pattern": props2.type === "number" ? "[0-9]*" : void 0, "class": "uni-input-input", "autocomplete": autocomplete.value, "onKeyup": onKeyUpEnter, "inputmode": props2.inputmode }, null, 40, ["onUpdate:modelValue", "disabled", "type", "maxlength", "step", "enterkeyhint", "pattern", "autocomplete", "onKeyup", "inputmode"]), [[vModelDynamic, state2.value]]); return createVNode("uni-input", { "ref": rootRef }, [createVNode("div", { "class": "uni-input-wrapper" }, [withDirectives(createVNode("div", mergeProps(scopedAttrsState.attrs, { "style": props2.placeholderStyle, "class": ["uni-input-placeholder", props2.placeholderClass] }), [props2.placeholder], 16), [[vShow, !(state2.value.length || cache.value === "-")]]), props2.confirmType === "search" ? createVNode("form", { "action": "", "onSubmit": (event) => event.preventDefault(), "class": "uni-input-form" }, [inputNode], 40, ["onSubmit"]) : inputNode])], 512); }; } }); function entries(obj) { return Object.keys(obj).map((key) => [key, obj[key]]); } const DEFAULT_EXCLUDE_KEYS = ["class", "style"]; const LISTENER_PREFIX = /^on[A-Z]+/; const useAttrs = (params = {}) => { const { excludeListeners = false, excludeKeys = [] } = params; const instance2 = getCurrentInstance(); const attrs2 = shallowRef({}); const listeners2 = shallowRef({}); const excludeAttrs = shallowRef({}); const allExcludeKeys = excludeKeys.concat(DEFAULT_EXCLUDE_KEYS); instance2.attrs = reactive(instance2.attrs); watchEffect(() => { const res = entries(instance2.attrs).reduce( (acc, [key, val]) => { if (allExcludeKeys.includes(key)) { acc.exclude[key] = val; } else if (LISTENER_PREFIX.test(key)) { if (!excludeListeners) { acc.attrs[key] = val; } acc.listeners[key] = val; } else { acc.attrs[key] = val; } return acc; }, { exclude: {}, attrs: {}, listeners: {} } ); attrs2.value = res.attrs; listeners2.value = res.listeners; excludeAttrs.value = res.exclude; }); return { $attrs: attrs2, $listeners: listeners2, $excludeAttrs: excludeAttrs }; }; function flatVNode(nodes) { const array = []; if (isArray(nodes)) { nodes.forEach((vnode) => { if (isVNode(vnode)) { if (vnode.type === Fragment) { array.push(...flatVNode(vnode.children)); } else { array.push(vnode); } } else if (isArray(vnode)) { array.push(...flatVNode(vnode)); } }); } return array; } const movableAreaProps = { scaleArea: { type: Boolean, default: false } }; const MovableArea = /* @__PURE__ */ defineBuiltInComponent({ inheritAttrs: false, name: "MovableArea", props: movableAreaProps, setup(props2, { slots }) { const rootRef = ref(null); const _isMounted = ref(false); let { setContexts, events: movableAreaEvents } = useMovableAreaState(props2, rootRef); const { $listeners, $attrs, $excludeAttrs } = useAttrs(); const _listeners = $listeners.value; let events = ["onTouchstart", "onTouchmove", "onTouchend"]; events.forEach((event) => { let existing = _listeners[event]; let ours = movableAreaEvents[`_${event}`]; _listeners[event] = existing ? [].concat(existing, ours) : ours; }); onMounted(() => { movableAreaEvents._resize(); _isMounted.value = true; }); let movableViewItems = []; const originMovableViewContexts = []; function updateMovableViewContexts() { const contexts = []; for (let index2 = 0; index2 < movableViewItems.length; index2++) { let movableViewItem = movableViewItems[index2]; { movableViewItem = movableViewItem.el; } const movableViewContext = originMovableViewContexts.find((context) => movableViewItem === context.rootRef.value); if (movableViewContext) { contexts.push(markRaw(movableViewContext)); } } setContexts(contexts); } const addMovableViewContext = (movableViewContext) => { originMovableViewContexts.push(movableViewContext); updateMovableViewContexts(); }; const removeMovableViewContext = (movableViewContext) => { const index2 = originMovableViewContexts.indexOf(movableViewContext); if (index2 >= 0) { originMovableViewContexts.splice(index2, 1); updateMovableViewContexts(); } }; provide("_isMounted", _isMounted); provide("movableAreaRootRef", rootRef); provide("addMovableViewContext", addMovableViewContext); provide("removeMovableViewContext", removeMovableViewContext); return () => { const defaultSlots = slots.default && slots.default(); { movableViewItems = flatVNode(defaultSlots); } return createVNode("uni-movable-area", mergeProps({ "ref": rootRef }, $attrs.value, $excludeAttrs.value, _listeners), [createVNode(ResizeSensor, { "onResize": movableAreaEvents._resize }, null, 8, ["onResize"]), movableViewItems], 16); }; } }); function calc(e2) { return Math.sqrt(e2.x * e2.x + e2.y * e2.y); } function useMovableAreaState(props2, rootRef) { const width = ref(0); const height = ref(0); const gapV = reactive({ x: null, y: null }); const pinchStartLen = ref(null); let _scaleMovableView = null; let movableViewContexts = []; function _updateScale(e2) { if (e2 && e2 !== 1) { if (props2.scaleArea) { movableViewContexts.forEach(function(item) { item._setScale(e2); }); } else { if (_scaleMovableView) { _scaleMovableView._setScale(e2); } } } } function _find(target, items = movableViewContexts) { let root = rootRef.value; function get(node) { for (let i = 0; i < items.length; i++) { const item = items[i]; if (node === item.rootRef.value) { return item; } } if (node === root || node === document.body || node === document) { return null; } return get(node.parentNode); } return get(target); } const _onTouchstart = withWebEvent((t2) => { let i = t2.touches; if (i) { if (i.length > 1) { let r = { x: i[1].pageX - i[0].pageX, y: i[1].pageY - i[0].pageY }; pinchStartLen.value = calc(r); gapV.x = r.x; gapV.y = r.y; if (!props2.scaleArea) { let touch0 = _find(i[0].target); let touch1 = _find(i[1].target); _scaleMovableView = touch0 && touch0 === touch1 ? touch0 : null; } } } }); const _onTouchmove = withWebEvent((t2) => { let n = t2.touches; if (n) { if (n.length > 1) { t2.preventDefault(); let i = { x: n[1].pageX - n[0].pageX, y: n[1].pageY - n[0].pageY }; if (gapV.x !== null && pinchStartLen.value && pinchStartLen.value > 0) { let r = calc(i) / pinchStartLen.value; _updateScale(r); } gapV.x = i.x; gapV.y = i.y; } } }); const _onTouchend = withWebEvent((e2) => { let t2 = e2.touches; if (!(t2 && t2.length)) { if (e2.changedTouches) { gapV.x = 0; gapV.y = 0; pinchStartLen.value = null; if (props2.scaleArea) { movableViewContexts.forEach(function(item) { item._endScale(); }); } else { if (_scaleMovableView) { _scaleMovableView._endScale(); } } } } }); function _resize() { _getWH(); movableViewContexts.forEach(function(item, index2) { item.setParent(); }); } function _getWH() { let style = window.getComputedStyle(rootRef.value); let rect = rootRef.value.getBoundingClientRect(); width.value = rect.width - ["Left", "Right"].reduce(function(all, item) { const LEFT = "border" + item + "Width"; const RIGHT = "padding" + item; return all + parseFloat(style[LEFT]) + parseFloat(style[RIGHT]); }, 0); height.value = rect.height - ["Top", "Bottom"].reduce(function(all, item) { const TOP = "border" + item + "Width"; const BOTTOM = "padding" + item; return all + parseFloat(style[TOP]) + parseFloat(style[BOTTOM]); }, 0); } provide("movableAreaWidth", width); provide("movableAreaHeight", height); return { setContexts(contexts) { movableViewContexts = contexts; }, events: { _onTouchstart, _onTouchmove, _onTouchend, _resize } }; } const addListenerToElement = function(element, type, callback, capture) { element.addEventListener( type, ($event) => { if (isFunction(callback)) { if (callback($event) === false) { if (typeof $event.cancelable !== "undefined" ? $event.cancelable : true) { $event.preventDefault(); } $event.stopPropagation(); } } }, { passive: false } ); }; let __mouseMoveEventListener; let __mouseUpEventListener; function useTouchtrack(element, method, useCancel) { onBeforeUnmount(() => { document.removeEventListener("mousemove", __mouseMoveEventListener); document.removeEventListener("mouseup", __mouseUpEventListener); }); let x0 = 0; let y0 = 0; let x1 = 0; let y1 = 0; const fn = function($event, state2, x, y) { if (method({ // @ts-expect-error cancelable: $event.cancelable, target: $event.target, currentTarget: $event.currentTarget, preventDefault: $event.preventDefault.bind($event), stopPropagation: $event.stopPropagation.bind($event), touches: $event.touches, changedTouches: $event.changedTouches, detail: { state: state2, x, y, dx: x - x0, dy: y - y0, ddx: x - x1, ddy: y - y1, timeStamp: $event.timeStamp } }) === false) { return false; } }; let $eventOld = null; let hasTouchStart; let hasMouseDown; addListenerToElement(element, "touchstart", function($event) { hasTouchStart = true; if ($event.touches.length === 1 && !$eventOld) { $eventOld = $event; x0 = x1 = $event.touches[0].pageX; y0 = y1 = $event.touches[0].pageY; return fn($event, "start", x0, y0); } }); addListenerToElement(element, "mousedown", function($event) { hasMouseDown = true; if (!hasTouchStart && !$eventOld) { $eventOld = $event; x0 = x1 = $event.pageX; y0 = y1 = $event.pageY; return fn($event, "start", x0, y0); } }); addListenerToElement(element, "touchmove", function($event) { if ($event.touches.length === 1 && $eventOld) { const res = fn( $event, "move", $event.touches[0].pageX, $event.touches[0].pageY ); x1 = $event.touches[0].pageX; y1 = $event.touches[0].pageY; return res; } }); const mouseMoveEventListener = __mouseMoveEventListener = function($event) { if (!hasTouchStart && hasMouseDown && $eventOld) { const res = fn($event, "move", $event.pageX, $event.pageY); x1 = $event.pageX; y1 = $event.pageY; return res; } }; document.addEventListener("mousemove", mouseMoveEventListener); addListenerToElement(element, "touchend", function($event) { if ($event.touches.length === 0 && $eventOld) { hasTouchStart = false; $eventOld = null; return fn( $event, "end", $event.changedTouches[0].pageX, $event.changedTouches[0].pageY ); } }); const mouseUpEventListener = __mouseUpEventListener = function($event) { hasMouseDown = false; if (!hasTouchStart && $eventOld) { $eventOld = null; return fn($event, "end", $event.pageX, $event.pageY); } }; document.addEventListener("mouseup", mouseUpEventListener); addListenerToElement(element, "touchcancel", function($event) { if ($eventOld) { hasTouchStart = false; const $eventTemp = $eventOld; $eventOld = null; return fn( $event, useCancel ? "cancel" : "end", $eventTemp.touches[0].pageX, $eventTemp.touches[0].pageY ); } }); } function e(e2, t2, n) { return e2 > t2 - n && e2 < t2 + n; } function t(t2, n) { return e(t2, 0, n); } function Decline() { } Decline.prototype.x = function(e2) { return Math.sqrt(e2); }; function Friction$1(e2, t2) { this._m = e2; this._f = 1e3 * t2; this._startTime = 0; this._v = 0; } Friction$1.prototype.setV = function(x, y) { const n = Math.pow(Math.pow(x, 2) + Math.pow(y, 2), 0.5); this._x_v = x; this._y_v = y; this._x_a = -this._f * this._x_v / n; this._y_a = -this._f * this._y_v / n; this._t = Math.abs(x / this._x_a) || Math.abs(y / this._y_a); this._lastDt = null; this._startTime = (/* @__PURE__ */ new Date()).getTime(); }; Friction$1.prototype.setS = function(x, y) { this._x_s = x; this._y_s = y; }; Friction$1.prototype.s = function(t2) { if (void 0 === t2) { t2 = ((/* @__PURE__ */ new Date()).getTime() - this._startTime) / 1e3; } if (t2 > this._t) { t2 = this._t; this._lastDt = t2; } let x = this._x_v * t2 + 0.5 * this._x_a * Math.pow(t2, 2) + this._x_s; let y = this._y_v * t2 + 0.5 * this._y_a * Math.pow(t2, 2) + this._y_s; if (this._x_a > 0 && x < this._endPositionX || this._x_a < 0 && x > this._endPositionX) { x = this._endPositionX; } if (this._y_a > 0 && y < this._endPositionY || this._y_a < 0 && y > this._endPositionY) { y = this._endPositionY; } return { x, y }; }; Friction$1.prototype.ds = function(t2) { if (void 0 === t2) { t2 = ((/* @__PURE__ */ new Date()).getTime() - this._startTime) / 1e3; } if (t2 > this._t) { t2 = this._t; } return { dx: this._x_v + this._x_a * t2, dy: this._y_v + this._y_a * t2 }; }; Friction$1.prototype.delta = function() { return { x: -1.5 * Math.pow(this._x_v, 2) / this._x_a || 0, y: -1.5 * Math.pow(this._y_v, 2) / this._y_a || 0 }; }; Friction$1.prototype.dt = function() { return -this._x_v / this._x_a; }; Friction$1.prototype.done = function() { const t2 = e(this.s().x, this._endPositionX) || e(this.s().y, this._endPositionY) || this._lastDt === this._t; this._lastDt = null; return t2; }; Friction$1.prototype.setEnd = function(x, y) { this._endPositionX = x; this._endPositionY = y; }; Friction$1.prototype.reconfigure = function(m, f2) { this._m = m; this._f = 1e3 * f2; }; function Spring$1(m, k, c) { this._m = m; this._k = k; this._c = c; this._solution = null; this._endPosition = 0; this._startTime = 0; } Spring$1.prototype._solve = function(e2, t2) { const n = this._c; const i = this._m; const r = this._k; const o2 = n * n - 4 * i * r; if (o2 === 0) { const a2 = -n / (2 * i); const s = e2; const l = t2 / (a2 * e2); return { x: function(e3) { return (s + l * e3) * Math.pow(Math.E, a2 * e3); }, dx: function(e3) { const t3 = Math.pow(Math.E, a2 * e3); return a2 * (s + l * e3) * t3 + l * t3; } }; } if (o2 > 0) { const c = (-n - Math.sqrt(o2)) / (2 * i); const u = (-n + Math.sqrt(o2)) / (2 * i); const d = (t2 - c * e2) / (u - c); const h2 = e2 - d; return { x: function(e3) { let t3; let n2; if (e3 === this._t) { t3 = this._powER1T; n2 = this._powER2T; } this._t = e3; if (!t3) { t3 = this._powER1T = Math.pow(Math.E, c * e3); } if (!n2) { n2 = this._powER2T = Math.pow(Math.E, u * e3); } return h2 * t3 + d * n2; }, dx: function(e3) { let t3; let n2; if (e3 === this._t) { t3 = this._powER1T; n2 = this._powER2T; } this._t = e3; if (!t3) { t3 = this._powER1T = Math.pow(Math.E, c * e3); } if (!n2) { n2 = this._powER2T = Math.pow(Math.E, u * e3); } return h2 * c * t3 + d * u * n2; } }; } const p2 = Math.sqrt(4 * i * r - n * n) / (2 * i); const f2 = -n / 2 * i; const v2 = e2; const g2 = (t2 - f2 * e2) / p2; return { x: function(e3) { return Math.pow(Math.E, f2 * e3) * (v2 * Math.cos(p2 * e3) + g2 * Math.sin(p2 * e3)); }, dx: function(e3) { const t3 = Math.pow(Math.E, f2 * e3); const n2 = Math.cos(p2 * e3); const i2 = Math.sin(p2 * e3); return t3 * (g2 * p2 * n2 - v2 * p2 * i2) + f2 * t3 * (g2 * i2 + v2 * n2); } }; }; Spring$1.prototype.x = function(e2) { if (void 0 === e2) { e2 = ((/* @__PURE__ */ new Date()).getTime() - this._startTime) / 1e3; } return this._solution ? this._endPosition + this._solution.x(e2) : 0; }; Spring$1.prototype.dx = function(e2) { if (void 0 === e2) { e2 = ((/* @__PURE__ */ new Date()).getTime() - this._startTime) / 1e3; } return this._solution ? this._solution.dx(e2) : 0; }; Spring$1.prototype.setEnd = function(e2, n, i) { if (!i) { i = (/* @__PURE__ */ new Date()).getTime(); } if (e2 !== this._endPosition || !t(n, 0.1)) { n = n || 0; let r = this._endPosition; if (this._solution) { if (t(n, 0.1)) { n = this._solution.dx((i - this._startTime) / 1e3); } r = this._solution.x((i - this._startTime) / 1e3); if (t(n, 0.1)) { n = 0; } if (t(r, 0.1)) { r = 0; } r += this._endPosition; } if (!(this._solution && t(r - e2, 0.1) && t(n, 0.1))) { this._endPosition = e2; this._solution = this._solve(r - this._endPosition, n); this._startTime = i; } } }; Spring$1.prototype.snap = function(e2) { this._startTime = (/* @__PURE__ */ new Date()).getTime(); this._endPosition = e2; this._solution = { x: function() { return 0; }, dx: function() { return 0; } }; }; Spring$1.prototype.done = function(n) { if (!n) { n = (/* @__PURE__ */ new Date()).getTime(); } return e(this.x(), this._endPosition, 0.1) && t(this.dx(), 0.1); }; Spring$1.prototype.reconfigure = function(m, t2, c) { this._m = m; this._k = t2; this._c = c; if (!this.done()) { this._solution = this._solve(this.x() - this._endPosition, this.dx()); this._startTime = (/* @__PURE__ */ new Date()).getTime(); } }; Spring$1.prototype.springConstant = function() { return this._k; }; Spring$1.prototype.damping = function() { return this._c; }; Spring$1.prototype.configuration = function() { function e2(e3, t3) { e3.reconfigure(1, t3, e3.damping()); } function t2(e3, t3) { e3.reconfigure(1, e3.springConstant(), t3); } return [ { label: "Spring Constant", read: this.springConstant.bind(this), write: e2.bind(this, this), min: 100, max: 1e3 }, { label: "Damping", read: this.damping.bind(this), write: t2.bind(this, this), min: 1, max: 500 } ]; }; function STD(e2, t2, n) { this._springX = new Spring$1(e2, t2, n); this._springY = new Spring$1(e2, t2, n); this._springScale = new Spring$1(e2, t2, n); this._startTime = 0; } STD.prototype.setEnd = function(e2, t2, n, i) { const r = (/* @__PURE__ */ new Date()).getTime(); this._springX.setEnd(e2, i, r); this._springY.setEnd(t2, i, r); this._springScale.setEnd(n, i, r); this._startTime = r; }; STD.prototype.x = function() { const e2 = ((/* @__PURE__ */ new Date()).getTime() - this._startTime) / 1e3; return { x: this._springX.x(e2), y: this._springY.x(e2), scale: this._springScale.x(e2) }; }; STD.prototype.done = function() { const e2 = (/* @__PURE__ */ new Date()).getTime(); return this._springX.done(e2) && this._springY.done(e2) && this._springScale.done(e2); }; STD.prototype.reconfigure = function(e2, t2, n) { this._springX.reconfigure(e2, t2, n); this._springY.reconfigure(e2, t2, n); this._springScale.reconfigure(e2, t2, n); }; const movableViewProps = { direction: { type: String, default: "none" }, inertia: { type: [Boolean, String], default: false }, outOfBounds: { type: [Boolean, String], default: false }, x: { type: [Number, String], default: 0 }, y: { type: [Number, String], default: 0 }, damping: { type: [Number, String], default: 20 }, friction: { type: [Number, String], default: 2 }, disabled: { type: [Boolean, String], default: false }, scale: { type: [Boolean, String], default: false }, scaleMin: { type: [Number, String], default: 0.5 }, scaleMax: { type: [Number, String], default: 10 }, scaleValue: { type: [Number, String], default: 1 }, animation: { type: [Boolean, String], default: true } }; function v(a2, b) { return +((1e3 * a2 - 1e3 * b) / 1e3).toFixed(1); } const MovableView = /* @__PURE__ */ defineBuiltInComponent({ name: "MovableView", props: movableViewProps, emits: ["change", "scale"], setup(props2, { slots, emit: emit2 }) { const rootRef = ref(null); const trigger = useCustomEvent(rootRef, emit2); const { setParent } = useMovableViewState(props2, trigger, rootRef); return () => { return createVNode("uni-movable-view", { "ref": rootRef }, [createVNode(ResizeSensor, { "onResize": setParent }, null, 8, ["onResize"]), slots.default && slots.default()], 512); }; } }); let requesting = false; function _requestAnimationFrame(e2) { if (!requesting) { requesting = true; requestAnimationFrame(function() { e2(); requesting = false; }); } } function p(t2, n) { if (t2 === n) { return 0; } let i = t2.offsetLeft; return t2.offsetParent ? i += p(t2.offsetParent, n) : 0; } function f(t2, n) { if (t2 === n) { return 0; } let i = t2.offsetTop; return t2.offsetParent ? i += f(t2.offsetParent, n) : 0; } function g(friction, execute, endCallback) { let record = { id: 0, cancelled: false }; let cancel = function(record2) { if (record2 && record2.id) { cancelAnimationFrame(record2.id); } if (record2) { record2.cancelled = true; } }; function fn(record2, friction2, execute2, endCallback2) { if (!record2 || !record2.cancelled) { execute2(friction2); let isDone = friction2.done(); if (!isDone) { if (!record2.cancelled) { record2.id = requestAnimationFrame(fn.bind(null, record2, friction2, execute2, endCallback2)); } } if (isDone && endCallback2) { endCallback2(friction2); } } } fn(record, friction, execute, endCallback); return { cancel: cancel.bind(null, record), model: friction }; } function _getPx(val) { if (/\d+[ur]px$/i.test(val)) { return uni.upx2px(parseFloat(val)); } return Number(val) || 0; } function useMovableViewLayout(rootRef, _scale, _adjustScale) { const movableAreaWidth = inject("movableAreaWidth", ref(0)); const movableAreaHeight = inject("movableAreaHeight", ref(0)); const movableAreaRootRef = inject("movableAreaRootRef"); const _offset = { x: 0, y: 0 }; const _scaleOffset = { x: 0, y: 0 }; const width = ref(0); const height = ref(0); const minX = ref(0); const minY = ref(0); const maxX = ref(0); const maxY = ref(0); function _updateBoundary() { let x = 0 - _offset.x + _scaleOffset.x; let _width = movableAreaWidth.value - width.value - _offset.x - _scaleOffset.x; minX.value = Math.min(x, _width); maxX.value = Math.max(x, _width); let y = 0 - _offset.y + _scaleOffset.y; let _height = movableAreaHeight.value - height.value - _offset.y - _scaleOffset.y; minY.value = Math.min(y, _height); maxY.value = Math.max(y, _height); } function _updateOffset() { _offset.x = p(rootRef.value, movableAreaRootRef.value); _offset.y = f(rootRef.value, movableAreaRootRef.value); } function _updateWH(scale) { scale = scale || _scale.value; scale = _adjustScale(scale); let rect = rootRef.value.getBoundingClientRect(); height.value = rect.height / _scale.value; width.value = rect.width / _scale.value; let _height = height.value * scale; let _width = width.value * scale; _scaleOffset.x = (_width - width.value) / 2; _scaleOffset.y = (_height - height.value) / 2; } return { _updateBoundary, _updateOffset, _updateWH, _scaleOffset, minX, minY, maxX, maxY }; } function useMovableViewTransform(rootRef, props2, _scaleOffset, _scale, maxX, maxY, minX, minY, _translateX, _translateY, _SFA, _FA, _adjustScale, trigger) { const dampingNumber = computed(() => { let val = Number(props2.damping); return isNaN(val) ? 20 : val; }); const xMove = computed(() => props2.direction === "all" || props2.direction === "horizontal"); const yMove = computed(() => props2.direction === "all" || props2.direction === "vertical"); const xSync = ref(_getPx(props2.x)); const ySync = ref(_getPx(props2.y)); watch(() => props2.x, (val) => { xSync.value = _getPx(val); }); watch(() => props2.y, (val) => { ySync.value = _getPx(val); }); watch(xSync, (val) => { _setX(val); }); watch(ySync, (val) => { _setY(val); }); const _STD = new STD(1, 9 * Math.pow(dampingNumber.value, 2) / 40, dampingNumber.value); function _getLimitXY(x, y) { let outOfBounds = false; if (x > maxX.value) { x = maxX.value; outOfBounds = true; } else { if (x < minX.value) { x = minX.value; outOfBounds = true; } } if (y > maxY.value) { y = maxY.value; outOfBounds = true; } else { if (y < minY.value) { y = minY.value; outOfBounds = true; } } return { x, y, outOfBounds }; } function FAandSFACancel() { if (_FA) { _FA.cancel(); } if (_SFA) { _SFA.cancel(); } } function _animationTo(x, y, scale, source, r, o2) { FAandSFACancel(); if (!xMove.value) { x = _translateX.value; } if (!yMove.value) { y = _translateY.value; } if (!props2.scale) { scale = _scale.value; } let limitXY = _getLimitXY(x, y); x = limitXY.x; y = limitXY.y; if (!props2.animation) { _setTransform(x, y, scale, source, r, o2); return; } _STD._springX._solution = null; _STD._springY._solution = null; _STD._springScale._solution = null; _STD._springX._endPosition = _translateX.value; _STD._springY._endPosition = _translateY.value; _STD._springScale._endPosition = _scale.value; _STD.setEnd(x, y, scale, 1); _SFA = g(_STD, function() { let data = _STD.x(); let x2 = data.x; let y2 = data.y; let scale2 = data.scale; _setTransform(x2, y2, scale2, source, r, o2); }, function() { _SFA.cancel(); }); } function _setTransform(x, y, scale, source = "", r, o2) { if (!(x !== null && x.toString() !== "NaN" && typeof x === "number")) { x = _translateX.value || 0; } if (!(y !== null && y.toString() !== "NaN" && typeof y === "number")) { y = _translateY.value || 0; } x = Number(x.toFixed(1)); y = Number(y.toFixed(1)); scale = Number(scale.toFixed(1)); if (!(_translateX.value === x && _translateY.value === y)) { if (!r) { trigger("change", {}, { x: v(x, _scaleOffset.x), y: v(y, _scaleOffset.y), source }); } } if (!props2.scale) { scale = _scale.value; } scale = _adjustScale(scale); scale = +scale.toFixed(3); if (o2 && scale !== _scale.value) { trigger("scale", {}, { x, y, scale }); } let transform = "translateX(" + x + "px) translateY(" + y + "px) translateZ(0px) scale(" + scale + ")"; if (rootRef.value) { rootRef.value.style.transform = transform; rootRef.value.style.webkitTransform = transform; _translateX.value = x; _translateY.value = y; _scale.value = scale; } } function _revise(source) { let limitXY = _getLimitXY(_translateX.value, _translateY.value); let x = limitXY.x; let y = limitXY.y; let outOfBounds = limitXY.outOfBounds; if (outOfBounds) { _animationTo(x, y, _scale.value, source); } return outOfBounds; } function _setX(val) { if (xMove.value) { if (val + _scaleOffset.x === _translateX.value) { return _translateX; } else { if (_SFA) { _SFA.cancel(); } _animationTo(val + _scaleOffset.x, ySync.value + _scaleOffset.y, _scale.value); } } return val; } function _setY(val) { if (yMove.value) { if (val + _scaleOffset.y === _translateY.value) { return _translateY; } else { if (_SFA) { _SFA.cancel(); } _animationTo(xSync.value + _scaleOffset.x, val + _scaleOffset.y, _scale.value); } } return val; } return { FAandSFACancel, _getLimitXY, _animationTo, _setTransform, _revise, dampingNumber, xMove, yMove, xSync, ySync, _STD }; } function useMovableViewInit(props2, rootRef, trigger, _scale, _oldScale, _isScaling, _translateX, _translateY, _SFA, _FA) { const scaleMinNumber = computed(() => { let val = Number(props2.scaleMin); return isNaN(val) ? 0.5 : val; }); const scaleMaxNumber = computed(() => { let val = Number(props2.scaleMax); return isNaN(val) ? 10 : val; }); const scaleValueSync = ref(Number(props2.scaleValue) || 1); watch(scaleValueSync, (val) => { _setScaleValue(val); }); watch(scaleMinNumber, () => { _setScaleMinOrMax(); }); watch(scaleMaxNumber, () => { _setScaleMinOrMax(); }); watch(() => props2.scaleValue, (val) => { scaleValueSync.value = Number(val) || 0; }); const { _updateBoundary, _updateOffset, _updateWH, _scaleOffset, minX, minY, maxX, maxY } = useMovableViewLayout(rootRef, _scale, _adjustScale); const { FAandSFACancel, _getLimitXY, _animationTo, _setTransform, _revise, dampingNumber, xMove, yMove, xSync, ySync, _STD } = useMovableViewTransform(rootRef, props2, _scaleOffset, _scale, maxX, maxY, minX, minY, _translateX, _translateY, _SFA, _FA, _adjustScale, trigger); function _updateScale(scale, animat) { if (props2.scale) { scale = _adjustScale(scale); _updateWH(scale); _updateBoundary(); const limitXY = _getLimitXY(_translateX.value, _translateY.value); const x = limitXY.x; const y = limitXY.y; if (animat) { _animationTo(x, y, scale, "", true, true); } else { _requestAnimationFrame(function() { _setTransform(x, y, scale, "", true, true); }); } } } function _beginScale() { _isScaling.value = true; } function _updateOldScale(scale) { _oldScale.value = scale; } function _adjustScale(scale) { scale = Math.max(0.5, scaleMinNumber.value, scale); scale = Math.min(10, scaleMaxNumber.value, scale); return scale; } function _setScaleMinOrMax() { if (!props2.scale) { return false; } _updateScale(_scale.value, true); _updateOldScale(_scale.value); } function _setScaleValue(scale) { if (!props2.scale) { return false; } scale = _adjustScale(scale); _updateScale(scale, true); _updateOldScale(scale); return scale; } function _endScale() { _isScaling.value = false; _updateOldScale(_scale.value); } function _setScale(scale) { if (scale) { scale = _oldScale.value * scale; _beginScale(); _updateScale(scale); } } return { // scale _updateOldScale, _endScale, _setScale, scaleValueSync, // layout _updateBoundary, _updateOffset, _updateWH, _scaleOffset, minX, minY, maxX, maxY, // transform FAandSFACancel, _getLimitXY, _animationTo, _setTransform, _revise, dampingNumber, xMove, yMove, xSync, ySync, _STD }; } function useMovableViewState(props2, trigger, rootRef) { const _isMounted = inject("_isMounted", ref(false)); const addMovableViewContext = inject("addMovableViewContext", () => { }); const removeMovableViewContext = inject("removeMovableViewContext", () => { }); let _scale = ref(1); let _oldScale = ref(1); let _isScaling = ref(false); let _translateX = ref(0); let _translateY = ref(0); let _SFA = null; let _FA = null; let _isTouching = false; let __baseX; let __baseY; let _checkCanMove = null; let _firstMoveDirection = null; const _declineX = new Decline(); const _declineY = new Decline(); const __touchInfo = { historyX: [0, 0], historyY: [0, 0], historyT: [0, 0] }; const frictionNumber = computed(() => { let val = Number(props2.friction); return isNaN(val) || val <= 0 ? 2 : val; }); const _friction = new Friction$1(1, frictionNumber.value); watch(() => props2.disabled, () => { __handleTouchStart(); }); const { // scale _updateOldScale, _endScale, _setScale, scaleValueSync, // layout _updateBoundary, _updateOffset, _updateWH, _scaleOffset, minX, minY, maxX, maxY, // transform FAandSFACancel, _getLimitXY, _setTransform, _revise, dampingNumber, xMove, yMove, xSync, ySync, _STD } = useMovableViewInit(props2, rootRef, trigger, _scale, _oldScale, _isScaling, _translateX, _translateY, _SFA, _FA); function __handleTouchStart() { if (!_isScaling.value) { if (!props2.disabled) { FAandSFACancel(); __touchInfo.historyX = [0, 0]; __touchInfo.historyY = [0, 0]; __touchInfo.historyT = [0, 0]; if (xMove.value) { __baseX = _translateX.value; } if (yMove.value) { __baseY = _translateY.value; } rootRef.value.style.willChange = "transform"; _checkCanMove = null; _firstMoveDirection = null; _isTouching = true; } } } function __handleTouchMove(event) { if (!_isScaling.value && !props2.disabled && _isTouching) { let x = _translateX.value; let y = _translateY.value; if (_firstMoveDirection === null) { _firstMoveDirection = Math.abs(event.detail.dx / event.detail.dy) > 1 ? "htouchmove" : "vtouchmove"; } if (xMove.value) { x = event.detail.dx + __baseX; __touchInfo.historyX.shift(); __touchInfo.historyX.push(x); if (!yMove.value && _checkCanMove === null) { _checkCanMove = Math.abs(event.detail.dx / event.detail.dy) < 1; } } if (yMove.value) { y = event.detail.dy + __baseY; __touchInfo.historyY.shift(); __touchInfo.historyY.push(y); if (!xMove.value && _checkCanMove === null) { _checkCanMove = Math.abs(event.detail.dy / event.detail.dx) < 1; } } __touchInfo.historyT.shift(); __touchInfo.historyT.push(event.detail.timeStamp); if (!_checkCanMove) { event.preventDefault(); let source = "touch"; if (x < minX.value) { if (props2.outOfBounds) { source = "touch-out-of-bounds"; x = minX.value - _declineX.x(minX.value - x); } else { x = minX.value; } } else if (x > maxX.value) { if (props2.outOfBounds) { source = "touch-out-of-bounds"; x = maxX.value + _declineX.x(x - maxX.value); } else { x = maxX.value; } } if (y < minY.value) { if (props2.outOfBounds) { source = "touch-out-of-bounds"; y = minY.value - _declineY.x(minY.value - y); } else { y = minY.value; } } else { if (y > maxY.value) { if (props2.outOfBounds) { source = "touch-out-of-bounds"; y = maxY.value + _declineY.x(y - maxY.value); } else { y = maxY.value; } } } _requestAnimationFrame(function() { _setTransform(x, y, _scale.value, source); }); } } } function __handleTouchEnd() { if (!_isScaling.value && !props2.disabled && _isTouching) { rootRef.value.style.willChange = "auto"; _isTouching = false; if (!_checkCanMove && !_revise("out-of-bounds") && props2.inertia) { const xv = 1e3 * (__touchInfo.historyX[1] - __touchInfo.historyX[0]) / (__touchInfo.historyT[1] - __touchInfo.historyT[0]); const yv = 1e3 * (__touchInfo.historyY[1] - __touchInfo.historyY[0]) / (__touchInfo.historyT[1] - __touchInfo.historyT[0]); const __translateX = _translateX.value; const __translateY = _translateY.value; _friction.setV(xv, yv); _friction.setS(__translateX, __translateY); const x0 = _friction.delta().x; const y0 = _friction.delta().y; let x = x0 + __translateX; let y = y0 + __translateY; if (x < minX.value) { x = minX.value; y = __translateY + (minX.value - __translateX) * y0 / x0; } else { if (x > maxX.value) { x = maxX.value; y = __translateY + (maxX.value - __translateX) * y0 / x0; } } if (y < minY.value) { y = minY.value; x = __translateX + (minY.value - __translateY) * x0 / y0; } else { if (y > maxY.value) { y = maxY.value; x = __translateX + (maxY.value - __translateY) * x0 / y0; } } _friction.setEnd(x, y); _FA = g(_friction, function() { let t2 = _friction.s(); let x2 = t2.x; let y2 = t2.y; _setTransform(x2, y2, _scale.value, "friction"); }, function() { _FA.cancel(); }); } } if (!props2.outOfBounds && !props2.inertia) { FAandSFACancel(); } } function setParent() { if (!_isMounted.value) { return; } FAandSFACancel(); let scale = props2.scale ? scaleValueSync.value : 1; _updateOffset(); _updateWH(scale); _updateBoundary(); let limitXY = _getLimitXY(xSync.value + _scaleOffset.x, ySync.value + _scaleOffset.y); let x = limitXY.x; let y = limitXY.y; _setTransform(x, y, scale, "", true); _updateOldScale(scale); } onMounted(() => { useTouchtrack(rootRef.value, (event) => { switch (event.detail.state) { case "start": __handleTouchStart(); break; case "move": __handleTouchMove(event); break; case "end": __handleTouchEnd(); } }); setParent(); _friction.reconfigure(1, frictionNumber.value); _STD.reconfigure(1, 9 * Math.pow(dampingNumber.value, 2) / 40, dampingNumber.value); rootRef.value.style.transformOrigin = "center"; const context = { rootRef, setParent, _endScale, _setScale }; addMovableViewContext(context); onUnmounted(() => { removeMovableViewContext(context); }); }); onUnmounted(() => { FAandSFACancel(); }); return { setParent }; } const OPEN_TYPES = [ "navigate", "redirect", "switchTab", "reLaunch", "navigateBack" ]; const ANIMATION_IN = [ "slide-in-right", "slide-in-left", "slide-in-top", "slide-in-bottom", "fade-in", "zoom-out", "zoom-fade-out", "pop-in", "none" ]; const ANIMATION_OUT = [ "slide-out-right", "slide-out-left", "slide-out-top", "slide-out-bottom", "fade-out", "zoom-in", "zoom-fade-in", "pop-out", "none" ]; const navigatorProps = { hoverClass: { type: String, default: "navigator-hover" }, url: { type: String, default: "" }, openType: { type: String, default: "navigate", validator(value) { return Boolean(~OPEN_TYPES.indexOf(value)); } }, delta: { type: Number, default: 1 }, hoverStartTime: { type: [Number, String], default: 50 }, hoverStayTime: { type: [Number, String], default: 600 }, exists: { type: String, default: "" }, hoverStopPropagation: { type: Boolean, default: false }, animationType: { type: String, default: "", validator(value) { return !value || ANIMATION_IN.concat(ANIMATION_OUT).includes(value); } }, animationDuration: { type: [String, Number], default: 300 } }; function createNavigatorOnClick(props2) { return () => { if (props2.openType !== "navigateBack" && !props2.url) { console.error( " should have url attribute when using navigateTo, redirectTo, reLaunch or switchTab" ); return; } const animationDuration = parseInt(props2.animationDuration); switch (props2.openType) { case "navigate": uni.navigateTo({ url: props2.url, animationType: props2.animationType || "pop-in", animationDuration }); break; case "redirect": uni.redirectTo({ url: props2.url, // @ts-ignore exists: props2.exists }); break; case "switchTab": uni.switchTab({ url: props2.url }); break; case "reLaunch": uni.reLaunch({ url: props2.url }); break; case "navigateBack": uni.navigateBack({ delta: props2.delta, animationType: props2.animationType || "pop-out", animationDuration }); break; } }; } const index$p = /* @__PURE__ */ defineBuiltInComponent({ name: "Navigator", inheritAttrs: false, compatConfig: { MODE: 3 }, props: extend({}, navigatorProps, { renderLink: { type: Boolean, default: true } }), setup(props2, { slots }) { const vm = getCurrentInstance(); const __scopeId = vm && vm.vnode.scopeId || ""; const { hovering, binding } = useHover(props2); const onClick = createNavigatorOnClick(props2); return () => { const { hoverClass, url } = props2; const hasHoverClass = props2.hoverClass && props2.hoverClass !== "none"; const navigatorTsx = createVNode("uni-navigator", mergeProps({ "class": hasHoverClass && hovering.value ? hoverClass : "" }, hasHoverClass && binding, vm ? vm.attrs : {}, { [__scopeId]: "" }, { "onClick": onClick }), [slots.default && slots.default()], 16, ["onClick"]); return props2.renderLink ? createVNode("a", { "class": "navigator-wrap", "href": url, "onClick": onEventPrevent, "onMousedown": onEventPrevent }, [navigatorTsx], 40, ["href", "onClick", "onMousedown"]) : navigatorTsx; }; } }); const pickerViewProps = { value: { type: Array, default() { return []; }, validator: function(val) { return isArray(val) && val.filter((val2) => typeof val2 === "number").length === val.length; } }, indicatorStyle: { type: String, default: "" }, indicatorClass: { type: String, default: "" }, maskStyle: { type: String, default: "" }, maskClass: { type: String, default: "" } }; function useState$4(props2) { const value = reactive([...props2.value]); const state2 = reactive({ value, height: 34 }); watch(() => props2.value, (val, oldVal) => { { state2.value.length = val.length; val.forEach((val2, index2) => { if (val2 !== state2.value[index2]) { state2.value.splice(index2, 1, val2); } }); } }); return state2; } const PickerView = /* @__PURE__ */ defineBuiltInComponent({ name: "PickerView", props: pickerViewProps, emits: ["change", "pickstart", "pickend", "update:value"], setup(props2, { slots, emit: emit2 }) { const rootRef = ref(null); const wrapperRef = ref(null); const trigger = useCustomEvent(rootRef, emit2); const state2 = useState$4(props2); const resizeSensorRef = ref(null); const onMountedCallback = () => { const resizeSensor = resizeSensorRef.value; resizeSensor && (state2.height = resizeSensor.offsetHeight); }; { onMounted(onMountedCallback); } let ColumnsPreRef = ref([]); let columnsRef = ref([]); function getItemIndex(vnode) { let columnVNodes = columnsRef.value; { columnVNodes = columnVNodes.filter((vnode2) => vnode2.type !== Comment); } let index2 = columnVNodes.indexOf(vnode); return index2 !== -1 ? index2 : ColumnsPreRef.value.indexOf(vnode); } const getPickerViewColumn = function(columnInstance) { const ref2 = computed({ get() { const index2 = getItemIndex(columnInstance.vnode); return state2.value[index2] || 0; }, set(current) { const index2 = getItemIndex(columnInstance.vnode); if (index2 < 0) { return; } const oldCurrent = state2.value[index2]; if (oldCurrent !== current) { state2.value[index2] = current; const value = state2.value.map((val) => val); emit2("update:value", value); trigger("change", {}, { value }); } } }); return ref2; }; provide("getPickerViewColumn", getPickerViewColumn); provide("pickerViewProps", props2); provide("pickerViewState", state2); return () => { const defaultSlots = slots.default && slots.default(); { const vnode = flatVNode(defaultSlots); ColumnsPreRef.value = vnode; nextTick(() => { columnsRef.value = vnode; }); } return createVNode("uni-picker-view", { "ref": rootRef }, [createVNode(ResizeSensor, { "ref": resizeSensorRef, "onResize": ({ height }) => state2.height = height }, null, 8, ["onResize"]), createVNode("div", { "ref": wrapperRef, "class": "uni-picker-view-wrapper" }, [defaultSlots], 512)], 512); }; } }); class Friction { constructor(drag) { this._drag = drag; this._dragLog = Math.log(drag); this._x = 0; this._v = 0; this._startTime = 0; } set(x, v2) { this._x = x; this._v = v2; this._startTime = (/* @__PURE__ */ new Date()).getTime(); } setVelocityByEnd(e2) { this._v = (e2 - this._x) * this._dragLog / (Math.pow(this._drag, 100) - 1); } x(e2) { if (e2 === void 0) { e2 = ((/* @__PURE__ */ new Date()).getTime() - this._startTime) / 1e3; } const t2 = e2 === this._dt && this._powDragDt ? this._powDragDt : this._powDragDt = Math.pow(this._drag, e2); this._dt = e2; return this._x + this._v * t2 / this._dragLog - this._v / this._dragLog; } dx(e2) { if (e2 === void 0) { e2 = ((/* @__PURE__ */ new Date()).getTime() - this._startTime) / 1e3; } const t2 = e2 === this._dt && this._powDragDt ? this._powDragDt : this._powDragDt = Math.pow(this._drag, e2); this._dt = e2; return this._v * t2; } done() { return Math.abs(this.dx()) < 3; } reconfigure(e2) { const t2 = this.x(); const n = this.dx(); this._drag = e2; this._dragLog = Math.log(e2); this.set(t2, n); } configuration() { const e2 = this; return [ { label: "Friction", read: function() { return e2._drag; }, write: function(t2) { e2.reconfigure(t2); }, min: 1e-3, max: 0.1, step: 1e-3 } ]; } } function o(e2, t2, n) { return e2 > t2 - n && e2 < t2 + n; } function a(e2, t2) { return o(e2, 0, t2); } class Spring { constructor(m, k, c) { this._m = m; this._k = k; this._c = c; this._solution = null; this._endPosition = 0; this._startTime = 0; } _solve(e2, t2) { const n = this._c; const i = this._m; const r = this._k; const o2 = n * n - 4 * i * r; if (o2 === 0) { const a3 = -n / (2 * i); const s2 = e2; const l2 = t2 / (a3 * e2); return { x: function(e22) { return (s2 + l2 * e22) * Math.pow(Math.E, a3 * e22); }, dx: function(e22) { const t22 = Math.pow(Math.E, a3 * e22); return a3 * (s2 + l2 * e22) * t22 + l2 * t22; } }; } if (o2 > 0) { const c = (-n - Math.sqrt(o2)) / (2 * i); const u = (-n + Math.sqrt(o2)) / (2 * i); const l2 = (t2 - c * e2) / (u - c); const s2 = e2 - l2; return { x: function(e22) { let t22; let n2; if (e22 === this._t) { t22 = this._powER1T; n2 = this._powER2T; } this._t = e22; if (!t22) { t22 = this._powER1T = Math.pow(Math.E, c * e22); } if (!n2) { n2 = this._powER2T = Math.pow(Math.E, u * e22); } return s2 * t22 + l2 * n2; }, dx: function(e22) { let t22; let n2; if (e22 === this._t) { t22 = this._powER1T; n2 = this._powER2T; } this._t = e22; if (!t22) { t22 = this._powER1T = Math.pow(Math.E, c * e22); } if (!n2) { n2 = this._powER2T = Math.pow(Math.E, u * e22); } return s2 * c * t22 + l2 * u * n2; } }; } const d = Math.sqrt(4 * i * r - n * n) / (2 * i); const a2 = -n / 2 * i; const s = e2; const l = (t2 - a2 * e2) / d; return { x: function(e22) { return Math.pow(Math.E, a2 * e22) * (s * Math.cos(d * e22) + l * Math.sin(d * e22)); }, dx: function(e22) { const t22 = Math.pow(Math.E, a2 * e22); const n2 = Math.cos(d * e22); const i2 = Math.sin(d * e22); return t22 * (l * d * n2 - s * d * i2) + a2 * t22 * (l * i2 + s * n2); } }; } x(e2) { if (e2 === void 0) { e2 = ((/* @__PURE__ */ new Date()).getTime() - this._startTime) / 1e3; } return this._solution ? this._endPosition + this._solution.x(e2) : 0; } dx(e2) { if (e2 === void 0) { e2 = ((/* @__PURE__ */ new Date()).getTime() - this._startTime) / 1e3; } return this._solution ? this._solution.dx(e2) : 0; } setEnd(e2, t2, n) { if (!n) { n = (/* @__PURE__ */ new Date()).getTime(); } if (e2 !== this._endPosition || !a(t2, 0.4)) { t2 = t2 || 0; let i = this._endPosition; if (this._solution) { if (a(t2, 0.4)) { t2 = this._solution.dx((n - this._startTime) / 1e3); } i = this._solution.x((n - this._startTime) / 1e3); if (a(t2, 0.4)) { t2 = 0; } if (a(i, 0.4)) { i = 0; } i += this._endPosition; } if (!(this._solution && a(i - e2, 0.4) && a(t2, 0.4))) { this._endPosition = e2; this._solution = this._solve(i - this._endPosition, t2); this._startTime = n; } } } snap(e2) { this._startTime = (/* @__PURE__ */ new Date()).getTime(); this._endPosition = e2; this._solution = { x: function() { return 0; }, dx: function() { return 0; } }; } done(e2) { if (!e2) { e2 = (/* @__PURE__ */ new Date()).getTime(); } return o(this.x(), this._endPosition, 0.4) && a(this.dx(), 0.4); } reconfigure(e2, t2, n) { this._m = e2; this._k = t2; this._c = n; if (!this.done()) { this._solution = this._solve(this.x() - this._endPosition, this.dx()); this._startTime = (/* @__PURE__ */ new Date()).getTime(); } } springConstant() { return this._k; } damping() { return this._c; } configuration() { function e2(e22, t22) { e22.reconfigure(1, t22, e22.damping()); } function t2(e22, t22) { e22.reconfigure(1, e22.springConstant(), t22); } return [ { label: "Spring Constant", read: this.springConstant.bind(this), write: e2.bind(this, this), min: 100, max: 1e3 }, { label: "Damping", read: this.damping.bind(this), write: t2.bind(this, this), min: 1, max: 500 } ]; } } class Scroll { constructor(extent, friction, spring) { this._extent = extent; this._friction = friction || new Friction(0.01); this._spring = spring || new Spring(1, 90, 20); this._startTime = 0; this._springing = false; this._springOffset = 0; } snap(e2, t2) { this._springOffset = 0; this._springing = true; this._spring.snap(e2); this._spring.setEnd(t2); } set(e2, t2) { this._friction.set(e2, t2); if (e2 > 0 && t2 >= 0) { this._springOffset = 0; this._springing = true; this._spring.snap(e2); this._spring.setEnd(0); } else { if (e2 < -this._extent && t2 <= 0) { this._springOffset = 0; this._springing = true; this._spring.snap(e2); this._spring.setEnd(-this._extent); } else { this._springing = false; } } this._startTime = (/* @__PURE__ */ new Date()).getTime(); } x(e2) { if (!this._startTime) { return 0; } if (!e2) { e2 = ((/* @__PURE__ */ new Date()).getTime() - this._startTime) / 1e3; } if (this._springing) { return this._spring.x() + this._springOffset; } let t2 = this._friction.x(e2); let n = this.dx(e2); if (t2 > 0 && n >= 0 || t2 < -this._extent && n <= 0) { this._springing = true; this._spring.setEnd(0, n); if (t2 < -this._extent) { this._springOffset = -this._extent; } else { this._springOffset = 0; } t2 = this._spring.x() + this._springOffset; } return t2; } dx(e2) { let t2; if (this._lastTime === e2) { t2 = this._lastDx; } else { t2 = this._springing ? this._spring.dx(e2) : this._friction.dx(e2); } this._lastTime = e2; this._lastDx = t2; return t2; } done() { return this._springing ? this._spring.done() : this._friction.done(); } setVelocityByEnd(e2) { this._friction.setVelocityByEnd(e2); } configuration() { const e2 = this._friction.configuration(); e2.push.apply(e2, this._spring.configuration()); return e2; } } function createAnimation(scroll, onScroll, onEnd) { const state2 = { id: 0, cancelled: false }; function startAnimation2(state22, scroll2, onScroll2, onEnd2) { if (!state22 || !state22.cancelled) { onScroll2(scroll2); const isDone = scroll2.done(); if (!isDone) { if (!state22.cancelled) { state22.id = requestAnimationFrame( startAnimation2.bind(null, state22, scroll2, onScroll2, onEnd2) ); } } if (isDone && onEnd2) { onEnd2(scroll2); } } } function cancel(state22) { if (state22 && state22.id) { cancelAnimationFrame(state22.id); } if (state22) { state22.cancelled = true; } } startAnimation2(state2, scroll, onScroll, onEnd); return { cancel: cancel.bind(null, state2), model: scroll }; } class Scroller { constructor(element, options) { options = options || {}; this._element = element; this._options = options; this._enableSnap = options.enableSnap || false; this._itemSize = options.itemSize || 0; this._enableX = options.enableX || false; this._enableY = options.enableY || false; this._shouldDispatchScrollEvent = !!options.onScroll; if (this._enableX) { this._extent = (options.scrollWidth || this._element.offsetWidth) - this._element.parentElement.offsetWidth; this._scrollWidth = options.scrollWidth; } else { this._extent = (options.scrollHeight || this._element.offsetHeight) - this._element.parentElement.offsetHeight; this._scrollHeight = options.scrollHeight; } this._position = 0; this._scroll = new Scroll(this._extent, options.friction, options.spring); this._onTransitionEnd = this.onTransitionEnd.bind(this); this.updatePosition(); } onTouchStart() { this._startPosition = this._position; this._lastChangePos = this._startPosition; if (this._startPosition > 0) { this._startPosition /= 0.5; } else { if (this._startPosition < -this._extent) { this._startPosition = (this._startPosition + this._extent) / 0.5 - this._extent; } } if (this._animation) { this._animation.cancel(); this._scrolling = false; } this.updatePosition(); } onTouchMove(x, y) { let startPosition = this._startPosition; if (this._enableX) { startPosition += x; } else if (this._enableY) { startPosition += y; } if (startPosition > 0) { startPosition *= 0.5; } else if (startPosition < -this._extent) { startPosition = 0.5 * (startPosition + this._extent) - this._extent; } this._position = startPosition; this.updatePosition(); this.dispatchScroll(); } onTouchEnd(x, y, o2) { if (this._enableSnap && this._position > -this._extent && this._position < 0) { if (this._enableY && (Math.abs(y) < this._itemSize && Math.abs(o2.y) < 300 || Math.abs(o2.y) < 150)) { this.snap(); return; } if (this._enableX && (Math.abs(x) < this._itemSize && Math.abs(o2.x) < 300 || Math.abs(o2.x) < 150)) { this.snap(); return; } } if (this._enableX) { this._scroll.set(this._position, o2.x); } else if (this._enableY) { this._scroll.set(this._position, o2.y); } let c; if (this._enableSnap) { const s = this._scroll._friction.x(100); const l = s % this._itemSize; c = Math.abs(l) > this._itemSize / 2 ? s - (this._itemSize - Math.abs(l)) : s - l; if (c <= 0 && c >= -this._extent) { this._scroll.setVelocityByEnd(c); } } this._lastTime = Date.now(); this._lastDelay = 0; this._scrolling = true; this._lastChangePos = this._position; this._lastIdx = Math.floor(Math.abs(this._position / this._itemSize)); this._animation = createAnimation( this._scroll, () => { const e2 = Date.now(); const i = (e2 - this._scroll._startTime) / 1e3; const r = this._scroll.x(i); this._position = r; this.updatePosition(); const o22 = this._scroll.dx(i); if (this._shouldDispatchScrollEvent && e2 - this._lastTime > this._lastDelay) { this.dispatchScroll(); this._lastDelay = Math.abs(2e3 / o22); this._lastTime = e2; } }, () => { if (this._enableSnap) { if (c <= 0 && c >= -this._extent) { this._position = c; this.updatePosition(); } if (isFunction(this._options.onSnap)) { this._options.onSnap( Math.floor(Math.abs(this._position) / this._itemSize) ); } } if (this._shouldDispatchScrollEvent) { this.dispatchScroll(); } this._scrolling = false; } ); } onTransitionEnd() { this._element.style.webkitTransition = ""; this._element.style.transition = ""; this._element.removeEventListener("transitionend", this._onTransitionEnd); if (this._snapping) { this._snapping = false; } this.dispatchScroll(); } snap() { const itemSize = this._itemSize; const position = this._position % itemSize; const i = Math.abs(position) > this._itemSize / 2 ? this._position - (itemSize - Math.abs(position)) : this._position - position; if (this._position !== i) { this._snapping = true; this.scrollTo(-i); if (isFunction(this._options.onSnap)) { this._options.onSnap( Math.floor(Math.abs(this._position) / this._itemSize) ); } } } scrollTo(position, time) { if (this._animation) { this._animation.cancel(); this._scrolling = false; } if (typeof position === "number") { this._position = -position; } if (this._position < -this._extent) { this._position = -this._extent; } else { if (this._position > 0) { this._position = 0; } } const transition = "transform " + (time || 0.2) + "s ease-out"; this._element.style.webkitTransition = "-webkit-" + transition; this._element.style.transition = transition; this.updatePosition(); this._element.addEventListener("transitionend", this._onTransitionEnd); } dispatchScroll() { if (isFunction(this._options.onScroll) && Math.round(Number(this._lastPos)) !== Math.round(this._position)) { this._lastPos = this._position; const event = { target: { scrollLeft: this._enableX ? -this._position : 0, scrollTop: this._enableY ? -this._position : 0, scrollHeight: this._scrollHeight || this._element.offsetHeight, scrollWidth: this._scrollWidth || this._element.offsetWidth, offsetHeight: this._element.parentElement.offsetHeight, offsetWidth: this._element.parentElement.offsetWidth } }; this._options.onScroll(event); } } update(height, scrollHeight, itemSize) { let extent = 0; const position = this._position; if (this._enableX) { extent = this._element.childNodes.length ? (scrollHeight || this._element.offsetWidth) - this._element.parentElement.offsetWidth : 0; this._scrollWidth = scrollHeight; } else { extent = this._element.childNodes.length ? (scrollHeight || this._element.offsetHeight) - this._element.parentElement.offsetHeight : 0; this._scrollHeight = scrollHeight; } if (typeof height === "number") { this._position = -height; } if (this._position < -extent) { this._position = -extent; } else { if (this._position > 0) { this._position = 0; } } this._itemSize = itemSize || this._itemSize; this.updatePosition(); if (position !== this._position) { this.dispatchScroll(); if (isFunction(this._options.onSnap)) { this._options.onSnap( Math.floor(Math.abs(this._position) / this._itemSize) ); } } this._extent = extent; this._scroll._extent = extent; } updatePosition() { let transform = ""; if (this._enableX) { transform = "translateX(" + this._position + "px) translateZ(0)"; } else { if (this._enableY) { transform = "translateY(" + this._position + "px) translateZ(0)"; } } this._element.style.webkitTransform = transform; this._element.style.transform = transform; } isScrolling() { return this._scrolling || this._snapping; } } function useScroller(element, options) { const touchInfo = { trackingID: -1, maxDy: 0, maxDx: 0 }; const scroller = new Scroller(element, options); function findDelta(event) { const touchtrackEvent = event; const mouseEvent = event; return touchtrackEvent.detail.state === "move" || touchtrackEvent.detail.state === "end" ? { x: touchtrackEvent.detail.dx, y: touchtrackEvent.detail.dy } : { x: mouseEvent.screenX - touchInfo.x, y: mouseEvent.screenY - touchInfo.y }; } function handleTouchStart(event) { const touchtrackEvent = event; const mouseEvent = event; if (touchtrackEvent.detail.state === "start") { touchInfo.trackingID = "touch"; touchInfo.x = touchtrackEvent.detail.x; touchInfo.y = touchtrackEvent.detail.y; } else { touchInfo.trackingID = "mouse"; touchInfo.x = mouseEvent.screenX; touchInfo.y = mouseEvent.screenY; } touchInfo.maxDx = 0; touchInfo.maxDy = 0; touchInfo.historyX = [0]; touchInfo.historyY = [0]; touchInfo.historyTime = [ touchtrackEvent.detail.timeStamp || mouseEvent.timeStamp ]; touchInfo.listener = scroller; if (scroller.onTouchStart) { scroller.onTouchStart(); } if (typeof event.cancelable !== "boolean" || event.cancelable) event.preventDefault(); } function handleTouchMove(event) { const touchtrackEvent = event; const mouseEvent = event; if (touchInfo.trackingID !== -1) { if (typeof event.cancelable !== "boolean" || event.cancelable) event.preventDefault(); const delta = findDelta(event); if (delta) { for (touchInfo.maxDy = Math.max(touchInfo.maxDy, Math.abs(delta.y)), touchInfo.maxDx = Math.max(touchInfo.maxDx, Math.abs(delta.x)), touchInfo.historyX.push(delta.x), touchInfo.historyY.push(delta.y), touchInfo.historyTime.push( touchtrackEvent.detail.timeStamp || mouseEvent.timeStamp ); touchInfo.historyTime.length > 10; ) { touchInfo.historyTime.shift(); touchInfo.historyX.shift(); touchInfo.historyY.shift(); } if (touchInfo.listener && touchInfo.listener.onTouchMove) { touchInfo.listener.onTouchMove(delta.x, delta.y); } } } } function handleTouchEnd(event) { if (touchInfo.trackingID !== -1) { event.preventDefault(); const delta = findDelta(event); if (delta) { const listener2 = touchInfo.listener; touchInfo.trackingID = -1; touchInfo.listener = null; const length = touchInfo.historyTime.length; const o2 = { x: 0, y: 0 }; if (length > 2) { for (let i = touchInfo.historyTime.length - 1, time1 = touchInfo.historyTime[i], x = touchInfo.historyX[i], y = touchInfo.historyY[i]; i > 0; ) { i--; const time0 = touchInfo.historyTime[i]; const time = time1 - time0; if (time > 30 && time < 50) { o2.x = (x - touchInfo.historyX[i]) / (time / 1e3); o2.y = (y - touchInfo.historyY[i]) / (time / 1e3); break; } } } touchInfo.historyTime = []; touchInfo.historyX = []; touchInfo.historyY = []; if (listener2 && listener2.onTouchEnd) { listener2.onTouchEnd(delta.x, delta.y, o2); } } } } return { scroller, handleTouchStart, handleTouchMove, handleTouchEnd }; } let scopedIndex = 0; function useScopedClass(indicatorHeightRef) { const className = `uni-picker-view-content-${scopedIndex++}`; function updateStyle2() { const style = document.createElement("style"); style.innerText = `.uni-picker-view-content.${className}>*{height: ${indicatorHeightRef.value}px;overflow: hidden;}`; document.head.appendChild(style); } watch(() => indicatorHeightRef.value, updateStyle2); return className; } function useCustomClick(dom) { const MAX_MOVE = 20; let x = 0; let y = 0; dom.addEventListener("touchstart", (event) => { const info = event.changedTouches[0]; x = info.clientX; y = info.clientY; }); dom.addEventListener("touchend", (event) => { const info = event.changedTouches[0]; if (Math.abs(info.clientX - x) < MAX_MOVE && Math.abs(info.clientY - y) < MAX_MOVE) { const options = { bubbles: true, cancelable: true, target: event.target, currentTarget: event.currentTarget }; const customClick = new CustomEvent("click", options); const props2 = ["screenX", "screenY", "clientX", "clientY", "pageX", "pageY"]; props2.forEach((key) => { customClick[key] = info[key]; }); event.target.dispatchEvent(customClick); } }); } const PickerViewColumn = /* @__PURE__ */ defineBuiltInComponent({ name: "PickerViewColumn", setup(props2, { slots, emit: emit2 }) { const rootRef = ref(null); const contentRef = ref(null); const getPickerViewColumn = inject("getPickerViewColumn"); const instance2 = getCurrentInstance(); const currentRef = getPickerViewColumn ? getPickerViewColumn(instance2) : ref(0); const pickerViewProps2 = inject("pickerViewProps"); const pickerViewState = inject("pickerViewState"); const indicatorHeight = ref(34); const resizeSensorRef = ref(null); const initIndicatorHeight = () => { const resizeSensor = resizeSensorRef.value; indicatorHeight.value = resizeSensor.offsetHeight; }; { onMounted(initIndicatorHeight); } const maskSize = computed(() => (pickerViewState.height - indicatorHeight.value) / 2); const { state: scopedAttrsState } = useScopedAttrs(); const className = useScopedClass(indicatorHeight); let scroller; const state2 = reactive({ current: currentRef.value, length: 0 }); let updatesScrollerRequest; function updatesScroller() { if (scroller && !updatesScrollerRequest) { updatesScrollerRequest = true; nextTick(() => { updatesScrollerRequest = false; let current = Math.min(state2.current, state2.length - 1); current = Math.max(current, 0); scroller.update(current * indicatorHeight.value, void 0, indicatorHeight.value); }); } } watch(() => currentRef.value, (current) => { if (current !== state2.current) { state2.current = current; updatesScroller(); } }); watch(() => state2.current, (current) => currentRef.value = current); watch([() => indicatorHeight.value, () => state2.length, () => pickerViewState.height], updatesScroller); let oldDeltaY = 0; function handleWheel(event) { const deltaY = oldDeltaY + event.deltaY; if (Math.abs(deltaY) > 10) { oldDeltaY = 0; let current = Math.min(state2.current + (deltaY < 0 ? -1 : 1), state2.length - 1); state2.current = current = Math.max(current, 0); scroller.scrollTo(current * indicatorHeight.value); } else { oldDeltaY = deltaY; } event.preventDefault(); } function handleTap({ clientY }) { const el = rootRef.value; if (!scroller.isScrolling()) { const rect = el.getBoundingClientRect(); const r = clientY - rect.top - pickerViewState.height / 2; const o2 = indicatorHeight.value / 2; if (!(Math.abs(r) <= o2)) { const a2 = Math.ceil((Math.abs(r) - o2) / indicatorHeight.value); const s = r < 0 ? -a2 : a2; let current = Math.min(state2.current + s, state2.length - 1); state2.current = current = Math.max(current, 0); scroller.scrollTo(current * indicatorHeight.value); } } } const initScroller = () => { const el = rootRef.value; const content = contentRef.value; const { scroller: scrollerOrigin, handleTouchStart, handleTouchMove, handleTouchEnd } = useScroller(content, { enableY: true, enableX: false, enableSnap: true, itemSize: indicatorHeight.value, friction: new Friction(1e-4), spring: new Spring(2, 90, 20), onSnap: (index2) => { if (!isNaN(index2) && index2 !== state2.current) { state2.current = index2; } } }); scroller = scrollerOrigin; useTouchtrack(el, (e2) => { switch (e2.detail.state) { case "start": handleTouchStart(e2); break; case "move": handleTouchMove(e2); e2.stopPropagation(); break; case "end": case "cancel": handleTouchEnd(e2); } }, true); useCustomClick(el); updatesScroller(); }; { onMounted(initScroller); } return () => { const defaultSlots = slots.default && slots.default(); { state2.length = flatVNode(defaultSlots).length; } const padding = `${maskSize.value}px 0`; return createVNode("uni-picker-view-column", { "ref": rootRef }, [createVNode("div", { "onWheel": handleWheel, "onClick": handleTap, "class": "uni-picker-view-group" }, [createVNode("div", mergeProps(scopedAttrsState.attrs, { "class": ["uni-picker-view-mask", pickerViewProps2.maskClass], "style": `background-size: 100% ${maskSize.value}px;${pickerViewProps2.maskStyle}` }), null, 16), createVNode("div", mergeProps(scopedAttrsState.attrs, { "class": ["uni-picker-view-indicator", pickerViewProps2.indicatorClass], "style": pickerViewProps2.indicatorStyle }), [createVNode(ResizeSensor, { "ref": resizeSensorRef, "onResize": ({ height }) => indicatorHeight.value = height }, null, 8, ["onResize"])], 16), createVNode("div", { "ref": contentRef, "class": ["uni-picker-view-content", className], "style": { padding } }, [defaultSlots], 6)], 40, ["onWheel", "onClick"])], 512); }; } }); const FONT_SIZE = 16; const PROGRESS_VALUES = { activeColor: PRIMARY_COLOR, backgroundColor: "#EBEBEB", activeMode: "backwards" }; const progressProps = { percent: { type: [Number, String], default: 0, validator(value) { return !isNaN(parseFloat(value)); } }, fontSize: { type: [String, Number], default: FONT_SIZE }, showInfo: { type: [Boolean, String], default: false }, strokeWidth: { type: [Number, String], default: 6, validator(value) { return !isNaN(parseFloat(value)); } }, color: { type: String, default: PROGRESS_VALUES.activeColor }, activeColor: { type: String, default: PROGRESS_VALUES.activeColor }, backgroundColor: { type: String, default: PROGRESS_VALUES.backgroundColor }, active: { type: [Boolean, String], default: false }, activeMode: { type: String, default: PROGRESS_VALUES.activeMode }, duration: { type: [Number, String], default: 30, validator(value) { return !isNaN(parseFloat(value)); } }, borderRadius: { type: [Number, String], default: 0 } }; const index$o = /* @__PURE__ */ defineBuiltInComponent({ name: "Progress", props: progressProps, setup(props2) { const state2 = useProgressState(props2); _activeAnimation(state2, props2); watch(() => state2.realPercent, (newValue, oldValue) => { state2.strokeTimer && clearInterval(state2.strokeTimer); state2.lastPercent = oldValue || 0; _activeAnimation(state2, props2); }); return () => { const { showInfo } = props2; const { outerBarStyle, innerBarStyle, currentPercent } = state2; return createVNode("uni-progress", { "class": "uni-progress" }, [createVNode("div", { "style": outerBarStyle, "class": "uni-progress-bar" }, [createVNode("div", { "style": innerBarStyle, "class": "uni-progress-inner-bar" }, null, 4)], 4), showInfo ? ( // {currentPercent}% 的写法会影响 SSR Hydration (tsx插件的问题) createVNode("p", { "class": "uni-progress-info" }, [currentPercent + "%"]) ) : ""]); }; } }); function useProgressState(props2) { const currentPercent = ref(0); const outerBarStyle = computed(() => `background-color: ${props2.backgroundColor}; height: ${props2.strokeWidth}px;`); const innerBarStyle = computed(() => { const backgroundColor = props2.color !== PROGRESS_VALUES.activeColor && props2.activeColor === PROGRESS_VALUES.activeColor ? props2.color : props2.activeColor; return `width: ${currentPercent.value}%;background-color: ${backgroundColor}`; }); const realPercent = computed(() => { let realValue = parseFloat(props2.percent); realValue < 0 && (realValue = 0); realValue > 100 && (realValue = 100); return realValue; }); const state2 = reactive({ outerBarStyle, innerBarStyle, realPercent, currentPercent, strokeTimer: 0, lastPercent: 0 }); return state2; } function _activeAnimation(state2, props2) { if (props2.active) { state2.currentPercent = props2.activeMode === PROGRESS_VALUES.activeMode ? 0 : state2.lastPercent; state2.strokeTimer = setInterval(() => { if (state2.currentPercent + 1 > state2.realPercent) { state2.currentPercent = state2.realPercent; state2.strokeTimer && clearInterval(state2.strokeTimer); } else { state2.currentPercent += 1; } }, parseFloat(props2.duration)); } else { state2.currentPercent = state2.realPercent; } } const uniRadioGroupKey = PolySymbol(process.env.NODE_ENV !== "production" ? "uniCheckGroup" : "ucg"); const props$p = { name: { type: String, default: "" } }; const index$n = /* @__PURE__ */ defineBuiltInComponent({ name: "RadioGroup", props: props$p, // emits: ['change'], setup(props2, { emit: emit2, slots }) { const rootRef = ref(null); const trigger = useCustomEvent(rootRef, emit2); useProvideRadioGroup(props2, trigger); return () => { return createVNode("uni-radio-group", { "ref": rootRef }, [slots.default && slots.default()], 512); }; } }); function useProvideRadioGroup(props2, trigger) { const fields2 = []; onMounted(() => { _resetRadioGroupValue(fields2.length - 1); }); const getFieldsValue = () => { var _a; return (_a = fields2.find((field) => field.value.radioChecked)) == null ? void 0 : _a.value.value; }; provide(uniRadioGroupKey, { addField(field) { fields2.push(field); }, removeField(field) { fields2.splice(fields2.indexOf(field), 1); }, radioChange($event, field) { const index2 = fields2.indexOf(field); _resetRadioGroupValue(index2, true); trigger("change", $event, { value: getFieldsValue() }); } }); const uniForm = inject(uniFormKey, false); const formField = { submit: () => { let data = ["", null]; if (props2.name !== "") { data[0] = props2.name; data[1] = getFieldsValue(); } return data; } }; if (uniForm) { uniForm.addField(formField); onBeforeUnmount(() => { uniForm.removeField(formField); }); } function setFieldChecked(field, radioChecked) { field.value = { radioChecked, value: field.value.value }; } function _resetRadioGroupValue(key, change) { fields2.forEach((value, index2) => { if (index2 === key) { return; } if (change) { setFieldChecked(fields2[index2], false); } else { fields2.forEach((v2, i) => { if (index2 >= i) { return; } if (fields2[i].value.radioChecked) { setFieldChecked(fields2[index2], false); } }); } }); } return fields2; } const props$o = { checked: { type: [Boolean, String], default: false }, id: { type: String, default: "" }, disabled: { type: [Boolean, String], default: false }, value: { type: String, default: "" }, color: { type: String, default: "#007aff" }, backgroundColor: { type: String, default: "" }, borderColor: { type: String, default: "" }, activeBackgroundColor: { type: String, default: "" }, activeBorderColor: { type: String, default: "" }, iconColor: { type: String, default: "#ffffff" } }; const index$m = /* @__PURE__ */ defineBuiltInComponent({ name: "Radio", props: props$o, setup(props2, { slots }) { const radioChecked = ref(props2.checked); const radioValue = ref(props2.value); const radioStyle = computed(() => { if (props2.disabled) { return { backgroundColor: "#E1E1E1", borderColor: "#D1D1D1" }; } const style = {}; if (radioChecked.value) { style.backgroundColor = props2.activeBackgroundColor || props2.color; style.borderColor = props2.activeBorderColor || style.backgroundColor; } else { if (props2.borderColor) style.borderColor = props2.borderColor; if (props2.backgroundColor) style.backgroundColor = props2.backgroundColor; } return style; }); watch([() => props2.checked, () => props2.value], ([newChecked, newModelValue]) => { radioChecked.value = newChecked; radioValue.value = newModelValue; }); const reset = () => { radioChecked.value = false; }; const { uniCheckGroup, uniLabel, field } = useRadioInject(radioChecked, radioValue, reset); const _onClick = ($event) => { if (props2.disabled || radioChecked.value) { return; } radioChecked.value = true; uniCheckGroup && uniCheckGroup.radioChange($event, field); $event.stopPropagation(); }; if (!!uniLabel) { uniLabel.addHandler(_onClick); onBeforeUnmount(() => { uniLabel.removeHandler(_onClick); }); } useListeners$1(props2, { "label-click": _onClick }); return () => { const booleanAttrs = useBooleanAttr(props2, "disabled"); return createVNode("uni-radio", mergeProps(booleanAttrs, { "onClick": _onClick }), [createVNode("div", { "class": "uni-radio-wrapper", "style": { "--HOVER-BD-COLOR": !radioChecked.value ? props2.activeBorderColor : radioStyle.value.borderColor } }, [createVNode("div", { "class": ["uni-radio-input", { "uni-radio-input-disabled": props2.disabled }], "style": radioStyle.value }, [radioChecked.value ? createSvgIconVNode(ICON_PATH_SUCCESS_NO_CIRCLE, props2.disabled ? "#ADADAD" : props2.iconColor, 18) : ""], 6), slots.default && slots.default()], 4)], 16, ["onClick"]); }; } }); function useRadioInject(radioChecked, radioValue, reset) { const field = computed({ get: () => ({ radioChecked: Boolean(radioChecked.value), value: radioValue.value }), set: ({ radioChecked: checked }) => { radioChecked.value = checked; } }); const formField = { reset }; const uniCheckGroup = inject(uniRadioGroupKey, false); if (!!uniCheckGroup) { uniCheckGroup.addField(field); } const uniForm = inject(uniFormKey, false); if (!!uniForm) { uniForm.addField(formField); } const uniLabel = inject(uniLabelKey, false); onBeforeUnmount(() => { uniCheckGroup && uniCheckGroup.removeField(field); uniForm && uniForm.removeField(formField); }); return { uniCheckGroup, uniForm, uniLabel, field }; } const TAGS = { a: "", abbr: "", address: "", article: "", aside: "", b: "", bdi: "", bdo: ["dir"], big: "", blockquote: "", br: "", caption: "", center: "", cite: "", code: "", col: ["span", "width"], colgroup: ["span", "width"], dd: "", del: "", div: "", dl: "", dt: "", em: "", fieldset: "", font: "", footer: "", h1: "", h2: "", h3: "", h4: "", h5: "", h6: "", header: "", hr: "", i: "", img: ["alt", "src", "height", "width"], ins: "", label: "", legend: "", li: "", mark: "", nav: "", ol: ["start", "type"], p: "", pre: "", q: "", rt: "", ruby: "", s: "", section: "", small: "", span: "", strong: "", sub: "", sup: "", table: ["width"], tbody: "", td: ["colspan", "height", "rowspan", "width"], tfoot: "", th: ["colspan", "height", "rowspan", "width"], thead: "", tr: ["colspan", "height", "rowspan", "width"], tt: "", u: "", ul: "" }; const CHARS = { amp: "&", gt: ">", lt: "<", nbsp: " ", quot: '"', apos: "'", ldquo: "“", rdquo: "”", yen: "¥", radic: "√", lceil: "⌈", rceil: "⌉", lfloor: "⌊", rfloor: "⌋", hellip: "…" }; function decodeEntities(htmlString) { return htmlString.replace( /&(([a-zA-Z]+)|(#x{0,1}[\da-zA-Z]+));/gi, function(match, stage) { if (hasOwn(CHARS, stage) && CHARS[stage]) { return CHARS[stage]; } if (/^#[0-9]{1,4}$/.test(stage)) { return String.fromCharCode(stage.slice(1)); } if (/^#x[0-9a-f]{1,4}$/i.test(stage)) { return String.fromCharCode(0 + stage.slice(1)); } return match; } ); } function processClickEvent(node, triggerItemClick) { if (["a", "img"].includes(node.name) && triggerItemClick) { return { onClick: (e2) => { triggerItemClick(e2, { node }); e2.stopPropagation(); e2.preventDefault(); e2.returnValue = false; } }; } } function normalizeAttrs(tagName, attrs2) { if (!isPlainObject(attrs2)) return; for (const key in attrs2) { if (hasOwn(attrs2, key)) { const value = attrs2[key]; if (tagName === "img" && key === "src") attrs2[key] = getRealPath(value); } } } const nodeList2VNode = (scopeId, triggerItemClick, nodeList) => { if (!nodeList || isArray(nodeList) && !nodeList.length) return []; return nodeList.map((node) => { if (!isPlainObject(node)) { return; } if (!hasOwn(node, "type") || node.type === "node") { let nodeProps = { [scopeId]: "" }; const tagName = node.name.toLowerCase(); if (!hasOwn(TAGS, tagName)) { return; } normalizeAttrs(tagName, node.attrs); nodeProps = extend( nodeProps, processClickEvent(node, triggerItemClick), node.attrs ); return h( node.name, nodeProps, nodeList2VNode(scopeId, triggerItemClick, node.children) ); } if (node.type === "text" && isString(node.text) && node.text !== "") return createTextVNode(decodeEntities(node.text || "")); }); }; function removeDOCTYPE(html) { return html.replace(/<\?xml.*\?>\n/, "").replace(/\n/, "").replace(/\n/, ""); } function parseAttrs(attrs2) { return attrs2.reduce(function(pre, attr2) { let value = attr2.value; const name = attr2.name; if (value.match(/ /) && ["style", "src"].indexOf(name) === -1) { value = value.split(" "); } if (pre[name]) { if (Array.isArray(pre[name])) { pre[name].push(value); } else { pre[name] = [pre[name], value]; } } else { pre[name] = value; } return pre; }, {}); } function parseHtml(html) { html = removeDOCTYPE(html); const stacks = []; const results = { node: "root", children: [] }; HTMLParser(html, { start: function(tag, attrs2, unary) { const node = { name: tag }; if (attrs2.length !== 0) { node.attrs = parseAttrs(attrs2); } if (unary) { const parent = stacks[0] || results; if (!parent.children) { parent.children = []; } parent.children.push(node); } else { stacks.unshift(node); } }, end: function(tag) { const node = stacks.shift(); if (node.name !== tag) console.error("invalid state: mismatch end tag"); if (stacks.length === 0) { results.children.push(node); } else { const parent = stacks[0]; if (!parent.children) { parent.children = []; } parent.children.push(node); } }, chars: function(text2) { const node = { type: "text", text: text2 }; if (stacks.length === 0) { results.children.push(node); } else { const parent = stacks[0]; if (!parent.children) { parent.children = []; } parent.children.push(node); } }, comment: function(text2) { const node = { node: "comment", text: text2 }; const parent = stacks[0]; if (!parent.children) { parent.children = []; } parent.children.push(node); } }); return results.children; } const props$n = { nodes: { type: [Array, String], default: function() { return []; } } }; const index$l = /* @__PURE__ */ defineBuiltInComponent({ name: "RichText", compatConfig: { MODE: 3 }, props: props$n, emits: ["click", "touchstart", "touchmove", "touchcancel", "touchend", "longpress", "itemclick"], setup(props2, { emit: emit2 }) { const vm = getCurrentInstance(); const scopeId = vm && vm.vnode.scopeId || ""; const rootRef = ref(null); const _vnode = ref([]); const trigger = useCustomEvent(rootRef, emit2); function triggerItemClick(e2, detail = {}) { trigger("itemclick", e2, detail); } function renderVNode() { let nodeList = props2.nodes; if (isString(nodeList)) { nodeList = parseHtml(props2.nodes); } _vnode.value = nodeList2VNode(scopeId, triggerItemClick, nodeList); } watch(() => props2.nodes, renderVNode, { immediate: true }); return () => h("uni-rich-text", { ref: rootRef }, h("div", {}, _vnode.value)); } }); const passiveOptions = /* @__PURE__ */ passive(true); const props$m = { scrollX: { type: [Boolean, String], default: false }, scrollY: { type: [Boolean, String], default: false }, upperThreshold: { type: [Number, String], default: 50 }, lowerThreshold: { type: [Number, String], default: 50 }, scrollTop: { type: [Number, String], default: 0 }, scrollLeft: { type: [Number, String], default: 0 }, scrollIntoView: { type: String, default: "" }, scrollWithAnimation: { type: [Boolean, String], default: false }, enableBackToTop: { type: [Boolean, String], default: false }, refresherEnabled: { type: [Boolean, String], default: false }, refresherThreshold: { type: Number, default: 45 }, refresherDefaultStyle: { type: String, default: "back" }, refresherBackground: { type: String, default: "#fff" }, refresherTriggered: { type: [Boolean, String], default: false } }; const ScrollView = /* @__PURE__ */ defineBuiltInComponent({ name: "ScrollView", compatConfig: { MODE: 3 }, props: props$m, emits: ["scroll", "scrolltoupper", "scrolltolower", "refresherrefresh", "refresherrestore", "refresherpulling", "refresherabort", "update:refresherTriggered"], setup(props2, { emit: emit2, slots }) { const rootRef = ref(null); const main = ref(null); const wrap = ref(null); const content = ref(null); const refresherinner = ref(null); const trigger = useCustomEvent(rootRef, emit2); const { state: state2, scrollTopNumber, scrollLeftNumber } = useScrollViewState(props2); useScrollViewLoader(props2, state2, scrollTopNumber, scrollLeftNumber, trigger, rootRef, main, content, emit2); const mainStyle = computed(() => { let style = ""; props2.scrollX ? style += "overflow-x:auto;" : style += "overflow-x:hidden;"; props2.scrollY ? style += "overflow-y:auto;" : style += "overflow-y:hidden;"; return style; }); return () => { const { refresherEnabled, refresherBackground, refresherDefaultStyle } = props2; const { refresherHeight, refreshState, refreshRotate } = state2; return createVNode("uni-scroll-view", { "ref": rootRef }, [createVNode("div", { "ref": wrap, "class": "uni-scroll-view" }, [createVNode("div", { "ref": main, "style": mainStyle.value, "class": "uni-scroll-view" }, [createVNode("div", { "ref": content, "class": "uni-scroll-view-content" }, [refresherEnabled ? createVNode("div", { "ref": refresherinner, "style": { backgroundColor: refresherBackground, height: refresherHeight + "px" }, "class": "uni-scroll-view-refresher" }, [refresherDefaultStyle !== "none" ? createVNode("div", { "class": "uni-scroll-view-refresh" }, [createVNode("div", { "class": "uni-scroll-view-refresh-inner" }, [refreshState == "pulling" ? createVNode("svg", { "key": "refresh__icon", "style": { transform: "rotate(" + refreshRotate + "deg)" }, "fill": "#2BD009", "class": "uni-scroll-view-refresh__icon", "width": "24", "height": "24", "viewBox": "0 0 24 24" }, [createVNode("path", { "d": "M17.65 6.35C16.2 4.9 14.21 4 12 4c-4.42 0-7.99 3.58-7.99 8s3.57 8 7.99 8c3.73 0 6.84-2.55 7.73-6h-2.08c-.82 2.33-3.04 4-5.65 4-3.31 0-6-2.69-6-6s2.69-6 6-6c1.66 0 3.14.69 4.22 1.78L13 11h7V4l-2.35 2.35z" }, null), createVNode("path", { "d": "M0 0h24v24H0z", "fill": "none" }, null)], 4) : null, refreshState == "refreshing" ? createVNode("svg", { "key": "refresh__spinner", "class": "uni-scroll-view-refresh__spinner", "width": "24", "height": "24", "viewBox": "25 25 50 50" }, [createVNode("circle", { "cx": "50", "cy": "50", "r": "20", "fill": "none", "style": "color: #2bd009", "stroke-width": "3" }, null)]) : null])]) : null, refresherDefaultStyle == "none" ? slots.refresher && slots.refresher() : null], 4) : null, slots.default && slots.default()], 512)], 4)], 512)], 512); }; } }); function useScrollViewState(props2) { const scrollTopNumber = computed(() => { return Number(props2.scrollTop) || 0; }); const scrollLeftNumber = computed(() => { return Number(props2.scrollLeft) || 0; }); const state2 = reactive({ lastScrollTop: scrollTopNumber.value, lastScrollLeft: scrollLeftNumber.value, lastScrollToUpperTime: 0, lastScrollToLowerTime: 0, refresherHeight: 0, refreshRotate: 0, refreshState: "" }); return { state: state2, scrollTopNumber, scrollLeftNumber }; } function useScrollViewLoader(props2, state2, scrollTopNumber, scrollLeftNumber, trigger, rootRef, main, content, emit2) { let beforeRefreshing = false; let toUpperNumber = 0; let triggerAbort = false; let __transitionEnd = () => { }; const upperThresholdNumber = computed(() => { let val = Number(props2.upperThreshold); return isNaN(val) ? 50 : val; }); const lowerThresholdNumber = computed(() => { let val = Number(props2.lowerThreshold); return isNaN(val) ? 50 : val; }); function scrollTo2(scrollToValue, direction2) { const container = main.value; let transformValue = 0; let transform = ""; scrollToValue < 0 ? scrollToValue = 0 : direction2 === "x" && scrollToValue > container.scrollWidth - container.offsetWidth ? scrollToValue = container.scrollWidth - container.offsetWidth : direction2 === "y" && scrollToValue > container.scrollHeight - container.offsetHeight && (scrollToValue = container.scrollHeight - container.offsetHeight); direction2 === "x" ? transformValue = container.scrollLeft - scrollToValue : direction2 === "y" && (transformValue = container.scrollTop - scrollToValue); if (transformValue === 0) return; let _content = content.value; _content.style.transition = "transform .3s ease-out"; _content.style.webkitTransition = "-webkit-transform .3s ease-out"; if (direction2 === "x") { transform = "translateX(" + transformValue + "px) translateZ(0)"; } else { direction2 === "y" && (transform = "translateY(" + transformValue + "px) translateZ(0)"); } _content.removeEventListener("transitionend", __transitionEnd); _content.removeEventListener("webkitTransitionEnd", __transitionEnd); __transitionEnd = () => _transitionEnd(scrollToValue, direction2); _content.addEventListener("transitionend", __transitionEnd); _content.addEventListener("webkitTransitionEnd", __transitionEnd); if (direction2 === "x") { container.style.overflowX = "hidden"; } else if (direction2 === "y") { container.style.overflowY = "hidden"; } _content.style.transform = transform; _content.style.webkitTransform = transform; } function _handleScroll($event) { const target = $event.target; trigger("scroll", $event, { scrollLeft: target.scrollLeft, scrollTop: target.scrollTop, scrollHeight: target.scrollHeight, scrollWidth: target.scrollWidth, deltaX: state2.lastScrollLeft - target.scrollLeft, deltaY: state2.lastScrollTop - target.scrollTop }); if (props2.scrollY) { if (target.scrollTop <= upperThresholdNumber.value && state2.lastScrollTop - target.scrollTop > 0 && $event.timeStamp - state2.lastScrollToUpperTime > 200) { trigger("scrolltoupper", $event, { direction: "top" }); state2.lastScrollToUpperTime = $event.timeStamp; } if (target.scrollTop + target.offsetHeight + lowerThresholdNumber.value >= target.scrollHeight && state2.lastScrollTop - target.scrollTop < 0 && $event.timeStamp - state2.lastScrollToLowerTime > 200) { trigger("scrolltolower", $event, { direction: "bottom" }); state2.lastScrollToLowerTime = $event.timeStamp; } } if (props2.scrollX) { if (target.scrollLeft <= upperThresholdNumber.value && state2.lastScrollLeft - target.scrollLeft > 0 && $event.timeStamp - state2.lastScrollToUpperTime > 200) { trigger("scrolltoupper", $event, { direction: "left" }); state2.lastScrollToUpperTime = $event.timeStamp; } if (target.scrollLeft + target.offsetWidth + lowerThresholdNumber.value >= target.scrollWidth && state2.lastScrollLeft - target.scrollLeft < 0 && $event.timeStamp - state2.lastScrollToLowerTime > 200) { trigger("scrolltolower", $event, { direction: "right" }); state2.lastScrollToLowerTime = $event.timeStamp; } } state2.lastScrollTop = target.scrollTop; state2.lastScrollLeft = target.scrollLeft; } function _scrollTopChanged(val) { if (props2.scrollY) { { if (props2.scrollWithAnimation) { scrollTo2(val, "y"); } else { main.value.scrollTop = val; } } } } function _scrollLeftChanged(val) { if (props2.scrollX) { { if (props2.scrollWithAnimation) { scrollTo2(val, "x"); } else { main.value.scrollLeft = val; } } } } function _scrollIntoViewChanged(val) { if (val) { if (!/^[_a-zA-Z][-_a-zA-Z0-9:]*$/.test(val)) { console.error(`id error: scroll-into-view=${val}`); return; } let element = rootRef.value.querySelector("#" + val); if (element) { let mainRect = main.value.getBoundingClientRect(); let elRect = element.getBoundingClientRect(); if (props2.scrollX) { let left = elRect.left - mainRect.left; let scrollLeft = main.value.scrollLeft; let x = scrollLeft + left; if (props2.scrollWithAnimation) { scrollTo2(x, "x"); } else { main.value.scrollLeft = x; } } if (props2.scrollY) { let top = elRect.top - mainRect.top; let scrollTop = main.value.scrollTop; let y = scrollTop + top; if (props2.scrollWithAnimation) { scrollTo2(y, "y"); } else { main.value.scrollTop = y; } } } } } function _transitionEnd(val, direction2) { content.value.style.transition = ""; content.value.style.webkitTransition = ""; content.value.style.transform = ""; content.value.style.webkitTransform = ""; let _main = main.value; if (direction2 === "x") { _main.style.overflowX = props2.scrollX ? "auto" : "hidden"; _main.scrollLeft = val; } else if (direction2 === "y") { _main.style.overflowY = props2.scrollY ? "auto" : "hidden"; _main.scrollTop = val; } content.value.removeEventListener("transitionend", __transitionEnd); content.value.removeEventListener("webkitTransitionEnd", __transitionEnd); } function _setRefreshState(_state) { if (!props2.refresherEnabled) return; switch (_state) { case "refreshing": state2.refresherHeight = props2.refresherThreshold; if (!beforeRefreshing) { beforeRefreshing = true; trigger("refresherrefresh", {}, {}); emit2("update:refresherTriggered", true); } break; case "restore": case "refresherabort": beforeRefreshing = false; state2.refresherHeight = toUpperNumber = 0; if (_state === "restore") { triggerAbort = false; trigger("refresherrestore", {}, {}); } if (_state === "refresherabort" && triggerAbort) { triggerAbort = false; trigger("refresherabort", {}, {}); } break; } state2.refreshState = _state; } onMounted(() => { nextTick(() => { _scrollTopChanged(scrollTopNumber.value); _scrollLeftChanged(scrollLeftNumber.value); }); _scrollIntoViewChanged(props2.scrollIntoView); let __handleScroll = function(event) { event.preventDefault(); event.stopPropagation(); _handleScroll(event); }; let touchStart = { x: 0, y: 0 }; let needStop = null; let __handleTouchMove = function(event) { if (touchStart === null) return; let x = event.touches[0].pageX; let y = event.touches[0].pageY; let _main = main.value; if (Math.abs(x - touchStart.x) > Math.abs(y - touchStart.y)) { if (props2.scrollX) { if (_main.scrollLeft === 0 && x > touchStart.x) { needStop = false; return; } else if (_main.scrollWidth === _main.offsetWidth + _main.scrollLeft && x < touchStart.x) { needStop = false; return; } needStop = true; } else { needStop = false; } } else { if (props2.scrollY) { if (_main.scrollTop === 0 && y > touchStart.y) { needStop = false; if (props2.refresherEnabled && event.cancelable !== false) event.preventDefault(); } else if (_main.scrollHeight === _main.offsetHeight + _main.scrollTop && y < touchStart.y) { needStop = false; return; } else { needStop = true; } } else { needStop = false; } } if (needStop) { event.stopPropagation(); } if (_main.scrollTop === 0 && event.touches.length === 1) { _setRefreshState("pulling"); } if (props2.refresherEnabled && state2.refreshState === "pulling") { const dy = y - touchStart.y; if (toUpperNumber === 0) { toUpperNumber = y; } if (!beforeRefreshing) { state2.refresherHeight = y - toUpperNumber; if (state2.refresherHeight > 0) { triggerAbort = true; trigger("refresherpulling", event, { deltaY: dy }); } } else { state2.refresherHeight = dy + props2.refresherThreshold; triggerAbort = false; } const route = state2.refresherHeight / props2.refresherThreshold; state2.refreshRotate = (route > 1 ? 1 : route) * 360; } }; let __handleTouchStart = function(event) { if (event.touches.length === 1) { touchStart = { x: event.touches[0].pageX, y: event.touches[0].pageY }; } }; let __handleTouchEnd = function(event) { touchStart = null; if (state2.refresherHeight >= props2.refresherThreshold) { _setRefreshState("refreshing"); } else { _setRefreshState("refresherabort"); } }; main.value.addEventListener("touchstart", __handleTouchStart, passiveOptions); main.value.addEventListener("touchmove", __handleTouchMove, passive(false)); main.value.addEventListener("scroll", __handleScroll, passive(false)); main.value.addEventListener("touchend", __handleTouchEnd, passiveOptions); onBeforeUnmount(() => { main.value.removeEventListener("touchstart", __handleTouchStart); main.value.removeEventListener("touchmove", __handleTouchMove); main.value.removeEventListener("scroll", __handleScroll); main.value.removeEventListener("touchend", __handleTouchEnd); }); }); onActivated(() => { props2.scrollY && (main.value.scrollTop = state2.lastScrollTop); props2.scrollX && (main.value.scrollLeft = state2.lastScrollLeft); }); watch(scrollTopNumber, (val) => { _scrollTopChanged(val); }); watch(scrollLeftNumber, (val) => { _scrollLeftChanged(val); }); watch(() => props2.scrollIntoView, (val) => { _scrollIntoViewChanged(val); }); watch(() => props2.refresherTriggered, (val) => { if (val === true) { _setRefreshState("refreshing"); } else if (val === false) { _setRefreshState("restore"); } }); } const props$l = { name: { type: String, default: "" }, min: { type: [Number, String], default: 0 }, max: { type: [Number, String], default: 100 }, value: { type: [Number, String], default: 0 }, step: { type: [Number, String], default: 1 }, disabled: { type: [Boolean, String], default: false }, color: { type: String, default: "#e9e9e9" }, backgroundColor: { type: String, default: "#e9e9e9" }, activeColor: { type: String, default: "#007aff" }, selectedColor: { type: String, default: "#007aff" }, blockColor: { type: String, default: "#ffffff" }, blockSize: { type: [Number, String], default: 28 }, showValue: { type: [Boolean, String], default: false } }; class UniSliderElement extends HTMLElement { get value() { return Number(this.getAttribute("value")); } set value(value) { this.dispatchEvent(new CustomEvent("change", { detail: { value } })); } } const index$k = /* @__PURE__ */ defineBuiltInComponent({ name: "Slider", props: props$l, emits: ["changing", "change"], rootElement: { name: "uni-slider", class: UniSliderElement }, setup(props2, { emit: emit2 }) { const sliderRef = ref(null); const sliderValueRef = ref(null); const sliderHandleRef = ref(null); const sliderValue = ref(Number(props2.value)); watch(() => props2.value, (val) => { sliderValue.value = Number(val); }); const trigger = useCustomEvent(sliderRef, emit2); const state2 = useSliderState(props2, sliderValue); const { _onClick, _onTrack } = useSliderLoader(props2, sliderValue, sliderRef, sliderValueRef, trigger); onMounted(() => { useTouchtrack(sliderHandleRef.value, _onTrack); }); function onUniSliderChange(e2) { sliderValue.value = Number(e2.detail.value); } return () => { const { setBgColor, setBlockBg, setActiveColor, setBlockStyle } = state2; return createVNode("uni-slider", { "ref": sliderRef, "onClick": withWebEvent(_onClick), "value": sliderValue.value, "onChange": withWebEvent(onUniSliderChange) }, [createVNode("div", { "class": "uni-slider-wrapper" }, [createVNode("div", { "class": "uni-slider-tap-area" }, [createVNode("div", { "style": setBgColor.value, "class": "uni-slider-handle-wrapper" }, [createVNode("div", { "ref": sliderHandleRef, "style": setBlockBg.value, "class": "uni-slider-handle" }, null, 4), createVNode("div", { "style": setBlockStyle.value, "class": "uni-slider-thumb" }, null, 4), createVNode("div", { "style": setActiveColor.value, "class": "uni-slider-track" }, null, 4)], 4)]), withDirectives(createVNode("span", { "ref": sliderValueRef, "class": "uni-slider-value" }, [sliderValue.value], 512), [[vShow, props2.showValue]])]), createVNode("slot", null, null)], 40, ["onClick", "value", "onChange"]); }; } }); function useSliderState(props2, sliderValue) { const _getValueWidth = () => { const max = Number(props2.max); const min = Number(props2.min); return 100 * (sliderValue.value - min) / (max - min) + "%"; }; const _getBgColor = () => { return props2.backgroundColor !== "#e9e9e9" ? props2.backgroundColor : props2.color !== "#007aff" ? props2.color : "#007aff"; }; const _getActiveColor = () => { return props2.activeColor !== "#007aff" ? props2.activeColor : props2.selectedColor !== "#e9e9e9" ? props2.selectedColor : "#e9e9e9"; }; const state2 = { setBgColor: computed(() => ({ backgroundColor: _getBgColor() })), setBlockBg: computed(() => ({ left: _getValueWidth() })), setActiveColor: computed(() => ({ backgroundColor: _getActiveColor(), width: _getValueWidth() })), setBlockStyle: computed(() => ({ width: props2.blockSize + "px", height: props2.blockSize + "px", marginLeft: -props2.blockSize / 2 + "px", marginTop: -props2.blockSize / 2 + "px", left: _getValueWidth(), backgroundColor: props2.blockColor })) }; return state2; } function useSliderLoader(props2, sliderValue, sliderRef, sliderValueRef, trigger) { const _onClick = ($event) => { if (props2.disabled) { return; } _onUserChangedValue($event); trigger("change", $event, { value: sliderValue.value }); }; const _filterValue = (e2) => { const max = Number(props2.max); const min = Number(props2.min); const step = Number(props2.step); return e2 < min ? min : e2 > max ? max : computeController.mul.call(Math.round((e2 - min) / step), step) + min; }; const _onUserChangedValue = (e2) => { const max = Number(props2.max); const min = Number(props2.min); const sliderRightBox = sliderValueRef.value; const sliderRightBoxLeft = getComputedStyle(sliderRightBox, null).marginLeft; let sliderRightBoxWidth = sliderRightBox.offsetWidth; sliderRightBoxWidth = sliderRightBoxWidth + parseInt(sliderRightBoxLeft); const slider = sliderRef.value; const offsetWidth = slider.offsetWidth - (props2.showValue ? sliderRightBoxWidth : 0); const boxLeft = slider.getBoundingClientRect().left; const value = (e2.x - boxLeft) * (max - min) / offsetWidth + min; sliderValue.value = _filterValue(value); }; const _onTrack = (e2) => { if (!props2.disabled) { return e2.detail.state === "move" ? (_onUserChangedValue({ x: e2.detail.x }), trigger("changing", e2, { value: sliderValue.value }), false) : e2.detail.state === "end" && trigger("change", e2, { value: sliderValue.value }); } }; const uniForm = inject(uniFormKey, false); if (!!uniForm) { const field = { reset: () => sliderValue.value = Number(props2.min), submit: () => { const data = ["", null]; if (props2.name !== "") { data[0] = props2.name; data[1] = sliderValue.value; } return data; } }; uniForm.addField(field); onBeforeUnmount(() => { uniForm.removeField(field); }); } return { _onClick, _onTrack }; } var computeController = { mul: function(arg) { let m = 0; let s1 = this.toString(); let s2 = arg.toString(); try { m += s1.split(".")[1].length; } catch (e2) { } try { m += s2.split(".")[1].length; } catch (e2) { } return Number(s1.replace(".", "")) * Number(s2.replace(".", "")) / Math.pow(10, m); } }; const props$k = { indicatorDots: { type: [Boolean, String], default: false }, vertical: { type: [Boolean, String], default: false }, autoplay: { type: [Boolean, String], default: false }, circular: { type: [Boolean, String], default: false }, interval: { type: [Number, String], default: 5e3 }, duration: { type: [Number, String], default: 500 }, current: { type: [Number, String], default: 0 }, indicatorColor: { type: String, default: "" }, indicatorActiveColor: { type: String, default: "" }, previousMargin: { type: String, default: "" }, nextMargin: { type: String, default: "" }, currentItemId: { type: String, default: "" }, skipHiddenItemLayout: { type: [Boolean, String], default: false }, displayMultipleItems: { type: [Number, String], default: 1 }, disableTouch: { type: [Boolean, String], default: false }, navigation: { type: [Boolean, String], default: false }, navigationColor: { type: String, default: "#fff" }, navigationActiveColor: { type: String, default: "rgba(53, 53, 53, 0.6)" } }; function useState$3(props2) { const interval = computed(() => { const interval2 = Number(props2.interval); return isNaN(interval2) ? 5e3 : interval2; }); const duration = computed(() => { const duration2 = Number(props2.duration); return isNaN(duration2) ? 500 : duration2; }); const displayMultipleItems = computed(() => { const displayMultipleItems2 = Math.round(props2.displayMultipleItems); return isNaN(displayMultipleItems2) ? 1 : displayMultipleItems2; }); const state2 = reactive({ interval, duration, displayMultipleItems, current: Math.round(props2.current) || 0, currentItemId: props2.currentItemId, userTracking: false }); return state2; } function useLayout(props2, state2, swiperContexts, slideFrameRef, emit2, trigger) { function cancelSchedule() { if (timer) { clearTimeout(timer); timer = null; } } let timer = null; let invalid = true; let viewportPosition = 0; let viewportMoveRatio = 1; let animating = null; let requestedAnimation = false; let contentTrackViewport = 0; let transitionStart; let currentChangeSource = ""; let animationFrame; const swiperEnabled = computed(() => swiperContexts.value.length > state2.displayMultipleItems); const circularEnabled = computed(() => props2.circular && swiperEnabled.value); function checkCircularLayout(index2) { if (!invalid) { for (let items = swiperContexts.value, n = items.length, i = index2 + state2.displayMultipleItems, r = 0; r < n; r++) { const item = items[r]; const s = Math.floor(index2 / n) * n + r; const l = s + n; const c = s - n; const u = Math.max(index2 - (s + 1), s - i, 0); const d = Math.max(index2 - (l + 1), l - i, 0); const h2 = Math.max(index2 - (c + 1), c - i, 0); const p2 = Math.min(u, d, h2); const position = [s, l, c][[u, d, h2].indexOf(p2)]; item.updatePosition(position, props2.vertical); } } } function updateViewport(index2) { if (!(Math.floor(2 * viewportPosition) === Math.floor(2 * index2) && Math.ceil(2 * viewportPosition) === Math.ceil(2 * index2))) { if (circularEnabled.value) { checkCircularLayout(index2); } } const x = props2.vertical ? "0" : 100 * -index2 * viewportMoveRatio + "%"; const y = props2.vertical ? 100 * -index2 * viewportMoveRatio + "%" : "0"; const transform = "translate(" + x + ", " + y + ") translateZ(0)"; const slideFrame = slideFrameRef.value; if (slideFrame) { slideFrame.style.webkitTransform = transform; slideFrame.style.transform = transform; } viewportPosition = index2; if (!transitionStart) { if (index2 % 1 === 0) { return; } transitionStart = index2; } index2 -= Math.floor(transitionStart); const items = swiperContexts.value; if (index2 <= -(items.length - 1)) { index2 += items.length; } else if (index2 >= items.length) { index2 -= items.length; } index2 = transitionStart % 1 > 0.5 || transitionStart < 0 ? index2 - 1 : index2; trigger("transition", {}, { dx: props2.vertical ? 0 : index2 * slideFrame.offsetWidth, dy: props2.vertical ? index2 * slideFrame.offsetHeight : 0 }); } function endViewportAnimation() { if (animating) { updateViewport(animating.toPos); animating = null; } } function normalizeCurrentValue(current) { const length = swiperContexts.value.length; if (!length) { return -1; } const index2 = (Math.round(current) % length + length) % length; if (circularEnabled.value) { if (length <= state2.displayMultipleItems) { return 0; } } else if (index2 > length - state2.displayMultipleItems) { return length - state2.displayMultipleItems; } return index2; } function cancelViewportAnimation() { animating = null; } function animateFrameFuncProto() { if (!animating) { requestedAnimation = false; return; } const _animating = animating; const toPos = _animating.toPos; const acc = _animating.acc; const endTime = _animating.endTime; const source = _animating.source; const time = endTime - Date.now(); if (time <= 0) { updateViewport(toPos); animating = null; requestedAnimation = false; transitionStart = null; const item = swiperContexts.value[state2.current]; if (item) { const currentItemId = item.getItemId(); trigger("animationfinish", {}, { current: state2.current, currentItemId, source }); } return; } const s = acc * time * time / 2; const l = toPos + s; updateViewport(l); animationFrame = requestAnimationFrame(animateFrameFuncProto); } function animateViewport(current, source, n) { cancelViewportAnimation(); const duration = state2.duration; const length = swiperContexts.value.length; let position = viewportPosition; if (circularEnabled.value) { if (n < 0) { for (; position < current; ) { position += length; } for (; position - length > current; ) { position -= length; } } else if (n > 0) { for (; position > current; ) { position -= length; } for (; position + length < current; ) { position += length; } if (position + length - current < current - position) { position += length; } } else { for (; position + length < current; ) { position += length; } for (; position - length > current; ) { position -= length; } if (position + length - current < current - position) { position += length; } } } else if (source === "click") { current = current + state2.displayMultipleItems - 1 < length ? current : 0; } animating = { toPos: current, acc: 2 * (position - current) / (duration * duration), endTime: Date.now() + duration, source }; if (!requestedAnimation) { requestedAnimation = true; animationFrame = requestAnimationFrame(animateFrameFuncProto); } } function scheduleAutoplay() { cancelSchedule(); const items = swiperContexts.value; const callback = function() { timer = null; currentChangeSource = "autoplay"; if (circularEnabled.value) { state2.current = normalizeCurrentValue(state2.current + 1); } else { state2.current = state2.current + state2.displayMultipleItems < items.length ? state2.current + 1 : 0; } animateViewport(state2.current, "autoplay", circularEnabled.value ? 1 : 0); timer = setTimeout(callback, state2.interval); }; if (!(invalid || items.length <= state2.displayMultipleItems)) { timer = setTimeout(callback, state2.interval); } } function resetLayout() { cancelSchedule(); endViewportAnimation(); const items = swiperContexts.value; for (let i = 0; i < items.length; i++) { items[i].updatePosition(i, props2.vertical); } viewportMoveRatio = 1; const slideFrameEl = slideFrameRef.value; if (state2.displayMultipleItems === 1 && items.length) { const itemRect = items[0].getBoundingClientRect(); const slideFrameRect = slideFrameEl.getBoundingClientRect(); viewportMoveRatio = itemRect.width / slideFrameRect.width; if (!(viewportMoveRatio > 0 && viewportMoveRatio < 1)) { viewportMoveRatio = 1; } } const position = viewportPosition; viewportPosition = -2; const current = state2.current; if (current >= 0) { invalid = false; if (state2.userTracking) { updateViewport(position + current - contentTrackViewport); contentTrackViewport = current; } else { updateViewport(current); if (props2.autoplay) { scheduleAutoplay(); } } } else { invalid = true; updateViewport(-state2.displayMultipleItems - 1); } } watch([() => props2.current, () => props2.currentItemId, () => [...swiperContexts.value]], () => { let current = -1; if (props2.currentItemId) { for (let i = 0, items = swiperContexts.value; i < items.length; i++) { const itemId = items[i].getItemId(); if (itemId === props2.currentItemId) { current = i; break; } } } if (current < 0) { current = Math.round(props2.current) || 0; } current = current < 0 ? 0 : current; if (state2.current !== current) { currentChangeSource = ""; state2.current = current; } }); watch([() => props2.vertical, () => circularEnabled.value, () => state2.displayMultipleItems, () => [...swiperContexts.value]], resetLayout); watch(() => state2.interval, () => { if (timer) { cancelSchedule(); scheduleAutoplay(); } }); function currentChanged(current, history2) { const source = currentChangeSource; currentChangeSource = ""; const items = swiperContexts.value; if (!source) { const length = items.length; animateViewport(current, "", circularEnabled.value && history2 + (length - current) % length > length / 2 ? 1 : 0); } const item = items[current]; if (item) { const currentItemId = state2.currentItemId = item.getItemId(); trigger("change", {}, { current: state2.current, currentItemId, source }); } } watch(() => state2.current, (val, oldVal) => { currentChanged(val, oldVal); emit2("update:current", val); }); watch(() => state2.currentItemId, (val) => { emit2("update:currentItemId", val); }); function inintAutoplay(enable) { if (enable) { scheduleAutoplay(); } else { cancelSchedule(); } } watch(() => props2.autoplay && !state2.userTracking, inintAutoplay); inintAutoplay(props2.autoplay && !state2.userTracking); onMounted(() => { let userDirectionChecked = false; let contentTrackSpeed = 0; let contentTrackT = 0; function handleTrackStart() { cancelSchedule(); contentTrackViewport = viewportPosition; contentTrackSpeed = 0; contentTrackT = Date.now(); cancelViewportAnimation(); } function handleTrackMove(data) { const oldContentTrackT = contentTrackT; contentTrackT = Date.now(); const length = swiperContexts.value.length; const other = length - state2.displayMultipleItems; function calc2(val) { return 0.5 - 0.25 / (val + 0.5); } function move(oldVal, newVal) { let val = contentTrackViewport + oldVal; contentTrackSpeed = 0.6 * contentTrackSpeed + 0.4 * newVal; if (!circularEnabled.value) { if (val < 0 || val > other) { if (val < 0) { val = -calc2(-val); } else { if (val > other) { val = other + calc2(val - other); } } contentTrackSpeed = 0; } } updateViewport(val); } const time = contentTrackT - oldContentTrackT || 1; const slideFrameEl = slideFrameRef.value; if (props2.vertical) { move(-data.dy / slideFrameEl.offsetHeight, -data.ddy / time); } else { move(-data.dx / slideFrameEl.offsetWidth, -data.ddx / time); } } function handleTrackEnd(isCancel) { state2.userTracking = false; const t2 = contentTrackSpeed / Math.abs(contentTrackSpeed); let n = 0; if (!isCancel && Math.abs(contentTrackSpeed) > 0.2) { n = 0.5 * t2; } const current = normalizeCurrentValue(viewportPosition + n); if (isCancel) { updateViewport(contentTrackViewport); } else { currentChangeSource = "touch"; state2.current = current; animateViewport(current, "touch", n !== 0 ? n : current === 0 && circularEnabled.value && viewportPosition >= 1 ? 1 : 0); } } useTouchtrack(slideFrameRef.value, (event) => { if (props2.disableTouch) { return; } if (!invalid) { if (event.detail.state === "start") { state2.userTracking = true; userDirectionChecked = false; return handleTrackStart(); } if (event.detail.state === "end") { return handleTrackEnd(false); } if (event.detail.state === "cancel") { return handleTrackEnd(true); } if (state2.userTracking) { if (!userDirectionChecked) { userDirectionChecked = true; const t2 = Math.abs(event.detail.dx); const n = Math.abs(event.detail.dy); if (t2 >= n && props2.vertical) { state2.userTracking = false; } else { if (t2 <= n && !props2.vertical) { state2.userTracking = false; } } if (!state2.userTracking) { if (props2.autoplay) { scheduleAutoplay(); } return; } } handleTrackMove(event.detail); return false; } } }); }); onUnmounted(() => { cancelSchedule(); cancelAnimationFrame(animationFrame); }); function onSwiperDotClick(index2) { animateViewport(state2.current = index2, currentChangeSource = "click", circularEnabled.value ? 1 : 0); } return { onSwiperDotClick, circularEnabled, swiperEnabled }; } const Swiper = /* @__PURE__ */ defineBuiltInComponent({ name: "Swiper", props: props$k, emits: ["change", "transition", "animationfinish", "update:current", "update:currentItemId"], setup(props2, { slots, emit: emit2 }) { const rootRef = ref(null); const trigger = useCustomEvent(rootRef, emit2); const slidesWrapperRef = ref(null); const slideFrameRef = ref(null); const state2 = useState$3(props2); const slidesStyle = computed(() => { let style = {}; if (props2.nextMargin || props2.previousMargin) { style = props2.vertical ? { left: 0, right: 0, top: rpx2px(props2.previousMargin, true), bottom: rpx2px(props2.nextMargin, true) } : { top: 0, bottom: 0, left: rpx2px(props2.previousMargin, true), right: rpx2px(props2.nextMargin, true) }; } return style; }); const slideFrameStyle = computed(() => { const value = Math.abs(100 / state2.displayMultipleItems) + "%"; return { width: props2.vertical ? "100%" : value, height: !props2.vertical ? "100%" : value }; }); let swiperItems = []; const originSwiperContexts = []; const swiperContexts = ref([]); function updateSwiperContexts() { const contexts = []; for (let index2 = 0; index2 < swiperItems.length; index2++) { let swiperItem = swiperItems[index2]; if (!(swiperItem instanceof Element)) { swiperItem = swiperItem.el; } const swiperContext = originSwiperContexts.find((context) => swiperItem === context.rootRef.value); if (swiperContext) { contexts.push(markRaw(swiperContext)); } } swiperContexts.value = contexts; } const addSwiperContext = function(swiperContext) { originSwiperContexts.push(swiperContext); updateSwiperContexts(); }; provide("addSwiperContext", addSwiperContext); const removeSwiperContext = function(swiperContext) { const index2 = originSwiperContexts.indexOf(swiperContext); if (index2 >= 0) { originSwiperContexts.splice(index2, 1); updateSwiperContexts(); } }; provide("removeSwiperContext", removeSwiperContext); const { onSwiperDotClick, circularEnabled, swiperEnabled } = useLayout(props2, state2, swiperContexts, slideFrameRef, emit2, trigger); let createNavigationTsx = () => null; { createNavigationTsx = useSwiperNavigation(rootRef, props2, state2, onSwiperDotClick, swiperContexts, circularEnabled, swiperEnabled); } return () => { const defaultSlots = slots.default && slots.default(); swiperItems = flatVNode(defaultSlots); return createVNode("uni-swiper", { "ref": rootRef }, [createVNode("div", { "ref": slidesWrapperRef, "class": "uni-swiper-wrapper" }, [createVNode("div", { "class": "uni-swiper-slides", "style": slidesStyle.value }, [createVNode("div", { "ref": slideFrameRef, "class": "uni-swiper-slide-frame", "style": slideFrameStyle.value }, [defaultSlots], 4)], 4), props2.indicatorDots && createVNode("div", { "class": ["uni-swiper-dots", props2.vertical ? "uni-swiper-dots-vertical" : "uni-swiper-dots-horizontal"] }, [swiperContexts.value.map((_, index2, array) => createVNode("div", { "onClick": () => onSwiperDotClick(index2), "class": { "uni-swiper-dot": true, "uni-swiper-dot-active": index2 < state2.current + state2.displayMultipleItems && index2 >= state2.current || index2 < state2.current + state2.displayMultipleItems - array.length }, "style": { background: index2 === state2.current ? props2.indicatorActiveColor : props2.indicatorColor } }, null, 14, ["onClick"]))], 2), createNavigationTsx()], 512)], 512); }; } }); const useSwiperNavigation = (rootRef, props2, state2, onSwiperDotClick, swiperContext, circularEnabled, swiperEnabled) => { let isNavigationAuto = false; let prevDisabled = false; let nextDisabled = false; let hideNavigation = ref(false); watchEffect(() => { isNavigationAuto = props2.navigation === "auto"; hideNavigation.value = props2.navigation !== true || isNavigationAuto; swiperAddMouseEvent(); }); watchEffect(() => { const swiperItemLength = swiperContext.value.length; const notCircular = !circularEnabled.value; prevDisabled = state2.current === 0 && notCircular; nextDisabled = state2.current === swiperItemLength - 1 && notCircular || notCircular && state2.current + state2.displayMultipleItems >= swiperItemLength; if (!swiperEnabled.value) { prevDisabled = true; nextDisabled = true; isNavigationAuto && (hideNavigation.value = true); } }); function navigationHover(event, type) { const target = event.currentTarget; if (!target) return; target.style.backgroundColor = type === "over" ? props2.navigationActiveColor : ""; } const navigationAttr = { onMouseover: (event) => navigationHover(event, "over"), onMouseout: (event) => navigationHover(event, "out") }; function navigationClick($event, type, disabled) { $event.stopPropagation(); if (disabled) return; const swiperItemLength = swiperContext.value.length; let _current = state2.current; switch (type) { case "prev": _current--; if (_current < 0 && circularEnabled.value) { _current = swiperItemLength - 1; } break; case "next": _current++; if (_current >= swiperItemLength && circularEnabled.value) { _current = 0; } break; } onSwiperDotClick(_current); } const createNavigationSVG = () => createSvgIconVNode(ICON_PATH_BACK, props2.navigationColor, 26); let setHideNavigationTimer; const _mousemove = (e2) => { clearTimeout(setHideNavigationTimer); const { clientX, clientY } = e2; const { left, right, top, bottom, width, height } = rootRef.value.getBoundingClientRect(); let hide = false; if (props2.vertical) { hide = !(clientY - top < height / 3 || bottom - clientY < height / 3); } else { hide = !(clientX - left < width / 3 || right - clientX < width / 3); } if (hide) { return setHideNavigationTimer = setTimeout(() => { hideNavigation.value = hide; }, 300); } hideNavigation.value = hide; }; const _mouseleave = () => { hideNavigation.value = true; }; function swiperAddMouseEvent() { if (rootRef.value) { rootRef.value.removeEventListener("mousemove", _mousemove); rootRef.value.removeEventListener("mouseleave", _mouseleave); if (isNavigationAuto) { rootRef.value.addEventListener("mousemove", _mousemove); rootRef.value.addEventListener("mouseleave", _mouseleave); } } } onMounted(swiperAddMouseEvent); function createNavigationTsx() { const navigationClass = { "uni-swiper-navigation-hide": hideNavigation.value, "uni-swiper-navigation-vertical": props2.vertical }; if (props2.navigation) { return createVNode(Fragment, null, [createVNode("div", mergeProps({ "class": ["uni-swiper-navigation uni-swiper-navigation-prev", extend({ "uni-swiper-navigation-disabled": prevDisabled }, navigationClass)], "onClick": (e2) => navigationClick(e2, "prev", prevDisabled) }, navigationAttr), [createNavigationSVG()], 16, ["onClick"]), createVNode("div", mergeProps({ "class": ["uni-swiper-navigation uni-swiper-navigation-next", extend({ "uni-swiper-navigation-disabled": nextDisabled }, navigationClass)], "onClick": (e2) => navigationClick(e2, "next", nextDisabled) }, navigationAttr), [createNavigationSVG()], 16, ["onClick"])]); } return null; } return createNavigationTsx; }; const props$j = { itemId: { type: String, default: "" } }; const SwiperItem = /* @__PURE__ */ defineBuiltInComponent({ name: "SwiperItem", props: props$j, setup(props2, { slots }) { const rootRef = ref(null); const context = { rootRef, getItemId() { return props2.itemId; }, getBoundingClientRect() { const el = rootRef.value; return el.getBoundingClientRect(); }, updatePosition(position, vertical) { const x = vertical ? "0" : 100 * position + "%"; const y = vertical ? 100 * position + "%" : "0"; const rootEl = rootRef.value; const value = `translate(${x},${y}) translateZ(0)`; if (rootEl) { rootEl.style.webkitTransform = value; rootEl.style.transform = value; } } }; onMounted(() => { const addSwiperContext = inject("addSwiperContext"); if (addSwiperContext) { addSwiperContext(context); } }); onUnmounted(() => { const removeSwiperContext = inject("removeSwiperContext"); if (removeSwiperContext) { removeSwiperContext(context); } }); return () => { return createVNode("uni-swiper-item", { "ref": rootRef, "style": { position: "absolute", width: "100%", height: "100%" } }, [slots.default && slots.default()], 512); }; } }); const props$i = { name: { type: String, default: "" }, checked: { type: [Boolean, String], default: false }, type: { type: String, default: "switch" }, id: { type: String, default: "" }, disabled: { type: [Boolean, String], default: false }, color: { type: String, default: "" } }; const index$j = /* @__PURE__ */ defineBuiltInComponent({ name: "Switch", props: props$i, emits: ["change"], setup(props2, { emit: emit2 }) { const rootRef = ref(null); const switchChecked = ref(props2.checked); const uniLabel = useSwitchInject(props2, switchChecked); const trigger = useCustomEvent(rootRef, emit2); watch(() => props2.checked, (val) => { switchChecked.value = val; }); const _onClick = ($event) => { if (props2.disabled) { return; } switchChecked.value = !switchChecked.value; trigger("change", $event, { value: switchChecked.value }); }; if (!!uniLabel) { uniLabel.addHandler(_onClick); onBeforeUnmount(() => { uniLabel.removeHandler(_onClick); }); } useListeners$1(props2, { "label-click": _onClick }); return () => { const { color, type } = props2; const booleanAttrs = useBooleanAttr(props2, "disabled"); const switchInputStyle = {}; if (color && switchChecked.value) { switchInputStyle["backgroundColor"] = color; switchInputStyle["borderColor"] = color; } return createVNode("uni-switch", mergeProps({ "ref": rootRef }, booleanAttrs, { "onClick": _onClick }), [createVNode("div", { "class": "uni-switch-wrapper" }, [withDirectives(createVNode("div", { "class": ["uni-switch-input", [switchChecked.value ? "uni-switch-input-checked" : ""]], "style": switchInputStyle }, null, 6), [[vShow, type === "switch"]]), withDirectives(createVNode("div", { "class": "uni-checkbox-input" }, [switchChecked.value ? createSvgIconVNode(ICON_PATH_SUCCESS_NO_CIRCLE, props2.color, 22) : ""], 512), [[vShow, type === "checkbox"]])])], 16, ["onClick"]); }; } }); function useSwitchInject(props2, switchChecked) { const uniForm = inject(uniFormKey, false); const uniLabel = inject(uniLabelKey, false); const formField = { submit: () => { const data = ["", null]; if (props2.name) { data[0] = props2.name; data[1] = switchChecked.value; } return data; }, reset: () => { switchChecked.value = false; } }; if (!!uniForm) { uniForm.addField(formField); onUnmounted(() => { uniForm.removeField(formField); }); } return uniLabel; } const SPACE_UNICODE = { ensp: " ", emsp: " ", nbsp: " " }; function parseText(text2, options) { return text2.replace(/\\n/g, LINEFEED).split(LINEFEED).map((text22) => { return normalizeText(text22, options); }); } function normalizeText(text2, { space, decode: decode2 }) { if (!text2) { return text2; } if (space && SPACE_UNICODE[space]) { text2 = text2.replace(/ /g, SPACE_UNICODE[space]); } if (!decode2) { return text2; } return text2.replace(/ /g, SPACE_UNICODE.nbsp).replace(/ /g, SPACE_UNICODE.ensp).replace(/ /g, SPACE_UNICODE.emsp).replace(/</g, "<").replace(/>/g, ">").replace(/&/g, "&").replace(/"/g, '"').replace(/'/g, "'"); } const index$i = /* @__PURE__ */ defineBuiltInComponent({ name: "Text", props: { selectable: { type: [Boolean, String], default: false }, space: { type: String, default: "" }, decode: { type: [Boolean, String], default: false } }, setup(props2, { slots }) { return () => { const children = []; if (slots.default) { slots.default().forEach((vnode) => { if (vnode.shapeFlag & 8 && vnode.type !== Comment) { const lines = parseText(vnode.children, { space: props2.space, decode: props2.decode }); const len = lines.length - 1; lines.forEach((line, index2) => { if (index2 === 0 && !line) ; else { children.push(createTextVNode(line)); } if (index2 !== len) { children.push(createVNode("br")); } }); } else { if (process.env.NODE_ENV !== "production" && vnode.shapeFlag & 6 && vnode.type.name !== "Text") { console.warn("Do not nest other components in the text component, as there may be display differences on different platforms."); } children.push(vnode); } }); } return createVNode("uni-text", { "selectable": props2.selectable ? true : null }, [createVNode("span", null, children)], 8, ["selectable"]); }; } }); const props$h = /* @__PURE__ */ extend({}, props$r, { placeholderClass: { type: String, default: "input-placeholder" }, autoHeight: { type: [Boolean, String], default: false }, confirmType: { type: String, default: "return", validator(val) { return ConfirmTypes.concat("return").includes(val); } } }); let fixMargin = false; const ConfirmTypes = ["done", "go", "next", "search", "send"]; function setFixMargin() { const DARK_TEST_STRING = "(prefers-color-scheme: dark)"; fixMargin = String(navigator.platform).indexOf("iP") === 0 && String(navigator.vendor).indexOf("Apple") === 0 && window.matchMedia(DARK_TEST_STRING).media !== DARK_TEST_STRING; } const index$h = /* @__PURE__ */ defineBuiltInComponent({ name: "Textarea", props: props$h, emits: ["confirm", "linechange", ...emit], setup(props2, { emit: emit2 }) { const rootRef = ref(null); const wrapperRef = ref(null); const { fieldRef, state: state2, scopedAttrsState, fixDisabledColor, trigger } = useField(props2, rootRef, emit2); const valueCompute = computed(() => state2.value.split(LINEFEED)); const isDone = computed(() => ConfirmTypes.includes(props2.confirmType)); const heightRef = ref(0); const lineRef = ref(null); watch(() => heightRef.value, (height) => { const el = rootRef.value; const lineEl = lineRef.value; const wrapper2 = wrapperRef.value; let lineHeight = parseFloat(getComputedStyle(el).lineHeight); if (isNaN(lineHeight)) { lineHeight = lineEl.offsetHeight; } var lineCount = Math.round(height / lineHeight); trigger("linechange", {}, { height, heightRpx: 750 / window.innerWidth * height, lineCount }); if (props2.autoHeight) { el.style.height = "auto"; wrapper2.style.height = height + "px"; } }); function onResize2({ height }) { heightRef.value = height; } function confirm(event) { trigger("confirm", event, { value: state2.value }); } function onKeyDownEnter(event) { if (event.key !== "Enter") { return; } if (isDone.value) { event.preventDefault(); } } function onKeyUpEnter(event) { if (event.key !== "Enter") { return; } if (isDone.value) { confirm(event); const textarea = event.target; !props2.confirmHold && textarea.blur(); } } { setFixMargin(); } return () => { let textareaNode = props2.disabled && fixDisabledColor ? createVNode("textarea", { "key": "disabled-textarea", "ref": fieldRef, "value": state2.value, "tabindex": "-1", "readonly": !!props2.disabled, "maxlength": state2.maxlength, "class": { "uni-textarea-textarea": true, "uni-textarea-textarea-fix-margin": fixMargin }, "style": { overflowY: props2.autoHeight ? "hidden" : "auto" }, "onFocus": (event) => event.target.blur() }, null, 46, ["value", "readonly", "maxlength", "onFocus"]) : createVNode("textarea", { "key": "textarea", "ref": fieldRef, "value": state2.value, "disabled": !!props2.disabled, "maxlength": state2.maxlength, "enterkeyhint": props2.confirmType, "inputmode": props2.inputmode, "class": { "uni-textarea-textarea": true, "uni-textarea-textarea-fix-margin": fixMargin }, "style": { overflowY: props2.autoHeight ? "hidden" : "auto" }, "onKeydown": onKeyDownEnter, "onKeyup": onKeyUpEnter }, null, 46, ["value", "disabled", "maxlength", "enterkeyhint", "inputmode", "onKeydown", "onKeyup"]); return createVNode("uni-textarea", { "ref": rootRef }, [createVNode("div", { "ref": wrapperRef, "class": "uni-textarea-wrapper" }, [withDirectives(createVNode("div", mergeProps(scopedAttrsState.attrs, { "style": props2.placeholderStyle, "class": ["uni-textarea-placeholder", props2.placeholderClass] }), [props2.placeholder], 16), [[vShow, !state2.value.length]]), createVNode("div", { "ref": lineRef, "class": "uni-textarea-line" }, [" "], 512), createVNode("div", { "class": "uni-textarea-compute" }, [valueCompute.value.map((item) => createVNode("div", null, [item.trim() ? item : "."])), createVNode(ResizeSensor, { "initial": true, "onResize": onResize2 }, null, 8, ["initial", "onResize"])]), props2.confirmType === "search" ? createVNode("form", { "action": "", "onSubmit": () => false, "class": "uni-input-form" }, [textareaNode], 40, ["onSubmit"]) : textareaNode], 512)], 512); }; } }); const index$g = /* @__PURE__ */ defineBuiltInComponent({ name: "View", props: extend({}, hoverProps), setup(props2, { slots }) { const { hovering, binding } = useHover(props2); return () => { const hoverClass = props2.hoverClass; if (hoverClass && hoverClass !== "none") { return createVNode("uni-view", mergeProps({ "class": hovering.value ? hoverClass : "" }, binding), [slots.default && slots.default()], 16); } return createVNode("uni-view", null, [slots.default && slots.default()]); }; } }); function normalizeEvent(vm, id2) { if (!id2) { id2 = vm.id; } if (!id2) { return; } return vm.$options.name.toLowerCase() + "." + id2; } function addSubscribe(name, callback, pageId) { if (!name) { return; } registerViewMethod( pageId || getCurrentPageId(), name, ({ type, data }, resolve) => { callback(type, data, resolve); } ); } function removeSubscribe(name, pageId) { if (!name) { return; } unregisterViewMethod(pageId || getCurrentPageId(), name); } function useSubscribe(callback, name, multiple, pageId) { const instance2 = getCurrentInstance(); const vm = instance2.proxy; onMounted(() => { addSubscribe(name || normalizeEvent(vm), callback, pageId); if (multiple || !name) { watch( () => vm.id, (value, oldValue) => { addSubscribe(normalizeEvent(vm, value), callback, pageId); removeSubscribe(oldValue && normalizeEvent(vm, oldValue)); } ); } }); onBeforeUnmount(() => { removeSubscribe(name || normalizeEvent(vm), pageId); }); } function useOn(name, callback) { onMounted(() => UniViewJSBridge.on(name, callback)); onBeforeUnmount(() => UniViewJSBridge.off(name)); } let index$f = 0; function useContextInfo(_id) { const page = useCurrentPageId(); const instance2 = getCurrentInstance(); const vm = instance2.proxy; const type = vm.$options.name.toLowerCase(); const id2 = _id || vm.id || `context${index$f++}`; onMounted(() => { const el = vm.$el; el.__uniContextInfo = { id: id2, type, page }; }); return `${type}.${id2}`; } function getContextInfo(el) { return el.__uniContextInfo; } function injectLifecycleHook(name, hook, publicThis, instance2) { if (isFunction(hook)) { injectHook(name, hook.bind(publicThis), instance2); } } function initHooks(options, instance2, publicThis) { var _a; const mpType = options.mpType || publicThis.$mpType; if (!mpType || mpType === "component") { return; } Object.keys(options).forEach((name) => { if (isUniLifecycleHook(name, options[name], false)) { const hooks = options[name]; if (isArray(hooks)) { hooks.forEach( (hook) => injectLifecycleHook(name, hook, publicThis, instance2) ); } else { injectLifecycleHook(name, hooks, publicThis, instance2); } } }); if (mpType === "page") { instance2.__isVisible = true; try { invokeHook(publicThis, ON_LOAD, instance2.attrs.__pageQuery); delete instance2.attrs.__pageQuery; if (((_a = publicThis.$page) == null ? void 0 : _a.openType) !== "preloadPage") { invokeHook(publicThis, ON_SHOW); } } catch (e2) { console.error(e2.message + LINEFEED + e2.stack); } } } function applyOptions(options, instance2, publicThis) { initHooks(options, instance2, publicThis); } function set(target, key, val) { return target[key] = val; } function $callMethod(method, ...args) { const fn = this[method]; if (fn) { return fn(...args); } console.error(`method ${method} not found`); return null; } function createErrorHandler(app) { return function errorHandler(err, instance2, _info) { if (!instance2) { throw err; } const appInstance = app._instance; if (!appInstance || !appInstance.proxy) { throw err; } { invokeHook(appInstance.proxy, ON_ERROR, err); } }; } function mergeAsArray(to, from) { return to ? [...new Set([].concat(to, from))] : from; } function initOptionMergeStrategies(optionMergeStrategies) { UniLifecycleHooks.forEach((name) => { optionMergeStrategies[name] = mergeAsArray; }); } let realAtob; const b64 = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/="; const b64re = /^(?:[A-Za-z\d+/]{4})*?(?:[A-Za-z\d+/]{2}(?:==)?|[A-Za-z\d+/]{3}=?)?$/; if (typeof atob !== "function") { realAtob = function(str) { str = String(str).replace(/[\t\n\f\r ]+/g, ""); if (!b64re.test(str)) { throw new Error( "Failed to execute 'atob' on 'Window': The string to be decoded is not correctly encoded." ); } str += "==".slice(2 - (str.length & 3)); var bitmap; var result = ""; var r1; var r2; var i = 0; for (; i < str.length; ) { bitmap = b64.indexOf(str.charAt(i++)) << 18 | b64.indexOf(str.charAt(i++)) << 12 | (r1 = b64.indexOf(str.charAt(i++))) << 6 | (r2 = b64.indexOf(str.charAt(i++))); result += r1 === 64 ? String.fromCharCode(bitmap >> 16 & 255) : r2 === 64 ? String.fromCharCode(bitmap >> 16 & 255, bitmap >> 8 & 255) : String.fromCharCode( bitmap >> 16 & 255, bitmap >> 8 & 255, bitmap & 255 ); } return result; }; } else { realAtob = atob; } function b64DecodeUnicode(str) { return decodeURIComponent( realAtob(str).split("").map(function(c) { return "%" + ("00" + c.charCodeAt(0).toString(16)).slice(-2); }).join("") ); } function getCurrentUserInfo() { const token = uni.getStorageSync("uni_id_token") || ""; const tokenArr = token.split("."); if (!token || tokenArr.length !== 3) { return { uid: null, role: [], permission: [], tokenExpired: 0 }; } let userInfo; try { userInfo = JSON.parse(b64DecodeUnicode(tokenArr[1])); } catch (error) { throw new Error("获取当前用户信息出错,详细错误信息为:" + error.message); } userInfo.tokenExpired = userInfo.exp * 1e3; delete userInfo.exp; delete userInfo.iat; return userInfo; } function uniIdMixin(globalProperties) { globalProperties.uniIDHasRole = function(roleId) { const { role } = getCurrentUserInfo(); return role.indexOf(roleId) > -1; }; globalProperties.uniIDHasPermission = function(permissionId) { const { permission } = getCurrentUserInfo(); return this.uniIDHasRole("admin") || permission.indexOf(permissionId) > -1; }; globalProperties.uniIDTokenValid = function() { const { tokenExpired } = getCurrentUserInfo(); return tokenExpired > Date.now(); }; } function initApp$1(app) { const appConfig = app._context.config; appConfig.errorHandler = invokeCreateErrorHandler(app, createErrorHandler); initOptionMergeStrategies(appConfig.optionMergeStrategies); const globalProperties = appConfig.globalProperties; { if (__UNI_FEATURE_UNI_CLOUD__) { uniIdMixin(globalProperties); } } { globalProperties.$set = set; globalProperties.$applyOptions = applyOptions; globalProperties.$callMethod = $callMethod; } { invokeCreateVueAppHook(app); } } const pageMetaKey = PolySymbol(process.env.NODE_ENV !== "production" ? "UniPageMeta" : "upm"); function usePageMeta() { return inject(pageMetaKey); } function providePageMeta(id2) { const pageMeta = initPageMeta(id2); provide(pageMetaKey, pageMeta); return pageMeta; } function usePageRoute() { if (__UNI_FEATURE_PAGES__) { return useRoute(); } const url = location.href; const searchPos = url.indexOf("?"); const hashPos = url.indexOf("#", searchPos > -1 ? searchPos : 0); let query = {}; if (searchPos > -1) { query = parseQuery( url.slice(searchPos + 1, hashPos > -1 ? hashPos : url.length) ); } const { meta } = __uniRoutes[0]; const path = addLeadingSlash(meta.route); return { meta, query, path, matched: [{ path }] }; } function initPageMeta(id2) { if (__UNI_FEATURE_PAGES__) { return reactive( normalizePageMeta( JSON.parse( JSON.stringify( initRouteMeta( useRoute().meta, id2 ) ) ) ) ); } return reactive( normalizePageMeta( JSON.parse(JSON.stringify(initRouteMeta(__uniRoutes[0].meta, id2))) ) ); } function normalizePageMeta(pageMeta) { if (__UNI_FEATURE_PULL_DOWN_REFRESH__) { const { enablePullDownRefresh, navigationBar } = pageMeta; if (enablePullDownRefresh) { const pullToRefresh = normalizePullToRefreshRpx( extend( { support: true, color: "#2BD009", style: "circle", height: 70, range: 150, offset: 0 }, pageMeta.pullToRefresh ) ); const { type, style } = navigationBar; if (style !== "custom" && type !== "transparent") { pullToRefresh.offset += NAVBAR_HEIGHT + safeAreaInsets$1.top; } pageMeta.pullToRefresh = pullToRefresh; } } if (__UNI_FEATURE_NAVIGATIONBAR__) { const { navigationBar } = pageMeta; const { titleSize, titleColor, backgroundColor } = navigationBar; navigationBar.titleText = navigationBar.titleText || ""; navigationBar.type = navigationBar.type || "default"; navigationBar.titleSize = titleSize || "16px"; navigationBar.titleColor = titleColor || "#000000"; navigationBar.backgroundColor = backgroundColor || "#F8F8F8"; __UNI_FEATURE_I18N_LOCALE__ && initNavigationBarI18n(navigationBar); } if (__UNI_FEATURE_PAGES__ && history.state) { const type = history.state.__type__; if ((type === "redirectTo" || type === "reLaunch") && getCurrentPages().length === 0) { pageMeta.isEntry = true; pageMeta.isQuit = true; } } return pageMeta; } const screen$1 = window.screen; const documentElement = document.documentElement; function checkMinWidth(minWidth) { const sizes = [ window.outerWidth, window.outerHeight, screen$1.width, screen$1.height, documentElement.clientWidth, documentElement.clientHeight ]; return Math.max.apply(null, sizes) > minWidth; } function getStateId() { return history.state && history.state.__id__ || 1; } let tabBar; function useTabBar() { if (!tabBar) { tabBar = __uniConfig.tabBar && reactive(initTabBarI18n(__uniConfig.tabBar)); } return tabBar; } const supports = window.CSS && window.CSS.supports; function cssSupports(css) { return supports && (supports(css) || supports.apply(window.CSS, css.split(":"))); } const cssVar = /* @__PURE__ */ cssSupports("--a:0"); const cssEnv = /* @__PURE__ */ cssSupports("top:env(a)"); const cssConstant = /* @__PURE__ */ cssSupports("top:constant(a)"); const cssBackdropFilter = /* @__PURE__ */ cssSupports("backdrop-filter:blur(10px)"); const SCHEMA_CSS = { "css.var": cssVar, "css.env": cssEnv, "css.constant": cssConstant, "css.backdrop-filter": cssBackdropFilter }; const canIUse = /* @__PURE__ */ defineSyncApi( API_CAN_I_USE, (schema) => { if (hasOwn(SCHEMA_CSS, schema)) { return SCHEMA_CSS[schema]; } return true; }, CanIUseProtocol ); const envMethod = /* @__PURE__ */ (() => cssEnv ? "env" : cssConstant ? "constant" : "")(); function updateCurPageCssVar(pageMeta) { let windowTopValue = 0; let windowBottomValue = 0; if (__UNI_FEATURE_NAVIGATIONBAR__ && pageMeta.navigationBar.style !== "custom" && ["default", "float"].indexOf(pageMeta.navigationBar.type) > -1) { windowTopValue = NAVBAR_HEIGHT; } if (__UNI_FEATURE_TABBAR__ && pageMeta.isTabBar) { const tabBar2 = useTabBar(); tabBar2.shown && (windowBottomValue = parseInt(tabBar2.height)); } updatePageCssVar({ "--window-top": normalizeWindowTop(windowTopValue), "--window-bottom": normalizeWindowBottom(windowBottomValue) }); } function normalizeWindowTop(windowTop) { return envMethod ? `calc(${windowTop}px + ${envMethod}(safe-area-inset-top))` : `${windowTop}px`; } function normalizeWindowBottom(windowBottom) { return envMethod ? `calc(${windowBottom}px + ${envMethod}(safe-area-inset-bottom))` : `${windowBottom}px`; } const SEP = "$$"; const currentPagesMap = /* @__PURE__ */ new Map(); function pruneCurrentPages() { currentPagesMap.forEach((page, id2) => { if (page.$.isUnmounted) { currentPagesMap.delete(id2); } }); } function getCurrentPagesMap() { return currentPagesMap; } function getCurrentPages$1() { const curPages = []; const pages = currentPagesMap.values(); for (const page of pages) { if (page.$.__isTabBar) { if (page.$.__isActive) { curPages.push(page); } } else { curPages.push(page); } } return curPages; } function removeRouteCache(routeKey) { const vnode = pageCacheMap.get(routeKey); if (vnode) { pageCacheMap.delete(routeKey); routeCache.pruneCacheEntry(vnode); } } function removePage(routeKey, removeRouteCaches = true) { const pageVm = currentPagesMap.get(routeKey); pageVm.$.__isUnload = true; invokeHook(pageVm, ON_UNLOAD); currentPagesMap.delete(routeKey); removeRouteCaches && removeRouteCache(routeKey); } let id = /* @__PURE__ */ getStateId(); function createPageState(type, __id__) { return { __id__: __id__ || ++id, __type__: type }; } function initPublicPage(route) { const meta = usePageMeta(); if (!__UNI_FEATURE_PAGES__) { return initPageInternalInstance("navigateTo", __uniRoutes[0].path, {}, meta); } let fullPath = route.fullPath; if (route.meta.isEntry && fullPath.indexOf(route.meta.route) === -1) { fullPath = "/" + route.meta.route + fullPath.replace("/", ""); } return initPageInternalInstance("navigateTo", fullPath, {}, meta); } function initPage(vm) { const route = vm.$route; const page = initPublicPage(route); initPageVm(vm, page); currentPagesMap.set(normalizeRouteKey(page.path, page.id), vm); } function normalizeRouteKey(path, id2) { return path + SEP + id2; } function useKeepAliveRoute() { const route = useRoute(); const routeKey = computed( () => normalizeRouteKey("/" + route.meta.route, getStateId()) ); const isTabBar = computed(() => route.meta.isTabBar); return { routeKey, isTabBar, routeCache }; } const pageCacheMap = /* @__PURE__ */ new Map(); const routeCache = { get(key) { return pageCacheMap.get(key); }, set(key, value) { pruneRouteCache(key); pageCacheMap.set(key, value); }, delete(key) { const vnode = pageCacheMap.get(key); if (!vnode) { return; } pageCacheMap.delete(key); }, forEach(fn) { pageCacheMap.forEach(fn); } }; function isTabBarVNode(vnode) { return vnode.props.type === "tabBar"; } function pruneRouteCache(key) { const pageId = parseInt(key.split(SEP)[1]); if (!pageId) { return; } routeCache.forEach((vnode, key2) => { const cPageId = parseInt(key2.split(SEP)[1]); if (cPageId && cPageId > pageId) { if (__UNI_FEATURE_TABBAR__ && isTabBarVNode(vnode)) { return; } routeCache.delete(key2); routeCache.pruneCacheEntry(vnode); nextTick(() => pruneCurrentPages()); } }); } function updateCurPageAttrs(pageMeta) { { const uvueDirKey = "uvue-dir-" + __uniConfig.uvue["flex-direction"]; document.body.setAttribute("uvue", ""); document.body.setAttribute(uvueDirKey, ""); } } function onPageShow(instance2, pageMeta) { updateBodyScopeId(instance2); updateCurPageCssVar(pageMeta); updateCurPageAttrs(); initPageScrollListener(instance2, pageMeta); } function onPageReady(instance2) { const scopeId = getScopeId(instance2); scopeId && updateCurPageBodyScopeId(scopeId); } function updateCurPageBodyScopeId(scopeId) { const pageBodyEl = document.querySelector("uni-page-body"); if (pageBodyEl) { pageBodyEl.setAttribute(scopeId, ""); } else if (process.env.NODE_ENV !== "production") { console.warn("uni-page-body not found"); } } function getScopeId(instance2) { return instance2.type.__scopeId; } let curScopeId; function updateBodyScopeId(instance2) { const scopeId = getScopeId(instance2); const { body } = document; curScopeId && body.removeAttribute(curScopeId); scopeId && body.setAttribute(scopeId, ""); curScopeId = scopeId; } let curScrollListener; function initPageScrollListener(instance2, pageMeta) { document.removeEventListener("touchmove", disableScrollListener); if (curScrollListener) { document.removeEventListener("scroll", curScrollListener); } if (pageMeta.disableScroll) { return document.addEventListener("touchmove", disableScrollListener); } const { onPageScroll, onReachBottom } = instance2; const navigationBarTransparent = pageMeta.navigationBar.type === "transparent"; if (!onPageScroll && !onReachBottom && !navigationBarTransparent) { return; } const opts = {}; const pageId = instance2.proxy.$page.id; if (onPageScroll || navigationBarTransparent) { opts.onPageScroll = createOnPageScroll( pageId, onPageScroll, navigationBarTransparent ); } if (onReachBottom) { opts.onReachBottomDistance = pageMeta.onReachBottomDistance || ON_REACH_BOTTOM_DISTANCE; opts.onReachBottom = () => UniViewJSBridge.publishHandler(ON_REACH_BOTTOM, {}, pageId); } curScrollListener = createScrollListener(opts); requestAnimationFrame( () => document.addEventListener("scroll", curScrollListener) ); } function createOnPageScroll(pageId, onPageScroll, navigationBarTransparent) { return (scrollTop) => { if (onPageScroll) { UniViewJSBridge.publishHandler(ON_PAGE_SCROLL, { scrollTop }, pageId); } if (navigationBarTransparent) { UniViewJSBridge.emit(pageId + "." + ON_PAGE_SCROLL, { scrollTop }); } }; } function initRouter(app) { const router = createRouter(createRouterOptions()); app.router = router; app.use(router); } const scrollBehavior = (_to, _from, savedPosition) => { if (savedPosition) { return savedPosition; } }; function createRouterOptions() { return { history: initHistory(), strict: !!__uniConfig.router.strict, routes: __uniRoutes, scrollBehavior }; } function removeCurrentPages(delta = 1) { const keys = getCurrentPages$1(); const start = keys.length - 1; const end = start - delta; for (let i = start; i > end; i--) { const page = keys[i].$page; removePage(normalizeRouteKey(page.path, page.id), false); } } function initHistory() { let { routerBase } = __uniConfig.router; if (routerBase === "/") { routerBase = ""; } const history2 = __UNI_FEATURE_ROUTER_MODE__ === "history" ? createWebHistory(routerBase) : createWebHashHistory(routerBase); history2.listen((_to, _from, info) => { if (info.direction === "back") { removeCurrentPages(Math.abs(info.delta)); } }); return history2; } const index$e = { install(app) { initApp$1(app); initViewPlugin(app); initServicePlugin(app); if (!app.config.warnHandler) { app.config.warnHandler = warnHandler; } if (__UNI_FEATURE_PAGES__) { initRouter(app); } } }; function warnHandler(msg, instance2, trace) { if (instance2) { const name = instance2.$.type.name; if ("PageMetaHead" === name) { return; } const parent = instance2.$.parent; if (parent && parent.type.name === "PageMeta") { return; } } const warnArgs = [`[Vue warn]: ${msg}`]; if (trace.length) { warnArgs.push(` `, trace); } console.warn(...warnArgs); } const clazz = { class: "uni-async-loading" }; const loadingVNode = /* @__PURE__ */ createVNode( "i", { class: "uni-loading" }, null, -1 /* HOISTED */ ); const AsyncLoadingComponent = /* @__PURE__ */ defineSystemComponent({ name: "AsyncLoading", render() { return openBlock(), createBlock("div", clazz, [loadingVNode]); } }); function reload() { window.location.reload(); } const AsyncErrorComponent = /* @__PURE__ */ defineSystemComponent({ name: "AsyncError", setup() { initI18nAsyncMsgsOnce(); const { t: t2 } = useI18n(); return () => createVNode("div", { "class": "uni-async-error", "onClick": reload }, [t2("uni.async.error")], 8, ["onClick"]); } }); let appVm; function getApp$1() { return appVm; } function initApp(vm) { appVm = vm; Object.defineProperty(appVm.$.ctx, "$children", { get() { return getCurrentPages().map((page) => page.$vm); } }); const app = appVm.$.appContext.app; if (!app.component(AsyncLoadingComponent.name)) { app.component(AsyncLoadingComponent.name, AsyncLoadingComponent); } if (!app.component(AsyncErrorComponent.name)) { app.component(AsyncErrorComponent.name, AsyncErrorComponent); } initAppVm(appVm); defineGlobalData(appVm); initService(); initView(); } function wrapperComponentSetup(comp, { clone, init: init2, setup, before }) { if (clone) { comp = extend({}, comp); } before && before(comp); const oldSetup = comp.setup; comp.setup = (props2, ctx) => { const instance2 = getCurrentInstance(); init2(instance2.proxy); const query = setup(instance2); if (oldSetup) { return oldSetup(query || props2, ctx); } }; return comp; } function setupComponent(comp, options) { if (comp && (comp.__esModule || comp[Symbol.toStringTag] === "Module")) { return wrapperComponentSetup(comp.default, options); } return wrapperComponentSetup(comp, options); } function setupWindow(comp, id2) { return setupComponent(comp, { init: (vm) => { vm.$page = { id: id2 }; }, setup(instance2) { instance2.$pageInstance = instance2; } }); } function setupPage(comp) { if (process.env.NODE_ENV !== "production") { comp.__mpType = "page"; } return setupComponent(comp, { clone: true, // 页面组件可能会被其他地方手动引用,比如 windows 等,需要 clone 一份新的作为页面组件 init: initPage, setup(instance2) { instance2.$pageInstance = instance2; const route = usePageRoute(); const query = decodedQuery(route.query); instance2.attrs.__pageQuery = query; instance2.proxy.$page.options = query; const pageMeta = usePageMeta(); onBeforeMount(() => { onPageShow(instance2, pageMeta); }); onMounted(() => { onPageReady(instance2); const { onReady } = instance2; onReady && invokeArrayFns$1(onReady); invokeOnTabItemTap(route); }); onBeforeActivate(() => { if (!instance2.__isVisible) { onPageShow(instance2, pageMeta); instance2.__isVisible = true; const { onShow } = instance2; onShow && invokeArrayFns$1(onShow); nextTick(() => { invokeOnTabItemTap(route); }); } }); onBeforeDeactivate(() => { if (instance2.__isVisible && !instance2.__isUnload) { instance2.__isVisible = false; const { onHide } = instance2; onHide && invokeArrayFns$1(onHide); } }); subscribeViewMethod(pageMeta.id); onBeforeUnmount(() => { unsubscribeViewMethod(pageMeta.id); }); return query; } }); } function setupApp(comp) { if (process.env.NODE_ENV !== "production") { comp.__mpType = "app"; } return setupComponent(comp, { init: initApp, setup(instance2) { const route = usePageRoute(); const onLaunch = () => { injectAppHooks(instance2); const { onLaunch: onLaunch2, onShow, onPageNotFound: onPageNotFound2, onError: onError2 } = instance2; const path = route.path.slice(1); const launchOptions2 = initLaunchOptions({ path: path || __uniRoutes[0].meta.route, query: decodedQuery(route.query) }); onLaunch2 && invokeArrayFns$1(onLaunch2, launchOptions2); onShow && invokeArrayFns$1(onShow, launchOptions2); if (__UNI_FEATURE_PAGES__) { if (!route.matched.length) { const pageNotFoundOptions = { notFound: true, openType: "appLaunch", path: route.path, query: {}, scene: 1001 }; onPageNotFound2 && invokeArrayFns$1(onPageNotFound2, pageNotFoundOptions); } } if (onError2) { instance2.appContext.config.errorHandler = (err) => { invokeArrayFns$1(onError2, err); }; } }; if (__UNI_FEATURE_PAGES__) { useRouter().isReady().then(onLaunch); } else { onBeforeMount(onLaunch); } onMounted(() => { window.addEventListener( "resize", debounce(onResize, 50, { setTimeout, clearTimeout }) ); window.addEventListener("message", onMessage); document.addEventListener("visibilitychange", onVisibilityChange); onThemeChange$2(); }); return route.query; }, before(comp2) { comp2.mpType = "app"; const { setup } = comp2; const render = () => { return openBlock(), createBlock(LayoutComponent); }; comp2.setup = (props2, ctx) => { const res = setup && setup(props2, ctx); return isFunction(res) ? render : res; }; comp2.render = render; } }); } function onResize() { const { windowWidth, windowHeight, screenWidth, screenHeight } = uni.getSystemInfoSync(); const landscape = Math.abs(Number(window.orientation)) === 90; const deviceOrientation = landscape ? "landscape" : "portrait"; UniServiceJSBridge.emit(ON_RESIZE, { deviceOrientation, size: { windowWidth, windowHeight, screenWidth, screenHeight } }); } function onMessage(evt) { if (isPlainObject(evt.data) && evt.data.type === WEB_INVOKE_APPSERVICE) { UniServiceJSBridge.emit( ON_WEB_INVOKE_APP_SERVICE, evt.data.data, evt.data.pageId ); } } function onVisibilityChange() { const { emit: emit2 } = UniServiceJSBridge; if (document.visibilityState === "visible") { emit2(ON_APP_ENTER_FOREGROUND, getEnterOptions()); } else { emit2(ON_APP_ENTER_BACKGROUND); } } function onThemeChange$2() { let mediaQueryList = null; try { mediaQueryList = window.matchMedia("(prefers-color-scheme: dark)"); } catch (error) { } if (mediaQueryList) { let callback = (e2) => { UniServiceJSBridge.emit(ON_THEME_CHANGE, { theme: e2.matches ? "dark" : "light" }); }; if (mediaQueryList.addEventListener) { mediaQueryList.addEventListener("change", callback); } else { mediaQueryList.addListener(callback); } } } function invokeOnTabItemTap(route) { const { tabBarText, tabBarIndex, route: pagePath } = route.meta; if (tabBarText) { invokeHook("onTabItemTap", { index: tabBarIndex, text: tabBarText, pagePath }); } } function formatTime(val) { val = val > 0 && val < Infinity ? val : 0; const h2 = Math.floor(val / 3600); const m = Math.floor(val % 3600 / 60); const s = Math.floor(val % 3600 % 60); const hStr = (h2 < 10 ? "0" : "") + h2; const mStr = (m < 10 ? "0" : "") + m; const sStr = (s < 10 ? "0" : "") + s; let str = mStr + ":" + sStr; if (hStr !== "00") { str = hStr + ":" + str; } return str; } function useGesture(props2, videoRef, fullscreenState) { const state2 = reactive({ gestureType: "none", volumeOld: 0, volumeNew: 0, currentTimeOld: 0, currentTimeNew: 0 }); const touchStartOrigin = { x: 0, y: 0 }; function onTouchstart(event) { const toucher = event.targetTouches[0]; touchStartOrigin.x = toucher.pageX; touchStartOrigin.y = toucher.pageY; state2.gestureType = "none"; state2.volumeOld = 0; state2.currentTimeOld = state2.currentTimeNew = 0; } function onTouchmove(event) { function stop() { event.stopPropagation(); event.preventDefault(); } if (fullscreenState.fullscreen) { stop(); } const gestureType = state2.gestureType; if (gestureType === "stop") { return; } const toucher = event.targetTouches[0]; const pageX = toucher.pageX; const pageY = toucher.pageY; const origin = touchStartOrigin; const video = videoRef.value; if (gestureType === "progress") { changeProgress(pageX - origin.x); } else if (gestureType === "volume") { changeVolume(pageY - origin.y); } if (gestureType !== "none") { return; } if (Math.abs(pageX - origin.x) > Math.abs(pageY - origin.y)) { if (!props2.enableProgressGesture) { state2.gestureType = "stop"; return; } state2.gestureType = "progress"; state2.currentTimeOld = state2.currentTimeNew = video.currentTime; if (!fullscreenState.fullscreen) { stop(); } } else { if (!props2.pageGesture) { state2.gestureType = "stop"; return; } state2.gestureType = "volume"; state2.volumeOld = video.volume; if (!fullscreenState.fullscreen) { stop(); } } } function onTouchend(event) { const video = videoRef.value; if (state2.gestureType !== "none" && state2.gestureType !== "stop") { event.stopPropagation(); event.preventDefault(); } if (state2.gestureType === "progress" && state2.currentTimeOld !== state2.currentTimeNew) { video.currentTime = state2.currentTimeNew; } state2.gestureType = "none"; } function changeProgress(x) { const video = videoRef.value; const duration = video.duration; let currentTimeNew = x / 600 * duration + state2.currentTimeOld; if (currentTimeNew < 0) { currentTimeNew = 0; } else if (currentTimeNew > duration) { currentTimeNew = duration; } state2.currentTimeNew = currentTimeNew; } function changeVolume(y) { const video = videoRef.value; const valueOld = state2.volumeOld; let value; if (typeof valueOld === "number") { value = valueOld - y / 200; if (value < 0) { value = 0; } else if (value > 1) { value = 1; } video.volume = value; state2.volumeNew = value; } } return { state: state2, onTouchstart, onTouchmove, onTouchend }; } function useFullscreen(trigger, containerRef, videoRef, userActionState, rootRef) { const state2 = reactive({ fullscreen: false }); const isSafari = /^Apple/.test(navigator.vendor); function onFullscreenChange($event, webkit) { if (webkit && document.fullscreenEnabled) { return; } emitFullscreenChange(!!(document.fullscreenElement || document.webkitFullscreenElement)); } function emitFullscreenChange(val) { state2.fullscreen = val; trigger("fullscreenchange", {}, { fullScreen: val, direction: "vertical" }); } function toggleFullscreen(val) { const root = rootRef.value; const container = containerRef.value; const video = videoRef.value; let mockFullScreen; if (val) { if ((document.fullscreenEnabled || document.webkitFullscreenEnabled) && (!isSafari || userActionState.userAction)) { container[document.fullscreenEnabled ? "requestFullscreen" : "webkitRequestFullscreen"](); } else if (video.webkitEnterFullScreen) { video.webkitEnterFullScreen(); } else { mockFullScreen = true; container.remove(); container.classList.add("uni-video-type-fullscreen"); document.body.appendChild(container); } } else { if (document.fullscreenEnabled || document.webkitFullscreenEnabled) { if (document.fullscreenElement) { document.exitFullscreen(); } else if (document.webkitFullscreenElement) { document.webkitExitFullscreen(); } } else if (video.webkitExitFullScreen) { video.webkitExitFullScreen(); } else { mockFullScreen = true; container.remove(); container.classList.remove("uni-video-type-fullscreen"); root.appendChild(container); } } if (mockFullScreen) { emitFullscreenChange(val); } } function requestFullScreen() { toggleFullscreen(true); } function exitFullScreen() { toggleFullscreen(false); } onBeforeUnmount(exitFullScreen); return { state: state2, onFullscreenChange, emitFullscreenChange, toggleFullscreen, requestFullScreen, exitFullScreen }; } function useVideo(props2, attrs2, trigger) { const videoRef = ref(null); const src = computed(() => getRealPath(props2.src)); const state2 = reactive({ start: false, src, playing: false, currentTime: 0, duration: 0, progress: 0, buffered: 0 }); watch(() => src.value, () => { state2.playing = false; state2.currentTime = 0; }); watch(() => state2.buffered, (buffered) => { trigger("progress", {}, { buffered }); }); function onDurationChange({ target }) { state2.duration = target.duration; } function onLoadedMetadata($event) { const initialTime = Number(props2.initialTime) || 0; const video = $event.target; if (initialTime > 0) { video.currentTime = initialTime; } trigger("loadedmetadata", $event, { width: video.videoWidth, height: video.videoHeight, duration: video.duration }); onProgress($event); } function onProgress($event) { const video = $event.target; const buffered = video.buffered; if (buffered.length) { state2.buffered = buffered.end(buffered.length - 1) / video.duration * 100; } } function onWaiting($event) { trigger("waiting", $event, {}); } function onVideoError($event) { state2.playing = false; trigger("error", $event, {}); } function onPlay($event) { state2.start = true; state2.playing = true; trigger("play", $event, {}); } function onPause($event) { state2.playing = false; trigger("pause", $event, {}); } function onEnded($event) { state2.playing = false; trigger("ended", $event, {}); } function onTimeUpdate($event) { const video = $event.target; const currentTime = state2.currentTime = video.currentTime; trigger("timeupdate", $event, { currentTime, duration: video.duration }); } function toggle() { const video = videoRef.value; if (state2.playing) { video.pause(); } else { video.play(); } } function play() { const video = videoRef.value; state2.start = true; video.play(); } function pause() { const video = videoRef.value; video.pause(); } function seek(position) { const video = videoRef.value; position = Number(position); if (typeof position === "number" && !isNaN(position)) { video.currentTime = position; } } function playbackRate(rate) { const video = videoRef.value; video.playbackRate = rate; } return { videoRef, state: state2, play, pause, seek, playbackRate, toggle, onDurationChange, onLoadedMetadata, onProgress, onWaiting, onVideoError, onPlay, onPause, onEnded, onTimeUpdate }; } function useControls(props2, videoState, seek) { const progressRef = ref(null); const ballRef = ref(null); const centerPlayBtnShow = computed(() => props2.showCenterPlayBtn && !videoState.start); const controlsVisible = ref(true); const controlsShow = computed(() => !centerPlayBtnShow.value && props2.controls && controlsVisible.value); const state2 = reactive({ touching: false, controlsTouching: false, centerPlayBtnShow, controlsShow, controlsVisible }); function clickProgress(event) { const $progress = progressRef.value; let element = event.target; let x = event.offsetX; while (element && element !== $progress) { x += element.offsetLeft; element = element.parentNode; } const w = $progress.offsetWidth; let progress = 0; if (x >= 0 && x <= w) { progress = x / w; seek(videoState.duration * progress); } } function toggleControls() { state2.controlsVisible = !state2.controlsVisible; } let hideTiming; function autoHideStart() { hideTiming = setTimeout(() => { state2.controlsVisible = false; }, 3e3); } function autoHideEnd() { if (hideTiming) { clearTimeout(hideTiming); hideTiming = null; } } onBeforeUnmount(() => { if (hideTiming) { clearTimeout(hideTiming); } }); watch(() => state2.controlsShow && videoState.playing && !state2.controlsTouching, (val) => { if (val) { autoHideStart(); } else { autoHideEnd(); } }); watch([() => videoState.currentTime, () => { props2.duration; }], function updateProgress() { if (!state2.touching) { videoState.progress = videoState.currentTime / videoState.duration * 100; } }); onMounted(() => { const passiveOptions2 = passive(false); let originX; let originY; let moveOnce = true; let originProgress; const ball = ballRef.value; function touchmove2(event) { const toucher = event.targetTouches[0]; const pageX = toucher.pageX; const pageY = toucher.pageY; if (moveOnce && Math.abs(pageX - originX) < Math.abs(pageY - originY)) { touchend(event); return; } moveOnce = false; const progressEl = progressRef.value; const w = progressEl.offsetWidth; let progress = originProgress + (pageX - originX) / w * 100; if (progress < 0) { progress = 0; } else if (progress > 100) { progress = 100; } videoState.progress = progress; event.preventDefault(); event.stopPropagation(); } function touchend(event) { state2.controlsTouching = false; if (state2.touching) { ball.removeEventListener("touchmove", touchmove2, passiveOptions2); if (!moveOnce) { event.preventDefault(); event.stopPropagation(); seek(videoState.duration * videoState.progress / 100); } state2.touching = false; } } ball.addEventListener("touchstart", (event) => { state2.controlsTouching = true; const toucher = event.targetTouches[0]; originX = toucher.pageX; originY = toucher.pageY; originProgress = videoState.progress; moveOnce = true; state2.touching = true; ball.addEventListener("touchmove", touchmove2, passiveOptions2); }); ball.addEventListener("touchend", touchend); ball.addEventListener("touchcancel", touchend); }); return { state: state2, progressRef, ballRef, clickProgress, toggleControls, autoHideStart, autoHideEnd }; } function useDanmu(props2, videoState) { const danmuRef = ref(null); const state2 = reactive({ enable: Boolean(props2.enableDanmu) }); let danmuIndex = { time: 0, index: -1 }; const danmuList = isArray(props2.danmuList) ? JSON.parse(JSON.stringify(props2.danmuList)) : []; danmuList.sort(function(a2, b) { return (a2.time || 0) - (b.time || 0); }); function toggleDanmu() { state2.enable = !state2.enable; } function updateDanmu(event) { const video = event.target; const currentTime = video.currentTime; const oldDanmuIndex = danmuIndex; const newDanmuIndex = { time: currentTime, index: oldDanmuIndex.index }; if (currentTime > oldDanmuIndex.time) { for (let index2 = oldDanmuIndex.index + 1; index2 < danmuList.length; index2++) { const element = danmuList[index2]; if (currentTime >= (element.time || 0)) { newDanmuIndex.index = index2; if (videoState.playing && state2.enable) { playDanmu(element); } } else { break; } } } else if (currentTime < oldDanmuIndex.time) { for (let index2 = oldDanmuIndex.index - 1; index2 > -1; index2--) { const element = danmuList[index2]; if (currentTime <= (element.time || 0)) { newDanmuIndex.index = index2 - 1; } else { break; } } } danmuIndex = newDanmuIndex; } function playDanmu(danmu) { const p2 = document.createElement("p"); p2.className = "uni-video-danmu-item"; p2.innerText = danmu.text; let style = `bottom: ${Math.random() * 100}%;color: ${danmu.color};`; p2.setAttribute("style", style); const danmuEl = danmuRef.value; danmuEl.appendChild(p2); setTimeout(function() { style += "left: 0;-webkit-transform: translateX(-100%);transform: translateX(-100%);"; p2.setAttribute("style", style); setTimeout(function() { p2.remove(); }, 4e3); }, 17); } function sendDanmu(danmu) { danmuList.splice(danmuIndex.index + 1, 0, { text: String(danmu.text), color: danmu.color, time: videoState.currentTime || 0 }); } return { state: state2, danmuRef, updateDanmu, toggleDanmu, sendDanmu }; } function useContext(play, pause, seek, sendDanmu, playbackRate, requestFullScreen, exitFullScreen) { const methods = { play, pause, seek, sendDanmu, playbackRate, requestFullScreen, exitFullScreen }; const id2 = useContextInfo(); useSubscribe((type, data) => { let options; switch (type) { case "seek": options = data.position; break; case "sendDanmu": options = data; break; case "playbackRate": options = data.rate; break; } if (type in methods) { methods[type](options); } }, id2, true); } const props$g = { id: { type: String, default: "" }, src: { type: String, default: "" }, duration: { type: [Number, String], default: "" }, controls: { type: [Boolean, String], default: true }, danmuList: { type: Array, default() { return []; } }, danmuBtn: { type: [Boolean, String], default: false }, enableDanmu: { type: [Boolean, String], default: false }, autoplay: { type: [Boolean, String], default: false }, loop: { type: [Boolean, String], default: false }, muted: { type: [Boolean, String], default: false }, objectFit: { type: String, default: "contain" }, poster: { type: String, default: "" }, direction: { type: [String, Number], default: "" }, showProgress: { type: Boolean, default: true }, initialTime: { type: [String, Number], default: 0 }, showFullscreenBtn: { type: [Boolean, String], default: true }, pageGesture: { type: [Boolean, String], default: false }, enableProgressGesture: { type: [Boolean, String], default: true }, showPlayBtn: { type: [Boolean, String], default: true }, showCenterPlayBtn: { type: [Boolean, String], default: true } }; const index$d = /* @__PURE__ */ defineBuiltInComponent({ name: "Video", props: props$g, emits: ["fullscreenchange", "progress", "loadedmetadata", "waiting", "error", "play", "pause", "ended", "timeupdate"], setup(props2, { emit: emit2, attrs: attrs2, slots }) { const rootRef = ref(null); const containerRef = ref(null); const trigger = useCustomEvent(rootRef, emit2); const { state: userActionState } = useUserAction(); const { $attrs: videoAttrs } = useAttrs({ excludeListeners: true }); const { t: t2 } = useI18n(); initI18nVideoMsgsOnce(); const { videoRef, state: videoState, play, pause, seek, playbackRate, toggle, onDurationChange, onLoadedMetadata, onProgress, onWaiting, onVideoError, onPlay, onPause, onEnded, onTimeUpdate } = useVideo(props2, attrs2, trigger); const { state: danmuState, danmuRef, updateDanmu, toggleDanmu, sendDanmu } = useDanmu(props2, videoState); const { state: fullscreenState, onFullscreenChange, emitFullscreenChange, toggleFullscreen, requestFullScreen, exitFullScreen } = useFullscreen(trigger, containerRef, videoRef, userActionState, rootRef); const { state: gestureState, onTouchstart, onTouchend, onTouchmove } = useGesture(props2, videoRef, fullscreenState); const { state: controlsState, progressRef, ballRef, clickProgress, toggleControls } = useControls(props2, videoState, seek); useContext(play, pause, seek, sendDanmu, playbackRate, requestFullScreen, exitFullScreen); return () => { return createVNode("uni-video", { "ref": rootRef, "id": props2.id }, [createVNode("div", { "ref": containerRef, "class": "uni-video-container", "onTouchstart": onTouchstart, "onTouchend": onTouchend, "onTouchmove": onTouchmove, "onFullscreenchange": withModifiers(onFullscreenChange, ["stop"]), "onWebkitfullscreenchange": withModifiers(($event) => onFullscreenChange($event, true), ["stop"]) }, [createVNode("video", mergeProps({ "ref": videoRef, "style": { "object-fit": props2.objectFit }, "muted": !!props2.muted, "loop": !!props2.loop, "src": videoState.src, "poster": props2.poster, "autoplay": !!props2.autoplay }, videoAttrs.value, { "class": "uni-video-video", "webkit-playsinline": true, "playsinline": true, "onClick": toggleControls, "onDurationchange": onDurationChange, "onLoadedmetadata": onLoadedMetadata, "onProgress": onProgress, "onWaiting": onWaiting, "onError": onVideoError, "onPlay": onPlay, "onPause": onPause, "onEnded": onEnded, "onTimeupdate": (event) => { onTimeUpdate(event); updateDanmu(event); }, "onWebkitbeginfullscreen": () => emitFullscreenChange(true), "onX5videoenterfullscreen": () => emitFullscreenChange(true), "onWebkitendfullscreen": () => emitFullscreenChange(false), "onX5videoexitfullscreen": () => emitFullscreenChange(false) }), null, 16, ["muted", "loop", "src", "poster", "autoplay", "webkit-playsinline", "playsinline", "onClick", "onDurationchange", "onLoadedmetadata", "onProgress", "onWaiting", "onError", "onPlay", "onPause", "onEnded", "onTimeupdate", "onWebkitbeginfullscreen", "onX5videoenterfullscreen", "onWebkitendfullscreen", "onX5videoexitfullscreen"]), withDirectives(createVNode("div", { "class": "uni-video-bar uni-video-bar-full", "onClick": withModifiers(() => { }, ["stop"]) }, [createVNode("div", { "class": "uni-video-controls" }, [withDirectives(createVNode("div", { "class": { "uni-video-control-button": true, "uni-video-control-button-play": !videoState.playing, "uni-video-control-button-pause": videoState.playing }, "onClick": withModifiers(toggle, ["stop"]) }, null, 10, ["onClick"]), [[vShow, props2.showPlayBtn]]), withDirectives(createVNode("div", { "class": "uni-video-current-time" }, [formatTime(videoState.currentTime)], 512), [[vShow, props2.showProgress]]), withDirectives(createVNode("div", { "ref": progressRef, "class": "uni-video-progress-container", "onClick": withModifiers(clickProgress, ["stop"]) }, [createVNode("div", { "class": "uni-video-progress" }, [createVNode("div", { "style": { width: videoState.buffered + "%" }, "class": "uni-video-progress-buffered" }, null, 4), createVNode("div", { "ref": ballRef, "style": { left: videoState.progress + "%" }, "class": "uni-video-ball" }, [createVNode("div", { "class": "uni-video-inner" }, null)], 4)])], 8, ["onClick"]), [[vShow, props2.showProgress]]), withDirectives(createVNode("div", { "class": "uni-video-duration" }, [formatTime(Number(props2.duration) || videoState.duration)], 512), [[vShow, props2.showProgress]])]), withDirectives(createVNode("div", { "class": { "uni-video-danmu-button": true, "uni-video-danmu-button-active": danmuState.enable }, "onClick": withModifiers(toggleDanmu, ["stop"]) }, [t2("uni.video.danmu")], 10, ["onClick"]), [[vShow, props2.danmuBtn]]), withDirectives(createVNode("div", { "class": { "uni-video-fullscreen": true, "uni-video-type-fullscreen": fullscreenState.fullscreen }, "onClick": withModifiers(() => toggleFullscreen(!fullscreenState.fullscreen), ["stop"]) }, null, 10, ["onClick"]), [[vShow, props2.showFullscreenBtn]])], 8, ["onClick"]), [[vShow, controlsState.controlsShow]]), withDirectives(createVNode("div", { "ref": danmuRef, "style": "z-index: 0;", "class": "uni-video-danmu" }, null, 512), [[vShow, videoState.start && danmuState.enable]]), controlsState.centerPlayBtnShow && createVNode("div", { "class": "uni-video-cover", "onClick": withModifiers(() => { }, ["stop"]) }, [createVNode("div", { "class": "uni-video-cover-play-button", "onClick": withModifiers(play, ["stop"]) }, null, 8, ["onClick"]), createVNode("p", { "class": "uni-video-cover-duration" }, [formatTime(Number(props2.duration) || videoState.duration)])], 8, ["onClick"]), createVNode("div", { "class": { "uni-video-toast": true, "uni-video-toast-volume": gestureState.gestureType === "volume" } }, [createVNode("div", { "class": "uni-video-toast-title" }, [t2("uni.video.volume")]), createVNode("svg", { "class": "uni-video-toast-icon", "width": "200px", "height": "200px", "viewBox": "0 0 1024 1024", "version": "1.1", "xmlns": "http://www.w3.org/2000/svg" }, [createVNode("path", { "d": "M475.400704 201.19552l0 621.674496q0 14.856192-10.856448 25.71264t-25.71264 10.856448-25.71264-10.856448l-190.273536-190.273536-149.704704 0q-14.856192 0-25.71264-10.856448t-10.856448-25.71264l0-219.414528q0-14.856192 10.856448-25.71264t25.71264-10.856448l149.704704 0 190.273536-190.273536q10.856448-10.856448 25.71264-10.856448t25.71264 10.856448 10.856448 25.71264zm219.414528 310.837248q0 43.425792-24.28416 80.851968t-64.2816 53.425152q-5.71392 2.85696-14.2848 2.85696-14.856192 0-25.71264-10.570752t-10.856448-25.998336q0-11.999232 6.856704-20.284416t16.570368-14.2848 19.427328-13.142016 16.570368-20.284416 6.856704-32.569344-6.856704-32.569344-16.570368-20.284416-19.427328-13.142016-16.570368-14.2848-6.856704-20.284416q0-15.427584 10.856448-25.998336t25.71264-10.570752q8.57088 0 14.2848 2.85696 39.99744 15.427584 64.2816 53.139456t24.28416 81.137664zm146.276352 0q0 87.422976-48.56832 161.41824t-128.5632 107.707392q-7.428096 2.85696-14.2848 2.85696-15.427584 0-26.284032-10.856448t-10.856448-25.71264q0-22.284288 22.284288-33.712128 31.997952-16.570368 43.425792-25.141248 42.283008-30.855168 65.995776-77.423616t23.712768-99.136512-23.712768-99.136512-65.995776-77.423616q-11.42784-8.57088-43.425792-25.141248-22.284288-11.42784-22.284288-33.712128 0-14.856192 10.856448-25.71264t25.71264-10.856448q7.428096 0 14.856192 2.85696 79.99488 33.712128 128.5632 107.707392t48.56832 161.41824zm146.276352 0q0 131.42016-72.566784 241.41312t-193.130496 161.989632q-7.428096 2.85696-14.856192 2.85696-14.856192 0-25.71264-10.856448t-10.856448-25.71264q0-20.570112 22.284288-33.712128 3.999744-2.285568 12.85632-5.999616t12.85632-5.999616q26.284032-14.2848 46.854144-29.140992 70.281216-51.996672 109.707264-129.705984t39.426048-165.132288-39.426048-165.132288-109.707264-129.705984q-20.570112-14.856192-46.854144-29.140992-3.999744-2.285568-12.85632-5.999616t-12.85632-5.999616q-22.284288-13.142016-22.284288-33.712128 0-14.856192 10.856448-25.71264t25.71264-10.856448q7.428096 0 14.856192 2.85696 120.563712 51.996672 193.130496 161.989632t72.566784 241.41312z" }, null)]), createVNode("div", { "class": "uni-video-toast-value" }, [createVNode("div", { "style": { width: gestureState.volumeNew * 100 + "%" }, "class": "uni-video-toast-value-content" }, [createVNode("div", { "class": "uni-video-toast-volume-grids" }, [renderList(10, () => createVNode("div", { "class": "uni-video-toast-volume-grids-item" }, null))])], 4)])], 2), createVNode("div", { "class": { "uni-video-toast": true, "uni-video-toast-progress": gestureState.gestureType === "progress" } }, [createVNode("div", { "class": "uni-video-toast-title" }, [formatTime(gestureState.currentTimeNew), " / ", formatTime(videoState.duration)])], 2), createVNode("div", { "class": "uni-video-slots" }, [slots.default && slots.default()])], 40, ["onTouchstart", "onTouchend", "onTouchmove", "onFullscreenchange", "onWebkitfullscreenchange"])], 8, ["id"]); }; } }); const onWebInvokeAppService = ({ name, arg }) => { if (name === "postMessage") ; else { uni[name](arg); } }; const Invoke = /* @__PURE__ */ once(() => UniServiceJSBridge.on(ON_WEB_INVOKE_APP_SERVICE, onWebInvokeAppService)); const props$f = { src: { type: String, default: "" }, fullscreen: { type: Boolean, default: true } }; const index$c = /* @__PURE__ */ defineBuiltInComponent({ inheritAttrs: false, name: "WebView", props: props$f, setup(props2) { Invoke(); const rootRef = ref(null); const iframeRef = ref(null); const { $attrs, $excludeAttrs, $listeners } = useAttrs({ excludeListeners: true }); let _resize; const renderIframe = () => { const iframe = document.createElement("iframe"); watchEffect(() => { for (const key in $attrs.value) { if (hasOwn($attrs.value, key)) { const attr2 = $attrs.value[key]; iframe[key] = attr2; } } }); watchEffect(() => { iframe.src = getRealPath(props2.src); }); iframeRef.value = iframe; _resize = useWebViewSize(rootRef, iframeRef, props2.fullscreen); if (props2.fullscreen) { document.body.appendChild(iframe); } }; renderIframe(); onMounted(() => { var _a; _resize(); !props2.fullscreen && ((_a = rootRef.value) == null ? void 0 : _a.appendChild(iframeRef.value)); }); onActivated(() => { props2.fullscreen && (iframeRef.value.style.display = "block"); }); onDeactivated(() => { props2.fullscreen && (iframeRef.value.style.display = "none"); }); onBeforeUnmount(() => { props2.fullscreen && document.body.removeChild(iframeRef.value); }); return () => { return createVNode(Fragment, null, [createVNode("uni-web-view", mergeProps({ "class": props2.fullscreen ? "uni-webview--fullscreen" : "" }, $listeners.value, $excludeAttrs.value, { "ref": rootRef }), [createVNode(ResizeSensor, { "onResize": _resize }, null, 8, ["onResize"])], 16)]); }; } }); function useWebViewSize(rootRef, iframeRef, fullscreen) { const _resize = () => { var _a, _b; if (fullscreen) { const { top, left, width, height } = rootRef.value.getBoundingClientRect(); updateElementStyle(iframeRef.value, { position: "absolute", display: "block", border: "0", top: top + "px", left: left + "px", width: width + "px", height: height + "px" }); } else { updateElementStyle(iframeRef.value, { width: ((_a = rootRef.value) == null ? void 0 : _a.style.width) || "300px", height: ((_b = rootRef.value) == null ? void 0 : _b.style.height) || "150px" }); } }; return _resize; } let index$b = 0; function getJSONP(url, options, success, error) { var js = document.createElement("script"); var callbackKey = options.callback || "callback"; var callbackName = "__uni_jsonp_callback_" + index$b++; var timeout = options.timeout || 3e4; var timing; function end() { clearTimeout(timing); delete window[callbackName]; js.remove(); } window[callbackName] = (res) => { if (isFunction(success)) { success(res); } end(); }; js.onerror = () => { if (isFunction(error)) { error(); } end(); }; timing = setTimeout(function() { if (isFunction(error)) { error(); } end(); }, timeout); js.src = url + (url.indexOf("?") >= 0 ? "&" : "?") + callbackKey + "=" + callbackName; document.body.appendChild(js); } function createCallout(maps2) { function onAdd() { const div = this.div; const panes = this.getPanes(); panes.floatPane.appendChild(div); } function onRemove() { const parentNode = this.div.parentNode; if (parentNode) { parentNode.removeChild(this.div); } } function createAMapText() { const option = this.option; this.Text = new maps2.Text({ text: option.content, anchor: "bottom-center", // 设置文本标记锚点 offset: new maps2.Pixel(0, option.offsetY - 16), style: { padding: (option.padding || 8) + "px", "line-height": (option.fontSize || 14) + "px", "border-radius": (option.borderRadius || 0) + "px", "border-color": `${option.bgColor || "#fff"} transparent transparent`, "background-color": option.bgColor || "#fff", "box-shadow": "0 2px 6px 0 rgba(114, 124, 245, .5)", "text-align": "center", "font-size": (option.fontSize || 14) + "px", color: option.color || "#000" }, position: option.position }); const event = maps2.event || maps2.Event; event.addListener(this.Text, "click", () => { this.callback(); }); this.Text.setMap(option.map); } function createBMapText() { } function removeAMapText() { if (this.Text) { this.option.map.remove(this.Text); } } function removeBMapText() { if (this.Text) { this.option.map.remove(this.Text); } } class Callout { constructor(option = {}, callback) { this.createAMapText = createAMapText; this.removeAMapText = removeAMapText; this.createBMapText = createBMapText; this.removeBMapText = removeBMapText; this.onAdd = onAdd; this.construct = onAdd; this.onRemove = onRemove; this.destroy = onRemove; this.option = option || {}; const visible = this.visible = this.alwaysVisible = option.display === "ALWAYS"; if (getIsAMap()) { this.callback = callback; if (this.visible) { this.createAMapText(); } } else if (getIsBMap()) { if (this.visible) { this.createBMapText(); } } else { const map = option.map; this.position = option.position; this.index = 1; const div = this.div = document.createElement("div"); const divStyle = div.style; divStyle.position = "absolute"; divStyle.whiteSpace = "nowrap"; divStyle.transform = "translateX(-50%) translateY(-100%)"; divStyle.zIndex = "1"; divStyle.boxShadow = option.boxShadow || "none"; divStyle.display = visible ? "block" : "none"; const triangle = this.triangle = document.createElement("div"); triangle.setAttribute( "style", "position: absolute;white-space: nowrap;border-width: 4px;border-style: solid;border-color: #fff transparent transparent;border-image: initial;font-size: 12px;padding: 0px;background-color: transparent;width: 0px;height: 0px;transform: translate(-50%, 100%);left: 50%;bottom: 0;" ); this.setStyle(option); div.appendChild(triangle); if (map) { this.setMap(map); } } } set onclick(callback) { this.div.onclick = callback; } get onclick() { return this.div.onclick; } setOption(option) { this.option = option; if (option.display === "ALWAYS") { this.alwaysVisible = this.visible = true; } else { this.alwaysVisible = false; } if (getIsAMap()) { if (this.visible) { this.createAMapText(); } } else if (getIsBMap()) { if (this.visible) { this.createBMapText(); } } else { this.setPosition(option.position); this.setStyle(option); } } setStyle(option) { const div = this.div; const divStyle = div.style; div.innerText = option.content || ""; divStyle.lineHeight = (option.fontSize || 14) + "px"; divStyle.fontSize = (option.fontSize || 14) + "px"; divStyle.padding = (option.padding || 8) + "px"; divStyle.color = option.color || "#000"; divStyle.borderRadius = (option.borderRadius || 0) + "px"; divStyle.backgroundColor = option.bgColor || "#fff"; divStyle.marginTop = "-" + ((option.top || 0) + 5) + "px"; this.triangle.style.borderColor = `${option.bgColor || "#fff"} transparent transparent`; } setPosition(position) { this.position = position; this.draw(); } draw() { const overlayProjection = this.getProjection(); if (!this.position || !this.div || !overlayProjection) { return; } const pixel = overlayProjection.fromLatLngToDivPixel( this.position ); const divStyle = this.div.style; divStyle.left = pixel.x + "px"; divStyle.top = pixel.y + "px"; } changed() { const divStyle = this.div.style; divStyle.display = this.visible ? "block" : "none"; } } if (!getIsAMap() && !getIsBMap()) { const overlay = new (maps2.OverlayView || maps2.Overlay)(); Callout.prototype.setMap = overlay.setMap; Callout.prototype.getMap = overlay.getMap; Callout.prototype.getPanes = overlay.getPanes; Callout.prototype.getProjection = overlay.getProjection; Callout.prototype.map_changed = overlay.map_changed; Callout.prototype.set = overlay.set; Callout.prototype.get = overlay.get; Callout.prototype.setOptions = overlay.setValues; Callout.prototype.bindTo = overlay.bindTo; Callout.prototype.bindsTo = overlay.bindsTo; Callout.prototype.notify = overlay.notify; Callout.prototype.setValues = overlay.setValues; Callout.prototype.unbind = overlay.unbind; Callout.prototype.unbindAll = overlay.unbindAll; Callout.prototype.addListener = overlay.addListener; } return Callout; } let maps; const callbacksMap = {}; const GOOGLE_MAP_CALLBACKNAME = "__map_callback__"; function loadMaps(libraries, callback) { const mapInfo = getMapInfo(); if (!mapInfo.key) { console.error("Map key not configured."); return; } const callbacks2 = callbacksMap[mapInfo.type] = callbacksMap[mapInfo.type] || []; if (maps) { callback(maps); } else if (window[mapInfo.type] && window[mapInfo.type].maps) { maps = getIsAMap() || getIsBMap() ? window[mapInfo.type] : window[mapInfo.type].maps; maps.Callout = maps.Callout || createCallout(maps); callback(maps); } else if (callbacks2.length) { callbacks2.push(callback); } else { callbacks2.push(callback); const globalExt = window; const callbackName = GOOGLE_MAP_CALLBACKNAME + mapInfo.type; globalExt[callbackName] = function() { delete globalExt[callbackName]; maps = getIsAMap() || getIsBMap() ? window[mapInfo.type] : window[mapInfo.type].maps; maps.Callout = createCallout(maps); callbacks2.forEach((callback2) => callback2(maps)); callbacks2.length = 0; }; if (getIsAMap()) { handleAMapSecurityPolicy(mapInfo); } const script = document.createElement("script"); let src = getScriptBaseUrl(mapInfo.type); if (mapInfo.type === MapType.QQ) { libraries.push("geometry"); } if (libraries.length) { src += `libraries=${libraries.join("%2C")}&`; } if (mapInfo.type === MapType.BMAP) { script.src = `${src}ak=${mapInfo.key}&callback=${callbackName}`; } else { script.src = `${src}key=${mapInfo.key}&callback=${callbackName}`; } script.onerror = function() { console.error("Map load failed."); }; document.body.appendChild(script); } } const getScriptBaseUrl = (mapType) => { const urlMap = { qq: "https://map.qq.com/api/js?v=2.exp&", google: "https://maps.googleapis.com/maps/api/js?", AMap: "https://webapi.amap.com/maps?v=2.0&", BMapGL: "https://api.map.baidu.com/api?type=webgl&v=1.0&" }; return urlMap[mapType]; }; function handleAMapSecurityPolicy(mapInfo) { window._AMapSecurityConfig = { securityJsCode: mapInfo.securityJsCode || "", serviceHost: mapInfo.serviceHost || "" }; } const ICON_PATH_LOCTAION = "M13.3334375 16 q0.033125 1.1334375 0.783125 1.8834375 q0.75 0.75 1.8834375 0.75 q1.1334375 0 1.8834375 -0.75 q0.75 -0.75 0.75 -1.8834375 q0 -1.1334375 -0.75 -1.8834375 q-0.75 -0.75 -1.8834375 -0.75 q-1.1334375 0 -1.8834375 0.75 q-0.75 0.75 -0.783125 1.8834375 ZM30.9334375 14.9334375 l-1.1334375 0 q-0.5 -5.2 -4.0165625 -8.716875 q-3.516875 -3.5165625 -8.716875 -4.0165625 l0 -1.1334375 q0 -0.4665625 -0.3 -0.7665625 q-0.3 -0.3 -0.7665625 -0.3 q-0.4665625 0 -0.7665625 0.3 q-0.3 0.3 -0.3 0.7665625 l0 1.1334375 q-5.2 0.5 -8.716875 4.0165625 q-3.5165625 3.516875 -4.0165625 8.716875 l-1.1334375 0 q-0.4665625 0 -0.7665625 0.3 q-0.3 0.3 -0.3 0.7665625 q0 0.4665625 0.3 0.7665625 q0.3 0.3 0.7665625 0.3 l1.1334375 0 q0.5 5.2 4.0165625 8.716875 q3.516875 3.5165625 8.716875 4.0165625 l0 1.1334375 q0 0.4665625 0.3 0.7665625 q0.3 0.3 0.7665625 0.3 q0.4665625 0 0.7665625 -0.3 q0.3 -0.3 0.3 -0.7665625 l0 -1.1334375 q5.2 -0.5 8.716875 -4.0165625 q3.5165625 -3.516875 4.0165625 -8.716875 l1.1334375 0 q0.4665625 0 0.7665625 -0.3 q0.3 -0.3 0.3 -0.7665625 q0 -0.4665625 -0.3 -0.7665625 q-0.3 -0.3 -0.7665625 -0.3 ZM17.0665625 27.6665625 l0 -2.0665625 q0 -0.4665625 -0.3 -0.7665625 q-0.3 -0.3 -0.7665625 -0.3 q-0.4665625 0 -0.7665625 0.3 q-0.3 0.3 -0.3 0.7665625 l0 2.0665625 q-4.3 -0.4665625 -7.216875 -3.383125 q-2.916875 -2.916875 -3.3834375 -7.216875 l2.0665625 0 q0.4665625 0 0.7665625 -0.3 q0.3 -0.3 0.3 -0.7665625 q0 -0.4665625 -0.3 -0.7665625 q-0.3 -0.3 -0.7665625 -0.3 l-2.0665625 0 q0.4665625 -4.3 3.3834375 -7.216875 q2.9165625 -2.916875 7.216875 -3.3834375 l0 2.0665625 q0 0.4665625 0.3 0.7665625 q0.3 0.3 0.7665625 0.3 q0.4665625 0 0.7665625 -0.3 q0.3 -0.3 0.3 -0.7665625 l0 -2.0665625 q4.3 0.4665625 7.216875 3.3834375 q2.9165625 2.9165625 3.383125 7.216875 l-2.0665625 0 q-0.4665625 0 -0.7665625 0.3 q-0.3 0.3 -0.3 0.7665625 q0 0.4665625 0.3 0.7665625 q0.3 0.3 0.7665625 0.3 l2.0665625 0 q-0.4665625 4.3 -3.383125 7.216875 q-2.916875 2.9165625 -7.216875 3.383125 Z"; const ICON_PATH_ORIGIN = ""; const ICON_PATH_TARGET = ""; var MapType = /* @__PURE__ */ ((MapType2) => { MapType2["QQ"] = "qq"; MapType2["GOOGLE"] = "google"; MapType2["AMAP"] = "AMap"; MapType2["BMAP"] = "BMapGL"; MapType2["UNKNOWN"] = ""; return MapType2; })(MapType || {}); function getMapInfo() { if (__uniConfig.bMapKey) { return { type: "BMapGL", key: __uniConfig.bMapKey }; } if (__uniConfig.qqMapKey) { return { type: "qq", key: __uniConfig.qqMapKey }; } if (__uniConfig.googleMapKey) { return { type: "google", key: __uniConfig.googleMapKey }; } if (__uniConfig.aMapKey) { return { type: "AMap", key: __uniConfig.aMapKey, securityJsCode: __uniConfig.aMapSecurityJsCode, serviceHost: __uniConfig.aMapServiceHost }; } return { type: "", key: "" }; } let IS_AMAP = false; let hasGetIsAMap = false; const getIsAMap = () => { if (hasGetIsAMap) { return IS_AMAP; } else { hasGetIsAMap = true; return IS_AMAP = getMapInfo().type === "AMap"; } }; const getIsBMap = () => { return getMapInfo().type === "BMapGL"; }; function translateCoordinateSystem(type, coords, skip) { const mapInfo = getMapInfo(); const wgs84Map = [ "google" /* GOOGLE */ ]; if (type && type.toUpperCase() === "WGS84" || wgs84Map.includes(mapInfo.type) || skip) { return Promise.resolve(coords); } if (mapInfo.type === "qq") { return new Promise((resolve) => { getJSONP( `https://apis.map.qq.com/jsapi?qt=translate&type=1&points=${coords.longitude},${coords.latitude}&key=${mapInfo.key}&output=jsonp&pf=jsapi&ref=jsapi`, { callback: "cb" }, (res) => { if ("detail" in res && "points" in res.detail && res.detail.points.length) { const { lng, lat } = res.detail.points[0]; resolve({ longitude: lng, latitude: lat, altitude: coords.altitude, accuracy: coords.accuracy, altitudeAccuracy: coords.altitudeAccuracy, heading: coords.heading, speed: coords.speed }); } else { resolve(coords); } }, () => resolve(coords) ); }); } if (mapInfo.type === "AMap") { return new Promise((resolve) => { loadMaps([], () => { window.AMap.convertFrom( [coords.longitude, coords.latitude], "gps", (_, res) => { if (res.info === "ok" && res.locations.length) { const { lat, lng } = res.locations[0]; resolve({ longitude: lng, latitude: lat, altitude: coords.altitude, accuracy: coords.accuracy, altitudeAccuracy: coords.altitudeAccuracy, heading: coords.heading, speed: coords.speed }); } else { resolve(coords); } } ); }); }); } return Promise.reject(new Error("translate coordinate system faild")); } const props$e = { id: { type: [Number, String], default: "" }, latitude: { type: [Number, String], require: true }, longitude: { type: [Number, String], require: true }, title: { type: String, default: "" }, iconPath: { type: String, require: true }, rotate: { type: [Number, String], default: 0 }, alpha: { type: [Number, String], default: 1 }, width: { type: [Number, String], default: "" }, height: { type: [Number, String], default: "" }, callout: { type: Object, default: null }, label: { type: Object, default: null }, anchor: { type: Object, default: null }, clusterId: { type: [Number, String], default: "" }, customCallout: { type: Object, default: null }, ariaLabel: { type: String, default: "" } }; function useMarkerLabelStyle(id2) { const className = "uni-map-marker-label-" + id2; const styleEl = document.createElement("style"); styleEl.id = className; document.head.appendChild(styleEl); onUnmounted(() => { styleEl.remove(); }); return function updateMarkerLabelStyle(style) { const newStyle = Object.assign({}, style, { position: "absolute", top: "70px", borderStyle: "solid" }); const div = document.createElement("div"); Object.keys(newStyle).forEach((key) => { div.style[key] = newStyle[key] || ""; }); styleEl.innerText = `.${className}{${div.getAttribute("style")}}`; return className; }; } const MapMarker = /* @__PURE__ */ defineSystemComponent({ name: "MapMarker", props: props$e, setup(props2) { const id2 = String(!isNaN(Number(props2.id)) ? props2.id : ""); const onMapReady = inject("onMapReady"); const updateMarkerLabelStyle = useMarkerLabelStyle(id2); let marker; function removeMarker() { if (marker) { if (marker.label && "setMap" in marker.label) { marker.label.setMap(null); } if (marker.callout) { removeMarkerCallout(marker.callout); } marker.setMap(null); } } function removeMarkerCallout(callout) { if (getIsAMap()) { callout.removeAMapText(); } else { callout.setMap(null); } } onMapReady((map, maps2, trigger) => { function updateMarker(option) { const title = option.title; let position; if (getIsAMap()) { position = new maps2.LngLat(option.longitude, option.latitude); } else if (getIsBMap()) { position = new maps2.Point(option.longitude, option.latitude); } else { position = new maps2.LatLng(option.latitude, option.longitude); } const img = new Image(); let imgHeight = 0; img.onload = () => { const anchor = option.anchor || {}; let icon; let w; let h2; let top; let x = typeof anchor.x === "number" ? anchor.x : 0.5; let y = typeof anchor.y === "number" ? anchor.y : 1; if (option.iconPath && (option.width || option.height)) { w = option.width || img.width / img.height * option.height; h2 = option.height || img.height / img.width * option.width; } else { w = img.width / 2; h2 = img.height / 2; } imgHeight = h2; top = h2 - (h2 - y * h2); if ("MarkerImage" in maps2) { icon = new maps2.MarkerImage(img.src, null, null, new maps2.Point(x * w, y * h2), new maps2.Size(w, h2)); } else if ("Icon" in maps2) { icon = new maps2.Icon({ image: img.src, size: new maps2.Size(w, h2), imageSize: new maps2.Size(w, h2), imageOffset: new maps2.Pixel(x * w, y * h2) }); } else { icon = { url: img.src, anchor: new maps2.Point(x, y), size: new maps2.Size(w, h2) }; } if (getIsBMap()) { marker = new maps2.Marker(new maps2.Point(position.lng, position.lat)); map.addOverlay(marker); } else { marker.setPosition(position); marker.setIcon(icon); } if ("setRotation" in marker) { marker.setRotation(option.rotate || 0); } const labelOpt = option.label || {}; if ("label" in marker) { marker.label.setMap(null); delete marker.label; } let label; if (labelOpt.content) { const labelStyle = { borderColor: labelOpt.borderColor, borderWidth: (Number(labelOpt.borderWidth) || 0) + "px", padding: (Number(labelOpt.padding) || 0) + "px", borderRadius: (Number(labelOpt.borderRadius) || 0) + "px", backgroundColor: labelOpt.bgColor, color: labelOpt.color, fontSize: (labelOpt.fontSize || 14) + "px", lineHeight: (labelOpt.fontSize || 14) + "px", marginLeft: (Number(labelOpt.anchorX || labelOpt.x) || 0) + "px", marginTop: (Number(labelOpt.anchorY || labelOpt.y) || 0) + "px" }; if ("Label" in maps2) { label = new maps2.Label({ position, map, clickable: false, content: labelOpt.content, style: labelStyle }); marker.label = label; } else if ("setLabel" in marker) { if (getIsAMap()) { const content = `
${labelOpt.content}
`; marker.setLabel({ content, direction: "bottom-right" }); } else { const className = updateMarkerLabelStyle(labelStyle); marker.setLabel({ text: labelOpt.content, color: labelStyle.color, fontSize: labelStyle.fontSize, className }); } } } const calloutOpt = option.callout || {}; let callout = marker.callout; let calloutStyle; if (calloutOpt.content || title) { if (getIsAMap() && calloutOpt.content) { calloutOpt.content = calloutOpt.content.replaceAll("\n", "
"); } const boxShadow = "0px 0px 3px 1px rgba(0,0,0,0.5)"; let offsetY = -imgHeight / 2; if (option.width || option.height) { offsetY += 14 - imgHeight / 2; } calloutStyle = calloutOpt.content ? { position, map, top, // handle AMap callout offset offsetY, content: calloutOpt.content, color: calloutOpt.color, fontSize: calloutOpt.fontSize, borderRadius: calloutOpt.borderRadius, bgColor: calloutOpt.bgColor, padding: calloutOpt.padding, boxShadow: calloutOpt.boxShadow || boxShadow, display: calloutOpt.display } : { position, map, top, // handle AMap callout offset offsetY, content: title, boxShadow }; if (callout) { callout.setOption(calloutStyle); } else { if (getIsAMap()) { const callback = (id3) => { if (id3 !== "") { trigger("callouttap", {}, { markerId: Number(id3) }); } }; callout = marker.callout = new maps2.Callout(calloutStyle, callback); } else { callout = marker.callout = new maps2.Callout(calloutStyle); callout.div.onclick = function($event) { if (id2 !== "") { trigger("callouttap", $event, { markerId: Number(id2) }); } $event.stopPropagation(); $event.preventDefault(); }; if (getMapInfo().type === MapType.GOOGLE) { callout.div.ontouchstart = function($event) { $event.stopPropagation(); }; callout.div.onpointerdown = function($event) { $event.stopPropagation(); }; } } } } else { if (callout) { removeMarkerCallout(callout); delete marker.callout; } } }; if (option.iconPath) { img.src = getRealPath(option.iconPath); } else { console.error("Marker.iconPath is required."); } } function addMarker(props3) { if (!getIsBMap()) { marker = new maps2.Marker({ map, flat: true, autoRotation: false }); } updateMarker(props3); const MapsEvent = maps2.event || maps2.Event; if (getIsBMap()) ; else { MapsEvent.addListener(marker, "click", () => { const callout = marker.callout; if (callout && !callout.alwaysVisible) { if (getIsAMap()) { callout.visible = !callout.visible; if (callout.visible) { marker.callout.createAMapText(); } else { marker.callout.removeAMapText(); } } else { callout.set("visible", !callout.visible); if (callout.visible) { const div = callout.div; const parent = div.parentNode; parent.removeChild(div); parent.appendChild(div); } } } if (id2) { trigger("markertap", {}, { markerId: Number(id2), latitude: props3.latitude, longitude: props3.longitude }); } }); } } addMarker(props2); watch(props2, updateMarker); }); if (id2) { const addMapChidlContext = inject("addMapChidlContext"); const removeMapChidlContext = inject("removeMapChidlContext"); const context = { id: id2, translate(data) { onMapReady((map, maps2, trigger) => { const destination = data.destination; const duration = data.duration; const autoRotate = !!data.autoRotate; let rotate = Number(data.rotate) || 0; let rotation = 0; if ("getRotation" in marker) { rotation = marker.getRotation(); } const a2 = marker.getPosition(); const b = new maps2.LatLng(destination.latitude, destination.longitude); const distance2 = maps2.geometry.spherical.computeDistanceBetween(a2, b) / 1e3; const time = (typeof duration === "number" ? duration : 1e3) / (1e3 * 60 * 60); const speed = distance2 / time; const MapsEvent = maps2.event || maps2.Event; const movingEvent = MapsEvent.addListener(marker, "moving", (e2) => { const latLng = e2.latLng; const label = marker.label; if (label) { label.setPosition(latLng); } const callout = marker.callout; if (callout) { callout.setPosition(latLng); } }); const event = MapsEvent.addListener(marker, "moveend", () => { event.remove(); movingEvent.remove(); marker.lastPosition = a2; marker.setPosition(b); const label = marker.label; if (label) { label.setPosition(b); } const callout = marker.callout; if (callout) { callout.setPosition(b); } const cb = data.animationEnd; if (isFunction(cb)) { cb(); } }); let lastRtate = 0; if (autoRotate) { if (marker.lastPosition) { lastRtate = maps2.geometry.spherical.computeHeading(marker.lastPosition, a2); } rotate = maps2.geometry.spherical.computeHeading(a2, b) - lastRtate; } if ("setRotation" in marker) { marker.setRotation(rotation + rotate); } if ("moveTo" in marker) { marker.moveTo(b, speed); } else { marker.setPosition(b); MapsEvent.trigger(marker, "moveend", {}); } }); } }; addMapChidlContext(context); onUnmounted(() => removeMapChidlContext(context)); } onUnmounted(removeMarker); return () => { return null; }; } }); function hexToRgba(hex) { if (!hex) { return { r: 0, g: 0, b: 0, a: 0 }; } let tmpHex = hex.slice(1); const tmpHexLen = tmpHex.length; if (![3, 4, 6, 8].includes(tmpHexLen)) { return { r: 0, g: 0, b: 0, a: 0 }; } if (tmpHexLen === 3 || tmpHexLen === 4) { tmpHex = tmpHex.replace(/(\w{1})/g, "$1$1"); } let [sr, sg, sb, sa] = tmpHex.match(/(\w{2})/g); const r = parseInt(sr, 16), g2 = parseInt(sg, 16), b = parseInt(sb, 16); if (!sa) { return { r, g: g2, b, a: 1 }; } return { r, g: g2, b, a: (`0x100${sa}` - 65536) / 255 }; } const props$d = { points: { type: Array, require: true }, color: { type: String, default: "#000000" }, width: { type: [Number, String], default: "" }, dottedLine: { type: [Boolean, String], default: false }, arrowLine: { type: [Boolean, String], default: false }, arrowIconPath: { type: String, default: "" }, borderColor: { type: String, default: "#000000" }, borderWidth: { type: [Number, String], default: "" }, colorList: { type: Array, default() { return []; } }, level: { type: String, default: "" } }; const MapPolyline = /* @__PURE__ */ defineSystemComponent({ name: "MapPolyline", props: props$d, setup(props2) { const onMapReady = inject("onMapReady"); let polyline; let polylineBorder; function removePolyline() { if (polyline) { polyline.setMap(null); } if (polylineBorder) { polylineBorder.setMap(null); } } onMapReady((map, maps2) => { function updatePolyline(option) { removePolyline(); addPolyline(option); } function addPolyline(option) { const path = []; option.points.forEach((point) => { let pointPosition; if (getIsAMap()) { pointPosition = [point.longitude, point.latitude]; } else if (getIsBMap()) { pointPosition = new maps2.Point(point.longitude, point.latitude); } else { pointPosition = new maps2.LatLng(point.latitude, point.longitude); } path.push(pointPosition); }); const strokeWeight = Number(option.width) || 1; const { r: sr, g: sg, b: sb, a: sa } = hexToRgba(option.color); const { r: br, g: bg, b: bb, a: ba } = hexToRgba(option.borderColor); const polylineOptions = { map, clickable: false, path, strokeWeight, strokeColor: option.color || void 0, strokeDashStyle: option.dottedLine ? "dash" : "solid" }; const borderWidth = Number(option.borderWidth) || 0; const polylineBorderOptions = { map, clickable: false, path, strokeWeight: strokeWeight + borderWidth * 2, strokeColor: option.borderColor || void 0, strokeDashStyle: option.dottedLine ? "dash" : "solid" }; if ("Color" in maps2) { polylineOptions.strokeColor = new maps2.Color(sr, sg, sb, sa); polylineBorderOptions.strokeColor = new maps2.Color(br, bg, bb, ba); } else { polylineOptions.strokeColor = `rgb(${sr}, ${sg}, ${sb})`; polylineOptions.strokeOpacity = sa; polylineBorderOptions.strokeColor = `rgb(${br}, ${bg}, ${bb})`; polylineBorderOptions.strokeOpacity = ba; } if (borderWidth) { polylineBorder = new maps2.Polyline(polylineBorderOptions); } if (getIsBMap()) { polyline = new maps2.Polyline(polylineOptions.path, polylineOptions); map.addOverlay(polyline); } else { polyline = new maps2.Polyline(polylineOptions); } } addPolyline(props2); watch(props2, updatePolyline); }); onUnmounted(removePolyline); return () => { return null; }; } }); const props$c = { latitude: { type: [Number, String], require: true }, longitude: { type: [Number, String], require: true }, color: { type: String, default: "#000000" }, fillColor: { type: String, default: "#00000000" }, radius: { type: [Number, String], require: true }, strokeWidth: { type: [Number, String], default: "" }, level: { type: String, default: "" } }; const MapCircle = /* @__PURE__ */ defineSystemComponent({ name: "MapCircle", props: props$c, setup(props2) { const onMapReady = inject("onMapReady"); let circle; function removeCircle() { if (circle) { circle.setMap(null); } } onMapReady((map, maps2) => { function updateCircle(option) { removeCircle(); addCircle(option); } function addCircle(option) { const center = getIsAMap() || getIsBMap() ? [option.longitude, option.latitude] : new maps2.LatLng(option.latitude, option.longitude); const circleOptions = { map, center, clickable: false, radius: option.radius, strokeWeight: Number(option.strokeWidth) || 1, strokeDashStyle: "solid" }; if (getIsBMap()) { circleOptions.strokeColor = option.color; circleOptions.fillColor = option.fillColor || "#000"; circleOptions.fillOpacity = 1; } else { const { r: fr, g: fg, b: fb, a: fa } = hexToRgba(option.fillColor); const { r: sr, g: sg, b: sb, a: sa } = hexToRgba(option.color); if ("Color" in maps2) { circleOptions.fillColor = new maps2.Color(fr, fg, fb, fa); circleOptions.strokeColor = new maps2.Color(sr, sg, sb, sa); } else { circleOptions.fillColor = `rgb(${fr}, ${fg}, ${fb})`; circleOptions.fillOpacity = fa; circleOptions.strokeColor = `rgb(${sr}, ${sg}, ${sb})`; circleOptions.strokeOpacity = sa; } } if (getIsBMap()) { let pt = new maps2.Point( // @ts-ignore circleOptions.center[0], // @ts-ignore circleOptions.center[1] ); circle = new maps2.Circle(pt, circleOptions.radius, circleOptions); map.addOverlay(circle); } else { circle = new maps2.Circle(circleOptions); if (getIsAMap()) { map.add(circle); } } } addCircle(props2); watch(props2, updateCircle); }); onUnmounted(removeCircle); return () => { return null; }; } }); const props$b = { id: { type: [Number, String], default: "" }, position: { type: Object, required: true }, iconPath: { type: String, required: true }, clickable: { type: [Boolean, String], default: "" }, trigger: { type: Function, required: true } }; const MapControl = /* @__PURE__ */ defineSystemComponent({ name: "MapControl", props: props$b, setup(props2) { const imgPath = computed(() => getRealPath(props2.iconPath)); const positionStyle = computed(() => { let positionStyle2 = `top:${props2.position.top || 0}px;left:${props2.position.left || 0}px;`; if (props2.position.width) { positionStyle2 += `width:${props2.position.width}px;`; } if (props2.position.height) { positionStyle2 += `height:${props2.position.height}px;`; } return positionStyle2; }); const handleClick = ($event) => { if (props2.clickable) { props2.trigger("controltap", $event, { controlId: props2.id }); } }; return () => { return createVNode("div", { "class": "uni-map-control" }, [createVNode("img", { "src": imgPath.value, "style": positionStyle.value, "class": "uni-map-control-icon", "onClick": handleClick }, null, 12, ["src", "onClick"])]); }; } }); const initInnerAudioContextEventOnce = /* @__PURE__ */ once(() => { innerAudioContextEventNames.forEach((eventName) => { InnerAudioContext.prototype[eventName] = function(callback) { if (isFunction(callback)) { this._events[eventName].push(callback); } }; }); innerAudioContextOffEventNames.forEach((eventName) => { InnerAudioContext.prototype[eventName] = function(callback) { var handle = this._events[eventName.replace("off", "on")]; var index2 = handle.indexOf(callback); if (index2 >= 0) { handle.splice(index2, 1); } }; }); }); class InnerAudioContext { /** * 音频上下文初始化 */ constructor() { this._src = ""; var audio = this._audio = new Audio(); this._stoping = false; const propertys = [ "src", "autoplay", "loop", "duration", "currentTime", "paused", "volume" ]; propertys.forEach((property) => { Object.defineProperty(this, property, { set: property === "src" ? (src) => { audio.src = getRealPath(src); this._src = src; return src; } : (val) => { audio[property] = val; return val; }, get: property === "src" ? () => { return this._src; } : () => { return audio[property]; } }); }); this.startTime = 0; Object.defineProperty(this, "obeyMuteSwitch", { set: () => false, get: () => false }); Object.defineProperty(this, "buffered", { get() { var buffered = audio.buffered; if (buffered.length) { return buffered.end(buffered.length - 1); } else { return 0; } } }); this._events = {}; innerAudioContextEventNames.forEach((eventName) => { this._events[eventName] = []; }); audio.addEventListener("loadedmetadata", () => { var startTime = Number(this.startTime) || 0; if (startTime > 0) { audio.currentTime = startTime; } }); var stopEventNames = ["canplay", "pause", "seeking", "seeked", "timeUpdate"]; var eventNames = stopEventNames.concat([ "play", "ended", "error", "waiting" ]); eventNames.forEach((eventName) => { audio.addEventListener( eventName.toLowerCase(), () => { if (this._stoping && stopEventNames.indexOf(eventName) >= 0) { return; } const EventName = `on${eventName.slice(0, 1).toUpperCase()}${eventName.slice(1)}`; this._events[EventName].forEach((callback) => { callback(); }); }, false ); }); initInnerAudioContextEventOnce(); } /** * 播放 */ play() { this._stoping = false; this._audio.play(); } /** * 暂停 */ pause() { this._audio.pause(); } /** * 停止 */ stop() { this._stoping = true; this._audio.pause(); this._audio.currentTime = 0; this._events.onStop.forEach((callback) => { callback(); }); } /** * 跳转到 * @param {number} position */ seek(position) { this._stoping = false; position = Number(position); if (typeof position === "number" && !isNaN(position)) { this._audio.currentTime = position; } } /** * 销毁 */ destroy() { this.stop(); } } const createInnerAudioContext = /* @__PURE__ */ defineSyncApi( API_CREATE_INNER_AUDIO_CONTEXT, () => { return new InnerAudioContext(); } ); const makePhoneCall = /* @__PURE__ */ defineAsyncApi( API_MAKE_PHONE_CALL, ({ phoneNumber }, { resolve }) => { window.location.href = `tel:${phoneNumber}`; return resolve(); }, MakePhoneCallProtocol ); const UUID_KEY = "__DC_STAT_UUID"; const storage = navigator.cookieEnabled && (window.localStorage || window.sessionStorage) || {}; let deviceId; function deviceId$1() { deviceId = deviceId || storage[UUID_KEY]; if (!deviceId) { deviceId = Date.now() + "" + Math.floor(Math.random() * 1e7); try { storage[UUID_KEY] = deviceId; } catch (error) { } } return deviceId; } function IEVersion() { const userAgent = navigator.userAgent; const isIE = userAgent.indexOf("compatible") > -1 && userAgent.indexOf("MSIE") > -1; const isEdge = userAgent.indexOf("Edge") > -1 && !isIE; const isIE11 = userAgent.indexOf("Trident") > -1 && userAgent.indexOf("rv:11.0") > -1; if (isIE) { const reIE = new RegExp("MSIE (\\d+\\.\\d+);"); reIE.test(userAgent); const fIEVersion = parseFloat(RegExp.$1); if (fIEVersion > 6) { return fIEVersion; } else { return 6; } } else if (isEdge) { return -1; } else if (isIE11) { return 11; } else { return -1; } } function getTheme() { if (__uniConfig.darkmode !== true) return isString(__uniConfig.darkmode) ? __uniConfig.darkmode : "light"; try { return window.matchMedia("(prefers-color-scheme: light)").matches ? "light" : "dark"; } catch (error) { return "light"; } } function getBrowserInfo() { let osname; let osversion = "0"; let model = ""; let deviceType = "phone"; const language = navigator.language; if (isIOS$1) { osname = "iOS"; const osversionFind = ua.match(/OS\s([\w_]+)\slike/); if (osversionFind) { osversion = osversionFind[1].replace(/_/g, "."); } const modelFind = ua.match(/\(([a-zA-Z]+);/); if (modelFind) { model = modelFind[1]; } } else if (isAndroid) { osname = "Android"; const osversionFind = ua.match(/Android[\s/]([\w\.]+)[;\s]/); if (osversionFind) { osversion = osversionFind[1]; } const infoFind = ua.match(/\((.+?)\)/); const infos = infoFind ? infoFind[1].split(";") : ua.split(" "); const otherInfo = [ /\bAndroid\b/i, /\bLinux\b/i, /\bU\b/i, /^\s?[a-z][a-z]$/i, /^\s?[a-z][a-z]-[a-z][a-z]$/i, /\bwv\b/i, /\/[\d\.,]+$/, /^\s?[\d\.,]+$/, /\bBrowser\b/i, /\bMobile\b/i ]; for (let i = 0; i < infos.length; i++) { const info = infos[i]; if (info.indexOf("Build") > 0) { model = info.split("Build")[0].trim(); break; } let other; for (let o2 = 0; o2 < otherInfo.length; o2++) { if (otherInfo[o2].test(info)) { other = true; break; } } if (!other) { model = info.trim(); break; } } } else if (isIPadOS) { model = "iPad"; osname = "iOS"; deviceType = "pad"; osversion = isFunction(window.BigInt) ? "14.0" : "13.0"; } else if (isWindows || isMac || isLinux) { model = "PC"; osname = "PC"; deviceType = "pc"; osversion = "0"; let osversionFind = ua.match(/\((.+?)\)/)[1]; if (isWindows) { osname = "Windows"; switch (isWindows[1]) { case "5.1": osversion = "XP"; break; case "6.0": osversion = "Vista"; break; case "6.1": osversion = "7"; break; case "6.2": osversion = "8"; break; case "6.3": osversion = "8.1"; break; case "10.0": osversion = "10"; break; } const framework = osversionFind && osversionFind.match(/[Win|WOW]([\d]+)/); if (framework) { osversion += ` x${framework[1]}`; } } else if (isMac) { osname = "macOS"; const _osversion = osversionFind && osversionFind.match(/Mac OS X (.+)/) || ""; if (osversion) { osversion = _osversion[1].replace(/_/g, "."); if (osversion.indexOf(";") !== -1) { osversion = osversion.split(";")[0]; } } } else if (isLinux) { osname = "Linux"; const _osversion = osversionFind && osversionFind.match(/Linux (.*)/) || ""; if (_osversion) { osversion = _osversion[1]; if (osversion.indexOf(";") !== -1) { osversion = osversion.split(";")[0]; } } } } else { osname = "Other"; osversion = "0"; deviceType = "unknown"; } const system = `${osname} ${osversion}`; const platform = osname.toLocaleLowerCase(); let browserName = ""; let browserVersion = String(IEVersion()); if (browserVersion !== "-1") { browserName = "IE"; } else { const browseVendors = ["Version", "Firefox", "Chrome", "Edge{0,1}"]; const vendors = ["Safari", "Firefox", "Chrome", "Edge"]; for (let index2 = 0; index2 < browseVendors.length; index2++) { const vendor = browseVendors[index2]; const reg = new RegExp(`(${vendor})/(\\S*)\\b`); if (reg.test(ua)) { browserName = vendors[index2]; browserVersion = ua.match(reg)[2]; } } } let deviceOrientation = "portrait"; const orientation = typeof window.screen.orientation === "undefined" ? window.orientation : window.screen.orientation.angle; deviceOrientation = Math.abs(orientation) === 90 ? "landscape" : "portrait"; return { deviceBrand: void 0, brand: void 0, deviceModel: model, deviceOrientation, model, system, platform, browserName: browserName.toLocaleLowerCase(), browserVersion, language, deviceType, ua, osname, osversion, theme: getTheme() }; } const getWindowInfo = /* @__PURE__ */ defineSyncApi( "getWindowInfo", () => { const pixelRatio2 = window.devicePixelRatio; const screenFix = getScreenFix(); const landscape = isLandscape(screenFix); const screenWidth = getScreenWidth(screenFix, landscape); const screenHeight = getScreenHeight(screenFix, landscape); const windowWidth = getWindowWidth(screenWidth); let windowHeight = window.innerHeight; const statusBarHeight = safeAreaInsets$1.top; const safeArea = { left: safeAreaInsets$1.left, right: windowWidth - safeAreaInsets$1.right, top: safeAreaInsets$1.top, bottom: windowHeight - safeAreaInsets$1.bottom, width: windowWidth - safeAreaInsets$1.left - safeAreaInsets$1.right, height: windowHeight - safeAreaInsets$1.top - safeAreaInsets$1.bottom }; const { top: windowTop, bottom: windowBottom } = getWindowOffset(); windowHeight -= windowTop; windowHeight -= windowBottom; return { windowTop, windowBottom, windowWidth, windowHeight, pixelRatio: pixelRatio2, screenWidth, screenHeight, statusBarHeight, safeArea, safeAreaInsets: { top: safeAreaInsets$1.top, right: safeAreaInsets$1.right, bottom: safeAreaInsets$1.bottom, left: safeAreaInsets$1.left }, screenTop: screenHeight - windowHeight }; } ); let browserInfo; let _initBrowserInfo = true; function initBrowserInfo() { if (!_initBrowserInfo) return; browserInfo = getBrowserInfo(); } const getDeviceInfo = /* @__PURE__ */ defineSyncApi( "getDeviceInfo", () => { initBrowserInfo(); const { deviceBrand, deviceModel, brand, model, platform, system, deviceOrientation, deviceType } = browserInfo; return { brand, deviceBrand, deviceModel, devicePixelRatio: window.devicePixelRatio, deviceId: deviceId$1(), deviceOrientation, deviceType, model, platform, system }; } ); const getAppBaseInfo = /* @__PURE__ */ defineSyncApi( "getAppBaseInfo", () => { initBrowserInfo(); const { theme, language, browserName, browserVersion } = browserInfo; return { appId: __uniConfig.appId, appName: __uniConfig.appName, appVersion: __uniConfig.appVersion, appVersionCode: __uniConfig.appVersionCode, appLanguage: getLocale ? getLocale() : language, enableDebug: false, hostSDKVersion: void 0, hostPackageName: void 0, hostFontSizeSetting: void 0, hostName: browserName, hostVersion: browserVersion, hostTheme: theme, hostLanguage: language, language, SDKVersion: "", theme, version: "" }; } ); const getSystemInfoSync = /* @__PURE__ */ defineSyncApi( "getSystemInfoSync", () => { _initBrowserInfo = true; initBrowserInfo(); _initBrowserInfo = false; const windowInfo = getWindowInfo(); const deviceInfo = getDeviceInfo(); const appBaseInfo = getAppBaseInfo(); _initBrowserInfo = true; const { ua: ua2, browserName, browserVersion, osname, osversion } = browserInfo; const systemInfo = extend( windowInfo, deviceInfo, appBaseInfo, { ua: ua2, browserName, browserVersion, uniPlatform: "web", uniCompileVersion: __uniConfig.compilerVersion, uniRuntimeVersion: __uniConfig.compilerVersion, fontSizeSetting: void 0, osName: osname.toLocaleLowerCase(), osVersion: osversion, osLanguage: void 0, osTheme: void 0 } ); delete systemInfo.screenTop; delete systemInfo.enableDebug; if (!__uniConfig.darkmode) delete systemInfo.theme; return sortObject(systemInfo); } ); const getSystemInfo = /* @__PURE__ */ defineAsyncApi( "getSystemInfo", (_args, { resolve }) => { return resolve(getSystemInfoSync()); } ); const API_ON_NETWORK_STATUS_CHANGE = "onNetworkStatusChange"; function networkListener() { getNetworkType().then(({ networkType }) => { UniServiceJSBridge.invokeOnCallback( API_ON_NETWORK_STATUS_CHANGE, { isConnected: networkType !== "none", networkType } ); }); } function getConnection() { return navigator.connection || navigator.webkitConnection || navigator.mozConnection; } const onNetworkStatusChange = /* @__PURE__ */ defineOnApi( API_ON_NETWORK_STATUS_CHANGE, () => { const connection = getConnection(); if (connection) { connection.addEventListener("change", networkListener); } else { window.addEventListener("offline", networkListener); window.addEventListener("online", networkListener); } } ); const offNetworkStatusChange = /* @__PURE__ */ defineOffApi("offNetworkStatusChange", () => { const connection = getConnection(); if (connection) { connection.removeEventListener("change", networkListener); } else { window.removeEventListener("offline", networkListener); window.removeEventListener("online", networkListener); } }); const getNetworkType = /* @__PURE__ */ defineAsyncApi( "getNetworkType", (_args, { resolve }) => { const connection = getConnection(); let networkType = "unknown"; if (connection) { networkType = connection.type; if (networkType === "cellular" && connection.effectiveType) { networkType = connection.effectiveType.replace("slow-", ""); } else if (!["none", "wifi"].includes(networkType)) { networkType = "unknown"; } } else if (navigator.onLine === false) { networkType = "none"; } return resolve({ networkType }); } ); let listener$1 = null; const onAccelerometerChange = /* @__PURE__ */ defineOnApi(API_ON_ACCELEROMETER, () => { startAccelerometer(); }); const offAccelerometerChange = /* @__PURE__ */ defineOffApi(API_OFF_ACCELEROMETER, () => { stopAccelerometer(); }); const startAccelerometer = /* @__PURE__ */ defineAsyncApi( API_START_ACCELEROMETER, (_, { resolve, reject }) => { if (!window.DeviceMotionEvent) { reject(); return; } function addEventListener() { listener$1 = function(event) { const acceleration = event.acceleration || event.accelerationIncludingGravity; UniServiceJSBridge.invokeOnCallback(API_ON_ACCELEROMETER, { x: acceleration && acceleration.x || 0, y: acceleration && acceleration.y || 0, z: acceleration && acceleration.z || 0 }); }; window.addEventListener("devicemotion", listener$1, false); } if (!listener$1) { if (DeviceMotionEvent.requestPermission) { DeviceMotionEvent.requestPermission().then((res) => { if (res === "granted") { addEventListener(); resolve(); } else { reject(`${res}`); } }).catch((error) => { reject(`${error}`); }); return; } addEventListener(); } resolve(); } ); const stopAccelerometer = /* @__PURE__ */ defineAsyncApi( API_STOP_ACCELEROMETER, (_, { resolve }) => { if (listener$1) { window.removeEventListener("devicemotion", listener$1, false); listener$1 = null; } resolve(); } ); let listener = null; const onCompassChange = /* @__PURE__ */ defineOnApi( API_ON_COMPASS, () => { startCompass(); } ); const offCompassChange = /* @__PURE__ */ defineOffApi( API_OFF_COMPASS, () => { stopCompass(); } ); const startCompass = /* @__PURE__ */ defineAsyncApi( API_START_COMPASS, (_, { resolve, reject }) => { if (!window.DeviceOrientationEvent) { reject(); return; } function addEventListener() { listener = function(event) { const direction2 = 360 - (event.alpha !== null ? event.alpha : 360); UniServiceJSBridge.invokeOnCallback(API_ON_COMPASS, { direction: direction2 }); }; window.addEventListener("deviceorientation", listener, false); } if (!listener) { if (DeviceOrientationEvent.requestPermission) { DeviceOrientationEvent.requestPermission().then((res) => { if (res === "granted") { addEventListener(); resolve(); } else { reject(`${res}`); } }).catch((error) => { reject(`${error}`); }); return; } addEventListener(); } resolve(); } ); const stopCompass = /* @__PURE__ */ defineAsyncApi( API_STOP_COMPASS, (_, { resolve }) => { if (listener) { window.removeEventListener("deviceorientation", listener, false); listener = null; } resolve(); } ); const _isSupport = !!window.navigator.vibrate; const vibrateShort = /* @__PURE__ */ defineAsyncApi( API_VIBRATE_SHORT, (args, { resolve, reject }) => { if (_isSupport && window.navigator.vibrate(15)) { resolve(); } else { reject("vibrateLong:fail"); } } ); const vibrateLong = /* @__PURE__ */ defineAsyncApi( API_VIBRATE_LONG, (args, { resolve, reject }) => { if (_isSupport && window.navigator.vibrate(400)) { resolve(); } else { reject("vibrateLong:fail"); } } ); var __async = (__this, __arguments, generator) => { return new Promise((resolve, reject) => { var fulfilled = (value) => { try { step(generator.next(value)); } catch (e2) { reject(e2); } }; var rejected = (value) => { try { step(generator.throw(value)); } catch (e2) { reject(e2); } }; var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected); step((generator = generator.apply(__this, __arguments)).next()); }); }; const getClipboardData = /* @__PURE__ */ defineAsyncApi( API_GET_CLIPBOARD_DATA, (_0, _1) => __async(void 0, [_0, _1], function* (_, { resolve, reject }) { initI18nGetClipboardDataMsgsOnce(); const { t: t2 } = useI18n(); try { const data = yield navigator.clipboard.readText(); resolve({ data }); } catch (error) { _getClipboardData(resolve, () => { reject(`${error} ${t2("uni.getClipboardData.fail")}`); }); } }) ); const setClipboardData = /* @__PURE__ */ defineAsyncApi( API_SET_CLIPBOARD_DATA, (_0, _1) => __async(void 0, [_0, _1], function* ({ data }, { resolve, reject }) { try { yield navigator.clipboard.writeText(data); resolve(); } catch (error) { _setClipboardData(data, resolve, reject); } }), SetClipboardDataProtocol, SetClipboardDataOptions ); function _getClipboardData(resolve, reject) { const pasteText = document.getElementById("#clipboard"); const data = pasteText ? pasteText.value : void 0; if (data) { resolve({ data }); } else { reject(); } } function _setClipboardData(data, resolve, reject) { const pasteText = document.getElementById("#clipboard"); pasteText && pasteText.remove(); const textarea = document.createElement("textarea"); textarea.id = "#clipboard"; textarea.style.position = "fixed"; textarea.style.top = "-9999px"; textarea.style.zIndex = "-9999"; document.body.appendChild(textarea); textarea.value = data; textarea.select(); textarea.setSelectionRange(0, textarea.value.length); const result = document.execCommand("Copy", false); textarea.blur(); if (result) { resolve(); } else { reject(); } } const themeChangeCallBack = (res) => { UniServiceJSBridge.invokeOnCallback(ON_THEME_CHANGE, res); }; const onThemeChange$1 = /* @__PURE__ */ defineOnApi( ON_THEME_CHANGE, () => { UniServiceJSBridge.on(ON_THEME_CHANGE, themeChangeCallBack); } ); const offThemeChange$1 = /* @__PURE__ */ defineOffApi( OFF_THEME_CHANGE, () => { UniServiceJSBridge.off(ON_THEME_CHANGE, themeChangeCallBack); } ); const STORAGE_KEYS = "uni-storage-keys"; function parseValue(value) { const types = ["object", "string", "number", "boolean", "undefined"]; try { const object = isString(value) ? JSON.parse(value) : value; const type = object.type; if (types.indexOf(type) >= 0) { const keys = Object.keys(object); if (keys.length === 2 && "data" in object) { if (typeof object.data === type) { return object.data; } if (type === "object" && /^\d{4}-\d{2}-\d{2}T\d{2}\:\d{2}\:\d{2}\.\d{3}Z$/.test(object.data)) { return new Date(object.data); } } else if (keys.length === 1) { return ""; } } } catch (error) { } } const setStorageSync = /* @__PURE__ */ defineSyncApi( API_SET_STORAGE_SYNC, (key, data) => { const type = typeof data; const value = type === "string" ? data : JSON.stringify({ type, data }); localStorage.setItem(key, value); }, SetStorageSyncProtocol ); const setStorage = /* @__PURE__ */ defineAsyncApi( API_SET_STORAGE, ({ key, data }, { resolve, reject }) => { try { setStorageSync(key, data); resolve(); } catch (error) { reject(error.message); } }, SetStorageProtocol ); function getStorageOrigin(key) { const value = localStorage && localStorage.getItem(key); if (!isString(value)) { throw new Error("data not found"); } let data = value; try { const object = JSON.parse(value); const result = parseValue(object); if (result !== void 0) { data = result; } } catch (error) { } return data; } const getStorageSync = /* @__PURE__ */ defineSyncApi( API_GET_STORAGE_SYNC, (key) => { try { return getStorageOrigin(key); } catch (error) { return ""; } }, GetStorageSyncProtocol ); const getStorage = /* @__PURE__ */ defineAsyncApi( API_GET_STORAGE, ({ key }, { resolve, reject }) => { try { const data = getStorageOrigin(key); resolve({ data }); } catch (error) { reject(error.message); } }, GetStorageProtocol ); const removeStorageSync = /* @__PURE__ */ defineSyncApi( API_REMOVE_STORAGE, (key) => { if (localStorage) { localStorage.removeItem(key); } }, RemoveStorageSyncProtocol ); const removeStorage = /* @__PURE__ */ defineAsyncApi( API_REMOVE_STORAGE, ({ key }, { resolve }) => { removeStorageSync(key); resolve(); }, RemoveStorageProtocol ); const clearStorageSync = /* @__PURE__ */ defineSyncApi( "clearStorageSync", () => { if (localStorage) { localStorage.clear(); } } ); const clearStorage = /* @__PURE__ */ defineAsyncApi( "clearStorage", (_, { resolve }) => { clearStorageSync(); resolve(); } ); const getStorageInfoSync = /* @__PURE__ */ defineSyncApi( "getStorageInfoSync", () => { const length = localStorage && localStorage.length || 0; const keys = []; let currentSize = 0; for (let index2 = 0; index2 < length; index2++) { const key = localStorage.key(index2); const value = localStorage.getItem(key) || ""; currentSize += key.length + value.length; if (key !== STORAGE_KEYS) { keys.push(key); } } return { keys, currentSize: Math.ceil(currentSize * 2 / 1024), limitSize: Number.MAX_VALUE }; } ); const getStorageInfo = /* @__PURE__ */ defineAsyncApi( "getStorageInfo", (_, { resolve }) => { resolve(getStorageInfoSync()); } ); const getFileInfo = /* @__PURE__ */ defineAsyncApi( API_GET_FILE_INFO, ({ filePath }, { resolve, reject }) => { urlToFile(filePath).then((res) => { resolve({ size: res.size }); }).catch((err) => { reject(String(err)); }); }, GetFileInfoProtocol, GetFileInfoOptions ); const openDocument = /* @__PURE__ */ defineAsyncApi( API_OPEN_DOCUMENT, ({ filePath }, { resolve }) => { window.open(filePath); return resolve(); }, OpenDocumentProtocol, OpenDocumentOptions ); const hideKeyboard = /* @__PURE__ */ defineAsyncApi( API_HIDE_KEYBOARD, (args, { resolve, reject }) => { const activeElement = document.activeElement; if (activeElement && (activeElement.tagName === "TEXTAREA" || activeElement.tagName === "INPUT")) { activeElement.blur(); resolve(); } } ); function getServiceAddress() { return window.location.protocol + "//" + window.location.host; } const getImageInfo = /* @__PURE__ */ defineAsyncApi( API_GET_IMAGE_INFO, ({ src }, { resolve, reject }) => { const img = new Image(); img.onload = function() { resolve({ width: img.naturalWidth, height: img.naturalHeight, path: src.indexOf("/") === 0 ? getServiceAddress() + src : src }); }; img.onerror = function() { reject(); }; img.src = src; }, GetImageInfoProtocol, GetImageInfoOptions ); const getVideoInfo = /* @__PURE__ */ defineAsyncApi( API_GET_VIDEO_INFO, ({ src }, { resolve, reject }) => { urlToFile(src, true).then((file) => { return file; }).catch(() => { return null; }).then((file) => { const video = document.createElement("video"); if (video.onloadedmetadata !== void 0) { const handle = setTimeout( () => { video.onloadedmetadata = null; video.onerror = null; reject(); }, src.startsWith("data:") || src.startsWith("blob:") ? 300 : 3e3 ); video.onloadedmetadata = function() { clearTimeout(handle); video.onerror = null; resolve({ size: file ? file.size : 0, duration: video.duration || 0, width: video.videoWidth || 0, height: video.videoHeight || 0 }); }; video.onerror = function() { clearTimeout(handle); video.onloadedmetadata = null; reject(); }; video.src = src; } else { reject(); } }); }, GetVideoInfoProtocol, GetVideoInfoOptions ); const MIMEType = { /** * 关于图片常见的MIME类型 */ image: { jpg: "jpeg", jpe: "jpeg", pbm: "x-portable-bitmap", pgm: "x-portable-graymap", pnm: "x-portable-anymap", ppm: "x-portable-pixmap", psd: "vnd.adobe.photoshop", pic: "x-pict", rgb: "x-rgb", svg: "svg+xml", svgz: "svg+xml", tif: "tiff", xif: "vnd.xiff", wbmp: "vnd.wap.wbmp", wdp: "vnd.ms-photo", xbm: "x-xbitmap", ico: "x-icon" }, /** * 关于视频常见的MIME类型 */ video: { "3g2": "3gpp2", "3gp": "3gpp", avi: "x-msvideo", f4v: "x-f4v", flv: "x-flv", jpgm: "jpm", jpgv: "jpeg", m1v: "mpeg", m2v: "mpeg", mpe: "mpeg", mpg: "mpeg", mpg4: "mpeg", m4v: "x-m4v", mkv: "x-matroska", mov: "quicktime", qt: "quicktime", movie: "x-sgi-movie", mp4v: "mp4", ogv: "ogg", smv: "x-smv", wm: "x-ms-wm", wmv: "x-ms-wmv", wmx: "x-ms-wmx", wvx: "x-ms-wvx" } }; const MIMEType$1 = MIMEType; const ALL = "all"; addInteractListener(); function isWXEnv() { const ua2 = window.navigator.userAgent.toLowerCase(); const matchUA = ua2.match(/MicroMessenger/i); return !!(matchUA && matchUA[0] === "micromessenger"); } function _createInput({ count, sourceType, type, extension }) { const inputEl = document.createElement("input"); inputEl.type = "file"; updateElementStyle(inputEl, { position: "absolute", visibility: "hidden", zIndex: "-999", width: "0", height: "0", top: "0", left: "0" }); inputEl.accept = extension.map((item) => { if (type !== ALL) { const MIMEKey = item.replace(".", ""); return `${type}/${MIMEType$1[type][MIMEKey] || MIMEKey}`; } else { if (isWXEnv()) { return "."; } return item.indexOf(".") === 0 ? item : `.${item}`; } }).join(","); if (count && count > 1) { inputEl.multiple = true; } if (type !== ALL && sourceType instanceof Array && sourceType.length === 1 && sourceType[0] === "camera") { inputEl.setAttribute("capture", "camera"); } return inputEl; } let fileInput = null; const chooseFile = /* @__PURE__ */ defineAsyncApi( API_CHOOSE_FILE, ({ // sizeType, count, sourceType, type, extension }, { resolve, reject }) => { initI18nChooseFileMsgsOnce(); const { t: t2 } = useI18n(); if (fileInput) { document.body.removeChild(fileInput); fileInput = null; } fileInput = _createInput({ count, sourceType, type, extension }); document.body.appendChild(fileInput); fileInput.addEventListener("change", function(event) { const eventTarget = event.target; const tempFiles = []; if (eventTarget && eventTarget.files) { const fileCount = eventTarget.files.length; for (let i = 0; i < fileCount; i++) { const file = eventTarget.files[i]; let filePath; Object.defineProperty(file, "path", { get() { filePath = filePath || fileToUrl(file); return filePath; } }); if (i < count) tempFiles.push(file); } } const res = { get tempFilePaths() { return tempFiles.map(({ path }) => path); }, tempFiles }; resolve(res); }); fileInput.click(); if (!getInteractStatus()) { console.warn(t2("uni.chooseFile.notUserActivation")); } }, ChooseFileProtocol, ChooseFileOptions ); let imageInput = null; const chooseImage = /* @__PURE__ */ defineAsyncApi( API_CHOOSE_IMAGE, ({ count, // sizeType, sourceType, extension }, { resolve, reject }) => { initI18nChooseFileMsgsOnce(); const { t: t2 } = useI18n(); if (imageInput) { document.body.removeChild(imageInput); imageInput = null; } imageInput = _createInput({ count, sourceType, extension, type: "image" }); document.body.appendChild(imageInput); imageInput.addEventListener("change", function(event) { const eventTarget = event.target; const tempFiles = []; if (eventTarget && eventTarget.files) { const fileCount = eventTarget.files.length; for (let i = 0; i < fileCount; i++) { const file = eventTarget.files[i]; let filePath; Object.defineProperty(file, "path", { get() { filePath = filePath || fileToUrl(file); return filePath; } }); if (i < count) tempFiles.push(file); } } const res = { get tempFilePaths() { return tempFiles.map(({ path }) => path); }, tempFiles }; resolve(res); }); imageInput.click(); if (!getInteractStatus()) { console.warn(t2("uni.chooseFile.notUserActivation")); } }, ChooseImageProtocol, ChooseImageOptions ); const KEY_MAPS = { esc: ["Esc", "Escape"], // tab: ['Tab'], enter: ["Enter"] // space: [' ', 'Spacebar'], // up: ['Up', 'ArrowUp'], // left: ['Left', 'ArrowLeft'], // right: ['Right', 'ArrowRight'], // down: ['Down', 'ArrowDown'], // delete: ['Backspace', 'Delete', 'Del'], }; const KEYS = Object.keys(KEY_MAPS); function useKeyboard() { const key = ref(""); const disable = ref(false); const onKeyup = (evt) => { if (disable.value) { return; } const res = KEYS.find( (key2) => KEY_MAPS[key2].indexOf(evt.key) !== -1 ); if (res) { key.value = res; } nextTick(() => key.value = ""); }; onMounted(() => { document.addEventListener("keyup", onKeyup); }); onBeforeUnmount(() => { document.removeEventListener("keyup", onKeyup); }); return { key, disable }; } const VNODE_MASK = /* @__PURE__ */ createVNode( "div", { class: "uni-mask" }, null, -1 /* HOISTED */ ); function createRootApp(component, rootState, callback) { rootState.onClose = (...args) => (rootState.visible = false, callback.apply(null, args)); return createApp( defineComponent({ setup() { return () => (openBlock(), createBlock( component, rootState, null, 16 /* FULL_PROPS */ )); } }) ); } function ensureRoot(id2) { let rootEl = document.getElementById(id2); if (!rootEl) { rootEl = document.createElement("div"); rootEl.id = id2; document.body.append(rootEl); } return rootEl; } function usePopup(props2, { onEsc, onEnter }) { const visible = ref(props2.visible); const { key, disable } = useKeyboard(); watch( () => props2.visible, (value) => visible.value = value ); watch( () => visible.value, (value) => disable.value = !value ); watchEffect(() => { const { value } = key; if (value === "esc") { onEsc && onEsc(); } else if (value === "enter") { onEnter && onEnter(); } }); return visible; } let index$a = 0; let overflow = ""; function preventScroll(prevent) { let before = index$a; index$a += prevent ? 1 : -1; index$a = Math.max(0, index$a); if (index$a > 0) { if (before === 0) { overflow = document.body.style.overflow; document.body.style.overflow = "hidden"; } } else { document.body.style.overflow = overflow; overflow = ""; } } function usePreventScroll() { onMounted(() => preventScroll(true)); onUnmounted(() => preventScroll(false)); } const props$a = { src: { type: String, default: "" } }; const ImageView = /* @__PURE__ */ defineSystemComponent({ name: "ImageView", props: props$a, setup(props2) { const state2 = reactive({ direction: "none" }); let scale = 1; let imgWidth = 0; let imgHeight = 0; let width = 0; let height = 0; function onScale({ detail }) { scale = detail.scale; } function onImgLoad(event) { const target = event.target; const rect = target.getBoundingClientRect(); imgWidth = rect.width; imgHeight = rect.height; } function onTouchStart(event) { const target = event.target; const rect = target.getBoundingClientRect(); width = rect.width; height = rect.height; checkDirection(event); } function onTouchEnd(event) { const horizontal = scale * imgWidth > width; const vertical = scale * imgHeight > height; if (horizontal && vertical) { state2.direction = "all"; } else if (horizontal) { state2.direction = "horizontal"; } else if (vertical) { state2.direction = "vertical"; } else { state2.direction = "none"; } checkDirection(event); } function checkDirection(event) { if (state2.direction === "all" || state2.direction === "horizontal") { event.stopPropagation(); } } return () => { const viewStyle = { position: "absolute", left: "0", top: "0", width: "100%", height: "100%" }; return createVNode(MovableArea, { "style": viewStyle, "onTouchstart": withWebEvent(onTouchStart), "onTouchmove": withWebEvent(checkDirection), "onTouchend": withWebEvent(onTouchEnd) }, { default: () => [createVNode(MovableView, { "style": viewStyle, "direction": state2.direction, "inertia": true, "scale": true, "scale-min": "1", "scale-max": "4", "onScale": onScale }, { default: () => [createVNode("img", { "src": props2.src, "style": { position: "absolute", left: "50%", top: "50%", transform: "translate(-50%, -50%)", maxHeight: "100%", maxWidth: "100%" }, "onLoad": onImgLoad }, null, 40, ["src", "onLoad"])] }, 8, ["style", "direction", "inertia", "scale", "onScale"])] }, 8, ["style", "onTouchstart", "onTouchmove", "onTouchend"]); }; } }); function _isSlot$2(s) { return typeof s === "function" || Object.prototype.toString.call(s) === "[object Object]" && !isVNode(s); } const props$9 = { urls: { type: Array, default() { return []; } }, current: { type: [Number, String], default: 0 } }; function getIndex(props2) { let index2 = typeof props2.current === "number" ? props2.current : props2.urls.indexOf(props2.current); index2 = index2 < 0 ? 0 : index2; return index2; } const ImagePreview = /* @__PURE__ */ defineSystemComponent({ name: "ImagePreview", props: props$9, emits: ["close"], setup(props2, { emit: emit2 }) { usePreventScroll(); const rootRef = ref(null); const indexRef = ref(getIndex(props2)); watch(() => props2.current, () => indexRef.value = getIndex(props2)); let preventDefault; onMounted(() => { const el = rootRef.value; const MAX_MOVE = 20; let x = 0; let y = 0; el.addEventListener("mousedown", (event) => { preventDefault = false; x = event.clientX; y = event.clientY; }); el.addEventListener("mouseup", (event) => { if (Math.abs(event.clientX - x) > MAX_MOVE || Math.abs(event.clientY - y) > MAX_MOVE) { preventDefault = true; } }); }); function onClick() { if (!preventDefault) { nextTick(() => { emit2("close"); }); } } function onChange2(event) { indexRef.value = event.detail.current; } const closeBtnStyle = { position: "absolute", "box-sizing": "border-box", top: "0", right: "0", width: "60px", height: "44px", padding: "6px", "line-height": "32px", "font-size": "26px", color: "white", "text-align": "center", cursor: "pointer" }; return () => { let _slot; return createVNode("div", { "ref": rootRef, "style": { display: "block", position: "fixed", left: "0", top: "0", width: "100%", height: "100%", zIndex: 999, background: "rgba(0,0,0,0.8)" }, "onClick": onClick }, [createVNode(Swiper, { "navigation": "auto", "current": indexRef.value, "onChange": onChange2, "indicator-dots": false, "autoplay": false, "style": { position: "absolute", left: "0", top: "0", width: "100%", height: "100%" } }, _isSlot$2(_slot = props2.urls.map((src) => createVNode(SwiperItem, null, { default: () => [createVNode(ImageView, { "src": src }, null, 8, ["src"])] }))) ? _slot : { default: () => [_slot], _: 1 }, 8, ["current", "onChange"]), createVNode("div", { "style": closeBtnStyle }, [createSvgIconVNode(ICON_PATH_CLOSE, "#ffffff", 26)], 4)], 8, ["onClick"]); }; } }); let state$2 = null; let imagePreviewInstance; const closePreviewImageView = () => { state$2 = null; nextTick(() => { imagePreviewInstance == null ? void 0 : imagePreviewInstance.unmount(); imagePreviewInstance = null; }); }; const previewImage = /* @__PURE__ */ defineAsyncApi( API_PREVIEW_IMAGE, (args, { resolve }) => { if (!state$2) { state$2 = reactive(args); nextTick(() => { imagePreviewInstance = createRootApp( ImagePreview, state$2, closePreviewImageView ); imagePreviewInstance.mount(ensureRoot("u-a-p")); }); } else { extend(state$2, args); } resolve(); }, PreviewImageProtocol, PreviewImageOptions ); const closePreviewImage = /* @__PURE__ */ defineAsyncApi( API_CLOSE_PREVIEW_IMAGE, (_, { resolve, reject }) => { if (imagePreviewInstance) { closePreviewImageView(); resolve(); } else { reject(); } } ); let videoInput = null; const chooseVideo = /* @__PURE__ */ defineAsyncApi( API_CHOOSE_VIDEO, ({ sourceType, extension }, { resolve, reject }) => { initI18nChooseFileMsgsOnce(); const { t: t2 } = useI18n(); if (videoInput) { document.body.removeChild(videoInput); videoInput = null; } videoInput = _createInput({ sourceType, extension, type: "video" }); document.body.appendChild(videoInput); videoInput.addEventListener("change", function(event) { const eventTarget = event.target; const file = eventTarget.files[0]; let filePath = ""; const callbackResult = { tempFilePath: filePath, tempFile: file, size: file.size, duration: 0, width: 0, height: 0, name: file.name }; Object.defineProperty(callbackResult, "tempFilePath", { get() { filePath = filePath || fileToUrl(this.tempFile); return filePath; } }); const video = document.createElement("video"); if (video.onloadedmetadata !== void 0) { const filePath2 = fileToUrl(file); video.onloadedmetadata = function() { revokeObjectURL(filePath2); resolve( extend(callbackResult, { duration: video.duration || 0, width: video.videoWidth || 0, height: video.videoHeight || 0 }) ); }; setTimeout(() => { video.onloadedmetadata = null; revokeObjectURL(filePath2); resolve(callbackResult); }, 300); video.src = filePath2; } else { resolve(callbackResult); } }); videoInput.click(); if (!getInteractStatus()) { console.warn(t2("uni.chooseFile.notUserActivation")); } }, ChooseVideoProtocol, ChooseVideoOptions ); const request = /* @__PURE__ */ defineTaskApi( API_REQUEST, ({ url, data, header, method, dataType: dataType2, responseType, withCredentials, timeout = __uniConfig.networkTimeout.request }, { resolve, reject }) => { let body = null; const contentType = normalizeContentType(header); if (method !== "GET") { if (isString(data) || data instanceof ArrayBuffer) { body = data; } else { if (contentType === "json") { try { body = JSON.stringify(data); } catch (error) { body = data.toString(); } } else if (contentType === "urlencoded") { const bodyArray = []; for (const key in data) { if (hasOwn(data, key)) { bodyArray.push( encodeURIComponent(key) + "=" + encodeURIComponent(data[key]) ); } } body = bodyArray.join("&"); } else { body = data.toString(); } } } const xhr = new XMLHttpRequest(); const requestTask = new RequestTask(xhr); xhr.open(method, url); for (const key in header) { if (hasOwn(header, key)) { xhr.setRequestHeader(key, header[key]); } } const timer = setTimeout(function() { xhr.onload = xhr.onabort = xhr.onerror = null; requestTask.abort(); reject("timeout"); }, timeout); xhr.responseType = responseType; xhr.onload = function() { clearTimeout(timer); const statusCode = xhr.status; let res = responseType === "text" ? xhr.responseText : xhr.response; if (responseType === "text" && dataType2 === "json") { try { res = JSON.parse(res); } catch (error) { } } resolve({ data: res, statusCode, header: parseHeaders(xhr.getAllResponseHeaders()), cookies: [] }); }; xhr.onabort = function() { clearTimeout(timer); reject("abort"); }; xhr.onerror = function() { clearTimeout(timer); reject(); }; xhr.withCredentials = withCredentials; xhr.send(body); return requestTask; }, RequestProtocol, RequestOptions ); function normalizeContentType(header) { const name = Object.keys(header).find( (name2) => name2.toLowerCase() === "content-type" ); if (!name) { return; } const contentType = header[name]; if (contentType.indexOf("application/json") === 0) { return "json"; } else if (contentType.indexOf("application/x-www-form-urlencoded") === 0) { return "urlencoded"; } return "string"; } class RequestTask { constructor(xhr) { this._xhr = xhr; } abort() { if (this._xhr) { this._xhr.abort(); delete this._xhr; } } onHeadersReceived(callback) { throw new Error("Method not implemented."); } offHeadersReceived(callback) { throw new Error("Method not implemented."); } } function parseHeaders(headers) { const headersObject = {}; headers.split(LINEFEED).forEach((header) => { const find = header.match(/(\S+\s*):\s*(.*)/); if (!find || find.length !== 3) { return; } headersObject[find[1]] = find[2]; }); return headersObject; } class DownloadTask { constructor(xhr) { this._callbacks = []; this._xhr = xhr; } /** * 监听下载进度 * @param {Function} callback 回调 */ onProgressUpdate(callback) { if (!isFunction(callback)) { return; } this._callbacks.push(callback); } offProgressUpdate(callback) { const index2 = this._callbacks.indexOf(callback); if (index2 >= 0) { this._callbacks.splice(index2, 1); } } /** * 停止任务 */ abort() { if (this._xhr) { this._xhr.abort(); delete this._xhr; } } onHeadersReceived(callback) { throw new Error("Method not implemented."); } offHeadersReceived(callback) { throw new Error("Method not implemented."); } } const downloadFile = /* @__PURE__ */ defineTaskApi( API_DOWNLOAD_FILE, ({ url, header, timeout = __uniConfig.networkTimeout.downloadFile }, { resolve, reject }) => { var timer; var xhr = new XMLHttpRequest(); var downloadTask = new DownloadTask(xhr); xhr.open("GET", url, true); Object.keys(header).forEach((key) => { xhr.setRequestHeader(key, header[key]); }); xhr.responseType = "blob"; xhr.onload = function() { clearTimeout(timer); const statusCode = xhr.status; const blob = this.response; let filename; const contentDisposition = xhr.getResponseHeader("content-disposition"); if (contentDisposition) { const res = contentDisposition.match(/filename="?(\S+)"?\b/); if (res) { filename = res[1]; } } blob.name = filename || getFileName(url); resolve({ statusCode, tempFilePath: fileToUrl(blob) }); }; xhr.onabort = function() { clearTimeout(timer); reject("abort"); }; xhr.onerror = function() { clearTimeout(timer); reject(); }; xhr.onprogress = function(event) { downloadTask._callbacks.forEach((callback) => { var totalBytesWritten = event.loaded; var totalBytesExpectedToWrite = event.total; var progress = Math.round( totalBytesWritten / totalBytesExpectedToWrite * 100 ); callback({ progress, totalBytesWritten, totalBytesExpectedToWrite }); }); }; xhr.send(); timer = setTimeout(function() { xhr.onprogress = xhr.onload = xhr.onabort = xhr.onerror = null; downloadTask.abort(); reject("timeout"); }, timeout); return downloadTask; }, DownloadFileProtocol, DownloadFileOptions ); class UploadTask { constructor(xhr) { this._callbacks = []; this._xhr = xhr; } /** * 监听上传进度 * @param callback 回调 */ onProgressUpdate(callback) { if (!isFunction(callback)) { return; } this._callbacks.push(callback); } offProgressUpdate(callback) { const index2 = this._callbacks.indexOf(callback); if (index2 >= 0) { this._callbacks.splice(index2, 1); } } /** * 中断上传任务 */ abort() { this._isAbort = true; if (this._xhr) { this._xhr.abort(); delete this._xhr; } } onHeadersReceived(callback) { throw new Error("Method not implemented."); } offHeadersReceived(callback) { throw new Error("Method not implemented."); } } const uploadFile = /* @__PURE__ */ defineTaskApi( API_UPLOAD_FILE, ({ url, file, filePath, name, files: files2, header, formData, timeout = __uniConfig.networkTimeout.uploadFile }, { resolve, reject }) => { var uploadTask = new UploadTask(); if (!isArray(files2) || !files2.length) { files2 = [ { name, file, uri: filePath } ]; } function upload(realFiles) { var xhr = new XMLHttpRequest(); var form = new FormData(); var timer; Object.keys(formData).forEach((key) => { form.append(key, formData[key]); }); Object.values(files2).forEach(({ name: name2 }, index2) => { const file2 = realFiles[index2]; form.append(name2 || "file", file2, file2.name || `file-${Date.now()}`); }); xhr.open("POST", url); Object.keys(header).forEach((key) => { xhr.setRequestHeader(key, header[key]); }); xhr.upload.onprogress = function(event) { uploadTask._callbacks.forEach((callback) => { var totalBytesSent = event.loaded; var totalBytesExpectedToSend = event.total; var progress = Math.round( totalBytesSent / totalBytesExpectedToSend * 100 ); callback({ progress, totalBytesSent, totalBytesExpectedToSend }); }); }; xhr.onerror = function() { clearTimeout(timer); reject(); }; xhr.onabort = function() { clearTimeout(timer); reject("abort"); }; xhr.onload = function() { clearTimeout(timer); const statusCode = xhr.status; resolve({ statusCode, data: xhr.responseText || xhr.response }); }; if (!uploadTask._isAbort) { timer = setTimeout(function() { xhr.upload.onprogress = xhr.onload = xhr.onabort = xhr.onerror = null; uploadTask.abort(); reject("timeout"); }, timeout); xhr.send(form); uploadTask._xhr = xhr; } else { reject("abort"); } } Promise.all( files2.map( ({ file: file2, uri }) => file2 instanceof Blob ? Promise.resolve(blobToFile(file2)) : urlToFile(uri) ) ).then(upload).catch(() => { setTimeout(() => { reject("file error"); }, 0); }); return uploadTask; }, UploadFileProtocol, UploadFileOptions ); const socketTasks = []; const globalEvent = { open: "", close: "", error: "", message: "" }; class SocketTask { /** * 构造函数 * @param {string} url * @param {Array} protocols */ constructor(url, protocols, callback) { this._callbacks = { open: [], close: [], error: [], message: [] }; let error; try { const webSocket = this._webSocket = new WebSocket(url, protocols); webSocket.binaryType = "arraybuffer"; const eventNames = ["open", "close", "error", "message"]; eventNames.forEach((name) => { this._callbacks[name] = []; webSocket.addEventListener(name, (event) => { const { data, code, reason } = event; const res = name === "message" ? { data } : name === "close" ? { code, reason } : {}; this._callbacks[name].forEach((callback2) => { try { callback2(res); } catch (e2) { console.error( `thirdScriptError ${e2};at socketTask.on${capitalize( name )} callback function `, e2 ); } }); if (this === socketTasks[0] && globalEvent[name]) { UniServiceJSBridge.invokeOnCallback(globalEvent[name], res); } if (name === "error" || name === "close") { const index2 = socketTasks.indexOf(this); if (index2 >= 0) { socketTasks.splice(index2, 1); } } }); }); const propertys = [ "CLOSED", "CLOSING", "CONNECTING", "OPEN", "readyState" ]; propertys.forEach((property) => { Object.defineProperty(this, property, { get() { return webSocket[property]; } }); }); } catch (e2) { error = e2; } callback && callback(error, this); } /** * 发送 * @param {any} data */ send(options) { const data = (options || {}).data; const ws = this._webSocket; try { if (ws.readyState !== ws.OPEN) { throw new Error("SocketTask.readyState is not OPEN"); } ws.send(data); callOptions(options, "sendSocketMessage:ok"); } catch (error) { callOptions(options, `sendSocketMessage:fail ${error}`); } } /** * 关闭 * @param {number} code * @param {string} reason */ close(options = {}) { const ws = this._webSocket; try { const code = options.code || 1e3; const reason = options.reason; if (isString(reason)) { ws.close(code, reason); } else { ws.close(code); } callOptions(options, "closeSocket:ok"); } catch (error) { callOptions(options, `closeSocket:fail ${error}`); } } onOpen(callback) { this._callbacks.open.push(callback); } onMessage(callback) { this._callbacks.message.push(callback); } onError(callback) { this._callbacks.error.push(callback); } onClose(callback) { this._callbacks.close.push(callback); } } const connectSocket = /* @__PURE__ */ defineTaskApi( API_CONNECT_SOCKET, ({ url, protocols }, { resolve, reject }) => { return new SocketTask( url, protocols, (error, socketTask) => { if (error) { reject(error.toString()); return; } socketTasks.push(socketTask); resolve(); } ); }, ConnectSocketProtocol, ConnectSocketOptions ); function callSocketTask(socketTask, method, option, resolve, reject) { const fn = socketTask[method]; if (isFunction(fn)) { fn.call( socketTask, extend({}, option, { success() { resolve(); }, fail({ errMsg }) { reject(errMsg.replace("sendSocketMessage:fail ", "")); }, complete: void 0 }) ); } } const sendSocketMessage = /* @__PURE__ */ defineAsyncApi( API_SEND_SOCKET_MESSAGE, (options, { resolve, reject }) => { const socketTask = socketTasks[0]; if (socketTask && socketTask.readyState === socketTask.OPEN) { callSocketTask(socketTask, "send", options, resolve, reject); } else { reject("WebSocket is not connected"); } }, SendSocketMessageProtocol ); const closeSocket = /* @__PURE__ */ defineAsyncApi( API_CLOSE_SOCKET, (options, { resolve, reject }) => { const socketTask = socketTasks[0]; if (socketTask) { callSocketTask(socketTask, "close", options, resolve, reject); } else { reject("WebSocket is not connected"); } }, CloseSocketProtocol ); function on(event) { const api2 = `onSocket${capitalize(event)}`; return /* @__PURE__ */ defineOnApi(api2, () => { globalEvent[event] = api2; }); } const onSocketOpen = /* @__PURE__ */ on("open"); const onSocketError = /* @__PURE__ */ on("error"); const onSocketMessage = /* @__PURE__ */ on("message"); const onSocketClose = /* @__PURE__ */ on("close"); const getLocation = /* @__PURE__ */ defineAsyncApi( API_GET_LOCATION, ({ type, altitude, highAccuracyExpireTime, isHighAccuracy }, { resolve, reject }) => { const mapInfo = getMapInfo(); new Promise((resolve2, reject2) => { if (navigator.geolocation) { navigator.geolocation.getCurrentPosition( (res) => resolve2({ coords: res.coords }), reject2, { enableHighAccuracy: isHighAccuracy || altitude, timeout: highAccuracyExpireTime || 1e3 * 100 } ); } else { reject2(new Error("device nonsupport geolocation")); } }).catch((error) => { return new Promise( (resolve2, reject2) => { if (mapInfo.type === MapType.QQ) { getJSONP( `https://apis.map.qq.com/ws/location/v1/ip?output=jsonp&key=${mapInfo.key}`, { callback: "callback" }, (res) => { if ("result" in res && res.result.location) { const location2 = res.result.location; resolve2({ coords: { latitude: location2.lat, longitude: location2.lng }, skip: true }); } else { reject2(new Error(res.message || JSON.stringify(res))); } }, () => reject2(new Error("network error")) ); } else if (mapInfo.type === MapType.GOOGLE) { request({ method: "POST", url: `https://www.googleapis.com/geolocation/v1/geolocate?key=${mapInfo.key}`, success(res) { const data = res.data; if ("location" in data) { resolve2({ coords: { latitude: data.location.lat, longitude: data.location.lng, accuracy: data.accuracy }, skip: true }); } else { reject2( new Error( data.error && data.error.message || JSON.stringify(res) ) ); } }, fail() { reject2(new Error("network error")); } }); } else if (mapInfo.type === MapType.AMAP) { loadMaps([], () => { window.AMap.plugin("AMap.Geolocation", () => { const geolocation = new window.AMap.Geolocation({ enableHighAccuracy: true, timeout: 1e4 }); geolocation.getCurrentPosition( (status, data) => { if (status === "complete") { resolve2({ coords: { latitude: data.position.lat, longitude: data.position.lng, accuracy: data.accuracy }, skip: true }); } else { reject2(new Error(data.message)); } } ); }); }); } else { reject2(error); } } ); }).then(({ coords, skip }) => { translateCoordinateSystem(type, coords, skip).then((coords2) => { resolve({ latitude: coords2.latitude, longitude: coords2.longitude, accuracy: coords2.accuracy, speed: coords2.altitude || 0, altitude: coords2.altitude || 0, verticalAccuracy: coords2.altitudeAccuracy || 0, // 无专门水平精度,使用位置精度替代 horizontalAccuracy: coords2.accuracy || 0 }); }).catch((error) => { reject(error.message); }); }).catch((error) => { reject(error.message || JSON.stringify(error)); }); }, GetLocationProtocol, GetLocationOptions ); const ICON_PATH_NAV = "M28 17c-6.49396875 0-12.13721875 2.57040625-15 6.34840625V5.4105l6.29859375 6.29859375c0.387875 0.387875 1.02259375 0.387875 1.4105 0 0.387875-0.387875 0.387875-1.02259375 0-1.4105L12.77853125 2.36803125a0.9978125 0.9978125 0 0 0-0.0694375-0.077125c-0.1944375-0.1944375-0.45090625-0.291375-0.70721875-0.290875l-0.00184375-0.0000625-0.00184375 0.0000625c-0.2563125-0.0005-0.51278125 0.09640625-0.70721875 0.290875a0.9978125 0.9978125 0 0 0-0.0694375 0.077125l-7.930625 7.9305625c-0.387875 0.387875-0.387875 1.02259375 0 1.4105 0.387875 0.387875 1.02259375 0.387875 1.4105 0L11 5.4105V29c0 0.55 0.45 1 1 1s1-0.45 1-1c0-5.52284375 6.71571875-10 15-10 0.55228125 0 1-0.44771875 1-1 0-0.55228125-0.44771875-1-1-1z"; const props$8 = { latitude: { type: Number }, longitude: { type: Number }, scale: { type: Number, default: 18 }, name: { type: String, default: "" }, address: { type: String, default: "" } }; function useState$2(props2) { const state2 = reactive({ center: { latitude: 0, longitude: 0 }, marker: { id: 1, latitude: 0, longitude: 0, iconPath: ICON_PATH_TARGET, width: 32, height: 52 }, location: { id: 2, latitude: 0, longitude: 0, iconPath: ICON_PATH_ORIGIN, width: 44, height: 44 } }); function updatePosition() { if (props2.latitude && props2.longitude) { state2.center.latitude = props2.latitude; state2.center.longitude = props2.longitude; state2.marker.latitude = props2.latitude; state2.marker.longitude = props2.longitude; } } watch([() => props2.latitude, () => props2.longitude], updatePosition); updatePosition(); return state2; } const LocationView = /* @__PURE__ */ defineSystemComponent({ name: "LocationView", props: props$8, emits: ["close"], setup(props2, { emit: emit2 }) { const state2 = useState$2(props2); usePreventScroll(); getLocation({ type: "gcj02", success: ({ latitude, longitude }) => { state2.location.latitude = latitude; state2.location.longitude = longitude; } }); function onRegionChange(event) { const centerLocation = event.detail.centerLocation; if (centerLocation) { state2.center.latitude = centerLocation.latitude; state2.center.longitude = centerLocation.longitude; } } function nav() { const mapInfo = getMapInfo(); let url = ""; if (mapInfo.type === MapType.GOOGLE) { const origin = state2.location.latitude ? `&origin=${state2.location.latitude}%2C${state2.location.longitude}` : ""; url = `https://www.google.com/maps/dir/?api=1${origin}&destination=${props2.latitude}%2C${props2.longitude}`; } else if (mapInfo.type === MapType.QQ) { const fromcoord = state2.location.latitude ? `&fromcoord=${state2.location.latitude}%2C${state2.location.longitude}&from=${encodeURIComponent("我的位置")}` : ""; url = `https://apis.map.qq.com/uri/v1/routeplan?type=drive${fromcoord}&tocoord=${props2.latitude}%2C${props2.longitude}&to=${encodeURIComponent(props2.name || "目的地")}&ref=${mapInfo.key}`; } else if (mapInfo.type === MapType.AMAP) { const from = state2.location.latitude ? `from=${state2.location.longitude},${state2.location.latitude},${encodeURIComponent("我的位置")}&` : ""; url = `https://uri.amap.com/navigation?${from}to=${props2.longitude},${props2.latitude},${encodeURIComponent(props2.name || "目的地")}`; } window.open(url); } function back() { emit2("close"); } function setCenter({ latitude, longitude }) { state2.center.latitude = latitude; state2.center.longitude = longitude; } return () => { return createVNode("div", { "class": "uni-system-open-location" }, [createVNode(Map$1, { "latitude": state2.center.latitude, "longitude": state2.center.longitude, "class": "map", "markers": [state2.marker, state2.location], "onRegionchange": onRegionChange }, { default: () => [createVNode("div", { "class": "map-move", "onClick": () => setCenter(state2.location) }, [createSvgIconVNode(ICON_PATH_LOCTAION, "#000000", 24)], 8, ["onClick"])] }, 8, ["latitude", "longitude", "markers", "onRegionchange"]), createVNode("div", { "class": "info" }, [createVNode("div", { "class": "name", "onClick": () => setCenter(state2.marker) }, [props2.name], 8, ["onClick"]), createVNode("div", { "class": "address", "onClick": () => setCenter(state2.marker) }, [props2.address], 8, ["onClick"]), createVNode("div", { "class": "nav", "onClick": nav }, [createSvgIconVNode(ICON_PATH_NAV, "#ffffff", 26)], 8, ["onClick"])]), createVNode("div", { "class": "nav-btn-back", "onClick": back }, [createSvgIconVNode(ICON_PATH_BACK, "#ffffff", 26)], 8, ["onClick"])]); }; } }); let state$1 = null; const openLocation = /* @__PURE__ */ defineAsyncApi( API_OPEN_LOCATION, (args, { resolve }) => { if (!state$1) { state$1 = reactive(args); nextTick(() => { const app = createRootApp(LocationView, state$1, () => { state$1 = null; nextTick(() => { app.unmount(); }); }); app.mount(ensureRoot("u-a-o")); }); } else { extend(state$1, args); } resolve(); }, OpenLocationProtocol, OpenLocationOptions ); function _isSlot$1(s) { return typeof s === "function" || Object.prototype.toString.call(s) === "[object Object]" && !isVNode(s); } const props$7 = { latitude: { type: Number }, longitude: { type: Number } }; function distance(distance2) { if (distance2 > 100) { return `${distance2 > 1e3 ? (distance2 / 1e3).toFixed(1) + "k" : distance2.toFixed(0)}m | `; } else if (distance2 > 0) { return "<100m | "; } else { return ""; } } function useState$1(props2) { const state2 = reactive({ latitude: 0, longitude: 0, keyword: "", searching: false }); function updatePosition() { if (props2.latitude && props2.longitude) { state2.latitude = props2.latitude; state2.longitude = props2.longitude; } } watch([() => props2.latitude, () => props2.longitude], updatePosition); updatePosition(); return state2; } function useList(state2) { const key = __uniConfig.qqMapKey; const list2 = reactive([]); const selectedIndexRef = ref(-1); const selectedRef = computed(() => list2[selectedIndexRef.value]); const listState = reactive({ loading: true, // google map default pageSize: 20, pageIndex: 1, hasNextPage: true, nextPage: null, selectedIndex: selectedIndexRef, selected: selectedRef }); const adcodeRef = ref(""); const boundaryRef = computed(() => adcodeRef.value ? `region(${adcodeRef.value},1,${state2.latitude},${state2.longitude})` : `nearby(${state2.latitude},${state2.longitude},5000)`); function pushData(array) { array.forEach((item) => { list2.push({ name: item.title || item.name, address: item.address, distance: item._distance || item.distance, latitude: item.location.lat, longitude: item.location.lng }); }); } function getList() { listState.loading = true; const mapInfo = getMapInfo(); if (mapInfo.type === MapType.GOOGLE) { if (listState.pageIndex > 1 && listState.nextPage) { listState.nextPage(); return; } const service = new google.maps.places.PlacesService(document.createElement("div")); service[state2.searching ? "textSearch" : "nearbySearch"]({ location: { lat: state2.latitude, lng: state2.longitude }, query: state2.keyword, radius: 5e3 }, (results, state3, page) => { listState.loading = false; if (results && results.length) { results.forEach((item) => { list2.push({ name: item.name || "", address: item.vicinity || item.formatted_address || "", distance: 0, latitude: item.geometry.location.lat(), longitude: item.geometry.location.lng() }); }); } if (page) { if (!page.hasNextPage) { listState.hasNextPage = false; } else { listState.nextPage = () => { page.nextPage(); }; } } }); } else if (mapInfo.type === MapType.QQ) { const url = state2.searching ? `https://apis.map.qq.com/ws/place/v1/search?output=jsonp&key=${key}&boundary=${boundaryRef.value}&keyword=${state2.keyword}&page_size=${listState.pageSize}&page_index=${listState.pageIndex}` : `https://apis.map.qq.com/ws/geocoder/v1/?output=jsonp&key=${key}&location=${state2.latitude},${state2.longitude}&get_poi=1&poi_options=page_size=${listState.pageSize};page_index=${listState.pageIndex}`; getJSONP(url, { callback: "callback" }, (res) => { listState.loading = false; if (state2.searching && "data" in res && res.data.length) { pushData(res.data); } else if ("result" in res) { const result = res.result; adcodeRef.value = result.ad_info ? result.ad_info.adcode : ""; if (result.pois) { pushData(result.pois); } } if (list2.length === listState.pageSize * listState.pageIndex) { listState.hasNextPage = false; } }, () => { listState.loading = false; }); } else if (mapInfo.type === MapType.AMAP) { window.AMap.plugin("AMap.PlaceSearch", function() { const placeSearch = new window.AMap.PlaceSearch({ city: "全国", pageSize: 10, pageIndex: listState.pageIndex }); const keyword = state2.searching ? state2.keyword : ""; const radius = state2.searching ? 5e4 : 5e3; placeSearch.searchNearBy(keyword, [state2.longitude, state2.latitude], radius, function(status, result) { if (status === "error") { console.error(result); } else if (status === "no_data") { listState.hasNextPage = false; } else { pushData(result.poiList.pois); } }); listState.loading = false; }); } } function loadMore() { if (!listState.loading && listState.hasNextPage) { listState.pageIndex++; getList(); } } function reset() { listState.selectedIndex = -1; listState.pageIndex = 1; listState.hasNextPage = true; listState.nextPage = null; list2.splice(0, list2.length); } return { listState, list: list2, loadMore, reset, getList }; } const LoctaionPicker = /* @__PURE__ */ defineSystemComponent({ name: "LoctaionPicker", props: props$7, emits: ["close"], setup(props2, { emit: emit2 }) { usePreventScroll(); initI18nChooseLocationMsgsOnce(); const { t: t2 } = useI18n(); const state2 = useState$1(props2); const { list: list2, listState, loadMore, reset, getList } = useList(state2); const search = debounce(() => { reset(); if (state2.keyword) { getList(); } }, 1e3, { setTimeout, clearTimeout }); watch(() => state2.searching, (val) => { reset(); if (!val) { getList(); } }); function onInput(event) { state2.keyword = event.detail.value; search(); } function onChoose() { emit2("close", extend({}, listState.selected)); } function onBack() { emit2("close"); } function onRegionChange(event) { const centerLocation = event.detail.centerLocation; if (centerLocation) { move(centerLocation); } } function moveToLocation() { getLocation({ type: "gcj02", success: move, fail: () => { } }); } function move({ latitude, longitude }) { state2.latitude = latitude; state2.longitude = longitude; if (!state2.searching) { reset(); getList(); } } if (!state2.latitude || !state2.longitude) { moveToLocation(); } return () => { const content = list2.map((item, index2) => { return createVNode("div", { "key": index2, "class": { "list-item": true, selected: listState.selectedIndex === index2 }, "onClick": () => { listState.selectedIndex = index2; state2.latitude = item.latitude; state2.longitude = item.longitude; } }, [createSvgIconVNode(ICON_PATH_CONFIRM, "#007aff", 24), createVNode("div", { "class": "list-item-title" }, [item.name]), createVNode("div", { "class": "list-item-detail" }, [distance(item.distance), item.address])], 10, ["onClick"]); }); if (listState.loading) { content.unshift(createVNode("div", { "class": "list-loading" }, [createVNode("i", { "class": "uni-loading" }, null)])); } return createVNode("div", { "class": "uni-system-choose-location" }, [createVNode(Map$1, { "latitude": state2.latitude, "longitude": state2.longitude, "class": "map", "show-location": true, "libraries": ["places"], "onUpdated": getList, "onRegionchange": onRegionChange }, { default: () => [createVNode("div", { "class": "map-location", "style": `background-image: url("${ICON_PATH_TARGET}")` }, null), createVNode("div", { "class": "map-move", "onClick": moveToLocation }, [createSvgIconVNode(ICON_PATH_LOCTAION, "#000000", 24)], 8, ["onClick"])], _: 1 }, 8, ["latitude", "longitude", "show-location", "onUpdated", "onRegionchange"]), createVNode("div", { "class": "nav" }, [createVNode("div", { "class": "nav-btn back", "onClick": onBack }, [createSvgIconVNode(ICON_PATH_CLOSE, "#ffffff", 26)], 8, ["onClick"]), createVNode("div", { "class": { "nav-btn": true, confirm: true, disable: !listState.selected }, "onClick": onChoose }, [createSvgIconVNode(ICON_PATH_CONFIRM, "#ffffff", 26)], 10, ["onClick"])]), createVNode("div", { "class": "menu" }, [createVNode("div", { "class": "search" }, [createVNode(Input, { "value": state2.keyword, "class": "search-input", "placeholder": t2("uni.chooseLocation.search"), "onFocus": () => state2.searching = true, "onInput": onInput }, null, 8, ["value", "placeholder", "onFocus", "onInput"]), state2.searching && createVNode("div", { "class": "search-btn", "onClick": () => { state2.searching = false; state2.keyword = ""; } }, [t2("uni.chooseLocation.cancel")], 8, ["onClick"])]), createVNode(ScrollView, { "scroll-y": true, "class": "list", "onScrolltolower": loadMore }, _isSlot$1(content) ? content : { default: () => [content], _: 2 }, 8, ["scroll-y", "onScrolltolower"])])]); }; } }); let state = null; const chooseLocation = /* @__PURE__ */ defineAsyncApi( API_CHOOSE_LOCATION, (args, { resolve, reject }) => { if (!state) { state = reactive(args); nextTick(() => { const app = createRootApp( LoctaionPicker, state, (poi) => { state = null; nextTick(() => { app.unmount(); }); poi ? resolve(poi) : reject("cancel"); } ); app.mount(ensureRoot("u-a-c")); }); } else { reject("cancel"); } }, ChooseLocationProtocol ); let started = false; let watchId = 0; const startLocationUpdate = /* @__PURE__ */ defineAsyncApi( API_START_LOCATION_UPDATE, (options, { resolve, reject }) => { if (!navigator.geolocation) { reject(); return; } watchId = watchId || navigator.geolocation.watchPosition( (res) => { started = true; translateCoordinateSystem(options == null ? void 0 : options.type, res.coords).then((coords) => { UniServiceJSBridge.invokeOnCallback( API_ON_LOCATION_CHANGE, coords ); resolve(); }).catch((error) => { UniServiceJSBridge.invokeOnCallback( API_ON_LOCATION_CHANGE_ERROR, { errMsg: `onLocationChange:fail ${error.message}` } ); }); }, (error) => { if (!started) { reject(error.message); started = true; } UniServiceJSBridge.invokeOnCallback(API_ON_LOCATION_CHANGE_ERROR, { errMsg: `onLocationChange:fail ${error.message}` }); } ); setTimeout(resolve, 100); }, StartLocationUpdateProtocol, StartLocationUpdateOptions ); const stopLocationUpdate = /* @__PURE__ */ defineAsyncApi( API_STOP_LOCATION_UPDATE, (_, { resolve }) => { if (watchId) { navigator.geolocation.clearWatch(watchId); started = false; watchId = 0; } resolve(); } ); const onLocationChange = /* @__PURE__ */ defineOnApi( API_ON_LOCATION_CHANGE, () => { } ); const offLocationChange = /* @__PURE__ */ defineOffApi( API_OFF_LOCATION_CHANGE, () => { } ); const onLocationChangeError = /* @__PURE__ */ defineOnApi( API_ON_LOCATION_CHANGE_ERROR, () => { } ); const offLocationChangeError = /* @__PURE__ */ defineOffApi( API_OFF_LOCATION_CHANGE_ERROR, () => { } ); const navigateBack = /* @__PURE__ */ defineAsyncApi( API_NAVIGATE_BACK, (args, { resolve, reject }) => { let canBack = true; if (invokeHook(ON_BACK_PRESS, { from: args.from || "navigateBack" }) === true) { canBack = false; } if (!canBack) { return reject(ON_BACK_PRESS); } getApp().$router.go(-args.delta); return resolve(); }, NavigateBackProtocol, NavigateBackOptions ); function navigate({ type, url, tabBarText, events, isAutomatedTesting }, __id__) { const router = getApp().$router; const { path, query } = parseUrl(url); return new Promise((resolve, reject) => { const state2 = createPageState(type, __id__); router[type === "navigateTo" ? "push" : "replace"]({ path, query, state: state2, force: true }).then((failure) => { if (isNavigationFailure(failure)) { return reject(failure.message); } if (type === "switchTab") { router.currentRoute.value.meta.tabBarText = tabBarText; } if (type === "navigateTo") { const meta = router.currentRoute.value.meta; if (!meta.eventChannel) { meta.eventChannel = new EventChannel(state2.__id__, events); } else if (events) { Object.keys(events).forEach((eventName) => { meta.eventChannel._addListener( eventName, "on", events[eventName] ); }); meta.eventChannel._clearCache(); } return isAutomatedTesting ? resolve({ __id__: state2.__id__ }) : resolve({ eventChannel: meta.eventChannel }); } return isAutomatedTesting ? resolve({ __id__: state2.__id__ }) : resolve(); }); }); } const navigateTo = /* @__PURE__ */ defineAsyncApi( API_NAVIGATE_TO, // @ts-ignore ({ url, events, isAutomatedTesting }, { resolve, reject }) => navigate({ type: API_NAVIGATE_TO, url, events, isAutomatedTesting }).then(resolve).catch(reject), NavigateToProtocol, NavigateToOptions ); function removeLastPage() { const page = getCurrentPage(); if (!page) { return; } const $page = page.$page; removePage(normalizeRouteKey($page.path, $page.id)); } const redirectTo = /* @__PURE__ */ defineAsyncApi( API_REDIRECT_TO, // @ts-ignore ({ url, isAutomatedTesting }, { resolve, reject }) => { return ( // TODO exists 属性未实现 removeLastPage(), navigate({ type: API_REDIRECT_TO, url, isAutomatedTesting }).then(resolve).catch(reject) ); }, RedirectToProtocol, RedirectToOptions ); function removeAllPages() { const keys = getCurrentPagesMap().keys(); for (const routeKey of keys) { removePage(routeKey); } } const reLaunch = /* @__PURE__ */ defineAsyncApi( API_RE_LAUNCH, // @ts-ignore ({ url, isAutomatedTesting }, { resolve, reject }) => { return removeAllPages(), navigate({ type: API_RE_LAUNCH, url, isAutomatedTesting }).then(resolve).catch(reject); }, ReLaunchProtocol, ReLaunchOptions ); function removeNonTabBarPages() { const curTabBarPageVm = getCurrentPageVm(); if (!curTabBarPageVm) { return; } const pagesMap = getCurrentPagesMap(); const keys = pagesMap.keys(); for (const routeKey of keys) { const page = pagesMap.get(routeKey); if (!page.$.__isTabBar) { removePage(routeKey); } else { page.$.__isActive = false; } } if (curTabBarPageVm.$.__isTabBar) { curTabBarPageVm.$.__isVisible = false; invokeHook(curTabBarPageVm, ON_HIDE); } } function isSamePage(url, $page) { return url === $page.fullPath || url === "/" && $page.meta.isEntry; } function getTabBarPageId(url) { const pages = getCurrentPagesMap().values(); for (const page of pages) { const $page = page.$page; if (isSamePage(url, $page)) { page.$.__isActive = true; return $page.id; } } } const switchTab = /* @__PURE__ */ defineAsyncApi( API_SWITCH_TAB, // @ts-ignore ({ url, tabBarText, isAutomatedTesting }, { resolve, reject }) => { return removeNonTabBarPages(), navigate( { type: API_SWITCH_TAB, url, tabBarText, isAutomatedTesting }, getTabBarPageId(url) ).then(resolve).catch(reject); }, SwitchTabProtocol, SwitchTabOptions ); const preloadPage = /* @__PURE__ */ defineAsyncApi( API_PRELOAD_PAGE, ({ url }, { resolve, reject }) => { const path = url.split("?")[0]; const route = getRouteOptions(path); if (!route) { reject(`${url}}`); return; } route.loader && route.loader().then(() => { resolve({ url, errMsg: "preloadPage:ok" }); }).catch((err) => { reject(`${url} ${String(err)}`); }); }, PreloadPageProtocol ); function onThemeChange(callback) { if (__uniConfig.darkmode) { UniServiceJSBridge.on(ON_THEME_CHANGE, callback); } } function offThemeChange(callback) { UniServiceJSBridge.off(ON_THEME_CHANGE, callback); } function parseTheme(pageStyle) { let parsedStyle = {}; if (__uniConfig.darkmode) { parsedStyle = normalizeStyles( pageStyle, __uniConfig.themeConfig, getTheme() ); } return __uniConfig.darkmode ? parsedStyle : pageStyle; } function useTheme(pageStyle, onThemeChangeCallback) { const isReactived = isReactive(pageStyle); const reactivePageStyle = isReactived ? reactive(parseTheme(pageStyle)) : parseTheme(pageStyle); if (__uniConfig.darkmode && isReactived) { watch(pageStyle, (value) => { const _pageStyle = parseTheme(value); for (const key in _pageStyle) { reactivePageStyle[key] = _pageStyle[key]; } }); } onThemeChangeCallback && onThemeChange(onThemeChangeCallback); return reactivePageStyle; } const ModalTheme = { light: { cancelColor: "#000000" }, dark: { cancelColor: "rgb(170, 170, 170)" } }; const setCancelColor = (theme, cancelColor) => cancelColor.value = ModalTheme[theme].cancelColor; const props$6 = { title: { type: String, default: "" }, content: { type: String, default: "" }, showCancel: { type: Boolean, default: true }, cancelText: { type: String, default: "Cancel" }, cancelColor: { type: String, default: "#000000" }, confirmText: { type: String, default: "OK" }, confirmColor: { type: String, default: "#007aff" }, visible: { type: Boolean }, editable: { type: Boolean, default: false }, placeholderText: { type: String, default: "" } }; const modal = /* @__PURE__ */ defineComponent({ props: props$6, setup(props2, { emit: emit2 }) { const editContent = ref(""); const close = () => visible.value = false; const cancel = () => (close(), emit2("close", "cancel")); const confirm = () => (close(), emit2("close", "confirm", editContent.value)); const visible = usePopup(props2, { onEsc: cancel, onEnter: () => { !props2.editable && confirm(); } }); const cancelColor = useOnThemeChange$1(props2); return () => { const { title, content, showCancel, confirmText, confirmColor, editable, placeholderText } = props2; editContent.value = content; return createVNode(Transition, { "name": "uni-fade" }, { default: () => [withDirectives(createVNode("uni-modal", { "onTouchmove": onEventPrevent }, [VNODE_MASK, createVNode("div", { "class": "uni-modal" }, [title && createVNode("div", { "class": "uni-modal__hd" }, [createVNode("strong", { "class": "uni-modal__title", "textContent": title }, null, 8, ["textContent"])]), editable ? createVNode("textarea", { "class": "uni-modal__textarea", "rows": "1", "placeholder": placeholderText, "value": content, "onInput": (e2) => editContent.value = e2.target.value }, null, 40, ["placeholder", "value", "onInput"]) : createVNode("div", { "class": "uni-modal__bd", "onTouchmovePassive": onEventStop, "textContent": content }, null, 40, ["onTouchmovePassive", "textContent"]), createVNode("div", { "class": "uni-modal__ft" }, [showCancel && createVNode("div", { "style": { color: cancelColor.value }, "class": "uni-modal__btn uni-modal__btn_default", "onClick": cancel }, [props2.cancelText], 12, ["onClick"]), createVNode("div", { "style": { color: confirmColor }, "class": "uni-modal__btn uni-modal__btn_primary", "onClick": confirm }, [confirmText], 12, ["onClick"])])])], 40, ["onTouchmove"]), [[vShow, visible.value]])] }); }; } }); function useOnThemeChange$1(props2) { const cancelColor = ref(props2.cancelColor); const _onThemeChange = ({ theme }) => { setCancelColor(theme, cancelColor); }; watchEffect(() => { if (props2.visible) { cancelColor.value = props2.cancelColor; if (props2.cancelColor === "#000") { if (getTheme() === "dark") _onThemeChange({ theme: "dark" }); onThemeChange(_onThemeChange); } } else { offThemeChange(_onThemeChange); } }); return cancelColor; } let showModalState; const onHidePopupOnce$1 = /* @__PURE__ */ once(() => { UniServiceJSBridge.on("onHidePopup", () => showModalState.visible = false); }); let currentShowModalResolve; function onModalClose(type, content) { const isConfirm = type === "confirm"; const res = { confirm: isConfirm, cancel: type === "cancel" }; isConfirm && showModalState.editable && (res.content = content); currentShowModalResolve && currentShowModalResolve(res); } const showModal = /* @__PURE__ */ defineAsyncApi( API_SHOW_MODAL, (args, { resolve }) => { onHidePopupOnce$1(); currentShowModalResolve = resolve; if (!showModalState) { showModalState = reactive(args); nextTick( () => (createRootApp(modal, showModalState, onModalClose).mount( ensureRoot("u-a-m") ), //下一帧执行,确保首次显示时有动画效果 nextTick(() => showModalState.visible = true)) ); } else { extend(showModalState, args); showModalState.visible = true; } }, ShowModalProtocol, ShowModalOptions ); const props$5 = { title: { type: String, default: "" }, icon: { default: "success", validator(value) { return SHOW_TOAST_ICON.indexOf(value) !== -1; } }, image: { type: String, default: "" }, duration: { type: Number, default: 1500 }, mask: { type: Boolean, default: false }, visible: { type: Boolean } }; const ToastIconClassName = "uni-toast__icon"; const ICONCOLOR = { light: "#fff", dark: "rgba(255,255,255,0.9)" }; const getIconColor = (theme) => ICONCOLOR[theme]; const Toast = /* @__PURE__ */ defineComponent({ name: "Toast", props: props$5, setup(props2) { initI18nShowToastMsgsOnce(); initI18nShowLoadingMsgsOnce(); const { Icon } = useToastIcon(props2); const visible = usePopup(props2, {}); return () => { const { mask, duration, title, image: image2 } = props2; return createVNode(Transition, { "name": "uni-fade" }, { default: () => [withDirectives(createVNode("uni-toast", { "data-duration": duration }, [mask ? createVNode("div", { "class": "uni-mask", "style": "background: transparent;", "onTouchmove": onEventPrevent }, null, 40, ["onTouchmove"]) : "", !image2 && !Icon.value ? createVNode("div", { "class": "uni-sample-toast" }, [createVNode("p", { "class": "uni-simple-toast__text" }, [title])]) : createVNode("div", { "class": "uni-toast" }, [image2 ? createVNode("img", { "src": image2, "class": ToastIconClassName }, null, 10, ["src"]) : Icon.value, createVNode("p", { "class": "uni-toast__content" }, [title])])], 8, ["data-duration"]), [[vShow, visible.value]])] }); }; } }); function useToastIcon(props2) { const iconColor = ref(getIconColor(getTheme())); const _onThemeChange = ({ theme }) => iconColor.value = getIconColor(theme); watchEffect(() => { if (props2.visible) { onThemeChange(_onThemeChange); } else { offThemeChange(_onThemeChange); } }); const Icon = computed(() => { switch (props2.icon) { case "success": return createVNode(createSvgIconVNode(ICON_PATH_SUCCESS_NO_CIRCLE, iconColor.value, 38), { class: ToastIconClassName }); case "error": return createVNode(createSvgIconVNode(ICON_PATH_WARN, iconColor.value, 38), { class: ToastIconClassName }); case "loading": return createVNode("i", { "class": [ToastIconClassName, "uni-loading"] }, null, 2); default: return null; } }); return { Icon }; } let showToastState; let showType = ""; let timeoutId; const scope = /* @__PURE__ */ effectScope(); function watchVisible() { scope.run(() => { watch( [() => showToastState.visible, () => showToastState.duration], ([visible, duration]) => { if (visible) { timeoutId && clearTimeout(timeoutId); if (showType === "onShowLoading") return; timeoutId = setTimeout(() => { hidePopup("onHideToast"); }, duration); } else { timeoutId && clearTimeout(timeoutId); } } ); }); } function createToast(args) { if (!showToastState) { showToastState = reactive(extend(args, { visible: false })); nextTick(() => { watchVisible(); UniServiceJSBridge.on("onHidePopup", () => hidePopup("onHidePopup")); createRootApp(Toast, showToastState, () => { }).mount(ensureRoot("u-a-t")); }); } else { extend(showToastState, args); } setTimeout(() => { showToastState.visible = true; }, 10); } const showToast = /* @__PURE__ */ defineAsyncApi( API_SHOW_TOAST, (args, { resolve, reject }) => { createToast(args); showType = "onShowToast"; resolve(); }, ShowToastProtocol, ShowToastOptions ); const showLoadingDefaultState = { icon: "loading", duration: 1e8, image: "" }; const showLoading = /* @__PURE__ */ defineAsyncApi( API_SHOW_LOADING, (args, { resolve, reject }) => { extend(args, showLoadingDefaultState); createToast(args); showType = "onShowLoading"; resolve(); }, ShowLoadingProtocol, ShowLoadingOptions ); const hideToast = /* @__PURE__ */ defineAsyncApi( API_HIDE_TOAST, (args, { resolve, reject }) => { hidePopup("onHideToast"); resolve(); } ); const hideLoading = /* @__PURE__ */ defineAsyncApi( API_HIDE_LOADING, (args, { resolve, reject }) => { hidePopup("onHideLoading"); resolve(); } ); function hidePopup(type) { const { t: t2 } = useI18n(); if (!showType) { return; } let warnMsg = ""; if (type === "onHideToast" && showType !== "onShowToast") { warnMsg = t2("uni.showToast.unpaired"); } else if (type === "onHideLoading" && showType !== "onShowLoading") { warnMsg = t2("uni.showLoading.unpaired"); } if (warnMsg) { return console.warn(warnMsg); } showType = ""; setTimeout(() => { showToastState.visible = false; }, 10); } function usePopupStyle(props2) { const popupWidth = ref(0); const popupHeight = ref(0); const isDesktop = computed( () => popupWidth.value >= 500 && popupHeight.value >= 500 ); const popupStyle = computed(() => { const style = { content: { transform: "", left: "", top: "", bottom: "" }, triangle: { left: "", top: "", bottom: "", "border-width": "", "border-color": "" } }; const contentStyle = style.content; const triangleStyle = style.triangle; const popover = props2.popover; function getNumber(value) { return Number(value) || 0; } if (isDesktop.value && popover) { extend(triangleStyle, { position: "absolute", width: "0", height: "0", "margin-left": "-6px", "border-style": "solid" }); const popoverLeft = getNumber(popover.left); const popoverWidth = getNumber(popover.width); const popoverTop = getNumber(popover.top); const popoverHeight = getNumber(popover.height); const center = popoverLeft + popoverWidth / 2; contentStyle.transform = "none !important"; const contentLeft = Math.max(0, center - 300 / 2); contentStyle.left = `${contentLeft}px`; let triangleLeft = Math.max(12, center - contentLeft); triangleLeft = Math.min(300 - 12, triangleLeft); triangleStyle.left = `${triangleLeft}px`; const vcl = popupHeight.value / 2; if (popoverTop + popoverHeight - vcl > vcl - popoverTop) { contentStyle.top = "auto"; contentStyle.bottom = `${popupHeight.value - popoverTop + 6}px`; triangleStyle.bottom = "-6px"; triangleStyle["border-width"] = "6px 6px 0 6px"; triangleStyle["border-color"] = "#fcfcfd transparent transparent transparent"; } else { contentStyle.top = `${popoverTop + popoverHeight + 6}px`; triangleStyle.top = "-6px"; triangleStyle["border-width"] = "0 6px 6px 6px"; triangleStyle["border-color"] = "transparent transparent #fcfcfd transparent"; } } return style; }); onMounted(() => { const fixSize = () => { const { windowWidth, windowHeight, windowTop } = uni.getSystemInfoSync(); popupWidth.value = windowWidth; popupHeight.value = windowHeight + (windowTop || 0); }; window.addEventListener("resize", fixSize); fixSize(); onUnmounted(() => { window.removeEventListener("resize", fixSize); }); }); return { isDesktop, popupStyle }; } const ACTION_SHEET_THEME = { light: { listItemColor: "#000000", cancelItemColor: "#000000" }, dark: { listItemColor: "rgba(255, 255, 255, 0.8)", cancelItemColor: "rgba(255, 255, 255)" } }; function setActionSheetTheme(theme, actionSheetTheme) { const ActionSheetThemeKey = ["listItemColor", "cancelItemColor"]; ActionSheetThemeKey.forEach((key) => { actionSheetTheme[key] = ACTION_SHEET_THEME[theme][key]; }); } const props$4 = { title: { type: String, default: "" }, itemList: { type: Array, default() { return []; } }, itemColor: { type: String, default: "#000000" }, popover: { type: Object, default: null }, visible: { type: Boolean, default: false } }; const actionSheet = /* @__PURE__ */ defineComponent({ name: "ActionSheet", props: props$4, emits: ["close"], setup(props2, { emit: emit2 }) { initI18nShowActionSheetMsgsOnce(); const HEIGHT = ref(260); const contentHeight = ref(0); const titleHeight = ref(0); const deltaY = ref(0); const scrollTop = ref(0); const content = ref(null); const main = ref(null); const { t: t2 } = useI18n(); const { _close } = useActionSheetLoader(props2, emit2); const { popupStyle } = usePopupStyle(props2); let scroller; onMounted(() => { const { scroller: _scroller, handleTouchStart, handleTouchMove, handleTouchEnd } = useScroller(content.value, { enableY: true, friction: new Friction(1e-4), spring: new Spring(2, 90, 20), onScroll: (e2) => { scrollTop.value = e2.target.scrollTop; } }); scroller = _scroller; useTouchtrack(content.value, (e2) => { if (_scroller) { switch (e2.detail.state) { case "start": handleTouchStart(e2); break; case "move": handleTouchMove(e2); break; case "end": case "cancel": handleTouchEnd(e2); } } }, true); }); function _handleWheel($event) { const _deltaY = deltaY.value + $event.deltaY; if (Math.abs(_deltaY) > 10) { scrollTop.value += _deltaY / 3; scrollTop.value = scrollTop.value >= contentHeight.value ? contentHeight.value : scrollTop.value <= 0 ? 0 : scrollTop.value; scroller.scrollTo(scrollTop.value); } else { deltaY.value = _deltaY; } $event.preventDefault(); } watch(() => props2.visible, () => { nextTick(() => { if (props2.title) { titleHeight.value = document.querySelector(".uni-actionsheet__title").offsetHeight; } scroller.update(); if (content.value) contentHeight.value = content.value.clientHeight - HEIGHT.value; document.querySelectorAll(".uni-actionsheet__cell").forEach((item) => { initClick(item); }); }); }); const actionSheetTheme = useOnThemeChange(props2); return () => { return createVNode("uni-actionsheet", { "onTouchmove": onEventPrevent }, [createVNode(Transition, { "name": "uni-fade" }, { default: () => [withDirectives(createVNode("div", { "class": "uni-mask uni-actionsheet__mask", "onClick": () => _close(-1) }, null, 8, ["onClick"]), [[vShow, props2.visible]])] }), createVNode("div", { "class": ["uni-actionsheet", { "uni-actionsheet_toggle": props2.visible }], "style": popupStyle.value.content }, [createVNode("div", { "ref": main, "class": "uni-actionsheet__menu", "onWheel": _handleWheel }, [props2.title ? createVNode(Fragment, null, [createVNode("div", { "class": "uni-actionsheet__cell", "style": { height: `${titleHeight.value}px` } }, null), createVNode("div", { "class": "uni-actionsheet__title" }, [props2.title])]) : "", createVNode("div", { "style": { maxHeight: `${HEIGHT.value}px`, overflow: "hidden" } }, [createVNode("div", { "ref": content }, [props2.itemList.map((itemTitle, index2) => createVNode("div", { "key": index2, "style": { color: actionSheetTheme.listItemColor }, "class": "uni-actionsheet__cell", "onClick": () => _close(index2) }, [itemTitle], 12, ["onClick"]))], 512)])], 40, ["onWheel"]), createVNode("div", { "class": "uni-actionsheet__action" }, [createVNode("div", { "style": { color: actionSheetTheme.cancelItemColor }, "class": "uni-actionsheet__cell", "onClick": () => _close(-1) }, [t2("uni.showActionSheet.cancel")], 12, ["onClick"])]), createVNode("div", { "style": popupStyle.value.triangle }, null, 4)], 6)], 40, ["onTouchmove"]); }; } }); function useActionSheetLoader(props2, emit2) { function _close(tapIndex) { emit2("close", tapIndex); } const { key, disable } = useKeyboard(); watch(() => props2.visible, (value) => disable.value = !value); watchEffect(() => { const { value } = key; if (value === "esc") { _close && _close(-1); } }); return { _close }; } function initClick(dom) { const MAX_MOVE = 20; let x = 0; let y = 0; dom.addEventListener("touchstart", (event) => { const info = event.changedTouches[0]; x = info.clientX; y = info.clientY; }); dom.addEventListener("touchend", (event) => { const info = event.changedTouches[0]; if (Math.abs(info.clientX - x) < MAX_MOVE && Math.abs(info.clientY - y) < MAX_MOVE) { const target = event.target; const currentTarget = event.currentTarget; const customEvent = new CustomEvent("click", { bubbles: true, cancelable: true, target, currentTarget }); ["screenX", "screenY", "clientX", "clientY", "pageX", "pageY"].forEach((key) => { customEvent[key] = info[key]; }); event.target.dispatchEvent(customEvent); } }); } function useOnThemeChange(props2) { const actionSheetTheme = reactive({ listItemColor: "#000", cancelItemColor: "#000" }); const _onThemeChange = ({ theme }) => { setActionSheetTheme(theme, actionSheetTheme); }; watchEffect(() => { if (props2.visible) { actionSheetTheme.listItemColor = actionSheetTheme.cancelItemColor = props2.itemColor; if (props2.itemColor === "#000") { _onThemeChange({ theme: getTheme() }); onThemeChange(_onThemeChange); } } else { offThemeChange(_onThemeChange); } }); return actionSheetTheme; } let resolveAction; let rejectAction; let showActionSheetState; const onHidePopupOnce = /* @__PURE__ */ once(() => { UniServiceJSBridge.on( "onHidePopup", () => showActionSheetState.visible = false ); }); function onActionSheetClose(tapIndex) { if (tapIndex === -1) { rejectAction && rejectAction("cancel"); } else { resolveAction && resolveAction({ tapIndex }); } } const showActionSheet = /* @__PURE__ */ defineAsyncApi( API_SHOW_ACTION_SHEET, (args, { resolve, reject }) => { onHidePopupOnce(); resolveAction = resolve; rejectAction = reject; if (!showActionSheetState) { showActionSheetState = reactive(args); nextTick( () => (createRootApp( actionSheet, showActionSheetState, onActionSheetClose ).mount(ensureRoot("u-s-a-s")), //下一帧执行,确保首次显示时有动画效果 nextTick(() => showActionSheetState.visible = true)) ); } else { extend(showActionSheetState, args); showActionSheetState.visible = true; } }, ShowActionSheetProtocol, ShowActionSheetOptions ); const loadFontFace = /* @__PURE__ */ defineAsyncApi( API_LOAD_FONT_FACE, ({ family, source, desc }, { resolve, reject }) => { addFont(family, source, desc).then(() => { resolve(); }).catch((err) => { reject(`loadFontFace:fail ${err}`); }); }, LoadFontFaceProtocol ); function updateDocumentTitle(title) { { document.title = title; } UniServiceJSBridge.emit(ON_NAVIGATION_BAR_CHANGE, { titleText: title }); } function useDocumentTitle(pageMeta) { function update() { updateDocumentTitle(pageMeta.navigationBar.titleText); } watchEffect(update); onActivated(update); } function setNavigationBar(pageMeta, type, args, resolve, reject) { if (!pageMeta) { return reject("page not found"); } const { navigationBar } = pageMeta; switch (type) { case API_SET_NAVIGATION_BAR_COLOR: const { frontColor, backgroundColor, animation: animation2 } = args; const { duration, timingFunc } = animation2; if (frontColor) { navigationBar.titleColor = frontColor === "#000000" ? "#000000" : "#ffffff"; } if (backgroundColor) { navigationBar.backgroundColor = backgroundColor; } navigationBar.duration = duration + "ms"; navigationBar.timingFunc = timingFunc; break; case API_SHOW_NAVIGATION_BAR_LOADING: navigationBar.loading = true; break; case API_HIDE_NAVIGATION_BAR_LOADING: navigationBar.loading = false; break; case API_SET_NAVIGATION_BAR_TITLE: const { title } = args; navigationBar.titleText = title; break; } resolve(); } const setNavigationBarColor = /* @__PURE__ */ defineAsyncApi( API_SET_NAVIGATION_BAR_COLOR, (args, { resolve, reject }) => { setNavigationBar( getCurrentPageMeta(), API_SET_NAVIGATION_BAR_COLOR, args, resolve, reject ); }, SetNavigationBarColorProtocol, SetNavigationBarColorOptions ); const showNavigationBarLoading = /* @__PURE__ */ defineAsyncApi( API_SHOW_NAVIGATION_BAR_LOADING, (args, { resolve, reject }) => { setNavigationBar( getCurrentPageMeta(), API_SHOW_NAVIGATION_BAR_LOADING, args || {}, resolve, reject ); } ); const hideNavigationBarLoading = /* @__PURE__ */ defineAsyncApi( API_HIDE_NAVIGATION_BAR_LOADING, (args, { resolve, reject }) => { setNavigationBar( getCurrentPageMeta(), API_HIDE_NAVIGATION_BAR_LOADING, args || {}, resolve, reject ); } ); const setNavigationBarTitle = /* @__PURE__ */ defineAsyncApi( API_SET_NAVIGATION_BAR_TITLE, (args, { resolve, reject }) => { setNavigationBar( getCurrentPageMeta(), API_SET_NAVIGATION_BAR_TITLE, args, resolve, reject ); }, SetNavigationBarTitleProtocol ); const pageScrollTo = /* @__PURE__ */ defineAsyncApi( API_PAGE_SCROLL_TO, ({ scrollTop, selector, duration }, { resolve }) => { scrollTo(selector || scrollTop || 0, duration, true); resolve(); }, PageScrollToProtocol, PageScrollToOptions ); const startPullDownRefresh = /* @__PURE__ */ defineAsyncApi( API_START_PULL_DOWN_REFRESH, (_args, { resolve }) => { UniServiceJSBridge.invokeViewMethod( API_START_PULL_DOWN_REFRESH, {}, getCurrentPageId() ); resolve(); } ); const stopPullDownRefresh = /* @__PURE__ */ defineAsyncApi( API_STOP_PULL_DOWN_REFRESH, (_args, { resolve }) => { UniServiceJSBridge.invokeViewMethod( API_STOP_PULL_DOWN_REFRESH, {}, getCurrentPageId() ); resolve(); } ); const setTabBarItemProps = [ "text", "iconPath", "iconfont", "selectedIconPath", "visible" ]; const setTabBarStyleProps = [ "color", "selectedColor", "backgroundColor", "borderStyle", "midButton" ]; const setTabBarBadgeProps = ["badge", "redDot"]; function setProperties(item, props2, propsData) { props2.forEach(function(name) { if (hasOwn(propsData, name)) { item[name] = propsData[name]; } }); } function setTabBar(type, args, resolve) { const tabBar2 = useTabBar(); switch (type) { case API_SHOW_TAB_BAR: tabBar2.shown = true; break; case API_HIDE_TAB_BAR: tabBar2.shown = false; break; case API_SET_TAB_BAR_ITEM: const { index: index2 } = args; const tabBarItem = tabBar2.list[index2]; const oldPagePath = tabBarItem.pagePath; setProperties(tabBarItem, setTabBarItemProps, args); const { pagePath } = args; if (pagePath) { const newPagePath = addLeadingSlash(pagePath); if (newPagePath !== oldPagePath) { normalizeTabBarRoute(index2, oldPagePath, newPagePath); } } break; case API_SET_TAB_BAR_STYLE: setProperties(tabBar2, setTabBarStyleProps, args); break; case API_SHOW_TAB_BAR_RED_DOT: setProperties(tabBar2.list[args.index], setTabBarBadgeProps, { badge: "", redDot: true }); break; case API_SET_TAB_BAR_BADGE: setProperties(tabBar2.list[args.index], setTabBarBadgeProps, { badge: args.text, redDot: true }); break; case API_HIDE_TAB_BAR_RED_DOT: case API_REMOVE_TAB_BAR_BADGE: setProperties(tabBar2.list[args.index], setTabBarBadgeProps, { badge: "", redDot: false }); break; } resolve(); } const setTabBarItem = /* @__PURE__ */ defineAsyncApi( API_SET_TAB_BAR_ITEM, (args, { resolve }) => { setTabBar(API_SET_TAB_BAR_ITEM, args, resolve); }, SetTabBarItemProtocol, SetTabBarItemOptions ); const setTabBarStyle = /* @__PURE__ */ defineAsyncApi( API_SET_TAB_BAR_STYLE, (args, { resolve }) => { setTabBar(API_SET_TAB_BAR_STYLE, args, resolve); }, SetTabBarStyleProtocol, SetTabBarStyleOptions ); const hideTabBar = /* @__PURE__ */ defineAsyncApi( API_HIDE_TAB_BAR, (args, { resolve }) => { setTabBar(API_HIDE_TAB_BAR, args ? args : {}, resolve); }, HideTabBarProtocol ); const showTabBar = /* @__PURE__ */ defineAsyncApi( API_SHOW_TAB_BAR, (args, { resolve }) => { setTabBar(API_SHOW_TAB_BAR, args ? args : {}, resolve); }, ShowTabBarProtocol ); const hideTabBarRedDot = /* @__PURE__ */ defineAsyncApi( API_HIDE_TAB_BAR_RED_DOT, (args, { resolve }) => { setTabBar(API_HIDE_TAB_BAR_RED_DOT, args, resolve); }, HideTabBarRedDotProtocol, HideTabBarRedDotOptions ); const showTabBarRedDot = /* @__PURE__ */ defineAsyncApi( API_SHOW_TAB_BAR_RED_DOT, (args, { resolve }) => { setTabBar(API_SHOW_TAB_BAR_RED_DOT, args, resolve); }, ShowTabBarRedDotProtocol, ShowTabBarRedDotOptions ); const removeTabBarBadge = /* @__PURE__ */ defineAsyncApi( API_REMOVE_TAB_BAR_BADGE, (args, { resolve }) => { setTabBar(API_REMOVE_TAB_BAR_BADGE, args, resolve); }, RemoveTabBarBadgeProtocol, RemoveTabBarBadgeOptions ); const setTabBarBadge = /* @__PURE__ */ defineAsyncApi( API_SET_TAB_BAR_BADGE, (args, { resolve }) => { setTabBar(API_SET_TAB_BAR_BADGE, args, resolve); }, SetTabBarBadgeProtocol, SetTabBarBadgeOptions ); const UNI_TABBAR_ICON_FONT = "UniTabbarIconFont"; const _middleButton = { width: "50px", height: "50px", iconWidth: "24px" }; const TabBar = /* @__PURE__ */ defineSystemComponent({ name: "TabBar", setup() { const visibleList = ref([]); const _tabBar = useTabBar(); const tabBar2 = useTheme(_tabBar, () => { const tabBarStyle = parseTheme(_tabBar); tabBar2.backgroundColor = tabBarStyle.backgroundColor; tabBar2.borderStyle = tabBarStyle.borderStyle; tabBar2.color = tabBarStyle.color; tabBar2.selectedColor = tabBarStyle.selectedColor; tabBar2.blurEffect = tabBarStyle.blurEffect; if (tabBarStyle.list && tabBarStyle.list.length) { tabBarStyle.list.forEach((item, index2) => { tabBar2.list[index2].iconPath = item.iconPath; tabBar2.list[index2].selectedIconPath = item.selectedIconPath; }); } }); useVisibleList(tabBar2, visibleList); useTabBarCssVar(tabBar2); const onSwitchTab = useSwitchTab(useRoute(), tabBar2, visibleList); const { style, borderStyle, placeholderStyle } = useTabBarStyle(tabBar2); onMounted(() => { if (tabBar2.iconfontSrc) { loadFontFace({ family: UNI_TABBAR_ICON_FONT, source: `url("${tabBar2.iconfontSrc}")` }); } }); return () => { const tabBarItemsTsx = createTabBarItemsTsx(tabBar2, onSwitchTab, visibleList); return createVNode("uni-tabbar", { "class": "uni-tabbar-" + tabBar2.position }, [createVNode("div", { "class": "uni-tabbar", "style": style.value }, [createVNode("div", { "class": "uni-tabbar-border", "style": borderStyle.value }, null, 4), tabBarItemsTsx], 4), createVNode("div", { "class": "uni-placeholder", "style": placeholderStyle.value }, null, 4)], 2); }; } }); function useTabBarCssVar(tabBar2) { watch(() => tabBar2.shown, (value) => { updatePageCssVar({ "--window-bottom": normalizeWindowBottom(value ? parseInt(tabBar2.height) : 0) }); }); } function useVisibleList(tabBar2, visibleList) { const internalMidButton = ref(extend({ type: "midButton" }, tabBar2.midButton)); function setVisibleList() { let tempList = []; tempList = tabBar2.list.filter((item) => item.visible !== false); if (__UNI_FEATURE_TABBAR_MIDBUTTON__ && tabBar2.midButton) { internalMidButton.value = extend({}, _middleButton, internalMidButton.value, tabBar2.midButton); tempList = tempList.filter((item) => !isMidButton(item)); if (tempList.length % 2 === 0) { tempList.splice(Math.floor(tempList.length / 2), 0, internalMidButton.value); } } visibleList.value = tempList; } watchEffect(setVisibleList); } function useSwitchTab(route, tabBar2, visibleList) { watchEffect(() => { const meta = route.meta; if (meta.isTabBar) { const pagePath = meta.route; const index2 = visibleList.value.findIndex((item) => item.pagePath === pagePath); tabBar2.selectedIndex = index2; } }); return (tabBarItem, index2) => { const { type } = tabBarItem; return () => { if (__UNI_FEATURE_TABBAR_MIDBUTTON__ && type === "midButton") { return UniServiceJSBridge.invokeOnCallback(API_ON_TAB_BAR_MID_BUTTON_TAP); } const { pagePath, text: text2 } = tabBarItem; let url = addLeadingSlash(pagePath); if (url === __uniRoutes[0].alias) { url = "/"; } if (route.path !== url) { uni.switchTab({ from: "tabBar", url, tabBarText: text2 }); } else { invokeHook("onTabItemTap", { index: index2, text: text2, pagePath }); } }; }; } const DEFAULT_BG_COLOR = "#f7f7fa"; const BLUR_EFFECT_COLOR_DARK = "rgb(0, 0, 0, 0.8)"; const BLUR_EFFECT_COLOR_LIGHT = "rgb(250, 250, 250, 0.8)"; const BLUR_EFFECT_COLORS = { dark: BLUR_EFFECT_COLOR_DARK, light: BLUR_EFFECT_COLOR_LIGHT, extralight: BLUR_EFFECT_COLOR_LIGHT }; const BORDER_COLORS = { white: "rgba(255, 255, 255, 0.33)", black: "rgba(0, 0, 0, 0.33)" }; function useTabBarStyle(tabBar2) { const style = computed(() => { let backgroundColor = tabBar2.backgroundColor; const blurEffect = tabBar2.blurEffect; if (!backgroundColor) { if (cssBackdropFilter && blurEffect && blurEffect !== "none") { backgroundColor = BLUR_EFFECT_COLORS[blurEffect]; } } return { backgroundColor: backgroundColor || DEFAULT_BG_COLOR, backdropFilter: blurEffect !== "none" ? "blur(10px)" : blurEffect }; }); const borderStyle = computed(() => { const { borderStyle: borderStyle2 } = tabBar2; return { backgroundColor: BORDER_COLORS[borderStyle2] || borderStyle2 }; }); const placeholderStyle = computed(() => { return { height: tabBar2.height }; }); return { style, borderStyle, placeholderStyle }; } function isMidButton(item) { return item.type === "midButton"; } function createTabBarItemsTsx(tabBar2, onSwitchTab, visibleList) { const { selectedIndex, selectedColor, color } = tabBar2; return visibleList.value.map((item, index2) => { const selected = selectedIndex === index2; const textColor = selected ? selectedColor : color; const iconPath = (selected ? item.selectedIconPath || item.iconPath : item.iconPath) || ""; const iconfontText = item.iconfont ? selected ? item.iconfont.selectedText || item.iconfont.text : item.iconfont.text : void 0; const iconfontColor = item.iconfont ? selected ? item.iconfont.selectedColor || item.iconfont.color : item.iconfont.color : void 0; if (!__UNI_FEATURE_TABBAR_MIDBUTTON__) { return createTabBarItemTsx(textColor, iconPath, iconfontText, iconfontColor, item, tabBar2, index2, onSwitchTab); } return isMidButton(item) ? createTabBarMidButtonTsx(textColor, iconPath, iconfontText, iconfontColor, item, tabBar2, index2, onSwitchTab) : createTabBarItemTsx(textColor, iconPath, iconfontText, iconfontColor, item, tabBar2, index2, onSwitchTab); }); } function createTabBarItemTsx(color, iconPath, iconfontText, iconfontColor, tabBarItem, tabBar2, index2, onSwitchTab) { return createVNode("div", { "key": index2, "class": "uni-tabbar__item", "onClick": onSwitchTab(tabBarItem, index2) }, [createTabBarItemBdTsx(color, iconPath || "", iconfontText, iconfontColor, tabBarItem, tabBar2)], 8, ["onClick"]); } function createTabBarItemBdTsx(color, iconPath, iconfontText, iconfontColor, tabBarItem, tabBar2) { const { height } = tabBar2; return createVNode("div", { "class": "uni-tabbar__bd", "style": { height } }, [iconfontText ? createTabBarItemIconfontTsx(iconfontText, iconfontColor || BLUR_EFFECT_COLOR_DARK, tabBarItem, tabBar2) : iconPath && createTabBarItemIconTsx(iconPath, tabBarItem, tabBar2), tabBarItem.text && createTabBarItemTextTsx(color, tabBarItem, tabBar2), tabBarItem.redDot && createTabBarItemRedDotTsx(tabBarItem.badge)], 4); } function createTabBarItemIconTsx(iconPath, tabBarItem, tabBar2) { const { type, text: text2 } = tabBarItem; const { iconWidth } = tabBar2; const clazz2 = "uni-tabbar__icon" + (text2 ? " uni-tabbar__icon__diff" : ""); const style = { width: iconWidth, height: iconWidth }; return createVNode("div", { "class": clazz2, "style": style }, [type !== "midButton" && createVNode("img", { "src": getRealPath(iconPath) }, null, 8, ["src"])], 6); } function createTabBarItemIconfontTsx(iconfontText, iconfontColor, tabBarItem, tabBar2) { var _a; const { type, text: text2 } = tabBarItem; const { iconWidth } = tabBar2; const clazz2 = "uni-tabbar__icon" + (text2 ? " uni-tabbar__icon__diff" : ""); const style = { width: iconWidth, height: iconWidth }; const iconfontStyle = { fontSize: ((_a = tabBarItem.iconfont) == null ? void 0 : _a.fontSize) || iconWidth, color: iconfontColor }; return createVNode("div", { "class": clazz2, "style": style }, [type !== "midButton" && createVNode("div", { "class": "uni-tabbar__iconfont", "style": iconfontStyle }, [iconfontText], 4)], 6); } function createTabBarItemTextTsx(color, tabBarItem, tabBar2) { const { iconPath, text: text2 } = tabBarItem; const { fontSize, spacing } = tabBar2; const style = { color, fontSize, lineHeight: !iconPath ? 1.8 : "normal", marginTop: !iconPath ? "inherit" : spacing }; return createVNode("div", { "class": "uni-tabbar__label", "style": style }, [text2], 4); } function createTabBarItemRedDotTsx(badge) { const clazz2 = "uni-tabbar__reddot" + (badge ? " uni-tabbar__badge" : ""); return createVNode("div", { "class": clazz2 }, [badge], 2); } function createTabBarMidButtonTsx(color, iconPath, iconfontText, iconfontColor, midButton, tabBar2, index2, onSwitchTab) { const { width, height, backgroundImage, iconWidth } = midButton; return createVNode("div", { "key": "midButton", "class": "uni-tabbar__item", "style": { flex: "0 0 " + width, position: "relative" }, "onClick": onSwitchTab(midButton, index2) }, [createVNode("div", { "class": "uni-tabbar__mid", "style": { width, height, backgroundImage: backgroundImage ? "url('" + getRealPath(backgroundImage) + "')" : "none" } }, [iconPath && createVNode("img", { "style": { width: iconWidth, height: iconWidth }, "src": getRealPath(iconPath) }, null, 12, ["src"])], 4), createTabBarItemBdTsx(color, iconPath, iconfontText, iconfontColor, midButton, tabBar2)], 12, ["onClick"]); } const DEFAULT_CSS_VAR_VALUE = "0px"; let globalLayoutState = void 0; function getLayoutState() { return globalLayoutState; } const LayoutComponent = /* @__PURE__ */ defineSystemComponent({ name: "Layout", setup(_props, { emit: emit2 }) { const rootRef = ref(null); initCssVar(); const keepAliveRoute = __UNI_FEATURE_PAGES__ && useKeepAliveRoute(); const { layoutState, windowState } = useState(); useMaxWidth(layoutState, rootRef); const topWindow = __UNI_FEATURE_TOPWINDOW__ && useTopWindow(layoutState); const leftWindow = __UNI_FEATURE_LEFTWINDOW__ && useLeftWindow(layoutState); const rightWindow = __UNI_FEATURE_RIGHTWINDOW__ && useRightWindow(layoutState); const showTabBar2 = __UNI_FEATURE_TABBAR__ && useShowTabBar(); const clazz2 = useAppClass(showTabBar2); globalLayoutState = layoutState; return () => { const layoutTsx = createLayoutTsx(keepAliveRoute, layoutState, windowState, topWindow, leftWindow, rightWindow); const tabBarTsx = __UNI_FEATURE_TABBAR__ && createTabBarTsx(showTabBar2); return createVNode("uni-app", { "ref": rootRef, "class": clazz2.value }, [layoutTsx, tabBarTsx], 2); }; } }); function useAppClass(showTabBar2) { const showMaxWidth = ref(false); return computed(() => { return { "uni-app--showtabbar": showTabBar2 && showTabBar2.value, "uni-app--maxwidth": showMaxWidth.value }; }); } function initCssVar() { updateCssVar({ "--status-bar-height": DEFAULT_CSS_VAR_VALUE, "--top-window-height": DEFAULT_CSS_VAR_VALUE, "--window-left": DEFAULT_CSS_VAR_VALUE, "--window-right": DEFAULT_CSS_VAR_VALUE, "--window-margin": DEFAULT_CSS_VAR_VALUE, "--tab-bar-height": DEFAULT_CSS_VAR_VALUE }); } function initMediaQuery(minWidth, callback) { const mediaQueryList = window.matchMedia("(min-width: " + minWidth + "px)"); if (mediaQueryList.addEventListener) { mediaQueryList.addEventListener("change", callback); } else { mediaQueryList.addListener(callback); } return mediaQueryList.matches; } function useMaxWidth(layoutState, rootRef) { const route = usePageRoute(); function checkMaxWidth2() { const windowWidth = document.body.clientWidth; const pages = getCurrentPages(); let meta = {}; if (pages.length > 0) { const curPage = pages[pages.length - 1]; meta = curPage.$page.meta; } else { const routeOptions = getRouteOptions(route.path, true); if (routeOptions) { meta = routeOptions.meta; } } const maxWidth2 = parseInt(String((hasOwn(meta, "maxWidth") ? meta.maxWidth : __uniConfig.globalStyle.maxWidth) || Number.MAX_SAFE_INTEGER)); let showMaxWidth = false; if (windowWidth > maxWidth2) { showMaxWidth = true; } else { showMaxWidth = false; } if (showMaxWidth && maxWidth2) { layoutState.marginWidth = (windowWidth - maxWidth2) / 2; nextTick(() => { const rootEl = rootRef.value; if (rootEl) { rootEl.setAttribute("style", "max-width:" + maxWidth2 + "px;margin:0 auto;"); } }); } else { layoutState.marginWidth = 0; nextTick(() => { const rootEl = rootRef.value; if (rootEl) { rootEl.removeAttribute("style"); } }); } } watch([() => route.path], checkMaxWidth2); onMounted(() => { checkMaxWidth2(); window.addEventListener("resize", checkMaxWidth2); }); } function useState() { const route = usePageRoute(); if (!__UNI_FEATURE_RESPONSIVE__) { const layoutState2 = reactive({ marginWidth: 0, leftWindowWidth: 0, rightWindowWidth: 0 }); watch(() => layoutState2.marginWidth, (value) => updateCssVar({ "--window-margin": value + "px" })); watch(() => layoutState2.leftWindowWidth + layoutState2.marginWidth, (value) => { updateCssVar({ "--window-left": value + "px" }); }); watch(() => layoutState2.rightWindowWidth + layoutState2.marginWidth, (value) => { updateCssVar({ "--window-right": value + "px" }); }); return { layoutState: layoutState2, windowState: computed(() => ({})) }; } const topWindowMediaQuery = ref(false); const leftWindowMediaQuery = ref(false); const rightWindowMediaQuery = ref(false); const showTopWindow2 = computed(() => __UNI_FEATURE_TOPWINDOW__ && route.meta.topWindow !== false && topWindowMediaQuery.value); const showLeftWindow2 = computed(() => __UNI_FEATURE_LEFTWINDOW__ && route.meta.leftWindow !== false && leftWindowMediaQuery.value); const showRightWindow2 = computed(() => __UNI_FEATURE_RIGHTWINDOW__ && route.meta.rightWindow !== false && rightWindowMediaQuery.value); const layoutState = reactive({ topWindowMediaQuery, showTopWindow: showTopWindow2, apiShowTopWindow: false, leftWindowMediaQuery, showLeftWindow: showLeftWindow2, apiShowLeftWindow: false, rightWindowMediaQuery, showRightWindow: showRightWindow2, apiShowRightWindow: false, topWindowHeight: 0, marginWidth: 0, leftWindowWidth: 0, rightWindowWidth: 0, navigationBarTitleText: "", topWindowStyle: {}, leftWindowStyle: {}, rightWindowStyle: {} }); const props2 = ["topWindow", "leftWindow", "rightWindow"]; props2.forEach((prop) => { var _a; const matchMedia = (_a = __uniConfig[prop]) == null ? void 0 : _a.matchMedia; let topWindowMinWidth = RESPONSIVE_MIN_WIDTH; if (matchMedia && hasOwn(matchMedia, "minWidth")) { const minWidth = matchMedia.minWidth; topWindowMinWidth = checkMinWidth(minWidth) ? minWidth : topWindowMinWidth; } const matches2 = initMediaQuery(topWindowMinWidth, (ev) => { layoutState[`${prop}MediaQuery`] = ev.matches; }); layoutState[`${prop}MediaQuery`] = matches2; }); watch(() => layoutState.topWindowHeight, (value) => updateCssVar({ "--top-window-height": value + "px" })); watch(() => layoutState.marginWidth, (value) => updateCssVar({ "--window-margin": value + "px" })); watch(() => layoutState.leftWindowWidth + layoutState.marginWidth, (value) => { updateCssVar({ "--window-left": value + "px" }); }); watch(() => layoutState.rightWindowWidth + layoutState.marginWidth, (value) => { updateCssVar({ "--window-right": value + "px" }); }); UniServiceJSBridge.on(ON_NAVIGATION_BAR_CHANGE, (navigationBar) => { layoutState.navigationBarTitleText = navigationBar.titleText; }); const windowState = computed(() => ({ matchTopWindow: layoutState.topWindowMediaQuery, showTopWindow: layoutState.showTopWindow || layoutState.apiShowTopWindow, matchLeftWindow: layoutState.leftWindowMediaQuery, showLeftWindow: layoutState.showLeftWindow || layoutState.apiShowLeftWindow, matchRightWindow: layoutState.rightWindowMediaQuery, showRightWindow: layoutState.showRightWindow || layoutState.apiShowRightWindow })); return { layoutState, windowState }; } function createLayoutTsx(keepAliveRoute, layoutState, windowState, topWindow, leftWindow, rightWindow) { const routerVNode = __UNI_FEATURE_PAGES__ ? createRouterViewVNode(keepAliveRoute) : createPageVNode(); if (!__UNI_FEATURE_RESPONSIVE__) { return routerVNode; } const topWindowTsx = __UNI_FEATURE_TOPWINDOW__ ? createTopWindowTsx(topWindow, layoutState, windowState.value) : null; const leftWindowTsx = __UNI_FEATURE_LEFTWINDOW__ ? createLeftWindowTsx(leftWindow, layoutState, windowState.value) : null; const rightWindowTsx = __UNI_FEATURE_RIGHTWINDOW__ ? createRightWindowTsx(rightWindow, layoutState, windowState.value) : null; return createVNode("uni-layout", { "class": { "uni-app--showtopwindow": __UNI_FEATURE_TOPWINDOW__ && layoutState.showTopWindow, "uni-app--showleftwindow": __UNI_FEATURE_LEFTWINDOW__ && layoutState.showLeftWindow, "uni-app--showrightwindow": __UNI_FEATURE_RIGHTWINDOW__ && layoutState.showRightWindow } }, [topWindowTsx, createVNode("uni-content", null, [createVNode("uni-main", null, [routerVNode]), leftWindowTsx, rightWindowTsx])], 2); } function useShowTabBar(emit2) { const route = usePageRoute(); const tabBar2 = useTabBar(); const showTabBar2 = computed(() => route.meta.isTabBar && tabBar2.shown); updateCssVar({ "--tab-bar-height": tabBar2.height }); return showTabBar2; } function createTabBarTsx(showTabBar2) { return withDirectives(createVNode(TabBar, null, null, 512), [[vShow, showTabBar2.value]]); } function createPageVNode() { return createVNode(__uniRoutes[0].component); } function createRouterViewVNode({ routeKey, isTabBar, routeCache: routeCache2 }) { return createVNode(RouterView, null, { default: withCtx(({ Component }) => [(openBlock(), createBlock(KeepAlive, { matchBy: "key", cache: routeCache2 }, [(openBlock(), createBlock(resolveDynamicComponent(Component), { type: isTabBar.value ? "tabBar" : "", key: routeKey.value }))], 1032, ["cache"]))]), _: 1 /* STABLE */ }); } function useTopWindow(layoutState) { const { component, style } = __uniConfig.topWindow; const windowRef = ref(null); function updateWindow() { const instance2 = windowRef.value; const el = resolveOwnerEl(instance2.$); const height = el.getBoundingClientRect().height; layoutState.topWindowHeight = height; } onMounted(updateWindow); watch(() => layoutState.showTopWindow || layoutState.apiShowTopWindow, () => nextTick(updateWindow)); layoutState.topWindowStyle = style; return { component, windowRef }; } function useLeftWindow(layoutState) { const { component, style } = __uniConfig.leftWindow; const windowRef = ref(null); function updateWindow() { const instance2 = windowRef.value; const el = resolveOwnerEl(instance2.$); const width = el.getBoundingClientRect().width; layoutState.leftWindowWidth = width; } onMounted(updateWindow); watch(() => layoutState.showLeftWindow || layoutState.apiShowLeftWindow, () => nextTick(updateWindow)); layoutState.leftWindowStyle = style; return { component, windowRef }; } function useRightWindow(layoutState) { const { component, style } = __uniConfig.rightWindow; const windowRef = ref(null); function updateWindow() { const instance2 = windowRef.value; const el = resolveOwnerEl(instance2.$); const width = el.getBoundingClientRect().width; layoutState.rightWindowWidth = width; } onMounted(updateWindow); watch(() => layoutState.showRightWindow || layoutState.apiShowRightWindow, () => nextTick(updateWindow)); layoutState.rightWindowStyle = style; return { component, windowRef }; } function createTopWindowTsx(topWindow, layoutState, windowState) { if (topWindow) { const { component: TopWindow, windowRef } = topWindow; return withDirectives(createVNode("uni-top-window", null, [createVNode("div", { "class": "uni-top-window", "style": layoutState.topWindowStyle }, [createVNode(TopWindow, mergeProps({ "ref": windowRef, "navigation-bar-title-text": layoutState.navigationBarTitleText }, windowState), null, 16, ["navigation-bar-title-text"])], 4), createVNode("div", { "class": "uni-top-window--placeholder", "style": { height: layoutState.topWindowHeight + "px" } }, null, 4)], 512), [[vShow, layoutState.showTopWindow || layoutState.apiShowTopWindow]]); } } function createLeftWindowTsx(leftWindow, layoutState, windowState) { if (leftWindow) { const { component: LeftWindow, windowRef } = leftWindow; return withDirectives(createVNode("uni-left-window", { "data-show": layoutState.apiShowLeftWindow || void 0, "style": layoutState.leftWindowStyle }, [layoutState.apiShowLeftWindow ? createVNode("div", { "class": "uni-mask", "onClick": () => layoutState.apiShowLeftWindow = false }, null, 8, ["onClick"]) : null, createVNode("div", { "class": "uni-left-window" }, [createVNode(LeftWindow, mergeProps({ "ref": windowRef }, windowState), null, 16)])], 12, ["data-show"]), [[vShow, layoutState.showLeftWindow || layoutState.apiShowLeftWindow]]); } } function createRightWindowTsx(rightWindow, layoutState, windowState) { if (rightWindow) { const { component: RightWindow, windowRef } = rightWindow; return withDirectives(createVNode("uni-right-window", { "data-show": layoutState.apiShowRightWindow || void 0, "style": layoutState.rightWindowStyle }, [layoutState.apiShowRightWindow ? createVNode("div", { "class": "uni-mask", "onClick": () => layoutState.apiShowRightWindow = false }, null, 8, ["onClick"]) : null, createVNode("div", { "class": "uni-right-window" }, [createVNode(RightWindow, mergeProps({ "ref": windowRef }, windowState), null, 16)])], 12, ["data-show"]), [[vShow, layoutState.showRightWindow || layoutState.apiShowRightWindow]]); } } const showTopWindow = /* @__PURE__ */ defineAsyncApi( "showTopWindow", (_, { resolve, reject }) => { const state2 = getLayoutState(); if (!state2) { reject(); return; } state2.apiShowTopWindow = true; nextTick(resolve); } ); const hideTopWindow = /* @__PURE__ */ defineAsyncApi( "hideTopWindow", (_, { resolve, reject }) => { const state2 = getLayoutState(); if (!state2) { reject(); return; } state2.apiShowTopWindow = false; nextTick(resolve); } ); const showLeftWindow = /* @__PURE__ */ defineAsyncApi( "showLeftWindow", (_, { resolve, reject }) => { const state2 = getLayoutState(); if (!state2) { reject(); return; } state2.apiShowLeftWindow = true; nextTick(resolve); } ); const hideLeftWindow = /* @__PURE__ */ defineAsyncApi( "hideLeftWindow", (_, { resolve, reject }) => { const state2 = getLayoutState(); if (!state2) { reject(); return; } state2.apiShowLeftWindow = false; nextTick(resolve); } ); const showRightWindow = /* @__PURE__ */ defineAsyncApi( "showRightWindow", (_, { resolve, reject }) => { const state2 = getLayoutState(); if (!state2) { reject(); return; } state2.apiShowRightWindow = true; nextTick(resolve); } ); const hideRightWindow = /* @__PURE__ */ defineAsyncApi( "hideRightWindow", (_, { resolve, reject }) => { const state2 = getLayoutState(); if (!state2) { reject(); return; } state2.apiShowRightWindow = false; nextTick(resolve); } ); const getTopWindowStyle = /* @__PURE__ */ defineSyncApi( "getTopWindowStyle", () => { const state2 = getLayoutState(); return extend({}, state2 && state2.topWindowStyle); } ); const setTopWindowStyle = /* @__PURE__ */ defineSyncApi( "setTopWindowStyle", (style) => { const state2 = getLayoutState(); if (state2) { state2.topWindowStyle = style; } } ); const getLeftWindowStyle = /* @__PURE__ */ defineSyncApi( "getLeftWindowStyle", () => { const state2 = getLayoutState(); return extend({}, state2 && state2.leftWindowStyle); } ); const setLeftWindowStyle = /* @__PURE__ */ defineSyncApi( "setLeftWindowStyle", (style) => { const state2 = getLayoutState(); if (state2) { state2.leftWindowStyle = style; } } ); const getRightWindowStyle = /* @__PURE__ */ defineSyncApi("getRightWindowStyle", () => { const state2 = getLayoutState(); return extend({}, state2 && state2.rightWindowStyle); }); const setRightWindowStyle = /* @__PURE__ */ defineSyncApi("setRightWindowStyle", (style) => { const state2 = getLayoutState(); if (state2) { state2.rightWindowStyle = style; } }); const saveImageToPhotosAlbum = /* @__PURE__ */ defineAsyncApi( API_SAVE_IMAGE_TO_PHOTOS_ALBUM, createUnsupportedAsyncApi(API_SAVE_IMAGE_TO_PHOTOS_ALBUM) ); const API_GET_RECORDER_MANAGER = "getRecorderManager"; const getRecorderManager = /* @__PURE__ */ defineSyncApi( API_GET_RECORDER_MANAGER, createUnsupportedSyncApi(API_GET_RECORDER_MANAGER) ); const saveVideoToPhotosAlbum = /* @__PURE__ */ defineAsyncApi( API_SAVE_VIDEO_TO_PHOTOS_ALBUM, createUnsupportedAsyncApi(API_SAVE_VIDEO_TO_PHOTOS_ALBUM) ); const API_CREATE_CAMERA_CONTEXT = "createCameraContext"; const createCameraContext = /* @__PURE__ */ defineSyncApi( API_CREATE_CAMERA_CONTEXT, createUnsupportedSyncApi(API_CREATE_CAMERA_CONTEXT) ); const API_CREATE_LIVE_PLAYER_CONTEXT = "createLivePlayerContext"; const createLivePlayerContext = /* @__PURE__ */ defineSyncApi( API_CREATE_LIVE_PLAYER_CONTEXT, createUnsupportedSyncApi(API_CREATE_LIVE_PLAYER_CONTEXT) ); const API_SAVE_FILE = "saveFile"; const saveFile = /* @__PURE__ */ defineAsyncApi( API_SAVE_FILE, createUnsupportedAsyncApi(API_SAVE_FILE) ); const API_GET_SAVED_FILE_LIST = "getSavedFileList"; const getSavedFileList = /* @__PURE__ */ defineAsyncApi( API_GET_SAVED_FILE_LIST, createUnsupportedAsyncApi(API_GET_SAVED_FILE_LIST) ); const API_GET_SAVED_FILE_INFO = "getSavedFileInfo"; const getSavedFileInfo = /* @__PURE__ */ defineAsyncApi( API_GET_SAVED_FILE_INFO, createUnsupportedAsyncApi(API_GET_SAVED_FILE_INFO) ); const API_REMOVE_SAVED_FILE = "removeSavedFile"; const removeSavedFile = /* @__PURE__ */ defineAsyncApi( API_REMOVE_SAVED_FILE, createUnsupportedAsyncApi(API_REMOVE_SAVED_FILE) ); const API_ON_MEMORY_WARNING = "onMemoryWarning"; const onMemoryWarning = /* @__PURE__ */ defineOnApi( API_ON_MEMORY_WARNING, createUnsupportedOnApi(API_ON_MEMORY_WARNING) ); const API_ON_GYROSCOPE_CHANGE = "onGyroscopeChange"; const onGyroscopeChange = /* @__PURE__ */ defineOnApi( API_ON_GYROSCOPE_CHANGE, createUnsupportedOnApi(API_ON_GYROSCOPE_CHANGE) ); const API_START_GYROSCOPE = "startGyroscope"; const startGyroscope = /* @__PURE__ */ defineAsyncApi( API_START_GYROSCOPE, createUnsupportedAsyncApi(API_START_GYROSCOPE) ); const API_STOP_GYROSCOPE = "stopGyroscope"; const stopGyroscope = /* @__PURE__ */ defineAsyncApi( API_STOP_GYROSCOPE, createUnsupportedAsyncApi(API_STOP_GYROSCOPE) ); const API_SCAN_CODE = "scanCode"; const scanCode = /* @__PURE__ */ defineAsyncApi( API_SCAN_CODE, createUnsupportedAsyncApi(API_SCAN_CODE) ); const API_SET_SCREEN_BRIGHTNESS = "setScreenBrightness"; const setScreenBrightness = /* @__PURE__ */ defineAsyncApi( API_SET_SCREEN_BRIGHTNESS, createUnsupportedAsyncApi(API_SET_SCREEN_BRIGHTNESS) ); const API_GET_SCREEN_BRIGHTNESS = "getScreenBrightness"; const getScreenBrightness = /* @__PURE__ */ defineAsyncApi( API_GET_SCREEN_BRIGHTNESS, createUnsupportedAsyncApi(API_GET_SCREEN_BRIGHTNESS) ); const API_SET_KEEP_SCREEN_ON = "setKeepScreenOn"; const setKeepScreenOn = /* @__PURE__ */ defineAsyncApi( API_SET_KEEP_SCREEN_ON, createUnsupportedAsyncApi(API_SET_KEEP_SCREEN_ON) ); const API_ON_USER_CAPTURE_SCREEN = "onUserCaptureScreen"; const onUserCaptureScreen = /* @__PURE__ */ defineOnApi( API_ON_USER_CAPTURE_SCREEN, createUnsupportedOnApi(API_ON_USER_CAPTURE_SCREEN) ); const API_ADD_PHONE_CONTACT = "addPhoneContact"; const addPhoneContact = /* @__PURE__ */ defineAsyncApi( API_ADD_PHONE_CONTACT, createUnsupportedAsyncApi(API_ADD_PHONE_CONTACT) ); const API_LOGIN = "login"; const login = /* @__PURE__ */ defineAsyncApi( API_LOGIN, createUnsupportedAsyncApi(API_LOGIN) ); const API_GET_PROVIDER = "getProvider"; const getProvider = /* @__PURE__ */ defineAsyncApi( API_GET_PROVIDER, createUnsupportedAsyncApi(API_GET_PROVIDER) ); const api = /* @__PURE__ */ Object.defineProperty({ __proto__: null, $emit, $off, $on, $once, addInterceptor, addPhoneContact, arrayBufferToBase64, base64ToArrayBuffer, canIUse, canvasGetImageData, canvasPutImageData, canvasToTempFilePath, chooseFile, chooseImage, chooseLocation, chooseVideo, clearStorage, clearStorageSync, closePreviewImage, closeSocket, connectSocket, createAnimation: createAnimation$1, createCameraContext, createCanvasContext, createInnerAudioContext, createIntersectionObserver, createLivePlayerContext, createMapContext, createMediaQueryObserver, createSelectorQuery, createVideoContext, cssBackdropFilter, cssConstant, cssEnv, cssVar, downloadFile, getAppBaseInfo, getClipboardData, getDeviceInfo, getEnterOptionsSync, getFileInfo, getImageInfo, getLaunchOptionsSync, getLeftWindowStyle, getLocale, getLocation, getNetworkType, getProvider, getPushClientId, getRecorderManager, getRightWindowStyle, getSavedFileInfo, getSavedFileList, getScreenBrightness, getSelectedTextRange: getSelectedTextRange$1, getStorage, getStorageInfo, getStorageInfoSync, getStorageSync, getSystemInfo, getSystemInfoSync, getTopWindowStyle, getVideoInfo, getWindowInfo, hideKeyboard, hideLeftWindow, hideLoading, hideNavigationBarLoading, hideRightWindow, hideTabBar, hideTabBarRedDot, hideToast, hideTopWindow, interceptors, invokePushCallback, loadFontFace, login, makePhoneCall, navigateBack, navigateTo, offAccelerometerChange, offAppHide, offAppShow, offCompassChange, offError, offLocationChange, offLocationChangeError, offNetworkStatusChange, offPageNotFound, offPushMessage, offThemeChange: offThemeChange$1, offUnhandledRejection, offWindowResize, onAccelerometerChange, onAppHide, onAppShow, onCompassChange, onCreateVueApp, onError, onGyroscopeChange, onLocaleChange, onLocationChange, onLocationChangeError, onMemoryWarning, onNetworkStatusChange, onPageNotFound, onPushMessage, onSocketClose, onSocketError, onSocketMessage, onSocketOpen, onTabBarMidButtonTap, onThemeChange: onThemeChange$1, onUnhandledRejection, onUserCaptureScreen, onWindowResize, openDocument, openLocation, pageScrollTo, preloadPage, previewImage, reLaunch, redirectTo, removeInterceptor, removeSavedFile, removeStorage, removeStorageSync, removeTabBarBadge, request, saveFile, saveImageToPhotosAlbum, saveVideoToPhotosAlbum, scanCode, sendSocketMessage, setClipboardData, setKeepScreenOn, setLeftWindowStyle, setLocale, setNavigationBarColor, setNavigationBarTitle, setPageMeta, setRightWindowStyle, setScreenBrightness, setStorage, setStorageSync, setTabBarBadge, setTabBarItem, setTabBarStyle, setTopWindowStyle, showActionSheet, showLeftWindow, showLoading, showModal, showNavigationBarLoading, showRightWindow, showTabBar, showTabBarRedDot, showToast, showTopWindow, startAccelerometer, startCompass, startGyroscope, startLocationUpdate, startPullDownRefresh, stopAccelerometer, stopCompass, stopGyroscope, stopLocationUpdate, stopPullDownRefresh, switchTab, uploadFile, upx2px, vibrateLong, vibrateShort }, Symbol.toStringTag, { value: "Module" }); const CONTEXT_ID = "MAP_LOCATION"; const MapLocation = /* @__PURE__ */ defineSystemComponent({ name: "MapLocation", setup() { const state2 = reactive({ latitude: 0, longitude: 0, rotate: 0 }); { let compassChangeHandler = function(res) { state2.rotate = res.direction; }, updateLocation = function() { getLocation({ type: "gcj02", success: (res) => { state2.latitude = res.latitude; state2.longitude = res.longitude; }, complete: () => { timer = setTimeout(updateLocation, 3e4); } }); }, removeLocation = function() { if (timer) { clearTimeout(timer); } offCompassChange(compassChangeHandler); }; const onMapReady = inject("onMapReady"); let timer; onCompassChange(compassChangeHandler); onMapReady(updateLocation); onUnmounted(removeLocation); const addMapChidlContext = inject("addMapChidlContext"); const removeMapChidlContext = inject("removeMapChidlContext"); const context = { id: CONTEXT_ID, state: state2 }; addMapChidlContext(context); onUnmounted(() => removeMapChidlContext(context)); } return () => { return state2.latitude ? createVNode(MapMarker, mergeProps({ "anchor": { x: 0.5, y: 0.5 }, "width": "44", "height": "44", "iconPath": ICON_PATH_ORIGIN }, state2), null, 16, ["iconPath"]) : null; }; } }); const props$3 = { // 边框虚线,腾讯地图支持,google 高德 地图不支持,默认值为[0, 0] 为实线,非 [0, 0] 为虚线,H5 端无法像微信小程序一样控制虚线的间隔像素大小 dashArray: { type: Array, default: () => [0, 0] }, // 经纬度数组,[{latitude: 0, longitude: 0}] points: { type: Array, required: true }, // 描边的宽度 strokeWidth: { type: Number, default: 1 }, // 描边的颜色,十六进制 strokeColor: { type: String, default: "#000000" }, // 填充颜色,十六进制 fillColor: { type: String, default: "#00000000" }, // 设置多边形 Z 轴数值 zIndex: { type: Number, default: 0 } }; const MapPolygon = /* @__PURE__ */ defineSystemComponent({ name: "MapPolygon", props: props$3, setup(props2) { let polygonIns; const onMapReady = inject("onMapReady"); onMapReady((map, maps2, trigger) => { function drawPolygon() { const { points, strokeWidth, strokeColor, dashArray, fillColor, zIndex } = props2; const path = points.map((item) => { const { latitude, longitude } = item; if (getIsAMap()) { return [longitude, latitude]; } else if (getIsBMap()) { return new maps2.Point(longitude, latitude); } else { return new maps2.LatLng(latitude, longitude); } }); const { r: fcR, g: fcG, b: fcB, a: fcA } = hexToRgba(fillColor); const { r: scR, g: scG, b: scB, a: scA } = hexToRgba(strokeColor); const polygonOptions = { //多边形是否可点击。 clickable: true, //鼠标在多边形内的光标样式。 cursor: "crosshair", //多边形是否可编辑。 editable: false, // 地图实例,即要显示多边形的地图 // @ts-ignore map, // 区域填充色 fillColor: "", //多边形的路径,以经纬度坐标数组构成。 path, // 区域边框 strokeColor: "", //多边形的边框样式。实线是solid,虚线是dash。 strokeDashStyle: dashArray.some((item) => item > 0) ? "dash" : "solid", //多边形的边框线宽。 strokeWeight: strokeWidth, //多边形是否可见。 visible: true, //多边形的zIndex值。 zIndex }; if (maps2.Color) { polygonOptions.fillColor = new maps2.Color(fcR, fcG, fcB, fcA); polygonOptions.strokeColor = new maps2.Color(scR, scG, scB, scA); } else { polygonOptions.fillColor = `rgb(${fcR}, ${fcG}, ${fcB})`; polygonOptions.fillOpacity = fcA; polygonOptions.strokeColor = `rgb(${scR}, ${scG}, ${scB})`; polygonOptions.strokeOpacity = scA; } if (polygonIns) { polygonIns.setOptions(polygonOptions); return; } if (getIsBMap()) { polygonIns = new maps2.Polygon(polygonOptions.path, polygonOptions); map.addOverlay(polygonIns); } else { polygonIns = new maps2.Polygon(polygonOptions); } } drawPolygon(); watch(props2, drawPolygon); }); onUnmounted(() => { polygonIns.setMap(null); }); return () => null; } }); const props$2 = { id: { type: String, default: "" }, latitude: { type: [String, Number], default: 0 }, longitude: { type: [String, Number], default: 0 }, scale: { type: [String, Number], default: 16 }, markers: { type: Array, default() { return []; } }, includePoints: { type: Array, default() { return []; } }, polyline: { type: Array, default() { return []; } }, circles: { type: Array, default() { return []; } }, controls: { type: Array, default() { return []; } }, showLocation: { type: [Boolean, String], default: false }, libraries: { type: Array, default() { return []; } }, polygons: { type: Array, default: () => [] } }; function getPoints(points) { const newPoints = []; if (isArray(points)) { points.forEach((point) => { if (point && point.latitude && point.longitude) { newPoints.push({ latitude: point.latitude, longitude: point.longitude }); } }); } return newPoints; } function getAMapPosition(maps2, latitude, longitude) { return new maps2.LngLat(longitude, latitude); } function getBMapPosition(maps2, latitude, longitude) { return new maps2.Point(longitude, latitude); } function getGoogleOrQQMapPosition(maps2, latitude, longitude) { return new maps2.LatLng(latitude, longitude); } function getMapPosition(maps2, latitude, longitude) { if (getIsBMap()) { return getBMapPosition(maps2, latitude, longitude); } else if (getIsAMap()) { return getAMapPosition(maps2, latitude, longitude); } else { return getGoogleOrQQMapPosition(maps2, latitude, longitude); } } function getLat(latLng) { if ("getLat" in latLng) { return latLng.getLat(); } else { if (getIsBMap()) { return latLng.lat; } return latLng.lat(); } } function getLng(latLng) { if ("getLng" in latLng) { return latLng.getLng(); } else { if (getIsBMap()) { return latLng.lng; } return latLng.lng(); } } function useMap(props2, rootRef, emit2) { const trigger = useCustomEvent(rootRef, emit2); const mapRef = ref(null); let maps2; let map; const state2 = reactive({ latitude: Number(props2.latitude), longitude: Number(props2.longitude), includePoints: getPoints(props2.includePoints) }); const onMapReadyCallbacks = []; let isMapReady; function onMapReady(callback) { if (isMapReady) { callback(map, maps2, trigger); } else { onMapReadyCallbacks.push(callback); } } function emitMapReady() { isMapReady = true; onMapReadyCallbacks.forEach((callback) => callback(map, maps2, trigger)); onMapReadyCallbacks.length = 0; } let isBoundsReady; const onBoundsReadyCallbacks = []; function onBoundsReady(callback) { if (isBoundsReady) { callback(); } else { onMapReadyCallbacks.push(callback); } } const contexts = {}; function addMapChidlContext(context) { contexts[context.id] = context; } function removeMapChidlContext(context) { delete contexts[context.id]; } watch([() => props2.latitude, () => props2.longitude], ([latitudeVlaue, longitudeVlaue]) => { const latitude = Number(latitudeVlaue); const longitude = Number(longitudeVlaue); if (latitude !== state2.latitude || longitude !== state2.longitude) { state2.latitude = latitude; state2.longitude = longitude; if (map) { const centerPosition = getMapPosition(maps2, state2.latitude, state2.longitude); map.setCenter(centerPosition); } } }); watch(() => props2.includePoints, (points) => { state2.includePoints = getPoints(points); if (isBoundsReady) { updateBounds(); } }, { deep: true }); function emitBoundsReady() { isBoundsReady = true; onBoundsReadyCallbacks.forEach((callback) => callback()); onBoundsReadyCallbacks.length = 0; } function getMapInfo2() { const center = map.getCenter(); return { scale: map.getZoom(), centerLocation: { latitude: getLat(center), longitude: getLng(center) } }; } function updateCenter() { const centerPosition = getMapPosition(maps2, state2.latitude, state2.longitude); map.setCenter(centerPosition); } function updateBounds() { if (getIsAMap()) { const points = []; state2.includePoints.forEach((point) => { points.push([point.longitude, point.latitude]); }); const bounds = new maps2.Bounds(...points); map.setBounds(bounds); } else if (getIsBMap()) ; else { const bounds = new maps2.LatLngBounds(); state2.includePoints.forEach(({ latitude, longitude }) => { const latLng = new maps2.LatLng(latitude, longitude); bounds.extend(latLng); }); map.fitBounds(bounds); } } function initMap() { const mapEl = mapRef.value; const center = getMapPosition(maps2, state2.latitude, state2.longitude); const event = maps2.event || maps2.Event; const map2 = new maps2.Map(mapEl, { center, zoom: Number(props2.scale), // scrollwheel: false, disableDoubleClickZoom: true, mapTypeControl: false, zoomControl: false, scaleControl: false, panControl: false, fullscreenControl: false, streetViewControl: false, keyboardShortcuts: false, minZoom: 5, maxZoom: 18, draggable: true }); if (getIsBMap()) { map2.centerAndZoom(center, Number(props2.scale)); map2.enableScrollWheelZoom(); map2._printLog && map2._printLog("uniapp"); } watch(() => props2.scale, (scale) => { map2.setZoom(Number(scale) || 16); }); onBoundsReady(() => { if (state2.includePoints.length) { updateBounds(); updateCenter(); } }); if (getIsBMap()) { map2.addEventListener("click", () => { trigger("tap", {}, {}); trigger("click", {}, {}); }); map2.addEventListener("dragstart", () => { trigger("regionchange", {}, { type: "begin", causedBy: "gesture" }); }); map2.addEventListener("dragend", () => { trigger("regionchange", {}, extend({ type: "end", causedBy: "drag" }, getMapInfo2())); }); } else { const boundsChangedEvent = event.addListener(map2, "bounds_changed", () => { boundsChangedEvent.remove(); emitBoundsReady(); }); event.addListener(map2, "click", () => { trigger("tap", {}, {}); trigger("click", {}, {}); }); event.addListener(map2, "dragstart", () => { trigger("regionchange", {}, { type: "begin", causedBy: "gesture" }); }); event.addListener(map2, "dragend", () => { trigger("regionchange", {}, extend({ type: "end", causedBy: "drag" }, getMapInfo2())); }); const zoomChangedCallback = () => { emit2("update:scale", map2.getZoom()); trigger("regionchange", {}, extend({ type: "end", causedBy: "scale" }, getMapInfo2())); }; event.addListener(map2, "zoom_changed", zoomChangedCallback); event.addListener(map2, "zoomend", zoomChangedCallback); event.addListener(map2, "center_changed", () => { const center2 = map2.getCenter(); const latitude = getLat(center2); const longitude = getLng(center2); emit2("update:latitude", latitude); emit2("update:longitude", longitude); }); } return map2; } try { const id2 = useContextInfo(); useSubscribe((type, data = {}) => { switch (type) { case "getCenterLocation": onMapReady(() => { const center = map.getCenter(); callOptions(data, { latitude: getLat(center), longitude: getLng(center), errMsg: `${type}:ok` }); }); break; case "moveToLocation": { let latitude = Number(data.latitude); let longitude = Number(data.longitude); if (!latitude || !longitude) { const context = contexts[CONTEXT_ID]; if (context) { latitude = context.state.latitude; longitude = context.state.longitude; } } if (latitude && longitude) { state2.latitude = latitude; state2.longitude = longitude; if (map) { const centerPosition = getMapPosition(maps2, latitude, longitude); map.setCenter(centerPosition); } onMapReady(() => { callOptions(data, `${type}:ok`); }); } else { callOptions(data, `${type}:fail`); } } break; case "translateMarker": onMapReady(() => { const context = contexts[data.markerId]; if (context) { try { context.translate(data); } catch (error) { callOptions(data, `${type}:fail ${error.message}`); } callOptions(data, `${type}:ok`); } else { callOptions(data, `${type}:fail not found`); } }); break; case "includePoints": state2.includePoints = getPoints(data.includePoints); if (isBoundsReady || getIsAMap()) { updateBounds(); } onBoundsReady(() => { callOptions(data, `${type}:ok`); }); break; case "getRegion": onBoundsReady(() => { const latLngBounds = map.getBounds(); const southwest = latLngBounds.getSouthWest(); const northeast = latLngBounds.getNorthEast(); callOptions(data, { southwest: { latitude: getLat(southwest), longitude: getLng(southwest) }, northeast: { latitude: getLat(northeast), longitude: getLng(northeast) }, errMsg: `${type}:ok` }); }); break; case "getScale": onMapReady(() => { callOptions(data, { scale: map.getZoom(), errMsg: `${type}:ok` }); }); break; } }, id2, true); } catch (error) { } onMounted(() => { loadMaps(props2.libraries, (result) => { maps2 = result; map = initMap(); emitMapReady(); trigger("updated", {}, {}); }); }); provide("onMapReady", onMapReady); provide("addMapChidlContext", addMapChidlContext); provide("removeMapChidlContext", removeMapChidlContext); return { state: state2, mapRef, trigger }; } const Map$1 = /* @__PURE__ */ defineBuiltInComponent({ name: "Map", props: props$2, emits: ["markertap", "labeltap", "callouttap", "controltap", "regionchange", "tap", "click", "updated", "update:scale", "update:latitude", "update:longitude"], setup(props2, { emit: emit2, slots }) { const rootRef = ref(null); const { mapRef, trigger } = useMap(props2, rootRef, emit2); return () => { return createVNode("uni-map", { "ref": rootRef, "id": props2.id }, [createVNode("div", { "ref": mapRef, "style": "width: 100%; height: 100%; position: relative; overflow: hidden" }, null, 512), props2.markers.map((item) => createVNode(MapMarker, mergeProps({ "key": item.id }, item), null, 16)), props2.polyline.map((item) => createVNode(MapPolyline, item, null, 16)), props2.circles.map((item) => createVNode(MapCircle, item, null, 16)), props2.controls.map((item) => createVNode(MapControl, mergeProps(item, { "trigger": trigger }), null, 16, ["trigger"])), props2.showLocation && createVNode(MapLocation, null, null), props2.polygons.map((item) => createVNode(MapPolygon, item, null, 16)), createVNode("div", { "style": "position: absolute;top: 0;width: 100%;height: 100%;overflow: hidden;pointer-events: none;" }, [slots.default && slots.default()])], 8, ["id"]); }; } }); const props$1 = { scrollTop: { type: [String, Number], default: 0 } }; const index$9 = /* @__PURE__ */ defineBuiltInComponent({ name: "CoverView", compatConfig: { MODE: 3 }, props: props$1, setup(props2, { slots }) { const content = ref(null); watch(() => props2.scrollTop, (val) => { setScrollTop(val); }); function setScrollTop(val) { let _content = content.value; if (getComputedStyle(_content).overflowY === "scroll") { _content.scrollTop = _upx2pxNum(val); } } function _upx2pxNum(val) { let _val = String(val); if (/\d+[ur]px$/i.test(_val)) { _val.replace(/\d+[ur]px$/i, (text2) => { return String(uni.upx2px(parseFloat(text2))); }); } return parseFloat(_val) || 0; } onMounted(() => { setScrollTop(props2.scrollTop); }); return () => { return createVNode("uni-cover-view", { "scroll-top": props2.scrollTop }, [createVNode("div", { "ref": content, "class": "uni-cover-view" }, [slots.default && slots.default()], 512)], 8, ["scroll-top"]); }; } }); const index$8 = /* @__PURE__ */ defineBuiltInComponent({ name: "CoverImage", compatConfig: { MODE: 3 }, props: { src: { type: String, default: "" } }, emits: ["load", "error"], setup(props2, { emit: emit2 }) { const root = ref(null); const trigger = useCustomEvent(root, emit2); function load($event) { trigger("load", $event); } function error($event) { trigger("error", $event); } return () => { const { src } = props2; return createVNode("uni-cover-image", { "ref": root, "src": src }, [createVNode("div", { "class": "uni-cover-image" }, [src ? createVNode("img", { "src": getRealPath(src), "onLoad": load, "onError": error }, null, 40, ["src", "onLoad", "onError"]) : null])], 8, ["src"]); }; } }); function _isSlot(s) { return typeof s === "function" || Object.prototype.toString.call(s) === "[object Object]" && !isVNode(s); } function getDefaultStartValue(props2) { if (props2.mode === mode.TIME) { return "00:00"; } if (props2.mode === mode.DATE) { const year = (/* @__PURE__ */ new Date()).getFullYear() - 150; switch (props2.fields) { case fields.YEAR: return year.toString(); case fields.MONTH: return year + "-01"; default: return year + "-01-01"; } } return ""; } function getDefaultEndValue(props2) { if (props2.mode === mode.TIME) { return "23:59"; } if (props2.mode === mode.DATE) { const year = (/* @__PURE__ */ new Date()).getFullYear() + 150; switch (props2.fields) { case fields.YEAR: return year.toString(); case fields.MONTH: return year + "-12"; default: return year + "-12-31"; } } return ""; } function getDateValueArray(props2, state2, valueStr, defaultValue) { const splitStr = props2.mode === mode.DATE ? "-" : ":"; const array = props2.mode === mode.DATE ? state2.dateArray : state2.timeArray; let max; if (props2.mode === mode.TIME) { max = 2; } else { switch (props2.fields) { case fields.YEAR: max = 1; break; case fields.MONTH: max = 2; break; default: max = 3; break; } } const inputArray = String(valueStr).split(splitStr); let value = []; for (let i = 0; i < max; i++) { const val = inputArray[i]; value.push(array[i].indexOf(val)); } if (value.indexOf(-1) >= 0) { value = defaultValue ? getDateValueArray(props2, state2, defaultValue) : value.map(() => 0); } return value; } const mode = { SELECTOR: "selector", MULTISELECTOR: "multiSelector", TIME: "time", DATE: "date" // 暂不支持城市选择 // REGION: 'region' }; const fields = { YEAR: "year", MONTH: "month", DAY: "day" }; const selectorType = { PICKER: "picker", SELECT: "select" }; const props = { name: { type: String, default: "" }, range: { type: Array, default() { return []; } }, rangeKey: { type: String, default: "" }, value: { type: [Number, String, Array], default: 0 }, mode: { type: String, default: mode.SELECTOR, validator(val) { return Object.values(mode).includes(val); } }, fields: { type: String, default: "" }, start: { type: String, default: (props2) => { return getDefaultStartValue(props2); } }, end: { type: String, default: (props2) => { return getDefaultEndValue(props2); } }, disabled: { type: [Boolean, String], default: false }, selectorType: { type: String, default: "" } }; const index$7 = /* @__PURE__ */ defineBuiltInComponent({ name: "Picker", compatConfig: { MODE: 3 }, props, emits: ["change", "cancel", "columnchange"], setup(props2, { emit: emit2, slots }) { initI18nPickerMsgsOnce(); const { t: t2 } = useI18n(); const rootRef = ref(null); const pickerRef = ref(null); const selectRef = ref(null); const inputRef = ref(null); const pickerRender = ref(false); const { state: state2, rangeArray } = usePickerState(props2); const trigger = useCustomEvent(rootRef, emit2); const { system, selectorTypeComputed, _show, _l10nColumn, _l10nItem, _input, _fixInputPosition, _pickerViewChange, _cancel, _change, _resetFormData, _getFormData, _createTime, _createDate, _setValueSync } = usePickerMethods(props2, state2, trigger, rootRef, pickerRef, selectRef, inputRef); usePickerWatch(state2, _cancel, _change); usePickerForm(_resetFormData, _getFormData); _createTime(); _createDate(); _setValueSync(); const popup = usePopupStyle(state2); watchEffect(() => { state2.isDesktop = popup.isDesktop.value; state2.popupStyle = popup.popupStyle.value; }); onBeforeUnmount(() => { pickerRef.value && pickerRef.value.remove(); }); onMounted(() => { pickerRender.value = true; }); return () => { let _slot2; const { visible, contentVisible, valueArray, popupStyle, valueSync } = state2; const { rangeKey, mode: mode2, start, end } = props2; const booleanAttrs = useBooleanAttr(props2, "disabled"); return createVNode("uni-picker", mergeProps({ "ref": rootRef }, booleanAttrs, { "onClick": withWebEvent(_show) }), [pickerRender.value ? createVNode("div", { "ref": pickerRef, "class": ["uni-picker-container", `uni-${mode2}-${selectorTypeComputed.value}`], "onWheel": onEventPrevent, "onTouchmove": onEventPrevent }, [createVNode(Transition, { "name": "uni-fade" }, { default: () => [withDirectives(createVNode("div", { "class": "uni-mask uni-picker-mask", "onClick": withWebEvent(_cancel), "onMousemove": _fixInputPosition }, null, 40, ["onClick", "onMousemove"]), [[vShow, visible]])] }), !system.value ? createVNode("div", { "class": [{ "uni-picker-toggle": visible }, "uni-picker-custom"], "style": popupStyle.content }, [createVNode("div", { "class": "uni-picker-header", "onClick": onEventStop }, [createVNode("div", { "class": "uni-picker-action uni-picker-action-cancel", "onClick": withWebEvent(_cancel) }, [t2("uni.picker.cancel")], 8, ["onClick"]), createVNode("div", { "class": "uni-picker-action uni-picker-action-confirm", "onClick": _change }, [t2("uni.picker.done")], 8, ["onClick"])], 8, ["onClick"]), contentVisible ? createVNode(PickerView, { "value": _l10nColumn(valueArray), "class": "uni-picker-content", "onChange": _pickerViewChange }, _isSlot(_slot2 = renderList(_l10nColumn(rangeArray.value), (rangeItem, index0) => { let _slot; return createVNode(PickerViewColumn, { "key": index0 }, _isSlot(_slot = renderList(rangeItem, (item, index2) => createVNode("div", { "key": index2, "class": "uni-picker-item" }, [typeof item === "object" ? item[rangeKey] || "" : _l10nItem(item, index0)]))) ? _slot : { default: () => [_slot], _: 1 }); })) ? _slot2 : { default: () => [_slot2], _: 1 }, 8, ["value", "onChange"]) : null, createVNode("div", { "ref": selectRef, "class": "uni-picker-select", "onWheel": onEventStop, "onTouchmove": onEventStop }, [renderList(rangeArray.value[0], (item, index2) => createVNode("div", { "key": index2, "class": ["uni-picker-item", { selected: valueArray[0] === index2 }], "onClick": () => { valueArray[0] = index2; _change(); } }, [typeof item === "object" ? item[rangeKey] || "" : item], 10, ["onClick"]))], 40, ["onWheel", "onTouchmove"]), createVNode("div", { "style": popupStyle.triangle }, null, 4)], 6) : null], 40, ["onWheel", "onTouchmove"]) : null, createVNode("div", null, [slots.default && slots.default()]), system.value ? createVNode("div", { "class": "uni-picker-system", "onMousemove": withWebEvent(_fixInputPosition) }, [createVNode("input", { "class": ["uni-picker-system_input", system.value], "ref": inputRef, "value": valueSync, "type": mode2, "tabindex": "-1", "min": start, "max": end, "onChange": ($event) => { _input($event); onEventStop($event); } }, null, 42, ["value", "type", "min", "max", "onChange"])], 40, ["onMousemove"]) : null], 16, ["onClick"]); }; } }); function usePickerState(props2) { const state2 = reactive({ valueSync: void 0, visible: false, contentVisible: false, popover: null, valueChangeSource: "", timeArray: [], dateArray: [], valueArray: [], oldValueArray: [], isDesktop: false, popupStyle: { content: {}, triangle: {} } }); const rangeArray = computed(() => { let val = props2.range; switch (props2.mode) { case mode.SELECTOR: return [val]; case mode.MULTISELECTOR: return val; case mode.TIME: return state2.timeArray; case mode.DATE: { const dateArray = state2.dateArray; switch (props2.fields) { case fields.YEAR: return [dateArray[0]]; case fields.MONTH: return [dateArray[0], dateArray[1]]; default: return [dateArray[0], dateArray[1], dateArray[2]]; } } } return []; }); return { state: state2, rangeArray }; } const getiPadFlag = () => String(navigator.vendor).indexOf("Apple") === 0 && navigator.maxTouchPoints > 0; function useIsiPad() { const isiPad = ref(false); { isiPad.value = getiPadFlag(); } return isiPad; } const getSystem = () => { if (/win|mac/i.test(navigator.platform)) { if (navigator.vendor === "Google Inc.") { return "chrome"; } else if (/Firefox/.test(navigator.userAgent)) { return "firefox"; } } return ""; }; function useSystem() { const _system = ref(""); { _system.value = getSystem(); } return _system; } let __contentVisibleDelay; function usePickerMethods(props2, state2, trigger, rootRef, pickerRef, selectRef, inputRef) { const isiPad = useIsiPad(); const _system = useSystem(); const selectorTypeComputed = computed(() => { const type = props2.selectorType; if (Object.values(selectorType).includes(type)) { return type; } return isiPad.value ? selectorType.PICKER : selectorType.SELECT; }); const system = computed(() => { if (props2.mode === mode.DATE && !Object.values(fields).includes(props2.fields) && state2.isDesktop) { return _system.value; } return ""; }); const startArray = computed(() => { return getDateValueArray(props2, state2, props2.start, getDefaultStartValue(props2)); }); const endArray = computed(() => { return getDateValueArray(props2, state2, props2.end, getDefaultEndValue(props2)); }); function _show(event) { if (props2.disabled) { return; } state2.valueChangeSource = ""; let $picker = pickerRef.value; let _currentTarget = event.currentTarget; $picker.remove(); (document.querySelector("uni-app") || document.body).appendChild($picker); $picker.style.display = "block"; const rect = _currentTarget.getBoundingClientRect(); state2.popover = { top: rect.top, left: rect.left, width: rect.width, height: rect.height }; setTimeout(() => { state2.visible = true; }, 20); } function _getFormData() { return { value: state2.valueSync, key: props2.name }; } function _resetFormData() { switch (props2.mode) { case mode.SELECTOR: state2.valueSync = 0; break; case mode.MULTISELECTOR: state2.valueSync = props2.value.map((val) => 0); break; case mode.DATE: case mode.TIME: state2.valueSync = ""; break; } } function _createTime() { let hours = []; let minutes = []; for (let i = 0; i < 24; i++) { hours.push((i < 10 ? "0" : "") + i); } for (let i = 0; i < 60; i++) { minutes.push((i < 10 ? "0" : "") + i); } state2.timeArray.push(hours, minutes); } function getYearStartEnd() { let year = (/* @__PURE__ */ new Date()).getFullYear(); let start = year - 150; let end = year + 150; if (props2.start) { const _year = new Date(props2.start).getFullYear(); if (!isNaN(_year) && _year < start) { start = _year; } } if (props2.end) { const _year = new Date(props2.end).getFullYear(); if (!isNaN(_year) && _year > end) { end = _year; } } return { start, end }; } function _createDate() { let years = []; const year = getYearStartEnd(); for (let i = year.start, end = year.end; i <= end; i++) { years.push(String(i)); } let months = []; for (let i = 1; i <= 12; i++) { months.push((i < 10 ? "0" : "") + i); } let days = []; for (let i = 1; i <= 31; i++) { days.push((i < 10 ? "0" : "") + i); } state2.dateArray.push(years, months, days); } function _getTimeValue(val) { return val[0] * 60 + val[1]; } function _getDateValue(val) { const DAY = 31; return val[0] * DAY * 12 + (val[1] || 0) * DAY + (val[2] || 0); } function _cloneArray(val1, val2) { for (let i = 0; i < val1.length && i < val2.length; i++) { val1[i] = val2[i]; } } function _setValueSync() { let val = props2.value; switch (props2.mode) { case mode.MULTISELECTOR: { if (!isArray(val)) { val = state2.valueArray; } if (!isArray(state2.valueSync)) { state2.valueSync = []; } const length = state2.valueSync.length = Math.max(val.length, props2.range.length); for (let index2 = 0; index2 < length; index2++) { const val0 = Number(val[index2]); const val1 = Number(state2.valueSync[index2]); const val2 = isNaN(val0) ? isNaN(val1) ? 0 : val1 : val0; const maxVal = props2.range[index2] ? props2.range[index2].length - 1 : 0; state2.valueSync.splice(index2, 1, val2 < 0 || val2 > maxVal ? 0 : val2); } } break; case mode.TIME: case mode.DATE: state2.valueSync = String(val); break; default: { const valueSync = Number(val); state2.valueSync = valueSync < 0 ? 0 : valueSync; break; } } } function _setValueArray() { let val = state2.valueSync; let valueArray; switch (props2.mode) { case mode.MULTISELECTOR: valueArray = [...val]; break; case mode.TIME: valueArray = getDateValueArray(props2, state2, val, formatDateTime({ mode: mode.TIME })); break; case mode.DATE: valueArray = getDateValueArray(props2, state2, val, formatDateTime({ mode: mode.DATE })); break; default: valueArray = [val]; break; } state2.oldValueArray = [...valueArray]; state2.valueArray = [...valueArray]; } function _getValue() { let val = state2.valueArray; switch (props2.mode) { case mode.SELECTOR: return val[0]; case mode.MULTISELECTOR: return val.map((val2) => val2); case mode.TIME: return state2.valueArray.map((val2, i) => state2.timeArray[i][val2]).join(":"); case mode.DATE: return state2.valueArray.map((val2, i) => state2.dateArray[i][val2]).join("-"); } } function _change() { _close(); state2.valueChangeSource = "click"; const value = _getValue(); state2.valueSync = isArray(value) ? value.map((val) => val) : value; trigger("change", {}, { value }); } function _cancel($event) { if (system.value === "firefox" && $event) { const { top, left, width, height } = state2.popover; const { pageX, pageY } = $event; if (pageX > left && pageX < left + width && pageY > top && pageY < top + height) { return; } } _close(); trigger("cancel", {}, {}); } function _close() { state2.visible = false; setTimeout(() => { let $picker = pickerRef.value; $picker.remove(); rootRef.value.prepend($picker); $picker.style.display = "none"; }, 260); } function _select() { if (props2.mode === mode.SELECTOR && selectorTypeComputed.value === selectorType.SELECT) { selectRef.value.scrollTop = state2.valueArray[0] * 34; } } function _input($event) { const EventTarget = $event.target; state2.valueSync = EventTarget.value; nextTick(() => { _change(); }); } function _fixInputPosition($event) { if (system.value === "chrome") { const rect = rootRef.value.getBoundingClientRect(); const fontSize = 32; inputRef.value.style.left = `${$event.clientX - rect.left - fontSize * 1.5}px`; inputRef.value.style.top = `${$event.clientY - rect.top - fontSize * 0.5}px`; } } function _pickerViewChange(event) { state2.valueArray = _l10nColumn(event.detail.value, true); } function _l10nColumn(array, normalize) { const { getLocale: getLocale2 } = useI18n(); if (props2.mode === mode.DATE) { const locale = getLocale2(); if (!locale.startsWith("zh")) { switch (props2.fields) { case fields.YEAR: return array; case fields.MONTH: return [array[1], array[0]]; default: switch (locale) { case "es": case "fr": return [array[2], array[1], array[0]]; default: return normalize ? [array[2], array[0], array[1]] : [array[1], array[2], array[0]]; } } } } return array; } function _l10nItem(item, index2) { const { getLocale: getLocale2 } = useI18n(); if (props2.mode === mode.DATE) { const locale = getLocale2(); if (locale.startsWith("zh")) { const array = ["年", "月", "日"]; return item + array[index2]; } else if (props2.fields !== fields.YEAR && index2 === (props2.fields !== fields.MONTH && (locale === "es" || locale === "fr") ? 1 : 0)) { let array; switch (locale) { case "es": array = ["enero", "febrero", "marzo", "abril", "mayo", "junio", "​​julio", "agosto", "septiembre", "octubre", "noviembre", "diciembre"]; break; case "fr": array = ["janvier", "février", "mars", "avril", "mai", "juin", "juillet", "août", "septembre", "octobre", "novembre", "décembre"]; break; default: array = ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"]; break; } return array[Number(item) - 1]; } } return item; } watch(() => state2.visible, (val) => { if (val) { clearTimeout(__contentVisibleDelay); state2.contentVisible = val; _select(); } else { __contentVisibleDelay = setTimeout(() => { state2.contentVisible = val; }, 300); } }); watch([() => props2.mode, () => props2.value, () => props2.range], _setValueSync, { deep: true }); watch(() => state2.valueSync, _setValueArray, { deep: true }); watch(() => state2.valueArray, (val) => { if (props2.mode === mode.TIME || props2.mode === mode.DATE) { const getValue = props2.mode === mode.TIME ? _getTimeValue : _getDateValue; const valueArray = state2.valueArray; const _startArray = startArray.value; const _endArray = endArray.value; if (props2.mode === mode.DATE) { const dateArray = state2.dateArray; const max = dateArray[2].length; const day = Number(dateArray[2][valueArray[2]]) || 1; const realDay = (/* @__PURE__ */ new Date(`${dateArray[0][valueArray[0]]}/${dateArray[1][valueArray[1]]}/${day}`)).getDate(); if (realDay < day) { valueArray[2] -= realDay + max - day; } } if (getValue(valueArray) < getValue(_startArray)) { _cloneArray(valueArray, _startArray); } else if (getValue(valueArray) > getValue(_endArray)) { _cloneArray(valueArray, _endArray); } } val.forEach((value, column) => { if (value !== state2.oldValueArray[column]) { state2.oldValueArray[column] = value; if (props2.mode === mode.MULTISELECTOR) { trigger("columnchange", {}, { column, value }); } } }); }); return { selectorTypeComputed, system, _show, _cancel, _change, _l10nColumn, _l10nItem, _input, _resetFormData, _getFormData, _createTime, _createDate, _setValueSync, _fixInputPosition, _pickerViewChange }; } function usePickerWatch(state2, _cancel, _change) { const { key, disable } = useKeyboard(); watchEffect(() => { disable.value = !state2.visible; }); watch(key, (value) => { if (value === "esc") { _cancel(); } else if (value === "enter") { _change(); } }); } function usePickerForm(_resetFormData, _getFormData) { const uniForm = inject(uniFormKey, false); if (uniForm) { const field = { reset: _resetFormData, submit: () => { const data = ["", null]; const { key, value } = _getFormData(); if (key !== "") { data[0] = key; data[1] = value; } return data; } }; uniForm.addField(field); onBeforeUnmount(() => { uniForm.removeField(field); }); } } const index$6 = /* @__PURE__ */ defineUnsupportedComponent("ad"); const index$5 = /* @__PURE__ */ defineUnsupportedComponent("ad-content-page"); const index$4 = /* @__PURE__ */ defineUnsupportedComponent("ad-draw"); const index$3 = /* @__PURE__ */ defineUnsupportedComponent("camera"); const index$2 = /* @__PURE__ */ defineUnsupportedComponent("live-player"); const index$1 = /* @__PURE__ */ defineUnsupportedComponent("live-pusher"); const UniViewJSBridge$1 = /* @__PURE__ */ extend(ViewJSBridge, { publishHandler(event, args, pageId) { UniServiceJSBridge.subscribeHandler(event, args, pageId); } }); const uni$1 = api; const UniServiceJSBridge$1 = /* @__PURE__ */ extend(ServiceJSBridge, { publishHandler(event, args, pageId) { UniViewJSBridge.subscribeHandler(event, args, pageId); } }); function usePageHeadTransparentBackgroundColor(backgroundColor) { const { r, g: g2, b } = hexToRgba(backgroundColor); return `rgba(${r},${g2},${b},0)`; } function usePageHeadTransparent(headRef, { id: id2, navigationBar: { titleColor, coverage, backgroundColor } }) { let A = 0; const rgb = computed(() => hexToRgba(backgroundColor)); const offset = parseInt(coverage); let titleElem; let transparentElemStyle; const iconElemsPaths = []; const borderRadiusElemsStyles = []; const oldColors = []; onMounted(() => { const $el = headRef.value; transparentElemStyle = $el.style; titleElem = $el.querySelector(".uni-page-head__title"); const borderRadiusElems = $el.querySelectorAll( ".uni-page-head-btn" ); const iconSvgElems = $el.querySelectorAll( "svg path" ); for (let i = 0; i < iconSvgElems.length; i++) { iconElemsPaths.push(iconSvgElems[i]); } for (let i = 0; i < borderRadiusElems.length; i++) { const borderRadiusElem = borderRadiusElems[i]; oldColors.push(getComputedStyle(borderRadiusElem).backgroundColor); borderRadiusElemsStyles.push(borderRadiusElem.style); } }); useOn(id2 + ".onPageScroll", ({ scrollTop }) => { const alpha = Math.min(scrollTop / offset, 1); if (alpha === 1 && A === 1) { return; } if (alpha > 0.5 && A <= 0.5) { iconElemsPaths.forEach(function(iconElemPath) { iconElemPath.setAttribute("fill", titleColor); }); } else if (alpha <= 0.5 && A > 0.5) { iconElemsPaths.forEach(function(iconElemPath) { iconElemPath.setAttribute("fill", "#fff"); }); } A = alpha; if (titleElem) { titleElem.style.opacity = alpha; } const bg = rgb.value; transparentElemStyle.backgroundColor = `rgba(${bg.r},${bg.g},${bg.b},${alpha})`; borderRadiusElemsStyles.forEach(function(borderRadiusElemStyle, index2) { const oldColor = oldColors[index2]; const rgba = oldColor.match(/[\d+\.]+/g); rgba[3] = (1 - alpha) * (rgba.length === 4 ? rgba[3] : 1); borderRadiusElemStyle.backgroundColor = `rgba(${rgba})`; }); }); } const ICON_PATHS = { none: "", forward: "M11 7.844q-0.25-0.219-0.25-0.578t0.25-0.578q0.219-0.25 0.563-0.25t0.563 0.25l9.656 9.125q0.125 0.125 0.188 0.297t0.063 0.328q0 0.188-0.063 0.359t-0.188 0.297l-9.656 9.125q-0.219 0.25-0.563 0.25t-0.563-0.25q-0.25-0.219-0.25-0.578t0.25-0.609l9.063-8.594-9.063-8.594z", back: ICON_PATH_BACK, select: ICON_PATH_BACK, share: "M26.563 24.844q0 0.125-0.109 0.234t-0.234 0.109h-17.938q-0.125 0-0.219-0.109t-0.094-0.234v-13.25q0-0.156 0.094-0.25t0.219-0.094h5.5v-1.531h-6q-0.531 0-0.906 0.391t-0.375 0.922v14.375q0 0.531 0.375 0.922t0.906 0.391h18.969q0.531 0 0.891-0.391t0.359-0.953v-5.156h-1.438v4.625zM29.813 10.969l-5.125-5.375-1.031 1.094 3.438 3.594-3.719 0.031q-2.313 0.188-4.344 1.125t-3.578 2.422-2.5 3.453-1.109 4.188l-0.031 0.25h1.469v-0.219q0.156-1.875 1-3.594t2.25-3.063 3.234-2.125 3.828-0.906l0.188-0.031 3.313-0.031-3.438 3.625 1.031 1.063 5.125-5.375-0.031-0.063 0.031-0.063z", favorite: "M27.594 13.375q-0.063-0.188-0.219-0.313t-0.344-0.156l-7.094-0.969-3.219-6.406q-0.094-0.188-0.25-0.281t-0.375-0.094q-0.188 0-0.344 0.094t-0.25 0.281l-3.125 6.438-7.094 1.094q-0.188 0.031-0.344 0.156t-0.219 0.313q-0.031 0.188 0.016 0.375t0.172 0.313l5.156 4.969-1.156 7.063q-0.031 0.188 0.047 0.375t0.234 0.313q0.094 0.063 0.188 0.094t0.219 0.031q0.063 0 0.141-0.031t0.172-0.063l6.313-3.375 6.375 3.313q0.063 0.031 0.141 0.047t0.172 0.016q0.188 0 0.344-0.094t0.25-0.281q0.063-0.094 0.078-0.234t-0.016-0.234q0-0.031 0-0.063l-1.25-6.938 5.094-5.031q0.156-0.156 0.203-0.344t-0.016-0.375zM11.469 19.063q0.031-0.188-0.016-0.344t-0.172-0.281l-4.406-4.25 6.063-0.906q0.156-0.031 0.297-0.125t0.203-0.25l2.688-5.531 2.75 5.5q0.063 0.156 0.203 0.25t0.297 0.125l6.094 0.844-4.375 4.281q-0.125 0.125-0.172 0.297t-0.016 0.328l1.063 6.031-5.438-2.813q-0.156-0.094-0.328-0.078t-0.297 0.078l-5.438 2.875 1-6.031z", home: "M23.719 16.5q-0.313 0-0.531 0.219t-0.219 0.5v7.063q0 0.219-0.172 0.391t-0.391 0.172h-12.344q-0.25 0-0.422-0.172t-0.172-0.391v-7.063q0-0.281-0.219-0.5t-0.531-0.219q-0.281 0-0.516 0.219t-0.234 0.5v7.063q0.031 0.844 0.625 1.453t1.438 0.609h12.375q0.844 0 1.453-0.609t0.609-1.453v-7.063q0-0.125-0.063-0.266t-0.156-0.234q-0.094-0.125-0.234-0.172t-0.297-0.047zM26.5 14.875l-8.813-8.813q-0.313-0.313-0.688-0.453t-0.781-0.141-0.781 0.141-0.656 0.422l-8.813 8.844q-0.188 0.219-0.188 0.516t0.219 0.484q0.094 0.125 0.234 0.172t0.297 0.047q0.125 0 0.25-0.047t0.25-0.141l8.781-8.781q0.156-0.156 0.406-0.156t0.406 0.156l8.813 8.781q0.219 0.188 0.516 0.188t0.516-0.219q0.188-0.188 0.203-0.484t-0.172-0.516z", menu: "M8.938 18.313q0.875 0 1.484-0.609t0.609-1.453-0.609-1.453-1.484-0.609q-0.844 0-1.453 0.609t-0.609 1.453 0.609 1.453 1.453 0.609zM16.188 18.313q0.875 0 1.484-0.609t0.609-1.453-0.609-1.453-1.484-0.609q-0.844 0-1.453 0.609t-0.609 1.453 0.609 1.453 1.453 0.609zM23.469 18.313q0.844 0 1.453-0.609t0.609-1.453-0.609-1.453-1.453-0.609q-0.875 0-1.484 0.609t-0.609 1.453 0.609 1.453 1.484 0.609z", close: ICON_PATH_CLOSE }; const PageHead = /* @__PURE__ */ defineSystemComponent({ name: "PageHead", setup() { const headRef = ref(null); const pageMeta = usePageMeta(); const navigationBar = useTheme(pageMeta.navigationBar, () => { const _navigationBar = parseTheme(pageMeta.navigationBar); navigationBar.backgroundColor = _navigationBar.backgroundColor; navigationBar.titleColor = _navigationBar.titleColor; }); const { clazz: clazz2, style } = usePageHead(navigationBar); const buttons = __UNI_FEATURE_NAVIGATIONBAR_BUTTONS__ && usePageHeadButtons(pageMeta); const searchInput = __UNI_FEATURE_NAVIGATIONBAR_SEARCHINPUT__ && navigationBar.searchInput && usePageHeadSearchInput(pageMeta); __UNI_FEATURE_NAVIGATIONBAR_TRANSPARENT__ && navigationBar.type === "transparent" && usePageHeadTransparent(headRef, pageMeta); return () => { const backButtonTsx = __UNI_FEATURE_PAGES__ ? createBackButtonTsx(navigationBar, pageMeta.isQuit) : null; const leftButtonsTsx = __UNI_FEATURE_NAVIGATIONBAR_BUTTONS__ ? createButtonsTsx(buttons.left) : []; const rightButtonsTsx = __UNI_FEATURE_NAVIGATIONBAR_BUTTONS__ ? createButtonsTsx(buttons.right) : []; const type = navigationBar.type || "default"; const placeholderTsx = type !== "transparent" && type !== "float" && createVNode("div", { "class": { "uni-placeholder": true, "uni-placeholder-titlePenetrate": navigationBar.titlePenetrate } }, null, 2); return createVNode("uni-page-head", { "uni-page-head-type": type }, [createVNode("div", { "ref": headRef, "class": clazz2.value, "style": style.value }, [createVNode("div", { "class": "uni-page-head-hd" }, [backButtonTsx, ...leftButtonsTsx]), createPageHeadBdTsx(navigationBar, searchInput), createVNode("div", { "class": "uni-page-head-ft" }, [...rightButtonsTsx])], 6), placeholderTsx], 8, ["uni-page-head-type"]); }; } }); function createBackButtonTsx(navigationBar, isQuit) { if (!isQuit) { return createVNode("div", { "class": "uni-page-head-btn", "onClick": onPageHeadBackButton }, [createSvgIconVNode(ICON_PATH_BACK, navigationBar.type === "transparent" ? "#fff" : navigationBar.titleColor, 27)], 8, ["onClick"]); } } function createButtonsTsx(btns) { return btns.map(({ onClick, btnClass, btnStyle, btnText, btnIconPath, badgeText, iconStyle, btnSelect }, index2) => { return createVNode("div", { "key": index2, "class": btnClass, "style": btnStyle, "onClick": onClick, "badge-text": badgeText }, [btnIconPath ? createSvgIconVNode(btnIconPath, iconStyle.color, iconStyle.fontSize) : btnSelect ? createVNode("span", { "style": iconStyle }, [createVNode("i", { "class": "uni-btn-icon", "innerHTML": btnText }, null, 8, ["innerHTML"]), createSvgIconVNode(ICON_PATHS["select"], "#000", 14)], 4) : createVNode("i", { "class": "uni-btn-icon", "style": iconStyle, "innerHTML": btnText }, null, 12, ["innerHTML"])], 14, ["onClick", "badge-text"]); }); } function createPageHeadBdTsx(navigationBar, searchInput) { if (!__UNI_FEATURE_NAVIGATIONBAR_SEARCHINPUT__ || !navigationBar.searchInput) { return createPageHeadTitleTextTsx(navigationBar); } return createPageHeadSearchInputTsx(navigationBar, searchInput); } function createPageHeadTitleTextTsx({ type, loading, titleSize, titleText, titleImage }) { return createVNode("div", { "class": "uni-page-head-bd" }, [createVNode("div", { "style": { fontSize: titleSize, opacity: type === "transparent" ? 0 : 1 }, "class": "uni-page-head__title" }, [loading ? createVNode("i", { "class": "uni-loading" }, null) : titleImage ? createVNode("img", { "src": titleImage, "class": "uni-page-head__title_image" }, null, 8, ["src"]) : titleText], 4)]); } function createPageHeadSearchInputTsx(navigationBar, { text: text2, focus, composing, onBlur, onFocus, onInput, onConfirm, onClick }) { const { color, align: align2, autoFocus, disabled, borderRadius, backgroundColor, placeholder, placeholderColor } = navigationBar.searchInput; const searchStyle = { borderRadius, backgroundColor }; const placeholderClass = ["uni-page-head-search-placeholder", `uni-page-head-search-placeholder-${focus.value || text2.value ? "left" : align2}`]; return createVNode("div", { "class": "uni-page-head-search", "style": searchStyle }, [createVNode("div", { "style": { color: placeholderColor }, "class": placeholderClass }, [createVNode("div", { "class": "uni-page-head-search-icon" }, [createSvgIconVNode(ICON_PATH_SEARCH, placeholderColor, 20)]), text2.value || composing.value ? "" : placeholder], 6), disabled ? createVNode(Input, { "disabled": true, "style": { color }, "placeholder-style": "color: " + placeholderColor, "class": "uni-page-head-search-input", "confirm-type": "search", "onClick": onClick }, null, 8, ["style", "placeholder-style", "onClick"]) : createVNode(Input, { "focus": autoFocus, "style": { color }, "placeholder-style": "color: " + placeholderColor, "class": "uni-page-head-search-input", "confirm-type": "search", "onFocus": onFocus, "onBlur": onBlur, "onInput": onInput, "onConfirm": onConfirm }, null, 8, ["focus", "style", "placeholder-style", "onFocus", "onBlur", "onInput", "onConfirm"])], 4); } function onPageHeadBackButton() { if (getCurrentPages().length === 1) { uni.reLaunch({ url: "/" }); } else { uni.navigateBack({ from: "backbutton", success() { } // 传入空方法,避免返回Promise,因为onBackPress可能导致fail }); } } function usePageHead(navigationBar) { const clazz2 = computed(() => { const { type, titlePenetrate, shadowColorType } = navigationBar; const clazz3 = { "uni-page-head": true, "uni-page-head-transparent": type === "transparent", "uni-page-head-titlePenetrate": titlePenetrate === "YES", "uni-page-head-shadow": !!shadowColorType }; if (shadowColorType) { clazz3[`uni-page-head-shadow-${shadowColorType}`] = true; } return clazz3; }); const style = computed(() => { const backgroundColor = __UNI_FEATURE_NAVIGATIONBAR_TRANSPARENT__ && navigationBar.type === "transparent" ? usePageHeadTransparentBackgroundColor(navigationBar.backgroundColor) : navigationBar.backgroundColor; return { backgroundColor, color: navigationBar.titleColor, transitionDuration: navigationBar.duration, transitionTimingFunction: navigationBar.timingFunc }; }); return { clazz: clazz2, style }; } function usePageHeadButtons({ id: id2, navigationBar }) { const left = []; const right = []; const { buttons } = navigationBar; if (isArray(buttons)) { const { type } = navigationBar; const isTransparent = type === "transparent"; const fonts = /* @__PURE__ */ Object.create(null); buttons.forEach((btn, index2) => { if (btn.fontSrc && !btn.fontFamily) { const fontSrc = getRealPath(btn.fontSrc); let fontFamily = fonts[fontSrc]; if (!fontFamily) { fontFamily = `font${Date.now()}`; fonts[fontSrc] = fontFamily; onBeforeMount(() => updateStyle("uni-btn-" + fontFamily, `@font-face{font-family: "${fontFamily}";src: url("${fontSrc}") format("truetype")}`)); } btn.fontFamily = fontFamily; } const pageHeadBtn = usePageHeadButton(id2, index2, btn, isTransparent); if (btn.float === "left") { left.push(pageHeadBtn); } else { right.push(pageHeadBtn); } }); } return { left, right }; } function usePageHeadButton(pageId, index2, btn, isTransparent) { const iconStyle = { color: btn.color, fontSize: btn.fontSize, fontWeight: btn.fontWeight }; if (btn.fontFamily) { iconStyle.fontFamily = btn.fontFamily; } return new Proxy({ btnClass: { // 类似这样的大量重复的字符串,会在gzip时压缩大小,无需在代码层考虑优化相同字符串 "uni-page-head-btn": true, "uni-page-head-btn-red-dot": !!(btn.redDot || btn.badgeText), "uni-page-head-btn-select": !!btn.select }, btnStyle: { backgroundColor: isTransparent ? btn.background : "transparent", width: btn.width }, btnText: "", btnIconPath: ICON_PATHS[btn.type], badgeText: btn.badgeText, iconStyle, onClick() { invokeHook(pageId, ON_NAVIGATION_BAR_BUTTON_TAP, extend({ index: index2 }, btn)); }, btnSelect: btn.select }, { get(target, key, receiver) { if (["btnText"].includes(key)) { return btn.fontSrc && btn.fontFamily ? btn.text.replace("\\u", "&#x") : btn.text; } else { return Reflect.get(target, key, receiver); } } }); } function usePageHeadSearchInput({ id: id2, navigationBar: { searchInput } }) { const focus = ref(false); const text2 = ref(""); const composing = ref(false); const { disabled } = searchInput; if (disabled) { const onClick = () => { invokeHook(id2, ON_NAVIGATION_BAR_SEARCH_INPUT_CLICKED); }; return { focus, text: text2, composing, onClick }; } const onFocus = () => { focus.value = true; invokeHook(id2, ON_NAVIGATION_BAR_SEARCH_INPUT_FOCUS_CHANGED, { focus: true }); }; const onBlur = () => { focus.value = false; invokeHook(id2, ON_NAVIGATION_BAR_SEARCH_INPUT_FOCUS_CHANGED, { focus: false }); }; const onInput = (evt) => { text2.value = evt.detail.value; invokeHook(id2, ON_NAVIGATION_BAR_SEARCH_INPUT_CHANGED, { text: text2.value }); }; const onConfirm = (evt) => { invokeHook(id2, ON_NAVIGATION_BAR_SEARCH_INPUT_CONFIRMED, { text: text2.value }); }; return { focus, text: text2, composing, onFocus, onBlur, onInput, onConfirm }; } const _sfc_main = { name: "PageRefresh", setup() { const { pullToRefresh } = usePageMeta(); return { offset: pullToRefresh.offset, color: pullToRefresh.color }; } }; const _export_sfc = (sfc, props2) => { const target = sfc.__vccOpts || sfc; for (const [key, val] of props2) { target[key] = val; } return target; }; const _hoisted_1 = { class: "uni-page-refresh-inner" }; const _hoisted_2 = ["fill"]; const _hoisted_3 = /* @__PURE__ */ createElementVNode("path", { d: "M17.65 6.35C16.2 4.9 14.21 4 12 4c-4.42 0-7.99 3.58-7.99 8s3.57 8 7.99 8c3.73 0 6.84-2.55 7.73-6h-2.08c-.82 2.33-3.04 4-5.65 4-3.31 0-6-2.69-6-6s2.69-6 6-6c1.66 0 3.14.69 4.22 1.78L13 11h7V4l-2.35 2.35z" }, null, -1); const _hoisted_4 = /* @__PURE__ */ createElementVNode("path", { d: "M0 0h24v24H0z", fill: "none" }, null, -1); const _hoisted_5 = [ _hoisted_3, _hoisted_4 ]; const _hoisted_6 = { class: "uni-page-refresh__spinner", width: "24", height: "24", viewBox: "25 25 50 50" }; const _hoisted_7 = ["stroke"]; function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) { return openBlock(), createElementBlock("uni-page-refresh", null, [ createElementVNode("div", { style: normalizeStyle({ "margin-top": $setup.offset + "px" }), class: "uni-page-refresh" }, [ createElementVNode("div", _hoisted_1, [ (openBlock(), createElementBlock("svg", { fill: $setup.color, class: "uni-page-refresh__icon", width: "24", height: "24", viewBox: "0 0 24 24" }, _hoisted_5, 8, _hoisted_2)), (openBlock(), createElementBlock("svg", _hoisted_6, [ createElementVNode("circle", { stroke: $setup.color, class: "uni-page-refresh__path", cx: "50", cy: "50", r: "20", fill: "none", "stroke-width": "4", "stroke-miterlimit": "10" }, null, 8, _hoisted_7) ])) ]) ], 4) ]); } const PageRefresh = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render]]); function processDeltaY(ev, identifier, startY) { const touch = Array.prototype.slice.call(ev.changedTouches).filter((touch2) => touch2.identifier === identifier)[0]; if (!touch) { return false; } ev.deltaY = touch.pageY - startY; return true; } const PULLING = "pulling"; const REACHED = "reached"; const ABORTING = "aborting"; const REFRESHING = "refreshing"; const RESTORING = "restoring"; function usePageRefresh(refreshRef) { const { id: id2, pullToRefresh } = usePageMeta(); const { range, height } = pullToRefresh; let refreshContainerElem; let refreshControllerElem; let refreshControllerElemStyle; let refreshInnerElemStyle; useSubscribe( () => { if (!state2) { state2 = REFRESHING; addClass(); setTimeout(() => { refreshing(); }, 50); } }, API_START_PULL_DOWN_REFRESH, false, id2 ); useSubscribe( () => { if (state2 === REFRESHING) { removeClass(); state2 = RESTORING; addClass(); restoring(() => { removeClass(); state2 = distance2 = offset = null; }); } }, API_STOP_PULL_DOWN_REFRESH, false, id2 ); onMounted(() => { refreshContainerElem = refreshRef.value.$el; refreshControllerElem = refreshContainerElem.querySelector(".uni-page-refresh"); refreshControllerElemStyle = refreshControllerElem.style; refreshInnerElemStyle = refreshControllerElem.querySelector( ".uni-page-refresh-inner" ).style; }); let touchId; let startY; let canRefresh; let state2; let distance2 = null; let offset = null; function toggleClass(type) { if (!state2) { return; } if (refreshContainerElem) { refreshContainerElem.classList[type]("uni-page-refresh--" + state2); } } function addClass() { toggleClass("add"); } function removeClass() { toggleClass("remove"); } function pulling(deltaY) { if (!refreshControllerElem) { return; } let rotate = deltaY / range; if (rotate > 1) { rotate = 1; } else { rotate = rotate * rotate * rotate; } const y = Math.round(deltaY / (range / height)) || 0; refreshInnerElemStyle.transform = "rotate(" + 360 * rotate + "deg)"; refreshControllerElemStyle.clip = "rect(" + (45 - y) + "px,45px,45px,-5px)"; refreshControllerElemStyle.transform = "translate3d(-50%, " + y + "px, 0)"; } const onTouchstartPassive = withWebEvent((ev) => { const touch = ev.changedTouches[0]; touchId = touch.identifier; startY = touch.pageY; if ([ABORTING, REFRESHING, RESTORING].indexOf(state2) >= 0) { canRefresh = false; } else { canRefresh = true; } }); const onTouchmove = withWebEvent((ev) => { if (!canRefresh) { return; } if (!processDeltaY(ev, touchId, startY)) { return; } let { deltaY } = ev; if ((document.documentElement.scrollTop || document.body.scrollTop) !== 0) { touchId = null; return; } if (deltaY < 0 && !state2) { return; } ev.preventDefault(); if (distance2 === null) { offset = deltaY; state2 = PULLING; addClass(); } deltaY = deltaY - offset; if (deltaY < 0) { deltaY = 0; } distance2 = deltaY; const isReached = deltaY >= range && state2 !== REACHED; const isPulling = deltaY < range && state2 !== PULLING; if (isReached || isPulling) { removeClass(); state2 = state2 === REACHED ? PULLING : REACHED; addClass(); } pulling(deltaY); }); const onTouchend = withWebEvent((ev) => { if (!processDeltaY(ev, touchId, startY)) { return; } if (state2 === null) { return; } if (state2 === PULLING) { removeClass(); state2 = ABORTING; addClass(); aborting(() => { removeClass(); state2 = distance2 = offset = null; }); } else if (state2 === REACHED) { removeClass(); state2 = REFRESHING; addClass(); refreshing(); } }); function aborting(callback) { if (!refreshControllerElem) { return; } if (refreshControllerElemStyle.transform) { refreshControllerElemStyle.transition = "-webkit-transform 0.3s"; refreshControllerElemStyle.transform = "translate3d(-50%, 0, 0)"; const abortTransitionEnd = function() { timeout && clearTimeout(timeout); refreshControllerElem.removeEventListener( "webkitTransitionEnd", abortTransitionEnd ); refreshControllerElemStyle.transition = ""; callback(); }; refreshControllerElem.addEventListener( "webkitTransitionEnd", abortTransitionEnd ); const timeout = setTimeout(abortTransitionEnd, 350); } else { callback(); } } function refreshing() { if (!refreshControllerElem) { return; } refreshControllerElemStyle.transition = "-webkit-transform 0.2s"; refreshControllerElemStyle.transform = "translate3d(-50%, " + height + "px, 0)"; invokeHook(id2, ON_PULL_DOWN_REFRESH); } function restoring(callback) { if (!refreshControllerElem) { return; } refreshControllerElemStyle.transition = "-webkit-transform 0.3s"; refreshControllerElemStyle.transform += " scale(0.01)"; const restoreTransitionEnd = function() { timeout && clearTimeout(timeout); refreshControllerElem.removeEventListener( "webkitTransitionEnd", restoreTransitionEnd ); refreshControllerElemStyle.transition = ""; refreshControllerElemStyle.transform = "translate3d(-50%, 0, 0)"; callback(); }; refreshControllerElem.addEventListener( "webkitTransitionEnd", restoreTransitionEnd ); const timeout = setTimeout(restoreTransitionEnd, 350); } return { onTouchstartPassive, onTouchmove, onTouchend, onTouchcancel: onTouchend }; } const PageBody = defineSystemComponent({ name: "PageBody", setup(props2, ctx) { const pageMeta = __UNI_FEATURE_PULL_DOWN_REFRESH__ && usePageMeta(); const refreshRef = __UNI_FEATURE_PULL_DOWN_REFRESH__ && ref(null); const pageRefresh = __UNI_FEATURE_PULL_DOWN_REFRESH__ && pageMeta.enablePullDownRefresh ? usePageRefresh(refreshRef) : null; return () => { const pageRefreshTsx = __UNI_FEATURE_PULL_DOWN_REFRESH__ && createPageRefreshTsx(refreshRef, pageMeta); return createVNode(Fragment, null, [pageRefreshTsx, createVNode("uni-page-wrapper", pageRefresh, [createVNode("uni-page-body", null, [renderSlot(ctx.slots, "default")])], 16)]); }; } }); function createPageRefreshTsx(refreshRef, pageMeta) { if (!__UNI_FEATURE_PULL_DOWN_REFRESH__ || !pageMeta.enablePullDownRefresh) { return null; } return createVNode(PageRefresh, { "ref": refreshRef }, null, 512); } const index = defineSystemComponent({ name: "Page", setup(_props, ctx) { const pageMeta = providePageMeta(getStateId()); const navigationBar = pageMeta.navigationBar; useDocumentTitle(pageMeta); return () => createVNode( "uni-page", { "data-page": pageMeta.route }, __UNI_FEATURE_NAVIGATIONBAR__ && navigationBar.style !== "custom" ? [createVNode(PageHead), createPageBodyVNode(ctx)] : [createPageBodyVNode(ctx)] ); } }); function createPageBodyVNode(ctx) { return openBlock(), createBlock( PageBody, { key: 0 }, { default: withCtx(() => [renderSlot(ctx.slots, "page")]), _: 3 } ); } export { $emit, $off, $on, $once, index$6 as Ad, index$5 as AdContentPage, index$4 as AdDraw, AsyncErrorComponent, AsyncLoadingComponent, index$x as Button, index$3 as Camera, index$v as Canvas, index$t as Checkbox, index$u as CheckboxGroup, index$8 as CoverImage, index$9 as CoverView, index$s as Editor, index$z as Form, index$r as Icon, index$q as Image, Input, index$y as Label, LayoutComponent, index$2 as LivePlayer, index$1 as LivePusher, Map$1 as Map, MovableArea, MovableView, index$p as Navigator, index as PageComponent, index$7 as Picker, PickerView, PickerViewColumn, index$o as Progress, index$m as Radio, index$n as RadioGroup, ResizeSensor, index$l as RichText, ScrollView, index$k as Slider, Swiper, SwiperItem, index$j as Switch, index$i as Text, index$h as Textarea, UniServiceJSBridge$1 as UniServiceJSBridge, UniViewJSBridge$1 as UniViewJSBridge, index$d as Video, index$g as View, index$c as WebView, addInterceptor, addPhoneContact, arrayBufferToBase64, base64ToArrayBuffer, canIUse, canvasGetImageData, canvasPutImageData, canvasToTempFilePath, chooseFile, chooseImage, chooseLocation, chooseVideo, clearStorage, clearStorageSync, closePreviewImage, closeSocket, connectSocket, createAnimation$1 as createAnimation, createCameraContext, createCanvasContext, createInnerAudioContext, createIntersectionObserver, createLivePlayerContext, createMapContext, createMediaQueryObserver, createSelectorQuery, createVideoContext, cssBackdropFilter, cssConstant, cssEnv, cssVar, downloadFile, getApp$1 as getApp, getAppBaseInfo, getClipboardData, getCurrentPages$1 as getCurrentPages, getDeviceInfo, getEnterOptionsSync, getFileInfo, getImageInfo, getLaunchOptionsSync, getLeftWindowStyle, getLocale, getLocation, getNetworkType, getProvider, getPushClientId, getRealPath, getRecorderManager, getRightWindowStyle, getSavedFileInfo, getSavedFileList, getScreenBrightness, getSelectedTextRange$1 as getSelectedTextRange, getStorage, getStorageInfo, getStorageInfoSync, getStorageSync, getSystemInfo, getSystemInfoSync, getTopWindowStyle, getVideoInfo, getWindowInfo, hideKeyboard, hideLeftWindow, hideLoading, hideNavigationBarLoading, hideRightWindow, hideTabBar, hideTabBarRedDot, hideToast, hideTopWindow, interceptors, invokePushCallback, loadFontFace, login, makePhoneCall, navigateBack, navigateTo, offAccelerometerChange, offAppHide, offAppShow, offCompassChange, offError, offLocationChange, offLocationChangeError, offNetworkStatusChange, offPageNotFound, offPushMessage, offThemeChange$1 as offThemeChange, offUnhandledRejection, offWindowResize, onAccelerometerChange, onAppHide, onAppShow, onCompassChange, onCreateVueApp2 as onCreateVueApp, onError, onGyroscopeChange, onLocaleChange, onLocationChange, onLocationChangeError, onMemoryWarning, onNetworkStatusChange, onPageNotFound, onPushMessage, onSocketClose, onSocketError, onSocketMessage, onSocketOpen, onTabBarMidButtonTap, onThemeChange$1 as onThemeChange, onUnhandledRejection, onUserCaptureScreen, onWindowResize, openDocument, openLocation, pageScrollTo, index$e as plugin, preloadPage, previewImage, reLaunch, redirectTo, removeInterceptor, removeSavedFile, removeStorage, removeStorageSync, removeTabBarBadge, request, saveFile, saveImageToPhotosAlbum, saveVideoToPhotosAlbum, scanCode, sendSocketMessage, setClipboardData, setKeepScreenOn, setLeftWindowStyle, setLocale, setNavigationBarColor, setNavigationBarTitle, setPageMeta, setRightWindowStyle, setScreenBrightness, setStorage, setStorageSync, setTabBarBadge, setTabBarItem, setTabBarStyle, setTopWindowStyle, setupApp, setupPage, setupWindow, showActionSheet, showLeftWindow, showLoading, showModal, showNavigationBarLoading, showRightWindow, showTabBar, showTabBarRedDot, showToast, showTopWindow, startAccelerometer, startCompass, startGyroscope, startLocationUpdate, startPullDownRefresh, stopAccelerometer, stopCompass, stopGyroscope, stopLocationUpdate, stopPullDownRefresh, switchTab, uni$1 as uni, uploadFile, upx2px, useI18n, useTabBar, vibrateLong, vibrateShort };