-
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathplugin.js
113 lines (101 loc) · 2.91 KB
/
plugin.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
import path from 'path';
import { transformSync } from '@babel/core';
import babelGlimmerPreset from '@glimmerx/babel-preset';
import tsPreset from '@babel/preset-typescript';
import parseStaticImports from 'parse-static-imports';
const templateFileRegex = /\.(hbs)$/;
const scriptFileRegex = /\.(ts|js)$/;
const fixDelimiter = '// [will-be-removed]';
function isNodeModulesPath(str) {
return str.includes('node_modules');
}
export default function vitePluginGlimmerX(plgOptions) {
let viteConfig;
return {
name: 'vite:glimmerx',
enforce: 'pre',
configResolved(resolvedConfig) {
viteConfig = resolvedConfig;
},
transform(rawCode, id) {
// console.log(id);
let code = rawCode;
if (templateFileRegex.test(id)) {
code = `
import { hbs } from '@glimmerx/component';
export default hbs\`${rawCode.trim()}\`;
`.trim();
} else if (!scriptFileRegex.test(id)) {
return;
}
if (!isNodeModulesPath(id)) {
// https://github.com/typed-ember/glint/issues/223
code = code.split('@glint/environment-glimmerx/').join('@glimmerx/');
}
const needPatch = !isNodeModulesPath(id);
const imports = parseStaticImports(code)
.filter((e) => {
return (
e.moduleName.startsWith('@glint/') ||
e.moduleName.startsWith('@glimmerx/') ||
!e.moduleName.startsWith('@')
);
})
.map((el) => [...el.namedImports.map((e) => e.alias), el.defaultImport])
.reduce((acc, items) => {
return acc.concat(items);
}, [])
.filter((el) => el.length && el !== 'hbs')
.map((e) => e.split(' ').pop().trim());
// https://github.com/glimmerjs/glimmer.js/issues/365
code = needPatch
? `
${code};
${fixDelimiter}
export const _params = [${imports.map((e) => `${e}`).join(',')}];
`
: code;
const result = transformSrcCode(code, id, plgOptions, viteConfig);
return {
code: needPatch ? result.split(fixDelimiter)[0].trim() : result,
map: null,
};
},
};
}
function transformSrcCode(code, fileName, plgOptions, viteConfig) {
let presets = [];
if (isNodeModulesPath(fileName) || fileName.endsWith('.js')) {
presets = [
function (api, opts) {
return babelGlimmerPreset(api, {
...opts,
...{
isDebug: !viteConfig.isProduction,
},
});
},
];
} else {
presets = [
tsPreset,
function (api, opts) {
return babelGlimmerPreset(api, {
...opts,
...{
isDebug: !viteConfig.isProduction,
},
});
},
];
}
let result = transformSync(code, {
sourceType: 'module',
babelrc: false,
configFile: false,
envName: viteConfig.mode,
filename: fileName,
presets,
});
return result.code;
}