ember-scoped-css 0.18.0 → 0.19.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.
Files changed (62) hide show
  1. package/README.md +7 -0
  2. package/declarations/lib/path/hash-from-absolute-path.d.ts +3 -0
  3. package/declarations/lib/path/hash-from-absolute-path.d.ts.map +1 -0
  4. package/declarations/lib/path/hash-from-absolute-path.test.d.ts +2 -0
  5. package/declarations/lib/path/hash-from-absolute-path.test.d.ts.map +1 -0
  6. package/declarations/lib/path/hash-from-module-path.d.ts +31 -0
  7. package/declarations/lib/path/hash-from-module-path.d.ts.map +1 -0
  8. package/declarations/lib/path/template-transform-paths.d.ts +11 -0
  9. package/declarations/lib/path/template-transform-paths.d.ts.map +1 -0
  10. package/declarations/lib/path/template-transform-paths.test.d.ts +2 -0
  11. package/declarations/lib/path/template-transform-paths.test.d.ts.map +1 -0
  12. package/declarations/lib/path/utils.appPath.test.d.ts +2 -0
  13. package/declarations/lib/path/utils.appPath.test.d.ts.map +1 -0
  14. package/declarations/lib/path/utils.d.ts +85 -0
  15. package/declarations/lib/path/utils.d.ts.map +1 -0
  16. package/declarations/lib/path/utils.hashFrom.test.d.ts +2 -0
  17. package/declarations/lib/path/utils.hashFrom.test.d.ts.map +1 -0
  18. package/declarations/lib/path/utils.isRelevantFile.test.d.ts +2 -0
  19. package/declarations/lib/path/utils.isRelevantFile.test.d.ts.map +1 -0
  20. package/declarations/lib/path/utils.paths.test.d.ts +7 -0
  21. package/declarations/lib/path/utils.paths.test.d.ts.map +1 -0
  22. package/dist/cjs/app-css-loader.cjs +220 -0
  23. package/dist/cjs/app-dependency-loader.cjs +41 -0
  24. package/dist/cjs/babel-plugin.cjs +378 -0
  25. package/dist/cjs/ember-classic-support.cjs +466 -0
  26. package/dist/cjs/index.cjs +662 -0
  27. package/dist/cjs/template-plugin.cjs +434 -0
  28. package/dist/runtime/test-support.js +7 -8
  29. package/dist/runtime/test-support.js.map +3 -3
  30. package/package.json +35 -25
  31. package/src/build/app-css-loader.js +19 -14
  32. package/src/build/app-dependency-loader.js +4 -4
  33. package/src/build/app-js-unplugin.js +3 -10
  34. package/src/build/babel-plugin.js +26 -35
  35. package/src/build/ember-classic-support.js +21 -14
  36. package/src/build/scoped-css-unplugin.js +8 -10
  37. package/src/build/template-plugin.js +76 -0
  38. package/src/lib/css/utils.js +17 -0
  39. package/src/lib/path/hash-from-absolute-path.js +16 -0
  40. package/src/lib/path/hash-from-absolute-path.test.ts +42 -0
  41. package/src/lib/path/hash-from-module-path.js +43 -0
  42. package/src/lib/path/template-transform-paths.js +103 -0
  43. package/src/lib/path/template-transform-paths.test.ts +47 -0
  44. package/src/lib/path/utils.appPath.test.ts +33 -0
  45. package/src/lib/path/utils.hashFrom.test.ts +51 -0
  46. package/src/lib/path/utils.isRelevantFile.test.ts +75 -0
  47. package/src/lib/path/utils.js +328 -0
  48. package/src/lib/path/utils.paths.test.ts +26 -0
  49. package/src/lib/replaceGlimmerAst.js +2 -3
  50. package/src/lib/rewriteHbs.js +15 -12
  51. package/src/runtime/test-support.ts +4 -4
  52. package/declarations/lib/generateRelativePathHash.d.ts +0 -7
  53. package/declarations/lib/generateRelativePathHash.d.ts.map +0 -1
  54. package/dist/cjs/build/app-css-loader.cjs +0 -202
  55. package/dist/cjs/build/app-dependency-loader.cjs +0 -53
  56. package/dist/cjs/build/ember-classic-support.cjs +0 -458
  57. package/dist/cjs/build/index.cjs +0 -656
  58. package/dist/cjs/scoped-babel-plugin.cjs +0 -295
  59. package/src/lib/fsExists.js +0 -11
  60. package/src/lib/generateAbsolutePathHash.js +0 -176
  61. package/src/lib/generateRelativePathHash.js +0 -10
  62. package/src/scoped-babel-plugin.js +0 -1
package/README.md CHANGED
@@ -19,6 +19,13 @@ This build tool emits CSS in a `@layer`.
19
19
  - non-embroider apps
20
20
  - embroider apps
21
21
 
