- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 74
Blog post for template-tag-codemod #1345
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: main
Are you sure you want to change the base?
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change | ||||
|---|---|---|---|---|---|---|
| @@ -0,0 +1,63 @@ | ||||||
| --- | ||||||
| title: Try out the Template Tag Codemod | ||||||
| authors: | ||||||
| - edward-faulkner | ||||||
| date: 2025-02-21T00:00:00.000Z | ||||||
| tags: | ||||||
| - polaris | ||||||
| - '2025' | ||||||
| - template-tag | ||||||
| - embroider | ||||||
| --- | ||||||
|  | ||||||
| One of the pillars of Ember's upcoming Polaris edition is [Template Tag](https://guides.emberjs.com/release/components/template-tag-format/). Many teams are already writing their components this way and enjoying the improved developer experience. The Template Tag RFC is currently in the "Released" status, and will reach "Recommended" [once we're satisfied that we have sufficient documentation and polish](https://github.com/emberjs/rfcs/pull/1059). | ||||||
|  | ||||||
| To make it easier for all teams to adopt Template Tag, we've created `@embroider/template-tag-codemod`. The goal of the codemod is fully-reliable conversion to the new format. | ||||||
|  | ||||||
| _Why is this codemod under the `@embroider` namespace?_ | ||||||
| There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think it would be okay to bump this section down below the list of actions to take | ||||||
|  | ||||||
| Because Template Tag Codemod is powered by the same backward-compatibility infrastrucutre that we created in Embroider to allow you to adopt modern build tooling. When you build an app with Embroider, Embroider needs to identify, locate, and synthesize import statements for all the components, helpers, and modifiers that you use in your traditional handlebars templates. The Template Tag Codemod does exactly the same thing, except instead of repeating that process every time you do a build, we can do it once-and-for-all and commit the resulting GJS (or GTS for typescript users) files directly into your project. As a result, switching to Template Tag can result in improved build performance for apps that have already adopted Embroider. | ||||||
| There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 
        Suggested change
       
 | ||||||
|  | ||||||
| This blog post is a call to **try out the codemod**. Even if you're not ready to commit yet to using Template Tag in your app, you can try running the codemod on your app to see what results you get and report bugs that get in your way. | ||||||
|  | ||||||
| The super-short version of the instructions if you just want to give it a try are: | ||||||
|  | ||||||
| 1. Make sure you don't have any uncommitted changes, because we're about to start mutating all your files! | ||||||
| 2. Run `npx @embroider/template-tag-codemod`. | ||||||
| There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 
        Suggested change
       
 | ||||||
| 3. (Optional but highly recommended) Use `prettier` (with GJS support enabled) to make the results pretty. | ||||||
|  | ||||||
| The default behavior will attempt to convert _everything_ in your app, and it will target the most forward-looking output format. | ||||||
|  | ||||||
| Read the `--help` and the complete instructions [in the README](https://github.com/embroider-build/embroider/tree/main/packages/template-tag-codemod) to: | ||||||
|  | ||||||
| - limit which files will be converted all at once: | ||||||
|  | ||||||
| ```sh | ||||||
| --renderTests false --routeTemplates false --components app/components/only-these-ones/**/*.hbs | ||||||
| ``` | ||||||
|  | ||||||
| - get output that is more compatible with non-bleeding-edge Ember: | ||||||
|  | ||||||
| ```sh | ||||||
| --nativeRouteTemplates false --nativeLexicalThis false | ||||||
| ``` | ||||||
|  | ||||||
| - get output that is more compatible with the classic build system: | ||||||
| There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Is this specifically for classic? I'm also seeing local paths not resolving with webpack-based embroider after running the codemod | ||||||
|  | ||||||
| ```sh | ||||||
| --relativeLocalPaths false | ||||||
| ``` | ||||||
|  | ||||||
| - produce TypeScript GTS files rather than JavaScript GJS files in cases that are ambiguous between those two choices: | ||||||
|  | ||||||
| ```sh | ||||||
| --defaultFormat gts | ||||||
| ``` | ||||||
|  | ||||||
| - customize the naming choices for imported components/helpers/modifiers: | ||||||
|  | ||||||
| ```sh | ||||||
| --renamingRules ./your-rules-here.mjs | ||||||
| ``` | ||||||
|  | ||||||
| Please [report issues here](https://github.com/embroider-build/embroider/issues) and ask questions in the #dev-embroider channel on the community Discord. | ||||||
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
| @@ -0,0 +1,7 @@ | ||
| --- | ||
| name: 2025 | ||
| image: | ||
| imageMeta: | ||
| --- | ||
| A description for the 2025 tag. If you delete this line it will say | ||
| `A collection of X posts` where the description should go. | 
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
| @@ -0,0 +1,7 @@ | ||
| --- | ||
| name: Embroider | ||
| image: | ||
| imageMeta: | ||
| --- | ||
| A description for the Embroider tag. If you delete this line it will say | ||
| `A collection of X posts` where the description should go. | 
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
| @@ -0,0 +1,6 @@ | ||
| --- | ||
| name: Polaris | ||
| image: | ||
| imageMeta: | ||
| --- | ||
| Polaris Edition of Ember.js | 
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
| @@ -0,0 +1,7 @@ | ||
| --- | ||
| name: Template Tag | ||
| image: | ||
| imageMeta: | ||
| --- | ||
| A description for the Template Tag tag. If you delete this line it will say | ||
| `A collection of X posts` where the description should go. | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Also the polaris tag file can be removed