ember-scoped-css 0.23.2 → 0.23.3
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/declarations/lib/path/utils.d.ts.map +1 -1
- package/dist/cjs/app-css-loader.cjs +3 -1
- package/dist/cjs/babel-plugin.cjs +3 -1
- package/dist/cjs/ember-classic-support.cjs +1 -1
- package/dist/cjs/index.cjs +7 -1
- package/dist/cjs/template-plugin.cjs +3 -1
- package/package.json +1 -1
- package/src/build/scoped-css-unplugin.js +8 -1
- package/src/lib/path/utils.js +5 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/path/utils.js"],"names":[],"mappings":"AAmBA;;;;;;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;AAED;;;;;;;;;GASG;AACH,yCAJW,MAAM,4BACN;IAAE,eAAe,CAAC,EAAE,MAAM,EAAE,CAAC;IAAC,GAAG,EAAE,MAAM,CAAA;CAAE,
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/path/utils.js"],"names":[],"mappings":"AAmBA;;;;;;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;AAED;;;;;;;;;GASG;AACH,yCAJW,MAAM,4BACN;IAAE,eAAe,CAAC,EAAE,MAAM,EAAE,CAAC;IAAC,GAAG,EAAE,MAAM,CAAA;CAAE,uBAmErD;AAED,8EAsCC;AAED;;;;;;GAMG;AACH,iDA4BC;AA0BD,sEAoCC;AA2BD;;;;GAIG;AACH,uCAFW,MAAM,OAyChB"}
|
|
@@ -85,6 +85,8 @@ function isPod(filePath) {
|
|
|
85
85
|
return filePath.endsWith("styles.css");
|
|
86
86
|
}
|
|
87
87
|
function isRelevantFile(fileName, { additionalRoots, cwd }) {
|
|
88
|
+
if (fileName.startsWith("\0")) return false;
|
|
89
|
+
if (fileName.match(/^[a-zA-Z]/)) return false;
|
|
88
90
|
if (fileName.startsWith("/@embroider")) return false;
|
|
89
91
|
if (IRRELEVANT_PATHS.some((i) => fileName.includes(i))) return false;
|
|
90
92
|
if (fileName.includes("/node_modules/")) {
|
|
@@ -305,4 +307,4 @@ async function app_css_loader_default(code) {
|
|
|
305
307
|
}
|
|
306
308
|
return code;
|
|
307
309
|
}
|
|
308
|
-
//# 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, isRelevantFile } 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 (!isRelevantFile(cssPath, { ...options, cwd: this.rootContext })) {\n    return code;\n  }\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 gtsPath = cssPath.replace('.css', '.ts');\n\n  if (existsSync(gjsPath) || existsSync(gtsPath) || existsSync(hbsPath)) {\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 assert from 'node:assert';\nimport fsSync from 'node:fs';\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 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'];\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 * 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  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  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 = require(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", "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": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,IAAAA,kBAA2B;AAC3B,IAAAC,oBAAiB;;;ACFjB,yBAAmB;AACnB,qBAAmB;AACnB,uBAAiB;;;ACFjB,yBAAgB;AAgBT,SAAS,KAAK,YAAY;AAC/B,SAAO,UAAM,mBAAAC,SAAI,UAAU,EAAE,UAAU,GAAG,CAAC;AAC7C;AAGO,IAAM,qBAAqB;;;AChB3B,SAAS,qBAAqB,cAAc;AAMjD,QAAM,aAAa,QAAQ,YAAY;AACvC,QAAM,UAAU,KAAK,UAAU;AAE/B,SAAO;AACT;;;AFLA,IAAM,gBAAgB;AACtB,IAAM,iCAAiC,GAAG,aAAa;AACvD,IAAM,mCAAmC,GAAG,8BAA8B;AAC1E,IAAM,iCAAiC,GAAG,aAAa;AACvD,IAAM,mBAAmB,CAAC,oBAAoB;AAC9C,IAAM,0BAA0B,oBAAI,IAAI,CAAC,OAAO,CAAC;AAEjD,IAAM,MAAM,QAAQ,IAAI;AASjB,SAAS,SAAS,UAAU;AACjC,MAAI,SAAS,WAAW,GAAG,GAAG;AAC5B,WAAO,qBAAqB,QAAQ;AAAA,EACtC;AAEA,SAAO,mBAAmB,QAAQ;AACpC;AA4CO,SAAS,cAAc,UAAU;AACtC,MAAI,SAAS,SAAS,cAAc,GAAG;AACrC,WAAO;AAAA,EACT;AAEA,SAAO,SAAS,SAAS,aAAa,KAAK,SAAS,SAAS,cAAc;AAC7E;AAaO,SAAS,MAAM,UAAU;AAC9B,MAAI,SAAS,SAAS,cAAc,GAAG;AACrC,WAAO;AAAA,EACT;AAEA,MAAI,cAAc,QAAQ,GAAG;AAC3B,WAAO;AAAA,EACT;AAEA,SAAO,SAAS,SAAS,YAAY;AACvC;AAuBO,SAAS,eAAe,UAAU,EAAE,iBAAiB,IAAI,GAAG;AACjE,MAAI,SAAS,WAAW,aAAa,EAAG,QAAO;AAC/C,MAAI,iBAAiB,KAAK,CAAC,MAAM,SAAS,SAAS,CAAC,CAAC,EAAG,QAAO;AAE/D,MAAI,SAAS,SAAS,gBAAgB,GAAG;AAGvC,QAAI,CAAC,SAAS,SAAS,aAAa,GAAG;AACrC,aAAO;AAAA,IACT;AAIA,QAAI,SAAS,SAAS,8BAA8B,GAAG;AACrD,aAAO;AAAA,IACT;AAGA,QAAI,SAAS,SAAS,gCAAgC,GAAG;AAEvD,UAAI,SAAS,SAAS,GAAG,gCAAgC,WAAW,GAAG;AACrE,eAAO;AAAA,MACT;AAKA,aAAO;AAAA,IACT;AAAA,EACF;AAEA,MAAI,YAAY,kBAAkB,QAAQ;AAE1C,yBAAAC,SAAO,KAAK,sCAAsC;AAElD,MAAI,eAAe,kBAAkB,GAAG;AAExC,MAAI,cAAc,cAAc;AAC9B,WAAO;AAAA,EACT;AAEA,MAAI,QAAQ,SAAS,QAAQ,WAAW,EAAE;AAC1C,MAAI,CAAC,EAAE,GAAG,KAAK,IAAI,MAAM,MAAM,GAAG,EAAE,OAAO,OAAO;AAElD,MAAI,wBAAwB,IAAI,MAAM,CAAC,CAAC,GAAG;AACzC,WAAO;AAAA,EACT;AAMA,MAAI,QAAQ,CAAC,gBAAgB,eAAe,GAAI,mBAAmB,CAAC,CAAE;AAEtE,MAAI,CAAC,MAAM,KAAK,CAAC,SAAS,SAAS,SAAS,IAAI,CAAC,GAAG;AAClD;AAAA,EACF;AAEA,SAAO;AACT;AAEO,SAAS,8BAA8B,mBAAmB;AAc/D,MAAI,kBAAkB,kBAAkB,QAAQ,YAAY,GAAG;AAE/D,MAAI,SAAS,iBAAAC,QAAK,MAAM,eAAe;AAEvC,MAAI,MAAM,eAAe,GAAG;AAI1B,WAAO,OAAO;AAAA,EAChB;AAYA,MAAI,yBAAyB,iBAAAA,QAAK,KAAK,OAAO,KAAK,OAAO,IAAI;AAE9D,SAAO;AACT;AASO,SAAS,QAAQ,YAAY;AAClC,MAAI,gBAAgB,kBAAkB,UAAU;AAChD,MAAI,OAAO,WAAW,UAAU;AAOhC,MAAI,kBAAkB,WAAW,QAAQ,eAAe,EAAE;AAK1D,oBAAkB,gBAAgB,QAAQ,SAAS,GAAG;AAMtD,oBAAkB,gBAAgB;AAAA,IAChC,GAAG,8BAA8B;AAAA,IACjC;AAAA,EACF;AAEA,MAAI,yBAAyB,8BAA8B,eAAe;AAE1E,SAAO,GAAG,IAAI,GAAG,sBAAsB;AACzC;AAQA,IAAM,OAAO,oBAAI,IAAI;AAErB,SAAS,QAAQ,YAAY;AAC3B,MAAI,KAAK,IAAI,UAAU,EAAG,QAAO;AAEjC,MAAI,QAAQ,WAAW,MAAM,GAAG;AAEhC,WAAS,IAAI,MAAM,SAAS,GAAG,IAAI,GAAG,KAAK;AACzC,QAAI,UAAU,MAAM,MAAM,GAAG,CAAC,EAAE,KAAK,GAAG;AAExC,QAAI,OAAO,KAAK,IAAI,OAAO;AAE3B,QAAI,MAAM;AACR,aAAO;AAAA,IACT;AAAA,EACF;AACF;AAEO,SAAS,kBAAkB,YAAY,SAAS;AACrD,MAAI,MAAM,SAAS,OAAO;AAE1B,MAAI,WAAW,SAAS,8BAA8B,GAAG;AACvD,iBAAa,WAAW,MAAM,8BAA8B,EAAE,CAAC;AAAA,EACjE;AAEA,MAAI,WAAW,SAAS,GAAG,GAAG;AAC5B,iBAAa,WAAW,QAAQ,OAAO,EAAE;AAAA,EAC3C;AAEA,MAAI,OAAO,QAAQ,UAAU;AAE7B,MAAI,MAAM;AACR,WAAO;AAAA,EACT;AAEA,MAAI,gBAAgB,iBAAAA,QAAK,KAAK,YAAY,cAAc;AAExD,QAAM,cAAc,eAAAC,QAAO,WAAW,aAAa;AAEnD,MAAI,aAAa;AACf,WAAO;AAAA,EACT;AAEA,QAAM,kBAAkB,kBAAkB,YAAY,EAAE,IAAI,CAAC;AAE7D,MAAI,CAAC,iBAAiB;AACpB,UAAM,IAAI,MAAM,mCAAmC,UAAU,EAAE;AAAA,EACjE;AAEA,QAAM,gBAAgB,iBAAAD,QAAK,QAAQ,eAAe;AAElD,OAAK,IAAI,aAAa;AAEtB,SAAO;AACT;AAEA,SAAS,kBAAkB,WAAW,SAAS;AAC7C,MAAI,MAAM,SAAS,OAAO;AAC1B,MAAI,QAAQ,UAAU,MAAM,GAAG;AAE/B,WAAS,IAAI,MAAM,SAAS,GAAG,IAAI,GAAG,KAAK;AACzC,QAAI,UAAU,MAAM,MAAM,GAAG,CAAC,EAAE,KAAK,GAAG;AAExC,QAAI,cAAc,iBAAAA,QAAK,KAAK,SAAS,cAAc;AACnD,QAAI,SAAS,eAAAC,QAAO,WAAW,WAAW;AAE1C,QAAI,QAAQ;AACV,aAAO;AAAA,IACT;AAGA,QAAI,YAAY,KAAK;AACnB;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AACT;AAEA,IAAM,iBAAiB,oBAAI,IAAI;AAOxB,SAAS,WAAW,YAAY;AACrC,QAAM,YAAY,kBAAkB,UAAU;AAC9C,QAAM,WAAW,YAAY,SAAS;AAEtC,MAAI,SAAS,aAAa,GAAG;AAO3B,WAAO,SAAS;AAAA,EAClB;AAMA,MAAI,gBAAgB,iBAAAD,QAAK,KAAK,WAAW,uBAAuB;AAShE,MAAI,eAAAC,QAAO,WAAW,aAAa,GAAG;AAEpC,UAAM,QAAQ,QAAQ,aAAa;AACnC,UAAM,MAAM,MAAM,kBAAkB;AAEpC,WAAO,IAAI,gBAAgB,SAAS;AAAA,EACtC;AAKA,SAAO,SAAS;AAClB;AAKA,SAAS,YAAY,WAAW;AAC9B,MAAI,WAAW,eAAe,IAAI,SAAS;AAE3C,MAAI,UAAU;AACZ,WAAO;AAAA,EACT;AAEA,MAAI,SAAS,eAAAA,QAAO,aAAa,iBAAAD,QAAK,KAAK,WAAW,cAAc,CAAC;AACrE,MAAI,UAAU,OAAO,SAAS;AAC9B,MAAI,OAAO,KAAK,MAAM,OAAO;AAE7B,iBAAe,IAAI,WAAW,IAAI;AAElC,SAAO;AACT;;;AGhaA,qBAAoB;AACpB,qCAAmB;;;ACDJ,SAAR,eAAgC,MAAM,MAAM;AACjD,QAAM,SAAS,KAAK;AAEpB,MAAI,CAAC,OAAQ,QAAO;AACpB,MAAI,OAAO,SAAS,YAAY,OAAO,UAAU,UAAW,QAAO;AAEnE,SAAO,eAAe,QAAQ,IAAI;AACpC;;;ADFA,SAAS,gBAAgB,KAAK,SAAS;AACrC,QAAM,YAAY,CAAC,cAAc;AAC/B,cAAU,KAAK,CAAC,aAAa;AAC3B,UAAI,SAAS,SAAS,WAAW,CAAC,eAAe,QAAQ,GAAG;AAC1D,iBAAS,SAAS,MAAM;AAAA,MAC1B,WAAW,SAAS,SAAS,SAAS,CAAC,eAAe,QAAQ,GAAG;AAC/D,iBAAS;AAAA,UACP,+BAAAE,QAAO,IAAI,EAAE,OAAO,SAAS,MAAM,CAAC;AAAA,UACpC,+BAAAA,QAAO,UAAU,EAAE,OAAO,QAAQ,CAAC;AAAA,QACrC;AAAA,MACF;AAAA,IACF,CAAC;AAGD,cAAU,KAAK,CAAC,aAAa;AAC3B,UAAI,SAAS,SAAS,YAAY,SAAS,UAAU,WAAW;AAC9D,iBAAS,YAAY,GAAG,SAAS,KAAK;AAAA,MACxC;AAAA,IACF,CAAC;AAAA,EACH;AACA,QAAM,kBAAc,+BAAAA,SAAO,SAAS,EAAE,YAAY,GAAG;AAErD,SAAO;AACT;AAEA,SAAS,kBAAkB,MAAM;AAC/B,QAAM,SAAS,KAAK;AAEpB,MAAI,CAAC,OAAQ,QAAO;AACpB,MAAI,OAAO,SAAS,YAAY,OAAO,SAAS,YAAa,QAAO;AAEpE,SAAO,kBAAkB,MAAM;AACjC;AAEe,SAAR,WAA4B,KAAK,SAAS,UAAU,WAAW;AACpE,QAAM,uBAAuB,aAAa;AAC1C,QAAM,MAAM,eAAAC,QAAQ,MAAM,GAAG;AAE7B,MAAI,KAAK,CAAC,SAAS;AACjB,QAAI,KAAK,SAAS,UAAU,CAAC,kBAAkB,IAAI,GAAG;AACpD,WAAK,WAAW,gBAAgB,KAAK,UAAU,OAAO;AAAA,IACxD;AAAA,EACF,CAAC;AAED,QAAM,eAAe,IAAI,SAAS;AAElC,MAAI,CAAC,sBAAsB;AACzB,WAAO,MAAM,QAAQ;AAAA,EAAQ,YAAY;AAAA;AAAA,EAC3C;AAEA,SACE,MAAM,QAAQ;AAAA,SAAe,oBAAoB;AAAA;AAAA,IACjD,eACA;AAEJ;;;AJrDA,eAAO,uBAAwB,MAAM;AACnC,QAAM,UAAU,KAAK,WAAW;AAChC,QAAM,UAAU,KAAK;AAErB,MAAI,CAAC,eAAe,SAAS,EAAE,GAAG,SAAS,KAAK,KAAK,YAAY,CAAC,GAAG;AACnE,WAAO;AAAA,EACT;AAEA,MAAI,CAAC,QAAQ,WAAW,KAAK,WAAW,GAAG;AACzC,WAAO;AAAA,EACT;AAEA,QAAM,cAAc,kBAAAC,QAAK,SAAS,OAAO;AAEzC,QAAM,UAAU,QAAQ,QAAQ,QAAQ,MAAM;AAC9C,QAAM,UAAU,QAAQ,QAAQ,QAAQ,KAAK;AAC7C,QAAM,UAAU,QAAQ,QAAQ,QAAQ,KAAK;AAE7C,UAAI,4BAAW,OAAO,SAAK,4BAAW,OAAO,SAAK,4BAAW,OAAO,GAAG;AACrE,UAAM,UAAU,SAAS,OAAO;AAChC,UAAM,eAAe;AAAA,MACnB;AAAA,MACA;AAAA,MACA;AAAA,MACA,QAAQ;AAAA,IACV;AAEA,WAAO;AAAA,EACT;AAEA,SAAO;AACT;",
  "names": ["import_node_fs", "import_node_path", "md5", "assert", "path", "fsSync", "parser", "postcss", "path"]
}

