@hqjs/babel-plugin-add-decorators-metadata

0.0.2 • Public • Published

babel-plugin-add-decorators-metadata

Add decorators metadata

Installation

npm install hqjs@babel-plugin-add-decorators-metadata

Usage

{
  "plugins": [["hqjs@babel-plugin-add-decorators-metadata"]]
}

Transformation

Transforms decorators into class metadata, takes care of wrapping providers property into an object. This transformations allow angular to use dependency injection.123

So the code

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import {CoreConfig} from './app.service';

import { AppComponent } from './app.component';

@NgModule({
  declarations: [
    AppComponent
  ],
  imports: [
    BrowserModule
  ],
  providers: [
    CoreConfig
  ],
  bootstrap: [AppComponent]
})
export class AppModule { }

will turn into

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { CoreConfig } from './app.service';
import { AppComponent } from './app.component';
@NgModule({
  declarations: [AppComponent],
  imports: [BrowserModule],
  providers: [{
    provide: CoreConfig
  }],
  bootstrap: [AppComponent]
})
export class AppModule {}
AppModule.decorators = [{
  type: NgModule,
  args: [{
    declarations: [AppComponent],
    imports: [BrowserModule],
    providers: [{
      provide: CoreConfig
    }],
    bootstrap: [AppComponent]
  }]
}];

Package Sidebar

Install

npm i @hqjs/babel-plugin-add-decorators-metadata

Homepage

hqjs.org

Weekly Downloads

4

Version

0.0.2

License

MIT

Unpacked Size

13.5 kB

Total Files

6

Last publish

Collaborators

  • hqjs