From 58de3f886936c603b0cdc7853e2f4d0a7e23682e Mon Sep 17 00:00:00 2001 From: rj Date: Thu, 19 Sep 2024 09:40:04 +0200 Subject: [PATCH] Activate Angular template linter --- .eslintrc.json | 57 ++++++++++++++++----- apps/angular-app/src/app/app.component.html | 1 + apps/angular-app/src/app/app.component.ts | 7 +++ apps/angular-app/tsconfig.app.json | 10 +++- apps/angular-app/tsconfig.editor.json | 21 +++++--- libs/.gitkeep | 0 nx.json | 6 ++- 7 files changed, 79 insertions(+), 23 deletions(-) delete mode 100644 libs/.gitkeep diff --git a/.eslintrc.json b/.eslintrc.json index 875a365..ffdfd73 100644 --- a/.eslintrc.json +++ b/.eslintrc.json @@ -14,6 +14,9 @@ "*.js", "*.jsx" ], + "plugins": [ + "@angular-eslint/eslint-plugin" + ], "rules": { "@nx/enforce-module-boundaries": [ "error", @@ -29,29 +32,59 @@ } ] } - ] + ], + "@angular-eslint/component-selector": [ + "error", + { + "type": "element", + "prefix": "app", + "style": "kebab-case" + } + ], + "@angular-eslint/directive-selector": [ + "error", + { + "type": "attribute", + "prefix": "app", + "style": "camelCase" + } + ], + "no-bitwise": "off", + "security-node/detect-crlf": "off", + "@angular-eslint/no-conflicting-lifecycle": "error", + "@angular-eslint/no-host-metadata-property": "error", + "@angular-eslint/no-input-rename": "error", + "@angular-eslint/no-inputs-metadata-property": "error", + "@angular-eslint/no-output-native": "error", + "@angular-eslint/no-output-on-prefix": "error", + "@angular-eslint/no-output-rename": "error", + "@angular-eslint/no-outputs-metadata-property": "error", + "@angular-eslint/use-lifecycle-interface": "error", + "@angular-eslint/use-pipe-transform-interface": "error" } }, { "files": [ - "*.ts", - "*.tsx" - ], - "extends": [ - "plugin:@nx/typescript" + "*.html" ], "rules": { - "@typescript-eslint/no-extra-semi": "error", - "no-extra-semi": "off" - } + "no-irregular-whitespace": "off", + "@angular-eslint/template/banana-in-box": "error", + "@angular-eslint/template/no-negated-async": "error", + "@angular-eslint/template/eqeqeq": "error", + "@angular-eslint/template/no-inline-styles": "error" + }, + "plugins": [ + "@angular-eslint/eslint-plugin-template" + ] }, { "files": [ - "*.js", - "*.jsx" + "*.ts", + "*.tsx" ], "extends": [ - "plugin:@nx/javascript" + "plugin:@nx/typescript" ], "rules": { "@typescript-eslint/no-extra-semi": "error", diff --git a/apps/angular-app/src/app/app.component.html b/apps/angular-app/src/app/app.component.html index 11579cb..355628f 100644 --- a/apps/angular-app/src/app/app.component.html +++ b/apps/angular-app/src/app/app.component.html @@ -4,6 +4,7 @@

Welcome to angular-app!

alt="Nx - Powerful, Extensible Dev Tools" />
Message: {{ hello$ | async | json }}
+
{{ someObject?.thisIsAlwaysThere?.str }}
\ No newline at end of file diff --git a/apps/angular-app/src/app/app.component.ts b/apps/angular-app/src/app/app.component.ts index dad03fa..8bca64b 100644 --- a/apps/angular-app/src/app/app.component.ts +++ b/apps/angular-app/src/app/app.component.ts @@ -2,6 +2,10 @@ import { Component } from '@angular/core'; import { HttpClient } from '@angular/common/http'; import { Message } from '@happynrwl/api-interfaces'; +interface ISomeObject { + thisIsAlwaysThere: { str: string }; +} + @Component({ selector: 'happynrwl-root', templateUrl: './app.component.html', @@ -9,6 +13,9 @@ import { Message } from '@happynrwl/api-interfaces'; }) export class AppComponent { hello$ = this.http.get('/api/hello'); + protected someObject: ISomeObject = { + thisIsAlwaysThere: { str: 'Here I am' }, + } constructor( private http: HttpClient, diff --git a/apps/angular-app/tsconfig.app.json b/apps/angular-app/tsconfig.app.json index 25f8f2c..25a1e3c 100644 --- a/apps/angular-app/tsconfig.app.json +++ b/apps/angular-app/tsconfig.app.json @@ -4,7 +4,8 @@ "outDir": "../../dist/out-tsc", "types": [], "target": "ES2022", - "useDefineForClassFields": false + "useDefineForClassFields": false, + "strict": true }, "files": [ "src/main.ts", @@ -18,5 +19,10 @@ "**/*.cy.js", "**/*.cy.tsx", "**/*.cy.jsx" - ] + ], + "angularCompilerOptions": { + "strictInjectionParameters": true, + "strictInputAccessModifiers": true, + "strictTemplates": true + } } \ No newline at end of file diff --git a/apps/angular-app/tsconfig.editor.json b/apps/angular-app/tsconfig.editor.json index 1bf3c0a..60775c4 100644 --- a/apps/angular-app/tsconfig.editor.json +++ b/apps/angular-app/tsconfig.editor.json @@ -1,8 +1,15 @@ { - "extends": "./tsconfig.json", - "include": ["**/*.ts"], - "compilerOptions": { - "types": ["jest", "node"] - }, - "exclude": ["jest.config.ts"] -} + "extends": "./tsconfig.json", + "include": [ + "**/*.ts" + ], + "compilerOptions": { + "types": [ + "jest", + "node" + ] + }, + "exclude": [ + "jest.config.ts" + ] +} \ No newline at end of file diff --git a/libs/.gitkeep b/libs/.gitkeep deleted file mode 100644 index e69de29..0000000 diff --git a/nx.json b/nx.json index 9528c9d..cb0b10a 100644 --- a/nx.json +++ b/nx.json @@ -14,11 +14,13 @@ "style": "scss", "linter": "eslint", "unitTestRunner": "jest", - "e2eTestRunner": "cypress" + "e2eTestRunner": "cypress", + "strict": true }, "@nx/angular:library": { "linter": "eslint", - "unitTestRunner": "jest" + "unitTestRunner": "jest", + "strict": true }, "@nx/angular:component": { "style": "scss"