|
|
310
|
+
//# 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, isRelevantFile } 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 (!isRelevantFile(cssPath, { ...options, cwd: this.rootContext })) {\n    return code;\n  }\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 gtsPath = cssPath.replace('.css', '.ts');\n\n  if (existsSync(gjsPath) || existsSync(gtsPath) || existsSync(hbsPath)) {\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 assert from 'node:assert';\nimport fsSync from 'node:fs';\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 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'];\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 * 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  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 = require(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", "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": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,IAAAA,kBAA2B;AAC3B,IAAAC,oBAAiB;;;ACFjB,yBAAmB;AACnB,qBAAmB;AACnB,uBAAiB;;;ACFjB,yBAAgB;AAgBT,SAAS,KAAK,YAAY;AAC/B,SAAO,UAAM,mBAAAC,SAAI,UAAU,EAAE,UAAU,GAAG,CAAC;AAC7C;AAGO,IAAM,qBAAqB;;;AChB3B,SAAS,qBAAqB,cAAc;AAMjD,QAAM,aAAa,QAAQ,YAAY;AACvC,QAAM,UAAU,KAAK,UAAU;AAE/B,SAAO;AACT;;;AFLA,IAAM,gBAAgB;AACtB,IAAM,iCAAiC,GAAG,aAAa;AACvD,IAAM,mCAAmC,GAAG,8BAA8B;AAC1E,IAAM,iCAAiC,GAAG,aAAa;AACvD,IAAM,mBAAmB,CAAC,oBAAoB;AAC9C,IAAM,0BAA0B,oBAAI,IAAI,CAAC,OAAO,CAAC;AAEjD,IAAM,MAAM,QAAQ,IAAI;AASjB,SAAS,SAAS,UAAU;AACjC,MAAI,SAAS,WAAW,GAAG,GAAG;AAC5B,WAAO,qBAAqB,QAAQ;AAAA,EACtC;AAEA,SAAO,mBAAmB,QAAQ;AACpC;AA4CO,SAAS,cAAc,UAAU;AACtC,MAAI,SAAS,SAAS,cAAc,GAAG;AACrC,WAAO;AAAA,EACT;AAEA,SAAO,SAAS,SAAS,aAAa,KAAK,SAAS,SAAS,cAAc;AAC7E;AAaO,SAAS,MAAM,UAAU;AAC9B,MAAI,SAAS,SAAS,cAAc,GAAG;AACrC,WAAO;AAAA,EACT;AAEA,MAAI,cAAc,QAAQ,GAAG;AAC3B,WAAO;AAAA,EACT;AAEA,SAAO,SAAS,SAAS,YAAY;AACvC;AAuBO,SAAS,eAAe,UAAU,EAAE,iBAAiB,IAAI,GAAG;AAEjE,MAAI,SAAS,WAAW,IAAI,EAAG,QAAO;AAEtC,MAAI,SAAS,MAAM,WAAW,EAAG,QAAO;AAExC,MAAI,SAAS,WAAW,aAAa,EAAG,QAAO;AAC/C,MAAI,iBAAiB,KAAK,CAAC,MAAM,SAAS,SAAS,CAAC,CAAC,EAAG,QAAO;AAE/D,MAAI,SAAS,SAAS,gBAAgB,GAAG;AAGvC,QAAI,CAAC,SAAS,SAAS,aAAa,GAAG;AACrC,aAAO;AAAA,IACT;AAIA,QAAI,SAAS,SAAS,8BAA8B,GAAG;AACrD,aAAO;AAAA,IACT;AAGA,QAAI,SAAS,SAAS,gCAAgC,GAAG;AAEvD,UAAI,SAAS,SAAS,GAAG,gCAAgC,WAAW,GAAG;AACrE,eAAO;AAAA,MACT;AAKA,aAAO;AAAA,IACT;AAAA,EACF;AAEA,MAAI,YAAY,kBAAkB,QAAQ;AAE1C,yBAAAC,SAAO,KAAK,sCAAsC;AAElD,MAAI,eAAe,kBAAkB,GAAG;AAExC,MAAI,cAAc,cAAc;AAC9B,WAAO;AAAA,EACT;AAEA,MAAI,QAAQ,SAAS,QAAQ,WAAW,EAAE;AAC1C,MAAI,CAAC,EAAE,GAAG,KAAK,IAAI,MAAM,MAAM,GAAG,EAAE,OAAO,OAAO;AAElD,MAAI,wBAAwB,IAAI,MAAM,CAAC,CAAC,GAAG;AACzC,WAAO;AAAA,EACT;AAMA,MAAI,QAAQ,CAAC,gBAAgB,eAAe,GAAI,mBAAmB,CAAC,CAAE;AAEtE,MAAI,CAAC,MAAM,KAAK,CAAC,SAAS,SAAS,SAAS,IAAI,CAAC,GAAG;AAClD;AAAA,EACF;AAEA,SAAO;AACT;AAEO,SAAS,8BAA8B,mBAAmB;AAc/D,MAAI,kBAAkB,kBAAkB,QAAQ,YAAY,GAAG;AAE/D,MAAI,SAAS,iBAAAC,QAAK,MAAM,eAAe;AAEvC,MAAI,MAAM,eAAe,GAAG;AAI1B,WAAO,OAAO;AAAA,EAChB;AAYA,MAAI,yBAAyB,iBAAAA,QAAK,KAAK,OAAO,KAAK,OAAO,IAAI;AAE9D,SAAO;AACT;AASO,SAAS,QAAQ,YAAY;AAClC,MAAI,gBAAgB,kBAAkB,UAAU;AAChD,MAAI,OAAO,WAAW,UAAU;AAOhC,MAAI,kBAAkB,WAAW,QAAQ,eAAe,EAAE;AAK1D,oBAAkB,gBAAgB,QAAQ,SAAS,GAAG;AAMtD,oBAAkB,gBAAgB;AAAA,IAChC,GAAG,8BAA8B;AAAA,IACjC;AAAA,EACF;AAEA,MAAI,yBAAyB,8BAA8B,eAAe;AAE1E,SAAO,GAAG,IAAI,GAAG,sBAAsB;AACzC;AAQA,IAAM,OAAO,oBAAI,IAAI;AAErB,SAAS,QAAQ,YAAY;AAC3B,MAAI,KAAK,IAAI,UAAU,EAAG,QAAO;AAEjC,MAAI,QAAQ,WAAW,MAAM,GAAG;AAEhC,WAAS,IAAI,MAAM,SAAS,GAAG,IAAI,GAAG,KAAK;AACzC,QAAI,UAAU,MAAM,MAAM,GAAG,CAAC,EAAE,KAAK,GAAG;AAExC,QAAI,OAAO,KAAK,IAAI,OAAO;AAE3B,QAAI,MAAM;AACR,aAAO;AAAA,IACT;AAAA,EACF;AACF;AAEO,SAAS,kBAAkB,YAAY,SAAS;AACrD,MAAI,MAAM,SAAS,OAAO;AAE1B,MAAI,WAAW,SAAS,8BAA8B,GAAG;AACvD,iBAAa,WAAW,MAAM,8BAA8B,EAAE,CAAC;AAAA,EACjE;AAEA,MAAI,WAAW,SAAS,GAAG,GAAG;AAC5B,iBAAa,WAAW,QAAQ,OAAO,EAAE;AAAA,EAC3C;AAEA,MAAI,OAAO,QAAQ,UAAU;AAE7B,MAAI,MAAM;AACR,WAAO;AAAA,EACT;AAEA,MAAI,gBAAgB,iBAAAA,QAAK,KAAK,YAAY,cAAc;AAExD,QAAM,cAAc,eAAAC,QAAO,WAAW,aAAa;AAEnD,MAAI,aAAa;AACf,WAAO;AAAA,EACT;AAEA,QAAM,kBAAkB,kBAAkB,YAAY,EAAE,IAAI,CAAC;AAE7D,MAAI,CAAC,iBAAiB;AACpB,UAAM,IAAI,MAAM,mCAAmC,UAAU,EAAE;AAAA,EACjE;AAEA,QAAM,gBAAgB,iBAAAD,QAAK,QAAQ,eAAe;AAElD,OAAK,IAAI,aAAa;AAEtB,SAAO;AACT;AAEA,SAAS,kBAAkB,WAAW,SAAS;AAC7C,MAAI,MAAM,SAAS,OAAO;AAC1B,MAAI,QAAQ,UAAU,MAAM,GAAG;AAE/B,WAAS,IAAI,MAAM,SAAS,GAAG,IAAI,GAAG,KAAK;AACzC,QAAI,UAAU,MAAM,MAAM,GAAG,CAAC,EAAE,KAAK,GAAG;AAExC,QAAI,cAAc,iBAAAA,QAAK,KAAK,SAAS,cAAc;AACnD,QAAI,SAAS,eAAAC,QAAO,WAAW,WAAW;AAE1C,QAAI,QAAQ;AACV,aAAO;AAAA,IACT;AAGA,QAAI,YAAY,KAAK;AACnB;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AACT;AAEA,IAAM,iBAAiB,oBAAI,IAAI;AAOxB,SAAS,WAAW,YAAY;AACrC,QAAM,YAAY,kBAAkB,UAAU;AAC9C,QAAM,WAAW,YAAY,SAAS;AAEtC,MAAI,SAAS,aAAa,GAAG;AAO3B,WAAO,SAAS;AAAA,EAClB;AAMA,MAAI,gBAAgB,iBAAAD,QAAK,KAAK,WAAW,uBAAuB;AAShE,MAAI,eAAAC,QAAO,WAAW,aAAa,GAAG;AAEpC,UAAM,QAAQ,QAAQ,aAAa;AACnC,UAAM,MAAM,MAAM,kBAAkB;AAEpC,WAAO,IAAI,gBAAgB,SAAS;AAAA,EACtC;AAKA,SAAO,SAAS;AAClB;AAKA,SAAS,YAAY,WAAW;AAC9B,MAAI,WAAW,eAAe,IAAI,SAAS;AAE3C,MAAI,UAAU;AACZ,WAAO;AAAA,EACT;AAEA,MAAI,SAAS,eAAAA,QAAO,aAAa,iBAAAD,QAAK,KAAK,WAAW,cAAc,CAAC;AACrE,MAAI,UAAU,OAAO,SAAS;AAC9B,MAAI,OAAO,KAAK,MAAM,OAAO;AAE7B,iBAAe,IAAI,WAAW,IAAI;AAElC,SAAO;AACT;;;AGraA,qBAAoB;AACpB,qCAAmB;;;ACDJ,SAAR,eAAgC,MAAM,MAAM;AACjD,QAAM,SAAS,KAAK;AAEpB,MAAI,CAAC,OAAQ,QAAO;AACpB,MAAI,OAAO,SAAS,YAAY,OAAO,UAAU,UAAW,QAAO;AAEnE,SAAO,eAAe,QAAQ,IAAI;AACpC;;;ADFA,SAAS,gBAAgB,KAAK,SAAS;AACrC,QAAM,YAAY,CAAC,cAAc;AAC/B,cAAU,KAAK,CAAC,aAAa;AAC3B,UAAI,SAAS,SAAS,WAAW,CAAC,eAAe,QAAQ,GAAG;AAC1D,iBAAS,SAAS,MAAM;AAAA,MAC1B,WAAW,SAAS,SAAS,SAAS,CAAC,eAAe,QAAQ,GAAG;AAC/D,iBAAS;AAAA,UACP,+BAAAE,QAAO,IAAI,EAAE,OAAO,SAAS,MAAM,CAAC;AAAA,UACpC,+BAAAA,QAAO,UAAU,EAAE,OAAO,QAAQ,CAAC;AAAA,QACrC;AAAA,MACF;AAAA,IACF,CAAC;AAGD,cAAU,KAAK,CAAC,aAAa;AAC3B,UAAI,SAAS,SAAS,YAAY,SAAS,UAAU,WAAW;AAC9D,iBAAS,YAAY,GAAG,SAAS,KAAK;AAAA,MACxC;AAAA,IACF,CAAC;AAAA,EACH;AACA,QAAM,kBAAc,+BAAAA,SAAO,SAAS,EAAE,YAAY,GAAG;AAErD,SAAO;AACT;AAEA,SAAS,kBAAkB,MAAM;AAC/B,QAAM,SAAS,KAAK;AAEpB,MAAI,CAAC,OAAQ,QAAO;AACpB,MAAI,OAAO,SAAS,YAAY,OAAO,SAAS,YAAa,QAAO;AAEpE,SAAO,kBAAkB,MAAM;AACjC;AAEe,SAAR,WAA4B,KAAK,SAAS,UAAU,WAAW;AACpE,QAAM,uBAAuB,aAAa;AAC1C,QAAM,MAAM,eAAAC,QAAQ,MAAM,GAAG;AAE7B,MAAI,KAAK,CAAC,SAAS;AACjB,QAAI,KAAK,SAAS,UAAU,CAAC,kBAAkB,IAAI,GAAG;AACpD,WAAK,WAAW,gBAAgB,KAAK,UAAU,OAAO;AAAA,IACxD;AAAA,EACF,CAAC;AAED,QAAM,eAAe,IAAI,SAAS;AAElC,MAAI,CAAC,sBAAsB;AACzB,WAAO,MAAM,QAAQ;AAAA,EAAQ,YAAY;AAAA;AAAA,EAC3C;AAEA,SACE,MAAM,QAAQ;AAAA,SAAe,oBAAoB;AAAA;AAAA,IACjD,eACA;AAEJ;;;AJrDA,eAAO,uBAAwB,MAAM;AACnC,QAAM,UAAU,KAAK,WAAW;AAChC,QAAM,UAAU,KAAK;AAErB,MAAI,CAAC,eAAe,SAAS,EAAE,GAAG,SAAS,KAAK,KAAK,YAAY,CAAC,GAAG;AACnE,WAAO;AAAA,EACT;AAEA,MAAI,CAAC,QAAQ,WAAW,KAAK,WAAW,GAAG;AACzC,WAAO;AAAA,EACT;AAEA,QAAM,cAAc,kBAAAC,QAAK,SAAS,OAAO;AAEzC,QAAM,UAAU,QAAQ,QAAQ,QAAQ,MAAM;AAC9C,QAAM,UAAU,QAAQ,QAAQ,QAAQ,KAAK;AAC7C,QAAM,UAAU,QAAQ,QAAQ,QAAQ,KAAK;AAE7C,UAAI,4BAAW,OAAO,SAAK,4BAAW,OAAO,SAAK,4BAAW,OAAO,GAAG;AACrE,UAAM,UAAU,SAAS,OAAO;AAChC,UAAM,eAAe;AAAA,MACnB;AAAA,MACA;AAAA,MACA;AAAA,MACA,QAAQ;AAAA,IACV;AAEA,WAAO;AAAA,EACT;AAEA,SAAO;AACT;",
  "names": ["import_node_fs", "import_node_path", "md5", "assert", "path", "fsSync", "parser", "postcss", "path"]
}

|
|
@@ -81,6 +81,8 @@ function withoutExtension(filePath) {
|
|
|
81
81
|
return import_node_path.default.join(parsed.dir, parsed.name);
|
|
82
82
|
}
|
|
83
83
|
function isRelevantFile(fileName, { additionalRoots, cwd }) {
|
|
84
|
+
if (fileName.startsWith("\0")) return false;
|
|
85
|
+
if (fileName.match(/^[a-zA-Z]/)) return false;
|
|
84
86
|
if (fileName.startsWith("/@embroider")) return false;
|
|
85
87
|
if (IRRELEVANT_PATHS.some((i) => fileName.includes(i))) return false;
|
|
86
88
|
if (fileName.includes("/node_modules/")) {
|
|
@@ -239,4 +241,4 @@ var babel_plugin_default = (env, options, workingDirectory) => {
|
|
|
239
241
|
}
|
|
240
242
|
};
|
|
241
243
|
};
|
|
242
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/build/babel-plugin.js", "../../src/lib/path/utils.js", "../../src/lib/path/hash-from-module-path.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 from 'node:fs';\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 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'];\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 * 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  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  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 = require(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", "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"],
  "mappings": "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",
  "names": ["path", "assert", "path", "fsSync", "path", "nodePath"]
}

|
|
244
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/build/babel-plugin.js", "../../src/lib/path/utils.js", "../../src/lib/path/hash-from-module-path.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 from 'node:fs';\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 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'];\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 * 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  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 = require(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", "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"],
  "mappings": "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",
  "names": ["path", "assert", "path", "fsSync", "path", "nodePath"]
}

