This schematic generates Angular modules with Dependency Injection (DI) support. It supports two key actions: create ➕ and update 🔄, making it easy to generate new modules or enhance existing ones. The schematic is designed to be directory-aware 📂, meaning:
- For create ➕: Run the schematic from the directory where the module should be created.
- For update 🔄: Run the schematic from the directory containing the module to be updated.
You can use the schematic either deployed from npm 🌐 or locally 💻 during development.
-
Install the schematic globally:
npm install -g di-config-module-schematic
-
Run the schematic in your Angular project directory:
ng generate di-module
-
Follow the prompts in the terminal. Once completed:
- For create ➕, a new module will be generated in the current directory.
- For update 🔄, the specified module will be enhanced with DI support.
-
Clone the repository:
git clone https://github.com/your-username/di-config-module-schematic.git cd di-config-module-schematic
-
Build the project:
npm run build
-
Run the schematic in your Angular project:
schematics ./dist/src/di-config-module-schematic:di-module
-
Follow the prompts in the terminal. Once completed:
- For create ➕, a new module will be generated in the current directory.
- For update 🔄, the specified module will be enhanced with DI support.
To create a new module:
- Navigate 📂 to the directory where you want the module to be created (e.g.,
src/app/modules
). - Run the schematic.
- Provide the following details when prompted:
- Module name 📛
- Configuration interface name 📝
- InjectionToken name 🔑
The schematic will generate the module and necessary files in the current directory.
To update an existing module:
- Navigate 📂 to the directory containing the module to be updated (e.g.,
src/app/modules/payments
). - Run the schematic.
- Provide the following details when prompted:
- Module name 📛
- Configuration interface name 📝
- InjectionToken name 🔑
The schematic will:
- Update the
forRoot
method for DI configuration if not already present. - Generate missing files like the configuration interface 📝 and InjectionToken 🔑, if required.
Assume you provided payments
as the module name during generation.
Edit the payments-config.interface.ts
file to include the configuration properties:
export interface PaymentsConfig {
baseUrl: string; // The base URL for the payments API
currency: string; // Default currency for transactions
retryAttempts: number; // Number of retry attempts for failed requests
enableDebugMode: boolean; // Whether to enable debug mode for logging
}
Import the generated module where needed and configure it using the forRoot
method:
Example: app.module.ts
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { PaymentsModule } from './app/payments/payments.module';
@NgModule({
declarations: [AppComponent],
imports: [
BrowserModule,
PaymentsModule.forRoot({
baseUrl: 'https://api.example.com/payments', // Payments API URL
currency: 'USD', // Default currency
retryAttempts: 3, // Retry attempts for failed requests
enableDebugMode: true, // Enable debug mode
}),
],
providers: [],
bootstrap: [AppComponent],
})
export class AppModule {}
Inject the configuration wherever required using the PAYMENTS_CONFIG_TOKEN
.
Example: app.component.ts
import { Component, Inject } from '@angular/core';
import { PAYMENTS_CONFIG_TOKEN } from './app/payments/payments-injection-tokens';
import { PaymentsConfig } from './app/payments/payments-config.interface';
@Component({
selector: 'app-root',
template: `
<h1>Welcome to the Payments App</h1>
<p>Base URL: {{ config.baseUrl }}</p>
<p>Default Currency: {{ config.currency }}</p>
<p>Retry Attempts: {{ config.retryAttempts }}</p>
<p>Debug Mode: {{ config.enableDebugMode ? 'Enabled' : 'Disabled' }}</p>
`,
})
export class AppComponent {
constructor(@Inject(PAYMENTS_CONFIG_TOKEN) public config: PaymentsConfig) {
console.log('Config Properties:', config.baseUrl, config.currency, config.retryAttempts, config.enableDebugMode);
}
}
- Challenge:
Files were created in incorrect locations due to absolute system paths (
/Users/...
) instead of workspace-relative paths (apps/...
,libs/...
). - Solution:
Implemented a utility to detect the workspace root (
nx.json
orangular.json
) and normalize paths dynamically.
- Challenge: Long CLI commands with multiple options were error-prone and intimidating for users.
- Solution:
Introduced interactive prompts using
x-prompt
and shortened the schematic name todi-module
for a streamlined experience.
This repository serves as a starting point to create and publish Angular schematics.
-
Install the schematics CLI globally:
npm install -g @angular-devkit/schematics-cli
-
Run the schematic locally using the
schematics
CLI:schematics ./dist/src/di-config-module-schematic:di-module
-
Follow the prompts to generate your module.
Run unit tests with:
npm run test
This uses Jasmine as the test framework.
To publish, simply do:
npm run build
npm publish