@weapp-vite/web 1.3.14 → 1.3.16
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/_virtual/_rolldown/runtime.mjs +18 -0
- package/dist/compiler/wxml/attributes.mjs +93 -0
- package/dist/compiler/wxml/attributes.mjs.map +1 -0
- package/dist/compiler/wxml/compile.mjs +158 -0
- package/dist/compiler/wxml/compile.mjs.map +1 -0
- package/dist/compiler/wxml/dependency.mjs +31 -0
- package/dist/compiler/wxml/dependency.mjs.map +1 -0
- package/dist/compiler/wxml/interpolation.mjs +142 -0
- package/dist/compiler/wxml/interpolation.mjs.map +1 -0
- package/dist/compiler/wxml/navigation.mjs +85 -0
- package/dist/compiler/wxml/navigation.mjs.map +1 -0
- package/dist/compiler/wxml/parser.mjs +41 -0
- package/dist/compiler/wxml/parser.mjs.map +1 -0
- package/dist/compiler/wxml/renderer.mjs +114 -0
- package/dist/compiler/wxml/renderer.mjs.map +1 -0
- package/dist/compiler/wxml/specialNodes.mjs +84 -0
- package/dist/compiler/wxml/specialNodes.mjs.map +1 -0
- package/dist/compiler/wxs.mjs +83 -0
- package/dist/compiler/wxs.mjs.map +1 -0
- package/dist/css/wxss.d.mts +25 -0
- package/dist/css/wxss.mjs +17 -0
- package/dist/css/wxss.mjs.map +1 -0
- package/dist/index.d.mts +18 -2
- package/dist/index.mjs +18 -3
- package/dist/plugin/constants.mjs +43 -0
- package/dist/plugin/constants.mjs.map +1 -0
- package/dist/plugin/entry.mjs +29 -0
- package/dist/plugin/entry.mjs.map +1 -0
- package/dist/plugin/files.mjs +58 -0
- package/dist/plugin/files.mjs.map +1 -0
- package/dist/plugin/index.d.mts +33 -0
- package/dist/plugin/index.mjs +188 -0
- package/dist/plugin/index.mjs.map +1 -0
- package/dist/plugin/navigation.mjs +20 -0
- package/dist/plugin/navigation.mjs.map +1 -0
- package/dist/plugin/path.mjs +85 -0
- package/dist/plugin/path.mjs.map +1 -0
- package/dist/plugin/register.mjs +83 -0
- package/dist/plugin/register.mjs.map +1 -0
- package/dist/plugin/scan.mjs +195 -0
- package/dist/plugin/scan.mjs.map +1 -0
- package/dist/plugin/scanConfig.mjs +45 -0
- package/dist/plugin/scanConfig.mjs.map +1 -0
- package/dist/plugin/state.mjs +22 -0
- package/dist/plugin/state.mjs.map +1 -0
- package/dist/plugin/types.d.mts +46 -0
- package/dist/plugin.d.mts +3 -2
- package/dist/plugin.mjs +3 -2
- package/dist/runtime/button/helpers.mjs +92 -0
- package/dist/runtime/button/helpers.mjs.map +1 -0
- package/dist/runtime/button/index.d.mts +9 -0
- package/dist/runtime/button/index.mjs +198 -0
- package/dist/runtime/button/index.mjs.map +1 -0
- package/dist/runtime/button/style.mjs +168 -0
- package/dist/runtime/button/style.mjs.map +1 -0
- package/dist/runtime/component/behavior.mjs +98 -0
- package/dist/runtime/component/behavior.mjs.map +1 -0
- package/dist/runtime/component/constants.mjs +8 -0
- package/dist/runtime/component/constants.mjs.map +1 -0
- package/dist/runtime/component/dom.mjs +26 -0
- package/dist/runtime/component/dom.mjs.map +1 -0
- package/dist/runtime/component/element.mjs +208 -0
- package/dist/runtime/component/element.mjs.map +1 -0
- package/dist/runtime/component/events.mjs +48 -0
- package/dist/runtime/component/events.mjs.map +1 -0
- package/dist/runtime/component/index.d.mts +7 -0
- package/dist/runtime/component/index.mjs +44 -0
- package/dist/runtime/component/index.mjs.map +1 -0
- package/dist/runtime/component/state.mjs +63 -0
- package/dist/runtime/component/state.mjs.map +1 -0
- package/dist/runtime/component/types.d.mts +49 -0
- package/dist/runtime/component/utils.mjs +39 -0
- package/dist/runtime/component/utils.mjs.map +1 -0
- package/dist/runtime/execution.d.mts +7 -0
- package/dist/runtime/execution.mjs +37 -0
- package/dist/runtime/execution.mjs.map +1 -0
- package/dist/runtime/index.d.mts +16 -2
- package/dist/runtime/index.mjs +16 -2
- package/dist/runtime/legacyTemplate/dom.mjs +131 -0
- package/dist/runtime/legacyTemplate/dom.mjs.map +1 -0
- package/dist/runtime/legacyTemplate/expression.mjs +113 -0
- package/dist/runtime/legacyTemplate/expression.mjs.map +1 -0
- package/dist/runtime/legacyTemplate/index.d.mts +9 -0
- package/dist/runtime/legacyTemplate/index.mjs +131 -0
- package/dist/runtime/legacyTemplate/index.mjs.map +1 -0
- package/dist/runtime/legacyTemplate/types.d.mts +6 -0
- package/dist/runtime/navigationBar/index.d.mts +10 -0
- package/dist/runtime/navigationBar/index.mjs +162 -0
- package/dist/runtime/navigationBar/index.mjs.map +1 -0
- package/dist/runtime/navigationBar/style.mjs +108 -0
- package/dist/runtime/navigationBar/style.mjs.map +1 -0
- package/dist/runtime/polyfill/ad.mjs +150 -0
- package/dist/runtime/polyfill/ad.mjs.map +1 -0
- package/dist/runtime/polyfill/appState.mjs +31 -0
- package/dist/runtime/polyfill/appState.mjs.map +1 -0
- package/dist/runtime/polyfill/async.mjs +31 -0
- package/dist/runtime/polyfill/async.mjs.map +1 -0
- package/dist/runtime/polyfill/auth.mjs +120 -0
- package/dist/runtime/polyfill/auth.mjs.map +1 -0
- package/dist/runtime/polyfill/authApi.mjs +101 -0
- package/dist/runtime/polyfill/authApi.mjs.map +1 -0
- package/dist/runtime/polyfill/background.mjs +31 -0
- package/dist/runtime/polyfill/background.mjs.map +1 -0
- package/dist/runtime/polyfill/canvasContext.mjs +115 -0
- package/dist/runtime/polyfill/canvasContext.mjs.map +1 -0
- package/dist/runtime/polyfill/capability.mjs +17 -0
- package/dist/runtime/polyfill/capability.mjs.map +1 -0
- package/dist/runtime/polyfill/cloud.mjs +39 -0
- package/dist/runtime/polyfill/cloud.mjs.map +1 -0
- package/dist/runtime/polyfill/device.mjs +44 -0
- package/dist/runtime/polyfill/device.mjs.map +1 -0
- package/dist/runtime/polyfill/deviceApi.mjs +31 -0
- package/dist/runtime/polyfill/deviceApi.mjs.map +1 -0
- package/dist/runtime/polyfill/deviceAuthSystemApi.d.mts +102 -0
- package/dist/runtime/polyfill/deviceAuthSystemApi.mjs +144 -0
- package/dist/runtime/polyfill/deviceAuthSystemApi.mjs.map +1 -0
- package/dist/runtime/polyfill/filePicker.mjs +158 -0
- package/dist/runtime/polyfill/filePicker.mjs.map +1 -0
- package/dist/runtime/polyfill/fileSystemManager.mjs +45 -0
- package/dist/runtime/polyfill/fileSystemManager.mjs.map +1 -0
- package/dist/runtime/polyfill/files.mjs +118 -0
- package/dist/runtime/polyfill/files.mjs.map +1 -0
- package/dist/runtime/polyfill/index.d.mts +40 -0
- package/dist/runtime/polyfill/index.mjs +99 -0
- package/dist/runtime/polyfill/index.mjs.map +1 -0
- package/dist/runtime/polyfill/interaction.mjs +38 -0
- package/dist/runtime/polyfill/interaction.mjs.map +1 -0
- package/dist/runtime/polyfill/interactionApi.mjs +54 -0
- package/dist/runtime/polyfill/interactionApi.mjs.map +1 -0
- package/dist/runtime/polyfill/location.mjs +106 -0
- package/dist/runtime/polyfill/location.mjs.map +1 -0
- package/dist/runtime/polyfill/locationApi.mjs +120 -0
- package/dist/runtime/polyfill/locationApi.mjs.map +1 -0
- package/dist/runtime/polyfill/mediaActions.mjs +52 -0
- package/dist/runtime/polyfill/mediaActions.mjs.map +1 -0
- package/dist/runtime/polyfill/mediaApi/file.mjs +63 -0
- package/dist/runtime/polyfill/mediaApi/file.mjs.map +1 -0
- package/dist/runtime/polyfill/mediaApi/info.mjs +59 -0
- package/dist/runtime/polyfill/mediaApi/info.mjs.map +1 -0
- package/dist/runtime/polyfill/mediaApi/picker.mjs +82 -0
- package/dist/runtime/polyfill/mediaApi/picker.mjs.map +1 -0
- package/dist/runtime/polyfill/mediaApi/preview.mjs +39 -0
- package/dist/runtime/polyfill/mediaApi/preview.mjs.map +1 -0
- package/dist/runtime/polyfill/mediaApi/process.mjs +46 -0
- package/dist/runtime/polyfill/mediaApi/process.mjs.map +1 -0
- package/dist/runtime/polyfill/mediaInfo.mjs +136 -0
- package/dist/runtime/polyfill/mediaInfo.mjs.map +1 -0
- package/dist/runtime/polyfill/mediaPicker.mjs +213 -0
- package/dist/runtime/polyfill/mediaPicker.mjs.map +1 -0
- package/dist/runtime/polyfill/mediaProcess.mjs +65 -0
- package/dist/runtime/polyfill/mediaProcess.mjs.map +1 -0
- package/dist/runtime/polyfill/menuApi.mjs +70 -0
- package/dist/runtime/polyfill/menuApi.mjs.map +1 -0
- package/dist/runtime/polyfill/navigationBarRuntime.mjs +65 -0
- package/dist/runtime/polyfill/navigationBarRuntime.mjs.map +1 -0
- package/dist/runtime/polyfill/network/request.mjs +162 -0
- package/dist/runtime/polyfill/network/request.mjs.map +1 -0
- package/dist/runtime/polyfill/network/requestBridge.mjs +49 -0
- package/dist/runtime/polyfill/network/requestBridge.mjs.map +1 -0
- package/dist/runtime/polyfill/network/status.mjs +55 -0
- package/dist/runtime/polyfill/network/status.mjs.map +1 -0
- package/dist/runtime/polyfill/platformApi.mjs +33 -0
- package/dist/runtime/polyfill/platformApi.mjs.map +1 -0
- package/dist/runtime/polyfill/platformRuntime.mjs +120 -0
- package/dist/runtime/polyfill/platformRuntime.mjs.map +1 -0
- package/dist/runtime/polyfill/routeRuntime/dom.mjs +36 -0
- package/dist/runtime/polyfill/routeRuntime/dom.mjs.map +1 -0
- package/dist/runtime/polyfill/routeRuntime/lifecycle.mjs +83 -0
- package/dist/runtime/polyfill/routeRuntime/lifecycle.mjs.map +1 -0
- package/dist/runtime/polyfill/routeRuntime/options.d.mts +33 -0
- package/dist/runtime/polyfill/routeRuntime/options.mjs +76 -0
- package/dist/runtime/polyfill/routeRuntime/options.mjs.map +1 -0
- package/dist/runtime/polyfill/routeRuntime/url.mjs +35 -0
- package/dist/runtime/polyfill/routeRuntime/url.mjs.map +1 -0
- package/dist/runtime/polyfill/routeRuntime.d.mts +43 -0
- package/dist/runtime/polyfill/routeRuntime.mjs +202 -0
- package/dist/runtime/polyfill/routeRuntime.mjs.map +1 -0
- package/dist/runtime/polyfill/runtimeCapabilityApi.mjs +26 -0
- package/dist/runtime/polyfill/runtimeCapabilityApi.mjs.map +1 -0
- package/dist/runtime/polyfill/runtimeDataApi.d.mts +79 -0
- package/dist/runtime/polyfill/runtimeDataApi.mjs +134 -0
- package/dist/runtime/polyfill/runtimeDataApi.mjs.map +1 -0
- package/dist/runtime/polyfill/runtimeInfra.mjs +40 -0
- package/dist/runtime/polyfill/runtimeInfra.mjs.map +1 -0
- package/dist/runtime/polyfill/runtimeOps.mjs +62 -0
- package/dist/runtime/polyfill/runtimeOps.mjs.map +1 -0
- package/dist/runtime/polyfill/selectorQuery.mjs +204 -0
- package/dist/runtime/polyfill/selectorQuery.mjs.map +1 -0
- package/dist/runtime/polyfill/storage.mjs +103 -0
- package/dist/runtime/polyfill/storage.mjs.map +1 -0
- package/dist/runtime/polyfill/storageAsync.mjs +62 -0
- package/dist/runtime/polyfill/storageAsync.mjs.map +1 -0
- package/dist/runtime/polyfill/subscribe.mjs +30 -0
- package/dist/runtime/polyfill/subscribe.mjs.map +1 -0
- package/dist/runtime/polyfill/system.mjs +111 -0
- package/dist/runtime/polyfill/system.mjs.map +1 -0
- package/dist/runtime/polyfill/systemApi.mjs +65 -0
- package/dist/runtime/polyfill/systemApi.mjs.map +1 -0
- package/dist/runtime/polyfill/types/base.d.mts +12 -0
- package/dist/runtime/polyfill/types/common.d.mts +126 -0
- package/dist/runtime/polyfill/types/locationRuntime.d.mts +151 -0
- package/dist/runtime/polyfill/types/mediaAuth.d.mts +152 -0
- package/dist/runtime/polyfill/types/platformRuntime.d.mts +141 -0
- package/dist/runtime/polyfill/types/systemAuth.d.mts +122 -0
- package/dist/runtime/polyfill/ui.mjs +135 -0
- package/dist/runtime/polyfill/ui.mjs.map +1 -0
- package/dist/runtime/polyfill/uiFeedback.mjs +35 -0
- package/dist/runtime/polyfill/uiFeedback.mjs.map +1 -0
- package/dist/runtime/polyfill/uiMediaApi.d.mts +172 -0
- package/dist/runtime/polyfill/uiMediaApi.mjs +162 -0
- package/dist/runtime/polyfill/uiMediaApi.mjs.map +1 -0
- package/dist/runtime/polyfill/videoContext.mjs +56 -0
- package/dist/runtime/polyfill/videoContext.mjs.map +1 -0
- package/dist/runtime/polyfill/vkSession.mjs +58 -0
- package/dist/runtime/polyfill/vkSession.mjs.map +1 -0
- package/dist/runtime/polyfill/windowResize.mjs +39 -0
- package/dist/runtime/polyfill/windowResize.mjs.map +1 -0
- package/dist/runtime/polyfill/worker.mjs +77 -0
- package/dist/runtime/polyfill/worker.mjs.map +1 -0
- package/dist/runtime/polyfill.d.mts +5 -0
- package/dist/runtime/renderContext.d.mts +21 -0
- package/dist/runtime/renderContext.mjs +147 -0
- package/dist/runtime/renderContext.mjs.map +1 -0
- package/dist/runtime/rpx.d.mts +9 -0
- package/dist/runtime/rpx.mjs +27 -0
- package/dist/runtime/rpx.mjs.map +1 -0
- package/dist/runtime/style.d.mts +6 -0
- package/dist/runtime/style.mjs +37 -0
- package/dist/runtime/style.mjs.map +1 -0
- package/dist/runtime/template.d.mts +10 -0
- package/dist/runtime/warning.d.mts +10 -0
- package/dist/runtime/warning.mjs +43 -0
- package/dist/runtime/warning.mjs.map +1 -0
- package/dist/{slugify-B4l45KNs.mjs → shared/slugify.mjs} +3 -1
- package/dist/shared/slugify.mjs.map +1 -0
- package/dist/shared/wxml.mjs +64 -0
- package/dist/shared/wxml.mjs.map +1 -0
- package/package.json +2 -2
- package/dist/index-w9xxIH-l.d.mts +0 -1229
- package/dist/plugin-BARxSPO8.mjs +0 -1567
- package/dist/plugin-DP2iPVmw.d.mts +0 -96
- package/dist/runtime-D6j2_x_N.mjs +0 -6251
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request.mjs","names":[],"sources":["../../../../src/runtime/polyfill/network/request.ts"],"sourcesContent":["import {\n normalizeFilePath,\n resolveUploadFileBlob,\n resolveUploadFileName,\n} from '../files'\n\ninterface RequestParseOptions {\n responseType?: 'text' | 'arraybuffer'\n dataType?: 'json' | 'text'\n}\n\ninterface RequestLikeOptions extends RequestParseOptions {\n url?: string\n method?: string\n header?: Record<string, string>\n data?: unknown\n timeout?: number\n}\n\ninterface DownloadLikeOptions {\n url?: string\n header?: Record<string, string>\n timeout?: number\n}\n\ninterface UploadLikeOptions {\n url?: string\n filePath?: string\n header?: Record<string, string>\n formData?: Record<string, unknown>\n name?: string\n timeout?: number\n}\n\nfunction resolveTimeoutSignal(timeout: number) {\n const controller = typeof AbortController === 'function' ? new AbortController() : undefined\n let timeoutTimer: ReturnType<typeof setTimeout> | undefined\n if (timeout > 0 && controller) {\n timeoutTimer = setTimeout(() => controller.abort(), timeout)\n }\n return {\n signal: controller?.signal,\n clear: () => {\n if (timeoutTimer) {\n clearTimeout(timeoutTimer)\n }\n },\n }\n}\n\nexport function getRuntimeFetch() {\n const runtime = globalThis as Record<string, unknown>\n const maybeFetch = runtime.fetch\n if (typeof maybeFetch === 'function') {\n return maybeFetch as typeof fetch\n }\n return undefined\n}\n\nexport function normalizeRequestMethod(method?: string) {\n return (method || 'GET').toUpperCase()\n}\n\nexport function normalizeRequestHeaders(header?: Record<string, string>) {\n if (!header) {\n return {}\n }\n return { ...header }\n}\n\nexport function buildRequestUrl(url: string, method: string, data: unknown) {\n if (method !== 'GET' || data == null) {\n return url\n }\n if (typeof data === 'string') {\n if (!data) {\n return url\n }\n return `${url}${url.includes('?') ? '&' : '?'}${data}`\n }\n if (typeof URLSearchParams !== 'undefined' && data instanceof URLSearchParams) {\n const query = data.toString()\n if (!query) {\n return url\n }\n return `${url}${url.includes('?') ? '&' : '?'}${query}`\n }\n if (typeof data === 'object') {\n const query = new URLSearchParams()\n for (const [key, value] of Object.entries(data as Record<string, unknown>)) {\n query.append(key, value == null ? '' : String(value))\n }\n const queryText = query.toString()\n if (!queryText) {\n return url\n }\n return `${url}${url.includes('?') ? '&' : '?'}${queryText}`\n }\n return url\n}\n\nexport function buildRequestBody(\n method: string,\n data: unknown,\n headers: Record<string, string>,\n) {\n if (method === 'GET' || data == null) {\n return undefined\n }\n if (typeof data === 'string') {\n return data\n }\n if (typeof URLSearchParams !== 'undefined' && data instanceof URLSearchParams) {\n return data\n }\n if (typeof FormData !== 'undefined' && data instanceof FormData) {\n return data\n }\n const contentTypeKey = Object.keys(headers).find(key => key.toLowerCase() === 'content-type')\n const contentType = contentTypeKey ? headers[contentTypeKey] : ''\n if (contentType && !contentType.includes('application/json')) {\n return String(data)\n }\n if (!contentTypeKey) {\n headers['content-type'] = 'application/json'\n }\n return JSON.stringify(data)\n}\n\nexport async function parseRequestResponseData(\n response: Response,\n options?: RequestParseOptions,\n) {\n if (options?.responseType === 'arraybuffer') {\n return response.arrayBuffer()\n }\n const contentType = response.headers.get('content-type') ?? ''\n if (options?.dataType === 'text') {\n return response.text()\n }\n if (options?.dataType === 'json' || contentType.includes('application/json')) {\n return response.json()\n }\n return response.text()\n}\n\nexport function createBlobObjectUrl(blob: Blob) {\n const runtimeUrl = (globalThis as {\n URL?: {\n createObjectURL?: (value: Blob) => string\n }\n }).URL\n if (runtimeUrl && typeof runtimeUrl.createObjectURL === 'function') {\n return runtimeUrl.createObjectURL(blob)\n }\n return ''\n}\n\nexport function collectResponseHeaders(response: {\n headers: {\n forEach: (callback: (value: string, key: string) => void) => void\n }\n}) {\n const headers: Record<string, string> = {}\n response.headers.forEach((value, key) => {\n headers[key] = value\n })\n return headers\n}\n\nexport function stripUploadContentType(headers: Record<string, string>) {\n const normalized = { ...headers }\n for (const key of Object.keys(normalized)) {\n if (key.toLowerCase() === 'content-type') {\n delete normalized[key]\n }\n }\n return normalized\n}\n\nexport async function performRequestByFetch(options?: RequestLikeOptions) {\n const url = options?.url?.trim() ?? ''\n if (!url) {\n throw new TypeError('invalid url')\n }\n const runtimeFetch = getRuntimeFetch()\n if (!runtimeFetch) {\n throw new TypeError('fetch is unavailable')\n }\n const method = normalizeRequestMethod(options?.method)\n const headers = normalizeRequestHeaders(options?.header)\n const requestUrl = buildRequestUrl(url, method, options?.data)\n const body = buildRequestBody(method, options?.data, headers)\n const timeout = typeof options?.timeout === 'number' && options.timeout > 0 ? options.timeout : 0\n const timeoutControl = resolveTimeoutSignal(timeout)\n\n try {\n const response = await runtimeFetch(requestUrl, {\n method,\n headers,\n body,\n signal: timeoutControl.signal,\n })\n const responseData = await parseRequestResponseData(response, options)\n return {\n data: responseData,\n statusCode: response.status,\n header: collectResponseHeaders(response),\n }\n }\n finally {\n timeoutControl.clear()\n }\n}\n\nexport async function performDownloadByFetch(options?: DownloadLikeOptions) {\n const url = options?.url?.trim() ?? ''\n if (!url) {\n throw new TypeError('invalid url')\n }\n const runtimeFetch = getRuntimeFetch()\n if (!runtimeFetch) {\n throw new TypeError('fetch is unavailable')\n }\n const headers = normalizeRequestHeaders(options?.header)\n const timeout = typeof options?.timeout === 'number' && options.timeout > 0 ? options.timeout : 0\n const timeoutControl = resolveTimeoutSignal(timeout)\n\n try {\n const response = await runtimeFetch(url, {\n method: 'GET',\n headers,\n signal: timeoutControl.signal,\n })\n const blob = await response.blob()\n return {\n tempFilePath: createBlobObjectUrl(blob) || url,\n statusCode: response.status,\n }\n }\n finally {\n timeoutControl.clear()\n }\n}\n\nexport async function performUploadByFetch(options?: UploadLikeOptions) {\n const url = options?.url?.trim() ?? ''\n if (!url) {\n throw new TypeError('invalid url')\n }\n const filePath = normalizeFilePath(options?.filePath)\n if (!filePath) {\n throw new TypeError('invalid filePath')\n }\n const runtimeFetch = getRuntimeFetch()\n if (!runtimeFetch) {\n throw new TypeError('fetch is unavailable')\n }\n const FormDataCtor = (globalThis as { FormData?: typeof FormData }).FormData\n if (typeof FormDataCtor !== 'function') {\n throw new TypeError('FormData is unavailable')\n }\n\n const headers = stripUploadContentType(normalizeRequestHeaders(options?.header))\n const formData = new FormDataCtor()\n for (const [key, value] of Object.entries(options?.formData ?? {})) {\n formData.append(key, value == null ? '' : String(value))\n }\n const blob = await resolveUploadFileBlob(filePath, runtimeFetch)\n formData.append(options?.name?.trim() || 'file', blob, resolveUploadFileName(filePath))\n\n const timeout = typeof options?.timeout === 'number' && options.timeout > 0 ? options.timeout : 0\n const timeoutControl = resolveTimeoutSignal(timeout)\n\n try {\n const response = await runtimeFetch(url, {\n method: 'POST',\n headers,\n body: formData,\n signal: timeoutControl.signal,\n })\n const data = await response.text()\n return {\n data,\n statusCode: response.status,\n header: collectResponseHeaders(response),\n }\n }\n finally {\n timeoutControl.clear()\n }\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { callWxAsyncFailure, callWxAsyncSuccess } from "../async.mjs";
|
|
2
|
+
import { performDownloadByFetch, performRequestByFetch, performUploadByFetch } from "./request.mjs";
|
|
3
|
+
|
|
4
|
+
//#region src/runtime/polyfill/network/requestBridge.ts
|
|
5
|
+
async function requestByFetchBridge(options) {
|
|
6
|
+
try {
|
|
7
|
+
const response = await performRequestByFetch(options);
|
|
8
|
+
return callWxAsyncSuccess(options, {
|
|
9
|
+
errMsg: "request:ok",
|
|
10
|
+
data: response.data,
|
|
11
|
+
statusCode: response.statusCode,
|
|
12
|
+
header: response.header
|
|
13
|
+
});
|
|
14
|
+
} catch (error) {
|
|
15
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
16
|
+
return Promise.reject(callWxAsyncFailure(options, `request:fail ${message}`));
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
async function downloadFileByFetchBridge(options) {
|
|
20
|
+
try {
|
|
21
|
+
const response = await performDownloadByFetch(options);
|
|
22
|
+
return callWxAsyncSuccess(options, {
|
|
23
|
+
errMsg: "downloadFile:ok",
|
|
24
|
+
tempFilePath: response.tempFilePath,
|
|
25
|
+
statusCode: response.statusCode
|
|
26
|
+
});
|
|
27
|
+
} catch (error) {
|
|
28
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
29
|
+
return Promise.reject(callWxAsyncFailure(options, `downloadFile:fail ${message}`));
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
async function uploadFileByFetchBridge(options) {
|
|
33
|
+
try {
|
|
34
|
+
const response = await performUploadByFetch(options);
|
|
35
|
+
return callWxAsyncSuccess(options, {
|
|
36
|
+
errMsg: "uploadFile:ok",
|
|
37
|
+
data: response.data,
|
|
38
|
+
statusCode: response.statusCode,
|
|
39
|
+
header: response.header
|
|
40
|
+
});
|
|
41
|
+
} catch (error) {
|
|
42
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
43
|
+
return Promise.reject(callWxAsyncFailure(options, `uploadFile:fail ${message}`));
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
//#endregion
|
|
48
|
+
export { downloadFileByFetchBridge, requestByFetchBridge, uploadFileByFetchBridge };
|
|
49
|
+
//# sourceMappingURL=requestBridge.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"requestBridge.mjs","names":[],"sources":["../../../../src/runtime/polyfill/network/requestBridge.ts"],"sourcesContent":["import type { DownloadFileOptions, RequestOptions, UploadFileOptions } from '../types/common'\nimport {\n callWxAsyncFailure,\n callWxAsyncSuccess,\n} from '../async'\nimport {\n performDownloadByFetch,\n performRequestByFetch,\n performUploadByFetch,\n} from './request'\n\nexport async function requestByFetchBridge(options?: RequestOptions) {\n try {\n const response = await performRequestByFetch(options)\n return callWxAsyncSuccess(options, {\n errMsg: 'request:ok',\n data: response.data,\n statusCode: response.statusCode,\n header: response.header,\n })\n }\n catch (error) {\n const message = error instanceof Error ? error.message : String(error)\n return Promise.reject(callWxAsyncFailure(options, `request:fail ${message}`))\n }\n}\n\nexport async function downloadFileByFetchBridge(options?: DownloadFileOptions) {\n try {\n const response = await performDownloadByFetch(options)\n return callWxAsyncSuccess(options, {\n errMsg: 'downloadFile:ok',\n tempFilePath: response.tempFilePath,\n statusCode: response.statusCode,\n })\n }\n catch (error) {\n const message = error instanceof Error ? error.message : String(error)\n return Promise.reject(callWxAsyncFailure(options, `downloadFile:fail ${message}`))\n }\n}\n\nexport async function uploadFileByFetchBridge(options?: UploadFileOptions) {\n try {\n const response = await performUploadByFetch(options)\n return callWxAsyncSuccess(options, {\n errMsg: 'uploadFile:ok',\n data: response.data,\n statusCode: response.statusCode,\n header: response.header,\n })\n }\n catch (error) {\n const message = error instanceof Error ? error.message : String(error)\n return Promise.reject(callWxAsyncFailure(options, `uploadFile:fail ${message}`))\n }\n}\n"],"mappings":";;;;AAWA,eAAsB,qBAAqB,SAA0B;AACnE,KAAI;EACF,MAAM,WAAW,MAAM,sBAAsB,QAAQ;AACrD,SAAO,mBAAmB,SAAS;GACjC,QAAQ;GACR,MAAM,SAAS;GACf,YAAY,SAAS;GACrB,QAAQ,SAAS;GAClB,CAAC;UAEG,OAAO;EACZ,MAAM,UAAU,iBAAiB,QAAQ,MAAM,UAAU,OAAO,MAAM;AACtE,SAAO,QAAQ,OAAO,mBAAmB,SAAS,gBAAgB,UAAU,CAAC;;;AAIjF,eAAsB,0BAA0B,SAA+B;AAC7E,KAAI;EACF,MAAM,WAAW,MAAM,uBAAuB,QAAQ;AACtD,SAAO,mBAAmB,SAAS;GACjC,QAAQ;GACR,cAAc,SAAS;GACvB,YAAY,SAAS;GACtB,CAAC;UAEG,OAAO;EACZ,MAAM,UAAU,iBAAiB,QAAQ,MAAM,UAAU,OAAO,MAAM;AACtE,SAAO,QAAQ,OAAO,mBAAmB,SAAS,qBAAqB,UAAU,CAAC;;;AAItF,eAAsB,wBAAwB,SAA6B;AACzE,KAAI;EACF,MAAM,WAAW,MAAM,qBAAqB,QAAQ;AACpD,SAAO,mBAAmB,SAAS;GACjC,QAAQ;GACR,MAAM,SAAS;GACf,YAAY,SAAS;GACrB,QAAQ,SAAS;GAClB,CAAC;UAEG,OAAO;EACZ,MAAM,UAAU,iBAAiB,QAAQ,MAAM,UAAU,OAAO,MAAM;AACtE,SAAO,QAAQ,OAAO,mBAAmB,SAAS,mBAAmB,UAAU,CAAC"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
//#region src/runtime/polyfill/network/status.ts
|
|
2
|
+
function getNavigatorConnection() {
|
|
3
|
+
const runtimeNavigator = typeof navigator !== "undefined" ? navigator : void 0;
|
|
4
|
+
return runtimeNavigator?.connection ?? runtimeNavigator?.mozConnection ?? runtimeNavigator?.webkitConnection;
|
|
5
|
+
}
|
|
6
|
+
function resolveNetworkType(connection, isConnected) {
|
|
7
|
+
if (!isConnected) return "none";
|
|
8
|
+
const type = typeof connection?.type === "string" ? connection.type.toLowerCase() : "";
|
|
9
|
+
const effectiveType = typeof connection?.effectiveType === "string" ? connection.effectiveType.toLowerCase() : "";
|
|
10
|
+
if (type.includes("wifi") || type.includes("ethernet")) return "wifi";
|
|
11
|
+
if (effectiveType.includes("5g")) return "5g";
|
|
12
|
+
if (effectiveType.includes("4g")) return "4g";
|
|
13
|
+
if (effectiveType.includes("3g")) return "3g";
|
|
14
|
+
if (effectiveType.includes("2g") || effectiveType.includes("slow-2g")) return "2g";
|
|
15
|
+
if (type.includes("cellular")) return "unknown";
|
|
16
|
+
return "unknown";
|
|
17
|
+
}
|
|
18
|
+
function readNetworkStatusSnapshot() {
|
|
19
|
+
const runtimeNavigator = typeof navigator !== "undefined" ? navigator : void 0;
|
|
20
|
+
const isConnected = typeof runtimeNavigator?.onLine === "boolean" ? runtimeNavigator.onLine : true;
|
|
21
|
+
return {
|
|
22
|
+
isConnected,
|
|
23
|
+
networkType: resolveNetworkType(getNavigatorConnection(), isConnected)
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
const networkStatusCallbacks = /* @__PURE__ */ new Set();
|
|
27
|
+
let networkStatusBridgeBound = false;
|
|
28
|
+
function notifyNetworkStatusChange() {
|
|
29
|
+
if (networkStatusCallbacks.size === 0) return;
|
|
30
|
+
const status = readNetworkStatusSnapshot();
|
|
31
|
+
for (const callback of networkStatusCallbacks) callback(status);
|
|
32
|
+
}
|
|
33
|
+
function bindNetworkStatusBridge() {
|
|
34
|
+
if (networkStatusBridgeBound) return;
|
|
35
|
+
networkStatusBridgeBound = true;
|
|
36
|
+
const runtimeTarget = globalThis;
|
|
37
|
+
runtimeTarget.addEventListener?.("online", notifyNetworkStatusChange);
|
|
38
|
+
runtimeTarget.addEventListener?.("offline", notifyNetworkStatusChange);
|
|
39
|
+
getNavigatorConnection()?.addEventListener?.("change", notifyNetworkStatusChange);
|
|
40
|
+
}
|
|
41
|
+
function addNetworkStatusCallback(callback) {
|
|
42
|
+
bindNetworkStatusBridge();
|
|
43
|
+
networkStatusCallbacks.add(callback);
|
|
44
|
+
}
|
|
45
|
+
function removeNetworkStatusCallback(callback) {
|
|
46
|
+
if (typeof callback !== "function") {
|
|
47
|
+
networkStatusCallbacks.clear();
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
networkStatusCallbacks.delete(callback);
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
//#endregion
|
|
54
|
+
export { addNetworkStatusCallback, readNetworkStatusSnapshot, removeNetworkStatusCallback };
|
|
55
|
+
//# sourceMappingURL=status.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status.mjs","names":[],"sources":["../../../../src/runtime/polyfill/network/status.ts"],"sourcesContent":["type NetworkType = 'wifi' | '2g' | '3g' | '4g' | '5g' | 'unknown' | 'none'\n\ninterface NetworkStatusSnapshot {\n isConnected: boolean\n networkType: NetworkType\n}\n\ninterface NavigatorConnection {\n type?: string\n effectiveType?: string\n addEventListener?: (type: string, listener: () => void) => void\n}\n\nexport function getNavigatorConnection() {\n const runtimeNavigator = (typeof navigator !== 'undefined' ? navigator : undefined) as (Navigator & {\n connection?: NavigatorConnection\n mozConnection?: NavigatorConnection\n webkitConnection?: NavigatorConnection\n }) | undefined\n return runtimeNavigator?.connection ?? runtimeNavigator?.mozConnection ?? runtimeNavigator?.webkitConnection\n}\n\nfunction resolveNetworkType(connection: NavigatorConnection | undefined, isConnected: boolean): NetworkType {\n if (!isConnected) {\n return 'none'\n }\n const type = typeof connection?.type === 'string' ? connection.type.toLowerCase() : ''\n const effectiveType = typeof connection?.effectiveType === 'string'\n ? connection.effectiveType.toLowerCase()\n : ''\n if (type.includes('wifi') || type.includes('ethernet')) {\n return 'wifi'\n }\n if (effectiveType.includes('5g')) {\n return '5g'\n }\n if (effectiveType.includes('4g')) {\n return '4g'\n }\n if (effectiveType.includes('3g')) {\n return '3g'\n }\n if (effectiveType.includes('2g') || effectiveType.includes('slow-2g')) {\n return '2g'\n }\n if (type.includes('cellular')) {\n return 'unknown'\n }\n return 'unknown'\n}\n\nexport function readNetworkStatusSnapshot(): NetworkStatusSnapshot {\n const runtimeNavigator = typeof navigator !== 'undefined' ? navigator : undefined\n const isConnected = typeof runtimeNavigator?.onLine === 'boolean' ? runtimeNavigator.onLine : true\n const connection = getNavigatorConnection()\n return {\n isConnected,\n networkType: resolveNetworkType(connection, isConnected),\n }\n}\n\nconst networkStatusCallbacks = new Set<(result: NetworkStatusSnapshot) => void>()\nlet networkStatusBridgeBound = false\n\nfunction notifyNetworkStatusChange() {\n if (networkStatusCallbacks.size === 0) {\n return\n }\n const status = readNetworkStatusSnapshot()\n for (const callback of networkStatusCallbacks) {\n callback(status)\n }\n}\n\nfunction bindNetworkStatusBridge() {\n if (networkStatusBridgeBound) {\n return\n }\n networkStatusBridgeBound = true\n const runtimeTarget = globalThis as {\n addEventListener?: (type: string, listener: () => void) => void\n }\n runtimeTarget.addEventListener?.('online', notifyNetworkStatusChange)\n runtimeTarget.addEventListener?.('offline', notifyNetworkStatusChange)\n const connection = getNavigatorConnection()\n connection?.addEventListener?.('change', notifyNetworkStatusChange)\n}\n\nexport function addNetworkStatusCallback(callback: (result: NetworkStatusSnapshot) => void) {\n bindNetworkStatusBridge()\n networkStatusCallbacks.add(callback)\n}\n\nexport function removeNetworkStatusCallback(callback?: (result: NetworkStatusSnapshot) => void) {\n if (typeof callback !== 'function') {\n networkStatusCallbacks.clear()\n return\n }\n networkStatusCallbacks.delete(callback)\n}\n"],"mappings":";AAaA,SAAgB,yBAAyB;CACvC,MAAM,mBAAoB,OAAO,cAAc,cAAc,YAAY;AAKzE,QAAO,kBAAkB,cAAc,kBAAkB,iBAAiB,kBAAkB;;AAG9F,SAAS,mBAAmB,YAA6C,aAAmC;AAC1G,KAAI,CAAC,YACH,QAAO;CAET,MAAM,OAAO,OAAO,YAAY,SAAS,WAAW,WAAW,KAAK,aAAa,GAAG;CACpF,MAAM,gBAAgB,OAAO,YAAY,kBAAkB,WACvD,WAAW,cAAc,aAAa,GACtC;AACJ,KAAI,KAAK,SAAS,OAAO,IAAI,KAAK,SAAS,WAAW,CACpD,QAAO;AAET,KAAI,cAAc,SAAS,KAAK,CAC9B,QAAO;AAET,KAAI,cAAc,SAAS,KAAK,CAC9B,QAAO;AAET,KAAI,cAAc,SAAS,KAAK,CAC9B,QAAO;AAET,KAAI,cAAc,SAAS,KAAK,IAAI,cAAc,SAAS,UAAU,CACnE,QAAO;AAET,KAAI,KAAK,SAAS,WAAW,CAC3B,QAAO;AAET,QAAO;;AAGT,SAAgB,4BAAmD;CACjE,MAAM,mBAAmB,OAAO,cAAc,cAAc,YAAY;CACxE,MAAM,cAAc,OAAO,kBAAkB,WAAW,YAAY,iBAAiB,SAAS;AAE9F,QAAO;EACL;EACA,aAAa,mBAHI,wBAAwB,EAGG,YAAY;EACzD;;AAGH,MAAM,yCAAyB,IAAI,KAA8C;AACjF,IAAI,2BAA2B;AAE/B,SAAS,4BAA4B;AACnC,KAAI,uBAAuB,SAAS,EAClC;CAEF,MAAM,SAAS,2BAA2B;AAC1C,MAAK,MAAM,YAAY,uBACrB,UAAS,OAAO;;AAIpB,SAAS,0BAA0B;AACjC,KAAI,yBACF;AAEF,4BAA2B;CAC3B,MAAM,gBAAgB;AAGtB,eAAc,mBAAmB,UAAU,0BAA0B;AACrE,eAAc,mBAAmB,WAAW,0BAA0B;AAEtE,CADmB,wBAAwB,EAC/B,mBAAmB,UAAU,0BAA0B;;AAGrE,SAAgB,yBAAyB,UAAmD;AAC1F,0BAAyB;AACzB,wBAAuB,IAAI,SAAS;;AAGtC,SAAgB,4BAA4B,UAAoD;AAC9F,KAAI,OAAO,aAAa,YAAY;AAClC,yBAAuB,OAAO;AAC9B;;AAEF,wBAAuB,OAAO,SAAS"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { callWxAsyncSuccess, scheduleMicrotask } from "./async.mjs";
|
|
2
|
+
import { createInterstitialAdImpl, createRewardedVideoAdImpl } from "./ad.mjs";
|
|
3
|
+
import { createLogManagerBridge, createUpdateManagerBridge, readExtConfigValue, readRuntimeConsole, reportAnalyticsEvent, resolveUpdateManagerPreset } from "./platformRuntime.mjs";
|
|
4
|
+
|
|
5
|
+
//#region src/runtime/polyfill/platformApi.ts
|
|
6
|
+
function createRewardedVideoAdBridge(options) {
|
|
7
|
+
return createRewardedVideoAdImpl(options);
|
|
8
|
+
}
|
|
9
|
+
function createInterstitialAdBridge(options) {
|
|
10
|
+
return createInterstitialAdImpl(options);
|
|
11
|
+
}
|
|
12
|
+
function getExtConfigSyncBridge() {
|
|
13
|
+
return readExtConfigValue();
|
|
14
|
+
}
|
|
15
|
+
function getExtConfigBridge(options) {
|
|
16
|
+
return Promise.resolve(callWxAsyncSuccess(options, {
|
|
17
|
+
errMsg: "getExtConfig:ok",
|
|
18
|
+
extConfig: getExtConfigSyncBridge()
|
|
19
|
+
}));
|
|
20
|
+
}
|
|
21
|
+
function getUpdateManagerBridge() {
|
|
22
|
+
return createUpdateManagerBridge(resolveUpdateManagerPreset, scheduleMicrotask);
|
|
23
|
+
}
|
|
24
|
+
function getLogManagerBridge(options) {
|
|
25
|
+
return createLogManagerBridge(options?.level === 0 ? 0 : 1, readRuntimeConsole());
|
|
26
|
+
}
|
|
27
|
+
function reportAnalyticsBridge(eventName, data) {
|
|
28
|
+
reportAnalyticsEvent(eventName, data);
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
//#endregion
|
|
32
|
+
export { createInterstitialAdBridge, createRewardedVideoAdBridge, getExtConfigBridge, getExtConfigSyncBridge, getLogManagerBridge, getUpdateManagerBridge, reportAnalyticsBridge };
|
|
33
|
+
//# sourceMappingURL=platformApi.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"platformApi.mjs","names":[],"sources":["../../../src/runtime/polyfill/platformApi.ts"],"sourcesContent":["import {\n createInterstitialAdImpl,\n createRewardedVideoAdImpl,\n} from './ad'\nimport { callWxAsyncSuccess, scheduleMicrotask } from './async'\nimport {\n createLogManagerBridge,\n createUpdateManagerBridge,\n readExtConfigValue,\n readRuntimeConsole,\n reportAnalyticsEvent,\n resolveUpdateManagerPreset,\n} from './platformRuntime'\n\nexport function createRewardedVideoAdBridge(options?: any): any {\n return createRewardedVideoAdImpl(options)\n}\n\nexport function createInterstitialAdBridge(options?: any): any {\n return createInterstitialAdImpl(options)\n}\n\nexport function getExtConfigSyncBridge() {\n return readExtConfigValue()\n}\n\nexport function getExtConfigBridge(options?: any): Promise<any> {\n return Promise.resolve(callWxAsyncSuccess(options, {\n errMsg: 'getExtConfig:ok',\n extConfig: getExtConfigSyncBridge(),\n }))\n}\n\nexport function getUpdateManagerBridge() {\n return createUpdateManagerBridge(resolveUpdateManagerPreset, scheduleMicrotask)\n}\n\nexport function getLogManagerBridge(options?: any) {\n const level = options?.level === 0 ? 0 : 1\n return createLogManagerBridge(level, readRuntimeConsole())\n}\n\nexport function reportAnalyticsBridge(eventName: string, data?: Record<string, unknown>) {\n reportAnalyticsEvent(eventName, data)\n}\n"],"mappings":";;;;;AAcA,SAAgB,4BAA4B,SAAoB;AAC9D,QAAO,0BAA0B,QAAQ;;AAG3C,SAAgB,2BAA2B,SAAoB;AAC7D,QAAO,yBAAyB,QAAQ;;AAG1C,SAAgB,yBAAyB;AACvC,QAAO,oBAAoB;;AAG7B,SAAgB,mBAAmB,SAA6B;AAC9D,QAAO,QAAQ,QAAQ,mBAAmB,SAAS;EACjD,QAAQ;EACR,WAAW,wBAAwB;EACpC,CAAC,CAAC;;AAGL,SAAgB,yBAAyB;AACvC,QAAO,0BAA0B,4BAA4B,kBAAkB;;AAGjF,SAAgB,oBAAoB,SAAe;AAEjD,QAAO,uBADO,SAAS,UAAU,IAAI,IAAI,GACJ,oBAAoB,CAAC;;AAG5D,SAAgB,sBAAsB,WAAmB,MAAgC;AACvF,sBAAqB,WAAW,KAAK"}
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
import { WEAPP_VITE_WEB_ANALYTICS_EVENTS_KEY, WEAPP_VITE_WEB_EXT_CONFIG_KEY, WEAPP_VITE_WEB_UPDATE_MANAGER_KEY } from "@weapp-core/constants";
|
|
2
|
+
|
|
3
|
+
//#region src/runtime/polyfill/platformRuntime.ts
|
|
4
|
+
function normalizeSubPackageName(value) {
|
|
5
|
+
if (typeof value !== "string") return "";
|
|
6
|
+
return value.trim();
|
|
7
|
+
}
|
|
8
|
+
function resolveSubPackageName(options) {
|
|
9
|
+
return normalizeSubPackageName(options?.name) || normalizeSubPackageName(options?.root);
|
|
10
|
+
}
|
|
11
|
+
function normalizeUpdateManagerPreset(value) {
|
|
12
|
+
if (typeof value === "boolean") return {
|
|
13
|
+
hasUpdate: value,
|
|
14
|
+
ready: value,
|
|
15
|
+
failed: false
|
|
16
|
+
};
|
|
17
|
+
if (typeof value === "string") {
|
|
18
|
+
const normalized = value.trim().toLowerCase();
|
|
19
|
+
if (!normalized || normalized === "none" || normalized === "false") return {
|
|
20
|
+
hasUpdate: false,
|
|
21
|
+
ready: false,
|
|
22
|
+
failed: false
|
|
23
|
+
};
|
|
24
|
+
if (normalized === "fail" || normalized === "failed" || normalized === "error") return {
|
|
25
|
+
hasUpdate: true,
|
|
26
|
+
ready: false,
|
|
27
|
+
failed: true
|
|
28
|
+
};
|
|
29
|
+
return {
|
|
30
|
+
hasUpdate: true,
|
|
31
|
+
ready: true,
|
|
32
|
+
failed: false
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
if (value && typeof value === "object") {
|
|
36
|
+
const payload = value;
|
|
37
|
+
const failed = Boolean(payload.failed ?? payload.fail);
|
|
38
|
+
const ready = failed ? false : Boolean(payload.ready ?? payload.updateReady);
|
|
39
|
+
const hasUpdate = payload.hasUpdate == null ? ready || failed : Boolean(payload.hasUpdate);
|
|
40
|
+
return {
|
|
41
|
+
hasUpdate,
|
|
42
|
+
ready: hasUpdate && ready,
|
|
43
|
+
failed: hasUpdate && failed
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
return {
|
|
47
|
+
hasUpdate: false,
|
|
48
|
+
ready: false,
|
|
49
|
+
failed: false
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
function resolveUpdateManagerPreset() {
|
|
53
|
+
const preset = globalThis[WEAPP_VITE_WEB_UPDATE_MANAGER_KEY];
|
|
54
|
+
if (typeof preset === "function") return normalizeUpdateManagerPreset(preset());
|
|
55
|
+
return normalizeUpdateManagerPreset(preset);
|
|
56
|
+
}
|
|
57
|
+
function readRuntimeConsole() {
|
|
58
|
+
return globalThis.console;
|
|
59
|
+
}
|
|
60
|
+
function readExtConfigValue() {
|
|
61
|
+
const value = globalThis[WEAPP_VITE_WEB_EXT_CONFIG_KEY];
|
|
62
|
+
if (value && typeof value === "object") return { ...value };
|
|
63
|
+
return {};
|
|
64
|
+
}
|
|
65
|
+
function createUpdateManagerBridge(resolveUpdateManagerPreset, scheduleMicrotask) {
|
|
66
|
+
return {
|
|
67
|
+
applyUpdate() {},
|
|
68
|
+
onCheckForUpdate(callback) {
|
|
69
|
+
if (typeof callback !== "function") return;
|
|
70
|
+
const preset = resolveUpdateManagerPreset();
|
|
71
|
+
scheduleMicrotask(() => callback({ hasUpdate: preset.hasUpdate }));
|
|
72
|
+
},
|
|
73
|
+
onUpdateReady(callback) {
|
|
74
|
+
if (typeof callback !== "function") return;
|
|
75
|
+
const preset = resolveUpdateManagerPreset();
|
|
76
|
+
if (!preset.hasUpdate || !preset.ready) return;
|
|
77
|
+
scheduleMicrotask(() => callback());
|
|
78
|
+
},
|
|
79
|
+
onUpdateFailed(callback) {
|
|
80
|
+
if (typeof callback !== "function") return;
|
|
81
|
+
const preset = resolveUpdateManagerPreset();
|
|
82
|
+
if (!preset.hasUpdate || !preset.failed) return;
|
|
83
|
+
scheduleMicrotask(() => callback());
|
|
84
|
+
}
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
function createLogManagerBridge(level, runtimeConsole) {
|
|
88
|
+
const invokeConsole = (method, args) => {
|
|
89
|
+
const handler = runtimeConsole?.[method];
|
|
90
|
+
if (typeof handler === "function") handler.apply(runtimeConsole, args);
|
|
91
|
+
};
|
|
92
|
+
return {
|
|
93
|
+
debug(...args) {
|
|
94
|
+
if (level > 0) return;
|
|
95
|
+
invokeConsole("debug", args);
|
|
96
|
+
},
|
|
97
|
+
info(...args) {
|
|
98
|
+
invokeConsole("info", args);
|
|
99
|
+
},
|
|
100
|
+
log(...args) {
|
|
101
|
+
invokeConsole("log", args);
|
|
102
|
+
},
|
|
103
|
+
warn(...args) {
|
|
104
|
+
invokeConsole("warn", args);
|
|
105
|
+
}
|
|
106
|
+
};
|
|
107
|
+
}
|
|
108
|
+
function reportAnalyticsEvent(eventName, data) {
|
|
109
|
+
const runtimeGlobal = globalThis;
|
|
110
|
+
runtimeGlobal[WEAPP_VITE_WEB_ANALYTICS_EVENTS_KEY] ??= [];
|
|
111
|
+
runtimeGlobal[WEAPP_VITE_WEB_ANALYTICS_EVENTS_KEY].push({
|
|
112
|
+
eventName: String(eventName ?? ""),
|
|
113
|
+
data: { ...data ?? {} },
|
|
114
|
+
timestamp: Date.now()
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
//#endregion
|
|
119
|
+
export { createLogManagerBridge, createUpdateManagerBridge, readExtConfigValue, readRuntimeConsole, reportAnalyticsEvent, resolveSubPackageName, resolveUpdateManagerPreset };
|
|
120
|
+
//# sourceMappingURL=platformRuntime.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"platformRuntime.mjs","names":[],"sources":["../../../src/runtime/polyfill/platformRuntime.ts"],"sourcesContent":["import {\n WEAPP_VITE_WEB_ANALYTICS_EVENTS_KEY,\n WEAPP_VITE_WEB_EXT_CONFIG_KEY,\n WEAPP_VITE_WEB_UPDATE_MANAGER_KEY,\n} from '@weapp-core/constants'\n\ninterface UpdatePresetSnapshot {\n hasUpdate: boolean\n ready: boolean\n failed: boolean\n}\n\ninterface RuntimeConsoleLike {\n debug?: (...args: unknown[]) => void\n info?: (...args: unknown[]) => void\n log?: (...args: unknown[]) => void\n warn?: (...args: unknown[]) => void\n}\n\nfunction normalizeSubPackageName(value: unknown) {\n if (typeof value !== 'string') {\n return ''\n }\n return value.trim()\n}\n\nexport function resolveSubPackageName(options?: { name?: unknown, root?: unknown }) {\n return normalizeSubPackageName(options?.name) || normalizeSubPackageName(options?.root)\n}\n\nfunction normalizeUpdateManagerPreset(value: unknown): UpdatePresetSnapshot {\n if (typeof value === 'boolean') {\n return {\n hasUpdate: value,\n ready: value,\n failed: false,\n }\n }\n if (typeof value === 'string') {\n const normalized = value.trim().toLowerCase()\n if (!normalized || normalized === 'none' || normalized === 'false') {\n return {\n hasUpdate: false,\n ready: false,\n failed: false,\n }\n }\n if (normalized === 'fail' || normalized === 'failed' || normalized === 'error') {\n return {\n hasUpdate: true,\n ready: false,\n failed: true,\n }\n }\n return {\n hasUpdate: true,\n ready: true,\n failed: false,\n }\n }\n if (value && typeof value === 'object') {\n const payload = value as {\n hasUpdate?: unknown\n ready?: unknown\n updateReady?: unknown\n failed?: unknown\n fail?: unknown\n }\n const failed = Boolean(payload.failed ?? payload.fail)\n const ready = failed ? false : Boolean(payload.ready ?? payload.updateReady)\n const hasUpdate = payload.hasUpdate == null ? (ready || failed) : Boolean(payload.hasUpdate)\n return {\n hasUpdate,\n ready: hasUpdate && ready,\n failed: hasUpdate && failed,\n }\n }\n return {\n hasUpdate: false,\n ready: false,\n failed: false,\n }\n}\n\nexport function resolveUpdateManagerPreset() {\n const runtimeGlobal = globalThis as Record<string, unknown>\n const preset = runtimeGlobal[WEAPP_VITE_WEB_UPDATE_MANAGER_KEY]\n if (typeof preset === 'function') {\n return normalizeUpdateManagerPreset((preset as () => unknown)())\n }\n return normalizeUpdateManagerPreset(preset)\n}\n\nexport function readRuntimeConsole() {\n const runtimeGlobal = globalThis as { console?: Console }\n return runtimeGlobal.console\n}\n\nexport function readExtConfigValue() {\n const runtimeGlobal = globalThis as Record<string, unknown>\n const value = runtimeGlobal[WEAPP_VITE_WEB_EXT_CONFIG_KEY]\n if (value && typeof value === 'object') {\n return { ...(value as Record<string, unknown>) }\n }\n return {}\n}\n\nexport function createUpdateManagerBridge(\n resolveUpdateManagerPreset: () => UpdatePresetSnapshot,\n scheduleMicrotask: (callback: () => void) => void,\n) {\n return {\n applyUpdate() {},\n onCheckForUpdate(callback: ((result: { hasUpdate: boolean }) => void) | undefined) {\n if (typeof callback !== 'function') {\n return\n }\n const preset = resolveUpdateManagerPreset()\n scheduleMicrotask(() => callback({ hasUpdate: preset.hasUpdate }))\n },\n onUpdateReady(callback: (() => void) | undefined) {\n if (typeof callback !== 'function') {\n return\n }\n const preset = resolveUpdateManagerPreset()\n if (!preset.hasUpdate || !preset.ready) {\n return\n }\n scheduleMicrotask(() => callback())\n },\n onUpdateFailed(callback: (() => void) | undefined) {\n if (typeof callback !== 'function') {\n return\n }\n const preset = resolveUpdateManagerPreset()\n if (!preset.hasUpdate || !preset.failed) {\n return\n }\n scheduleMicrotask(() => callback())\n },\n }\n}\n\nexport function createLogManagerBridge(level: 0 | 1, runtimeConsole: RuntimeConsoleLike | undefined) {\n const invokeConsole = (method: 'debug' | 'info' | 'log' | 'warn', args: unknown[]) => {\n const handler = runtimeConsole?.[method]\n if (typeof handler === 'function') {\n handler.apply(runtimeConsole, args)\n }\n }\n return {\n debug(...args: unknown[]) {\n if (level > 0) {\n return\n }\n invokeConsole('debug', args)\n },\n info(...args: unknown[]) {\n invokeConsole('info', args)\n },\n log(...args: unknown[]) {\n invokeConsole('log', args)\n },\n warn(...args: unknown[]) {\n invokeConsole('warn', args)\n },\n }\n}\n\nexport function reportAnalyticsEvent(eventName: string, data?: Record<string, unknown>) {\n const runtimeGlobal = globalThis as {\n [WEAPP_VITE_WEB_ANALYTICS_EVENTS_KEY]?: Array<{\n eventName: string\n data: Record<string, unknown>\n timestamp: number\n }>\n }\n runtimeGlobal[WEAPP_VITE_WEB_ANALYTICS_EVENTS_KEY] ??= []\n runtimeGlobal[WEAPP_VITE_WEB_ANALYTICS_EVENTS_KEY].push({\n eventName: String(eventName ?? ''),\n data: { ...(data ?? {}) },\n timestamp: Date.now(),\n })\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { attachRouteMeta } from "./lifecycle.mjs";
|
|
2
|
+
|
|
3
|
+
//#region src/runtime/polyfill/routeRuntime/dom.ts
|
|
4
|
+
function ensureDocumentReady(callback) {
|
|
5
|
+
if (typeof document === "undefined") return;
|
|
6
|
+
if (document.readyState === "loading") {
|
|
7
|
+
document.addEventListener("DOMContentLoaded", () => callback(), { once: true });
|
|
8
|
+
return;
|
|
9
|
+
}
|
|
10
|
+
callback();
|
|
11
|
+
}
|
|
12
|
+
function ensureContainer() {
|
|
13
|
+
if (typeof document === "undefined") return;
|
|
14
|
+
return document.querySelector("#app") ?? document.body;
|
|
15
|
+
}
|
|
16
|
+
function mountEntryToDom(entry, pageRegistry, onMounted) {
|
|
17
|
+
const record = pageRegistry.get(entry.id);
|
|
18
|
+
if (!record) return;
|
|
19
|
+
ensureDocumentReady(() => {
|
|
20
|
+
const container = ensureContainer();
|
|
21
|
+
if (!container) return;
|
|
22
|
+
while (container.childNodes.length) container.removeChild(container.childNodes[0]);
|
|
23
|
+
const element = document.createElement(record.tag);
|
|
24
|
+
attachRouteMeta(element, {
|
|
25
|
+
id: entry.id,
|
|
26
|
+
query: entry.query,
|
|
27
|
+
entry
|
|
28
|
+
});
|
|
29
|
+
container.append(element);
|
|
30
|
+
onMounted(entry);
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
//#endregion
|
|
35
|
+
export { mountEntryToDom };
|
|
36
|
+
//# sourceMappingURL=dom.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dom.mjs","names":[],"sources":["../../../../src/runtime/polyfill/routeRuntime/dom.ts"],"sourcesContent":["import type { ComponentPublicInstance } from '../../component'\nimport type { PageRecord, PageStackEntry } from './options'\nimport { attachRouteMeta } from './lifecycle'\n\nfunction ensureDocumentReady(callback: () => void) {\n if (typeof document === 'undefined') {\n return\n }\n if (document.readyState === 'loading') {\n document.addEventListener('DOMContentLoaded', () => callback(), { once: true })\n return\n }\n callback()\n}\n\nfunction ensureContainer(): HTMLElement | undefined {\n if (typeof document === 'undefined') {\n return undefined\n }\n return (document.querySelector('#app') as HTMLElement | null) ?? document.body\n}\n\nexport function mountEntryToDom(\n entry: PageStackEntry,\n pageRegistry: Map<string, PageRecord>,\n onMounted: (entry: PageStackEntry) => void,\n) {\n const record = pageRegistry.get(entry.id)\n if (!record) {\n return\n }\n ensureDocumentReady(() => {\n const container = ensureContainer()\n if (!container) {\n return\n }\n while (container.childNodes.length) {\n container.removeChild(container.childNodes[0]!)\n }\n const element = document.createElement(record.tag) as HTMLElement & ComponentPublicInstance\n attachRouteMeta(element, {\n id: entry.id,\n query: entry.query,\n entry,\n })\n container.append(element)\n onMounted(entry)\n })\n}\n"],"mappings":";;;AAIA,SAAS,oBAAoB,UAAsB;AACjD,KAAI,OAAO,aAAa,YACtB;AAEF,KAAI,SAAS,eAAe,WAAW;AACrC,WAAS,iBAAiB,0BAA0B,UAAU,EAAE,EAAE,MAAM,MAAM,CAAC;AAC/E;;AAEF,WAAU;;AAGZ,SAAS,kBAA2C;AAClD,KAAI,OAAO,aAAa,YACtB;AAEF,QAAQ,SAAS,cAAc,OAAO,IAA2B,SAAS;;AAG5E,SAAgB,gBACd,OACA,cACA,WACA;CACA,MAAM,SAAS,aAAa,IAAI,MAAM,GAAG;AACzC,KAAI,CAAC,OACH;AAEF,2BAA0B;EACxB,MAAM,YAAY,iBAAiB;AACnC,MAAI,CAAC,UACH;AAEF,SAAO,UAAU,WAAW,OAC1B,WAAU,YAAY,UAAU,WAAW,GAAI;EAEjD,MAAM,UAAU,SAAS,cAAc,OAAO,IAAI;AAClD,kBAAgB,SAAS;GACvB,IAAI,MAAM;GACV,OAAO,MAAM;GACb;GACD,CAAC;AACF,YAAU,OAAO,QAAQ;AACzB,YAAU,MAAM;GAChB"}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
//#region src/runtime/polyfill/routeRuntime/lifecycle.ts
|
|
2
|
+
const ROUTE_META_SYMBOL = Symbol("@weapp-vite/web:route-meta");
|
|
3
|
+
const PAGE_STATE_SYMBOL = Symbol("@weapp-vite/web:page-state");
|
|
4
|
+
function getRouteMeta(instance) {
|
|
5
|
+
return instance[ROUTE_META_SYMBOL];
|
|
6
|
+
}
|
|
7
|
+
function getPageState(instance) {
|
|
8
|
+
const target = instance;
|
|
9
|
+
target[PAGE_STATE_SYMBOL] ??= { loaded: false };
|
|
10
|
+
return target[PAGE_STATE_SYMBOL];
|
|
11
|
+
}
|
|
12
|
+
function walkElementsDeep(root, collector) {
|
|
13
|
+
const nodes = Array.from(root.childNodes ?? []);
|
|
14
|
+
for (const node of nodes) {
|
|
15
|
+
if (!(node instanceof HTMLElement)) continue;
|
|
16
|
+
collector.add(node);
|
|
17
|
+
walkElementsDeep(node, collector);
|
|
18
|
+
if (node.shadowRoot) walkElementsDeep(node.shadowRoot, collector);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
function dispatchPageLifetimeToComponents(page, type) {
|
|
22
|
+
const host = page;
|
|
23
|
+
const root = host.renderRoot ?? host.shadowRoot ?? host;
|
|
24
|
+
if (!root || typeof root.querySelectorAll !== "function") return;
|
|
25
|
+
const elements = /* @__PURE__ */ new Set();
|
|
26
|
+
walkElementsDeep(root, elements);
|
|
27
|
+
for (const element of elements) {
|
|
28
|
+
const component = element;
|
|
29
|
+
if (typeof component.__weappInvokePageLifetime === "function") component.__weappInvokePageLifetime(type);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
function attachRouteMeta(element, meta) {
|
|
33
|
+
element[ROUTE_META_SYMBOL] = meta;
|
|
34
|
+
}
|
|
35
|
+
function augmentPageComponentOptions(component, record) {
|
|
36
|
+
const lifetimes = component.lifetimes ?? {};
|
|
37
|
+
const originalCreated = lifetimes?.created;
|
|
38
|
+
const originalAttached = lifetimes?.attached;
|
|
39
|
+
const originalReady = lifetimes?.ready;
|
|
40
|
+
const originalDetached = lifetimes?.detached;
|
|
41
|
+
return {
|
|
42
|
+
...component,
|
|
43
|
+
lifetimes: {
|
|
44
|
+
...lifetimes,
|
|
45
|
+
created() {
|
|
46
|
+
originalCreated?.call(this);
|
|
47
|
+
getPageState(this);
|
|
48
|
+
record.instances.add(this);
|
|
49
|
+
},
|
|
50
|
+
attached() {
|
|
51
|
+
originalAttached?.call(this);
|
|
52
|
+
const meta = getRouteMeta(this);
|
|
53
|
+
if (meta?.entry) meta.entry.instance = this;
|
|
54
|
+
const state = getPageState(this);
|
|
55
|
+
if (!state.loaded) {
|
|
56
|
+
record.hooks.onLoad?.call(this, meta?.query ?? {});
|
|
57
|
+
state.loaded = true;
|
|
58
|
+
}
|
|
59
|
+
record.hooks.onShow?.call(this);
|
|
60
|
+
},
|
|
61
|
+
ready() {
|
|
62
|
+
originalReady?.call(this);
|
|
63
|
+
record.hooks.onReady?.call(this);
|
|
64
|
+
dispatchPageLifetimeToComponents(this, "show");
|
|
65
|
+
},
|
|
66
|
+
detached() {
|
|
67
|
+
originalDetached?.call(this);
|
|
68
|
+
const meta = getRouteMeta(this);
|
|
69
|
+
if (meta?.entry) meta.entry.instance = void 0;
|
|
70
|
+
dispatchPageLifetimeToComponents(this, "hide");
|
|
71
|
+
record.hooks.onHide?.call(this);
|
|
72
|
+
record.hooks.onUnload?.call(this);
|
|
73
|
+
const state = getPageState(this);
|
|
74
|
+
state.loaded = false;
|
|
75
|
+
record.instances.delete(this);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
//#endregion
|
|
82
|
+
export { attachRouteMeta, augmentPageComponentOptions, dispatchPageLifetimeToComponents };
|
|
83
|
+
//# sourceMappingURL=lifecycle.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lifecycle.mjs","names":[],"sources":["../../../../src/runtime/polyfill/routeRuntime/lifecycle.ts"],"sourcesContent":["import type { ComponentOptions, ComponentPublicInstance } from '../../component'\nimport type { PageRecord, RouteMeta } from './options'\n\nconst ROUTE_META_SYMBOL = Symbol('@weapp-vite/web:route-meta')\nconst PAGE_STATE_SYMBOL = Symbol('@weapp-vite/web:page-state')\n\ninterface RouteMetaCarrier {\n [ROUTE_META_SYMBOL]?: RouteMeta\n}\n\ninterface PageInstanceState {\n loaded: boolean\n}\n\ninterface PageStateCarrier {\n [PAGE_STATE_SYMBOL]?: PageInstanceState\n}\n\ntype ComponentPageLifetimeType = 'show' | 'hide' | 'resize'\n\ninterface PageLifetimeAwareComponent extends HTMLElement {\n __weappInvokePageLifetime?: (type: ComponentPageLifetimeType) => void\n renderRoot?: ShadowRoot | HTMLElement\n}\n\nfunction getRouteMeta(instance: ComponentPublicInstance): RouteMeta | undefined {\n return (instance as RouteMetaCarrier)[ROUTE_META_SYMBOL]\n}\n\nfunction getPageState(instance: ComponentPublicInstance): PageInstanceState {\n const target = instance as PageStateCarrier\n target[PAGE_STATE_SYMBOL] ??= { loaded: false }\n return target[PAGE_STATE_SYMBOL]!\n}\n\nfunction walkElementsDeep(root: ParentNode, collector: Set<HTMLElement>) {\n const nodes = Array.from((root as ParentNode & { childNodes?: ArrayLike<unknown> }).childNodes ?? [])\n for (const node of nodes) {\n if (!(node instanceof HTMLElement)) {\n continue\n }\n collector.add(node)\n walkElementsDeep(node, collector)\n if (node.shadowRoot) {\n walkElementsDeep(node.shadowRoot, collector)\n }\n }\n}\n\nexport function dispatchPageLifetimeToComponents(\n page: ComponentPublicInstance,\n type: ComponentPageLifetimeType,\n) {\n const host = page as ComponentPublicInstance & {\n renderRoot?: ShadowRoot | HTMLElement\n shadowRoot?: ShadowRoot | null\n }\n const root = host.renderRoot ?? host.shadowRoot ?? host\n if (!root || typeof root.querySelectorAll !== 'function') {\n return\n }\n const elements = new Set<HTMLElement>()\n walkElementsDeep(root, elements)\n for (const element of elements) {\n const component = element as PageLifetimeAwareComponent\n if (typeof component.__weappInvokePageLifetime === 'function') {\n component.__weappInvokePageLifetime(type)\n }\n }\n}\n\nexport function attachRouteMeta(\n element: HTMLElement & ComponentPublicInstance,\n meta: RouteMeta,\n) {\n (element as RouteMetaCarrier)[ROUTE_META_SYMBOL] = meta\n}\n\nexport function augmentPageComponentOptions(component: ComponentOptions, record: PageRecord) {\n const lifetimes = component.lifetimes ?? {}\n const originalCreated = lifetimes?.created\n const originalAttached = lifetimes?.attached\n const originalReady = lifetimes?.ready\n const originalDetached = lifetimes?.detached\n\n const enhanced: ComponentOptions = {\n ...component,\n lifetimes: {\n ...lifetimes,\n created(this: ComponentPublicInstance) {\n originalCreated?.call(this)\n getPageState(this)\n record.instances.add(this)\n },\n attached(this: ComponentPublicInstance) {\n originalAttached?.call(this)\n const meta = getRouteMeta(this)\n if (meta?.entry) {\n meta.entry.instance = this\n }\n const state = getPageState(this)\n if (!state.loaded) {\n record.hooks.onLoad?.call(this, meta?.query ?? {})\n state.loaded = true\n }\n record.hooks.onShow?.call(this)\n },\n ready(this: ComponentPublicInstance) {\n originalReady?.call(this)\n record.hooks.onReady?.call(this)\n dispatchPageLifetimeToComponents(this, 'show')\n },\n detached(this: ComponentPublicInstance) {\n originalDetached?.call(this)\n const meta = getRouteMeta(this)\n if (meta?.entry) {\n meta.entry.instance = undefined\n }\n dispatchPageLifetimeToComponents(this, 'hide')\n record.hooks.onHide?.call(this)\n record.hooks.onUnload?.call(this)\n const state = getPageState(this)\n state.loaded = false\n record.instances.delete(this)\n },\n },\n }\n\n return enhanced\n}\n"],"mappings":";AAGA,MAAM,oBAAoB,OAAO,6BAA6B;AAC9D,MAAM,oBAAoB,OAAO,6BAA6B;AAqB9D,SAAS,aAAa,UAA0D;AAC9E,QAAQ,SAA8B;;AAGxC,SAAS,aAAa,UAAsD;CAC1E,MAAM,SAAS;AACf,QAAO,uBAAuB,EAAE,QAAQ,OAAO;AAC/C,QAAO,OAAO;;AAGhB,SAAS,iBAAiB,MAAkB,WAA6B;CACvE,MAAM,QAAQ,MAAM,KAAM,KAA0D,cAAc,EAAE,CAAC;AACrG,MAAK,MAAM,QAAQ,OAAO;AACxB,MAAI,EAAE,gBAAgB,aACpB;AAEF,YAAU,IAAI,KAAK;AACnB,mBAAiB,MAAM,UAAU;AACjC,MAAI,KAAK,WACP,kBAAiB,KAAK,YAAY,UAAU;;;AAKlD,SAAgB,iCACd,MACA,MACA;CACA,MAAM,OAAO;CAIb,MAAM,OAAO,KAAK,cAAc,KAAK,cAAc;AACnD,KAAI,CAAC,QAAQ,OAAO,KAAK,qBAAqB,WAC5C;CAEF,MAAM,2BAAW,IAAI,KAAkB;AACvC,kBAAiB,MAAM,SAAS;AAChC,MAAK,MAAM,WAAW,UAAU;EAC9B,MAAM,YAAY;AAClB,MAAI,OAAO,UAAU,8BAA8B,WACjD,WAAU,0BAA0B,KAAK;;;AAK/C,SAAgB,gBACd,SACA,MACA;AACA,CAAC,QAA6B,qBAAqB;;AAGrD,SAAgB,4BAA4B,WAA6B,QAAoB;CAC3F,MAAM,YAAY,UAAU,aAAa,EAAE;CAC3C,MAAM,kBAAkB,WAAW;CACnC,MAAM,mBAAmB,WAAW;CACpC,MAAM,gBAAgB,WAAW;CACjC,MAAM,mBAAmB,WAAW;AA6CpC,QA3CmC;EACjC,GAAG;EACH,WAAW;GACT,GAAG;GACH,UAAuC;AACrC,qBAAiB,KAAK,KAAK;AAC3B,iBAAa,KAAK;AAClB,WAAO,UAAU,IAAI,KAAK;;GAE5B,WAAwC;AACtC,sBAAkB,KAAK,KAAK;IAC5B,MAAM,OAAO,aAAa,KAAK;AAC/B,QAAI,MAAM,MACR,MAAK,MAAM,WAAW;IAExB,MAAM,QAAQ,aAAa,KAAK;AAChC,QAAI,CAAC,MAAM,QAAQ;AACjB,YAAO,MAAM,QAAQ,KAAK,MAAM,MAAM,SAAS,EAAE,CAAC;AAClD,WAAM,SAAS;;AAEjB,WAAO,MAAM,QAAQ,KAAK,KAAK;;GAEjC,QAAqC;AACnC,mBAAe,KAAK,KAAK;AACzB,WAAO,MAAM,SAAS,KAAK,KAAK;AAChC,qCAAiC,MAAM,OAAO;;GAEhD,WAAwC;AACtC,sBAAkB,KAAK,KAAK;IAC5B,MAAM,OAAO,aAAa,KAAK;AAC/B,QAAI,MAAM,MACR,MAAK,MAAM,WAAW;AAExB,qCAAiC,MAAM,OAAO;AAC9C,WAAO,MAAM,QAAQ,KAAK,KAAK;AAC/B,WAAO,MAAM,UAAU,KAAK,KAAK;IACjC,MAAM,QAAQ,aAAa,KAAK;AAChC,UAAM,SAAS;AACf,WAAO,UAAU,OAAO,KAAK;;GAEhC;EACF"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { TemplateRenderer } from "../../template.mjs";
|
|
2
|
+
import { ComponentOptions, ComponentPublicInstance } from "../../component/types.mjs";
|
|
3
|
+
//#region src/runtime/polyfill/routeRuntime/options.d.ts
|
|
4
|
+
interface RegisterMeta {
|
|
5
|
+
id: string;
|
|
6
|
+
template?: TemplateRenderer;
|
|
7
|
+
style?: string;
|
|
8
|
+
}
|
|
9
|
+
interface PageHooks {
|
|
10
|
+
onLoad?: (this: ComponentPublicInstance, query: Record<string, string>) => void;
|
|
11
|
+
onReady?: (this: ComponentPublicInstance) => void;
|
|
12
|
+
onShow?: (this: ComponentPublicInstance) => void;
|
|
13
|
+
onHide?: (this: ComponentPublicInstance) => void;
|
|
14
|
+
onUnload?: (this: ComponentPublicInstance) => void;
|
|
15
|
+
}
|
|
16
|
+
interface AppLifecycleHooks {
|
|
17
|
+
onLaunch?: (this: AppRuntime, options: AppLaunchOptions) => void;
|
|
18
|
+
onShow?: (this: AppRuntime, options: AppLaunchOptions) => void;
|
|
19
|
+
}
|
|
20
|
+
type AppRuntime = Record<string, unknown> & Partial<AppLifecycleHooks> & {
|
|
21
|
+
globalData?: Record<string, unknown>;
|
|
22
|
+
};
|
|
23
|
+
interface AppLaunchOptions {
|
|
24
|
+
path: string;
|
|
25
|
+
scene: number;
|
|
26
|
+
query: Record<string, string>;
|
|
27
|
+
referrerInfo: Record<string, unknown>;
|
|
28
|
+
}
|
|
29
|
+
type PageRawOptions = ComponentOptions & PageHooks & Record<string, unknown>;
|
|
30
|
+
type ComponentRawOptions = ComponentOptions & Record<string, unknown>;
|
|
31
|
+
//#endregion
|
|
32
|
+
export { AppLaunchOptions, AppRuntime, ComponentRawOptions, PageRawOptions, RegisterMeta };
|
|
33
|
+
//# sourceMappingURL=options.d.mts.map
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
//#region src/runtime/polyfill/routeRuntime/options.ts
|
|
2
|
+
const RESERVED_PAGE_METHOD_KEYS = new Set([
|
|
3
|
+
"data",
|
|
4
|
+
"methods",
|
|
5
|
+
"lifetimes",
|
|
6
|
+
"properties",
|
|
7
|
+
"behaviors",
|
|
8
|
+
"options",
|
|
9
|
+
"observers",
|
|
10
|
+
"mixins",
|
|
11
|
+
...new Set([
|
|
12
|
+
"onLoad",
|
|
13
|
+
"onReady",
|
|
14
|
+
"onShow",
|
|
15
|
+
"onHide",
|
|
16
|
+
"onUnload"
|
|
17
|
+
])
|
|
18
|
+
]);
|
|
19
|
+
const RESERVED_COMPONENT_METHOD_KEYS = new Set([
|
|
20
|
+
"data",
|
|
21
|
+
"methods",
|
|
22
|
+
"lifetimes",
|
|
23
|
+
"pageLifetimes",
|
|
24
|
+
"properties",
|
|
25
|
+
"behaviors",
|
|
26
|
+
"options",
|
|
27
|
+
"observers",
|
|
28
|
+
"mixins"
|
|
29
|
+
]);
|
|
30
|
+
function cloneLifetimes(source) {
|
|
31
|
+
if (!source) return;
|
|
32
|
+
return { ...source };
|
|
33
|
+
}
|
|
34
|
+
function isRecord(value) {
|
|
35
|
+
return typeof value === "object" && value !== null;
|
|
36
|
+
}
|
|
37
|
+
function isMethodHandler(value) {
|
|
38
|
+
return typeof value === "function";
|
|
39
|
+
}
|
|
40
|
+
function normalizeMethodBag(source, reserved) {
|
|
41
|
+
const methods = {};
|
|
42
|
+
const sourceMethods = isRecord(source?.methods) ? source?.methods : void 0;
|
|
43
|
+
if (sourceMethods) {
|
|
44
|
+
for (const [key, value] of Object.entries(sourceMethods)) if (isMethodHandler(value)) methods[key] = value;
|
|
45
|
+
}
|
|
46
|
+
if (source) for (const [key, value] of Object.entries(source)) {
|
|
47
|
+
if (reserved.has(key)) continue;
|
|
48
|
+
if (isMethodHandler(value) && methods[key] === void 0) methods[key] = value;
|
|
49
|
+
}
|
|
50
|
+
return methods;
|
|
51
|
+
}
|
|
52
|
+
function normalizePageOptions(raw) {
|
|
53
|
+
const component = { ...raw ?? {} };
|
|
54
|
+
component.methods = normalizeMethodBag(raw, RESERVED_PAGE_METHOD_KEYS);
|
|
55
|
+
if (raw?.lifetimes) component.lifetimes = cloneLifetimes(raw.lifetimes);
|
|
56
|
+
const hooks = {};
|
|
57
|
+
if (typeof raw?.onLoad === "function") hooks.onLoad = raw.onLoad;
|
|
58
|
+
if (typeof raw?.onReady === "function") hooks.onReady = raw.onReady;
|
|
59
|
+
if (typeof raw?.onShow === "function") hooks.onShow = raw.onShow;
|
|
60
|
+
if (typeof raw?.onHide === "function") hooks.onHide = raw.onHide;
|
|
61
|
+
if (typeof raw?.onUnload === "function") hooks.onUnload = raw.onUnload;
|
|
62
|
+
return {
|
|
63
|
+
component,
|
|
64
|
+
hooks
|
|
65
|
+
};
|
|
66
|
+
}
|
|
67
|
+
function normalizeComponentOptions(raw) {
|
|
68
|
+
const component = { ...raw ?? {} };
|
|
69
|
+
component.methods = normalizeMethodBag(raw, RESERVED_COMPONENT_METHOD_KEYS);
|
|
70
|
+
if (raw?.lifetimes) component.lifetimes = cloneLifetimes(raw.lifetimes);
|
|
71
|
+
return component;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
//#endregion
|
|
75
|
+
export { isRecord, normalizeComponentOptions, normalizePageOptions };
|
|
76
|
+
//# sourceMappingURL=options.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"options.mjs","names":[],"sources":["../../../../src/runtime/polyfill/routeRuntime/options.ts"],"sourcesContent":["import type { ComponentOptions, ComponentPublicInstance } from '../../component'\nimport type { TemplateRenderer } from '../../template'\n\nexport interface RegisterMeta {\n id: string\n template?: TemplateRenderer\n style?: string\n}\n\nexport interface PageHooks {\n onLoad?: (this: ComponentPublicInstance, query: Record<string, string>) => void\n onReady?: (this: ComponentPublicInstance) => void\n onShow?: (this: ComponentPublicInstance) => void\n onHide?: (this: ComponentPublicInstance) => void\n onUnload?: (this: ComponentPublicInstance) => void\n}\n\nexport interface PageRecord {\n tag: string\n hooks: PageHooks\n instances: Set<ComponentPublicInstance>\n}\n\nexport interface ComponentRecord {\n tag: string\n}\n\nexport interface PageStackEntry {\n id: string\n query: Record<string, string>\n instance?: ComponentPublicInstance\n}\n\nexport interface RouteMeta {\n id: string\n query: Record<string, string>\n entry: PageStackEntry\n}\n\ninterface AppLifecycleHooks {\n onLaunch?: (this: AppRuntime, options: AppLaunchOptions) => void\n onShow?: (this: AppRuntime, options: AppLaunchOptions) => void\n}\n\nexport type AppRuntime = Record<string, unknown> & Partial<AppLifecycleHooks> & {\n globalData?: Record<string, unknown>\n}\n\nexport interface AppLaunchOptions {\n path: string\n scene: number\n query: Record<string, string>\n referrerInfo: Record<string, unknown>\n}\n\ntype MethodHandler = (this: ComponentPublicInstance, ...args: unknown[]) => unknown\n\nexport type PageRawOptions = ComponentOptions & PageHooks & Record<string, unknown>\nexport type ComponentRawOptions = ComponentOptions & Record<string, unknown>\n\nconst PAGE_LIFECYCLE_KEYS = new Set(['onLoad', 'onReady', 'onShow', 'onHide', 'onUnload'])\nconst RESERVED_PAGE_METHOD_KEYS = new Set([\n 'data',\n 'methods',\n 'lifetimes',\n 'properties',\n 'behaviors',\n 'options',\n 'observers',\n 'mixins',\n ...PAGE_LIFECYCLE_KEYS,\n])\nconst RESERVED_COMPONENT_METHOD_KEYS = new Set([\n 'data',\n 'methods',\n 'lifetimes',\n 'pageLifetimes',\n 'properties',\n 'behaviors',\n 'options',\n 'observers',\n 'mixins',\n])\n\nfunction cloneLifetimes(source?: ComponentOptions['lifetimes']): ComponentOptions['lifetimes'] {\n if (!source) {\n return undefined\n }\n return {\n ...source,\n }\n}\n\nexport function isRecord(value: unknown): value is Record<string, unknown> {\n return typeof value === 'object' && value !== null\n}\n\nfunction isMethodHandler(value: unknown): value is MethodHandler {\n return typeof value === 'function'\n}\n\nfunction normalizeMethodBag(\n source: Record<string, unknown> | undefined,\n reserved: Set<string>,\n) {\n const methods: Record<string, MethodHandler> = {}\n const sourceMethods = isRecord(source?.methods) ? source?.methods : undefined\n\n if (sourceMethods) {\n for (const [key, value] of Object.entries(sourceMethods)) {\n if (isMethodHandler(value)) {\n methods[key] = value\n }\n }\n }\n\n if (source) {\n for (const [key, value] of Object.entries(source)) {\n if (reserved.has(key)) {\n continue\n }\n if (isMethodHandler(value) && methods[key] === undefined) {\n methods[key] = value\n }\n }\n }\n return methods\n}\n\nexport function normalizePageOptions(raw: PageRawOptions | undefined): { component: ComponentOptions, hooks: PageHooks } {\n const component = { ...(raw ?? {}) } as ComponentOptions\n component.methods = normalizeMethodBag(raw as Record<string, unknown> | undefined, RESERVED_PAGE_METHOD_KEYS) as ComponentOptions['methods']\n if (raw?.lifetimes) {\n component.lifetimes = cloneLifetimes(raw.lifetimes)\n }\n const hooks: PageHooks = {}\n if (typeof raw?.onLoad === 'function') {\n hooks.onLoad = raw.onLoad as PageHooks['onLoad']\n }\n if (typeof raw?.onReady === 'function') {\n hooks.onReady = raw.onReady as PageHooks['onReady']\n }\n if (typeof raw?.onShow === 'function') {\n hooks.onShow = raw.onShow as PageHooks['onShow']\n }\n if (typeof raw?.onHide === 'function') {\n hooks.onHide = raw.onHide as PageHooks['onHide']\n }\n if (typeof raw?.onUnload === 'function') {\n hooks.onUnload = raw.onUnload as PageHooks['onUnload']\n }\n return { component, hooks }\n}\n\nexport function normalizeComponentOptions(raw: ComponentRawOptions | undefined): ComponentOptions {\n const component = { ...(raw ?? {}) } as ComponentOptions\n component.methods = normalizeMethodBag(raw as Record<string, unknown> | undefined, RESERVED_COMPONENT_METHOD_KEYS) as ComponentOptions['methods']\n if (raw?.lifetimes) {\n component.lifetimes = cloneLifetimes(raw.lifetimes)\n }\n return component\n}\n"],"mappings":";AA6DA,MAAM,4BAA4B,IAAI,IAAI;CACxC;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA,GAV0B,IAAI,IAAI;EAAC;EAAU;EAAW;EAAU;EAAU;EAAW,CAAC;CAWzF,CAAC;AACF,MAAM,iCAAiC,IAAI,IAAI;CAC7C;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACD,CAAC;AAEF,SAAS,eAAe,QAAuE;AAC7F,KAAI,CAAC,OACH;AAEF,QAAO,EACL,GAAG,QACJ;;AAGH,SAAgB,SAAS,OAAkD;AACzE,QAAO,OAAO,UAAU,YAAY,UAAU;;AAGhD,SAAS,gBAAgB,OAAwC;AAC/D,QAAO,OAAO,UAAU;;AAG1B,SAAS,mBACP,QACA,UACA;CACA,MAAM,UAAyC,EAAE;CACjD,MAAM,gBAAgB,SAAS,QAAQ,QAAQ,GAAG,QAAQ,UAAU;AAEpE,KAAI,eACF;OAAK,MAAM,CAAC,KAAK,UAAU,OAAO,QAAQ,cAAc,CACtD,KAAI,gBAAgB,MAAM,CACxB,SAAQ,OAAO;;AAKrB,KAAI,OACF,MAAK,MAAM,CAAC,KAAK,UAAU,OAAO,QAAQ,OAAO,EAAE;AACjD,MAAI,SAAS,IAAI,IAAI,CACnB;AAEF,MAAI,gBAAgB,MAAM,IAAI,QAAQ,SAAS,OAC7C,SAAQ,OAAO;;AAIrB,QAAO;;AAGT,SAAgB,qBAAqB,KAAoF;CACvH,MAAM,YAAY,EAAE,GAAI,OAAO,EAAE,EAAG;AACpC,WAAU,UAAU,mBAAmB,KAA4C,0BAA0B;AAC7G,KAAI,KAAK,UACP,WAAU,YAAY,eAAe,IAAI,UAAU;CAErD,MAAM,QAAmB,EAAE;AAC3B,KAAI,OAAO,KAAK,WAAW,WACzB,OAAM,SAAS,IAAI;AAErB,KAAI,OAAO,KAAK,YAAY,WAC1B,OAAM,UAAU,IAAI;AAEtB,KAAI,OAAO,KAAK,WAAW,WACzB,OAAM,SAAS,IAAI;AAErB,KAAI,OAAO,KAAK,WAAW,WACzB,OAAM,SAAS,IAAI;AAErB,KAAI,OAAO,KAAK,aAAa,WAC3B,OAAM,WAAW,IAAI;AAEvB,QAAO;EAAE;EAAW;EAAO;;AAG7B,SAAgB,0BAA0B,KAAwD;CAChG,MAAM,YAAY,EAAE,GAAI,OAAO,EAAE,EAAG;AACpC,WAAU,UAAU,mBAAmB,KAA4C,+BAA+B;AAClH,KAAI,KAAK,UACP,WAAU,YAAY,eAAe,IAAI,UAAU;AAErD,QAAO"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
//#region src/runtime/polyfill/routeRuntime/url.ts
|
|
2
|
+
const PAGE_TEMPLATE_EXTENSIONS = [
|
|
3
|
+
".wxml",
|
|
4
|
+
".axml",
|
|
5
|
+
".swan",
|
|
6
|
+
".ttml",
|
|
7
|
+
".qml",
|
|
8
|
+
".ksml",
|
|
9
|
+
".xhsml",
|
|
10
|
+
".html"
|
|
11
|
+
];
|
|
12
|
+
function stripTemplateExtension(id) {
|
|
13
|
+
const lowered = id.toLowerCase();
|
|
14
|
+
for (const ext of PAGE_TEMPLATE_EXTENSIONS) if (lowered.endsWith(ext)) return id.slice(0, -ext.length);
|
|
15
|
+
return id;
|
|
16
|
+
}
|
|
17
|
+
function parsePageId(raw) {
|
|
18
|
+
return stripTemplateExtension(raw.replace(/^\//, ""));
|
|
19
|
+
}
|
|
20
|
+
function parsePageUrl(url) {
|
|
21
|
+
const [path, search = ""] = url.split("?");
|
|
22
|
+
const query = {};
|
|
23
|
+
if (search) {
|
|
24
|
+
const params = new URLSearchParams(search);
|
|
25
|
+
for (const [key, value] of params.entries()) query[key] = value;
|
|
26
|
+
}
|
|
27
|
+
return {
|
|
28
|
+
id: parsePageId(path || ""),
|
|
29
|
+
query
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
//#endregion
|
|
34
|
+
export { parsePageUrl };
|
|
35
|
+
//# sourceMappingURL=url.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"url.mjs","names":[],"sources":["../../../../src/runtime/polyfill/routeRuntime/url.ts"],"sourcesContent":["import type { PageStackEntry } from './options'\n\nconst PAGE_TEMPLATE_EXTENSIONS = ['.wxml', '.axml', '.swan', '.ttml', '.qml', '.ksml', '.xhsml', '.html']\n\nfunction stripTemplateExtension(id: string) {\n const lowered = id.toLowerCase()\n for (const ext of PAGE_TEMPLATE_EXTENSIONS) {\n if (lowered.endsWith(ext)) {\n return id.slice(0, -ext.length)\n }\n }\n return id\n}\n\nfunction parsePageId(raw: string) {\n const normalized = raw.replace(/^\\//, '')\n return stripTemplateExtension(normalized)\n}\n\nexport function parsePageUrl(url: string): Pick<PageStackEntry, 'id' | 'query'> {\n const [path, search = ''] = url.split('?')\n const query: Record<string, string> = {}\n if (search) {\n const params = new URLSearchParams(search)\n for (const [key, value] of params.entries()) {\n query[key] = value\n }\n }\n return {\n id: parsePageId(path || ''),\n query,\n }\n}\n"],"mappings":";AAEA,MAAM,2BAA2B;CAAC;CAAS;CAAS;CAAS;CAAS;CAAQ;CAAS;CAAU;CAAQ;AAEzG,SAAS,uBAAuB,IAAY;CAC1C,MAAM,UAAU,GAAG,aAAa;AAChC,MAAK,MAAM,OAAO,yBAChB,KAAI,QAAQ,SAAS,IAAI,CACvB,QAAO,GAAG,MAAM,GAAG,CAAC,IAAI,OAAO;AAGnC,QAAO;;AAGT,SAAS,YAAY,KAAa;AAEhC,QAAO,uBADY,IAAI,QAAQ,OAAO,GAAG,CACA;;AAG3C,SAAgB,aAAa,KAAmD;CAC9E,MAAM,CAAC,MAAM,SAAS,MAAM,IAAI,MAAM,IAAI;CAC1C,MAAM,QAAgC,EAAE;AACxC,KAAI,QAAQ;EACV,MAAM,SAAS,IAAI,gBAAgB,OAAO;AAC1C,OAAK,MAAM,CAAC,KAAK,UAAU,OAAO,SAAS,CACzC,OAAM,OAAO;;AAGjB,QAAO;EACL,IAAI,YAAY,QAAQ,GAAG;EAC3B;EACD"}
|