|
|
@@ -481,4 +481,4 @@ var ScopedCssPreprocessor = class {
|
|
|
481
481
|
}
|
|
482
482
|
}
|
|
483
483
|
};
|
|
484
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/build/ember-classic-support.js", "../../src/lib/getClassesTagsFromCss.js", "../../src/lib/isInsideGlobal.js", "../../src/lib/path/utils.js", "../../src/lib/path/hash-from-module-path.js", "../../src/lib/rewriteCss.js", "../../src/lib/rewriteHbs.js", "../../src/lib/renameClass.js"],
  "sourcesContent": ["'use strict';\n\nimport { existsSync } from 'node:fs';\nimport { readFile, writeFile } from 'node:fs/promises';\nimport path from 'node:path';\n\nimport Concat from 'broccoli-concat';\nimport { Funnel } from 'broccoli-funnel';\nimport MergeTrees from 'broccoli-merge-trees';\nimport Filter from 'broccoli-persistent-filter';\nimport { Preprocessor } from 'content-tag';\n\nimport getClassesTagsFromCss from '../lib/getClassesTagsFromCss.js';\nimport {\n  hashFromModulePath,\n  packageScopedPathToModulePath,\n} from '../lib/path/utils.js';\nimport rewriteCss from '../lib/rewriteCss.js';\nimport rewriteHbs from '../lib/rewriteHbs.js';\n\nconst p = new Preprocessor();\nconst COMPONENT_EXTENSIONS = ['hbs', 'js', 'ts', 'gjs', 'gts'];\nconst TEMPLATE_EXTENSIONS = ['hbs', 'gjs', 'gts'];\n\nclass ScopedFilter extends Filter {\n  constructor(componentsNode, options = {}) {\n    super(componentsNode, options);\n    this.warningStream = process.stderr;\n    this.options = options;\n  }\n\n  get extensions() {\n    return ['css'];\n  }\n\n  get targetExtension() {\n    return 'css';\n  }\n\n  async processString(content, relativePath) {\n    // ignore css files for ember-css-modules\n    if (relativePath.endsWith('.module.css')) {\n      return '';\n    }\n\n    // check if corresponding js file exists\n    let hasRelevantFile = false;\n\n    for (let inputPath of this.inputPaths) {\n      if (hasRelevantFile) break;\n\n      for (let ext of COMPONENT_EXTENSIONS) {\n        if (hasRelevantFile) break;\n\n        const relativeComponentPath = relativePath.replace(/\\.css$/, '.' + ext);\n        const componentPath = path.join(inputPath, relativeComponentPath);\n\n        if (existsSync(componentPath)) {\n          hasRelevantFile = true;\n        }\n      }\n\n      /**\n       * Pods support\n       */\n      if (relativePath.endsWith('styles.css')) {\n        const directory = relativePath.replace(/styles\\.css$/, 'template.hbs');\n        const templatePath = path.join(inputPath, directory);\n\n        if (existsSync(templatePath)) {\n          hasRelevantFile = true;\n        }\n      }\n    }\n\n    // rewrite css file\n    if (hasRelevantFile) {\n      let localPackagerStylePath = packageScopedPathToModulePath(relativePath);\n\n      const hash = hashFromModulePath(localPackagerStylePath);\n\n      content = rewriteCss(\n        content,\n        hash,\n        relativePath,\n        this.options.getUserOptions?.()?.layerName,\n      );\n\n      return content;\n    } else {\n      return '';\n    }\n  }\n\n  async postProcess(results, relativePath) {\n    if (process.env.CI || relativePath.endsWith('.module.css')) {\n      return results;\n    }\n\n    for (let inputPath of this.inputPaths) {\n      const templateFile = {};\n\n      eachExtension: for (let ext of TEMPLATE_EXTENSIONS) {\n        const templatePath = relativePath.replace(/\\.css/, '.' + ext);\n        let templateFilePath = path.join(inputPath, templatePath);\n        let exists = existsSync(templateFilePath);\n\n        /**\n         * Pods support\n         */\n        if (ext === 'hbs' && !exists && relativePath.endsWith('styles.css')) {\n          let podsName = relativePath.replace(/styles\\.css$/, 'template.hbs');\n\n          templateFilePath = path.join(inputPath, podsName);\n          exists = existsSync(templateFilePath);\n        }\n\n        if (exists) {\n          templateFile.path = templateFilePath;\n          templateFile.ext = ext;\n\n          break eachExtension;\n        }\n      }\n\n      // if the template exists we check the css for changes\n      if (templateFile.path) {\n        const cssFilePath = path.join(inputPath, relativePath);\n        const cssContents = await readFile(cssFilePath, 'utf-8');\n        const { classes, tags } = getClassesTagsFromCss(cssContents);\n        const previousClasses = this.options.previousClasses.get(relativePath);\n\n        // if we have previous classes, and they are different, build templates to compare\n        if (previousClasses && classes !== previousClasses) {\n          const localPackagerStylePath =\n            packageScopedPathToModulePath(relativePath);\n          const postfix = hashFromModulePath(localPackagerStylePath);\n          const templateRaw = await readFile(templateFile.path, 'utf-8');\n          const templateComparison = [];\n          let templateContents = templateRaw;\n\n          if (templateFile.ext === 'hbs') {\n            templateComparison.push(\n              didTemplateChange(\n                templateContents,\n                previousClasses,\n                classes,\n                tags,\n                postfix,\n              ),\n            );\n          } else {\n            // find all template tags, and extract the contents to compare\n            const results = p.parse(templateRaw, '');\n            const templates = results.map((x) => x.contents);\n\n            for (let template of templates) {\n              templateComparison.push(\n                didTemplateChange(\n                  template,\n                  previousClasses,\n                  classes,\n                  tags,\n                  postfix,\n                ),\n              );\n            }\n          }\n\n          const templateChanged = templateComparison.some((v) => v);\n\n          // if the rewrite doesn't match the original output, we want to rebuild the template\n          if (templateChanged) {\n            // this is an awful hack because we don't know how to invalidate broccoli-persistent-filter cache\n            // ideally we'd invalidate the broccoli-peristent-filter cache here\n            await writeFile(templateFile.path, templateContents + ' ');\n          }\n        }\n        // assign for next run comparison\n\n        this.options.previousClasses.set(relativePath, classes);\n      }\n    }\n\n    return results;\n  }\n}\n\n/**\n * Compares a template with the context of different sets of extraced css classes\n *\n * @param {string} contents\n * @param {Set} previousClasses\n * @param {Set} currentClasses\n * @param {Set} tags\n * @param {string} postfix\n * @returns {Boolean}\n */\nfunction didTemplateChange(\n  contents,\n  previousClasses,\n  currentClasses,\n  tags,\n  postfix,\n) {\n  const original = rewriteHbs(contents, previousClasses, tags, postfix);\n  const current = rewriteHbs(contents, currentClasses, tags, postfix);\n\n  return original !== current;\n}\n\nexport default class ScopedCssPreprocessor {\n  constructor(options) {\n    this.owner = options.owner;\n    this.appName = options.owner.parent.pkg.name;\n    this.name = 'scoped-css-preprocessor';\n    this.previousClasses = new Map();\n  }\n\n  /**\n   * Sets the options from `setupPreprocessorRegistry`, the v1-Addon Hook\n   * @param {{ layerName?: string }} options\n   */\n  configureOptions(options) {\n    this.userOptions = options || { ['not configured']: true };\n  }\n\n  toTree(inputNode, inputPath, outputDirectory, options) {\n    const otherPreprocessors = this.preprocessors.filter((p) => p !== this);\n    const otherTrees = otherPreprocessors.map((p) => p.toTree(...arguments));\n    let mergedOtherTrees = new MergeTrees(otherTrees);\n\n    let roots = [\n      this.appName + '/components/',\n      ...(this.userOptions.additionalRoots || []).map(\n        (root) => `${this.appName}/${root}`,\n      ),\n    ];\n    let include = roots\n      .map((root) => {\n        let withSlash = root.endsWith('/') ? root : `${root}/`;\n\n        return [\n          `${withSlash}**/*.css`,\n          ...COMPONENT_EXTENSIONS.map((ext) => `${withSlash}**/*.${ext}`),\n        ];\n      })\n      .flat();\n\n    let componentsNode = new Funnel(inputNode, { include });\n\n    componentsNode = new ScopedFilter(componentsNode, {\n      inputPath,\n      getUserOptions: () => this.userOptions,\n      owner: this.owner,\n      previousClasses: this.previousClasses,\n    });\n\n    const componentStyles = new Funnel(componentsNode, {\n      include: roots.map((root) => {\n        let withSlash = root.endsWith('/') ? root : `${root}/`;\n\n        return `${withSlash}**/*.css`;\n      }),\n    });\n\n    const appCss = new Funnel(inputNode, {\n      include: [this.appName + '/styles/app.css'],\n    });\n\n    let mergedStyles = new MergeTrees(\n      [appCss, mergedOtherTrees, componentStyles],\n      { overwrite: true },\n    );\n\n    let newOutput = new Concat(mergedStyles, {\n      outputFile: options.outputPaths['app'],\n      allowNone: true,\n      sourceMapConfig: { enabled: true },\n    });\n\n    if (this.userOptions?.passthrough) {\n      let passedThrough = new Funnel(mergedStyles, {\n        include: this.userOptions.passthrough,\n        destDir: this.userOptions.passthroughDestination,\n      });\n\n      return new MergeTrees([passedThrough, newOutput], { overwrite: true });\n    } else {\n      return newOutput;\n    }\n  }\n}\n", "import postcss from 'postcss';\nimport parser from 'postcss-selector-parser';\n\nimport isInsideGlobal from './isInsideGlobal.js';\n\nfunction getClassesAndTags(sel, classes, tags) {\n  const transform = (sls) => {\n    sls.walk((selector) => {\n      if (selector.type === 'class' && !isInsideGlobal(selector)) {\n        classes.add(selector.value);\n      } else if (selector.type === 'tag' && !isInsideGlobal(selector)) {\n        tags.add(selector.value);\n      }\n    });\n  };\n\n  parser(transform).processSync(sel);\n}\n\nexport default function getClassesTagsFromCss(css) {\n  const classes = new Set();\n  const tags = new Set();\n\n  const ast = postcss.parse(css);\n\n  ast.walk((node) => {\n    if (node.type === 'rule') {\n      getClassesAndTags(node.selector, classes, tags);\n    }\n  });\n\n  return { classes, tags };\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", "import assert from 'node:assert';\nimport fsSync from 'node:fs';\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 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'];\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 * 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  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  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 = require(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", "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 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", "import recast from 'ember-template-recast';\n\nimport { renameClass } from './renameClass.js';\n\nexport function templatePlugin({ classes, tags, postfix }) {\n  let stack = [];\n  // scoped-class is a global we allow in hbs\n  // scopedClass is importable, and we'll error if someone tries to rename it\n  let scopedClassCandidates = ['scoped-class', 'scopedClass'];\n\n  function isScopedClass(str) {\n    if (!str) return false;\n\n    return scopedClassCandidates.some((candidate) => candidate === str);\n  }\n\n  return {\n    AttrNode(node) {\n      if (node.name === 'class') {\n        if (node.value.type === 'TextNode' && node.value.chars) {\n          const renamedClass = renameClass(node.value.chars, postfix, classes);\n\n          node.value.chars = renamedClass;\n        } else if (node.value.type === 'ConcatStatement') {\n          for (let part of node.value.parts) {\n            if (part.type === 'TextNode' && part.chars) {\n              const renamedClass = renameClass(part.chars, postfix, classes);\n\n              part.chars = renamedClass;\n            } else if (part.type === 'MustacheStatement') {\n              recast.traverse(part, {\n                StringLiteral(node) {\n                  const renamedClass = renameClass(\n                    node.value,\n                    postfix,\n                    classes,\n                  );\n\n                  node.value = renamedClass;\n                },\n              });\n            }\n          }\n        }\n      }\n    },\n\n    ElementNode(node) {\n      if (tags.has(node.tag)) {\n        // check if class attribute already exists\n        const classAttr = node.attributes.find((attr) => attr.name === 'class');\n\n        if (classAttr) {\n          classAttr.value.chars += ' ' + postfix;\n        } else {\n          // push class attribute\n          node.attributes.push(\n            recast.builders.attr('class', recast.builders.text(postfix)),\n          );\n        }\n      }\n    },\n\n    All: {\n      enter(node) {\n        stack.push(node);\n      },\n      exit() {\n        stack.pop();\n      },\n    },\n\n    MustacheStatement(node) {\n      let cssClass;\n\n      if (\n        isScopedClass(getValue(node.path)) &&\n        node.params?.length === 1 &&\n        node.params[0].type === 'StringLiteral'\n      ) {\n        cssClass = node.params[0].value;\n      }\n\n      if (\n        isScopedClass(getValue(node.path?.path)) &&\n        node.path?.params?.length === 1 &&\n        node.path?.params[0].type === 'StringLiteral'\n      ) {\n        cssClass = node.path.params[0].value;\n      }\n\n      if (cssClass) {\n        const textNode = recast.builders.text(renameClass(cssClass, postfix));\n        const parent = stack[stack.length - 1];\n\n        if (parent.type === 'AttrNode') {\n          parent.quoteType = '\"';\n        }\n\n        return textNode;\n      }\n    },\n\n    SubExpression(node) {\n      if (\n        isScopedClass(getValue(node.path)) &&\n        node.params?.length === 1 &&\n        node.params[0].type === 'StringLiteral'\n      ) {\n        const cssClass = node.params[0].value;\n        const textNode = recast.builders.literal(\n          'StringLiteral',\n          renameClass(cssClass, postfix),\n        );\n\n        return textNode;\n      }\n    },\n  };\n}\n\nfunction getValue(path) {\n  if (!path) return;\n\n  if ('value' in path) {\n    return path.value;\n  }\n\n  /**\n   * Deprecated in ember 5.9+\n   * (so we use the above for newer embers)\n   */\n  return path.original;\n}\n\nexport default function rewriteHbs(hbs, classes, tags, postfix) {\n  let ast = recast.parse(hbs);\n\n  recast.traverse(ast, templatePlugin({ classes, tags, postfix }));\n\n  let result = recast.print(ast);\n\n  return result;\n}\n", "/**\n *\n * @param {string} className\n * @param {string} postfix\n * @param {Set<string>} [classesInCss]\n * @returns\n */\nexport function renameClass(className, postfix, classesInCss) {\n  const classes = className.split(/\\s+/);\n  const renamedClasses = classes\n    .filter((c) => c)\n    .map((c) => c.trim())\n    .map((c) => {\n      if (!classesInCss || classesInCss.has(c)) {\n        if (c.endsWith(postfix)) return c;\n\n        return c + '_' + postfix;\n      }\n\n      return c;\n    })\n    .join(' ');\n\n  const renamedWithPreservedSpaces = className.replace(\n    className.trimStart().trimEnd(),\n    renamedClasses,\n  );\n\n  return renamedWithPreservedSpaces;\n}\n"],
  "mappings": "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",
  "names": ["import_node_path", "parser", "postcss", "md5", "path", "import_postcss", "import_postcss_selector_parser", "parser", "postcss", "recast", "node", "path", "Filter", "path", "hash", "results", "p", "MergeTrees", "Concat"]
}

|
|
484
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/build/ember-classic-support.js", "../../src/lib/getClassesTagsFromCss.js", "../../src/lib/isInsideGlobal.js", "../../src/lib/path/utils.js", "../../src/lib/path/hash-from-module-path.js", "../../src/lib/rewriteCss.js", "../../src/lib/rewriteHbs.js", "../../src/lib/renameClass.js"],
  "sourcesContent": ["'use strict';\n\nimport { existsSync } from 'node:fs';\nimport { readFile, writeFile } from 'node:fs/promises';\nimport path from 'node:path';\n\nimport Concat from 'broccoli-concat';\nimport { Funnel } from 'broccoli-funnel';\nimport MergeTrees from 'broccoli-merge-trees';\nimport Filter from 'broccoli-persistent-filter';\nimport { Preprocessor } from 'content-tag';\n\nimport getClassesTagsFromCss from '../lib/getClassesTagsFromCss.js';\nimport {\n  hashFromModulePath,\n  packageScopedPathToModulePath,\n} from '../lib/path/utils.js';\nimport rewriteCss from '../lib/rewriteCss.js';\nimport rewriteHbs from '../lib/rewriteHbs.js';\n\nconst p = new Preprocessor();\nconst COMPONENT_EXTENSIONS = ['hbs', 'js', 'ts', 'gjs', 'gts'];\nconst TEMPLATE_EXTENSIONS = ['hbs', 'gjs', 'gts'];\n\nclass ScopedFilter extends Filter {\n  constructor(componentsNode, options = {}) {\n    super(componentsNode, options);\n    this.warningStream = process.stderr;\n    this.options = options;\n  }\n\n  get extensions() {\n    return ['css'];\n  }\n\n  get targetExtension() {\n    return 'css';\n  }\n\n  async processString(content, relativePath) {\n    // ignore css files for ember-css-modules\n    if (relativePath.endsWith('.module.css')) {\n      return '';\n    }\n\n    // check if corresponding js file exists\n    let hasRelevantFile = false;\n\n    for (let inputPath of this.inputPaths) {\n      if (hasRelevantFile) break;\n\n      for (let ext of COMPONENT_EXTENSIONS) {\n        if (hasRelevantFile) break;\n\n        const relativeComponentPath = relativePath.replace(/\\.css$/, '.' + ext);\n        const componentPath = path.join(inputPath, relativeComponentPath);\n\n        if (existsSync(componentPath)) {\n          hasRelevantFile = true;\n        }\n      }\n\n      /**\n       * Pods support\n       */\n      if (relativePath.endsWith('styles.css')) {\n        const directory = relativePath.replace(/styles\\.css$/, 'template.hbs');\n        const templatePath = path.join(inputPath, directory);\n\n        if (existsSync(templatePath)) {\n          hasRelevantFile = true;\n        }\n      }\n    }\n\n    // rewrite css file\n    if (hasRelevantFile) {\n      let localPackagerStylePath = packageScopedPathToModulePath(relativePath);\n\n      const hash = hashFromModulePath(localPackagerStylePath);\n\n      content = rewriteCss(\n        content,\n        hash,\n        relativePath,\n        this.options.getUserOptions?.()?.layerName,\n      );\n\n      return content;\n    } else {\n      return '';\n    }\n  }\n\n  async postProcess(results, relativePath) {\n    if (process.env.CI || relativePath.endsWith('.module.css')) {\n      return results;\n    }\n\n    for (let inputPath of this.inputPaths) {\n      const templateFile = {};\n\n      eachExtension: for (let ext of TEMPLATE_EXTENSIONS) {\n        const templatePath = relativePath.replace(/\\.css/, '.' + ext);\n        let templateFilePath = path.join(inputPath, templatePath);\n        let exists = existsSync(templateFilePath);\n\n        /**\n         * Pods support\n         */\n        if (ext === 'hbs' && !exists && relativePath.endsWith('styles.css')) {\n          let podsName = relativePath.replace(/styles\\.css$/, 'template.hbs');\n\n          templateFilePath = path.join(inputPath, podsName);\n          exists = existsSync(templateFilePath);\n        }\n\n        if (exists) {\n          templateFile.path = templateFilePath;\n          templateFile.ext = ext;\n\n          break eachExtension;\n        }\n      }\n\n      // if the template exists we check the css for changes\n      if (templateFile.path) {\n        const cssFilePath = path.join(inputPath, relativePath);\n        const cssContents = await readFile(cssFilePath, 'utf-8');\n        const { classes, tags } = getClassesTagsFromCss(cssContents);\n        const previousClasses = this.options.previousClasses.get(relativePath);\n\n        // if we have previous classes, and they are different, build templates to compare\n        if (previousClasses && classes !== previousClasses) {\n          const localPackagerStylePath =\n            packageScopedPathToModulePath(relativePath);\n          const postfix = hashFromModulePath(localPackagerStylePath);\n          const templateRaw = await readFile(templateFile.path, 'utf-8');\n          const templateComparison = [];\n          let templateContents = templateRaw;\n\n          if (templateFile.ext === 'hbs') {\n            templateComparison.push(\n              didTemplateChange(\n                templateContents,\n                previousClasses,\n                classes,\n                tags,\n                postfix,\n              ),\n            );\n          } else {\n            // find all template tags, and extract the contents to compare\n            const results = p.parse(templateRaw, '');\n            const templates = results.map((x) => x.contents);\n\n            for (let template of templates) {\n              templateComparison.push(\n                didTemplateChange(\n                  template,\n                  previousClasses,\n                  classes,\n                  tags,\n                  postfix,\n                ),\n              );\n            }\n          }\n\n          const templateChanged = templateComparison.some((v) => v);\n\n          // if the rewrite doesn't match the original output, we want to rebuild the template\n          if (templateChanged) {\n            // this is an awful hack because we don't know how to invalidate broccoli-persistent-filter cache\n            // ideally we'd invalidate the broccoli-peristent-filter cache here\n            await writeFile(templateFile.path, templateContents + ' ');\n          }\n        }\n        // assign for next run comparison\n\n        this.options.previousClasses.set(relativePath, classes);\n      }\n    }\n\n    return results;\n  }\n}\n\n/**\n * Compares a template with the context of different sets of extraced css classes\n *\n * @param {string} contents\n * @param {Set} previousClasses\n * @param {Set} currentClasses\n * @param {Set} tags\n * @param {string} postfix\n * @returns {Boolean}\n */\nfunction didTemplateChange(\n  contents,\n  previousClasses,\n  currentClasses,\n  tags,\n  postfix,\n) {\n  const original = rewriteHbs(contents, previousClasses, tags, postfix);\n  const current = rewriteHbs(contents, currentClasses, tags, postfix);\n\n  return original !== current;\n}\n\nexport default class ScopedCssPreprocessor {\n  constructor(options) {\n    this.owner = options.owner;\n    this.appName = options.owner.parent.pkg.name;\n    this.name = 'scoped-css-preprocessor';\n    this.previousClasses = new Map();\n  }\n\n  /**\n   * Sets the options from `setupPreprocessorRegistry`, the v1-Addon Hook\n   * @param {{ layerName?: string }} options\n   */\n  configureOptions(options) {\n    this.userOptions = options || { ['not configured']: true };\n  }\n\n  toTree(inputNode, inputPath, outputDirectory, options) {\n    const otherPreprocessors = this.preprocessors.filter((p) => p !== this);\n    const otherTrees = otherPreprocessors.map((p) => p.toTree(...arguments));\n    let mergedOtherTrees = new MergeTrees(otherTrees);\n\n    let roots = [\n      this.appName + '/components/',\n      ...(this.userOptions.additionalRoots || []).map(\n        (root) => `${this.appName}/${root}`,\n      ),\n    ];\n    let include = roots\n      .map((root) => {\n        let withSlash = root.endsWith('/') ? root : `${root}/`;\n\n        return [\n          `${withSlash}**/*.css`,\n          ...COMPONENT_EXTENSIONS.map((ext) => `${withSlash}**/*.${ext}`),\n        ];\n      })\n      .flat();\n\n    let componentsNode = new Funnel(inputNode, { include });\n\n    componentsNode = new ScopedFilter(componentsNode, {\n      inputPath,\n      getUserOptions: () => this.userOptions,\n      owner: this.owner,\n      previousClasses: this.previousClasses,\n    });\n\n    const componentStyles = new Funnel(componentsNode, {\n      include: roots.map((root) => {\n        let withSlash = root.endsWith('/') ? root : `${root}/`;\n\n        return `${withSlash}**/*.css`;\n      }),\n    });\n\n    const appCss = new Funnel(inputNode, {\n      include: [this.appName + '/styles/app.css'],\n    });\n\n    let mergedStyles = new MergeTrees(\n      [appCss, mergedOtherTrees, componentStyles],\n      { overwrite: true },\n    );\n\n    let newOutput = new Concat(mergedStyles, {\n      outputFile: options.outputPaths['app'],\n      allowNone: true,\n      sourceMapConfig: { enabled: true },\n    });\n\n    if (this.userOptions?.passthrough) {\n      let passedThrough = new Funnel(mergedStyles, {\n        include: this.userOptions.passthrough,\n        destDir: this.userOptions.passthroughDestination,\n      });\n\n      return new MergeTrees([passedThrough, newOutput], { overwrite: true });\n    } else {\n      return newOutput;\n    }\n  }\n}\n", "import postcss from 'postcss';\nimport parser from 'postcss-selector-parser';\n\nimport isInsideGlobal from './isInsideGlobal.js';\n\nfunction getClassesAndTags(sel, classes, tags) {\n  const transform = (sls) => {\n    sls.walk((selector) => {\n      if (selector.type === 'class' && !isInsideGlobal(selector)) {\n        classes.add(selector.value);\n      } else if (selector.type === 'tag' && !isInsideGlobal(selector)) {\n        tags.add(selector.value);\n      }\n    });\n  };\n\n  parser(transform).processSync(sel);\n}\n\nexport default function getClassesTagsFromCss(css) {\n  const classes = new Set();\n  const tags = new Set();\n\n  const ast = postcss.parse(css);\n\n  ast.walk((node) => {\n    if (node.type === 'rule') {\n      getClassesAndTags(node.selector, classes, tags);\n    }\n  });\n\n  return { classes, tags };\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", "import assert from 'node:assert';\nimport fsSync from 'node:fs';\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 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'];\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 * 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  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 = require(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", "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 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", "import recast from 'ember-template-recast';\n\nimport { renameClass } from './renameClass.js';\n\nexport function templatePlugin({ classes, tags, postfix }) {\n  let stack = [];\n  // scoped-class is a global we allow in hbs\n  // scopedClass is importable, and we'll error if someone tries to rename it\n  let scopedClassCandidates = ['scoped-class', 'scopedClass'];\n\n  function isScopedClass(str) {\n    if (!str) return false;\n\n    return scopedClassCandidates.some((candidate) => candidate === str);\n  }\n\n  return {\n    AttrNode(node) {\n      if (node.name === 'class') {\n        if (node.value.type === 'TextNode' && node.value.chars) {\n          const renamedClass = renameClass(node.value.chars, postfix, classes);\n\n          node.value.chars = renamedClass;\n        } else if (node.value.type === 'ConcatStatement') {\n          for (let part of node.value.parts) {\n            if (part.type === 'TextNode' && part.chars) {\n              const renamedClass = renameClass(part.chars, postfix, classes);\n\n              part.chars = renamedClass;\n            } else if (part.type === 'MustacheStatement') {\n              recast.traverse(part, {\n                StringLiteral(node) {\n                  const renamedClass = renameClass(\n                    node.value,\n                    postfix,\n                    classes,\n                  );\n\n                  node.value = renamedClass;\n                },\n              });\n            }\n          }\n        }\n      }\n    },\n\n    ElementNode(node) {\n      if (tags.has(node.tag)) {\n        // check if class attribute already exists\n        const classAttr = node.attributes.find((attr) => attr.name === 'class');\n\n        if (classAttr) {\n          classAttr.value.chars += ' ' + postfix;\n        } else {\n          // push class attribute\n          node.attributes.push(\n            recast.builders.attr('class', recast.builders.text(postfix)),\n          );\n        }\n      }\n    },\n\n    All: {\n      enter(node) {\n        stack.push(node);\n      },\n      exit() {\n        stack.pop();\n      },\n    },\n\n    MustacheStatement(node) {\n      let cssClass;\n\n      if (\n        isScopedClass(getValue(node.path)) &&\n        node.params?.length === 1 &&\n        node.params[0].type === 'StringLiteral'\n      ) {\n        cssClass = node.params[0].value;\n      }\n\n      if (\n        isScopedClass(getValue(node.path?.path)) &&\n        node.path?.params?.length === 1 &&\n        node.path?.params[0].type === 'StringLiteral'\n      ) {\n        cssClass = node.path.params[0].value;\n      }\n\n      if (cssClass) {\n        const textNode = recast.builders.text(renameClass(cssClass, postfix));\n        const parent = stack[stack.length - 1];\n\n        if (parent.type === 'AttrNode') {\n          parent.quoteType = '\"';\n        }\n\n        return textNode;\n      }\n    },\n\n    SubExpression(node) {\n      if (\n        isScopedClass(getValue(node.path)) &&\n        node.params?.length === 1 &&\n        node.params[0].type === 'StringLiteral'\n      ) {\n        const cssClass = node.params[0].value;\n        const textNode = recast.builders.literal(\n          'StringLiteral',\n          renameClass(cssClass, postfix),\n        );\n\n        return textNode;\n      }\n    },\n  };\n}\n\nfunction getValue(path) {\n  if (!path) return;\n\n  if ('value' in path) {\n    return path.value;\n  }\n\n  /**\n   * Deprecated in ember 5.9+\n   * (so we use the above for newer embers)\n   */\n  return path.original;\n}\n\nexport default function rewriteHbs(hbs, classes, tags, postfix) {\n  let ast = recast.parse(hbs);\n\n  recast.traverse(ast, templatePlugin({ classes, tags, postfix }));\n\n  let result = recast.print(ast);\n\n  return result;\n}\n", "/**\n *\n * @param {string} className\n * @param {string} postfix\n * @param {Set<string>} [classesInCss]\n * @returns\n */\nexport function renameClass(className, postfix, classesInCss) {\n  const classes = className.split(/\\s+/);\n  const renamedClasses = classes\n    .filter((c) => c)\n    .map((c) => c.trim())\n    .map((c) => {\n      if (!classesInCss || classesInCss.has(c)) {\n        if (c.endsWith(postfix)) return c;\n\n        return c + '_' + postfix;\n      }\n\n      return c;\n    })\n    .join(' ');\n\n  const renamedWithPreservedSpaces = className.replace(\n    className.trimStart().trimEnd(),\n    renamedClasses,\n  );\n\n  return renamedWithPreservedSpaces;\n}\n"],
  "mappings": "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",
  "names": ["import_node_path", "parser", "postcss", "md5", "path", "import_postcss", "import_postcss_selector_parser", "parser", "postcss", "recast", "node", "path", "Filter", "path", "hash", "results", "p", "MergeTrees", "Concat"]
}

