@hirarijs/loader-vue 1.0.0

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/index.cjs ADDED
@@ -0,0 +1,114 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/index.ts
21
+ var index_exports = {};
22
+ __export(index_exports, {
23
+ default: () => index_default
24
+ });
25
+ module.exports = __toCommonJS(index_exports);
26
+ var import_crypto = require("crypto");
27
+ var import_compiler_sfc = require("@vue/compiler-sfc");
28
+ var import_esbuild = require("esbuild");
29
+ var import_loader = require("@hirarijs/loader");
30
+ var extensions = [".vue"];
31
+ function normalizeScript(code, fallbackVar) {
32
+ const defaultExport = /export default\s+([\s\S]*?);?\s*$/;
33
+ let componentVar = fallbackVar;
34
+ const match = code.match(defaultExport);
35
+ if (match && match.index !== void 0) {
36
+ const expr = match[1].trim();
37
+ const before = code.slice(0, match.index).trimEnd();
38
+ const decl = `const ${componentVar} = ${expr}`;
39
+ const pieces = [before, decl].filter(Boolean);
40
+ return { code: pieces.join("\n"), componentVar };
41
+ }
42
+ if (!code.includes(fallbackVar)) {
43
+ code += `
44
+ const ${componentVar} = {}`;
45
+ }
46
+ return { code, componentVar };
47
+ }
48
+ function compileVue(code, filename, ctx) {
49
+ const { descriptor } = (0, import_compiler_sfc.parse)(code, { filename });
50
+ const id = (0, import_crypto.createHash)("sha256").update(filename).digest("hex").slice(0, 8);
51
+ let output;
52
+ let componentVar = "_sfc_main";
53
+ if (descriptor.script || descriptor.scriptSetup) {
54
+ const script = (0, import_compiler_sfc.compileScript)(descriptor, {
55
+ id,
56
+ inlineTemplate: false
57
+ });
58
+ const normalized = normalizeScript(script.content, componentVar);
59
+ output = normalized.code;
60
+ componentVar = normalized.componentVar;
61
+ if (descriptor.template) {
62
+ const template = (0, import_compiler_sfc.compileTemplate)({
63
+ source: descriptor.template.content,
64
+ filename,
65
+ id,
66
+ compilerOptions: {
67
+ bindingMetadata: script.bindings
68
+ }
69
+ });
70
+ output += `
71
+ ${template.code}`;
72
+ output += `
73
+ ;(${componentVar} as any).render = render`;
74
+ }
75
+ } else {
76
+ output = `const ${componentVar} = {}`;
77
+ if (descriptor.template) {
78
+ const template = (0, import_compiler_sfc.compileTemplate)({
79
+ source: descriptor.template.content,
80
+ filename,
81
+ id
82
+ });
83
+ output += `
84
+ ${template.code}`;
85
+ output += `
86
+ ;(${componentVar} as any).render = render`;
87
+ }
88
+ }
89
+ output += `
90
+ export default ${componentVar}`;
91
+ const banner = ctx.format === "cjs" ? `const ${import_loader.IMPORT_META_URL_VARIABLE} = require('url').pathToFileURL(__filename).href;` : void 0;
92
+ const transformed = (0, import_esbuild.transformSync)(output, {
93
+ loader: "ts",
94
+ format: ctx.format,
95
+ sourcemap: "both",
96
+ sourcefile: filename,
97
+ define: ctx.format === "cjs" ? {
98
+ "import.meta.url": import_loader.IMPORT_META_URL_VARIABLE
99
+ } : void 0,
100
+ banner
101
+ });
102
+ return {
103
+ code: transformed.code,
104
+ map: transformed.map,
105
+ format: ctx.format
106
+ };
107
+ }
108
+ var plugin = {
109
+ name: "@hirarijs/loader-vue",
110
+ extensions,
111
+ match: (filename) => extensions.some((ext) => filename.endsWith(ext)),
112
+ transform: (code, filename, ctx) => compileVue(code, filename, ctx)
113
+ };
114
+ var index_default = plugin;
@@ -0,0 +1,5 @@
1
+ import { LoaderPlugin } from '@hirarijs/loader';
2
+
3
+ declare const plugin: LoaderPlugin;
4
+
5
+ export { plugin as default };
@@ -0,0 +1,5 @@
1
+ import { LoaderPlugin } from '@hirarijs/loader';
2
+
3
+ declare const plugin: LoaderPlugin;
4
+
5
+ export { plugin as default };
package/dist/index.js ADDED
@@ -0,0 +1,95 @@
1
+ // src/index.ts
2
+ import { createHash } from "crypto";
3
+ import { compileScript, compileTemplate, parse } from "@vue/compiler-sfc";
4
+ import { transformSync } from "esbuild";
5
+ import {
6
+ IMPORT_META_URL_VARIABLE
7
+ } from "@hirarijs/loader";
8
+ var extensions = [".vue"];
9
+ function normalizeScript(code, fallbackVar) {
10
+ const defaultExport = /export default\s+([\s\S]*?);?\s*$/;
11
+ let componentVar = fallbackVar;
12
+ const match = code.match(defaultExport);
13
+ if (match && match.index !== void 0) {
14
+ const expr = match[1].trim();
15
+ const before = code.slice(0, match.index).trimEnd();
16
+ const decl = `const ${componentVar} = ${expr}`;
17
+ const pieces = [before, decl].filter(Boolean);
18
+ return { code: pieces.join("\n"), componentVar };
19
+ }
20
+ if (!code.includes(fallbackVar)) {
21
+ code += `
22
+ const ${componentVar} = {}`;
23
+ }
24
+ return { code, componentVar };
25
+ }
26
+ function compileVue(code, filename, ctx) {
27
+ const { descriptor } = parse(code, { filename });
28
+ const id = createHash("sha256").update(filename).digest("hex").slice(0, 8);
29
+ let output;
30
+ let componentVar = "_sfc_main";
31
+ if (descriptor.script || descriptor.scriptSetup) {
32
+ const script = compileScript(descriptor, {
33
+ id,
34
+ inlineTemplate: false
35
+ });
36
+ const normalized = normalizeScript(script.content, componentVar);
37
+ output = normalized.code;
38
+ componentVar = normalized.componentVar;
39
+ if (descriptor.template) {
40
+ const template = compileTemplate({
41
+ source: descriptor.template.content,
42
+ filename,
43
+ id,
44
+ compilerOptions: {
45
+ bindingMetadata: script.bindings
46
+ }
47
+ });
48
+ output += `
49
+ ${template.code}`;
50
+ output += `
51
+ ;(${componentVar} as any).render = render`;
52
+ }
53
+ } else {
54
+ output = `const ${componentVar} = {}`;
55
+ if (descriptor.template) {
56
+ const template = compileTemplate({
57
+ source: descriptor.template.content,
58
+ filename,
59
+ id
60
+ });
61
+ output += `
62
+ ${template.code}`;
63
+ output += `
64
+ ;(${componentVar} as any).render = render`;
65
+ }
66
+ }
67
+ output += `
68
+ export default ${componentVar}`;
69
+ const banner = ctx.format === "cjs" ? `const ${IMPORT_META_URL_VARIABLE} = require('url').pathToFileURL(__filename).href;` : void 0;
70
+ const transformed = transformSync(output, {
71
+ loader: "ts",
72
+ format: ctx.format,
73
+ sourcemap: "both",
74
+ sourcefile: filename,
75
+ define: ctx.format === "cjs" ? {
76
+ "import.meta.url": IMPORT_META_URL_VARIABLE
77
+ } : void 0,
78
+ banner
79
+ });
80
+ return {
81
+ code: transformed.code,
82
+ map: transformed.map,
83
+ format: ctx.format
84
+ };
85
+ }
86
+ var plugin = {
87
+ name: "@hirarijs/loader-vue",
88
+ extensions,
89
+ match: (filename) => extensions.some((ext) => filename.endsWith(ext)),
90
+ transform: (code, filename, ctx) => compileVue(code, filename, ctx)
91
+ };
92
+ var index_default = plugin;
93
+ export {
94
+ index_default as default
95
+ };
package/package.json ADDED
@@ -0,0 +1,35 @@
1
+ {
2
+ "name": "@hirarijs/loader-vue",
3
+ "version": "1.0.0",
4
+ "description": "Vue SFC loader plugin for HirariJS loader",
5
+ "type": "module",
6
+ "main": "./dist/index.cjs",
7
+ "module": "./dist/index.js",
8
+ "types": "./dist/index.d.ts",
9
+ "exports": {
10
+ ".": {
11
+ "import": "./dist/index.js",
12
+ "require": "./dist/index.cjs",
13
+ "types": "./dist/index.d.ts"
14
+ }
15
+ },
16
+ "files": [
17
+ "dist"
18
+ ],
19
+ "scripts": {
20
+ "build": "tsup src/index.ts --format esm,cjs --dts",
21
+ "test": "node --test"
22
+ },
23
+ "peerDependencies": {
24
+ "@hirarijs/loader": "*"
25
+ },
26
+ "dependencies": {
27
+ "@vue/compiler-sfc": "^3.4.15",
28
+ "esbuild": "^0.21.5"
29
+ },
30
+ "devDependencies": {
31
+ "@hirarijs/loader": "workspace:*",
32
+ "tsup": "^8.0.1",
33
+ "typescript": "^5.3.3"
34
+ }
35
+ }