ember-scoped-css 0.16.0 → 0.17.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -184,6 +184,19 @@ There is a `scoped-class` helper that you can use to pass a class name as an arg
184
184
  />
185
185
  ```
186
186
 
187
+ In gjs/gts/`<template>`, the above would look like:
188
+ ```gjs
189
+ import { scopedClass } from 'ember-scoped-css';
190
+
191
+ <template>
192
+ <OtherComponent @internalClass={{scopedClass 'hello-class'}} />
193
+ <OtherComponent @internalClass={{(scopedClass 'hello-class')}} />
194
+ <OtherComponent
195
+ @internalClass={{concat (scopedClass 'hello-class') ' other-class'}}
196
+ />
197
+ </template>
198
+ ```
199
+
187
200
  ## Testing
188
201
 
189
202
  As classes are renamed during the build process you can't directly verify if classes are present in your tests. To solve this problem you can use the `scopedClass` function from the `ember-scoped-css/test-support` module. The function takes the class names and path to the CSS file where are the classes defined and returns the scoped class names.
@@ -199,4 +199,4 @@ async function app_css_loader_default(code) {
199
199
  }
200
200
  return rewrittenCss;
201
201
  }
202
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/build/app-css-loader.js", "../../../src/lib/fsExists.js", "../../../src/lib/generateAbsolutePathHash.js", "../../../src/lib/generateRelativePathHash.ts", "../../../src/lib/rewriteCss.js", "../../../src/lib/isInsideGlobal.js"],
  "sourcesContent": ["// import { createUnplugin }  from 'unplugin';\nimport path from 'node:path';\n\nimport fsExists from '../lib/fsExists.js';\nimport generateHash from '../lib/generateAbsolutePathHash.js';\nimport rewriteCss from '../lib/rewriteCss.js';\n\nexport default async function (code) {\n  const options = this.getOptions();\n  const cssPath = this.resourcePath;\n  const cssFileName = path.basename(cssPath);\n\n  const postfix = generateHash(cssPath);\n\n  const hbsPath = cssPath.replace('.css', '.hbs');\n  const gjsPath = cssPath.replace('.css', '.js');\n  const [hbsExists, gjsExists] = await Promise.all([\n    fsExists(hbsPath),\n    fsExists(gjsPath),\n  ]);\n\n  let rewrittenCss;\n\n  if (hbsExists || (gjsExists && cssPath.startsWith(this.rootContext))) {\n    rewrittenCss = rewriteCss(code, postfix, cssFileName, options.layerName);\n  } else {\n    rewrittenCss = code;\n  }\n\n  return rewrittenCss;\n}\n", "import { stat } from 'node:fs/promises';\n\nexport default async function (path) {\n  try {\n    await stat(path);\n\n    return true;\n  } catch (e) {\n    return false;\n  }\n}\n", "import fsSync from 'node:fs';\nimport path from 'node:path';\n\nimport findUp from 'find-up';\n\nimport generateHash from './generateRelativePathHash.ts';\n\nexport default function generateHashFromAbsolutePath(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\n  const hash = generateHash(modulePath);\n\n  return hash;\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  /**\n   * Pods support.\n   * For pods, we chop off the whole file, and use the dir name as the \"modulePath\"\n   *\n   * Note that pods for components will never be supported.\n   */\n  let isPod =\n    !packageRelative.includes('/components/') &&\n    (packageRelative.endsWith('styles.css') ||\n      packageRelative.endsWith('template.hbs') ||\n      packageRelative.endsWith('template.js'));\n\n  if (isPod) {\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 */\nfunction appPath(sourcePath) {\n  let workspacePath = findWorkspacePath(sourcePath);\n  let name = workspacePackageName(sourcePath);\n\n  /**\n   *  Under embroider builds, the spec-compliant version of the app\n   * has all the files under a folder which represents the package name,\n   * rather than \"app\".\n   */\n  let packageRelative = sourcePath.replace(workspacePath, '');\n\n  let localPackagerStylePath = packageScopedPathToModulePath(packageRelative);\n\n  return `${name}${localPackagerStylePath}`;\n}\n\nconst CACHE = new Set();\n\n/**\n * For a given source path, if we have seen a\n * source file within the workspace directory,\n * find that workspace directory and return it.\n */\nfunction hasSeen(sourcePath) {\n  for (let entry of CACHE) {\n    if (sourcePath.startsWith(entry)) {\n      return entry;\n    }\n  }\n\n  // we have not seen this source path yet\n  return;\n}\n\n/**\n * Populates the \"seen\" workspace cache,\n * so that we don't hit the file system too often.\n */\nfunction findWorkspacePath(sourcePath) {\n  let seen = hasSeen(sourcePath);\n\n  if (seen) {\n    return seen;\n  }\n\n  const packageJsonPath = findUp.sync('package.json', {\n    cwd: path.dirname(sourcePath),\n  });\n\n  const workspacePath = path.dirname(packageJsonPath);\n\n  CACHE.add(workspacePath);\n\n  return workspacePath;\n}\n\nconst MANIFEST_CACHE = new Map();\n\n/**\n * returns the package.json#name for a given sourcePath\n */\nfunction workspacePackageName(sourcePath) {\n  const workspace = findWorkspacePath(sourcePath);\n\n  let existing = MANIFEST_CACHE.get(workspace);\n\n  if (existing) {\n    return existing.name;\n  }\n\n  let buffer = fsSync.readFileSync(path.join(workspace, 'package.json'));\n  let content = buffer.toString();\n  let json = JSON.parse(content);\n\n  MANIFEST_CACHE.set(workspace, json);\n\n  return json.name;\n}\n\n", "import md5 from 'blueimp-md5';\n\nexport default function generateRelativePathHash(relativePath: string) {\n  return 'e' + md5(relativePath).substring(0, 8);\n}\n", "import postcss from 'postcss';\nimport parser from 'postcss-selector-parser';\n\nimport isInsideGlobal from './isInsideGlobal.js';\n\nfunction rewriteSelector(sel, postfix) {\n  const transform = (selectors) => {\n    selectors.walk((selector) => {\n      if (selector.type === 'class' && !isInsideGlobal(selector)) {\n        selector.value += '_' + postfix;\n      } else if (selector.type === 'tag' && !isInsideGlobal(selector)) {\n        selector.replaceWith(\n          parser.tag({ value: selector.value }),\n          parser.className({ value: postfix }),\n        );\n      }\n    });\n\n    // remove :global\n    selectors.walk((selector) => {\n      if (selector.type === 'pseudo' && selector.value === ':global') {\n        selector.replaceWith(...selector.nodes);\n      }\n    });\n  };\n  const transformed = parser(transform).processSync(sel);\n\n  return transformed;\n}\n\nfunction isInsideKeyframes(node) {\n  const parent = node.parent;\n\n  if (!parent) return false;\n  if (parent.type === 'atrule' && parent.name === 'keyframes') return true;\n\n  return isInsideKeyframes(parent);\n}\n\nexport default function rewriteCss(css, postfix, fileName, layerName) {\n  const layerNameWithDefault = layerName ?? 'components';\n  const ast = postcss.parse(css);\n\n  ast.walk((node) => {\n    if (node.type === 'rule' && !isInsideKeyframes(node)) {\n      node.selector = rewriteSelector(node.selector, postfix);\n    }\n  });\n\n  const rewrittenCss = ast.toString();\n\n  if (!layerNameWithDefault) {\n    return `/* ${fileName} */\\n${rewrittenCss}\\n`;\n  }\n\n  return (\n    `/* ${fileName} */\\n@layer ${layerNameWithDefault} {\\n\\n` +\n    rewrittenCss +\n    '\\n}\\n'\n  );\n}\n\n", "export default function isInsideGlobal(node, func) {\n  const parent = node.parent;\n\n  if (!parent) return false;\n  if (parent.type === 'pseudo' && parent.value === ':global') return true;\n\n  return isInsideGlobal(parent, func);\n}\n"],
  "mappings": "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",
  "names": ["import_node_path", "path", "md5", "path", "findUp", "fsSync", "parser", "postcss", "path"]
}

202
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/build/app-css-loader.js", "../../../src/lib/fsExists.js", "../../../src/lib/generateAbsolutePathHash.js", "../../../src/lib/generateRelativePathHash.ts", "../../../src/lib/rewriteCss.js", "../../../src/lib/isInsideGlobal.js"],
  "sourcesContent": ["// import { createUnplugin }  from 'unplugin';\nimport path from 'node:path';\n\nimport fsExists from '../lib/fsExists.js';\nimport generateHash from '../lib/generateAbsolutePathHash.js';\nimport rewriteCss from '../lib/rewriteCss.js';\n\nexport default async function (code) {\n  const options = this.getOptions();\n  const cssPath = this.resourcePath;\n  const cssFileName = path.basename(cssPath);\n\n  const postfix = generateHash(cssPath);\n\n  const hbsPath = cssPath.replace('.css', '.hbs');\n  const gjsPath = cssPath.replace('.css', '.js');\n  const [hbsExists, gjsExists] = await Promise.all([\n    fsExists(hbsPath),\n    fsExists(gjsPath),\n  ]);\n\n  let rewrittenCss;\n\n  if (hbsExists || (gjsExists && cssPath.startsWith(this.rootContext))) {\n    rewrittenCss = rewriteCss(code, postfix, cssFileName, options.layerName);\n  } else {\n    rewrittenCss = code;\n  }\n\n  return rewrittenCss;\n}\n", "import { stat } from 'node:fs/promises';\n\nexport default async function (path) {\n  try {\n    await stat(path);\n\n    return true;\n  } catch (e) {\n    return false;\n  }\n}\n", "import fsSync from 'node:fs';\nimport path from 'node:path';\n\nimport findUp from 'find-up';\n\nimport generateHash from './generateRelativePathHash.ts';\n\nexport default function generateHashFromAbsolutePath(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\n  const hash = generateHash(modulePath);\n\n  return hash;\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  /**\n   * Pods support.\n   * For pods, we chop off the whole file, and use the dir name as the \"modulePath\"\n   *\n   * Note that pods for components will never be supported.\n   */\n  let isPod =\n    !packageRelative.includes('/components/') &&\n    (packageRelative.endsWith('styles.css') ||\n      packageRelative.endsWith('template.hbs') ||\n      packageRelative.endsWith('template.js'));\n\n  if (isPod) {\n    return parsed.dir;\n  }\n\n  /**\n   * If an extension is passed, remove it.\n   * When using packagers, folks are used to not having to specify extensions for files.\n   * Since we don't even emit css files co-located to each module,\n   * this helps us not convey a lie that a file may exist in at runtime.\n   *\n   * For example `<module-name>/components/button`.\n   * It doesn't matter what the extension is, because you can only have one css file\n   * for the button module anyway.\n   */\n  let localPackagerStylePath = path.join(parsed.dir, parsed.name);\n\n  return localPackagerStylePath;\n}\n\n/**\n * returns the app-module path of the source file\n *\n * This assumes normal ember app conventions\n *\n * which is `<package.json#name>/path-to-file`\n */\nexport function appPath(sourcePath) {\n  let workspacePath = findWorkspacePath(sourcePath);\n  let name = workspacePackageName(sourcePath);\n\n  /**\n   *  Under embroider builds, the spec-compliant version of the app\n   * has all the files under a folder which represents the package name,\n   * rather than \"app\".\n   */\n  let packageRelative = sourcePath.replace(workspacePath, '');\n\n  let localPackagerStylePath = packageScopedPathToModulePath(packageRelative);\n\n  return `${name}${localPackagerStylePath}`;\n}\n\nconst CACHE = new Set();\n\n/**\n * For a given source path, if we have seen a\n * source file within the workspace directory,\n * find that workspace directory and return it.\n */\nfunction hasSeen(sourcePath) {\n  for (let entry of CACHE) {\n    if (sourcePath.startsWith(entry)) {\n      return entry;\n    }\n  }\n\n  // we have not seen this source path yet\n  return;\n}\n\n/**\n * Populates the \"seen\" workspace cache,\n * so that we don't hit the file system too often.\n */\nfunction findWorkspacePath(sourcePath) {\n  let seen = hasSeen(sourcePath);\n\n  if (seen) {\n    return seen;\n  }\n\n  const packageJsonPath = findUp.sync('package.json', {\n    cwd: path.dirname(sourcePath),\n  });\n\n  const workspacePath = path.dirname(packageJsonPath);\n\n  CACHE.add(workspacePath);\n\n  return workspacePath;\n}\n\nconst MANIFEST_CACHE = new Map();\n\n/**\n * returns the package.json#name for a given sourcePath\n */\nfunction workspacePackageName(sourcePath) {\n  const workspace = findWorkspacePath(sourcePath);\n\n  let existing = MANIFEST_CACHE.get(workspace);\n\n  if (existing) {\n    return existing.name;\n  }\n\n  let buffer = fsSync.readFileSync(path.join(workspace, 'package.json'));\n  let content = buffer.toString();\n  let json = JSON.parse(content);\n\n  MANIFEST_CACHE.set(workspace, json);\n\n  return json.name;\n}\n\n", "import md5 from 'blueimp-md5';\n\nexport default function generateRelativePathHash(relativePath: string) {\n  return 'e' + md5(relativePath).substring(0, 8);\n}\n", "import postcss from 'postcss';\nimport parser from 'postcss-selector-parser';\n\nimport isInsideGlobal from './isInsideGlobal.js';\n\nfunction rewriteSelector(sel, postfix) {\n  const transform = (selectors) => {\n    selectors.walk((selector) => {\n      if (selector.type === 'class' && !isInsideGlobal(selector)) {\n        selector.value += '_' + postfix;\n      } else if (selector.type === 'tag' && !isInsideGlobal(selector)) {\n        selector.replaceWith(\n          parser.tag({ value: selector.value }),\n          parser.className({ value: postfix }),\n        );\n      }\n    });\n\n    // remove :global\n    selectors.walk((selector) => {\n      if (selector.type === 'pseudo' && selector.value === ':global') {\n        selector.replaceWith(...selector.nodes);\n      }\n    });\n  };\n  const transformed = parser(transform).processSync(sel);\n\n  return transformed;\n}\n\nfunction isInsideKeyframes(node) {\n  const parent = node.parent;\n\n  if (!parent) return false;\n  if (parent.type === 'atrule' && parent.name === 'keyframes') return true;\n\n  return isInsideKeyframes(parent);\n}\n\nexport default function rewriteCss(css, postfix, fileName, layerName) {\n  const layerNameWithDefault = layerName ?? 'components';\n  const ast = postcss.parse(css);\n\n  ast.walk((node) => {\n    if (node.type === 'rule' && !isInsideKeyframes(node)) {\n      node.selector = rewriteSelector(node.selector, postfix);\n    }\n  });\n\n  const rewrittenCss = ast.toString();\n\n  if (!layerNameWithDefault) {\n    return `/* ${fileName} */\\n${rewrittenCss}\\n`;\n  }\n\n  return (\n    `/* ${fileName} */\\n@layer ${layerNameWithDefault} {\\n\\n` +\n    rewrittenCss +\n    '\\n}\\n'\n  );\n}\n\n", "export default function isInsideGlobal(node, func) {\n  const parent = node.parent;\n\n  if (!parent) return false;\n  if (parent.type === 'pseudo' && parent.value === ':global') return true;\n\n  return isInsideGlobal(parent, func);\n}\n"],
  "mappings": "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",
  "names": ["import_node_path", "path", "md5", "path", "findUp", "fsSync", "parser", "postcss", "path"]
}