22
+ | You Have | ember-scoped-css | ember-scoped-css-compat |
23
+ | -------- | ----------- | ---------------------- |
24
+ | ember-template-imports@v4 or babel-plugin-ember-template-compilation@2.2.5+ | 0.19.0 | 10.0.0 |
25
+ | ember-template-imports@v3 or babel-plugin-ember-template-compilation@2.2.1 or rollup-plugin-glimmer-template-tag | <= 0.18.0 | <= 9.0.0 |
26
+ | classic components | <= 0.18.0 | <= 8.0.0 |
27
+ | ember < 4 | <= 0.18.0 | <= 8.0.0 |
28
+
22
29
 
23
30
  ## Installation for a non-embroider ember app
24
31
 
@@ -0,0 +1,3 @@
1
+ export function hashFromAbsolutePath(absolutePath: any): string;
2
+ export { hash } from "./hash-from-module-path.js";
3
+ //# sourceMappingURL=hash-from-absolute-path.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hash-from-absolute-path.d.ts","sourceRoot":"","sources":["../../../src/lib/path/hash-from-absolute-path.js"],"names":[],"mappings":"AAKA,gEAUC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=hash-from-absolute-path.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hash-from-absolute-path.test.d.ts","sourceRoot":"","sources":["../../../src/lib/path/hash-from-absolute-path.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,31 @@
1
+ /**
2
+ * The intent of this function is to generate the suffix/postfix for the
3
+ * css classes, based on the module-scoped path name.
4
+ *
5
+ * for example,
6
+ * hash('my-app/components/foo')
7
+ * instead of
8
+ * hash('app/components/foo')
9
+ *
10
+ * (unless your app name is 'app')
11
+ *
12
+ * @param {string} modulePath
13
+ * @returns {string}
14
+ */
15
+ export function hash(modulePath: string): string;
16
+ /**
17
+ * The intent of this function is to generate the suffix/postfix for the
18
+ * css classes, based on the module-scoped path name.
19
+ *
20
+ * for example,
21
+ * hash('my-app/components/foo')
22
+ * instead of
23
+ * hash('app/components/foo')
24
+ *
25
+ * (unless your app name is 'app')
26
+ *
27
+ * @param {string} modulePath
28
+ * @returns {string}
29
+ */
30
+ export function hashFromModulePath(modulePath: string): string;
31
+ //# sourceMappingURL=hash-from-module-path.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hash-from-module-path.d.ts","sourceRoot":"","sources":["../../../src/lib/path/hash-from-module-path.js"],"names":[],"mappings":"AAEA;;;;;;;;;;;;;GAaG;AACH,iCAHW,MAAM,GACJ,MAAM,CAIlB;AAhBD;;;;;;;;;;;;;GAaG;AACH,+CAHW,MAAM,GACJ,MAAM,CAIlB"}
@@ -0,0 +1,11 @@
1
+ /**
2
+ * template plugins do not hand us the correct file path.
3
+ * additionally, we may not be able to rely on this data in the future,
4
+ * so this functions acts as a means of normalizing _whatever_ we're given
5
+ * in the future.
6
+ *
7
+ * @param {string} filename
8
+ * @returns {string} the absolute path to the file
9
+ */
10
+ export function fixFilename(filename: string): string;
11
+ //# sourceMappingURL=template-transform-paths.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"template-transform-paths.d.ts","sourceRoot":"","sources":["../../../src/lib/path/template-transform-paths.js"],"names":[],"mappings":"AAMA;;;;;;;;GAQG;AACH,sCAHW,MAAM,GACJ,MAAM,CAqElB"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=template-transform-paths.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"template-transform-paths.test.d.ts","sourceRoot":"","sources":["../../../src/lib/path/template-transform-paths.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=utils.appPath.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.appPath.test.d.ts","sourceRoot":"","sources":["../../../src/lib/path/utils.appPath.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,85 @@
1
+ /**
2
+ * Regardless of what the filePath format is,
3
+ * this will try to return the correct postfix.
4
+ *
5
+ * @param {string} filePath
6
+ * @returns
7
+ */
8
+ export function hashFrom(filePath: string): string;
9
+ /**
10
+ * Based on ember's component location conventions,
11
+ * this function will provide a path for where we
12
+ * expect the CSS to live.
13
+ *
14
+ * For co-located structure:
15
+ * - components/my-component.hbs
16
+ * - components/my-component.css
17
+ *
18
+ * For nested co-located structure
19
+ * - components/my-component/foo.hbs
20
+ * - components/my-component/foo.css
21
+ *
22
+ * For Pods routes structure
23
+ * - routes/my-route/template.{hbs,js}
24
+ * - routes/my-route/styles.css
25
+ *
26
+ * Deliberately not supported:
27
+ * - components w/ pods -- this is deprecated in 5.10
28
+ *
29
+ * @param {string} fileName - the hbs, js, gjs, gts or whatever co-located path.
30
+ * @returns {string} - expected css path
31
+ */
32
+ export function cssPathFor(fileName: string): string;
33
+ /**
34
+ * Note that components in the "pods" convention will
35
+ * never be supported.
36
+ *
37
+ * @param {string} filePath
38
+ */
39
+ export function isPodTemplate(filePath: string): boolean;
40
+ /**
41
+ * Note that components in the "pods" convention will
42
+ * never be supported.
43
+ *
44
+ * Checks if a file ends with
45
+ * - template.js
46
+ * - template.hbs
47
+ * - styles.css
48
+ *
49
+ * @param {string} filePath
50
+ */
51
+ export function isPod(filePath: string): boolean;
52
+ /**
53
+ *
54
+ * @param {string} filePath
55
+ * @returns the same path, but without the extension
56
+ */
57
+ export function withoutExtension(filePath: string): string;
58
+ /**
59
+ * Examples for fileName
60
+ * - absolute on-disk path
61
+ * - in webpack
62
+ * - URL-absolute path, starting with /
63
+ *
64
+ * @param {string} fileName
65
+ * @param {string[]} [additionalRoots]
66
+ * @returns
67
+ */
68
+ export function isRelevantFile(fileName: string, additionalRoots?: string[] | undefined): boolean | undefined;
69
+ export function packageScopedPathToModulePath(packageScopedPath: any): string;
70
+ /**
71
+ * returns the app-module path of the source file
72
+ *
73
+ * This assumes normal ember app conventions
74
+ *
75
+ * which is `<package.json#name>/path-to-file`
76
+ */
77
+ export function appPath(sourcePath: any): string;
78
+ /**
79
+ * Populates the "seen" workspace cache,
80
+ * so that we don't hit the file system too often.
81
+ */
82
+ export function findWorkspacePath(sourcePath: any): any;
83
+ export { hashFromAbsolutePath } from "./hash-from-absolute-path.js";
84
+ export { hashFromModulePath } from "./hash-from-module-path.js";
85
+ //# sourceMappingURL=utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/path/utils.js"],"names":[],"mappings":"AAWA;;;;;;GAMG;AACH,mCAHW,MAAM,UAShB;AAED;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,qCAHW,MAAM,GACJ,MAAM,CAalB;AAED;;;;;GAKG;AACH,wCAFW,MAAM,WAQhB;AAED;;;;;;;;;;GAUG;AACH,gCAFW,MAAM,WAYhB;AAED;;;;GAIG;AACH,2CAHW,MAAM,UAOhB;AAMD;;;;;;;;;GASG;AACH,yCAJW,MAAM,+DAmEhB;AAED,8EAsCC;AAED;;;;;;GAMG;AACH,iDA4BC;AAoBD;;;GAGG;AACH,wDAgBC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=utils.hashFrom.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.hashFrom.test.d.ts","sourceRoot":"","sources":["../../../src/lib/path/utils.hashFrom.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=utils.isRelevantFile.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.isRelevantFile.test.d.ts","sourceRoot":"","sources":["../../../src/lib/path/utils.isRelevantFile.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,7 @@
1
+ export declare const paths: {
2
+ rewritten: string;
3
+ embroiderApp: string;
4
+ classicApp: string;
5
+ v2Addon: string;
6
+ };
7
+ //# sourceMappingURL=utils.paths.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.paths.test.d.ts","sourceRoot":"","sources":["../../../src/lib/path/utils.paths.test.ts"],"names":[],"mappings":"AAUA,eAAO,MAAM,KAAK;;;;;CAKjB,CAAC"}
@@ -0,0 +1,220 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+
30
+ // src/build/app-css-loader.js
31
+ var app_css_loader_exports = {};
32
+ __export(app_css_loader_exports, {
33
+ default: () => app_css_loader_default
34
+ });
35
+ module.exports = __toCommonJS(app_css_loader_exports);
36
+ var import_node_fs2 = require("node:fs");
37
+ var import_node_path2 = __toESM(require("node:path"), 1);
38
+
39
+ // src/lib/path/utils.js
40
+ var import_node_fs = __toESM(require("node:fs"), 1);
41
+ var import_node_path = __toESM(require("node:path"), 1);
42
+ var import_find_up = __toESM(require("find-up"), 1);
43
+
44
+ // src/lib/path/hash-from-module-path.js
45
+ var import_blueimp_md5 = __toESM(require("blueimp-md5"), 1);
46
+ function hash(modulePath) {
47
+ return "e" + (0, import_blueimp_md5.default)(modulePath).substring(0, 8);
48
+ }
49
+ var hashFromModulePath = hash;
50
+
51
+ // src/lib/path/hash-from-absolute-path.js
52
+ function hashFromAbsolutePath(absolutePath) {
53
+ const modulePath = appPath(absolutePath);
54
+ const postfix = hash(modulePath);
55
+ return postfix;
56
+ }
57
+
58
+ // src/lib/path/utils.js
59
+ function hashFrom(filePath) {
60
+ if (filePath.startsWith("/")) {
61
+ return hashFromAbsolutePath(filePath);
62
+ }
63
+ return hashFromModulePath(filePath);
64
+ }
65
+ function isPodTemplate(filePath) {
66
+ if (filePath.includes("/components/")) {
67
+ return false;
68
+ }
69
+ return filePath.endsWith("template.js") || filePath.endsWith("template.hbs");
70
+ }
71
+ function isPod(filePath) {
72
+ if (filePath.includes("/components/")) {
73
+ return false;
74
+ }
75
+ if (isPodTemplate(filePath)) {
76
+ return true;
77
+ }
78
+ return filePath.endsWith("styles.css");
79
+ }
80
+ function packageScopedPathToModulePath(packageScopedPath) {
81
+ let packageRelative = packageScopedPath.replace(/^\/src\//, "/");
82
+ let parsed = import_node_path.default.parse(packageRelative);
83
+ if (isPod(packageRelative)) {
84
+ return parsed.dir;
85
+ }
86
+ let localPackagerStylePath = import_node_path.default.join(parsed.dir, parsed.name);
87
+ return localPackagerStylePath;
88
+ }
89
+ function appPath(sourcePath) {
90
+ let workspacePath = findWorkspacePath(sourcePath);
91
+ let name = workspacePackageName(sourcePath);
92
+ let packageRelative = sourcePath.replace(workspacePath, "");
93
+ packageRelative = packageRelative.replace(`/app/`, `/`);
94
+ packageRelative = packageRelative.replace(
95
+ `/node_modules/.embroider/rewritten-app/`,
96
+ "/"
97
+ );
98
+ let localPackagerStylePath = packageScopedPathToModulePath(packageRelative);
99
+ return `${name}${localPackagerStylePath}`;
100
+ }
101
+ var CACHE = /* @__PURE__ */ new Set();
102
+ function hasSeen(sourcePath) {
103
+ for (let entry of CACHE) {
104
+ if (sourcePath.startsWith(entry)) {
105
+ return entry;
106
+ }
107
+ }
108
+ return;
109
+ }
110
+ function findWorkspacePath(sourcePath) {
111
+ let seen = hasSeen(sourcePath);
112
+ if (seen) {
113
+ return seen;
114
+ }
115
+ const packageJsonPath = import_find_up.default.sync("package.json", {
116
+ cwd: import_node_path.default.dirname(sourcePath)
117
+ });
118
+ const workspacePath = import_node_path.default.dirname(packageJsonPath);
119
+ CACHE.add(workspacePath);
120
+ return workspacePath;
121
+ }
122
+ var MANIFEST_CACHE = /* @__PURE__ */ new Map();
123
+ function workspacePackageName(sourcePath) {
124
+ const workspace = findWorkspacePath(sourcePath);
125
+ let existing = MANIFEST_CACHE.get(workspace);
126
+ if (existing) {
127
+ return existing.name;
128
+ }
129
+ let buffer = import_node_fs.default.readFileSync(import_node_path.default.join(workspace, "package.json"));
130
+ let content = buffer.toString();
131
+ let json = JSON.parse(content);
132
+ MANIFEST_CACHE.set(workspace, json);
133
+ return json.name;
134
+ }
135
+
136
+ // src/lib/rewriteCss.js
137
+ var import_postcss = __toESM(require("postcss"), 1);
138
+ var import_postcss_selector_parser = __toESM(require("postcss-selector-parser"), 1);
139
+
140
+ // src/lib/isInsideGlobal.js
141
+ function isInsideGlobal(node, func) {
142
+ const parent = node.parent;
143
+ if (!parent) return false;
144
+ if (parent.type === "pseudo" && parent.value === ":global") return true;
145
+ return isInsideGlobal(parent, func);
146
+ }
147
+
148
+ // src/lib/rewriteCss.js
149
+ function rewriteSelector(sel, postfix) {
150
+ const transform = (selectors) => {
151
+ selectors.walk((selector) => {
152
+ if (selector.type === "class" && !isInsideGlobal(selector)) {
153
+ selector.value += "_" + postfix;
154
+ } else if (selector.type === "tag" && !isInsideGlobal(selector)) {
155
+ selector.replaceWith(
156
+ import_postcss_selector_parser.default.tag({ value: selector.value }),
157
+ import_postcss_selector_parser.default.className({ value: postfix })
158
+ );
159
+ }
160
+ });
161
+ selectors.walk((selector) => {
162
+ if (selector.type === "pseudo" && selector.value === ":global") {
163
+ selector.replaceWith(...selector.nodes);
164
+ }
165
+ });
166
+ };
167
+ const transformed = (0, import_postcss_selector_parser.default)(transform).processSync(sel);
168
+ return transformed;
169
+ }
170
+ function isInsideKeyframes(node) {
171
+ const parent = node.parent;
172
+ if (!parent) return false;
173
+ if (parent.type === "atrule" && parent.name === "keyframes") return true;
174
+ return isInsideKeyframes(parent);
175
+ }
176
+ function rewriteCss(css, postfix, fileName, layerName) {
177
+ const layerNameWithDefault = layerName ?? "components";
178
+ const ast = import_postcss.default.parse(css);
179
+ ast.walk((node) => {
180
+ if (node.type === "rule" && !isInsideKeyframes(node)) {
181
+ node.selector = rewriteSelector(node.selector, postfix);
182
+ }
183
+ });
184
+ const rewrittenCss = ast.toString();
185
+ if (!layerNameWithDefault) {
186
+ return `/* ${fileName} */
187
+ ${rewrittenCss}
188
+ `;
189
+ }
190
+ return `/* ${fileName} */
191
+ @layer ${layerNameWithDefault} {
192
+
193
+ ` + rewrittenCss + "\n}\n";
194
+ }
195
+
196
+ // src/build/app-css-loader.js
197
+ async function app_css_loader_default(code) {
198
+ const options = this.getOptions();
199
+ const cssPath = this.resourcePath;
200
+ if (!cssPath.startsWith(this.rootContext)) {
201
+ return code;
202
+ }
203
+ const cssFileName = import_node_path2.default.basename(cssPath);
204
+ const hbsPath = cssPath.replace(".css", ".hbs");
205
+ const gjsPath = cssPath.replace(".css", ".js");
206
+ const hbsExists = (0, import_node_fs2.existsSync)(hbsPath);
207
+ const gjsExists = (0, import_node_fs2.existsSync)(gjsPath);
208
+ if (hbsExists || gjsExists) {
209
+ const postfix = hashFrom(cssPath);
210
+ const rewrittenCss = rewriteCss(
211
+ code,
212
+ postfix,
213
+ cssFileName,
214
+ options.layerName
215
+ );
216
+ return rewrittenCss;
217
+ }
218
+ return code;
219
+ }
220
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/build/app-css-loader.js", "../../src/lib/path/utils.js", "../../src/lib/path/hash-from-module-path.js", "../../src/lib/path/hash-from-absolute-path.js", "../../src/lib/rewriteCss.js", "../../src/lib/isInsideGlobal.js"],
  "sourcesContent": ["// import { createUnplugin }  from 'unplugin';\nimport { existsSync } from 'node:fs';\nimport path from 'node:path';\n\nimport { hashFrom } from '../lib/path/utils.js';\nimport rewriteCss from '../lib/rewriteCss.js';\n\nexport default async function (code) {\n  const options = this.getOptions();\n  const cssPath = this.resourcePath;\n\n  if (!cssPath.startsWith(this.rootContext)) {\n    return code;\n  }\n\n  const cssFileName = path.basename(cssPath);\n\n  const hbsPath = cssPath.replace('.css', '.hbs');\n  const gjsPath = cssPath.replace('.css', '.js');\n  const hbsExists = existsSync(hbsPath);\n  const gjsExists = existsSync(gjsPath);\n\n  if (hbsExists || gjsExists) {\n    const postfix = hashFrom(cssPath);\n    const rewrittenCss = rewriteCss(\n      code,\n      postfix,\n      cssFileName,\n      options.layerName,\n    );\n\n    return rewrittenCss;\n  }\n\n  return code;\n}\n", "import fsSync from 'node:fs';\nimport path from 'node:path';\n\nimport findUp from 'find-up';\n\nimport { hashFromAbsolutePath } from './hash-from-absolute-path.js';\nimport { hashFromModulePath } from './hash-from-module-path.js';\n\nexport { hashFromAbsolutePath } from './hash-from-absolute-path.js';\nexport { hashFromModulePath } from './hash-from-module-path.js';\n\n/**\n * Regardless of what the filePath format is,\n * this will try to return the correct postfix.\n *\n * @param {string} filePath\n * @returns\n */\nexport function hashFrom(filePath) {\n  if (filePath.startsWith('/')) {\n    return hashFromAbsolutePath(filePath);\n  }\n\n  return hashFromModulePath(filePath);\n}\n\n/**\n * Based on ember's component location conventions,\n * this function will provide a path for where we\n * expect the CSS to live.\n *\n * For co-located structure:\n *   - components/my-component.hbs\n *   - components/my-component.css\n *\n * For nested co-located structure\n *   - components/my-component/foo.hbs\n *   - components/my-component/foo.css\n *\n * For Pods routes structure\n *   - routes/my-route/template.{hbs,js}\n *   - routes/my-route/styles.css\n *\n * Deliberately not supported:\n *   - components w/ pods -- this is deprecated in 5.10\n *\n * @param {string} fileName - the hbs, js, gjs, gts or whatever co-located path.\n * @returns {string} - expected css path\n */\nexport function cssPathFor(fileName) {\n  let withoutExt = withoutExtension(fileName);\n  let cssPath = withoutExt + '.css';\n\n  if (isPod(fileName)) {\n    cssPath = fileName\n      .replace(/template\\.js$/, 'styles.css')\n      .replace(/template\\.hbs/, 'styles.css');\n  }\n\n  return cssPath;\n}\n\n/**\n * Note that components in the \"pods\" convention will\n * never be supported.\n *\n * @param {string} filePath\n */\nexport function isPodTemplate(filePath) {\n  if (filePath.includes('/components/')) {\n    return false;\n  }\n\n  return filePath.endsWith('template.js') || filePath.endsWith('template.hbs');\n}\n\n/**\n * Note that components in the \"pods\" convention will\n * never be supported.\n *\n * Checks if a file ends with\n * - template.js\n * - template.hbs\n * - styles.css\n *\n * @param {string} filePath\n */\nexport function isPod(filePath) {\n  if (filePath.includes('/components/')) {\n    return false;\n  }\n\n  if (isPodTemplate(filePath)) {\n    return true;\n  }\n\n  return filePath.endsWith('styles.css');\n}\n\n/**\n *\n * @param {string} filePath\n * @returns the same path, but without the extension\n */\nexport function withoutExtension(filePath) {\n  let parsed = path.parse(filePath);\n\n  return path.join(parsed.dir, parsed.name);\n}\n\nconst IRRELEVANT_PATHS = ['node_modules/.pnpm'];\n\nconst UNSUPPORTED_DIRECTORIES = new Set(['tests']);\n\n/**\n * Examples for fileName\n * - absolute on-disk path\n * - in webpack\n *   - URL-absolute path, starting with /\n *\n * @param {string} fileName\n * @param {string[]} [additionalRoots]\n * @returns\n */\nexport function isRelevantFile(fileName, additionalRoots) {\n  if (fileName.startsWith('/@embroider')) return false;\n  if (IRRELEVANT_PATHS.some((i) => fileName.includes(i))) return false;\n\n  if (fileName.includes('/node_modules/')) {\n    // if a file is not the embroider cache directory\n    // and is in node_modules, skip it.\n    if (!fileName.includes('/node_modules/.embroider/')) {\n      return false;\n    }\n\n    // rewritten packages should have already been processed at their own\n    // publish time\n    if (fileName.includes('/node_modules/.embroider/rewritten-packages/')) {\n      return false;\n    }\n\n    // These are already the bundled files.\n    if (fileName.includes('/node_modules/.embroider/rewritten-app/assets/')) {\n      // not supported, never will be\n      if (\n        fileName.endsWith(\n          '/node_modules/.embroider/rewritten-app/assets/tests.js',\n        )\n      ) {\n        return false;\n      }\n\n      // Ideally, we never get here -- indicates we're not filtering effectively in babel\n      console.warn(\n        `[ScopedCSS]: transformation is attempting too late. Cannot operate on output file: ${fileName}`,\n      );\n\n      return false;\n    }\n  }\n\n  let workspace = findWorkspacePath(fileName);\n  let cwd = process.cwd();\n  let ourWorkspace = findWorkspacePath(cwd);\n\n  if (workspace !== ourWorkspace) {\n    return false;\n  }\n\n  let local = fileName.replace(workspace, '');\n  let [, ...parts] = local.split('/').filter(Boolean);\n\n  if (UNSUPPORTED_DIRECTORIES.has(parts[0])) {\n    return false;\n  }\n\n  /**\n   * Mostly pods support.\n   * folks need to opt in to pods (routes), because every pods app can be configured differently\n   */\n  let roots = ['/components/', ...(additionalRoots || [])];\n\n  if (!roots.some((root) => fileName.includes(root))) {\n    return;\n  }\n\n  return true;\n}\n\nexport function packageScopedPathToModulePath(packageScopedPath) {\n  /**\n   * *By convention*, `src` is omitted from component paths.\n   * We can reflect the same behavior by replacing src/\n   * with an empty string.\n   *\n   * CSS isn't emitted as a co-located module, but\n   * to keep conventions consistent across languages,\n   * we can pretend it is.\n   *\n   * Any customization beyond removing `src` and `app` is potentially confusing.\n   * If we need further customizations, we'll want to match on `exports` in the\n   * corresponding package.json\n   */\n  let packageRelative = packageScopedPath.replace(/^\\/src\\//, '/');\n\n  let parsed = path.parse(packageRelative);\n\n  if (isPod(packageRelative)) {\n    /**\n     * For pods, we chop off the whole file, and use the dir name as the \"modulePath\"\n     */\n    return parsed.dir;\n  }\n\n  /**\n   * If an extension is passed, remove it.\n   * When using packagers, folks are used to not having to specify extensions for files.\n   * Since we don't even emit css files co-located to each module,\n   * this helps us not convey a lie that a file may exist in at runtime.\n   *\n   * For example `<module-name>/components/button`.\n   * It doesn't matter what the extension is, because you can only have one css file\n   * for the button module anyway.\n   */\n  let localPackagerStylePath = path.join(parsed.dir, parsed.name);\n\n  return localPackagerStylePath;\n}\n\n/**\n * returns the app-module path of the source file\n *\n * This assumes normal ember app conventions\n *\n * which is `<package.json#name>/path-to-file`\n */\nexport function appPath(sourcePath) {\n  let workspacePath = findWorkspacePath(sourcePath);\n  let name = workspacePackageName(sourcePath);\n\n  /**\n   *  Under embroider builds, the spec-compliant version of the app\n   * has all the files under a folder which represents the package name,\n   * rather than \"app\".\n   */\n  let packageRelative = sourcePath.replace(workspacePath, '');\n\n  /**\n   * But we also don't want 'app' -- which is present in the v1 addon pipeline\n   */\n  packageRelative = packageRelative.replace(`/app/`, `/`);\n\n  /**\n   * also also, we know that the re-written app structure in embroider@v3\n   * is extraneous, and we can collapse it\n   */\n  packageRelative = packageRelative.replace(\n    `/node_modules/.embroider/rewritten-app/`,\n    '/',\n  );\n\n  let localPackagerStylePath = packageScopedPathToModulePath(packageRelative);\n\n  return `${name}${localPackagerStylePath}`;\n}\n\nconst CACHE = new Set();\n\n/**\n * For a given source path, if we have seen a\n * source file within the workspace directory,\n * find that workspace directory and return it.\n */\nfunction hasSeen(sourcePath) {\n  for (let entry of CACHE) {\n    if (sourcePath.startsWith(entry)) {\n      return entry;\n    }\n  }\n\n  // we have not seen this source path yet\n  return;\n}\n\n/**\n * Populates the \"seen\" workspace cache,\n * so that we don't hit the file system too often.\n */\nexport function findWorkspacePath(sourcePath) {\n  let seen = hasSeen(sourcePath);\n\n  if (seen) {\n    return seen;\n  }\n\n  const packageJsonPath = findUp.sync('package.json', {\n    cwd: path.dirname(sourcePath),\n  });\n\n  const workspacePath = path.dirname(packageJsonPath);\n\n  CACHE.add(workspacePath);\n\n  return workspacePath;\n}\n\nconst MANIFEST_CACHE = new Map();\n\n/**\n * returns the package.json#name for a given sourcePath\n */\nfunction workspacePackageName(sourcePath) {\n  const workspace = findWorkspacePath(sourcePath);\n\n  let existing = MANIFEST_CACHE.get(workspace);\n\n  if (existing) {\n    return existing.name;\n  }\n\n  let buffer = fsSync.readFileSync(path.join(workspace, 'package.json'));\n  let content = buffer.toString();\n  let json = JSON.parse(content);\n\n  MANIFEST_CACHE.set(workspace, json);\n\n  return json.name;\n}\n", "import md5 from 'blueimp-md5';\n\n/**\n * The intent of this function is to generate the suffix/postfix for the\n * css classes, based on the module-scoped path name.\n *\n * for example,\n *    hash('my-app/components/foo')\n *  instead of\n *    hash('app/components/foo')\n *\n *  (unless your app name is 'app')\n *\n * @param {string} modulePath\n * @returns {string}\n */\nexport function hash(modulePath) {\n  return 'e' + md5(modulePath).substring(0, 8);\n}\n\n\nexport const hashFromModulePath = hash;\n", "import { hash } from './hash-from-module-path.js';\nimport { appPath } from './utils.js';\n\nexport { hash } from './hash-from-module-path.js';\n\nexport function hashFromAbsolutePath(absolutePath) {\n  /**\n   * The whole of `appPath` ultimately transforms the `absolutePath`\n   * into the exact string that folks will pass to `relativePath`\n   * at runtime.\n   */\n  const modulePath = appPath(absolutePath);\n  const postfix = hash(modulePath);\n\n  return postfix;\n}\n", "import postcss from 'postcss';\nimport parser from 'postcss-selector-parser';\n\nimport isInsideGlobal from './isInsideGlobal.js';\n\nfunction rewriteSelector(sel, postfix) {\n  const transform = (selectors) => {\n    selectors.walk((selector) => {\n      if (selector.type === 'class' && !isInsideGlobal(selector)) {\n        selector.value += '_' + postfix;\n      } else if (selector.type === 'tag' && !isInsideGlobal(selector)) {\n        selector.replaceWith(\n          parser.tag({ value: selector.value }),\n          parser.className({ value: postfix }),\n        );\n      }\n    });\n\n    // remove :global\n    selectors.walk((selector) => {\n      if (selector.type === 'pseudo' && selector.value === ':global') {\n        selector.replaceWith(...selector.nodes);\n      }\n    });\n  };\n  const transformed = parser(transform).processSync(sel);\n\n  return transformed;\n}\n\nfunction isInsideKeyframes(node) {\n  const parent = node.parent;\n\n  if (!parent) return false;\n  if (parent.type === 'atrule' && parent.name === 'keyframes') return true;\n\n  return isInsideKeyframes(parent);\n}\n\nexport default function rewriteCss(css, postfix, fileName, layerName) {\n  const layerNameWithDefault = layerName ?? 'components';\n  const ast = postcss.parse(css);\n\n  ast.walk((node) => {\n    if (node.type === 'rule' && !isInsideKeyframes(node)) {\n      node.selector = rewriteSelector(node.selector, postfix);\n    }\n  });\n\n  const rewrittenCss = ast.toString();\n\n  if (!layerNameWithDefault) {\n    return `/* ${fileName} */\\n${rewrittenCss}\\n`;\n  }\n\n  return (\n    `/* ${fileName} */\\n@layer ${layerNameWithDefault} {\\n\\n` +\n    rewrittenCss +\n    '\\n}\\n'\n  );\n}\n\n", "export default function isInsideGlobal(node, func) {\n  const parent = node.parent;\n\n  if (!parent) return false;\n  if (parent.type === 'pseudo' && parent.value === ':global') return true;\n\n  return isInsideGlobal(parent, func);\n}\n"],
  "mappings": "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",
  "names": ["import_node_fs", "import_node_path", "md5", "path", "findUp", "fsSync", "parser", "postcss", "path"]
}

