ember-scoped-css 0.24.2 → 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/README.md +110 -115
- package/declarations/lib/path/template-transform-paths.d.ts.map +1 -1
- package/declarations/lib/path/utils.d.ts.map +1 -1
- package/declarations/lib/path/utils.paths.test.d.ts +0 -3
- package/declarations/lib/path/utils.paths.test.d.ts.map +1 -1
- package/dist/cjs/babel-plugin.cjs +2 -72
- package/dist/cjs/index.cjs +206 -390
- package/dist/cjs/template-plugin.cjs +201 -120
- package/package.json +5 -18
- package/src/build/babel-plugin.js +2 -38
- package/src/build/index.js +4 -0
- package/src/build/scoped-css-unplugin.js +31 -193
- package/src/build/template-plugin.js +124 -9
- package/src/lib/{rewriteCss.js → css/rewrite.js} +2 -2
- package/src/lib/css/utils.js +74 -3
- package/src/lib/path/hash-from-absolute-path.test.ts +2 -24
- package/src/lib/path/template-transform-paths.js +0 -15
- package/src/lib/path/template-transform-paths.test.ts +8 -69
- package/src/lib/path/utils.appPath.test.ts +4 -15
- package/src/lib/path/utils.findWorkspacePath.test.ts +16 -22
- package/src/lib/path/utils.hashFrom.test.ts +8 -8
- package/src/lib/path/utils.isRelevantFile.test.ts +9 -29
- package/src/lib/path/utils.js +2 -79
- package/src/lib/path/utils.paths.test.ts +1 -4
- package/src/lib/request.js +40 -0
- package/src/lib/rewriteHbs.js +1 -1
- package/dist/cjs/app-css-loader.cjs +0 -531
- package/dist/cjs/ember-classic-support.cjs +0 -708
- package/src/build/app-css-livereload-loader.js +0 -119
- package/src/build/app-css-loader.js +0 -38
- package/src/build/ember-classic-support.js +0 -293
- package/src/lib/findCssInJs.js +0 -29
- package/src/lib/getClassesTagsFromCss.js +0 -48
- package/src/lib/getImportedCssFiles.js +0 -19
- package/src/lib/isInsideGlobal.js +0 -8
- package/src/lib/replaceGlimmerAst.js +0 -63
- package/src/lib/replaceHbsInJs.js +0 -113
package/README.md
CHANGED
|
@@ -1,8 +1,42 @@
|
|
|
1
1
|
# ember-scoped-css
|
|
2
2
|
|
|
3
|
-
|
|
3
|
+
Scope your component styles and never worry about a collision ever again.
|
|
4
4
|
|
|
5
|
-
|
|
5
|
+
```gjs
|
|
6
|
+
const greeting = "hello world";
|
|
7
|
+
|
|
8
|
+
<template>
|
|
9
|
+
<div>{{greeting}}</div>
|
|
10
|
+
|
|
11
|
+
<style scoped>
|
|
12
|
+
div {
|
|
13
|
+
color: blue;
|
|
14
|
+
}
|
|
15
|
+
</style>
|
|
16
|
+
</template>
|
|
17
|
+
```
|
|
18
|
+
becomes the equivelent of;
|
|
19
|
+
```gjs
|
|
20
|
+
const greeting = "hello world";
|
|
21
|
+
|
|
22
|
+
<template>
|
|
23
|
+
<div class="abcd1234">{{greeting}}</div>
|
|
24
|
+
|
|
25
|
+
<style scoped>
|
|
26
|
+
div.abcd1234 {
|
|
27
|
+
color: blue;
|
|
28
|
+
}
|
|
29
|
+
</style>
|
|
30
|
+
</template>
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
This is a build-time-only addon, so there is no need to worry about runtime performance.
|
|
34
|
+
|
|
35
|
+
You can also write your styles as a co-located `.css` file, right next to your `.gjs`/`.gts` files.
|
|
36
|
+
Every selector you write in your styles is automatically scoped to the component.
|
|
37
|
+
So you can develop your component with styles isolated from the rest of the application and you don't have to worry about CSS selectors collisions or issues with the CSS cascade.
|
|
38
|
+
|
|
39
|
+
_See [Usage](#usage) for details_.
|
|
6
40
|
|
|
7
41
|
If you want to read more specifics on how this addon achieves isolation with CSS you can read more in the [detailed CSS isolation documentation](docs/css-isolation.md)
|
|
8
42
|
|
|
@@ -11,7 +45,7 @@ As selectors are scoped/renamed during the build process. So there is no perform
|
|
|
11
45
|
The philosophy of `ember-scoped-css` is to stick as close to CSS and HTML as possible and not introduce new syntax or concepts unless it is absolutely necessary.
|
|
12
46
|
|
|
13
47
|
You may also find the docs on [CSS `@layer`](https://developer.mozilla.org/en-US/docs/Web/CSS/@layer) interesting.
|
|
14
|
-
This build tool
|
|
48
|
+
This build tool can emit CSS in a `@layer`.
|
|
15
49
|
|
|
16
50
|
## Compatibility
|
|
17
51
|
|
|
@@ -20,12 +54,21 @@ This build tool emits CSS in a `@layer`.
|
|
|
20
54
|
- non-embroider apps
|
|
21
55
|
- embroider apps
|
|
22
56
|
|
|
23
|
-
| You Have | ember-scoped-css | ember-scoped-css-compat |
|
|
24
|
-
| -------- | ----------- | ---------------------- |
|
|
25
|
-
|
|
|
26
|
-
|
|
|
27
|
-
|
|
|
28
|
-
|
|
|
57
|
+
| You Have | ember-scoped-css | ember-scoped-css-compat | docs |
|
|
58
|
+
| -------- | ----------- | ---------------------- | --- |
|
|
59
|
+
| vite | >= 1.0.0 | 🚫 | [main][docs-main]
|
|
60
|
+
| gjs / gts library (no hbs) | >= 1.0.0 | 🚫 | [main][docs-main]
|
|
61
|
+
| webpack | <= 0.24.3 | <= 10.0.0 | [0.24.3][docs-2]
|
|
62
|
+
| hbs | <= 0.24.3 | <= 10.0.0 | [0.24.3][docs-2]
|
|
63
|
+
| ember-template-imports@v4 or babel-plugin-ember-template-compilation@2.2.5+ | 0.19.0 | 10.0.0 | [0.19][docs-3] - [0.24][docs-2]
|
|
64
|
+
| 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 | [0.18][docs-4]
|
|
65
|
+
| classic components | <= 0.18.0 | <= 8.0.0 | [0.18][docs-4]
|
|
66
|
+
| ember < 4 | <= 0.18.0 | <= 8.0.0 | [0.18][docs-4]
|
|
67
|
+
|
|
68
|
+
[docs-main]: https://github.com/auditboard/ember-scoped-css/
|
|
69
|
+
[docs-2]: https://github.com/auditboard/ember-scoped-css/tree/v0.24.3-ember-scoped-css
|
|
70
|
+
[docs-3]: https://github.com/auditboard/ember-scoped-css/tree/v0.19.1-ember-scoped-css
|
|
71
|
+
[docs-4]: https://github.com/auditboard/ember-scoped-css/tree/ember-scoped-css%400.18.0
|
|
29
72
|
|
|
30
73
|
## Installation for a Vite app
|
|
31
74
|
|
|
@@ -56,6 +99,7 @@ import * as scopedCSS from "ember-scoped-css/build";
|
|
|
56
99
|
module.exports = {
|
|
57
100
|
plugins: [
|
|
58
101
|
// ...
|
|
102
|
+
[scopedCSS.babelPlugin, {}],
|
|
59
103
|
[
|
|
60
104
|
'babel-plugin-ember-template-compilation',
|
|
61
105
|
{
|
|
@@ -70,29 +114,16 @@ module.exports = {
|
|
|
70
114
|
|
|
71
115
|
```
|
|
72
116
|
|
|
73
|
-
|
|
117
|
+
If you have a rollup config:
|
|
118
|
+
```js
|
|
119
|
+
import * as scopedCss from 'ember-scoped-css/build';
|
|
74
120
|
|
|
75
|
-
|
|
76
|
-
|
|
121
|
+
// ...
|
|
122
|
+
plugins: [
|
|
123
|
+
scopedCss.rollupPlugin(),
|
|
124
|
+
]
|
|
77
125
|
```
|
|
78
126
|
|
|
79
|
-
### Configuration
|
|
80
|
-
|
|
81
|
-
In your `ember-cli-build.js`, you can configure the behavior of scoped-css transformations within the app via
|
|
82
|
-
```js
|
|
83
|
-
|
|
84
|
-
const app = new EmberApp(defaults, {
|
|
85
|
-
/* ... */
|
|
86
|
-
'ember-scoped-css': {
|
|
87
|
-
layerName: 'app-styles', // default: 'components', set to false to disable the layer
|
|
88
|
-
additionalRoots: ['routes/'], // default: [], set this to use scoped-css in pods-using apps
|
|
89
|
-
passthrough: ['some-other-file.css'], // default: [] this is only used in a non-embroider app to pass files through the build pipeline
|
|
90
|
-
passthroughDestination: 'assets' // default: undefined this alters where the passthrough files are placed in the output tree
|
|
91
|
-
}
|
|
92
|
-
});
|
|
93
|
-
```
|
|
94
|
-
|
|
95
|
-
Note that supporting `pods` is _opt in_, because all apps can have their pods root directory configured differently.
|
|
96
127
|
|
|
97
128
|
## Installation for an embroider app
|
|
98
129
|
|
|
@@ -100,91 +131,62 @@ Note that supporting `pods` is _opt in_, because all apps can have their pods ro
|
|
|
100
131
|
npm install --save-dev ember-scoped-css ember-scoped-css-compat
|
|
101
132
|
```
|
|
102
133
|
|
|
103
|
-
|
|
104
|
-
```js
|
|
105
|
-
// ember-cli-build.js
|
|
106
|
-
module.exports = async function (defaults) {
|
|
107
|
-
const app = new EmberApp(defaults, { /* ... */ });
|
|
108
|
-
|
|
109
|
-
const { Webpack } = require('@embroider/webpack');
|
|
110
|
-
|
|
111
|
-
return require('@embroider/compat').compatBuild(app, Webpack, {
|
|
112
|
-
/* ... */
|
|
113
|
-
packagerOptions: {
|
|
114
|
-
webpackConfig: {
|
|
115
|
-
module: {
|
|
116
|
-
rules: [
|
|
117
|
-
// css loaders for your app CSS
|
|
118
|
-
{
|
|
119
|
-
test: /\.css$/,
|
|
120
|
-
use: [
|
|
121
|
-
{
|
|
122
|
-
loader: require.resolve(
|
|
123
|
-
'ember-scoped-css/build/app-css-loader'
|
|
124
|
-
),
|
|
125
|
-
options: {
|
|
126
|
-
layerName: 'the-layer-name', // optional
|
|
127
|
-
}
|
|
128
|
-
},
|
|
129
|
-
],
|
|
130
|
-
},
|
|
131
|
-
],
|
|
132
|
-
},
|
|
133
|
-
},
|
|
134
|
-
},
|
|
135
|
-
});
|
|
136
|
-
}
|
|
137
|
-
```
|
|
138
|
-
|
|
139
|
-
## Installation for a V2 Addon
|
|
140
|
-
|
|
141
|
-
```
|
|
142
|
-
npm install --save-dev ember-scoped-css
|
|
143
|
-
```
|
|
144
|
-
|
|
145
|
-
1. If you want to use `.gjs/gts` components, [`@embroider/addon-dev`](https://github.com/embroider-build/embroider/tree/main/packages/addon-dev) provides a plugin for you, `addon.gjs()`.
|
|
146
|
-
|
|
147
|
-
<details><summary>An older approach</summary>
|
|
148
|
-
|
|
149
|
-
There is a deprecated plugin (superseded by `@embroider/addon-dev`) that uses ember-template-imports -- to use this follow the instructions from [rollup-plugin-glimmer-template-tag](https://github.com/NullVoxPopuli/rollup-plugin-glimmer-template-tag) addon.
|
|
150
|
-
|
|
151
|
-
This plugin is not recommended, and is archived.
|
|
152
|
-
|
|
153
|
-
</details>
|
|
134
|
+
### Configuration
|
|
154
135
|
|
|
155
|
-
|
|
136
|
+
All forms of `scopedCss` take an options hash except for the rollup and vite plugins.
|
|
156
137
|
|
|
157
|
-
|
|
158
|
-
+ import { scopedCssUnplugin } from 'ember-scoped-css/build';
|
|
138
|
+
Configuration in the two locations in the babel config should match, for example:
|
|
159
139
|
|
|
160
|
-
// if you want to have some global styles in your addon then
|
|
161
|
-
// put them in the styles folder and change the path to the styles folder
|
|
162
|
-
// if there are no global styles then you can remove addon.keepAssets
|
|
163
|
-
- addon.keepAssets(['**/*.css']),
|
|
164
|
-
+ addon.keepAssets(['**/styles/*.css']),
|
|
165
140
|
|
|
166
|
-
|
|
167
|
-
|
|
141
|
+
```js
|
|
142
|
+
plugins: [
|
|
143
|
+
[scopedCSS.babelPlugin, { layerName: 'my-library' }],
|
|
144
|
+
|
|
145
|
+
[
|
|
146
|
+
'babel-plugin-ember-template-compilation',
|
|
147
|
+
{
|
|
148
|
+
targetFormat: 'hbs',
|
|
149
|
+
transforms: [scopedCSS.templatePlugin({ layerName: 'my-libarry' })],
|
|
150
|
+
},
|
|
151
|
+
],
|
|
152
|
+
],
|
|
168
153
|
```
|
|
169
154
|
|
|
170
|
-
|
|
155
|
+
## Usage
|
|
171
156
|
|
|
172
|
-
|
|
157
|
+
With `ember-scoped-css` you define styles in an inline `<style scoped>` block or `.css` files that are colocated with your components
|
|
173
158
|
|
|
174
|
-
|
|
159
|
+
```gjs
|
|
160
|
+
// ...
|
|
175
161
|
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
162
|
+
<template>
|
|
163
|
+
<div data-test-my-component class='hello-class header'>
|
|
164
|
+
<b>Hello</b>, world!
|
|
165
|
+
</div>
|
|
166
|
+
|
|
167
|
+
<style scoped>
|
|
168
|
+
.hello-class {
|
|
169
|
+
color: red;
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
/* the :global() pseudo-class is used to define a global class.
|
|
173
|
+
It mean that header class wont be scoped to that component */
|
|
174
|
+
.hello-class:global(.header) {
|
|
175
|
+
font-size: 20px;
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
b {
|
|
179
|
+
color: blue;
|
|
180
|
+
}
|
|
181
|
+
</style>
|
|
182
|
+
</template>
|
|
180
183
|
```
|
|
181
184
|
|
|
182
|
-
|
|
185
|
+
Note that `<style>` (without `scoped`) will continue to work as it does today and be "global styles"
|
|
183
186
|
|
|
184
|
-
|
|
187
|
+
<details><summary>separate CSS file</summary>
|
|
185
188
|
|
|
186
189
|
```hbs
|
|
187
|
-
{{! src/components/my-component.hbs }}
|
|
188
190
|
<div data-test-my-component class='hello-class header'><b>Hello</b>, world!</div>
|
|
189
191
|
```
|
|
190
192
|
|
|
@@ -206,22 +208,14 @@ b {
|
|
|
206
208
|
|
|
207
209
|
NOTE: that if you're using pods, css co-located with templates/routes/etc will need to be named `styles.css`
|
|
208
210
|
|
|
211
|
+
</details>
|
|
212
|
+
|
|
209
213
|
|
|
210
214
|
|
|
211
215
|
### Passing classes as arguments to a component
|
|
212
216
|
|
|
213
|
-
There is a `
|
|
217
|
+
There is a `scopedClass` helper that you can use to pass a class name as an argument to a component. The helper takes a class name and returns a scoped class name. `scopedClass` helper is replaced at build time so there is no performance hit when running the app.
|
|
214
218
|
|
|
215
|
-
```hbs
|
|
216
|
-
{{! src/components/my-component.hbs }}
|
|
217
|
-
<OtherComponent @internalClass={{scoped-class 'hello-class'}} />
|
|
218
|
-
<OtherComponent @internalClass={{(scoped-class 'hello-class')}} />
|
|
219
|
-
<OtherComponent
|
|
220
|
-
@internalClass={{concat (scoped-class 'hello-class') ' other-class'}}
|
|
221
|
-
/>
|
|
222
|
-
```
|
|
223
|
-
|
|
224
|
-
In gjs/gts/`<template>`, the above would look like:
|
|
225
219
|
```gjs
|
|
226
220
|
import { scopedClass } from 'ember-scoped-css';
|
|
227
221
|
|
|
@@ -240,15 +234,15 @@ As classes are renamed during the build process you can't directly verify if cla
|
|
|
240
234
|
|
|
241
235
|
The path to the CSS file is always relative to the V2 addon root no matter where the test is located.
|
|
242
236
|
|
|
243
|
-
```
|
|
237
|
+
```gjs
|
|
244
238
|
import { scopedClass } from 'ember-scoped-css/test-support';
|
|
245
239
|
|
|
246
240
|
test('MyComponent has hello-class', async function (assert) {
|
|
247
241
|
assert.expect(1);
|
|
248
242
|
|
|
249
|
-
await render(
|
|
243
|
+
await render(<template>
|
|
250
244
|
<MyComponent />
|
|
251
|
-
|
|
245
|
+
</template>);
|
|
252
246
|
|
|
253
247
|
const rewrittenClass = scopedClass(
|
|
254
248
|
'hello-class',
|
|
@@ -261,7 +255,7 @@ test('MyComponent has hello-class', async function (assert) {
|
|
|
261
255
|
|
|
262
256
|
## Linting
|
|
263
257
|
|
|
264
|
-
`ember-scoped-css` exports a ember-template-lint plugin with one rule `scoped-class-helper`. This lint rule is intended to help you prevent improper use of the `
|
|
258
|
+
`ember-scoped-css` exports a ember-template-lint plugin with one rule `scoped-class-helper`. This lint rule is intended to help you prevent improper use of the `scopedClass` helper which might not be immediately obvious during regular development. You can read more information in the [lint rules documentation](docs/lint-rules.md)
|
|
265
259
|
|
|
266
260
|
### Steps for adding the rule to the project
|
|
267
261
|
|
|
@@ -288,6 +282,7 @@ module.exports = {
|
|
|
288
282
|
],
|
|
289
283
|
rules: {
|
|
290
284
|
+ 'scoped-class-helper': 'error',
|
|
285
|
+
+ 'no-forbidden-elements': ['meta', 'html', 'script'], // style removed
|
|
291
286
|
}
|
|
292
287
|
|
|
293
288
|
```
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"template-transform-paths.d.ts","sourceRoot":"","sources":["../../../src/lib/path/template-transform-paths.js"],"names":[],"mappings":"AAIA;;;;;;;;GAQG;AACH,sCAHW,MAAM,GACJ,MAAM,
|
|
1
|
+
{"version":3,"file":"template-transform-paths.d.ts","sourceRoot":"","sources":["../../../src/lib/path/template-transform-paths.js"],"names":[],"mappings":"AAIA;;;;;;;;GAQG;AACH,sCAHW,MAAM,GACJ,MAAM,CAqDlB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/path/utils.js"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/path/utils.js"],"names":[],"mappings":"AA4BA;;;;;;GAMG;AACH,mCAHW,MAAM,UAShB;AAED;;GAEG;AACH,6EAEC;AA4CD;;;;;;;;;;;;;;;;;;;;;;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;AAED;;;;;;;;;GASG;AACH,yCAJW,MAAM,4BACN;IAAE,eAAe,CAAC,EAAE,MAAM,EAAE,CAAC;IAAC,GAAG,EAAE,MAAM,CAAA;CAAE,uBA0CrD;AAED,8EAsCC;AAED;;;;;;GAMG;AACH,iDAsBC;AA0BD,sEAgCC;AA2BD;;;;GAIG;AACH,uCAFW,MAAM,OAOhB"}
|
|
@@ -1 +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
|
|
1
|
+
{"version":3,"file":"utils.paths.test.d.ts","sourceRoot":"","sources":["../../../src/lib/path/utils.paths.test.ts"],"names":[],"mappings":"AAUA,eAAO,MAAM,KAAK;;;CAGjB,CAAC"}
|
|
@@ -33,9 +33,6 @@ __export(babel_plugin_exports, {
|
|
|
33
33
|
default: () => babel_plugin_default
|
|
34
34
|
});
|
|
35
35
|
module.exports = __toCommonJS(babel_plugin_exports);
|
|
36
|
-
var import_babel_import_util = require("babel-import-util");
|
|
37
|
-
var import_fs = require("fs");
|
|
38
|
-
var import_path = __toESM(require("path"), 1);
|
|
39
36
|
|
|
40
37
|
// src/lib/path/utils.js
|
|
41
38
|
var import_node_assert = __toESM(require("node:assert"), 1);
|
|
@@ -48,59 +45,15 @@ var ourRequire = globalThis.require ? globalThis.require : here && (0, import_no
|
|
|
48
45
|
if (!ourRequire) {
|
|
49
46
|
ourRequire = require;
|
|
50
47
|
}
|
|
51
|
-
var EMBROIDER_DIR = "node_modules/.embroider";
|
|
52
|
-
var EMBROIDER_3_REWRITTEN_APP_PATH = `${EMBROIDER_DIR}/rewritten-app`;
|
|
53
|
-
var EMBROIDER_3_REWRITTEN_APP_ASSETS = `${EMBROIDER_3_REWRITTEN_APP_PATH}/assets`;
|
|
54
|
-
var EMBROIDER_3_REWRITTEN_PACKAGES = `${EMBROIDER_DIR}/rewritten-packages`;
|
|
55
48
|
var IRRELEVANT_PATHS = ["node_modules/.pnpm", "__vite-"];
|
|
56
49
|
var UNSUPPORTED_DIRECTORIES = /* @__PURE__ */ new Set(["tests"]);
|
|
57
50
|
var CWD = process.cwd();
|
|
58
|
-
function cssPathFor(fileName) {
|
|
59
|
-
let withoutExt = withoutExtension(fileName);
|
|
60
|
-
let cssPath = withoutExt + ".css";
|
|
61
|
-
if (isPod(fileName)) {
|
|
62
|
-
cssPath = fileName.replace(/template\.js$/, "styles.css").replace(/template\.hbs/, "styles.css");
|
|
63
|
-
}
|
|
64
|
-
return cssPath;
|
|
65
|
-
}
|
|
66
|
-
function isPodTemplate(filePath) {
|
|
67
|
-
if (filePath.includes("/components/")) {
|
|
68
|
-
return false;
|
|
69
|
-
}
|
|
70
|
-
return filePath.endsWith("template.js") || filePath.endsWith("template.hbs");
|
|
71
|
-
}
|
|
72
|
-
function isPod(filePath) {
|
|
73
|
-
if (filePath.includes("/components/")) {
|
|
74
|
-
return false;
|
|
75
|
-
}
|
|
76
|
-
if (isPodTemplate(filePath)) {
|
|
77
|
-
return true;
|
|
78
|
-
}
|
|
79
|
-
return filePath.endsWith("styles.css");
|
|
80
|
-
}
|
|
81
|
-
function withoutExtension(filePath) {
|
|
82
|
-
let parsed = import_node_path.default.parse(filePath);
|
|
83
|
-
return import_node_path.default.join(parsed.dir, parsed.name);
|
|
84
|
-
}
|
|
85
51
|
function isRelevantFile(fileName, { additionalRoots, cwd }) {
|
|
52
|
+
if (fileName.startsWith("/testem")) return false;
|
|
86
53
|
if (fileName.startsWith("\0")) return false;
|
|
87
54
|
if (fileName.match(/^[a-zA-Z]/)) return false;
|
|
88
55
|
if (fileName.startsWith("/@embroider")) return false;
|
|
89
56
|
if (IRRELEVANT_PATHS.some((i) => fileName.includes(i))) return false;
|
|
90
|
-
if (fileName.includes("/node_modules/")) {
|
|
91
|
-
if (!fileName.includes(EMBROIDER_DIR)) {
|
|
92
|
-
return false;
|
|
93
|
-
}
|
|
94
|
-
if (fileName.includes(EMBROIDER_3_REWRITTEN_PACKAGES)) {
|
|
95
|
-
return false;
|
|
96
|
-
}
|
|
97
|
-
if (fileName.includes(EMBROIDER_3_REWRITTEN_APP_ASSETS)) {
|
|
98
|
-
if (fileName.endsWith(`${EMBROIDER_3_REWRITTEN_APP_ASSETS}/tests.js`)) {
|
|
99
|
-
return false;
|
|
100
|
-
}
|
|
101
|
-
return false;
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
57
|
let workspace = findWorkspacePath(fileName);
|
|
105
58
|
(0, import_node_assert.default)(cwd, `cwd was not passed to isRelevantFile`);
|
|
106
59
|
let ourWorkspace = findWorkspacePath(cwd);
|
|
@@ -132,9 +85,6 @@ function getSeen(sourcePath) {
|
|
|
132
85
|
}
|
|
133
86
|
function findWorkspacePath(sourcePath, options) {
|
|
134
87
|
let cwd = options?.cwd ?? CWD;
|
|
135
|
-
if (sourcePath.includes(EMBROIDER_3_REWRITTEN_APP_PATH)) {
|
|
136
|
-
sourcePath = sourcePath.split(EMBROIDER_3_REWRITTEN_APP_PATH)[0];
|
|
137
|
-
}
|
|
138
88
|
if (sourcePath.endsWith("/")) {
|
|
139
89
|
sourcePath = sourcePath.replace(/\/$/, "");
|
|
140
90
|
}
|
|
@@ -190,7 +140,6 @@ var babel_plugin_default = (env, options, workingDirectory) => {
|
|
|
190
140
|
state.canSkip = true;
|
|
191
141
|
return;
|
|
192
142
|
}
|
|
193
|
-
state.importUtil = new import_babel_import_util.ImportUtil(env, path2);
|
|
194
143
|
}
|
|
195
144
|
},
|
|
196
145
|
ImportDeclaration(path2, state) {
|
|
@@ -220,27 +169,8 @@ var babel_plugin_default = (env, options, workingDirectory) => {
|
|
|
220
169
|
if (path2.node.value.type === "Identifier" && path2.node.value.name === state.file.opts?.importedScopedClass) {
|
|
221
170
|
path2.remove();
|
|
222
171
|
}
|
|
223
|
-
},
|
|
224
|
-
/**
|
|
225
|
-
* If there is a CSS file, AND a corresponding template,
|
|
226
|
-
* we can import the CSS to then defer to the CSS loader
|
|
227
|
-
* or other CSS processing to handle the postfixing
|
|
228
|
-
*/
|
|
229
|
-
CallExpression(path2, state) {
|
|
230
|
-
if (state.canSkip) {
|
|
231
|
-
return;
|
|
232
|
-
}
|
|
233
|
-
const node = path2.node;
|
|
234
|
-
if (node.callee.name === "precompileTemplate" || node.callee.name === "hbs" || node.callee.name === "createTemplateFactory") {
|
|
235
|
-
const fileName = state.file.opts.sourceFileName || state.file.opts.filename;
|
|
236
|
-
let cssPath = cssPathFor(fileName);
|
|
237
|
-
if ((0, import_fs.existsSync)(cssPath)) {
|
|
238
|
-
let baseCSS = import_path.default.basename(cssPath);
|
|
239
|
-
state.importUtil.importForSideEffect(`./${baseCSS}`);
|
|
240
|
-
}
|
|
241
|
-
}
|
|
242
172
|
}
|
|
243
173
|
}
|
|
244
174
|
};
|
|
245
175
|
};
|
|
246
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/build/babel-plugin.js", "../../src/lib/path/utils.js"],
  "sourcesContent": ["import { ImportUtil } from 'babel-import-util';\nimport { existsSync } from 'fs';\nimport nodePath from 'path';\n\nimport { cssPathFor, isRelevantFile } from '../lib/path/utils.js';\n\nfunction _isRelevantFile(state, cwd) {\n  let fileName = state.file.opts.filename;\n  let additionalRoots = state.opts?.additionalRoots;\n\n  return isRelevantFile(fileName, {\n    additionalRoots,\n    cwd,\n  });\n}\n\n/**\n * @param {any} env - babel plugin env, env.types is most commonly used (esp in TS)\n * @param {object} options - the options for scoped-css -- this is also available in each visitor's state.opts\n * @param {string} workingDirectory\n */\nexport default (env, options, workingDirectory) => {\n  /**\n   * This babel plugin does three things:\n   * - removes the import of scopedClass, if it exists\n   *   - if scopedClass was imported, it is removed from any component's \"scope bag\"\n   *     (the scope bag being a low-level object used for passing what is \"in scope\" for a component)\n   * - adds an import to the CSS file, if it exists\n   */\n  return {\n    visitor: {\n      Program: {\n        enter(path, state) {\n          if (!_isRelevantFile(state, workingDirectory)) {\n            state.canSkip = true;\n\n            return;\n          }\n\n          state.importUtil = new ImportUtil(env, path);\n        },\n      },\n      ImportDeclaration(path, state) {\n        if (state.canSkip) {\n          return;\n        }\n\n        if (path.node.source.value === 'ember-scoped-css') {\n          let specifier = path.node.specifiers.find(\n            (x) => x.imported.name === 'scopedClass',\n          );\n\n          if (specifier) {\n            state.file.opts.importedScopedClass = specifier.local.name;\n          }\n\n          if (specifier.local.name !== 'scopedClass') {\n            throw new Error(\n              `The scopedClass import is a psuedo-helper, and may not be renamed as it is removed at build time.`,\n            );\n          }\n\n          path.remove();\n        }\n      },\n      /**\n       * Only in strict mode, do we care about remoning the scope bag reference\n       */\n      ObjectProperty(path, state) {\n        if (!state.file.opts?.importedScopedClass) return;\n\n        if (\n          path.node.value.type === 'Identifier' &&\n          path.node.value.name === state.file.opts?.importedScopedClass\n        ) {\n          path.remove();\n        }\n      },\n      /**\n       * If there is a CSS file, AND a corresponding template,\n       * we can import the CSS to then defer to the CSS loader\n       * or other CSS processing to handle the postfixing\n       */\n      CallExpression(path, state) {\n        if (state.canSkip) {\n          return;\n        }\n\n        const node = path.node;\n\n        if (\n          node.callee.name === 'precompileTemplate' ||\n          node.callee.name === 'hbs' ||\n          node.callee.name === 'createTemplateFactory'\n        ) {\n          const fileName =\n            state.file.opts.sourceFileName || state.file.opts.filename;\n\n          let cssPath = cssPathFor(fileName);\n\n          if (existsSync(cssPath)) {\n            let baseCSS = nodePath.basename(cssPath);\n\n            state.importUtil.importForSideEffect(`./${baseCSS}`);\n          }\n        }\n      },\n    },\n  };\n};\n", "import assert from 'node:assert';\nimport fsSync, { existsSync } from 'node:fs';\nimport { createRequire } from 'node:module';\nimport path from 'node:path';\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\nconst COMPONENT_EXTENSIONS = ['.gts', '.gjs', '.ts', '.js', '.hbs'];\n\n// CJS / ESM?\nlet here = import.meta.url;\nlet ourRequire = globalThis.require\n  ? globalThis.require\n  : here && createRequire(here);\n\nif (!ourRequire) {\n  // eslint-disable-next-line no-undef\n  ourRequire = require;\n}\n\nconst EMBROIDER_DIR = 'node_modules/.embroider';\nconst EMBROIDER_3_REWRITTEN_APP_PATH = `${EMBROIDER_DIR}/rewritten-app`;\nconst EMBROIDER_3_REWRITTEN_APP_ASSETS = `${EMBROIDER_3_REWRITTEN_APP_PATH}/assets`;\nconst EMBROIDER_3_REWRITTEN_PACKAGES = `${EMBROIDER_DIR}/rewritten-packages`;\nconst IRRELEVANT_PATHS = ['node_modules/.pnpm', '__vite-'];\nconst UNSUPPORTED_DIRECTORIES = new Set(['tests']);\n\nconst CWD = process.cwd();\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 *\n */\nexport function cssHasAssociatedComponent(cssPath) {\n  return cssHasStandardFile(cssPath) || cssHasPodsFile(cssPath);\n}\n\nfunction cssHasStandardFile(id) {\n  /**\n   * Normally we don't need to check a JS path here, but when using\n   * embroider@3, we have a \"rewritten app\", which has all our source\n   * preprocessed a bit before scoped-css transformations.\n   *\n   * (In Vite, we operate more directly with the source)\n   */\n  for (let ext of COMPONENT_EXTENSIONS) {\n    let candidatePath = id.replace(/\\.css$/, ext);\n\n    if (existsSync(candidatePath)) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\nfunction cssHasPodsFile(id) {\n  if (!id.endsWith('styles.css')) {\n    return;\n  }\n\n  /**\n   * Normally we don't need to check a JS path here, but when using\n   * embroider@3, we have a \"rewritten app\", which has all our source\n   * preprocessed a bit before scoped-css transformations.\n   *\n   * (In Vite, we operate more directly with the source)\n   */\n  for (let ext of COMPONENT_EXTENSIONS) {\n    let candidatePath = id.replace(/styles\\.css$/, `template${ext}`);\n\n    if (existsSync(candidatePath)) {\n      return true;\n    }\n  }\n\n  return false;\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\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 {{ additionalRoots?: string[]; cwd: string }} options\n * @returns\n */\nexport function isRelevantFile(fileName, { additionalRoots, cwd }) {\n  // Private Virtual Modules\n  if (fileName.startsWith('\\0')) return false;\n  // These are not valid userland names (or are from libraries)\n  if (fileName.match(/^[a-zA-Z]/)) return false;\n  // External to us\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(EMBROIDER_DIR)) {\n      return false;\n    }\n\n    // rewritten packages should have already been processed at their own\n    // publish time\n    if (fileName.includes(EMBROIDER_3_REWRITTEN_PACKAGES)) {\n      return false;\n    }\n\n    // These are already the bundled files.\n    if (fileName.includes(EMBROIDER_3_REWRITTEN_APP_ASSETS)) {\n      // not supported, never will be\n      if (fileName.endsWith(`${EMBROIDER_3_REWRITTEN_APP_ASSETS}/tests.js`)) {\n        return false;\n      }\n\n      // Ideally, we never get here -- indicates we're not filtering effectively in babel\n      // NOTE: if we get here, we're trying to operate on a file too late.\n      //       we need ScopedCSS to operate as close to original source as possible -- not output files.\n      return false;\n    }\n  }\n\n  let workspace = findWorkspacePath(fileName);\n\n  assert(cwd, `cwd was not passed to isRelevantFile`);\n\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/', '/templates/', ...(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 = moduleName(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    `${EMBROIDER_3_REWRITTEN_APP_PATH}/`,\n    '/',\n  );\n\n  // Any of the above relpacements could accidentally give us an extra / (depending on our build environment)\n  packageRelative = packageRelative.replace('//', '/');\n\n  let localPackagerStylePath = packageScopedPathToModulePath(packageRelative);\n\n  return `${name}${localPackagerStylePath}`;\n}\n\n/**\n * To avoid hitting the filesysetm, we'll store all found\n * project paths bere, so we can, in memory,\n * get the folder where a package.json exists, rather than\n * hit the file system every time.\n */\nconst SEEN = new Set();\n\nfunction getSeen(sourcePath) {\n  if (SEEN.has(sourcePath)) return sourcePath;\n\n  let parts = sourcePath.split('/');\n\n  for (let i = parts.length - 1; i > 1; i--) {\n    let toCheck = parts.slice(0, i).join('/');\n\n    let seen = SEEN.has(toCheck);\n\n    if (seen) {\n      return toCheck;\n    }\n  }\n}\n\nexport function findWorkspacePath(sourcePath, options) {\n  let cwd = options?.cwd ?? CWD;\n\n  if (sourcePath.includes(EMBROIDER_3_REWRITTEN_APP_PATH)) {\n    sourcePath = sourcePath.split(EMBROIDER_3_REWRITTEN_APP_PATH)[0];\n  }\n\n  if (sourcePath.endsWith('/')) {\n    sourcePath = sourcePath.replace(/\\/$/, '');\n  }\n\n  let seen = getSeen(sourcePath);\n\n  if (seen) {\n    return seen;\n  }\n\n  let candidatePath = path.join(sourcePath, 'package.json');\n\n  const isWorkspace = fsSync.existsSync(candidatePath);\n\n  if (isWorkspace) {\n    return sourcePath;\n  }\n\n  const packageJsonPath = findPackageJsonUp(sourcePath, { cwd });\n\n  if (!packageJsonPath) {\n    throw new Error(`Could not determine project for ${sourcePath}`);\n  }\n\n  const workspacePath = path.dirname(packageJsonPath);\n\n  SEEN.add(workspacePath);\n\n  return workspacePath;\n}\n\nfunction findPackageJsonUp(startPath, options) {\n  let cwd = options?.cwd ?? CWD;\n  let parts = startPath.split('/');\n\n  for (let i = parts.length - 1; i > 1; i--) {\n    let toCheck = parts.slice(0, i).join('/');\n\n    let packageJson = path.join(toCheck, 'package.json');\n    let exists = fsSync.existsSync(packageJson);\n\n    if (exists) {\n      return packageJson;\n    }\n\n    // Don't traverse all the way to the root of the file system.\n    if (toCheck === cwd) {\n      break;\n    }\n  }\n\n  return null;\n}\n\nconst MANIFEST_CACHE = new Map();\n\n/**\n * Will return the package.json#name, or config/environment#moudlePrefix (if v1 app)\n *\n * @param {string} sourcePath\n */\nexport function moduleName(sourcePath) {\n  const workspace = findWorkspacePath(sourcePath);\n  const manifest = getManifest(workspace);\n\n  if (manifest['ember-addon']) {\n    /**\n     * Libraries are not allowed to customize their module name\n     * to be different from their package name.\n     *\n     * (It's also bonkers that this is allowed for v1 apps)\n     */\n    return manifest.name;\n  }\n\n  /**\n   * For v1 apps, we need to reference the config/environment.js file\n   * to see if the modulePrefix setting differs from manifest.name;\n   */\n  let environmentJS = path.join(workspace, 'config/environment.js');\n\n  /**\n   * NOTE: the environment.js is a commonJS file, so we can synchronously require it\n   *\n   * TODO: if we have issues with loading this file later we should probably just run jscodeshift on it\n   *       but that could allow us to be brittle in different ways, like if folks stray from the way the\n   *       file is laid out from the blueprint defaults.\n   */\n  if (fsSync.existsSync(environmentJS)) {\n    // eslint-disable-next-line no-undef -- this exists\n    const envFn = ourRequire(environmentJS);\n    const env = envFn('ember-scoped-css');\n\n    return env.modulePrefix || manifest.name;\n  }\n\n  /**\n   * Fallback to the true\u2122 module\u2122 name.\n   */\n  return manifest.name;\n}\n\n/**\n * @param {string} workspace\n */\nfunction getManifest(workspace) {\n  let existing = MANIFEST_CACHE.get(workspace);\n\n  if (existing) {\n    return existing;\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;\n}\n"],
  "mappings": "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",
  "names": ["path", "assert", "path", "fsSync", "path", "nodePath"]
}

|
|
176
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/build/babel-plugin.js", "../../src/lib/path/utils.js"],
  "sourcesContent": ["import { isRelevantFile } from '../lib/path/utils.js';\n\nfunction _isRelevantFile(state, cwd) {\n  let fileName = state.file.opts.filename;\n  let additionalRoots = state.opts?.additionalRoots;\n\n  return isRelevantFile(fileName, {\n    additionalRoots,\n    cwd,\n  });\n}\n\n/**\n * @param {any} env - babel plugin env, env.types is most commonly used (esp in TS)\n * @param {object} options - the options for scoped-css -- this is also available in each visitor's state.opts\n * @param {string} workingDirectory\n */\nexport default (env, options, workingDirectory) => {\n  /**\n   * This babel plugin does two things:\n   * - removes the import of scopedClass, if it exists\n   *   - if scopedClass was imported, it is removed from any component's \"scope bag\"\n   *     (the scope bag being a low-level object used for passing what is \"in scope\" for a component)\n   */\n  return {\n    visitor: {\n      Program: {\n        enter(path, state) {\n          if (!_isRelevantFile(state, workingDirectory)) {\n            state.canSkip = true;\n\n            return;\n          }\n        },\n      },\n      ImportDeclaration(path, state) {\n        if (state.canSkip) {\n          return;\n        }\n\n        if (path.node.source.value === 'ember-scoped-css') {\n          let specifier = path.node.specifiers.find(\n            (x) => x.imported.name === 'scopedClass',\n          );\n\n          if (specifier) {\n            state.file.opts.importedScopedClass = specifier.local.name;\n          }\n\n          if (specifier.local.name !== 'scopedClass') {\n            throw new Error(\n              `The scopedClass import is a psuedo-helper, and may not be renamed as it is removed at build time.`,\n            );\n          }\n\n          path.remove();\n        }\n      },\n      /**\n       * Only in strict mode, do we care about remoning the scope bag reference\n       */\n      ObjectProperty(path, state) {\n        if (!state.file.opts?.importedScopedClass) return;\n\n        if (\n          path.node.value.type === 'Identifier' &&\n          path.node.value.name === state.file.opts?.importedScopedClass\n        ) {\n          path.remove();\n        }\n      },\n    },\n  };\n};\n", "import assert from 'node:assert';\nimport fsSync, { existsSync } from 'node:fs';\nimport { createRequire } from 'node:module';\nimport path from 'node:path';\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\nconst COMPONENT_EXTENSIONS = ['.gts', '.gjs', '.ts', '.js', '.hbs'];\n\n// CJS / ESM?\nlet here = import.meta.url;\nlet ourRequire = globalThis.require\n  ? globalThis.require\n  : here && createRequire(here);\n\nif (!ourRequire) {\n  ourRequire = require;\n}\n\nconst IRRELEVANT_PATHS = ['node_modules/.pnpm', '__vite-'];\nconst UNSUPPORTED_DIRECTORIES = new Set(['tests']);\n\nconst CWD = process.cwd();\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 *\n */\nexport function cssHasAssociatedComponent(cssPath) {\n  return cssHasStandardFile(cssPath) || cssHasPodsFile(cssPath);\n}\n\nfunction cssHasStandardFile(id) {\n  /**\n   * Normally we don't need to check a JS path here, but when using\n   * embroider@3, we have a \"rewritten app\", which has all our source\n   * preprocessed a bit before scoped-css transformations.\n   *\n   * (In Vite, we operate more directly with the source)\n   */\n  for (let ext of COMPONENT_EXTENSIONS) {\n    let candidatePath = id.replace(/\\.css$/, ext);\n\n    if (existsSync(candidatePath)) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\nfunction cssHasPodsFile(id) {\n  if (!id.endsWith('styles.css')) {\n    return;\n  }\n\n  /**\n   * Normally we don't need to check a JS path here, but when using\n   * embroider@3, we have a \"rewritten app\", which has all our source\n   * preprocessed a bit before scoped-css transformations.\n   *\n   * (In Vite, we operate more directly with the source)\n   */\n  for (let ext of COMPONENT_EXTENSIONS) {\n    let candidatePath = id.replace(/styles\\.css$/, `template${ext}`);\n\n    if (existsSync(candidatePath)) {\n      return true;\n    }\n  }\n\n  return false;\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\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 {{ additionalRoots?: string[]; cwd: string }} options\n * @returns\n */\nexport function isRelevantFile(fileName, { additionalRoots, cwd }) {\n  // Fake file handled by testem server when it runs\n  if (fileName.startsWith('/testem')) return false;\n  // Private Virtual Modules\n  if (fileName.startsWith('\\0')) return false;\n  // These are not valid userland names (or are from libraries)\n  if (fileName.match(/^[a-zA-Z]/)) return false;\n  // External to us\n  if (fileName.startsWith('/@embroider')) return false;\n  if (IRRELEVANT_PATHS.some((i) => fileName.includes(i))) return false;\n\n  let workspace = findWorkspacePath(fileName);\n\n  assert(cwd, `cwd was not passed to isRelevantFile`);\n\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/', '/templates/', ...(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 = moduleName(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  // Any of the above relpacements could accidentally give us an extra / (depending on our build environment)\n  packageRelative = packageRelative.replace('//', '/');\n\n  let localPackagerStylePath = packageScopedPathToModulePath(packageRelative);\n\n  return `${name}${localPackagerStylePath}`;\n}\n\n/**\n * To avoid hitting the filesysetm, we'll store all found\n * project paths bere, so we can, in memory,\n * get the folder where a package.json exists, rather than\n * hit the file system every time.\n */\nconst SEEN = new Set();\n\nfunction getSeen(sourcePath) {\n  if (SEEN.has(sourcePath)) return sourcePath;\n\n  let parts = sourcePath.split('/');\n\n  for (let i = parts.length - 1; i > 1; i--) {\n    let toCheck = parts.slice(0, i).join('/');\n\n    let seen = SEEN.has(toCheck);\n\n    if (seen) {\n      return toCheck;\n    }\n  }\n}\n\nexport function findWorkspacePath(sourcePath, options) {\n  let cwd = options?.cwd ?? CWD;\n\n  if (sourcePath.endsWith('/')) {\n    sourcePath = sourcePath.replace(/\\/$/, '');\n  }\n\n  let seen = getSeen(sourcePath);\n\n  if (seen) {\n    return seen;\n  }\n\n  let candidatePath = path.join(sourcePath, 'package.json');\n\n  const isWorkspace = fsSync.existsSync(candidatePath);\n\n  if (isWorkspace) {\n    return sourcePath;\n  }\n\n  const packageJsonPath = findPackageJsonUp(sourcePath, { cwd });\n\n  if (!packageJsonPath) {\n    throw new Error(`Could not determine project for ${sourcePath}`);\n  }\n\n  const workspacePath = path.dirname(packageJsonPath);\n\n  SEEN.add(workspacePath);\n\n  return workspacePath;\n}\n\nfunction findPackageJsonUp(startPath, options) {\n  let cwd = options?.cwd ?? CWD;\n  let parts = startPath.split('/');\n\n  for (let i = parts.length - 1; i > 1; i--) {\n    let toCheck = parts.slice(0, i).join('/');\n\n    let packageJson = path.join(toCheck, 'package.json');\n    let exists = fsSync.existsSync(packageJson);\n\n    if (exists) {\n      return packageJson;\n    }\n\n    // Don't traverse all the way to the root of the file system.\n    if (toCheck === cwd) {\n      break;\n    }\n  }\n\n  return null;\n}\n\nconst MANIFEST_CACHE = new Map();\n\n/**\n * Will return the package.json#name, or config/environment#moudlePrefix (if v1 app)\n *\n * @param {string} sourcePath\n */\nexport function moduleName(sourcePath) {\n  const workspace = findWorkspacePath(sourcePath);\n  const manifest = getManifest(workspace);\n\n  return manifest.name;\n}\n\n/**\n * @param {string} workspace\n */\nfunction getManifest(workspace) {\n  let existing = MANIFEST_CACHE.get(workspace);\n\n  if (existing) {\n    return existing;\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;\n}\n"],
  "mappings": "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",
  "names": ["assert", "path", "fsSync", "path"]
}

|