@@ -463,18 +463,53 @@ var parseOptions2 = {
463
463
  }
464
464
  }
465
465
  };
466
+ function removeScopeBagReference(ast, scopedClass) {
467
+ if (!scopedClass)
468
+ return;
469
+ import_recast2.default.visit(ast, {
470
+ visitObjectProperty(path6) {
471
+ if (path6.node.value.type === "Identifier" && path6.node.value.name === scopedClass) {
472
+ path6.prune();
473
+ return false;
474
+ }
475
+ this.traverse(path6);
476
+ }
477
+ });
478
+ }
466
479
  function replaceHbsInJs_default(script, replaceFunction) {
467
480
  const ast = import_recast2.default.parse(script, parseOptions2);
481
+ let importedScopedClass;
468
482
  import_recast2.default.visit(ast, {
483
+ visitImportDeclaration(path6) {
484
+ if (path6.node.source.value === "ember-scoped-css") {
485
+ let specifier = path6.node.specifiers.find(
486
+ (x) => x.imported.name === "scopedClass"
487
+ );
488
+ if (specifier) {
489
+ importedScopedClass = specifier.local.name;
490
+ }
491
+ path6.prune();
492
+ return false;
493
+ }
494
+ this.traverse(path6);
495
+ },
469
496
  visitCallExpression(path6) {
470
497
  const node = path6.node;
498
+ const scopedClass = importedScopedClass ?? "scoped-class";
471
499
  if (node.callee.name === "__GLIMMER_TEMPLATE" || node.callee.name === "precompileTemplate") {
472
500
  if (node.arguments[0].type === "TemplateLiteral") {
473
501
  node.arguments[0].quasis[0].value.raw = replaceFunction(
474
- node.arguments[0].quasis[0].value.raw
502
+ node.arguments[0].quasis[0].value.raw,
503
+ scopedClass
475
504
  );
476
505
  } else if (node.arguments[0].type === "StringLiteral" || node.arguments[0].type === "Literal") {
477
- node.arguments[0].value = replaceFunction(node.arguments[0].value);
506
+ node.arguments[0].value = replaceFunction(
507
+ node.arguments[0].value,
508
+ scopedClass
509
+ );
510
+ }
511
+ if (importedScopedClass) {
512
+ removeScopeBagReference(path6, scopedClass);
478
513
  }
479
514
  }
480
515
  this.traverse(path6);
@@ -505,7 +540,7 @@ function renameClass(className, postfix, classesInCss) {
505
540
  }
506
541
 
507
542
  // src/lib/rewriteHbs.js
508
- function rewriteHbs(hbs, classes, tags, postfix) {
543
+ function rewriteHbs(hbs, classes, tags, postfix, scopedClass = "scoped-class") {
509
544
  let ast = import_ember_template_recast.default.parse(hbs);
510
545
  let stack = [];
511
546
  import_ember_template_recast.default.traverse(ast, {
@@ -557,10 +592,10 @@ function rewriteHbs(hbs, classes, tags, postfix) {
557
592
  },
558
593
  MustacheStatement(node) {
559
594
  let cssClass;
560
- if (node.path?.original === "scoped-class" && node.params?.length === 1 && node.params[0].type === "StringLiteral") {
595
+ if (node.path?.original === scopedClass && node.params?.length === 1 && node.params[0].type === "StringLiteral") {
561
596
  cssClass = node.params[0].value;
562
597
  }
563
- if (node.path?.path?.original === "scoped-class" && node.path?.params?.length === 1 && node.path?.params[0].type === "StringLiteral") {
598
+ if (node.path?.path?.original === scopedClass && node.path?.params?.length === 1 && node.path?.params[0].type === "StringLiteral") {
564
599
  cssClass = node.path.params[0].value;
565
600
  }
566
601
  if (cssClass) {
@@ -573,7 +608,7 @@ function rewriteHbs(hbs, classes, tags, postfix) {
573
608
  }
574
609
  },
575
610
  SubExpression(node) {
576
- if (node.path?.original === "scoped-class" && node.params?.length === 1 && node.params[0].type === "StringLiteral") {
611
+ if (node.path?.original === scopedClass && node.params?.length === 1 && node.params[0].type === "StringLiteral") {
577
612
  const cssClass = node.params[0].value;
578
613
  const textNode = import_ember_template_recast.default.builders.literal(
579
614
  "StringLiteral",
@@ -589,7 +624,7 @@ function rewriteHbs(hbs, classes, tags, postfix) {
589
624
 
590
625
  // src/build/scoped-css-unplugin.js
591
626
  function isJsFile(id) {
592
- return id.endsWith(".js") || id.endsWith(".ts");
627
+ return id.endsWith(".js") || id.endsWith(".ts") || id.endsWith(".gjs") || id.endsWith(".gts");
593
628
  }
594
629
  function isHbsFile(id) {
595
630
  return id.endsWith(".hbs");
@@ -598,7 +633,7 @@ function isCssFile(id) {
598
633
  return id.endsWith(".css");
599
634
  }
600
635
  async function transformJsFile(code, id) {
601
- const cssPath = id.endsWith(".hbs") ? id.replace(/\.hbs$/, ".css") : id.replace(/(\.hbs)?\.((js)|(ts))$/, ".css");
636
+ const cssPath = id.endsWith(".hbs") ? id.replace(/\.hbs$/, ".css") : id.replace(/(\.hbs)?\.(js|ts|gjs|gts)$/, ".css");
602
637
  const cssFileName = import_node_path5.default.basename(cssPath);
603
638
  const cssExists = await fsExists_default(cssPath);
604
639
  let css;
@@ -613,10 +648,10 @@ async function transformJsFile(code, id) {
613
648
  code = `import './${cssFileName}';
614
649
 
615
650
  ${code}`;
616
- const rewrittenCode = replaceHbsInJs_default(code, (hbs) => {
651
+ const rewrittenCode = replaceHbsInJs_default(code, (hbs, scopedClass) => {
617
652
  const { classes, tags } = getClassesTagsFromCss(css);
618
653
  const postfix = generateHashFromAbsolutePath(cssPath);
619
- const rewritten = rewriteHbs(hbs, classes, tags, postfix);
654
+ const rewritten = rewriteHbs(hbs, classes, tags, postfix, scopedClass);
620
655
  return rewritten;
621
656
  });
622
657
  return {
@@ -682,9 +717,6 @@ var scoped_css_unplugin_default = (0, import_unplugin3.createUnplugin)(
682
717
  });
683
718
  }
684
719
  },
685
- // loadInclude(id) {
686
- // return isJsFile(id) || isCssFile(id) || isHbsFile(id);
687
- // },
688
720
  transform(code, jsPath) {
689
721
  if (isHbsFile(jsPath)) {
690
722
  return transformJsFile(code, jsPath);
@@ -709,4 +741,4 @@ var scoped_css_unplugin_default = (0, import_unplugin3.createUnplugin)(
709
741
  appScopedcssWebpack,
710
742
  scopedCssUnplugin
711
743
  });
712
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/build/index.js", "../../../src/build/app-css-unplugin.js", "../../../src/build/app-js-unplugin.js", "../../../src/lib/generateAbsolutePathHash.js", "../../../src/lib/generateRelativePathHash.ts", "../../../src/lib/getClassesTagsFromCss.js", "../../../src/lib/isInsideGlobal.js", "../../../src/lib/replaceGlimmerAst.js", "../../../src/lib/fsExists.js", "../../../src/build/app-scopedcss-webpack.js", "../../../src/lib/getFiles.js", "../../../src/lib/rewriteCss.js", "../../../src/build/scoped-css-unplugin.js", "../../../src/lib/replaceHbsInJs.js", "../../../src/lib/rewriteHbs.js", "../../../src/lib/renameClass.ts"],
  "sourcesContent": ["import appCssUnplugin from './app-css-unplugin.js';\nimport appJsUnplugin from './app-js-unplugin.js';\nimport appScopedcssWebpack from './app-scopedcss-webpack.js';\nimport scopedCssUnplugin from './scoped-css-unplugin.js';\n\nexport {\n  appCssUnplugin,\n  appJsUnplugin,\n  appScopedcssWebpack,\n  scopedCssUnplugin,\n};\n", "import { createUnplugin } from 'unplugin';\n\nexport default createUnplugin(() => {\n  return {\n    name: 'app-css-unplugin',\n\n    // loadInclude(id){\n    //   if(id.endsWith('.css')){\n    //     return true;\n    //   }\n    // },\n\n    // load(id){\n    //   // this.addWatchFile(id);\n    //   return 'console.log(' + JSON.stringify(id) + ');';\n    // },\n\n    // transformInclude(id) {\n    //   if(id.endsWith('.css')){\n    //     return true;\n    //   }\n    // },\n\n    // async transform(code, id) {\n    //   return code;\n    // },\n  };\n});\n", "import path from 'node:path';\n\nimport { createUnplugin } from 'unplugin';\n\nimport generateHash from '../lib/generateAbsolutePathHash.js';\nimport getClassesTagsFromCss from '../lib/getClassesTagsFromCss.js';\nimport replaceGlimmerAst from '../lib/replaceGlimmerAst.js';\n\nfunction* iterateOpcodes(opcodes) {\n  for (let instruction of opcodes) {\n    if (!Array.isArray(instruction)) {\n      continue;\n    }\n\n    yield instruction;\n\n    for (let subInstruction of iterateOpcodes(instruction)) {\n      yield subInstruction;\n    }\n  }\n}\n\nfunction inflateTagName(tag) {\n  if (typeof tag === 'string') {\n    return tag;\n  } else {\n    if (tag === 0) {\n      return 'div';\n    } else if (tag === 1) {\n      return 'span';\n    } else if (tag === 2) {\n      return 'p';\n    } else if (tag === 3) {\n      return 'a';\n    }\n  }\n\n  throw new Error('Unknown tag');\n}\n\nexport default createUnplugin(({ appDir }) => {\n  return {\n    name: 'app-js-unplugin',\n\n    transformInclude(id) {\n      return (\n        id.includes(path.basename(appDir)) &&\n        (id.endsWith('.js') || id.endsWith('.hbs'))\n      );\n    },\n\n    /**\n     * This whole thing is error prone, and we should switch the embroider\n     * technique to using a babel plugin.\n     *\n     * Using a webpack plugin is too late in the process.\n     * We don't want to be dealing with wire-format, because\n     * - it's not public API\n     * - it can change as ember-source is upgraded\n     * - the numbers are not \"stable\", in that they are bitwise anded and ored\n     *   together so that storage is efficient -- which means we'd need to know\n     *   all the opcodes and appropriately | / & to deconstruct appropriately.\n     * @returns\n     */\n    async transform(code, id) {\n      let cssPath = id.replace(/(\\.js)|(\\.hbs)/, '.css');\n      let moduleGroupPath = cssPath;\n\n      /**\n       * Pods support\n       *\n       * Note that Pod-components will never be supported.\n       */\n      let isPod = !id.includes('/components/') && id.endsWith('/template.hbs');\n\n      if (isPod) {\n        cssPath = path.join(path.dirname(id), 'styles.css');\n        moduleGroupPath = path.dirname(cssPath);\n      }\n\n      const postfix = generateHash(moduleGroupPath);\n\n      return await replaceGlimmerAst(code, id, (opcodes, css) => {\n        const { classes, tags } = getClassesTagsFromCss(css);\n        // this.addWatchFile(cssPath);\n        const insertions = [];\n\n        for (let instruction of iterateOpcodes(opcodes[0])) {\n          // replace classes\n          if (\n            instruction[0] === 14 &&\n            instruction[1] === 0 &&\n            instruction[2] &&\n            instruction[2].split(' ').find((i) => classes.has(i.trim()))\n          ) {\n            // 14 - css attribute, 0 - class\n            instruction[2] = instruction[2]\n              .split(' ')\n              .map((className) => {\n                if (className.trim() && classes.has(className.trim())) {\n                  return className.trim() + '_' + postfix;\n                } else {\n                  return className;\n                }\n              })\n              .join(' ');\n          }\n\n          // replace strings in if conditions\n          // this is brittle, because subexpressions can be deeply nested\n          //\n          // this particular one is <div class=\"global-probably {{if @condition \"a-local-class\"}}\">\"\n          // if (instruction[0] === 15 && Array.isArray(instruction[1]) && instruction[1][0] === 29) {\n\n          // }\n\n          // add postfix to tags\n          if (\n            instruction[0] === 10 &&\n            tags.has(inflateTagName(instruction[1]))\n          ) {\n            // 10 - open element\n            let existingClassInstruction;\n\n            for (\n              let i = opcodes[0].indexOf(instruction);\n              i <= opcodes[0].length;\n              i++\n            ) {\n              if (opcodes[0][i][0] === 14 && opcodes[0][i][1] === 0) {\n                // 14 - css attribute, 0 - class\n                existingClassInstruction = opcodes[0][i];\n\n                break;\n              }\n\n              if (opcodes[0][i][0] === 12) {\n                // 12 - flush element\n                break;\n              }\n            }\n\n            if (existingClassInstruction) {\n              existingClassInstruction[2] += ' ' + postfix;\n            } else {\n              const classInstruction = [14, 0, postfix, undefined];\n\n              insertions.push([instruction, classInstruction]);\n            }\n          }\n        }\n\n        // insert new instructions\n        for (let [instruction, classInstruction] of insertions) {\n          const index = opcodes[0].indexOf(instruction);\n\n          opcodes[0].splice(index + 1, 0, classInstruction);\n        }\n\n        // rewrite opcodes\n        // const dbg = new WireFormatDebugger(opcodes);\n        // const wfd = dbg.format(opcodes);\n\n        return opcodes;\n      });\n    },\n  };\n});\n", "import fsSync from 'node:fs';\nimport path from 'node:path';\n\nimport findUp from 'find-up';\n\nimport generateHash from './generateRelativePathHash.ts';\n\nexport default function generateHashFromAbsolutePath(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\n  const hash = generateHash(modulePath);\n\n  return hash;\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  /**\n   * Pods support.\n   * For pods, we chop off the whole file, and use the dir name as the \"modulePath\"\n   *\n   * Note that pods for components will never be supported.\n   */\n  let isPod =\n    !packageRelative.includes('/components/') &&\n    (packageRelative.endsWith('styles.css') ||\n      packageRelative.endsWith('template.hbs') ||\n      packageRelative.endsWith('template.js'));\n\n  if (isPod) {\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 */\nfunction appPath(sourcePath) {\n  let workspacePath = findWorkspacePath(sourcePath);\n  let name = workspacePackageName(sourcePath);\n\n  /**\n   *  Under embroider builds, the spec-compliant version of the app\n   * has all the files under a folder which represents the package name,\n   * rather than \"app\".\n   */\n  let packageRelative = sourcePath.replace(workspacePath, '');\n\n  let localPackagerStylePath = packageScopedPathToModulePath(packageRelative);\n\n  return `${name}${localPackagerStylePath}`;\n}\n\nconst CACHE = new Set();\n\n/**\n * For a given source path, if we have seen a\n * source file within the workspace directory,\n * find that workspace directory and return it.\n */\nfunction hasSeen(sourcePath) {\n  for (let entry of CACHE) {\n    if (sourcePath.startsWith(entry)) {\n      return entry;\n    }\n  }\n\n  // we have not seen this source path yet\n  return;\n}\n\n/**\n * Populates the \"seen\" workspace cache,\n * so that we don't hit the file system too often.\n */\nfunction findWorkspacePath(sourcePath) {\n  let seen = hasSeen(sourcePath);\n\n  if (seen) {\n    return seen;\n  }\n\n  const packageJsonPath = findUp.sync('package.json', {\n    cwd: path.dirname(sourcePath),\n  });\n\n  const workspacePath = path.dirname(packageJsonPath);\n\n  CACHE.add(workspacePath);\n\n  return workspacePath;\n}\n\nconst MANIFEST_CACHE = new Map();\n\n/**\n * returns the package.json#name for a given sourcePath\n */\nfunction workspacePackageName(sourcePath) {\n  const workspace = findWorkspacePath(sourcePath);\n\n  let existing = MANIFEST_CACHE.get(workspace);\n\n  if (existing) {\n    return existing.name;\n  }\n\n  let buffer = fsSync.readFileSync(path.join(workspace, 'package.json'));\n  let content = buffer.toString();\n  let json = JSON.parse(content);\n\n  MANIFEST_CACHE.set(workspace, json);\n\n  return json.name;\n}\n\n", "import md5 from 'blueimp-md5';\n\nexport default function generateRelativePathHash(relativePath: string) {\n  return 'e' + md5(relativePath).substring(0, 8);\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 { readFile } from 'node:fs/promises';\nimport path from 'node:path';\n\nimport babelParser from '@babel/parser';\nimport recast from 'recast';\n\nimport fsExists from './fsExists.js';\n\nconst parseOptions = {\n  parser: babelParser,\n};\n\nexport default async function replaceGlimmerAst(script, id, replaceFunction) {\n  const ast = recast.parse(script, parseOptions);\n  const cssPath = id.replace(/(\\.js)|(\\.hbs)/, '.css');\n  let css;\n\n  const cssExists = await fsExists(cssPath);\n\n  if (cssExists) {\n    css = await readFile(cssPath, 'utf-8');\n  }\n\n  if (!css) {\n    return script;\n  }\n\n  recast.visit(ast, {\n    visitCallExpression(nodePath) {\n      const node = nodePath.node;\n\n      if (\n        node.callee.name === 'createTemplateFactory' &&\n        node.arguments.length === 1\n      ) {\n        const blockProp = node.arguments[0].properties.find(\n          (prop) => prop.key.value === 'block',\n        );\n        const opcodes = JSON.parse(blockProp.value.value);\n        const newOpcodes = replaceFunction(opcodes, css);\n\n        blockProp.value.value = JSON.stringify(newOpcodes);\n\n        const fileName = path.basename(cssPath);\n        // if (!importPath) {\n        //   unplugin.addWatchFile(cssPath);\n        // }\n        const importCss = recast.parse(\n          `import './${fileName}';\\n`,\n          parseOptions,\n        );\n        const importCssNode = importCss.program.body[0];\n\n        ast.program.body.unshift(importCssNode);\n      }\n\n      this.traverse(nodePath);\n    },\n  });\n\n  const resultScript = recast.print(ast).code;\n\n  return resultScript;\n}\n", "import { stat } from 'node:fs/promises';\n\nexport default async function (path) {\n  try {\n    await stat(path);\n\n    return true;\n  } catch (e) {\n    return false;\n  }\n}\n", "// import { RawSource }  from 'webpack-sources';\nimport { readFile, writeFile } from 'node:fs/promises';\nimport path from 'node:path';\n\nimport fsExists from '../lib/fsExists.js';\nimport generateHash from '../lib/generateAbsolutePathHash.js';\nimport getFiles from '../lib/getFiles.js';\nimport rewriteCss from '../lib/rewriteCss.js';\n\nexport default class {\n  apply(compiler) {\n    if (process.env.EMBER_ENV === 'production') {\n      return;\n    }\n\n    compiler.hooks.emit.tapAsync(\n      'scoped-webpack-plugin',\n      async (compilation, callback) => {\n        try {\n          const cssFiles = await getFiles(\n            path.resolve(compiler.context, '**/*.css'),\n          );\n\n          // Rewrite the CSS files\n          const rewrittenFiles = [];\n\n          // const rewritenFiles = cssFiles.map((file) => {\n          for (let file of cssFiles) {\n            if (file.endsWith(`/${path.basename(compiler.context)}.css`)) {\n              // import scoped.css into app.css\n              let appCss = await readFile(file, 'utf-8');\n\n              await writeFile(file, `@import \"scoped.css\";\\n${appCss}`);\n            }\n\n            if (\n              [\n                path.basename(compiler.context) + '.css',\n                'test-support.css',\n              ].some((f) => file.endsWith(f)) ||\n              file.includes('/vendor/') ||\n              !(\n                (await fsExists(file.replace('.css', '.js'))) ||\n                (await fsExists(file.replace('.css', '.hbs')))\n              )\n            ) {\n              continue;\n            }\n\n            const fileName = path.basename(file);\n            const postfix = generateHash(fileName);\n            const css = await readFile(file, 'utf-8');\n            const rewrittenCss = rewriteCss(css, postfix, fileName);\n\n            rewrittenFiles.push(rewrittenCss);\n          }\n\n          // Concatenate the rewritten CSS files\n          let concatenatedCSS = rewrittenFiles.join('\\n\\n');\n\n          // Store the concatenated CSS in the assets/scoped-components.css\n          compilation.assets['assets/scoped.css'] = {\n            source: () => concatenatedCSS,\n            size: () => concatenatedCSS.length,\n          };\n        } finally {\n          callback();\n        }\n      },\n    );\n  }\n}\n", "import glob from 'glob';\n\nexport default function (globPath) {\n  return new Promise((resolve, reject) => {\n    glob(globPath, (err, files) => {\n      if (err) {\n        reject(err);\n      }\n\n      resolve(files);\n    });\n  });\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 { readFile } from 'node:fs/promises';\nimport path from 'node:path';\n\nimport { createUnplugin } from 'unplugin';\n\nimport fsExists from '../lib/fsExists.js';\nimport generateHash from '../lib/generateAbsolutePathHash.js';\nimport getClassesTagsFromCss from '../lib/getClassesTagsFromCss.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 id.endsWith('.js') || id.endsWith('.ts');\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))$/, '.css');\n  const cssFileName = path.basename(cssPath);\n\n  const cssExists = await fsExists(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) => {\n    const { classes, tags } = getClassesTagsFromCss(css);\n    const postfix = generateHash(cssPath);\n    const rewritten = rewriteHbs(hbs, classes, tags, postfix);\n\n    return rewritten;\n  });\n\n  return {\n    code: rewrittenCode,\n    map: null,\n  };\n}\n\nasync function transformCssFile(code, id, layerName, emitFile) {\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, gtsExists, hbsExists] = await Promise.all([\n    fsExists(jsPath),\n    fsExists(gtsPath),\n    fsExists(hbsPath),\n  ]);\n\n  if (jsExists || hbsExists || gtsExists) {\n    const postfix = generateHash(id);\n\n    code = rewriteCss(code, postfix, path.basename(id), layerName);\n  }\n\n  const emittedFileName = id.replace(path.join(process.cwd(), 'src/'), '');\n\n  emitFile({\n    type: 'asset',\n    fileName: emittedFileName,\n    source: code,\n  });\n\n  return '';\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(a, 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            // add import to js files\n            if (bundle[asset].code.indexOf(importLine) < 0) {\n              bundle[asset].code = `${importLine}\\n` + bundle[asset].code;\n            }\n          }\n        }\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\n      // loadInclude(id) {\n      //   return isJsFile(id) || isCssFile(id) || isHbsFile(id);\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(\n            code,\n            jsPath,\n            options?.layerName,\n            this.emitFile,\n          );\n        }\n      },\n    };\n  },\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      });\n    },\n  },\n};\n\nexport default function (script, replaceFunction) {\n  const ast = recast.parse(script, parseOptions);\n\n  recast.visit(ast, {\n    visitCallExpression(path) {\n      const node = path.node;\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          );\n        } else if (\n          node.arguments[0].type === 'StringLiteral' ||\n          node.arguments[0].type === 'Literal'\n        ) {\n          node.arguments[0].value = replaceFunction(node.arguments[0].value);\n        }\n      }\n\n      this.traverse(path);\n    },\n  });\n\n  return recast.print(ast).code;\n}\n", "import recast from 'ember-template-recast';\n\nimport renameClass from './renameClass.js';\n\nexport default function rewriteHbs(hbs, classes, tags, postfix) {\n  let ast = recast.parse(hbs);\n  let stack = [];\n\n  recast.traverse(ast, {\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        node.path?.original === 'scoped-class' &&\n        node.params?.length === 1 &&\n        node.params[0].type === 'StringLiteral'\n      ) {\n        cssClass = node.params[0].value;\n      }\n\n      if (\n        node.path?.path?.original === 'scoped-class' &&\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        node.path?.original === 'scoped-class' &&\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  let result = recast.print(ast);\n\n  return result;\n}\n", "export default function renameClass(\n  className: string,\n  postfix: string,\n  classesInCss?: Set<string>,\n) {\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", "import_unplugin", "md5", "path", "findUp", "fsSync", "parser", "postcss", "import_promises", "import_node_path", "path", "babelParser", "recast", "path", "path", "import_promises", "import_node_path", "glob", "import_postcss", "import_postcss_selector_parser", "parser", "postcss", "path", "import_promises", "import_node_path", "import_unplugin", "import_parser", "import_recast", "parseOptions", "babelParser", "recast", "path", "recast", "node", "path"]
}

744
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/build/index.js", "../../../src/build/app-css-unplugin.js", "../../../src/build/app-js-unplugin.js", "../../../src/lib/generateAbsolutePathHash.js", "../../../src/lib/generateRelativePathHash.ts", "../../../src/lib/getClassesTagsFromCss.js", "../../../src/lib/isInsideGlobal.js", "../../../src/lib/replaceGlimmerAst.js", "../../../src/lib/fsExists.js", "../../../src/build/app-scopedcss-webpack.js", "../../../src/lib/getFiles.js", "../../../src/lib/rewriteCss.js", "../../../src/build/scoped-css-unplugin.js", "../../../src/lib/replaceHbsInJs.js", "../../../src/lib/rewriteHbs.js", "../../../src/lib/renameClass.ts"],
  "sourcesContent": ["import appCssUnplugin from './app-css-unplugin.js';\nimport appJsUnplugin from './app-js-unplugin.js';\nimport appScopedcssWebpack from './app-scopedcss-webpack.js';\nimport scopedCssUnplugin from './scoped-css-unplugin.js';\n\nexport {\n  appCssUnplugin,\n  appJsUnplugin,\n  appScopedcssWebpack,\n  scopedCssUnplugin,\n};\n", "import { createUnplugin } from 'unplugin';\n\nexport default createUnplugin(() => {\n  return {\n    name: 'app-css-unplugin',\n\n    // loadInclude(id){\n    //   if(id.endsWith('.css')){\n    //     return true;\n    //   }\n    // },\n\n    // load(id){\n    //   // this.addWatchFile(id);\n    //   return 'console.log(' + JSON.stringify(id) + ');';\n    // },\n\n    // transformInclude(id) {\n    //   if(id.endsWith('.css')){\n    //     return true;\n    //   }\n    // },\n\n    // async transform(code, id) {\n    //   return code;\n    // },\n  };\n});\n", "import path from 'node:path';\n\nimport { createUnplugin } from 'unplugin';\n\nimport generateHash from '../lib/generateAbsolutePathHash.js';\nimport getClassesTagsFromCss from '../lib/getClassesTagsFromCss.js';\nimport replaceGlimmerAst from '../lib/replaceGlimmerAst.js';\n\nfunction* iterateOpcodes(opcodes) {\n  for (let instruction of opcodes) {\n    if (!Array.isArray(instruction)) {\n      continue;\n    }\n\n    yield instruction;\n\n    for (let subInstruction of iterateOpcodes(instruction)) {\n      yield subInstruction;\n    }\n  }\n}\n\nfunction inflateTagName(tag) {\n  if (typeof tag === 'string') {\n    return tag;\n  } else {\n    if (tag === 0) {\n      return 'div';\n    } else if (tag === 1) {\n      return 'span';\n    } else if (tag === 2) {\n      return 'p';\n    } else if (tag === 3) {\n      return 'a';\n    }\n  }\n\n  throw new Error('Unknown tag');\n}\n\nexport default createUnplugin(({ appDir }) => {\n  return {\n    name: 'app-js-unplugin',\n\n    transformInclude(id) {\n      return (\n        id.includes(path.basename(appDir)) &&\n        (id.endsWith('.js') || id.endsWith('.hbs'))\n      );\n    },\n\n    /**\n     * This whole thing is error prone, and we should switch the embroider\n     * technique to using a babel plugin.\n     *\n     * Using a webpack plugin is too late in the process.\n     * We don't want to be dealing with wire-format, because\n     * - it's not public API\n     * - it can change as ember-source is upgraded\n     * - the numbers are not \"stable\", in that they are bitwise anded and ored\n     *   together so that storage is efficient -- which means we'd need to know\n     *   all the opcodes and appropriately | / & to deconstruct appropriately.\n     * @returns\n     */\n    async transform(code, id) {\n      let cssPath = id.replace(/(\\.js)|(\\.hbs)/, '.css');\n      let moduleGroupPath = cssPath;\n\n      /**\n       * Pods support\n       *\n       * Note that Pod-components will never be supported.\n       */\n      let isPod = !id.includes('/components/') && id.endsWith('/template.hbs');\n\n      if (isPod) {\n        cssPath = path.join(path.dirname(id), 'styles.css');\n        moduleGroupPath = path.dirname(cssPath);\n      }\n\n      const postfix = generateHash(moduleGroupPath);\n\n      return await replaceGlimmerAst(code, id, (opcodes, css) => {\n        const { classes, tags } = getClassesTagsFromCss(css);\n        // this.addWatchFile(cssPath);\n        const insertions = [];\n\n        for (let instruction of iterateOpcodes(opcodes[0])) {\n          // replace classes\n          if (\n            instruction[0] === 14 &&\n            instruction[1] === 0 &&\n            instruction[2] &&\n            instruction[2].split(' ').find((i) => classes.has(i.trim()))\n          ) {\n            // 14 - css attribute, 0 - class\n            instruction[2] = instruction[2]\n              .split(' ')\n              .map((className) => {\n                if (className.trim() && classes.has(className.trim())) {\n                  return className.trim() + '_' + postfix;\n                } else {\n                  return className;\n                }\n              })\n              .join(' ');\n          }\n\n          // replace strings in if conditions\n          // this is brittle, because subexpressions can be deeply nested\n          //\n          // this particular one is <div class=\"global-probably {{if @condition \"a-local-class\"}}\">\"\n          // if (instruction[0] === 15 && Array.isArray(instruction[1]) && instruction[1][0] === 29) {\n\n          // }\n\n          // add postfix to tags\n          if (\n            instruction[0] === 10 &&\n            tags.has(inflateTagName(instruction[1]))\n          ) {\n            // 10 - open element\n            let existingClassInstruction;\n\n            for (\n              let i = opcodes[0].indexOf(instruction);\n              i <= opcodes[0].length;\n              i++\n            ) {\n              if (opcodes[0][i][0] === 14 && opcodes[0][i][1] === 0) {\n                // 14 - css attribute, 0 - class\n                existingClassInstruction = opcodes[0][i];\n\n                break;\n              }\n\n              if (opcodes[0][i][0] === 12) {\n                // 12 - flush element\n                break;\n              }\n            }\n\n            if (existingClassInstruction) {\n              existingClassInstruction[2] += ' ' + postfix;\n            } else {\n              const classInstruction = [14, 0, postfix, undefined];\n\n              insertions.push([instruction, classInstruction]);\n            }\n          }\n        }\n\n        // insert new instructions\n        for (let [instruction, classInstruction] of insertions) {\n          const index = opcodes[0].indexOf(instruction);\n\n          opcodes[0].splice(index + 1, 0, classInstruction);\n        }\n\n        // rewrite opcodes\n        // const dbg = new WireFormatDebugger(opcodes);\n        // const wfd = dbg.format(opcodes);\n\n        return opcodes;\n      });\n    },\n  };\n});\n", "import fsSync from 'node:fs';\nimport path from 'node:path';\n\nimport findUp from 'find-up';\n\nimport generateHash from './generateRelativePathHash.ts';\n\nexport default function generateHashFromAbsolutePath(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\n  const hash = generateHash(modulePath);\n\n  return hash;\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  /**\n   * Pods support.\n   * For pods, we chop off the whole file, and use the dir name as the \"modulePath\"\n   *\n   * Note that pods for components will never be supported.\n   */\n  let isPod =\n    !packageRelative.includes('/components/') &&\n    (packageRelative.endsWith('styles.css') ||\n      packageRelative.endsWith('template.hbs') ||\n      packageRelative.endsWith('template.js'));\n\n  if (isPod) {\n    return parsed.dir;\n  }\n\n  /**\n   * If an extension is passed, remove it.\n   * When using packagers, folks are used to not having to specify extensions for files.\n   * Since we don't even emit css files co-located to each module,\n   * this helps us not convey a lie that a file may exist in at runtime.\n   *\n   * For example `<module-name>/components/button`.\n   * It doesn't matter what the extension is, because you can only have one css file\n   * for the button module anyway.\n   */\n  let localPackagerStylePath = path.join(parsed.dir, parsed.name);\n\n  return localPackagerStylePath;\n}\n\n/**\n * returns the app-module path of the source file\n *\n * This assumes normal ember app conventions\n *\n * which is `<package.json#name>/path-to-file`\n */\nexport function appPath(sourcePath) {\n  let workspacePath = findWorkspacePath(sourcePath);\n  let name = workspacePackageName(sourcePath);\n\n  /**\n   *  Under embroider builds, the spec-compliant version of the app\n   * has all the files under a folder which represents the package name,\n   * rather than \"app\".\n   */\n  let packageRelative = sourcePath.replace(workspacePath, '');\n\n  let localPackagerStylePath = packageScopedPathToModulePath(packageRelative);\n\n  return `${name}${localPackagerStylePath}`;\n}\n\nconst CACHE = new Set();\n\n/**\n * For a given source path, if we have seen a\n * source file within the workspace directory,\n * find that workspace directory and return it.\n */\nfunction hasSeen(sourcePath) {\n  for (let entry of CACHE) {\n    if (sourcePath.startsWith(entry)) {\n      return entry;\n    }\n  }\n\n  // we have not seen this source path yet\n  return;\n}\n\n/**\n * Populates the \"seen\" workspace cache,\n * so that we don't hit the file system too often.\n */\nfunction findWorkspacePath(sourcePath) {\n  let seen = hasSeen(sourcePath);\n\n  if (seen) {\n    return seen;\n  }\n\n  const packageJsonPath = findUp.sync('package.json', {\n    cwd: path.dirname(sourcePath),\n  });\n\n  const workspacePath = path.dirname(packageJsonPath);\n\n  CACHE.add(workspacePath);\n\n  return workspacePath;\n}\n\nconst MANIFEST_CACHE = new Map();\n\n/**\n * returns the package.json#name for a given sourcePath\n */\nfunction workspacePackageName(sourcePath) {\n  const workspace = findWorkspacePath(sourcePath);\n\n  let existing = MANIFEST_CACHE.get(workspace);\n\n  if (existing) {\n    return existing.name;\n  }\n\n  let buffer = fsSync.readFileSync(path.join(workspace, 'package.json'));\n  let content = buffer.toString();\n  let json = JSON.parse(content);\n\n  MANIFEST_CACHE.set(workspace, json);\n\n  return json.name;\n}\n\n", "import md5 from 'blueimp-md5';\n\nexport default function generateRelativePathHash(relativePath: string) {\n  return 'e' + md5(relativePath).substring(0, 8);\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 { readFile } from 'node:fs/promises';\nimport path from 'node:path';\n\nimport babelParser from '@babel/parser';\nimport recast from 'recast';\n\nimport fsExists from './fsExists.js';\n\nconst parseOptions = {\n  parser: babelParser,\n};\n\nexport default async function replaceGlimmerAst(script, id, replaceFunction) {\n  const ast = recast.parse(script, parseOptions);\n  const cssPath = id.replace(/(\\.js)|(\\.hbs)/, '.css');\n  let css;\n\n  const cssExists = await fsExists(cssPath);\n\n  if (cssExists) {\n    css = await readFile(cssPath, 'utf-8');\n  }\n\n  if (!css) {\n    return script;\n  }\n\n  recast.visit(ast, {\n    visitCallExpression(nodePath) {\n      const node = nodePath.node;\n\n      if (\n        node.callee.name === 'createTemplateFactory' &&\n        node.arguments.length === 1\n      ) {\n        const blockProp = node.arguments[0].properties.find(\n          (prop) => prop.key.value === 'block',\n        );\n        const opcodes = JSON.parse(blockProp.value.value);\n        const newOpcodes = replaceFunction(opcodes, css);\n\n        blockProp.value.value = JSON.stringify(newOpcodes);\n\n        const fileName = path.basename(cssPath);\n        // if (!importPath) {\n        //   unplugin.addWatchFile(cssPath);\n        // }\n        const importCss = recast.parse(\n          `import './${fileName}';\\n`,\n          parseOptions,\n        );\n        const importCssNode = importCss.program.body[0];\n\n        ast.program.body.unshift(importCssNode);\n      }\n\n      this.traverse(nodePath);\n    },\n  });\n\n  const resultScript = recast.print(ast).code;\n\n  return resultScript;\n}\n", "import { stat } from 'node:fs/promises';\n\nexport default async function (path) {\n  try {\n    await stat(path);\n\n    return true;\n  } catch (e) {\n    return false;\n  }\n}\n", "// import { RawSource }  from 'webpack-sources';\nimport { readFile, writeFile } from 'node:fs/promises';\nimport path from 'node:path';\n\nimport fsExists from '../lib/fsExists.js';\nimport generateHash from '../lib/generateAbsolutePathHash.js';\nimport getFiles from '../lib/getFiles.js';\nimport rewriteCss from '../lib/rewriteCss.js';\n\nexport default class {\n  apply(compiler) {\n    if (process.env.EMBER_ENV === 'production') {\n      return;\n    }\n\n    compiler.hooks.emit.tapAsync(\n      'scoped-webpack-plugin',\n      async (compilation, callback) => {\n        try {\n          const cssFiles = await getFiles(\n            path.resolve(compiler.context, '**/*.css'),\n          );\n\n          // Rewrite the CSS files\n          const rewrittenFiles = [];\n\n          // const rewritenFiles = cssFiles.map((file) => {\n          for (let file of cssFiles) {\n            if (file.endsWith(`/${path.basename(compiler.context)}.css`)) {\n              // import scoped.css into app.css\n              let appCss = await readFile(file, 'utf-8');\n\n              await writeFile(file, `@import \"scoped.css\";\\n${appCss}`);\n            }\n\n            if (\n              [\n                path.basename(compiler.context) + '.css',\n                'test-support.css',\n              ].some((f) => file.endsWith(f)) ||\n              file.includes('/vendor/') ||\n              !(\n                (await fsExists(file.replace('.css', '.js'))) ||\n                (await fsExists(file.replace('.css', '.hbs')))\n              )\n            ) {\n              continue;\n            }\n\n            const fileName = path.basename(file);\n            const postfix = generateHash(fileName);\n            const css = await readFile(file, 'utf-8');\n            const rewrittenCss = rewriteCss(css, postfix, fileName);\n\n            rewrittenFiles.push(rewrittenCss);\n          }\n\n          // Concatenate the rewritten CSS files\n          let concatenatedCSS = rewrittenFiles.join('\\n\\n');\n\n          // Store the concatenated CSS in the assets/scoped-components.css\n          compilation.assets['assets/scoped.css'] = {\n            source: () => concatenatedCSS,\n            size: () => concatenatedCSS.length,\n          };\n        } finally {\n          callback();\n        }\n      },\n    );\n  }\n}\n", "import glob from 'glob';\n\nexport default function (globPath) {\n  return new Promise((resolve, reject) => {\n    glob(globPath, (err, files) => {\n      if (err) {\n        reject(err);\n      }\n\n      resolve(files);\n    });\n  });\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 { readFile } from 'node:fs/promises';\nimport path from 'node:path';\n\nimport { createUnplugin } from 'unplugin';\n\nimport fsExists from '../lib/fsExists.js';\nimport generateHash from '../lib/generateAbsolutePathHash.js';\nimport getClassesTagsFromCss from '../lib/getClassesTagsFromCss.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 = await fsExists(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 = generateHash(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\nasync function transformCssFile(code, id, layerName, emitFile) {\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, gtsExists, hbsExists] = await Promise.all([\n    fsExists(jsPath),\n    fsExists(gtsPath),\n    fsExists(hbsPath),\n  ]);\n\n  if (jsExists || hbsExists || gtsExists) {\n    const postfix = generateHash(id);\n\n    code = rewriteCss(code, postfix, path.basename(id), layerName);\n  }\n\n  const emittedFileName = id.replace(path.join(process.cwd(), 'src/'), '');\n\n  emitFile({\n    type: 'asset',\n    fileName: emittedFileName,\n    source: code,\n  });\n\n  return '';\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(a, 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            // add import to js files\n            if (bundle[asset].code.indexOf(importLine) < 0) {\n              bundle[asset].code = `${importLine}\\n` + bundle[asset].code;\n            }\n          }\n        }\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\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(\n            code,\n            jsPath,\n            options?.layerName,\n            this.emitFile,\n          );\n        }\n      },\n    };\n  },\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      });\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 recast from 'ember-template-recast';\n\nimport renameClass from './renameClass.js';\n\nexport default function rewriteHbs(\n  hbs,\n  classes,\n  tags,\n  postfix,\n  scopedClass = 'scoped-class',\n) {\n  let ast = recast.parse(hbs);\n  let stack = [];\n\n  recast.traverse(ast, {\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        node.path?.original === scopedClass &&\n        node.params?.length === 1 &&\n        node.params[0].type === 'StringLiteral'\n      ) {\n        cssClass = node.params[0].value;\n      }\n\n      if (\n        node.path?.path?.original === scopedClass &&\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        node.path?.original === scopedClass &&\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  let result = recast.print(ast);\n\n  return result;\n}\n", "export default function renameClass(\n  className: string,\n  postfix: string,\n  classesInCss?: Set<string>,\n) {\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", "import_unplugin", "md5", "path", "findUp", "fsSync", "parser", "postcss", "import_promises", "import_node_path", "path", "babelParser", "recast", "path", "path", "import_promises", "import_node_path", "glob", "import_postcss", "import_postcss_selector_parser", "parser", "postcss", "path", "import_promises", "import_node_path", "import_unplugin", "import_parser", "import_recast", "parseOptions", "babelParser", "recast", "path", "recast", "node", "path"]
}
