Bug Report or Feature Request (mark with an x)
- [X ] bug report -> please search issues before submitting
- [X ] feature request
Whether this is a bug or a feature depends on whether or not custom paths in tsconfig.json are supported with the Cli.
Command (mark with an x)
Versions
Angular CLI: 7.0.2
Node: 10.8.0
OS: win32 x64
Angular: 7.0.0
... animations, common, compiler, compiler-cli, core, forms
... http, language-service, platform-browser
... platform-browser-dynamic, router
Repro steps
ng new app-name (pick defaults)
- Add
"paths": { "@app/*": ["src/app/*"] } to tsconfig.json
- Update
main.ts to use this new path
import { AppModule } from '@app/app.module';
import { environment } from './environments/environment';
ng add @angular/material
- Select
Yes for ? Set up browser animations for Angular Material?
Repository all set up to reproduce this error is available here.
Just clone and type ng add @angular/material.
The log given by the failure
Could not read Angular module file: /src/@app/app.module.ts
Desired functionality
Cli handles custom paths in tsconfig.json.
Mention any other details that might be useful
Here is where material tries to get the app.module.ts path
https://github.com/angular/material2/blob/985774a4eaa14d1dcbf1ad96ab176043d38f433e/src/lib/schematics/ng-add/setup-project.ts#L56
Here is where the path to app.module.ts is being calculated in the schematics code
|
export function getAppModulePath(host: Tree, mainPath: string): string { |
I believe the above link is what is causing the problem.
I've always preferred absolute urls in Angular apps compared to the relative paths (which become very difficult to read for nested components).
Adding custom paths to tsconfig.json works pretty well to solve this problem. VSCode works fine with it and the Cli has no other issues I've run into.
If using paths isn't officially supported does the Angular team recommend using relative paths like import { MyApiService } from '../../../../../my-api.service'?
Bug Report or Feature Request (mark with an
x)Whether this is a bug or a feature depends on whether or not custom
pathsintsconfig.jsonare supported with the Cli.Command (mark with an
x)Versions
Angular CLI: 7.0.2
Node: 10.8.0
OS: win32 x64
Angular: 7.0.0
... animations, common, compiler, compiler-cli, core, forms
... http, language-service, platform-browser
... platform-browser-dynamic, router
Repro steps
ng new app-name(pick defaults)"paths": { "@app/*": ["src/app/*"] }totsconfig.jsonmain.tsto use this new pathimport { AppModule } from '@app/app.module';import { environment } from './environments/environment';ng add @angular/materialYesfor? Set up browser animations for Angular Material?Repository all set up to reproduce this error is available here.
Just clone and type
ng add @angular/material.The log given by the failure
Could not read Angular module file: /src/@app/app.module.tsDesired functionality
Cli handles custom paths in
tsconfig.json.Mention any other details that might be useful
Here is where material tries to get the
app.module.tspathhttps://github.com/angular/material2/blob/985774a4eaa14d1dcbf1ad96ab176043d38f433e/src/lib/schematics/ng-add/setup-project.ts#L56
Here is where the path to
app.module.tsis being calculated in the schematics codeangular-cli/packages/schematics/angular/utility/ng-ast-utils.ts
Line 78 in 82f2bda
I believe the above link is what is causing the problem.
I've always preferred absolute urls in Angular apps compared to the relative paths (which become very difficult to read for nested components).
Adding custom
pathstotsconfig.jsonworks pretty well to solve this problem. VSCode works fine with it and the Cli has no other issues I've run into.If using
pathsisn't officially supported does the Angular team recommend using relative paths likeimport { MyApiService } from '../../../../../my-api.service'?