|
package/dist/cjs/index.cjs
CHANGED
|
@@ -96,6 +96,8 @@ function withoutExtension(filePath) {
|
|
|
96
96
|
return import_node_path.default.join(parsed.dir, parsed.name);
|
|
97
97
|
}
|
|
98
98
|
function isRelevantFile(fileName, { additionalRoots, cwd }) {
|
|
99
|
+
if (fileName.startsWith("\0")) return false;
|
|
100
|
+
if (fileName.match(/^[a-zA-Z]/)) return false;
|
|
99
101
|
if (fileName.startsWith("/@embroider")) return false;
|
|
100
102
|
if (IRRELEVANT_PATHS.some((i) => fileName.includes(i))) return false;
|
|
101
103
|
if (fileName.includes("/node_modules/")) {
|
|
@@ -663,6 +665,8 @@ var scoped_css_unplugin_default = (0, import_unplugin.createUnplugin)(
|
|
|
663
665
|
* @param {Options} [options]
|
|
664
666
|
*/
|
|
665
667
|
(options) => {
|
|
668
|
+
let cwd = import_node_process.default.cwd();
|
|
669
|
+
let additionalRoots = options?.additionalRoots || [];
|
|
666
670
|
return {
|
|
667
671
|
name: "ember-scoped-css-unplugin",
|
|
668
672
|
generateBundle(_, bundle) {
|
|
@@ -679,6 +683,7 @@ var scoped_css_unplugin_default = (0, import_unplugin.createUnplugin)(
|
|
|
679
683
|
generateBundle() {
|
|
680
684
|
},
|
|
681
685
|
transform(code, jsPath) {
|
|
686
|
+
if (!isRelevantFile(jsPath, { additionalRoots, cwd })) return;
|
|
682
687
|
if (isHbsFile(jsPath)) {
|
|
683
688
|
return transformJsFile(code, jsPath);
|
|
684
689
|
} else if (isJsFile(jsPath)) {
|
|
@@ -689,6 +694,7 @@ var scoped_css_unplugin_default = (0, import_unplugin.createUnplugin)(
|
|
|
689
694
|
}
|
|
690
695
|
},
|
|
691
696
|
transform(code, jsPath) {
|
|
697
|
+
if (!isRelevantFile(jsPath, { additionalRoots, cwd })) return;
|
|
692
698
|
if (isHbsFile(jsPath)) {
|
|
693
699
|
return transformJsFile(code, jsPath);
|
|
694
700
|
} else if (isJsFile(jsPath)) {
|
|
@@ -810,4 +816,4 @@ function createPlugin(config) {
|
|
|
810
816
|
scopedCssUnplugin,
|
|
811
817
|
templatePlugin
|
|
812
818
|
});
|
|
813
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/build/index.js", "../../src/build/babel-plugin.js", "../../src/lib/path/utils.js", "../../src/lib/path/hash-from-module-path.js", "../../src/lib/path/hash-from-absolute-path.js", "../../src/build/scoped-css-unplugin.js", "../../src/lib/getClassesTagsFromCss.js", "../../src/lib/isInsideGlobal.js", "../../src/lib/replaceHbsInJs.js", "../../src/lib/rewriteCss.js", "../../src/lib/rewriteHbs.js", "../../src/lib/renameClass.js", "../../src/lib/css/utils.js", "../../src/lib/path/template-transform-paths.js", "../../src/build/template-plugin.js"],
  "sourcesContent": ["export { default as babelPlugin } from './babel-plugin.js';\nexport { default as scopedCssUnplugin } from './scoped-css-unplugin.js';\nexport { createPlugin as templatePlugin } from './template-plugin.js';\n", "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 from 'node:fs';\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 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'];\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 * 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  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  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 = require(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", "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 { existsSync } from 'node:fs';\nimport { readFile } from 'node:fs/promises';\nimport path from 'node:path';\nimport process from 'node:process';\n\nimport { createUnplugin } from 'unplugin';\n\nimport getClassesTagsFromCss from '../lib/getClassesTagsFromCss.js';\nimport { hashFromAbsolutePath } from '../lib/path/utils.js';\nimport replaceHbsInJs from '../lib/replaceHbsInJs.js';\nimport rewriteCss from '../lib/rewriteCss.js';\nimport rewriteHbs from '../lib/rewriteHbs.js';\n\nfunction isJsFile(id) {\n  return (\n    id.endsWith('.js') ||\n    id.endsWith('.ts') ||\n    id.endsWith('.gjs') ||\n    id.endsWith('.gts')\n  );\n}\n\nfunction isHbsFile(id) {\n  return id.endsWith('.hbs');\n}\n\nfunction isCssFile(id) {\n  return id.endsWith('.css');\n}\n\nasync function transformJsFile(code, id) {\n  const cssPath = id.endsWith('.hbs')\n    ? id.replace(/\\.hbs$/, '.css')\n    : id.replace(/(\\.hbs)?\\.(js|ts|gjs|gts)$/, '.css');\n  const cssFileName = path.basename(cssPath);\n\n  const cssExists = existsSync(cssPath);\n  let css;\n\n  if (cssExists) {\n    css = await readFile(cssPath, 'utf8');\n  } else {\n    return {\n      code,\n      map: null,\n    };\n  }\n\n  // add css import for js and gjs files\n  code = `import './${cssFileName}';\\n\\n${code}`;\n\n  // rewrite hbs in js in case it is gjs file (for gjs files hbs is already in js file)\n\n  const rewrittenCode = replaceHbsInJs(code, (hbs, scopedClass) => {\n    const { classes, tags } = getClassesTagsFromCss(css);\n    const postfix = hashFromAbsolutePath(cssPath);\n    const rewritten = rewriteHbs(hbs, classes, tags, postfix, scopedClass);\n\n    return rewritten;\n  });\n\n  return {\n    code: rewrittenCode,\n    map: null,\n  };\n}\n\nfunction transformCssFile(code, id, layerName) {\n  const jsPath = id.replace(/\\.css$/, '.gjs');\n  const gtsPath = id.replace(/\\.css$/, '.gts');\n  const hbsPath = id.replace(/\\.css$/, '.hbs');\n\n  const jsExists = existsSync(jsPath);\n  const gtsExists = existsSync(gtsPath);\n  const hbsExists = existsSync(hbsPath);\n\n  if (jsExists || hbsExists || gtsExists) {\n    const postfix = hashFromAbsolutePath(id);\n\n    code = rewriteCss(code, postfix, path.basename(id), layerName);\n  }\n\n  return code;\n}\n\nfunction gatherCSSFiles(bundle) {\n  let cssFiles = [];\n\n  for (let asset in bundle) {\n    const cssAsset = asset.replace('js', 'css');\n\n    if (!asset.endsWith('js') || !bundle[cssAsset]) {\n      continue;\n    }\n\n    if (process.env.environment === 'development') {\n      cssFiles.push(bundle[cssAsset].source);\n      delete bundle[cssAsset];\n    } else {\n      const cssImport = path.basename(asset.replace('.js', '.css'));\n      const importLine = `import './${cssImport}';`;\n\n      const code = bundle[asset].code;\n\n      // add import to js files\n      if (code && code.indexOf(importLine) < 0) {\n        bundle[asset].code = `${importLine}\\n` + code;\n      }\n    }\n  }\n\n  return cssFiles;\n}\n\nexport default createUnplugin(\n  /**\n   * @typedef {object} Options\n   * @property {string} [layerName] the name of the layer to place the generated css. Defaults to \"components\"\n   *\n   * @param {Options} [options]\n   */\n  (options) => {\n    return {\n      name: 'ember-scoped-css-unplugin',\n\n      generateBundle(_, bundle) {\n        let cssFiles = gatherCSSFiles(bundle);\n\n        if (process.env.environment === 'development') {\n          this.emitFile({\n            type: 'asset',\n            fileName: 'scoped.css',\n            source: cssFiles.join('\\n'),\n          });\n        }\n      },\n      vite: {\n        generateBundle() {\n          /* deliberately do nothing */\n        },\n        transform(code, jsPath) {\n          /**\n           * HBS files are actually JS files with a call to precompileTemplate\n           */\n          if (isHbsFile(jsPath)) {\n            return transformJsFile(code, jsPath);\n          } else if (isJsFile(jsPath)) {\n            return transformJsFile(code, jsPath);\n          } else if (isCssFile(jsPath)) {\n            return transformCssFile(code, jsPath, options?.layerName);\n          }\n        },\n      },\n\n      transform(code, jsPath) {\n        /**\n         * HBS files are actually JS files with a call to precompileTemplate\n         */\n        if (isHbsFile(jsPath)) {\n          return transformJsFile(code, jsPath);\n        } else if (isJsFile(jsPath)) {\n          return transformJsFile(code, jsPath);\n        } else if (isCssFile(jsPath)) {\n          let css = transformCssFile(code, jsPath, options?.layerName);\n\n          const emittedFileName = jsPath.replace(\n            path.join(process.cwd(), 'src/'),\n            '',\n          );\n\n          this.emitFile({\n            type: 'asset',\n            fileName: emittedFileName,\n            source: css,\n          });\n\n          return '';\n        }\n      },\n    };\n  },\n);\n", "import postcss from 'postcss';\nimport parser from 'postcss-selector-parser';\n\nimport isInsideGlobal from './isInsideGlobal.js';\n\nfunction getClassesAndTags(sel, classes, tags) {\n  const transform = (sls) => {\n    sls.walk((selector) => {\n      if (selector.type === 'class' && !isInsideGlobal(selector)) {\n        classes.add(selector.value);\n      } else if (selector.type === 'tag' && !isInsideGlobal(selector)) {\n        tags.add(selector.value);\n      }\n    });\n  };\n\n  parser(transform).processSync(sel);\n}\n\nexport default function getClassesTagsFromCss(css) {\n  const classes = new Set();\n  const tags = new Set();\n\n  const ast = postcss.parse(css);\n\n  ast.walk((node) => {\n    if (node.type === 'rule') {\n      getClassesAndTags(node.selector, classes, tags);\n    }\n  });\n\n  return { classes, tags };\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", "import babelParser from '@babel/parser';\nimport recast from 'recast';\n\nconst parseOptions = {\n  parser: {\n    parse(source) {\n      return babelParser.parse(source, {\n        sourceType: 'module',\n        allowImportExportEverywhere: true,\n        tokens: true,\n        plugins: ['decorators'],\n      });\n    },\n  },\n};\n\nfunction removeScopeBagReference(ast, scopedClass) {\n  if (!scopedClass) return;\n\n  recast.visit(ast, {\n    visitObjectProperty(path) {\n      if (\n        path.node.value.type === 'Identifier' &&\n        path.node.value.name === scopedClass\n      ) {\n        path.prune();\n\n        return false;\n      }\n\n      this.traverse(path);\n    },\n  });\n}\n\nexport default function (script, replaceFunction) {\n  const ast = recast.parse(script, parseOptions);\n  let importedScopedClass;\n\n  recast.visit(ast, {\n    visitImportDeclaration(path) {\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          importedScopedClass = specifier.local.name;\n        }\n\n        path.prune();\n\n        return false;\n      }\n\n      this.traverse(path);\n    },\n    visitCallExpression(path) {\n      const node = path.node;\n\n      const scopedClass = importedScopedClass ?? 'scoped-class';\n\n      /**\n       * __GLIMMER_TEMPLATE is for use with\n       * https://github.com/NullVoxPopuli/rollup-plugin-glimmer-template-tag/\n       * which uses\n       * https://github.com/ember-template-imports/ember-template-imports/\n       * @v3, which is known to have a lot of parser bugs.\n       *\n       * in @embroider/addon-dev@v4, we have native GJS support\n       * and we don't inline co-located hbs and JS (or rather, a rollup optimization later does it for us).\n       * Instead, we import, which looks like this:\n       * ```\n       * import TEMPLATE from './the-file.hbs';\n       *\n       * ...\n       *\n       * setComponentTemplate(TEMPLATE, X);\n       * ```\n       * And we don't want to enter this codepath (or rather, it no-ops).\n       * _BUT_, because this file imports the hbs file, we'll end up here later\n       * and ready to hit the `precompileTemplate` codepath.\n       */\n      if (\n        node.callee.name === '__GLIMMER_TEMPLATE' ||\n        node.callee.name === 'precompileTemplate'\n      ) {\n        if (node.arguments[0].type === 'TemplateLiteral') {\n          node.arguments[0].quasis[0].value.raw = replaceFunction(\n            node.arguments[0].quasis[0].value.raw,\n            scopedClass,\n          );\n        } else if (\n          node.arguments[0].type === 'StringLiteral' ||\n          node.arguments[0].type === 'Literal'\n        ) {\n          node.arguments[0].value = replaceFunction(\n            node.arguments[0].value,\n            scopedClass,\n          );\n        }\n\n        if (importedScopedClass) {\n          removeScopeBagReference(path, scopedClass);\n        }\n      }\n\n      this.traverse(path);\n    },\n  });\n\n  return recast.print(ast).code;\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", "import recast from 'ember-template-recast';\n\nimport { renameClass } from './renameClass.js';\n\nexport function templatePlugin({ classes, tags, postfix }) {\n  let stack = [];\n  // scoped-class is a global we allow in hbs\n  // scopedClass is importable, and we'll error if someone tries to rename it\n  let scopedClassCandidates = ['scoped-class', 'scopedClass'];\n\n  function isScopedClass(str) {\n    if (!str) return false;\n\n    return scopedClassCandidates.some((candidate) => candidate === str);\n  }\n\n  return {\n    AttrNode(node) {\n      if (node.name === 'class') {\n        if (node.value.type === 'TextNode' && node.value.chars) {\n          const renamedClass = renameClass(node.value.chars, postfix, classes);\n\n          node.value.chars = renamedClass;\n        } else if (node.value.type === 'ConcatStatement') {\n          for (let part of node.value.parts) {\n            if (part.type === 'TextNode' && part.chars) {\n              const renamedClass = renameClass(part.chars, postfix, classes);\n\n              part.chars = renamedClass;\n            } else if (part.type === 'MustacheStatement') {\n              recast.traverse(part, {\n                StringLiteral(node) {\n                  const renamedClass = renameClass(\n                    node.value,\n                    postfix,\n                    classes,\n                  );\n\n                  node.value = renamedClass;\n                },\n              });\n            }\n          }\n        }\n      }\n    },\n\n    ElementNode(node) {\n      if (tags.has(node.tag)) {\n        // check if class attribute already exists\n        const classAttr = node.attributes.find((attr) => attr.name === 'class');\n\n        if (classAttr) {\n          classAttr.value.chars += ' ' + postfix;\n        } else {\n          // push class attribute\n          node.attributes.push(\n            recast.builders.attr('class', recast.builders.text(postfix)),\n          );\n        }\n      }\n    },\n\n    All: {\n      enter(node) {\n        stack.push(node);\n      },\n      exit() {\n        stack.pop();\n      },\n    },\n\n    MustacheStatement(node) {\n      let cssClass;\n\n      if (\n        isScopedClass(getValue(node.path)) &&\n        node.params?.length === 1 &&\n        node.params[0].type === 'StringLiteral'\n      ) {\n        cssClass = node.params[0].value;\n      }\n\n      if (\n        isScopedClass(getValue(node.path?.path)) &&\n        node.path?.params?.length === 1 &&\n        node.path?.params[0].type === 'StringLiteral'\n      ) {\n        cssClass = node.path.params[0].value;\n      }\n\n      if (cssClass) {\n        const textNode = recast.builders.text(renameClass(cssClass, postfix));\n        const parent = stack[stack.length - 1];\n\n        if (parent.type === 'AttrNode') {\n          parent.quoteType = '\"';\n        }\n\n        return textNode;\n      }\n    },\n\n    SubExpression(node) {\n      if (\n        isScopedClass(getValue(node.path)) &&\n        node.params?.length === 1 &&\n        node.params[0].type === 'StringLiteral'\n      ) {\n        const cssClass = node.params[0].value;\n        const textNode = recast.builders.literal(\n          'StringLiteral',\n          renameClass(cssClass, postfix),\n        );\n\n        return textNode;\n      }\n    },\n  };\n}\n\nfunction getValue(path) {\n  if (!path) return;\n\n  if ('value' in path) {\n    return path.value;\n  }\n\n  /**\n   * Deprecated in ember 5.9+\n   * (so we use the above for newer embers)\n   */\n  return path.original;\n}\n\nexport default function rewriteHbs(hbs, classes, tags, postfix) {\n  let ast = recast.parse(hbs);\n\n  recast.traverse(ast, templatePlugin({ classes, tags, postfix }));\n\n  let result = recast.print(ast);\n\n  return result;\n}\n", "/**\n *\n * @param {string} className\n * @param {string} postfix\n * @param {Set<string>} [classesInCss]\n * @returns\n */\nexport function renameClass(className, postfix, classesInCss) {\n  const classes = className.split(/\\s+/);\n  const renamedClasses = classes\n    .filter((c) => c)\n    .map((c) => c.trim())\n    .map((c) => {\n      if (!classesInCss || classesInCss.has(c)) {\n        if (c.endsWith(postfix)) return c;\n\n        return c + '_' + postfix;\n      }\n\n      return c;\n    })\n    .join(' ');\n\n  const renamedWithPreservedSpaces = className.replace(\n    className.trimStart().trimEnd(),\n    renamedClasses,\n  );\n\n  return renamedWithPreservedSpaces;\n}\n", "import { existsSync, readFileSync } from 'fs';\n\nimport getClassesTagsFromCss from '../getClassesTagsFromCss.js';\n\n/**\n * @param {string} cssPath path to a CSS file\n */\nexport function getCSSInfo(cssPath) {\n  if (!existsSync(cssPath)) {\n    return null;\n  }\n\n  let css = readFileSync(cssPath, 'utf8');\n  let result = getClassesTagsFromCss(css);\n\n  return result;\n}\n", "import path from 'node:path';\n\nimport { findWorkspacePath } from './utils.js';\n\n/**\n * template plugins do not hand us the correct file path.\n * additionally, we may not be able to rely on this data in the future,\n * so this functions acts as a means of normalizing _whatever_ we're given\n * in the future.\n *\n * @param {string} filename\n * @returns {string} the absolute path to the file\n */\nexport function fixFilename(filename) {\n  let fileName = filename;\n  let workspace = findWorkspacePath(fileName);\n\n  /**\n   * ember-source 5.8:\n   * - the filename looks like an absolute path, but swapped out the 'app' part of the path\n   *   with the module name, so the file paths never exist on disk\n   *\n   * - in vite apps:\n   *   the 'app' part _may_ be `src`, so we also need to ensure that `src` is excluded as well\n   */\n  let hasAppDir = fileName.includes(path.join(workspace, 'app'));\n  let hasSrcDir = fileName.includes(path.join(workspace, 'src'));\n\n  if (\n    !(hasAppDir || hasSrcDir) &&\n    !fileName.includes('/node_modules/.embroider/')\n  ) {\n    let maybeModule = fileName.replace(workspace, '');\n    let [maybeScope, ...rest] = maybeModule.split('/').filter(Boolean);\n    let parts = rest;\n\n    if (maybeScope.startsWith('@')) {\n      let [, ...rester] = rest;\n\n      parts = rester;\n    }\n\n    let relative = path.join(...parts);\n\n    /**\n     * We don't actually know if this file is an app.\n     * it could be an addon (v1 or v2)\n     *\n     * So here we log to see if we have unhandled situations.\n     */\n    let candidatePath = path.join(workspace, 'app', relative);\n\n    return candidatePath;\n  }\n\n  /**\n   * under embroider@3, the fileName will be the path to the rewritten file.\n   * we don't want this.\n   * we want the path to the original source.\n   * Through the powers of \u2728 convention \u2728, we can map back to source.\n   */\n  if (fileName.includes('/node_modules/.embroider/rewritten-app/')) {\n    let candidatePath = fileName.replace(\n      '/node_modules/.embroider/rewritten-app/',\n      '/app/',\n    );\n\n    return candidatePath;\n  }\n\n  // TODO: why are we passed files to other projects?\n  if (!fileName.includes(workspace)) {\n    return fileName;\n  }\n\n  // Fallback to what the plugin system gives us.\n  // This may be wrong, and if wrong, reveals\n  // unhandled scenarios with the file names in the plugin infra\n  return fileName;\n}\n", "/**\n * @typedef {import('@glimmer/syntax').ASTPlugin} ASTPlugin\n * @typedef {import('@glimmer/syntax').ASTPluginEnvironment} ASTPluginEnvironment\n *\n */\n\nimport { getCSSInfo } from '../lib/css/utils.js';\nimport { fixFilename } from '../lib/path/template-transform-paths.js';\nimport {\n  appPath,\n  cssPathFor,\n  hashFromModulePath,\n  isRelevantFile,\n} from '../lib/path/utils.js';\nimport { templatePlugin } from '../lib/rewriteHbs.js';\n\nconst noopPlugin = {\n  name: 'ember-scoped-css:noop',\n  visitor: {},\n};\n\n/**\n * @returns {ASTPlugin}\n */\nexport function createPlugin(config) {\n  /**\n   *\n   * @param {ASTPluginEnvironment} env\n   */\n  return function scopedCss(env) {\n    let isRelevant = isRelevantFile(env.filename, {\n      additionalRoots: config.additionalRoots,\n      cwd: process.cwd(),\n    });\n\n    if (!isRelevant) {\n      return noopPlugin;\n    }\n\n    let absolutePath = fixFilename(env.filename);\n    let modulePath = appPath(absolutePath);\n\n    let cssPath = cssPathFor(absolutePath);\n    let info = getCSSInfo(cssPath);\n    let postfix = hashFromModulePath(modulePath);\n\n    if (!info) {\n      return noopPlugin;\n    }\n\n    let visitors = templatePlugin({\n      classes: info.classes,\n      tags: info.tags,\n      postfix,\n    });\n\n    return {\n      name: 'ember-scoped-css:template-plugin',\n      visitor: {\n        // Stack Manager\n        ...visitors,\n        // Visitors broken out like this so we can conditionally\n        // debug based on file path.\n        AttrNode(...args) {\n          return visitors.AttrNode(...args);\n        },\n        ElementNode(...args) {\n          return visitors.ElementNode(...args);\n        },\n        MustacheStatement(...args) {\n          return visitors.MustacheStatement(...args);\n        },\n        SubExpression(...args) {\n          return visitors.SubExpression(...args);\n        },\n      },\n    };\n  };\n}\n"],
  "mappings": "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",
  "names": ["md5", "path", "assert", "fsSync", "path", "nodePath", "import_node_fs", "import_node_path", "parser", "postcss", "babelParser", "recast", "path", "import_postcss", "import_postcss_selector_parser", "parser", "postcss", "recast", "node", "path", "path", "process", "import_fs", "import_node_path", "path"]
}

|
|
819
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/build/index.js", "../../src/build/babel-plugin.js", "../../src/lib/path/utils.js", "../../src/lib/path/hash-from-module-path.js", "../../src/lib/path/hash-from-absolute-path.js", "../../src/build/scoped-css-unplugin.js", "../../src/lib/getClassesTagsFromCss.js", "../../src/lib/isInsideGlobal.js", "../../src/lib/replaceHbsInJs.js", "../../src/lib/rewriteCss.js", "../../src/lib/rewriteHbs.js", "../../src/lib/renameClass.js", "../../src/lib/css/utils.js", "../../src/lib/path/template-transform-paths.js", "../../src/build/template-plugin.js"],
  "sourcesContent": ["export { default as babelPlugin } from './babel-plugin.js';\nexport { default as scopedCssUnplugin } from './scoped-css-unplugin.js';\nexport { createPlugin as templatePlugin } from './template-plugin.js';\n", "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 from 'node:fs';\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 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'];\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 * 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  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 = require(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", "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 { existsSync } from 'node:fs';\nimport { readFile } from 'node:fs/promises';\nimport path from 'node:path';\nimport process from 'node:process';\n\nimport { createUnplugin } from 'unplugin';\n\nimport getClassesTagsFromCss from '../lib/getClassesTagsFromCss.js';\nimport { hashFromAbsolutePath, isRelevantFile } from '../lib/path/utils.js';\nimport replaceHbsInJs from '../lib/replaceHbsInJs.js';\nimport rewriteCss from '../lib/rewriteCss.js';\nimport rewriteHbs from '../lib/rewriteHbs.js';\n\nfunction isJsFile(id) {\n  return (\n    id.endsWith('.js') ||\n    id.endsWith('.ts') ||\n    id.endsWith('.gjs') ||\n    id.endsWith('.gts')\n  );\n}\n\nfunction isHbsFile(id) {\n  return id.endsWith('.hbs');\n}\n\nfunction isCssFile(id) {\n  return id.endsWith('.css');\n}\n\nasync function transformJsFile(code, id) {\n  const cssPath = id.endsWith('.hbs')\n    ? id.replace(/\\.hbs$/, '.css')\n    : id.replace(/(\\.hbs)?\\.(js|ts|gjs|gts)$/, '.css');\n  const cssFileName = path.basename(cssPath);\n\n  const cssExists = existsSync(cssPath);\n  let css;\n\n  if (cssExists) {\n    css = await readFile(cssPath, 'utf8');\n  } else {\n    return {\n      code,\n      map: null,\n    };\n  }\n\n  // add css import for js and gjs files\n  code = `import './${cssFileName}';\\n\\n${code}`;\n\n  // rewrite hbs in js in case it is gjs file (for gjs files hbs is already in js file)\n\n  const rewrittenCode = replaceHbsInJs(code, (hbs, scopedClass) => {\n    const { classes, tags } = getClassesTagsFromCss(css);\n    const postfix = hashFromAbsolutePath(cssPath);\n    const rewritten = rewriteHbs(hbs, classes, tags, postfix, scopedClass);\n\n    return rewritten;\n  });\n\n  return {\n    code: rewrittenCode,\n    map: null,\n  };\n}\n\nfunction transformCssFile(code, id, layerName) {\n  const jsPath = id.replace(/\\.css$/, '.gjs');\n  const gtsPath = id.replace(/\\.css$/, '.gts');\n  const hbsPath = id.replace(/\\.css$/, '.hbs');\n\n  const jsExists = existsSync(jsPath);\n  const gtsExists = existsSync(gtsPath);\n  const hbsExists = existsSync(hbsPath);\n\n  if (jsExists || hbsExists || gtsExists) {\n    const postfix = hashFromAbsolutePath(id);\n\n    code = rewriteCss(code, postfix, path.basename(id), layerName);\n  }\n\n  return code;\n}\n\nfunction gatherCSSFiles(bundle) {\n  let cssFiles = [];\n\n  for (let asset in bundle) {\n    const cssAsset = asset.replace('js', 'css');\n\n    if (!asset.endsWith('js') || !bundle[cssAsset]) {\n      continue;\n    }\n\n    if (process.env.environment === 'development') {\n      cssFiles.push(bundle[cssAsset].source);\n      delete bundle[cssAsset];\n    } else {\n      const cssImport = path.basename(asset.replace('.js', '.css'));\n      const importLine = `import './${cssImport}';`;\n\n      const code = bundle[asset].code;\n\n      // add import to js files\n      if (code && code.indexOf(importLine) < 0) {\n        bundle[asset].code = `${importLine}\\n` + code;\n      }\n    }\n  }\n\n  return cssFiles;\n}\n\nexport default createUnplugin(\n  /**\n   * @typedef {object} Options\n   * @property {string} [layerName] the name of the layer to place the generated css. Defaults to \"components\"\n   *\n   * @param {Options} [options]\n   */\n  (options) => {\n    let cwd = process.cwd();\n    let additionalRoots = options?.additionalRoots || [];\n\n    return {\n      name: 'ember-scoped-css-unplugin',\n\n      generateBundle(_, bundle) {\n        let cssFiles = gatherCSSFiles(bundle);\n\n        if (process.env.environment === 'development') {\n          this.emitFile({\n            type: 'asset',\n            fileName: 'scoped.css',\n            source: cssFiles.join('\\n'),\n          });\n        }\n      },\n      vite: {\n        generateBundle() {\n          /* deliberately do nothing */\n        },\n        transform(code, jsPath) {\n          if (!isRelevantFile(jsPath, { additionalRoots, cwd })) return;\n\n          /**\n           * HBS files are actually JS files with a call to precompileTemplate\n           */\n          if (isHbsFile(jsPath)) {\n            return transformJsFile(code, jsPath);\n          } else if (isJsFile(jsPath)) {\n            return transformJsFile(code, jsPath);\n          } else if (isCssFile(jsPath)) {\n            return transformCssFile(code, jsPath, options?.layerName);\n          }\n        },\n      },\n\n      transform(code, jsPath) {\n        if (!isRelevantFile(jsPath, { additionalRoots, cwd })) return;\n\n        /**\n         * HBS files are actually JS files with a call to precompileTemplate\n         */\n        if (isHbsFile(jsPath)) {\n          return transformJsFile(code, jsPath);\n        } else if (isJsFile(jsPath)) {\n          return transformJsFile(code, jsPath);\n        } else if (isCssFile(jsPath)) {\n          let css = transformCssFile(code, jsPath, options?.layerName);\n\n          const emittedFileName = jsPath.replace(\n            path.join(process.cwd(), 'src/'),\n            '',\n          );\n\n          this.emitFile({\n            type: 'asset',\n            fileName: emittedFileName,\n            source: css,\n          });\n\n          return '';\n        }\n      },\n    };\n  },\n);\n", "import postcss from 'postcss';\nimport parser from 'postcss-selector-parser';\n\nimport isInsideGlobal from './isInsideGlobal.js';\n\nfunction getClassesAndTags(sel, classes, tags) {\n  const transform = (sls) => {\n    sls.walk((selector) => {\n      if (selector.type === 'class' && !isInsideGlobal(selector)) {\n        classes.add(selector.value);\n      } else if (selector.type === 'tag' && !isInsideGlobal(selector)) {\n        tags.add(selector.value);\n      }\n    });\n  };\n\n  parser(transform).processSync(sel);\n}\n\nexport default function getClassesTagsFromCss(css) {\n  const classes = new Set();\n  const tags = new Set();\n\n  const ast = postcss.parse(css);\n\n  ast.walk((node) => {\n    if (node.type === 'rule') {\n      getClassesAndTags(node.selector, classes, tags);\n    }\n  });\n\n  return { classes, tags };\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", "import babelParser from '@babel/parser';\nimport recast from 'recast';\n\nconst parseOptions = {\n  parser: {\n    parse(source) {\n      return babelParser.parse(source, {\n        sourceType: 'module',\n        allowImportExportEverywhere: true,\n        tokens: true,\n        plugins: ['decorators'],\n      });\n    },\n  },\n};\n\nfunction removeScopeBagReference(ast, scopedClass) {\n  if (!scopedClass) return;\n\n  recast.visit(ast, {\n    visitObjectProperty(path) {\n      if (\n        path.node.value.type === 'Identifier' &&\n        path.node.value.name === scopedClass\n      ) {\n        path.prune();\n\n        return false;\n      }\n\n      this.traverse(path);\n    },\n  });\n}\n\nexport default function (script, replaceFunction) {\n  const ast = recast.parse(script, parseOptions);\n  let importedScopedClass;\n\n  recast.visit(ast, {\n    visitImportDeclaration(path) {\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          importedScopedClass = specifier.local.name;\n        }\n\n        path.prune();\n\n        return false;\n      }\n\n      this.traverse(path);\n    },\n    visitCallExpression(path) {\n      const node = path.node;\n\n      const scopedClass = importedScopedClass ?? 'scoped-class';\n\n      /**\n       * __GLIMMER_TEMPLATE is for use with\n       * https://github.com/NullVoxPopuli/rollup-plugin-glimmer-template-tag/\n       * which uses\n       * https://github.com/ember-template-imports/ember-template-imports/\n       * @v3, which is known to have a lot of parser bugs.\n       *\n       * in @embroider/addon-dev@v4, we have native GJS support\n       * and we don't inline co-located hbs and JS (or rather, a rollup optimization later does it for us).\n       * Instead, we import, which looks like this:\n       * ```\n       * import TEMPLATE from './the-file.hbs';\n       *\n       * ...\n       *\n       * setComponentTemplate(TEMPLATE, X);\n       * ```\n       * And we don't want to enter this codepath (or rather, it no-ops).\n       * _BUT_, because this file imports the hbs file, we'll end up here later\n       * and ready to hit the `precompileTemplate` codepath.\n       */\n      if (\n        node.callee.name === '__GLIMMER_TEMPLATE' ||\n        node.callee.name === 'precompileTemplate'\n      ) {\n        if (node.arguments[0].type === 'TemplateLiteral') {\n          node.arguments[0].quasis[0].value.raw = replaceFunction(\n            node.arguments[0].quasis[0].value.raw,\n            scopedClass,\n          );\n        } else if (\n          node.arguments[0].type === 'StringLiteral' ||\n          node.arguments[0].type === 'Literal'\n        ) {\n          node.arguments[0].value = replaceFunction(\n            node.arguments[0].value,\n            scopedClass,\n          );\n        }\n\n        if (importedScopedClass) {\n          removeScopeBagReference(path, scopedClass);\n        }\n      }\n\n      this.traverse(path);\n    },\n  });\n\n  return recast.print(ast).code;\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", "import recast from 'ember-template-recast';\n\nimport { renameClass } from './renameClass.js';\n\nexport function templatePlugin({ classes, tags, postfix }) {\n  let stack = [];\n  // scoped-class is a global we allow in hbs\n  // scopedClass is importable, and we'll error if someone tries to rename it\n  let scopedClassCandidates = ['scoped-class', 'scopedClass'];\n\n  function isScopedClass(str) {\n    if (!str) return false;\n\n    return scopedClassCandidates.some((candidate) => candidate === str);\n  }\n\n  return {\n    AttrNode(node) {\n      if (node.name === 'class') {\n        if (node.value.type === 'TextNode' && node.value.chars) {\n          const renamedClass = renameClass(node.value.chars, postfix, classes);\n\n          node.value.chars = renamedClass;\n        } else if (node.value.type === 'ConcatStatement') {\n          for (let part of node.value.parts) {\n            if (part.type === 'TextNode' && part.chars) {\n              const renamedClass = renameClass(part.chars, postfix, classes);\n\n              part.chars = renamedClass;\n            } else if (part.type === 'MustacheStatement') {\n              recast.traverse(part, {\n                StringLiteral(node) {\n                  const renamedClass = renameClass(\n                    node.value,\n                    postfix,\n                    classes,\n                  );\n\n                  node.value = renamedClass;\n                },\n              });\n            }\n          }\n        }\n      }\n    },\n\n    ElementNode(node) {\n      if (tags.has(node.tag)) {\n        // check if class attribute already exists\n        const classAttr = node.attributes.find((attr) => attr.name === 'class');\n\n        if (classAttr) {\n          classAttr.value.chars += ' ' + postfix;\n        } else {\n          // push class attribute\n          node.attributes.push(\n            recast.builders.attr('class', recast.builders.text(postfix)),\n          );\n        }\n      }\n    },\n\n    All: {\n      enter(node) {\n        stack.push(node);\n      },\n      exit() {\n        stack.pop();\n      },\n    },\n\n    MustacheStatement(node) {\n      let cssClass;\n\n      if (\n        isScopedClass(getValue(node.path)) &&\n        node.params?.length === 1 &&\n        node.params[0].type === 'StringLiteral'\n      ) {\n        cssClass = node.params[0].value;\n      }\n\n      if (\n        isScopedClass(getValue(node.path?.path)) &&\n        node.path?.params?.length === 1 &&\n        node.path?.params[0].type === 'StringLiteral'\n      ) {\n        cssClass = node.path.params[0].value;\n      }\n\n      if (cssClass) {\n        const textNode = recast.builders.text(renameClass(cssClass, postfix));\n        const parent = stack[stack.length - 1];\n\n        if (parent.type === 'AttrNode') {\n          parent.quoteType = '\"';\n        }\n\n        return textNode;\n      }\n    },\n\n    SubExpression(node) {\n      if (\n        isScopedClass(getValue(node.path)) &&\n        node.params?.length === 1 &&\n        node.params[0].type === 'StringLiteral'\n      ) {\n        const cssClass = node.params[0].value;\n        const textNode = recast.builders.literal(\n          'StringLiteral',\n          renameClass(cssClass, postfix),\n        );\n\n        return textNode;\n      }\n    },\n  };\n}\n\nfunction getValue(path) {\n  if (!path) return;\n\n  if ('value' in path) {\n    return path.value;\n  }\n\n  /**\n   * Deprecated in ember 5.9+\n   * (so we use the above for newer embers)\n   */\n  return path.original;\n}\n\nexport default function rewriteHbs(hbs, classes, tags, postfix) {\n  let ast = recast.parse(hbs);\n\n  recast.traverse(ast, templatePlugin({ classes, tags, postfix }));\n\n  let result = recast.print(ast);\n\n  return result;\n}\n", "/**\n *\n * @param {string} className\n * @param {string} postfix\n * @param {Set<string>} [classesInCss]\n * @returns\n */\nexport function renameClass(className, postfix, classesInCss) {\n  const classes = className.split(/\\s+/);\n  const renamedClasses = classes\n    .filter((c) => c)\n    .map((c) => c.trim())\n    .map((c) => {\n      if (!classesInCss || classesInCss.has(c)) {\n        if (c.endsWith(postfix)) return c;\n\n        return c + '_' + postfix;\n      }\n\n      return c;\n    })\n    .join(' ');\n\n  const renamedWithPreservedSpaces = className.replace(\n    className.trimStart().trimEnd(),\n    renamedClasses,\n  );\n\n  return renamedWithPreservedSpaces;\n}\n", "import { existsSync, readFileSync } from 'fs';\n\nimport getClassesTagsFromCss from '../getClassesTagsFromCss.js';\n\n/**\n * @param {string} cssPath path to a CSS file\n */\nexport function getCSSInfo(cssPath) {\n  if (!existsSync(cssPath)) {\n    return null;\n  }\n\n  let css = readFileSync(cssPath, 'utf8');\n  let result = getClassesTagsFromCss(css);\n\n  return result;\n}\n", "import path from 'node:path';\n\nimport { findWorkspacePath } from './utils.js';\n\n/**\n * template plugins do not hand us the correct file path.\n * additionally, we may not be able to rely on this data in the future,\n * so this functions acts as a means of normalizing _whatever_ we're given\n * in the future.\n *\n * @param {string} filename\n * @returns {string} the absolute path to the file\n */\nexport function fixFilename(filename) {\n  let fileName = filename;\n  let workspace = findWorkspacePath(fileName);\n\n  /**\n   * ember-source 5.8:\n   * - the filename looks like an absolute path, but swapped out the 'app' part of the path\n   *   with the module name, so the file paths never exist on disk\n   *\n   * - in vite apps:\n   *   the 'app' part _may_ be `src`, so we also need to ensure that `src` is excluded as well\n   */\n  let hasAppDir = fileName.includes(path.join(workspace, 'app'));\n  let hasSrcDir = fileName.includes(path.join(workspace, 'src'));\n\n  if (\n    !(hasAppDir || hasSrcDir) &&\n    !fileName.includes('/node_modules/.embroider/')\n  ) {\n    let maybeModule = fileName.replace(workspace, '');\n    let [maybeScope, ...rest] = maybeModule.split('/').filter(Boolean);\n    let parts = rest;\n\n    if (maybeScope.startsWith('@')) {\n      let [, ...rester] = rest;\n\n      parts = rester;\n    }\n\n    let relative = path.join(...parts);\n\n    /**\n     * We don't actually know if this file is an app.\n     * it could be an addon (v1 or v2)\n     *\n     * So here we log to see if we have unhandled situations.\n     */\n    let candidatePath = path.join(workspace, 'app', relative);\n\n    return candidatePath;\n  }\n\n  /**\n   * under embroider@3, the fileName will be the path to the rewritten file.\n   * we don't want this.\n   * we want the path to the original source.\n   * Through the powers of \u2728 convention \u2728, we can map back to source.\n   */\n  if (fileName.includes('/node_modules/.embroider/rewritten-app/')) {\n    let candidatePath = fileName.replace(\n      '/node_modules/.embroider/rewritten-app/',\n      '/app/',\n    );\n\n    return candidatePath;\n  }\n\n  // TODO: why are we passed files to other projects?\n  if (!fileName.includes(workspace)) {\n    return fileName;\n  }\n\n  // Fallback to what the plugin system gives us.\n  // This may be wrong, and if wrong, reveals\n  // unhandled scenarios with the file names in the plugin infra\n  return fileName;\n}\n", "/**\n * @typedef {import('@glimmer/syntax').ASTPlugin} ASTPlugin\n * @typedef {import('@glimmer/syntax').ASTPluginEnvironment} ASTPluginEnvironment\n *\n */\n\nimport { getCSSInfo } from '../lib/css/utils.js';\nimport { fixFilename } from '../lib/path/template-transform-paths.js';\nimport {\n  appPath,\n  cssPathFor,\n  hashFromModulePath,\n  isRelevantFile,\n} from '../lib/path/utils.js';\nimport { templatePlugin } from '../lib/rewriteHbs.js';\n\nconst noopPlugin = {\n  name: 'ember-scoped-css:noop',\n  visitor: {},\n};\n\n/**\n * @returns {ASTPlugin}\n */\nexport function createPlugin(config) {\n  /**\n   *\n   * @param {ASTPluginEnvironment} env\n   */\n  return function scopedCss(env) {\n    let isRelevant = isRelevantFile(env.filename, {\n      additionalRoots: config.additionalRoots,\n      cwd: process.cwd(),\n    });\n\n    if (!isRelevant) {\n      return noopPlugin;\n    }\n\n    let absolutePath = fixFilename(env.filename);\n    let modulePath = appPath(absolutePath);\n\n    let cssPath = cssPathFor(absolutePath);\n    let info = getCSSInfo(cssPath);\n    let postfix = hashFromModulePath(modulePath);\n\n    if (!info) {\n      return noopPlugin;\n    }\n\n    let visitors = templatePlugin({\n      classes: info.classes,\n      tags: info.tags,\n      postfix,\n    });\n\n    return {\n      name: 'ember-scoped-css:template-plugin',\n      visitor: {\n        // Stack Manager\n        ...visitors,\n        // Visitors broken out like this so we can conditionally\n        // debug based on file path.\n        AttrNode(...args) {\n          return visitors.AttrNode(...args);\n        },\n        ElementNode(...args) {\n          return visitors.ElementNode(...args);\n        },\n        MustacheStatement(...args) {\n          return visitors.MustacheStatement(...args);\n        },\n        SubExpression(...args) {\n          return visitors.SubExpression(...args);\n        },\n      },\n    };\n  };\n}\n"],
  "mappings": "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",
  "names": ["md5", "path", "assert", "fsSync", "path", "nodePath", "import_node_fs", "import_node_path", "parser", "postcss", "babelParser", "recast", "path", "import_postcss", "import_postcss_selector_parser", "parser", "postcss", "recast", "node", "path", "path", "process", "import_fs", "import_node_path", "path"]
}

|
|
@@ -135,6 +135,8 @@ function withoutExtension(filePath) {
|
|
|
135
135
|
return import_node_path.default.join(parsed.dir, parsed.name);
|
|
136
136
|
}
|
|
137
137
|
function isRelevantFile(fileName, { additionalRoots, cwd }) {
|
|
138
|
+
if (fileName.startsWith("\0")) return false;
|
|
139
|
+
if (fileName.match(/^[a-zA-Z]/)) return false;
|
|
138
140
|
if (fileName.startsWith("/@embroider")) return false;
|
|
139
141
|
if (IRRELEVANT_PATHS.some((i) => fileName.includes(i))) return false;
|
|
140
142
|
if (fileName.includes("/node_modules/")) {
|
|
@@ -466,4 +468,4 @@ function createPlugin(config) {
|
|
|
466
468
|
0 && (module.exports = {
|
|
467
469
|
createPlugin
|
|
468
470
|
});
|
|
469
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/build/template-plugin.js", "../../src/lib/css/utils.js", "../../src/lib/getClassesTagsFromCss.js", "../../src/lib/isInsideGlobal.js", "../../src/lib/path/template-transform-paths.js", "../../src/lib/path/utils.js", "../../src/lib/path/hash-from-module-path.js", "../../src/lib/rewriteHbs.js", "../../src/lib/renameClass.js"],
  "sourcesContent": ["/**\n * @typedef {import('@glimmer/syntax').ASTPlugin} ASTPlugin\n * @typedef {import('@glimmer/syntax').ASTPluginEnvironment} ASTPluginEnvironment\n *\n */\n\nimport { getCSSInfo } from '../lib/css/utils.js';\nimport { fixFilename } from '../lib/path/template-transform-paths.js';\nimport {\n  appPath,\n  cssPathFor,\n  hashFromModulePath,\n  isRelevantFile,\n} from '../lib/path/utils.js';\nimport { templatePlugin } from '../lib/rewriteHbs.js';\n\nconst noopPlugin = {\n  name: 'ember-scoped-css:noop',\n  visitor: {},\n};\n\n/**\n * @returns {ASTPlugin}\n */\nexport function createPlugin(config) {\n  /**\n   *\n   * @param {ASTPluginEnvironment} env\n   */\n  return function scopedCss(env) {\n    let isRelevant = isRelevantFile(env.filename, {\n      additionalRoots: config.additionalRoots,\n      cwd: process.cwd(),\n    });\n\n    if (!isRelevant) {\n      return noopPlugin;\n    }\n\n    let absolutePath = fixFilename(env.filename);\n    let modulePath = appPath(absolutePath);\n\n    let cssPath = cssPathFor(absolutePath);\n    let info = getCSSInfo(cssPath);\n    let postfix = hashFromModulePath(modulePath);\n\n    if (!info) {\n      return noopPlugin;\n    }\n\n    let visitors = templatePlugin({\n      classes: info.classes,\n      tags: info.tags,\n      postfix,\n    });\n\n    return {\n      name: 'ember-scoped-css:template-plugin',\n      visitor: {\n        // Stack Manager\n        ...visitors,\n        // Visitors broken out like this so we can conditionally\n        // debug based on file path.\n        AttrNode(...args) {\n          return visitors.AttrNode(...args);\n        },\n        ElementNode(...args) {\n          return visitors.ElementNode(...args);\n        },\n        MustacheStatement(...args) {\n          return visitors.MustacheStatement(...args);\n        },\n        SubExpression(...args) {\n          return visitors.SubExpression(...args);\n        },\n      },\n    };\n  };\n}\n", "import { existsSync, readFileSync } from 'fs';\n\nimport getClassesTagsFromCss from '../getClassesTagsFromCss.js';\n\n/**\n * @param {string} cssPath path to a CSS file\n */\nexport function getCSSInfo(cssPath) {\n  if (!existsSync(cssPath)) {\n    return null;\n  }\n\n  let css = readFileSync(cssPath, 'utf8');\n  let result = getClassesTagsFromCss(css);\n\n  return result;\n}\n", "import postcss from 'postcss';\nimport parser from 'postcss-selector-parser';\n\nimport isInsideGlobal from './isInsideGlobal.js';\n\nfunction getClassesAndTags(sel, classes, tags) {\n  const transform = (sls) => {\n    sls.walk((selector) => {\n      if (selector.type === 'class' && !isInsideGlobal(selector)) {\n        classes.add(selector.value);\n      } else if (selector.type === 'tag' && !isInsideGlobal(selector)) {\n        tags.add(selector.value);\n      }\n    });\n  };\n\n  parser(transform).processSync(sel);\n}\n\nexport default function getClassesTagsFromCss(css) {\n  const classes = new Set();\n  const tags = new Set();\n\n  const ast = postcss.parse(css);\n\n  ast.walk((node) => {\n    if (node.type === 'rule') {\n      getClassesAndTags(node.selector, classes, tags);\n    }\n  });\n\n  return { classes, tags };\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", "import path from 'node:path';\n\nimport { findWorkspacePath } from './utils.js';\n\n/**\n * template plugins do not hand us the correct file path.\n * additionally, we may not be able to rely on this data in the future,\n * so this functions acts as a means of normalizing _whatever_ we're given\n * in the future.\n *\n * @param {string} filename\n * @returns {string} the absolute path to the file\n */\nexport function fixFilename(filename) {\n  let fileName = filename;\n  let workspace = findWorkspacePath(fileName);\n\n  /**\n   * ember-source 5.8:\n   * - the filename looks like an absolute path, but swapped out the 'app' part of the path\n   *   with the module name, so the file paths never exist on disk\n   *\n   * - in vite apps:\n   *   the 'app' part _may_ be `src`, so we also need to ensure that `src` is excluded as well\n   */\n  let hasAppDir = fileName.includes(path.join(workspace, 'app'));\n  let hasSrcDir = fileName.includes(path.join(workspace, 'src'));\n\n  if (\n    !(hasAppDir || hasSrcDir) &&\n    !fileName.includes('/node_modules/.embroider/')\n  ) {\n    let maybeModule = fileName.replace(workspace, '');\n    let [maybeScope, ...rest] = maybeModule.split('/').filter(Boolean);\n    let parts = rest;\n\n    if (maybeScope.startsWith('@')) {\n      let [, ...rester] = rest;\n\n      parts = rester;\n    }\n\n    let relative = path.join(...parts);\n\n    /**\n     * We don't actually know if this file is an app.\n     * it could be an addon (v1 or v2)\n     *\n     * So here we log to see if we have unhandled situations.\n     */\n    let candidatePath = path.join(workspace, 'app', relative);\n\n    return candidatePath;\n  }\n\n  /**\n   * under embroider@3, the fileName will be the path to the rewritten file.\n   * we don't want this.\n   * we want the path to the original source.\n   * Through the powers of \u2728 convention \u2728, we can map back to source.\n   */\n  if (fileName.includes('/node_modules/.embroider/rewritten-app/')) {\n    let candidatePath = fileName.replace(\n      '/node_modules/.embroider/rewritten-app/',\n      '/app/',\n    );\n\n    return candidatePath;\n  }\n\n  // TODO: why are we passed files to other projects?\n  if (!fileName.includes(workspace)) {\n    return fileName;\n  }\n\n  // Fallback to what the plugin system gives us.\n  // This may be wrong, and if wrong, reveals\n  // unhandled scenarios with the file names in the plugin infra\n  return fileName;\n}\n", "import assert from 'node:assert';\nimport fsSync from 'node:fs';\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 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'];\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 * 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  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  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 = require(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", "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 recast from 'ember-template-recast';\n\nimport { renameClass } from './renameClass.js';\n\nexport function templatePlugin({ classes, tags, postfix }) {\n  let stack = [];\n  // scoped-class is a global we allow in hbs\n  // scopedClass is importable, and we'll error if someone tries to rename it\n  let scopedClassCandidates = ['scoped-class', 'scopedClass'];\n\n  function isScopedClass(str) {\n    if (!str) return false;\n\n    return scopedClassCandidates.some((candidate) => candidate === str);\n  }\n\n  return {\n    AttrNode(node) {\n      if (node.name === 'class') {\n        if (node.value.type === 'TextNode' && node.value.chars) {\n          const renamedClass = renameClass(node.value.chars, postfix, classes);\n\n          node.value.chars = renamedClass;\n        } else if (node.value.type === 'ConcatStatement') {\n          for (let part of node.value.parts) {\n            if (part.type === 'TextNode' && part.chars) {\n              const renamedClass = renameClass(part.chars, postfix, classes);\n\n              part.chars = renamedClass;\n            } else if (part.type === 'MustacheStatement') {\n              recast.traverse(part, {\n                StringLiteral(node) {\n                  const renamedClass = renameClass(\n                    node.value,\n                    postfix,\n                    classes,\n                  );\n\n                  node.value = renamedClass;\n                },\n              });\n            }\n          }\n        }\n      }\n    },\n\n    ElementNode(node) {\n      if (tags.has(node.tag)) {\n        // check if class attribute already exists\n        const classAttr = node.attributes.find((attr) => attr.name === 'class');\n\n        if (classAttr) {\n          classAttr.value.chars += ' ' + postfix;\n        } else {\n          // push class attribute\n          node.attributes.push(\n            recast.builders.attr('class', recast.builders.text(postfix)),\n          );\n        }\n      }\n    },\n\n    All: {\n      enter(node) {\n        stack.push(node);\n      },\n      exit() {\n        stack.pop();\n      },\n    },\n\n    MustacheStatement(node) {\n      let cssClass;\n\n      if (\n        isScopedClass(getValue(node.path)) &&\n        node.params?.length === 1 &&\n        node.params[0].type === 'StringLiteral'\n      ) {\n        cssClass = node.params[0].value;\n      }\n\n      if (\n        isScopedClass(getValue(node.path?.path)) &&\n        node.path?.params?.length === 1 &&\n        node.path?.params[0].type === 'StringLiteral'\n      ) {\n        cssClass = node.path.params[0].value;\n      }\n\n      if (cssClass) {\n        const textNode = recast.builders.text(renameClass(cssClass, postfix));\n        const parent = stack[stack.length - 1];\n\n        if (parent.type === 'AttrNode') {\n          parent.quoteType = '\"';\n        }\n\n        return textNode;\n      }\n    },\n\n    SubExpression(node) {\n      if (\n        isScopedClass(getValue(node.path)) &&\n        node.params?.length === 1 &&\n        node.params[0].type === 'StringLiteral'\n      ) {\n        const cssClass = node.params[0].value;\n        const textNode = recast.builders.literal(\n          'StringLiteral',\n          renameClass(cssClass, postfix),\n        );\n\n        return textNode;\n      }\n    },\n  };\n}\n\nfunction getValue(path) {\n  if (!path) return;\n\n  if ('value' in path) {\n    return path.value;\n  }\n\n  /**\n   * Deprecated in ember 5.9+\n   * (so we use the above for newer embers)\n   */\n  return path.original;\n}\n\nexport default function rewriteHbs(hbs, classes, tags, postfix) {\n  let ast = recast.parse(hbs);\n\n  recast.traverse(ast, templatePlugin({ classes, tags, postfix }));\n\n  let result = recast.print(ast);\n\n  return result;\n}\n", "/**\n *\n * @param {string} className\n * @param {string} postfix\n * @param {Set<string>} [classesInCss]\n * @returns\n */\nexport function renameClass(className, postfix, classesInCss) {\n  const classes = className.split(/\\s+/);\n  const renamedClasses = classes\n    .filter((c) => c)\n    .map((c) => c.trim())\n    .map((c) => {\n      if (!classesInCss || classesInCss.has(c)) {\n        if (c.endsWith(postfix)) return c;\n\n        return c + '_' + postfix;\n      }\n\n      return c;\n    })\n    .join(' ');\n\n  const renamedWithPreservedSpaces = className.replace(\n    className.trimStart().trimEnd(),\n    renamedClasses,\n  );\n\n  return renamedWithPreservedSpaces;\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,gBAAyC;;;ACAzC,qBAAoB;AACpB,qCAAmB;;;ACDJ,SAAR,eAAgC,MAAM,MAAM;AACjD,QAAM,SAAS,KAAK;AAEpB,MAAI,CAAC,OAAQ,QAAO;AACpB,MAAI,OAAO,SAAS,YAAY,OAAO,UAAU,UAAW,QAAO;AAEnE,SAAO,eAAe,QAAQ,IAAI;AACpC;;;ADFA,SAAS,kBAAkB,KAAK,SAAS,MAAM;AAC7C,QAAM,YAAY,CAAC,QAAQ;AACzB,QAAI,KAAK,CAAC,aAAa;AACrB,UAAI,SAAS,SAAS,WAAW,CAAC,eAAe,QAAQ,GAAG;AAC1D,gBAAQ,IAAI,SAAS,KAAK;AAAA,MAC5B,WAAW,SAAS,SAAS,SAAS,CAAC,eAAe,QAAQ,GAAG;AAC/D,aAAK,IAAI,SAAS,KAAK;AAAA,MACzB;AAAA,IACF,CAAC;AAAA,EACH;AAEA,qCAAAA,SAAO,SAAS,EAAE,YAAY,GAAG;AACnC;AAEe,SAAR,sBAAuC,KAAK;AACjD,QAAM,UAAU,oBAAI,IAAI;AACxB,QAAM,OAAO,oBAAI,IAAI;AAErB,QAAM,MAAM,eAAAC,QAAQ,MAAM,GAAG;AAE7B,MAAI,KAAK,CAAC,SAAS;AACjB,QAAI,KAAK,SAAS,QAAQ;AACxB,wBAAkB,KAAK,UAAU,SAAS,IAAI;AAAA,IAChD;AAAA,EACF,CAAC;AAED,SAAO,EAAE,SAAS,KAAK;AACzB;;;ADzBO,SAAS,WAAW,SAAS;AAClC,MAAI,KAAC,sBAAW,OAAO,GAAG;AACxB,WAAO;AAAA,EACT;AAEA,MAAI,UAAM,wBAAa,SAAS,MAAM;AACtC,MAAI,SAAS,sBAAsB,GAAG;AAEtC,SAAO;AACT;;;AGhBA,IAAAC,oBAAiB;;;ACAjB,yBAAmB;AACnB,qBAAmB;AACnB,uBAAiB;;;ACFjB,yBAAgB;AAgBT,SAAS,KAAK,YAAY;AAC/B,SAAO,UAAM,mBAAAC,SAAI,UAAU,EAAE,UAAU,GAAG,CAAC;AAC7C;AAGO,IAAM,qBAAqB;;;ADXlC,IAAM,gBAAgB;AACtB,IAAM,iCAAiC,GAAG,aAAa;AACvD,IAAM,mCAAmC,GAAG,8BAA8B;AAC1E,IAAM,iCAAiC,GAAG,aAAa;AACvD,IAAM,mBAAmB,CAAC,oBAAoB;AAC9C,IAAM,0BAA0B,oBAAI,IAAI,CAAC,OAAO,CAAC;AAEjD,IAAM,MAAM,QAAQ,IAAI;AAwCjB,SAAS,WAAW,UAAU;AACnC,MAAI,aAAa,iBAAiB,QAAQ;AAC1C,MAAI,UAAU,aAAa;AAE3B,MAAI,MAAM,QAAQ,GAAG;AACnB,cAAU,SACP,QAAQ,iBAAiB,YAAY,EACrC,QAAQ,iBAAiB,YAAY;AAAA,EAC1C;AAEA,SAAO;AACT;AAQO,SAAS,cAAc,UAAU;AACtC,MAAI,SAAS,SAAS,cAAc,GAAG;AACrC,WAAO;AAAA,EACT;AAEA,SAAO,SAAS,SAAS,aAAa,KAAK,SAAS,SAAS,cAAc;AAC7E;AAaO,SAAS,MAAM,UAAU;AAC9B,MAAI,SAAS,SAAS,cAAc,GAAG;AACrC,WAAO;AAAA,EACT;AAEA,MAAI,cAAc,QAAQ,GAAG;AAC3B,WAAO;AAAA,EACT;AAEA,SAAO,SAAS,SAAS,YAAY;AACvC;AAOO,SAAS,iBAAiB,UAAU;AACzC,MAAI,SAAS,iBAAAC,QAAK,MAAM,QAAQ;AAEhC,SAAO,iBAAAA,QAAK,KAAK,OAAO,KAAK,OAAO,IAAI;AAC1C;AAYO,SAAS,eAAe,UAAU,EAAE,iBAAiB,IAAI,GAAG;AACjE,MAAI,SAAS,WAAW,aAAa,EAAG,QAAO;AAC/C,MAAI,iBAAiB,KAAK,CAAC,MAAM,SAAS,SAAS,CAAC,CAAC,EAAG,QAAO;AAE/D,MAAI,SAAS,SAAS,gBAAgB,GAAG;AAGvC,QAAI,CAAC,SAAS,SAAS,aAAa,GAAG;AACrC,aAAO;AAAA,IACT;AAIA,QAAI,SAAS,SAAS,8BAA8B,GAAG;AACrD,aAAO;AAAA,IACT;AAGA,QAAI,SAAS,SAAS,gCAAgC,GAAG;AAEvD,UAAI,SAAS,SAAS,GAAG,gCAAgC,WAAW,GAAG;AACrE,eAAO;AAAA,MACT;AAKA,aAAO;AAAA,IACT;AAAA,EACF;AAEA,MAAI,YAAY,kBAAkB,QAAQ;AAE1C,yBAAAC,SAAO,KAAK,sCAAsC;AAElD,MAAI,eAAe,kBAAkB,GAAG;AAExC,MAAI,cAAc,cAAc;AAC9B,WAAO;AAAA,EACT;AAEA,MAAI,QAAQ,SAAS,QAAQ,WAAW,EAAE;AAC1C,MAAI,CAAC,EAAE,GAAG,KAAK,IAAI,MAAM,MAAM,GAAG,EAAE,OAAO,OAAO;AAElD,MAAI,wBAAwB,IAAI,MAAM,CAAC,CAAC,GAAG;AACzC,WAAO;AAAA,EACT;AAMA,MAAI,QAAQ,CAAC,gBAAgB,eAAe,GAAI,mBAAmB,CAAC,CAAE;AAEtE,MAAI,CAAC,MAAM,KAAK,CAAC,SAAS,SAAS,SAAS,IAAI,CAAC,GAAG;AAClD;AAAA,EACF;AAEA,SAAO;AACT;AAEO,SAAS,8BAA8B,mBAAmB;AAc/D,MAAI,kBAAkB,kBAAkB,QAAQ,YAAY,GAAG;AAE/D,MAAI,SAAS,iBAAAD,QAAK,MAAM,eAAe;AAEvC,MAAI,MAAM,eAAe,GAAG;AAI1B,WAAO,OAAO;AAAA,EAChB;AAYA,MAAI,yBAAyB,iBAAAA,QAAK,KAAK,OAAO,KAAK,OAAO,IAAI;AAE9D,SAAO;AACT;AASO,SAAS,QAAQ,YAAY;AAClC,MAAI,gBAAgB,kBAAkB,UAAU;AAChD,MAAI,OAAO,WAAW,UAAU;AAOhC,MAAI,kBAAkB,WAAW,QAAQ,eAAe,EAAE;AAK1D,oBAAkB,gBAAgB,QAAQ,SAAS,GAAG;AAMtD,oBAAkB,gBAAgB;AAAA,IAChC,GAAG,8BAA8B;AAAA,IACjC;AAAA,EACF;AAEA,MAAI,yBAAyB,8BAA8B,eAAe;AAE1E,SAAO,GAAG,IAAI,GAAG,sBAAsB;AACzC;AAQA,IAAM,OAAO,oBAAI,IAAI;AAErB,SAAS,QAAQ,YAAY;AAC3B,MAAI,KAAK,IAAI,UAAU,EAAG,QAAO;AAEjC,MAAI,QAAQ,WAAW,MAAM,GAAG;AAEhC,WAAS,IAAI,MAAM,SAAS,GAAG,IAAI,GAAG,KAAK;AACzC,QAAI,UAAU,MAAM,MAAM,GAAG,CAAC,EAAE,KAAK,GAAG;AAExC,QAAI,OAAO,KAAK,IAAI,OAAO;AAE3B,QAAI,MAAM;AACR,aAAO;AAAA,IACT;AAAA,EACF;AACF;AAEO,SAAS,kBAAkB,YAAY,SAAS;AACrD,MAAI,MAAM,SAAS,OAAO;AAE1B,MAAI,WAAW,SAAS,8BAA8B,GAAG;AACvD,iBAAa,WAAW,MAAM,8BAA8B,EAAE,CAAC;AAAA,EACjE;AAEA,MAAI,WAAW,SAAS,GAAG,GAAG;AAC5B,iBAAa,WAAW,QAAQ,OAAO,EAAE;AAAA,EAC3C;AAEA,MAAI,OAAO,QAAQ,UAAU;AAE7B,MAAI,MAAM;AACR,WAAO;AAAA,EACT;AAEA,MAAI,gBAAgB,iBAAAA,QAAK,KAAK,YAAY,cAAc;AAExD,QAAM,cAAc,eAAAE,QAAO,WAAW,aAAa;AAEnD,MAAI,aAAa;AACf,WAAO;AAAA,EACT;AAEA,QAAM,kBAAkB,kBAAkB,YAAY,EAAE,IAAI,CAAC;AAE7D,MAAI,CAAC,iBAAiB;AACpB,UAAM,IAAI,MAAM,mCAAmC,UAAU,EAAE;AAAA,EACjE;AAEA,QAAM,gBAAgB,iBAAAF,QAAK,QAAQ,eAAe;AAElD,OAAK,IAAI,aAAa;AAEtB,SAAO;AACT;AAEA,SAAS,kBAAkB,WAAW,SAAS;AAC7C,MAAI,MAAM,SAAS,OAAO;AAC1B,MAAI,QAAQ,UAAU,MAAM,GAAG;AAE/B,WAAS,IAAI,MAAM,SAAS,GAAG,IAAI,GAAG,KAAK;AACzC,QAAI,UAAU,MAAM,MAAM,GAAG,CAAC,EAAE,KAAK,GAAG;AAExC,QAAI,cAAc,iBAAAA,QAAK,KAAK,SAAS,cAAc;AACnD,QAAI,SAAS,eAAAE,QAAO,WAAW,WAAW;AAE1C,QAAI,QAAQ;AACV,aAAO;AAAA,IACT;AAGA,QAAI,YAAY,KAAK;AACnB;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AACT;AAEA,IAAM,iBAAiB,oBAAI,IAAI;AAOxB,SAAS,WAAW,YAAY;AACrC,QAAM,YAAY,kBAAkB,UAAU;AAC9C,QAAM,WAAW,YAAY,SAAS;AAEtC,MAAI,SAAS,aAAa,GAAG;AAO3B,WAAO,SAAS;AAAA,EAClB;AAMA,MAAI,gBAAgB,iBAAAF,QAAK,KAAK,WAAW,uBAAuB;AAShE,MAAI,eAAAE,QAAO,WAAW,aAAa,GAAG;AAEpC,UAAM,QAAQ,QAAQ,aAAa;AACnC,UAAM,MAAM,MAAM,kBAAkB;AAEpC,WAAO,IAAI,gBAAgB,SAAS;AAAA,EACtC;AAKA,SAAO,SAAS;AAClB;AAKA,SAAS,YAAY,WAAW;AAC9B,MAAI,WAAW,eAAe,IAAI,SAAS;AAE3C,MAAI,UAAU;AACZ,WAAO;AAAA,EACT;AAEA,MAAI,SAAS,eAAAA,QAAO,aAAa,iBAAAF,QAAK,KAAK,WAAW,cAAc,CAAC;AACrE,MAAI,UAAU,OAAO,SAAS;AAC9B,MAAI,OAAO,KAAK,MAAM,OAAO;AAE7B,iBAAe,IAAI,WAAW,IAAI;AAElC,SAAO;AACT;;;ADnZO,SAAS,YAAY,UAAU;AACpC,MAAI,WAAW;AACf,MAAI,YAAY,kBAAkB,QAAQ;AAU1C,MAAI,YAAY,SAAS,SAAS,kBAAAG,QAAK,KAAK,WAAW,KAAK,CAAC;AAC7D,MAAI,YAAY,SAAS,SAAS,kBAAAA,QAAK,KAAK,WAAW,KAAK,CAAC;AAE7D,MACE,EAAE,aAAa,cACf,CAAC,SAAS,SAAS,2BAA2B,GAC9C;AACA,QAAI,cAAc,SAAS,QAAQ,WAAW,EAAE;AAChD,QAAI,CAAC,YAAY,GAAG,IAAI,IAAI,YAAY,MAAM,GAAG,EAAE,OAAO,OAAO;AACjE,QAAI,QAAQ;AAEZ,QAAI,WAAW,WAAW,GAAG,GAAG;AAC9B,UAAI,CAAC,EAAE,GAAG,MAAM,IAAI;AAEpB,cAAQ;AAAA,IACV;AAEA,QAAI,WAAW,kBAAAA,QAAK,KAAK,GAAG,KAAK;AAQjC,QAAI,gBAAgB,kBAAAA,QAAK,KAAK,WAAW,OAAO,QAAQ;AAExD,WAAO;AAAA,EACT;AAQA,MAAI,SAAS,SAAS,yCAAyC,GAAG;AAChE,QAAI,gBAAgB,SAAS;AAAA,MAC3B;AAAA,MACA;AAAA,IACF;AAEA,WAAO;AAAA,EACT;AAGA,MAAI,CAAC,SAAS,SAAS,SAAS,GAAG;AACjC,WAAO;AAAA,EACT;AAKA,SAAO;AACT;;;AG/EA,mCAAmB;;;ACOZ,SAAS,YAAY,WAAW,SAAS,cAAc;AAC5D,QAAM,UAAU,UAAU,MAAM,KAAK;AACrC,QAAM,iBAAiB,QACpB,OAAO,CAAC,MAAM,CAAC,EACf,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,EACnB,IAAI,CAAC,MAAM;AACV,QAAI,CAAC,gBAAgB,aAAa,IAAI,CAAC,GAAG;AACxC,UAAI,EAAE,SAAS,OAAO,EAAG,QAAO;AAEhC,aAAO,IAAI,MAAM;AAAA,IACnB;AAEA,WAAO;AAAA,EACT,CAAC,EACA,KAAK,GAAG;AAEX,QAAM,6BAA6B,UAAU;AAAA,IAC3C,UAAU,UAAU,EAAE,QAAQ;AAAA,IAC9B;AAAA,EACF;AAEA,SAAO;AACT;;;ADzBO,SAAS,eAAe,EAAE,SAAS,MAAM,QAAQ,GAAG;AACzD,MAAI,QAAQ,CAAC;AAGb,MAAI,wBAAwB,CAAC,gBAAgB,aAAa;AAE1D,WAAS,cAAc,KAAK;AAC1B,QAAI,CAAC,IAAK,QAAO;AAEjB,WAAO,sBAAsB,KAAK,CAAC,cAAc,cAAc,GAAG;AAAA,EACpE;AAEA,SAAO;AAAA,IACL,SAAS,MAAM;AACb,UAAI,KAAK,SAAS,SAAS;AACzB,YAAI,KAAK,MAAM,SAAS,cAAc,KAAK,MAAM,OAAO;AACtD,gBAAM,eAAe,YAAY,KAAK,MAAM,OAAO,SAAS,OAAO;AAEnE,eAAK,MAAM,QAAQ;AAAA,QACrB,WAAW,KAAK,MAAM,SAAS,mBAAmB;AAChD,mBAAS,QAAQ,KAAK,MAAM,OAAO;AACjC,gBAAI,KAAK,SAAS,cAAc,KAAK,OAAO;AAC1C,oBAAM,eAAe,YAAY,KAAK,OAAO,SAAS,OAAO;AAE7D,mBAAK,QAAQ;AAAA,YACf,WAAW,KAAK,SAAS,qBAAqB;AAC5C,2CAAAC,QAAO,SAAS,MAAM;AAAA,gBACpB,cAAcC,OAAM;AAClB,wBAAM,eAAe;AAAA,oBACnBA,MAAK;AAAA,oBACL;AAAA,oBACA;AAAA,kBACF;AAEA,kBAAAA,MAAK,QAAQ;AAAA,gBACf;AAAA,cACF,CAAC;AAAA,YACH;AAAA,UACF;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,IAEA,YAAY,MAAM;AAChB,UAAI,KAAK,IAAI,KAAK,GAAG,GAAG;AAEtB,cAAM,YAAY,KAAK,WAAW,KAAK,CAAC,SAAS,KAAK,SAAS,OAAO;AAEtE,YAAI,WAAW;AACb,oBAAU,MAAM,SAAS,MAAM;AAAA,QACjC,OAAO;AAEL,eAAK,WAAW;AAAA,YACd,6BAAAD,QAAO,SAAS,KAAK,SAAS,6BAAAA,QAAO,SAAS,KAAK,OAAO,CAAC;AAAA,UAC7D;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,IAEA,KAAK;AAAA,MACH,MAAM,MAAM;AACV,cAAM,KAAK,IAAI;AAAA,MACjB;AAAA,MACA,OAAO;AACL,cAAM,IAAI;AAAA,MACZ;AAAA,IACF;AAAA,IAEA,kBAAkB,MAAM;AACtB,UAAI;AAEJ,UACE,cAAc,SAAS,KAAK,IAAI,CAAC,KACjC,KAAK,QAAQ,WAAW,KACxB,KAAK,OAAO,CAAC,EAAE,SAAS,iBACxB;AACA,mBAAW,KAAK,OAAO,CAAC,EAAE;AAAA,MAC5B;AAEA,UACE,cAAc,SAAS,KAAK,MAAM,IAAI,CAAC,KACvC,KAAK,MAAM,QAAQ,WAAW,KAC9B,KAAK,MAAM,OAAO,CAAC,EAAE,SAAS,iBAC9B;AACA,mBAAW,KAAK,KAAK,OAAO,CAAC,EAAE;AAAA,MACjC;AAEA,UAAI,UAAU;AACZ,cAAM,WAAW,6BAAAA,QAAO,SAAS,KAAK,YAAY,UAAU,OAAO,CAAC;AACpE,cAAM,SAAS,MAAM,MAAM,SAAS,CAAC;AAErC,YAAI,OAAO,SAAS,YAAY;AAC9B,iBAAO,YAAY;AAAA,QACrB;AAEA,eAAO;AAAA,MACT;AAAA,IACF;AAAA,IAEA,cAAc,MAAM;AAClB,UACE,cAAc,SAAS,KAAK,IAAI,CAAC,KACjC,KAAK,QAAQ,WAAW,KACxB,KAAK,OAAO,CAAC,EAAE,SAAS,iBACxB;AACA,cAAM,WAAW,KAAK,OAAO,CAAC,EAAE;AAChC,cAAM,WAAW,6BAAAA,QAAO,SAAS;AAAA,UAC/B;AAAA,UACA,YAAY,UAAU,OAAO;AAAA,QAC/B;AAEA,eAAO;AAAA,MACT;AAAA,IACF;AAAA,EACF;AACF;AAEA,SAAS,SAASE,OAAM;AACtB,MAAI,CAACA,MAAM;AAEX,MAAI,WAAWA,OAAM;AACnB,WAAOA,MAAK;AAAA,EACd;AAMA,SAAOA,MAAK;AACd;;;APrHA,IAAM,aAAa;AAAA,EACjB,MAAM;AAAA,EACN,SAAS,CAAC;AACZ;AAKO,SAAS,aAAa,QAAQ;AAKnC,SAAO,SAAS,UAAU,KAAK;AAC7B,QAAI,aAAa,eAAe,IAAI,UAAU;AAAA,MAC5C,iBAAiB,OAAO;AAAA,MACxB,KAAK,QAAQ,IAAI;AAAA,IACnB,CAAC;AAED,QAAI,CAAC,YAAY;AACf,aAAO;AAAA,IACT;AAEA,QAAI,eAAe,YAAY,IAAI,QAAQ;AAC3C,QAAI,aAAa,QAAQ,YAAY;AAErC,QAAI,UAAU,WAAW,YAAY;AACrC,QAAI,OAAO,WAAW,OAAO;AAC7B,QAAI,UAAU,mBAAmB,UAAU;AAE3C,QAAI,CAAC,MAAM;AACT,aAAO;AAAA,IACT;AAEA,QAAI,WAAW,eAAe;AAAA,MAC5B,SAAS,KAAK;AAAA,MACd,MAAM,KAAK;AAAA,MACX;AAAA,IACF,CAAC;AAED,WAAO;AAAA,MACL,MAAM;AAAA,MACN,SAAS;AAAA;AAAA,QAEP,GAAG;AAAA;AAAA;AAAA,QAGH,YAAY,MAAM;AAChB,iBAAO,SAAS,SAAS,GAAG,IAAI;AAAA,QAClC;AAAA,QACA,eAAe,MAAM;AACnB,iBAAO,SAAS,YAAY,GAAG,IAAI;AAAA,QACrC;AAAA,QACA,qBAAqB,MAAM;AACzB,iBAAO,SAAS,kBAAkB,GAAG,IAAI;AAAA,QAC3C;AAAA,QACA,iBAAiB,MAAM;AACrB,iBAAO,SAAS,cAAc,GAAG,IAAI;AAAA,QACvC;AAAA,MACF;AAAA,IACF;AAAA,EACF;AACF;",
  "names": ["parser", "postcss", "import_node_path", "md5", "path", "assert", "fsSync", "path", "recast", "node", "path"]
}

|
|
471
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/build/template-plugin.js", "../../src/lib/css/utils.js", "../../src/lib/getClassesTagsFromCss.js", "../../src/lib/isInsideGlobal.js", "../../src/lib/path/template-transform-paths.js", "../../src/lib/path/utils.js", "../../src/lib/path/hash-from-module-path.js", "../../src/lib/rewriteHbs.js", "../../src/lib/renameClass.js"],
  "sourcesContent": ["/**\n * @typedef {import('@glimmer/syntax').ASTPlugin} ASTPlugin\n * @typedef {import('@glimmer/syntax').ASTPluginEnvironment} ASTPluginEnvironment\n *\n */\n\nimport { getCSSInfo } from '../lib/css/utils.js';\nimport { fixFilename } from '../lib/path/template-transform-paths.js';\nimport {\n  appPath,\n  cssPathFor,\n  hashFromModulePath,\n  isRelevantFile,\n} from '../lib/path/utils.js';\nimport { templatePlugin } from '../lib/rewriteHbs.js';\n\nconst noopPlugin = {\n  name: 'ember-scoped-css:noop',\n  visitor: {},\n};\n\n/**\n * @returns {ASTPlugin}\n */\nexport function createPlugin(config) {\n  /**\n   *\n   * @param {ASTPluginEnvironment} env\n   */\n  return function scopedCss(env) {\n    let isRelevant = isRelevantFile(env.filename, {\n      additionalRoots: config.additionalRoots,\n      cwd: process.cwd(),\n    });\n\n    if (!isRelevant) {\n      return noopPlugin;\n    }\n\n    let absolutePath = fixFilename(env.filename);\n    let modulePath = appPath(absolutePath);\n\n    let cssPath = cssPathFor(absolutePath);\n    let info = getCSSInfo(cssPath);\n    let postfix = hashFromModulePath(modulePath);\n\n    if (!info) {\n      return noopPlugin;\n    }\n\n    let visitors = templatePlugin({\n      classes: info.classes,\n      tags: info.tags,\n      postfix,\n    });\n\n    return {\n      name: 'ember-scoped-css:template-plugin',\n      visitor: {\n        // Stack Manager\n        ...visitors,\n        // Visitors broken out like this so we can conditionally\n        // debug based on file path.\n        AttrNode(...args) {\n          return visitors.AttrNode(...args);\n        },\n        ElementNode(...args) {\n          return visitors.ElementNode(...args);\n        },\n        MustacheStatement(...args) {\n          return visitors.MustacheStatement(...args);\n        },\n        SubExpression(...args) {\n          return visitors.SubExpression(...args);\n        },\n      },\n    };\n  };\n}\n", "import { existsSync, readFileSync } from 'fs';\n\nimport getClassesTagsFromCss from '../getClassesTagsFromCss.js';\n\n/**\n * @param {string} cssPath path to a CSS file\n */\nexport function getCSSInfo(cssPath) {\n  if (!existsSync(cssPath)) {\n    return null;\n  }\n\n  let css = readFileSync(cssPath, 'utf8');\n  let result = getClassesTagsFromCss(css);\n\n  return result;\n}\n", "import postcss from 'postcss';\nimport parser from 'postcss-selector-parser';\n\nimport isInsideGlobal from './isInsideGlobal.js';\n\nfunction getClassesAndTags(sel, classes, tags) {\n  const transform = (sls) => {\n    sls.walk((selector) => {\n      if (selector.type === 'class' && !isInsideGlobal(selector)) {\n        classes.add(selector.value);\n      } else if (selector.type === 'tag' && !isInsideGlobal(selector)) {\n        tags.add(selector.value);\n      }\n    });\n  };\n\n  parser(transform).processSync(sel);\n}\n\nexport default function getClassesTagsFromCss(css) {\n  const classes = new Set();\n  const tags = new Set();\n\n  const ast = postcss.parse(css);\n\n  ast.walk((node) => {\n    if (node.type === 'rule') {\n      getClassesAndTags(node.selector, classes, tags);\n    }\n  });\n\n  return { classes, tags };\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", "import path from 'node:path';\n\nimport { findWorkspacePath } from './utils.js';\n\n/**\n * template plugins do not hand us the correct file path.\n * additionally, we may not be able to rely on this data in the future,\n * so this functions acts as a means of normalizing _whatever_ we're given\n * in the future.\n *\n * @param {string} filename\n * @returns {string} the absolute path to the file\n */\nexport function fixFilename(filename) {\n  let fileName = filename;\n  let workspace = findWorkspacePath(fileName);\n\n  /**\n   * ember-source 5.8:\n   * - the filename looks like an absolute path, but swapped out the 'app' part of the path\n   *   with the module name, so the file paths never exist on disk\n   *\n   * - in vite apps:\n   *   the 'app' part _may_ be `src`, so we also need to ensure that `src` is excluded as well\n   */\n  let hasAppDir = fileName.includes(path.join(workspace, 'app'));\n  let hasSrcDir = fileName.includes(path.join(workspace, 'src'));\n\n  if (\n    !(hasAppDir || hasSrcDir) &&\n    !fileName.includes('/node_modules/.embroider/')\n  ) {\n    let maybeModule = fileName.replace(workspace, '');\n    let [maybeScope, ...rest] = maybeModule.split('/').filter(Boolean);\n    let parts = rest;\n\n    if (maybeScope.startsWith('@')) {\n      let [, ...rester] = rest;\n\n      parts = rester;\n    }\n\n    let relative = path.join(...parts);\n\n    /**\n     * We don't actually know if this file is an app.\n     * it could be an addon (v1 or v2)\n     *\n     * So here we log to see if we have unhandled situations.\n     */\n    let candidatePath = path.join(workspace, 'app', relative);\n\n    return candidatePath;\n  }\n\n  /**\n   * under embroider@3, the fileName will be the path to the rewritten file.\n   * we don't want this.\n   * we want the path to the original source.\n   * Through the powers of \u2728 convention \u2728, we can map back to source.\n   */\n  if (fileName.includes('/node_modules/.embroider/rewritten-app/')) {\n    let candidatePath = fileName.replace(\n      '/node_modules/.embroider/rewritten-app/',\n      '/app/',\n    );\n\n    return candidatePath;\n  }\n\n  // TODO: why are we passed files to other projects?\n  if (!fileName.includes(workspace)) {\n    return fileName;\n  }\n\n  // Fallback to what the plugin system gives us.\n  // This may be wrong, and if wrong, reveals\n  // unhandled scenarios with the file names in the plugin infra\n  return fileName;\n}\n", "import assert from 'node:assert';\nimport fsSync from 'node:fs';\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 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'];\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 * 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  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 = require(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", "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 recast from 'ember-template-recast';\n\nimport { renameClass } from './renameClass.js';\n\nexport function templatePlugin({ classes, tags, postfix }) {\n  let stack = [];\n  // scoped-class is a global we allow in hbs\n  // scopedClass is importable, and we'll error if someone tries to rename it\n  let scopedClassCandidates = ['scoped-class', 'scopedClass'];\n\n  function isScopedClass(str) {\n    if (!str) return false;\n\n    return scopedClassCandidates.some((candidate) => candidate === str);\n  }\n\n  return {\n    AttrNode(node) {\n      if (node.name === 'class') {\n        if (node.value.type === 'TextNode' && node.value.chars) {\n          const renamedClass = renameClass(node.value.chars, postfix, classes);\n\n          node.value.chars = renamedClass;\n        } else if (node.value.type === 'ConcatStatement') {\n          for (let part of node.value.parts) {\n            if (part.type === 'TextNode' && part.chars) {\n              const renamedClass = renameClass(part.chars, postfix, classes);\n\n              part.chars = renamedClass;\n            } else if (part.type === 'MustacheStatement') {\n              recast.traverse(part, {\n                StringLiteral(node) {\n                  const renamedClass = renameClass(\n                    node.value,\n                    postfix,\n                    classes,\n                  );\n\n                  node.value = renamedClass;\n                },\n              });\n            }\n          }\n        }\n      }\n    },\n\n    ElementNode(node) {\n      if (tags.has(node.tag)) {\n        // check if class attribute already exists\n        const classAttr = node.attributes.find((attr) => attr.name === 'class');\n\n        if (classAttr) {\n          classAttr.value.chars += ' ' + postfix;\n        } else {\n          // push class attribute\n          node.attributes.push(\n            recast.builders.attr('class', recast.builders.text(postfix)),\n          );\n        }\n      }\n    },\n\n    All: {\n      enter(node) {\n        stack.push(node);\n      },\n      exit() {\n        stack.pop();\n      },\n    },\n\n    MustacheStatement(node) {\n      let cssClass;\n\n      if (\n        isScopedClass(getValue(node.path)) &&\n        node.params?.length === 1 &&\n        node.params[0].type === 'StringLiteral'\n      ) {\n        cssClass = node.params[0].value;\n      }\n\n      if (\n        isScopedClass(getValue(node.path?.path)) &&\n        node.path?.params?.length === 1 &&\n        node.path?.params[0].type === 'StringLiteral'\n      ) {\n        cssClass = node.path.params[0].value;\n      }\n\n      if (cssClass) {\n        const textNode = recast.builders.text(renameClass(cssClass, postfix));\n        const parent = stack[stack.length - 1];\n\n        if (parent.type === 'AttrNode') {\n          parent.quoteType = '\"';\n        }\n\n        return textNode;\n      }\n    },\n\n    SubExpression(node) {\n      if (\n        isScopedClass(getValue(node.path)) &&\n        node.params?.length === 1 &&\n        node.params[0].type === 'StringLiteral'\n      ) {\n        const cssClass = node.params[0].value;\n        const textNode = recast.builders.literal(\n          'StringLiteral',\n          renameClass(cssClass, postfix),\n        );\n\n        return textNode;\n      }\n    },\n  };\n}\n\nfunction getValue(path) {\n  if (!path) return;\n\n  if ('value' in path) {\n    return path.value;\n  }\n\n  /**\n   * Deprecated in ember 5.9+\n   * (so we use the above for newer embers)\n   */\n  return path.original;\n}\n\nexport default function rewriteHbs(hbs, classes, tags, postfix) {\n  let ast = recast.parse(hbs);\n\n  recast.traverse(ast, templatePlugin({ classes, tags, postfix }));\n\n  let result = recast.print(ast);\n\n  return result;\n}\n", "/**\n *\n * @param {string} className\n * @param {string} postfix\n * @param {Set<string>} [classesInCss]\n * @returns\n */\nexport function renameClass(className, postfix, classesInCss) {\n  const classes = className.split(/\\s+/);\n  const renamedClasses = classes\n    .filter((c) => c)\n    .map((c) => c.trim())\n    .map((c) => {\n      if (!classesInCss || classesInCss.has(c)) {\n        if (c.endsWith(postfix)) return c;\n\n        return c + '_' + postfix;\n      }\n\n      return c;\n    })\n    .join(' ');\n\n  const renamedWithPreservedSpaces = className.replace(\n    className.trimStart().trimEnd(),\n    renamedClasses,\n  );\n\n  return renamedWithPreservedSpaces;\n}\n"],
  "mappings": "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",
  "names": ["parser", "postcss", "import_node_path", "md5", "path", "assert", "fsSync", "path", "recast", "node", "path"]
}

|
package/package.json
CHANGED
|
@@ -6,7 +6,7 @@ import process from 'node:process';
|
|
|
6
6
|
import { createUnplugin } from 'unplugin';
|
|
7
7
|
|
|
8
8
|
import getClassesTagsFromCss from '../lib/getClassesTagsFromCss.js';
|
|
9
|
-
import { hashFromAbsolutePath } from '../lib/path/utils.js';
|
|
9
|
+
import { hashFromAbsolutePath, isRelevantFile } from '../lib/path/utils.js';
|
|
10
10
|
import replaceHbsInJs from '../lib/replaceHbsInJs.js';
|
|
11
11
|
import rewriteCss from '../lib/rewriteCss.js';
|
|
12
12
|
import rewriteHbs from '../lib/rewriteHbs.js';
|
|
@@ -120,6 +120,9 @@ export default createUnplugin(
|
|
|
120
120
|
* @param {Options} [options]
|
|
121
121
|
*/
|
|
122
122
|
(options) => {
|
|
123
|
+
let cwd = process.cwd();
|
|
124
|
+
let additionalRoots = options?.additionalRoots || [];
|
|
125
|
+
|
|
123
126
|
return {
|
|
124
127
|
name: 'ember-scoped-css-unplugin',
|
|
125
128
|
|
|
@@ -139,6 +142,8 @@ export default createUnplugin(
|
|
|
139
142
|
/* deliberately do nothing */
|
|
140
143
|
},
|
|
141
144
|
transform(code, jsPath) {
|
|
145
|
+
if (!isRelevantFile(jsPath, { additionalRoots, cwd })) return;
|
|
146
|
+
|
|
142
147
|
/**
|
|
143
148
|
* HBS files are actually JS files with a call to precompileTemplate
|
|
144
149
|
*/
|
|
@@ -153,6 +158,8 @@ export default createUnplugin(
|
|
|
153
158
|
},
|
|
154
159
|
|
|
155
160
|
transform(code, jsPath) {
|
|
161
|
+
if (!isRelevantFile(jsPath, { additionalRoots, cwd })) return;
|
|
162
|
+
|
|
156
163
|
/**
|
|
157
164
|
* HBS files are actually JS files with a call to precompileTemplate
|
|
158
165
|
*/
|
package/src/lib/path/utils.js
CHANGED
|
@@ -127,6 +127,11 @@ export function withoutExtension(filePath) {
|
|
|
127
127
|
* @returns
|
|
128
128
|
*/
|
|
129
129
|
export function isRelevantFile(fileName, { additionalRoots, cwd }) {
|
|
130
|
+
// Private Virtual Modules
|
|
131
|
+
if (fileName.startsWith('\0')) return false;
|
|
132
|
+
// These are not valid userland names (or are from libraries)
|
|
133
|
+
if (fileName.match(/^[a-zA-Z]/)) return false;
|
|
134
|
+
// External to us
|
|
130
135
|
if (fileName.startsWith('/@embroider')) return false;
|
|
131
136
|
if (IRRELEVANT_PATHS.some((i) => fileName.includes(i))) return false;
|
|
132
137
|
|