@@ -0,0 +1,41 @@
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/build/app-dependency-loader.js
21
+ var app_dependency_loader_exports = {};
22
+ __export(app_dependency_loader_exports, {
23
+ default: () => app_dependency_loader_default
24
+ });
25
+ module.exports = __toCommonJS(app_dependency_loader_exports);
26
+ var import_node_fs = require("node:fs");
27
+ function app_dependency_loader_default(source) {
28
+ if (this.resourcePath.endsWith(".js")) {
29
+ const hbsExists = (0, import_node_fs.existsSync)(this.resourcePath.replace(/\.js/, ".hbs"));
30
+ if (hbsExists) {
31
+ return source;
32
+ }
33
+ }
34
+ const cssPath = this.resourcePath.replace(/(\.js)|(\.hbs)/, ".css");
35
+ const cssExists = (0, import_node_fs.existsSync)(cssPath);
36
+ if (cssExists) {
37
+ this.addDependency(cssPath);
38
+ }
39
+ return source;
40
+ }
41
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2J1aWxkL2FwcC1kZXBlbmRlbmN5LWxvYWRlci5qcyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiaW1wb3J0IHsgZXhpc3RzU3luYyB9IGZyb20gJ25vZGU6ZnMnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiAoc291cmNlKSB7XG4gIGlmICh0aGlzLnJlc291cmNlUGF0aC5lbmRzV2l0aCgnLmpzJykpIHtcbiAgICBjb25zdCBoYnNFeGlzdHMgPSBleGlzdHNTeW5jKHRoaXMucmVzb3VyY2VQYXRoLnJlcGxhY2UoL1xcLmpzLywgJy5oYnMnKSk7XG5cbiAgICBpZiAoaGJzRXhpc3RzKSB7XG4gICAgICByZXR1cm4gc291cmNlO1xuICAgIH1cbiAgfVxuXG4gIGNvbnN0IGNzc1BhdGggPSB0aGlzLnJlc291cmNlUGF0aC5yZXBsYWNlKC8oXFwuanMpfChcXC5oYnMpLywgJy5jc3MnKTtcbiAgY29uc3QgY3NzRXhpc3RzID0gZXhpc3RzU3luYyhjc3NQYXRoKTtcblxuICBpZiAoY3NzRXhpc3RzKSB7XG4gICAgdGhpcy5hZGREZXBlbmRlbmN5KGNzc1BhdGgpO1xuICB9XG5cbiAgcmV0dXJuIHNvdXJjZTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLHFCQUEyQjtBQUVaLFNBQVIsOEJBQWtCLFFBQVE7QUFDL0IsTUFBSSxLQUFLLGFBQWEsU0FBUyxLQUFLLEdBQUc7QUFDckMsVUFBTSxnQkFBWSwyQkFBVyxLQUFLLGFBQWEsUUFBUSxRQUFRLE1BQU0sQ0FBQztBQUV0RSxRQUFJLFdBQVc7QUFDYixhQUFPO0FBQUEsSUFDVDtBQUFBLEVBQ0Y7QUFFQSxRQUFNLFVBQVUsS0FBSyxhQUFhLFFBQVEsa0JBQWtCLE1BQU07QUFDbEUsUUFBTSxnQkFBWSwyQkFBVyxPQUFPO0FBRXBDLE1BQUksV0FBVztBQUNiLFNBQUssY0FBYyxPQUFPO0FBQUEsRUFDNUI7QUFFQSxTQUFPO0FBQ1Q7IiwKICAibmFtZXMiOiBbXQp9Cg==