import { createRequire } from "node:module"; import fs from "node:fs"; import { createFilter, formatPostcssSourceMap, isCSSRequest, normalizePath, transformWithEsbuild } from "vite"; import { computed, shallowRef } from "vue"; import { exactRegex, makeIdFiltersToMatchWithQuery } from "@rolldown/pluginutils"; import path from "node:path"; import crypto from "node:crypto"; //#region rolldown:runtime var __create = Object.create; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __getProtoOf = Object.getPrototypeOf; var __hasOwnProp = Object.prototype.hasOwnProperty; var __commonJS = (cb, mod) => function() { return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports; }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") for (var keys = __getOwnPropNames(from), i = 0, n = keys.length, key; i < n; i++) { key = keys[i]; if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: ((k) => from[k]).bind(null, key), enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod)); var __require = /* @__PURE__ */ createRequire(import.meta.url); //#endregion //#region package.json var version = "6.0.1"; //#endregion //#region src/compiler.ts function resolveCompiler(root) { const compiler = tryResolveCompiler(root) || tryResolveCompiler(); if (!compiler) throw new Error("Failed to resolve vue/compiler-sfc.\n@vitejs/plugin-vue requires vue (>=3.2.25) to be present in the dependency tree."); return compiler; } function tryResolveCompiler(root) { const vueMeta = tryRequire("vue/package.json", root); if (vueMeta && vueMeta.version.split(".")[0] >= 3) return tryRequire("vue/compiler-sfc", root); } const _require = createRequire(import.meta.url); function tryRequire(id, from) { try { return from ? _require(_require.resolve(id, { paths: [from] })) : _require(id); } catch (e) {} } //#endregion //#region src/utils/query.ts function parseVueRequest(id) { const [filename, rawQuery] = id.split(`?`, 2); const query = Object.fromEntries(new URLSearchParams(rawQuery)); if (query.vue != null) query.vue = true; if (query.index != null) query.index = Number(query.index); if (query.raw != null) query.raw = true; if (query.url != null) query.url = true; if (query.scoped != null) query.scoped = true; return { filename, query }; } //#endregion //#region src/utils/descriptorCache.ts const cache = /* @__PURE__ */ new Map(); const hmrCache = /* @__PURE__ */ new Map(); const prevCache = /* @__PURE__ */ new Map(); function createDescriptor(filename, source, { root, isProduction, sourceMap, compiler, template, features }, hmr = false) { const { descriptor, errors } = compiler.parse(source, { filename, sourceMap, templateParseOptions: template?.compilerOptions }); const normalizedPath = normalizePath(path.relative(root, filename)); const componentIdGenerator = features?.componentIdGenerator; if (componentIdGenerator === "filepath") descriptor.id = getHash(normalizedPath); else if (componentIdGenerator === "filepath-source") descriptor.id = getHash(normalizedPath + source); else if (typeof componentIdGenerator === "function") descriptor.id = componentIdGenerator(normalizedPath, source, isProduction, getHash); else descriptor.id = getHash(normalizedPath + (isProduction ? source : "")); (hmr ? hmrCache : cache).set(filename, descriptor); return { descriptor, errors }; } function getPrevDescriptor(filename) { return prevCache.get(filename); } function invalidateDescriptor(filename, hmr = false) { const _cache = hmr ? hmrCache : cache; const prev = _cache.get(filename); _cache.delete(filename); if (prev) prevCache.set(filename, prev); } function getDescriptor(filename, options, createIfNotFound = true, hmr = false, code) { const _cache = hmr ? hmrCache : cache; if (_cache.has(filename)) return _cache.get(filename); if (createIfNotFound) { const { descriptor, errors } = createDescriptor(filename, code ?? fs.readFileSync(filename, "utf-8"), options, hmr); if (errors.length && !hmr) throw errors[0]; return descriptor; } } function getSrcDescriptor(filename, query) { if (query.scoped) return cache.get(`${filename}?src=${query.src}`); return cache.get(filename); } function getTempSrcDescriptor(filename, query) { return { filename, id: query.id || "", styles: [{ scoped: query.scoped, loc: { start: { line: 0, column: 0 } } }], isTemp: true }; } function setSrcDescriptor(filename, entry, scoped) { if (scoped) { cache.set(`${filename}?src=${entry.id}`, entry); return; } cache.set(filename, entry); } function getHash(text) { return crypto.hash("sha256", text, "hex").substring(0, 8); } //#endregion //#region ../../node_modules/.pnpm/slash@5.1.0/node_modules/slash/index.js function slash(path$1) { const isExtendedLengthPath = path$1.startsWith("\\\\?\\"); if (isExtendedLengthPath) return path$1; return path$1.replace(/\\/g, "/"); } //#endregion //#region src/utils/error.ts function createRollupError(id, error) { const { message, name, stack } = error; const rollupError = { id, plugin: "vue", message, name, stack }; if ("code" in error && error.loc) rollupError.loc = { file: id, line: error.loc.start.line, column: error.loc.start.column }; return rollupError; } //#endregion //#region src/template.ts async function transformTemplateAsModule(code, filename, descriptor, options, pluginContext, ssr, customElement) { const result = compile(code, filename, descriptor, options, pluginContext, ssr, customElement); let returnCode = result.code; if (options.devServer && options.devServer.config.server.hmr !== false && !ssr && !options.isProduction) returnCode += `\nimport.meta.hot.accept(({ render }) => { __VUE_HMR_RUNTIME__.rerender(${JSON.stringify(descriptor.id)}, render) })`; return { code: returnCode, map: result.map }; } /** * transform the template directly in the main SFC module */ function transformTemplateInMain(code, descriptor, options, pluginContext, ssr, customElement) { const result = compile(code, descriptor.filename, descriptor, options, pluginContext, ssr, customElement); return { ...result, code: result.code.replace(/\nexport (function|const) (render|ssrRender)/, "\n$1 _sfc_$2") }; } function compile(code, filename, descriptor, options, pluginContext, ssr, customElement) { resolveScript(descriptor, options, ssr, customElement); const result = options.compiler.compileTemplate({ ...resolveTemplateCompilerOptions(descriptor, options, filename, ssr), source: code }); if (result.errors.length) result.errors.forEach((error) => pluginContext.error(typeof error === "string" ? { id: filename, message: error } : createRollupError(filename, error))); if (result.tips.length) result.tips.forEach((tip) => pluginContext.warn({ id: filename, message: tip })); return result; } function resolveTemplateCompilerOptions(descriptor, options, filename, ssr) { const block = descriptor.template; if (!block) return; const resolvedScript = getResolvedScript(descriptor, ssr); const hasScoped = descriptor.styles.some((s$1) => s$1.scoped); const { id, cssVars } = descriptor; let transformAssetUrls = options.template?.transformAssetUrls; let assetUrlOptions; if (transformAssetUrls === false) {} else if (options.devServer) { if (filename.startsWith(options.root)) { const devBase = options.devServer.config.base; assetUrlOptions = { base: (options.devServer.config.server?.origin ?? "") + devBase + slash(path.relative(options.root, path.dirname(filename))), includeAbsolute: !!devBase }; } } else assetUrlOptions = { includeAbsolute: true }; if (transformAssetUrls && typeof transformAssetUrls === "object") if (Object.values(transformAssetUrls).some((val) => Array.isArray(val))) transformAssetUrls = { ...assetUrlOptions, tags: transformAssetUrls }; else transformAssetUrls = { ...assetUrlOptions, ...transformAssetUrls }; else transformAssetUrls = assetUrlOptions; let preprocessOptions = block.lang && options.template?.preprocessOptions; if (block.lang === "pug") preprocessOptions = { doctype: "html", ...preprocessOptions }; const expressionPlugins = options.template?.compilerOptions?.expressionPlugins || []; const lang = descriptor.scriptSetup?.lang || descriptor.script?.lang; if (lang && /tsx?$/.test(lang) && !expressionPlugins.includes("typescript")) expressionPlugins.push("typescript"); return { ...options.template, vapor: descriptor.vapor, id, ast: canReuseAST(options.compiler.version) ? descriptor.template?.ast : void 0, filename, scoped: hasScoped, slotted: descriptor.slotted, isProd: options.isProduction, inMap: block.src ? void 0 : block.map, ssr, ssrCssVars: cssVars, transformAssetUrls, preprocessLang: block.lang === "html" ? void 0 : block.lang, preprocessOptions, compilerOptions: { ...options.template?.compilerOptions, scopeId: hasScoped ? `data-v-${id}` : void 0, bindingMetadata: resolvedScript ? resolvedScript.bindings : void 0, expressionPlugins, sourceMap: options.sourceMap } }; } /** * Versions before 3.4.3 have issues when the user has passed additional * template parse options e.g. `isCustomElement`. */ function canReuseAST(version$1) { if (version$1) { const [_, minor, patch] = version$1.split(".").map(Number); if (minor >= 4 && patch >= 3) return true; } return false; } //#endregion //#region src/script.ts let clientCache = /* @__PURE__ */ new WeakMap(); let ssrCache = /* @__PURE__ */ new WeakMap(); const typeDepToSFCMap = /* @__PURE__ */ new Map(); function invalidateScript(filename) { const desc = cache.get(filename); if (desc) { clientCache.delete(desc); ssrCache.delete(desc); } } function getResolvedScript(descriptor, ssr) { return (ssr ? ssrCache : clientCache).get(descriptor); } function setResolvedScript(descriptor, script, ssr) { (ssr ? ssrCache : clientCache).set(descriptor, script); } function clearScriptCache() { clientCache = /* @__PURE__ */ new WeakMap(); ssrCache = /* @__PURE__ */ new WeakMap(); } function isUseInlineTemplate(descriptor, options) { return !options.devServer && !options.devToolsEnabled && !!descriptor.scriptSetup && !descriptor.template?.src; } const scriptIdentifier = `_sfc_main`; function resolveScript(descriptor, options, ssr, customElement) { if (!descriptor.script && !descriptor.scriptSetup) return null; const cached = getResolvedScript(descriptor, ssr); if (cached) return cached; const resolved = options.compiler.compileScript(descriptor, { ...options.script, id: descriptor.id, isProd: options.isProduction, inlineTemplate: isUseInlineTemplate(descriptor, options), templateOptions: resolveTemplateCompilerOptions(descriptor, options, descriptor.filename, ssr), sourceMap: options.sourceMap, genDefaultAs: canInlineMain(descriptor, options) ? scriptIdentifier : void 0, customElement, propsDestructure: options.features?.propsDestructure ?? options.script?.propsDestructure }); if (!options.isProduction && resolved?.deps) { for (const [key, sfcs] of typeDepToSFCMap) if (sfcs.has(descriptor.filename) && !resolved.deps.includes(key)) sfcs.delete(descriptor.filename); for (const dep of resolved.deps) { const existingSet = typeDepToSFCMap.get(dep); if (!existingSet) typeDepToSFCMap.set(dep, new Set([descriptor.filename])); else existingSet.add(descriptor.filename); } } setResolvedScript(descriptor, resolved, ssr); return resolved; } function canInlineMain(descriptor, options) { if (descriptor.script?.src || descriptor.scriptSetup?.src) return false; const lang = descriptor.script?.lang || descriptor.scriptSetup?.lang; if (!lang || lang === "js") return true; if (lang === "ts" && options.devServer) return true; return false; } //#endregion //#region ../../node_modules/.pnpm/@jridgewell+sourcemap-codec@1.5.0/node_modules/@jridgewell/sourcemap-codec/dist/sourcemap-codec.mjs const comma = ",".charCodeAt(0); const semicolon = ";".charCodeAt(0); const chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; const intToChar = new Uint8Array(64); const charToInt = new Uint8Array(128); for (let i = 0; i < 64; i++) { const c = chars.charCodeAt(i); intToChar[i] = c; charToInt[c] = i; } function decodeInteger(reader, relative) { let value = 0; let shift = 0; let integer = 0; do { const c = reader.next(); integer = charToInt[c]; value |= (integer & 31) << shift; shift += 5; } while (integer & 32); const shouldNegate = value & 1; value >>>= 1; if (shouldNegate) value = -2147483648 | -value; return relative + value; } function encodeInteger(builder, num, relative) { let delta = num - relative; delta = delta < 0 ? -delta << 1 | 1 : delta << 1; do { let clamped = delta & 31; delta >>>= 5; if (delta > 0) clamped |= 32; builder.write(intToChar[clamped]); } while (delta > 0); return num; } function hasMoreVlq(reader, max) { if (reader.pos >= max) return false; return reader.peek() !== comma; } const bufLength = 1024 * 16; const td = typeof TextDecoder !== "undefined" ? /* @__PURE__ */ new TextDecoder() : typeof Buffer !== "undefined" ? { decode(buf) { const out = Buffer.from(buf.buffer, buf.byteOffset, buf.byteLength); return out.toString(); } } : { decode(buf) { let out = ""; for (let i = 0; i < buf.length; i++) out += String.fromCharCode(buf[i]); return out; } }; var StringWriter = class { constructor() { this.pos = 0; this.out = ""; this.buffer = new Uint8Array(bufLength); } write(v) { const { buffer } = this; buffer[this.pos++] = v; if (this.pos === bufLength) { this.out += td.decode(buffer); this.pos = 0; } } flush() { const { buffer, out, pos } = this; return pos > 0 ? out + td.decode(buffer.subarray(0, pos)) : out; } }; var StringReader = class { constructor(buffer) { this.pos = 0; this.buffer = buffer; } next() { return this.buffer.charCodeAt(this.pos++); } peek() { return this.buffer.charCodeAt(this.pos); } indexOf(char) { const { buffer, pos } = this; const idx = buffer.indexOf(char, pos); return idx === -1 ? buffer.length : idx; } }; function decode(mappings) { const { length } = mappings; const reader = new StringReader(mappings); const decoded = []; let genColumn = 0; let sourcesIndex = 0; let sourceLine = 0; let sourceColumn = 0; let namesIndex = 0; do { const semi = reader.indexOf(";"); const line = []; let sorted = true; let lastCol = 0; genColumn = 0; while (reader.pos < semi) { let seg; genColumn = decodeInteger(reader, genColumn); if (genColumn < lastCol) sorted = false; lastCol = genColumn; if (hasMoreVlq(reader, semi)) { sourcesIndex = decodeInteger(reader, sourcesIndex); sourceLine = decodeInteger(reader, sourceLine); sourceColumn = decodeInteger(reader, sourceColumn); if (hasMoreVlq(reader, semi)) { namesIndex = decodeInteger(reader, namesIndex); seg = [ genColumn, sourcesIndex, sourceLine, sourceColumn, namesIndex ]; } else seg = [ genColumn, sourcesIndex, sourceLine, sourceColumn ]; } else seg = [genColumn]; line.push(seg); reader.pos++; } if (!sorted) sort(line); decoded.push(line); reader.pos = semi + 1; } while (reader.pos <= length); return decoded; } function sort(line) { line.sort(sortComparator$1); } function sortComparator$1(a, b) { return a[0] - b[0]; } function encode(decoded) { const writer = new StringWriter(); let sourcesIndex = 0; let sourceLine = 0; let sourceColumn = 0; let namesIndex = 0; for (let i = 0; i < decoded.length; i++) { const line = decoded[i]; if (i > 0) writer.write(semicolon); if (line.length === 0) continue; let genColumn = 0; for (let j = 0; j < line.length; j++) { const segment = line[j]; if (j > 0) writer.write(comma); genColumn = encodeInteger(writer, segment[0], genColumn); if (segment.length === 1) continue; sourcesIndex = encodeInteger(writer, segment[1], sourcesIndex); sourceLine = encodeInteger(writer, segment[2], sourceLine); sourceColumn = encodeInteger(writer, segment[3], sourceColumn); if (segment.length === 4) continue; namesIndex = encodeInteger(writer, segment[4], namesIndex); } } return writer.flush(); } //#endregion //#region ../../node_modules/.pnpm/@jridgewell+resolve-uri@3.1.2/node_modules/@jridgewell/resolve-uri/dist/resolve-uri.mjs const schemeRegex = /^[\w+.-]+:\/\//; /** * Matches the parts of a URL: * 1. Scheme, including ":", guaranteed. * 2. User/password, including "@", optional. * 3. Host, guaranteed. * 4. Port, including ":", optional. * 5. Path, including "/", optional. * 6. Query, including "?", optional. * 7. Hash, including "#", optional. */ const urlRegex = /^([\w+.-]+:)\/\/([^@/#?]*@)?([^:/#?]*)(:\d+)?(\/[^#?]*)?(\?[^#]*)?(#.*)?/; /** * File URLs are weird. They dont' need the regular `//` in the scheme, they may or may not start * with a leading `/`, they can have a domain (but only if they don't start with a Windows drive). * * 1. Host, optional. * 2. Path, which may include "/", guaranteed. * 3. Query, including "?", optional. * 4. Hash, including "#", optional. */ const fileRegex = /^file:(?:\/\/((?![a-z]:)[^/#?]*)?)?(\/?[^#?]*)(\?[^#]*)?(#.*)?/i; function isAbsoluteUrl(input) { return schemeRegex.test(input); } function isSchemeRelativeUrl(input) { return input.startsWith("//"); } function isAbsolutePath(input) { return input.startsWith("/"); } function isFileUrl(input) { return input.startsWith("file:"); } function isRelative(input) { return /^[.?#]/.test(input); } function parseAbsoluteUrl(input) { const match = urlRegex.exec(input); return makeUrl(match[1], match[2] || "", match[3], match[4] || "", match[5] || "/", match[6] || "", match[7] || ""); } function parseFileUrl(input) { const match = fileRegex.exec(input); const path$1 = match[2]; return makeUrl("file:", "", match[1] || "", "", isAbsolutePath(path$1) ? path$1 : "/" + path$1, match[3] || "", match[4] || ""); } function makeUrl(scheme, user, host, port, path$1, query, hash) { return { scheme, user, host, port, path: path$1, query, hash, type: 7 }; } function parseUrl(input) { if (isSchemeRelativeUrl(input)) { const url$1 = parseAbsoluteUrl("http:" + input); url$1.scheme = ""; url$1.type = 6; return url$1; } if (isAbsolutePath(input)) { const url$1 = parseAbsoluteUrl("http://foo.com" + input); url$1.scheme = ""; url$1.host = ""; url$1.type = 5; return url$1; } if (isFileUrl(input)) return parseFileUrl(input); if (isAbsoluteUrl(input)) return parseAbsoluteUrl(input); const url = parseAbsoluteUrl("http://foo.com/" + input); url.scheme = ""; url.host = ""; url.type = input ? input.startsWith("?") ? 3 : input.startsWith("#") ? 2 : 4 : 1; return url; } function stripPathFilename(path$1) { if (path$1.endsWith("/..")) return path$1; const index = path$1.lastIndexOf("/"); return path$1.slice(0, index + 1); } function mergePaths(url, base) { normalizePath$1(base, base.type); if (url.path === "/") url.path = base.path; else url.path = stripPathFilename(base.path) + url.path; } /** * The path can have empty directories "//", unneeded parents "foo/..", or current directory * "foo/.". We need to normalize to a standard representation. */ function normalizePath$1(url, type) { const rel = type <= 4; const pieces = url.path.split("/"); let pointer = 1; let positive = 0; let addTrailingSlash = false; for (let i = 1; i < pieces.length; i++) { const piece = pieces[i]; if (!piece) { addTrailingSlash = true; continue; } addTrailingSlash = false; if (piece === ".") continue; if (piece === "..") { if (positive) { addTrailingSlash = true; positive--; pointer--; } else if (rel) pieces[pointer++] = piece; continue; } pieces[pointer++] = piece; positive++; } let path$1 = ""; for (let i = 1; i < pointer; i++) path$1 += "/" + pieces[i]; if (!path$1 || addTrailingSlash && !path$1.endsWith("/..")) path$1 += "/"; url.path = path$1; } /** * Attempts to resolve `input` URL/path relative to `base`. */ function resolve(input, base) { if (!input && !base) return ""; const url = parseUrl(input); let inputType = url.type; if (base && inputType !== 7) { const baseUrl = parseUrl(base); const baseType = baseUrl.type; switch (inputType) { case 1: url.hash = baseUrl.hash; case 2: url.query = baseUrl.query; case 3: case 4: mergePaths(url, baseUrl); case 5: url.user = baseUrl.user; url.host = baseUrl.host; url.port = baseUrl.port; case 6: url.scheme = baseUrl.scheme; } if (baseType > inputType) inputType = baseType; } normalizePath$1(url, inputType); const queryHash = url.query + url.hash; switch (inputType) { case 2: case 3: return queryHash; case 4: { const path$1 = url.path.slice(1); if (!path$1) return queryHash || "."; if (isRelative(base || input) && !isRelative(path$1)) return "./" + path$1 + queryHash; return path$1 + queryHash; } case 5: return url.path + queryHash; default: return url.scheme + "//" + url.user + url.host + url.port + url.path + queryHash; } } //#endregion //#region ../../node_modules/.pnpm/@jridgewell+trace-mapping@0.3.29/node_modules/@jridgewell/trace-mapping/dist/trace-mapping.mjs function stripFilename(path$1) { if (!path$1) return ""; const index = path$1.lastIndexOf("/"); return path$1.slice(0, index + 1); } function resolver(mapUrl, sourceRoot) { const from = stripFilename(mapUrl); const prefix = sourceRoot ? sourceRoot + "/" : ""; return (source) => resolve(prefix + (source || ""), from); } var COLUMN$1 = 0; function maybeSort(mappings, owned) { const unsortedIndex = nextUnsortedSegmentLine(mappings, 0); if (unsortedIndex === mappings.length) return mappings; if (!owned) mappings = mappings.slice(); for (let i = unsortedIndex; i < mappings.length; i = nextUnsortedSegmentLine(mappings, i + 1)) mappings[i] = sortSegments(mappings[i], owned); return mappings; } function nextUnsortedSegmentLine(mappings, start) { for (let i = start; i < mappings.length; i++) if (!isSorted(mappings[i])) return i; return mappings.length; } function isSorted(line) { for (let j = 1; j < line.length; j++) if (line[j][COLUMN$1] < line[j - 1][COLUMN$1]) return false; return true; } function sortSegments(line, owned) { if (!owned) line = line.slice(); return line.sort(sortComparator); } function sortComparator(a, b) { return a[COLUMN$1] - b[COLUMN$1]; } function memoizedState() { return { lastKey: -1, lastNeedle: -1, lastIndex: -1 }; } function parse$1(map) { return typeof map === "string" ? JSON.parse(map) : map; } var TraceMap = class { constructor(map, mapUrl) { const isString = typeof map === "string"; if (!isString && map._decodedMemo) return map; const parsed = parse$1(map); const { version: version$1, file, names, sourceRoot, sources, sourcesContent } = parsed; this.version = version$1; this.file = file; this.names = names || []; this.sourceRoot = sourceRoot; this.sources = sources; this.sourcesContent = sourcesContent; this.ignoreList = parsed.ignoreList || parsed.x_google_ignoreList || void 0; const resolve$1 = resolver(mapUrl, sourceRoot); this.resolvedSources = sources.map(resolve$1); const { mappings } = parsed; if (typeof mappings === "string") { this._encoded = mappings; this._decoded = void 0; } else if (Array.isArray(mappings)) { this._encoded = void 0; this._decoded = maybeSort(mappings, isString); } else if (parsed.sections) throw new Error(`TraceMap passed sectioned source map, please use FlattenMap export instead`); else throw new Error(`invalid source map: ${JSON.stringify(parsed)}`); this._decodedMemo = memoizedState(); this._bySources = void 0; this._bySourceMemos = void 0; } }; function cast$1(map) { return map; } function decodedMappings(map) { var _a; return (_a = cast$1(map))._decoded || (_a._decoded = decode(cast$1(map)._encoded)); } function eachMapping(map, cb) { const decoded = decodedMappings(map); const { names, resolvedSources } = map; for (let i = 0; i < decoded.length; i++) { const line = decoded[i]; for (let j = 0; j < line.length; j++) { const seg = line[j]; const generatedLine = i + 1; const generatedColumn = seg[0]; let source = null; let originalLine = null; let originalColumn = null; let name = null; if (seg.length !== 1) { source = resolvedSources[seg[1]]; originalLine = seg[2] + 1; originalColumn = seg[3]; } if (seg.length === 5) name = names[seg[4]]; cb({ generatedLine, generatedColumn, source, originalLine, originalColumn, name }); } } } //#endregion //#region ../../node_modules/.pnpm/@jridgewell+gen-mapping@0.3.12/node_modules/@jridgewell/gen-mapping/dist/gen-mapping.mjs var SetArray = class { constructor() { this._indexes = { __proto__: null }; this.array = []; } }; function cast(set) { return set; } function get(setarr, key) { return cast(setarr)._indexes[key]; } function put(setarr, key) { const index = get(setarr, key); if (index !== void 0) return index; const { array, _indexes: indexes } = cast(setarr); const length = array.push(key); return indexes[key] = length - 1; } var COLUMN = 0; var SOURCES_INDEX = 1; var SOURCE_LINE = 2; var SOURCE_COLUMN = 3; var NAMES_INDEX = 4; var NO_NAME = -1; var GenMapping = class { constructor({ file, sourceRoot } = {}) { this._names = new SetArray(); this._sources = new SetArray(); this._sourcesContent = []; this._mappings = []; this.file = file; this.sourceRoot = sourceRoot; this._ignoreList = new SetArray(); } }; function cast2(map) { return map; } function addMapping(map, mapping) { return addMappingInternal(false, map, mapping); } function toDecodedMap(map) { const { _mappings: mappings, _sources: sources, _sourcesContent: sourcesContent, _names: names, _ignoreList: ignoreList$1 } = cast2(map); removeEmptyFinalLines(mappings); return { version: 3, file: map.file || void 0, names: names.array, sourceRoot: map.sourceRoot || void 0, sources: sources.array, sourcesContent, mappings, ignoreList: ignoreList$1.array }; } function toEncodedMap(map) { const decoded = toDecodedMap(map); return Object.assign({}, decoded, { mappings: encode(decoded.mappings) }); } function fromMap(input) { const map = new TraceMap(input); const gen = new GenMapping({ file: map.file, sourceRoot: map.sourceRoot }); putAll(cast2(gen)._names, map.names); putAll(cast2(gen)._sources, map.sources); cast2(gen)._sourcesContent = map.sourcesContent || map.sources.map(() => null); cast2(gen)._mappings = decodedMappings(map); if (map.ignoreList) putAll(cast2(gen)._ignoreList, map.ignoreList); return gen; } function addSegmentInternal(skipable, map, genLine, genColumn, source, sourceLine, sourceColumn, name, content) { const { _mappings: mappings, _sources: sources, _sourcesContent: sourcesContent, _names: names } = cast2(map); const line = getIndex(mappings, genLine); const index = getColumnIndex(line, genColumn); if (!source) { if (skipable && skipSourceless(line, index)) return; return insert(line, index, [genColumn]); } assert(sourceLine); assert(sourceColumn); const sourcesIndex = put(sources, source); const namesIndex = name ? put(names, name) : NO_NAME; if (sourcesIndex === sourcesContent.length) sourcesContent[sourcesIndex] = content != null ? content : null; if (skipable && skipSource(line, index, sourcesIndex, sourceLine, sourceColumn, namesIndex)) return; return insert(line, index, name ? [ genColumn, sourcesIndex, sourceLine, sourceColumn, namesIndex ] : [ genColumn, sourcesIndex, sourceLine, sourceColumn ]); } function assert(_val) {} function getIndex(arr, index) { for (let i = arr.length; i <= index; i++) arr[i] = []; return arr[index]; } function getColumnIndex(line, genColumn) { let index = line.length; for (let i = index - 1; i >= 0; index = i--) { const current = line[i]; if (genColumn >= current[COLUMN]) break; } return index; } function insert(array, index, value) { for (let i = array.length; i > index; i--) array[i] = array[i - 1]; array[index] = value; } function removeEmptyFinalLines(mappings) { const { length } = mappings; let len = length; for (let i = len - 1; i >= 0; len = i, i--) if (mappings[i].length > 0) break; if (len < length) mappings.length = len; } function putAll(setarr, array) { for (let i = 0; i < array.length; i++) put(setarr, array[i]); } function skipSourceless(line, index) { if (index === 0) return true; const prev = line[index - 1]; return prev.length === 1; } function skipSource(line, index, sourcesIndex, sourceLine, sourceColumn, namesIndex) { if (index === 0) return false; const prev = line[index - 1]; if (prev.length === 1) return false; return sourcesIndex === prev[SOURCES_INDEX] && sourceLine === prev[SOURCE_LINE] && sourceColumn === prev[SOURCE_COLUMN] && namesIndex === (prev.length === 5 ? prev[NAMES_INDEX] : NO_NAME); } function addMappingInternal(skipable, map, mapping) { const { generated, source, original, name, content } = mapping; if (!source) return addSegmentInternal(skipable, map, generated.line - 1, generated.column, null, null, null, null, null); assert(original); return addSegmentInternal(skipable, map, generated.line - 1, generated.column, source, original.line - 1, original.column, name, content); } //#endregion //#region ../../node_modules/.pnpm/ms@2.1.3/node_modules/ms/index.js var require_ms = __commonJS({ "../../node_modules/.pnpm/ms@2.1.3/node_modules/ms/index.js"(exports, module) { /** * Helpers. */ var s = 1e3; var m = s * 60; var h = m * 60; var d = h * 24; var w = d * 7; var y = d * 365.25; /** * Parse or format the given `val`. * * Options: * * - `long` verbose formatting [false] * * @param {String|Number} val * @param {Object} [options] * @throws {Error} throw an error if val is not a non-empty string or a number * @return {String|Number} * @api public */ module.exports = function(val, options) { options = options || {}; var type = typeof val; if (type === "string" && val.length > 0) return parse(val); else if (type === "number" && isFinite(val)) return options.long ? fmtLong(val) : fmtShort(val); throw new Error("val is not a non-empty string or a valid number. val=" + JSON.stringify(val)); }; /** * Parse the given `str` and return milliseconds. * * @param {String} str * @return {Number} * @api private */ function parse(str) { str = String(str); if (str.length > 100) return; var match = /^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(str); if (!match) return; var n = parseFloat(match[1]); var type = (match[2] || "ms").toLowerCase(); switch (type) { case "years": case "year": case "yrs": case "yr": case "y": return n * y; case "weeks": case "week": case "w": return n * w; case "days": case "day": case "d": return n * d; case "hours": case "hour": case "hrs": case "hr": case "h": return n * h; case "minutes": case "minute": case "mins": case "min": case "m": return n * m; case "seconds": case "second": case "secs": case "sec": case "s": return n * s; case "milliseconds": case "millisecond": case "msecs": case "msec": case "ms": return n; default: return void 0; } } /** * Short format for `ms`. * * @param {Number} ms * @return {String} * @api private */ function fmtShort(ms) { var msAbs = Math.abs(ms); if (msAbs >= d) return Math.round(ms / d) + "d"; if (msAbs >= h) return Math.round(ms / h) + "h"; if (msAbs >= m) return Math.round(ms / m) + "m"; if (msAbs >= s) return Math.round(ms / s) + "s"; return ms + "ms"; } /** * Long format for `ms`. * * @param {Number} ms * @return {String} * @api private */ function fmtLong(ms) { var msAbs = Math.abs(ms); if (msAbs >= d) return plural(ms, msAbs, d, "day"); if (msAbs >= h) return plural(ms, msAbs, h, "hour"); if (msAbs >= m) return plural(ms, msAbs, m, "minute"); if (msAbs >= s) return plural(ms, msAbs, s, "second"); return ms + " ms"; } /** * Pluralization helper. */ function plural(ms, msAbs, n, name) { var isPlural = msAbs >= n * 1.5; return Math.round(ms / n) + " " + name + (isPlural ? "s" : ""); } } }); //#endregion //#region ../../node_modules/.pnpm/debug@4.4.1/node_modules/debug/src/common.js var require_common = __commonJS({ "../../node_modules/.pnpm/debug@4.4.1/node_modules/debug/src/common.js"(exports, module) { /** * This is the common logic for both the Node.js and web browser * implementations of `debug()`. */ function setup(env) { createDebug.debug = createDebug; createDebug.default = createDebug; createDebug.coerce = coerce; createDebug.disable = disable; createDebug.enable = enable; createDebug.enabled = enabled; createDebug.humanize = require_ms(); createDebug.destroy = destroy; Object.keys(env).forEach((key) => { createDebug[key] = env[key]; }); /** * The currently active debug mode names, and names to skip. */ createDebug.names = []; createDebug.skips = []; /** * Map of special "%n" handling functions, for the debug "format" argument. * * Valid key names are a single, lower or upper-case letter, i.e. "n" and "N". */ createDebug.formatters = {}; /** * Selects a color for a debug namespace * @param {String} namespace The namespace string for the debug instance to be colored * @return {Number|String} An ANSI color code for the given namespace * @api private */ function selectColor(namespace) { let hash = 0; for (let i = 0; i < namespace.length; i++) { hash = (hash << 5) - hash + namespace.charCodeAt(i); hash |= 0; } return createDebug.colors[Math.abs(hash) % createDebug.colors.length]; } createDebug.selectColor = selectColor; /** * Create a debugger with the given `namespace`. * * @param {String} namespace * @return {Function} * @api public */ function createDebug(namespace) { let prevTime; let enableOverride = null; let namespacesCache; let enabledCache; function debug$1(...args) { if (!debug$1.enabled) return; const self = debug$1; const curr = Number(/* @__PURE__ */ new Date()); const ms = curr - (prevTime || curr); self.diff = ms; self.prev = prevTime; self.curr = curr; prevTime = curr; args[0] = createDebug.coerce(args[0]); if (typeof args[0] !== "string") args.unshift("%O"); let index = 0; args[0] = args[0].replace(/%([a-zA-Z%])/g, (match, format) => { if (match === "%%") return "%"; index++; const formatter = createDebug.formatters[format]; if (typeof formatter === "function") { const val = args[index]; match = formatter.call(self, val); args.splice(index, 1); index--; } return match; }); createDebug.formatArgs.call(self, args); const logFn = self.log || createDebug.log; logFn.apply(self, args); } debug$1.namespace = namespace; debug$1.useColors = createDebug.useColors(); debug$1.color = createDebug.selectColor(namespace); debug$1.extend = extend; debug$1.destroy = createDebug.destroy; Object.defineProperty(debug$1, "enabled", { enumerable: true, configurable: false, get: () => { if (enableOverride !== null) return enableOverride; if (namespacesCache !== createDebug.namespaces) { namespacesCache = createDebug.namespaces; enabledCache = createDebug.enabled(namespace); } return enabledCache; }, set: (v) => { enableOverride = v; } }); if (typeof createDebug.init === "function") createDebug.init(debug$1); return debug$1; } function extend(namespace, delimiter) { const newDebug = createDebug(this.namespace + (typeof delimiter === "undefined" ? ":" : delimiter) + namespace); newDebug.log = this.log; return newDebug; } /** * Enables a debug mode by namespaces. This can include modes * separated by a colon and wildcards. * * @param {String} namespaces * @api public */ function enable(namespaces) { createDebug.save(namespaces); createDebug.namespaces = namespaces; createDebug.names = []; createDebug.skips = []; const split = (typeof namespaces === "string" ? namespaces : "").trim().replace(/\s+/g, ",").split(",").filter(Boolean); for (const ns of split) if (ns[0] === "-") createDebug.skips.push(ns.slice(1)); else createDebug.names.push(ns); } /** * Checks if the given string matches a namespace template, honoring * asterisks as wildcards. * * @param {String} search * @param {String} template * @return {Boolean} */ function matchesTemplate(search, template) { let searchIndex = 0; let templateIndex = 0; let starIndex = -1; let matchIndex = 0; while (searchIndex < search.length) if (templateIndex < template.length && (template[templateIndex] === search[searchIndex] || template[templateIndex] === "*")) if (template[templateIndex] === "*") { starIndex = templateIndex; matchIndex = searchIndex; templateIndex++; } else { searchIndex++; templateIndex++; } else if (starIndex !== -1) { templateIndex = starIndex + 1; matchIndex++; searchIndex = matchIndex; } else return false; while (templateIndex < template.length && template[templateIndex] === "*") templateIndex++; return templateIndex === template.length; } /** * Disable debug output. * * @return {String} namespaces * @api public */ function disable() { const namespaces = [...createDebug.names, ...createDebug.skips.map((namespace) => "-" + namespace)].join(","); createDebug.enable(""); return namespaces; } /** * Returns true if the given mode name is enabled, false otherwise. * * @param {String} name * @return {Boolean} * @api public */ function enabled(name) { for (const skip of createDebug.skips) if (matchesTemplate(name, skip)) return false; for (const ns of createDebug.names) if (matchesTemplate(name, ns)) return true; return false; } /** * Coerce `val`. * * @param {Mixed} val * @return {Mixed} * @api private */ function coerce(val) { if (val instanceof Error) return val.stack || val.message; return val; } /** * XXX DO NOT USE. This is a temporary stub function. * XXX It WILL be removed in the next major release. */ function destroy() { console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."); } createDebug.enable(createDebug.load()); return createDebug; } module.exports = setup; } }); //#endregion //#region ../../node_modules/.pnpm/debug@4.4.1/node_modules/debug/src/node.js var require_node = __commonJS({ "../../node_modules/.pnpm/debug@4.4.1/node_modules/debug/src/node.js"(exports, module) { /** * Module dependencies. */ const tty = __require("tty"); const util = __require("util"); /** * This is the Node.js implementation of `debug()`. */ exports.init = init; exports.log = log; exports.formatArgs = formatArgs; exports.save = save; exports.load = load; exports.useColors = useColors; exports.destroy = util.deprecate(() => {}, "Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."); /** * Colors. */ exports.colors = [ 6, 2, 3, 4, 5, 1 ]; try { const supportsColor = __require("supports-color"); if (supportsColor && (supportsColor.stderr || supportsColor).level >= 2) exports.colors = [ 20, 21, 26, 27, 32, 33, 38, 39, 40, 41, 42, 43, 44, 45, 56, 57, 62, 63, 68, 69, 74, 75, 76, 77, 78, 79, 80, 81, 92, 93, 98, 99, 112, 113, 128, 129, 134, 135, 148, 149, 160, 161, 162, 163, 164, 165, 166, 167, 168, 169, 170, 171, 172, 173, 178, 179, 184, 185, 196, 197, 198, 199, 200, 201, 202, 203, 204, 205, 206, 207, 208, 209, 214, 215, 220, 221 ]; } catch (error) {} /** * Build up the default `inspectOpts` object from the environment variables. * * $ DEBUG_COLORS=no DEBUG_DEPTH=10 DEBUG_SHOW_HIDDEN=enabled node script.js */ exports.inspectOpts = Object.keys(process.env).filter((key) => { return /^debug_/i.test(key); }).reduce((obj, key) => { const prop = key.substring(6).toLowerCase().replace(/_([a-z])/g, (_, k) => { return k.toUpperCase(); }); let val = process.env[key]; if (/^(yes|on|true|enabled)$/i.test(val)) val = true; else if (/^(no|off|false|disabled)$/i.test(val)) val = false; else if (val === "null") val = null; else val = Number(val); obj[prop] = val; return obj; }, {}); /** * Is stdout a TTY? Colored output is enabled when `true`. */ function useColors() { return "colors" in exports.inspectOpts ? Boolean(exports.inspectOpts.colors) : tty.isatty(process.stderr.fd); } /** * Adds ANSI color escape codes if enabled. * * @api public */ function formatArgs(args) { const { namespace: name, useColors: useColors$1 } = this; if (useColors$1) { const c = this.color; const colorCode = "\x1B[3" + (c < 8 ? c : "8;5;" + c); const prefix = ` ${colorCode};1m${name} \u001B[0m`; args[0] = prefix + args[0].split("\n").join("\n" + prefix); args.push(colorCode + "m+" + module.exports.humanize(this.diff) + "\x1B[0m"); } else args[0] = getDate() + name + " " + args[0]; } function getDate() { if (exports.inspectOpts.hideDate) return ""; return (/* @__PURE__ */ new Date()).toISOString() + " "; } /** * Invokes `util.formatWithOptions()` with the specified arguments and writes to stderr. */ function log(...args) { return process.stderr.write(util.formatWithOptions(exports.inspectOpts, ...args) + "\n"); } /** * Save `namespaces`. * * @param {String} namespaces * @api private */ function save(namespaces) { if (namespaces) process.env.DEBUG = namespaces; else delete process.env.DEBUG; } /** * Load `namespaces`. * * @return {String} returns the previously persisted debug modes * @api private */ function load() { return process.env.DEBUG; } /** * Init logic for `debug` instances. * * Create a new `inspectOpts` object in case `useColors` is set * differently for a particular `debug` instance. */ function init(debug$1) { debug$1.inspectOpts = {}; const keys = Object.keys(exports.inspectOpts); for (let i = 0; i < keys.length; i++) debug$1.inspectOpts[keys[i]] = exports.inspectOpts[keys[i]]; } module.exports = require_common()(exports); const { formatters } = module.exports; /** * Map %o to `util.inspect()`, all on a single line. */ formatters.o = function(v) { this.inspectOpts.colors = this.useColors; return util.inspect(v, this.inspectOpts).split("\n").map((str) => str.trim()).join(" "); }; /** * Map %O to `util.inspect()`, allowing multiple lines if needed. */ formatters.O = function(v) { this.inspectOpts.colors = this.useColors; return util.inspect(v, this.inspectOpts); }; } }); //#endregion //#region src/handleHotUpdate.ts var import_node = __toESM(require_node(), 1); const debug = (0, import_node.default)("vite:hmr"); const directRequestRE = /(?:\?|&)direct\b/; /** * Vite-specific HMR handling */ async function handleHotUpdate({ file, modules, read }, options, customElement, typeDepModules) { const prevDescriptor = getDescriptor(file, options, false, true); if (!prevDescriptor) return; const content = await read(); const { descriptor } = createDescriptor(file, content, options, true); let needRerender = false; const affectedModules = new Set(modules.filter((mod) => mod.type !== "js")); const mainModule = getMainModule(modules); const templateModule = modules.find((m$1) => /type=template/.test(m$1.url)); resolveScript(descriptor, options, false, customElement); const scriptChanged = hasScriptChanged(prevDescriptor, descriptor); if (scriptChanged) affectedModules.add(getScriptModule(modules) || mainModule); if (!isEqualBlock(descriptor.template, prevDescriptor.template)) { if (!scriptChanged) setResolvedScript(descriptor, getResolvedScript(prevDescriptor, false), false); affectedModules.add(templateModule); needRerender = true; } let didUpdateStyle = false; const prevStyles = prevDescriptor.styles || []; const nextStyles = descriptor.styles || []; if (prevDescriptor.cssVars.join("") !== descriptor.cssVars.join("")) affectedModules.add(mainModule); if (prevStyles.some((s$1) => s$1.scoped) !== nextStyles.some((s$1) => s$1.scoped)) { affectedModules.add(templateModule); affectedModules.add(mainModule); } for (let i = 0; i < nextStyles.length; i++) { const prev = prevStyles[i]; const next = nextStyles[i]; if (!prev || !isEqualBlock(prev, next)) { didUpdateStyle = true; const mod = modules.find((m$1) => m$1.url.includes(`type=style&index=${i}`) && m$1.url.endsWith(`.${next.lang || "css"}`) && !directRequestRE.test(m$1.url)); if (mod) { affectedModules.add(mod); if (mod.url.includes("&inline")) affectedModules.add(mainModule); } else affectedModules.add(mainModule); } } if (prevStyles.length > nextStyles.length) affectedModules.add(mainModule); const prevCustoms = prevDescriptor.customBlocks || []; const nextCustoms = descriptor.customBlocks || []; if (prevCustoms.length !== nextCustoms.length) affectedModules.add(mainModule); else for (let i = 0; i < nextCustoms.length; i++) { const prev = prevCustoms[i]; const next = nextCustoms[i]; if (!prev || !isEqualBlock(prev, next)) { const mod = modules.find((m$1) => m$1.url.includes(`type=${prev.type}&index=${i}`)); if (mod) affectedModules.add(mod); else affectedModules.add(mainModule); } } const updateType = []; if (needRerender) { updateType.push(`template`); if (!templateModule) affectedModules.add(mainModule); else if (mainModule && !affectedModules.has(mainModule)) { const styleImporters = [...mainModule.importers].filter((m$1) => isCSSRequest(m$1.url)); styleImporters.forEach((m$1) => affectedModules.add(m$1)); } } if (didUpdateStyle) updateType.push(`style`); if (updateType.length) { if (file.endsWith(".vue")) invalidateDescriptor(file); else cache.set(file, descriptor); debug(`[vue:update(${updateType.join("&")})] ${file}`); } return [...affectedModules, ...typeDepModules || []].filter(Boolean); } function isEqualBlock(a, b) { if (!a && !b) return true; if (!a || !b) return false; if (a.src && b.src && a.src === b.src) return true; if (a.content !== b.content) return false; const keysA = Object.keys(a.attrs); const keysB = Object.keys(b.attrs); if (keysA.length !== keysB.length) return false; return keysA.every((key) => a.attrs[key] === b.attrs[key]); } function isOnlyTemplateChanged(prev, next) { return !hasScriptChanged(prev, next) && prev.styles.length === next.styles.length && prev.styles.every((s$1, i) => isEqualBlock(s$1, next.styles[i])) && prev.customBlocks.length === next.customBlocks.length && prev.customBlocks.every((s$1, i) => isEqualBlock(s$1, next.customBlocks[i])); } function deepEqual(obj1, obj2, excludeProps = [], deepParentsOfObj1 = []) { if (typeof obj1 !== typeof obj2) return false; if (obj1 == null || obj2 == null || typeof obj1 !== "object" || deepParentsOfObj1.includes(obj1)) return obj1 === obj2; const keys1 = Object.keys(obj1); const keys2 = Object.keys(obj2); if (keys1.length !== keys2.length) return false; for (const key of keys1) { if (excludeProps.includes(key)) continue; if (!deepEqual(obj1[key], obj2[key], excludeProps, [...deepParentsOfObj1, obj1])) return false; } return true; } function isEqualAst(prev, next) { if (typeof prev === "undefined" || typeof next === "undefined") return prev === next; if (prev.length !== next.length) return false; for (let i = 0; i < prev.length; i++) { const prevNode = prev[i]; const nextNode = next[i]; if (!deepEqual(prevNode, nextNode, [ "start", "end", "loc", "range", "leadingComments", "trailingComments", "innerComments", "_ownerScope", "_resolvedReference", "_resolvedElements" ])) return false; } return true; } function hasScriptChanged(prev, next) { const prevScript = getResolvedScript(prev, false); const nextScript = getResolvedScript(next, false); if (!isEqualBlock(prev.script, next.script) && !isEqualAst(prevScript?.scriptAst, nextScript?.scriptAst)) return true; if (!isEqualBlock(prev.scriptSetup, next.scriptSetup) && !isEqualAst(prevScript?.scriptSetupAst, nextScript?.scriptSetupAst)) return true; const prevResolvedScript = getResolvedScript(prev, false); const prevImports = prevResolvedScript?.imports; if (prevImports) return !next.template || next.shouldForceReload(prevImports); return false; } function getMainModule(modules) { return modules.filter((m$1) => !/type=/.test(m$1.url) || /type=script/.test(m$1.url)).sort((m1, m2) => { return m1.url.length - m2.url.length; })[0]; } function getScriptModule(modules) { return modules.find((m$1) => /type=script.*&lang\.\w+$/.test(m$1.url)); } function handleTypeDepChange(affectedComponents, { modules, server: { moduleGraph } }) { const affected = /* @__PURE__ */ new Set(); for (const file of affectedComponents) { invalidateScript(file); const mods = moduleGraph.getModulesByFile(file); if (mods) { const arr = [...mods]; affected.add(getScriptModule(arr) || getMainModule(arr)); } } return [...modules, ...affected]; } //#endregion //#region src/helper.ts const EXPORT_HELPER_ID = "\0plugin-vue:export-helper"; const helperCode = ` export default (sfc, props) => { const target = sfc.__vccOpts || sfc; for (const [key, val] of props) { target[key] = val; } return target; } `; //#endregion //#region src/main.ts async function transformMain(code, filename, options, pluginContext, ssr, customElement) { const { devServer, isProduction, devToolsEnabled } = options; const prevDescriptor = getPrevDescriptor(filename); const { descriptor, errors } = createDescriptor(filename, code, options); if (fs.existsSync(filename)) getDescriptor(filename, options, true, true, filename.endsWith(".vue") ? void 0 : code); if (errors.length) { errors.forEach((error) => pluginContext.error(createRollupError(filename, error))); return null; } const attachedProps = []; const hasScoped = descriptor.styles.some((s$1) => s$1.scoped); const { code: scriptCode, map: scriptMap } = await genScriptCode(descriptor, options, pluginContext, ssr, customElement); const hasTemplateImport = descriptor.template && !isUseInlineTemplate(descriptor, options); let templateCode = ""; let templateMap = void 0; if (hasTemplateImport) ({code: templateCode, map: templateMap} = await genTemplateCode(descriptor, options, pluginContext, ssr, customElement)); if (hasTemplateImport) attachedProps.push(ssr ? ["ssrRender", "_sfc_ssrRender"] : ["render", "_sfc_render"]); else if (prevDescriptor && !isEqualBlock(descriptor.template, prevDescriptor.template)) attachedProps.push([ssr ? "ssrRender" : "render", "() => {}"]); const stylesCode = await genStyleCode(descriptor, pluginContext, customElement, attachedProps); const customBlocksCode = await genCustomBlockCode(descriptor, pluginContext); const output = [ scriptCode, templateCode, stylesCode, customBlocksCode ]; if (hasScoped) attachedProps.push([`__scopeId`, JSON.stringify(`data-v-${descriptor.id}`)]); if (devToolsEnabled || devServer && !isProduction) attachedProps.push([`__file`, JSON.stringify(isProduction ? path.basename(filename) : filename)]); if (devServer && devServer.config.server.hmr !== false && !ssr && !isProduction) { output.push(`_sfc_main.__hmrId = ${JSON.stringify(descriptor.id)}`); output.push("typeof __VUE_HMR_RUNTIME__ !== 'undefined' && __VUE_HMR_RUNTIME__.createRecord(_sfc_main.__hmrId, _sfc_main)"); output.push(`import.meta.hot.on('file-changed', ({ file }) => {`, ` __VUE_HMR_RUNTIME__.CHANGED_FILE = file`, `})`); if (prevDescriptor && isOnlyTemplateChanged(prevDescriptor, descriptor)) output.push(`export const _rerender_only = __VUE_HMR_RUNTIME__.CHANGED_FILE === ${JSON.stringify(normalizePath(filename))}`); output.push(`import.meta.hot.accept(mod => {`, ` if (!mod) return`, ` const { default: updated, _rerender_only } = mod`, ` if (_rerender_only) {`, ` __VUE_HMR_RUNTIME__.rerender(updated.__hmrId, updated.render)`, ` } else {`, ` __VUE_HMR_RUNTIME__.reload(updated.__hmrId, updated)`, ` }`, `})`); } if (ssr) { const normalizedFilename = normalizePath(path.relative(options.root, filename)); output.push(`import { useSSRContext as __vite_useSSRContext } from 'vue'`, `const _sfc_setup = _sfc_main.setup`, `_sfc_main.setup = (props, ctx) => {`, ` const ssrContext = __vite_useSSRContext()`, ` ;(ssrContext.modules || (ssrContext.modules = new Set())).add(${JSON.stringify(normalizedFilename)})`, ` return _sfc_setup ? _sfc_setup(props, ctx) : undefined`, `}`); } let resolvedMap = void 0; if (options.sourceMap) if (templateMap) { const from = scriptMap ?? { file: filename, sourceRoot: "", version: 3, sources: [], sourcesContent: [], names: [], mappings: "" }; const gen = fromMap(from); const tracer = new TraceMap(templateMap); const offset = (scriptCode.match(/\r?\n/g)?.length ?? 0) + 1; eachMapping(tracer, (m$1) => { if (m$1.source == null) return; addMapping(gen, { source: m$1.source, original: { line: m$1.originalLine, column: m$1.originalColumn }, generated: { line: m$1.generatedLine + offset, column: m$1.generatedColumn } }); }); resolvedMap = toEncodedMap(gen); resolvedMap.sourcesContent = templateMap.sourcesContent; } else resolvedMap = scriptMap; if (!attachedProps.length) output.push(`export default _sfc_main`); else output.push(`import _export_sfc from '${EXPORT_HELPER_ID}'`, `export default /*#__PURE__*/_export_sfc(_sfc_main, [${attachedProps.map(([key, val]) => `['${key}',${val}]`).join(",")}])`); let resolvedCode = output.join("\n"); const lang = descriptor.scriptSetup?.lang || descriptor.script?.lang; if (lang && /tsx?$/.test(lang) && !descriptor.script?.src) { const { transformWithOxc } = await import("vite"); if (transformWithOxc) { const { code: code$1, map } = await transformWithOxc(resolvedCode, filename, { ...options.devServer?.config.oxc, lang: "ts", sourcemap: options.sourceMap }, resolvedMap); resolvedCode = code$1; resolvedMap = resolvedMap ? map : resolvedMap; } else { const { code: code$1, map } = await transformWithEsbuild(resolvedCode, filename, { target: "esnext", charset: "utf8", ...options.devServer?.config.esbuild, loader: "ts", sourcemap: options.sourceMap }, resolvedMap); resolvedCode = code$1; resolvedMap = resolvedMap ? map : resolvedMap; } } return { code: resolvedCode, map: resolvedMap || { mappings: "" }, meta: { vite: { lang: descriptor.script?.lang || descriptor.scriptSetup?.lang || "js" } } }; } async function genTemplateCode(descriptor, options, pluginContext, ssr, customElement) { const template = descriptor.template; const hasScoped = descriptor.styles.some((style) => style.scoped); if ((!template.lang || template.lang === "html") && !template.src) return transformTemplateInMain(template.content, descriptor, options, pluginContext, ssr, customElement); else { if (template.src) await linkSrcToDescriptor(template.src, descriptor, pluginContext, hasScoped); const src = template.src || descriptor.filename; const srcQuery = template.src ? hasScoped ? `&src=${descriptor.id}` : "&src=true" : ""; const scopedQuery = hasScoped ? `&scoped=${descriptor.id}` : ``; const attrsQuery = attrsToQuery(template.attrs, "js", true); const query = `?vue&type=template${srcQuery}${scopedQuery}${attrsQuery}`; const request = JSON.stringify(src + query); const renderFnName = ssr ? "ssrRender" : "render"; return { code: `import { ${renderFnName} as _sfc_${renderFnName} } from ${request}`, map: void 0 }; } } async function genScriptCode(descriptor, options, pluginContext, ssr, customElement) { const vaporFlag = descriptor.vapor ? "__vapor: true" : ""; let scriptCode = `const ${scriptIdentifier} = { ${vaporFlag} }`; let map; const script = resolveScript(descriptor, options, ssr, customElement); if (script) if (canInlineMain(descriptor, options)) { if (!options.compiler.version) { const userPlugins = options.script?.babelParserPlugins || []; const defaultPlugins = script.lang === "ts" ? userPlugins.includes("decorators") ? ["typescript"] : ["typescript", "decorators-legacy"] : []; scriptCode = options.compiler.rewriteDefault(script.content, scriptIdentifier, [...defaultPlugins, ...userPlugins]); } else scriptCode = script.content; map = script.map; } else { if (script.src) await linkSrcToDescriptor(script.src, descriptor, pluginContext, false); const src = script.src || descriptor.filename; const langFallback = script.src && path.extname(src).slice(1) || "js"; const attrsQuery = attrsToQuery(script.attrs, langFallback); const srcQuery = script.src ? `&src=true` : ``; const query = `?vue&type=script${srcQuery}${attrsQuery}`; const request = JSON.stringify(src + query); scriptCode = `import _sfc_main from ${request}\nexport * from ${request}`; } return { code: scriptCode, map }; } async function genStyleCode(descriptor, pluginContext, customElement, attachedProps) { let stylesCode = ``; let cssModulesMap; if (descriptor.styles.length) { for (let i = 0; i < descriptor.styles.length; i++) { const style = descriptor.styles[i]; if (style.src) await linkSrcToDescriptor(style.src, descriptor, pluginContext, style.scoped); const src = style.src || descriptor.filename; const attrsQuery = attrsToQuery(style.attrs, "css"); const srcQuery = style.src ? style.scoped ? `&src=${descriptor.id}` : "&src=true" : ""; const directQuery = customElement ? `&inline` : ``; const scopedQuery = style.scoped ? `&scoped=${descriptor.id}` : ``; const query = `?vue&type=style&index=${i}${srcQuery}${directQuery}${scopedQuery}`; const styleRequest = src + query + attrsQuery; if (style.module) { if (customElement) throw new Error(`