RSS Git Download  Clone
  inspectionProfiles p3x-robot sunday release 2017-6-3 15:44:33 4 years, 8 months ago
  angular-compile.iml 336B p3x-robot sunday release 5/20/2017, 5:00:16 PM 4 years, 8 months ago
  codeStyleSettings.xml 277B p3x-robot sunday release 2017-8-30 16:39:17 4 years, 5 months ago
  misc.xml 174B p3x-robot sunday release 5/28/2017, 7:59:00 AM 4 years, 8 months ago
  modules.xml 282B p3x-robot sunday release 5/20/2017, 5:00:16 PM 4 years, 8 months ago
  vcs.xml 167B p3x-robot sunday release 5/20/2017, 5:00:16 PM 4 years, 8 months ago
[//]: #@corifeus-header [![NPM](]( [![Donate for Corifeus / P3X](]( [![Contact Corifeus / P3X](]( [![Corifeus @ Facebook](]( [![Build Status](]( [![Uptime Robot ratio (30 days)](]( # 🆖 Angular Dynamic Compile - Convert strings to Angular components v2020.10.142 **Bugs are evident™ - MATRIX️** ### NodeJs LTS Version Requirement ```txt >=12.13.0 ``` ### Built on NodeJs ```txt v12.19.0 ``` The ```async``` and ```await``` keywords are required. Only the latest LTS variant is supported. Install NodeJs: # Built on Angular ```text 10.1.6 ``` # Description [//]: #@corifeus-header:end # Use case Dynamically compile standard strings to fully functional Angular components. Supports imports, exports, and standard context. ## Install ```bash npm install --save p3x-angular-compile lodash # or yarn add p3x-angular-compile lodash ``` ## Check out how it works and code ## IMPORTANT Make sure Ivy is disabled and allow synthetic default imports in the `tsconfig.json`: ```json "compilerOptions": { "allowSyntheticDefaultImports": true }, "angularCompilerOptions": { "enableIvy": false } ``` Make sure AOT is disabled in the `angular.json`: ```json { "architect": { "build": { "builder": "@angular-devkit/build-angular:browser", "options": { "outputPath": "dist/workspace", "index": "src/index.html", "main": "src/main.ts", "polyfills": "src/polyfills.ts", "tsConfig": "", "aot-info": "make sure it is false", "aot": false, "assets": [ "src/favicon.ico", "src/assets" ], "styles": [ "src/styles.scss" ], "scripts": [] } } } ``` When you work with P3X Angular Compile, you have to disable AOT as well, so like this: ```bash ng serve --aot=false ``` ## Usage ```typescript import { CompileModule} from "p3x-angular-compile" // the module settings @NgModule({ imports: [ CorifeusWebMaterialModule, // Optional CompileModule, // Required ], declarations: [ Page, ], providers: [ ], bootstrap: [ Page ] }) export class Module { }; ``` #### Template ```html <span <!--- Not required --> *ngIf="isEnabled" <!--- Required --> [p3x-compile]="template" <!--- Required --> [p3x-compile-ctx]="this" <!--- Not required, will just throw the component's exception if not provided --> [p3x-compile-error-handler]="handleCompileErrorHandler" <!--- Not required --> [p3x-compile-module]="dataModule" > </span> ``` #### Code ```typescript // A page example export class Page { isEnabled: boolean = true; dataModule : any = { //schemas: [CUSTOM_ELEMENTS_SCHEMA], //declarations: [], imports: [ MatButtonModule ], exports: [ ] } template: string = "<button mat-button mat-raised-button (click)="context.alert()">Dynamic template</button>"; handleCompileErrorHandler(error: Error) { console.error(error) } alert() { alert('ok'); } } ``` <!-- #### Actual used dynamic compiler I use a dynamic Markdown page with ```p3x-angular-compile```: [Module]( , [Example page]( #### Service [Please refer to use an a service]( ```typescript export interface CompileOptions { // cached by template template: string; container: ViewContainerRef; context?: any, // you can customize here any you want to // CommonModule, BrowserModule are auto added // (like *ngIf and angular default directives) // though CompileModule.forRoot is usually enough // so you do not need to use it module?: NgModule; onCompiled?: Function, onError?: Function; } ``` --> ### Options [Reference for the Angular module settings which are available.]( <!-- The templates are cached. --> <!-- ### Deployed example [Corifeus Pages (JIT + AOT at once)]( #### For now, until there is no options in Angular to use JIT, I just use AOT, so I don't use this component [Corifeus Pages (AOT)]( []( --> ## Dev environment end test ```bash npm install -g yarn git clone cd angular-compile npm install npm run start ``` [http://localhost:4200](http://localhost:4200) # Errors ## Type x is part of the declarations of 2 modules Basically, you need a shared component. ## AOT + JIT ### Since Angular 5.x.x + We cannot use AOT + JIT at once. #### Info On the issue, you can see: ```text To reduce the payload, we do not ship the compiler in AOT. ``` So right now, it is not possible. Although, there are some hacks, but you are on your own... <!--- ### Angular 4.x.x It is not working out of the box (the default is either JIT or AOT, not both), but the apps become 10 folds faster. The ``@ngtools/webpack`` is AOT and the ```awesome-typescript-loader``` is JIT only. The solution can be architect with the ```@angular/compiler``` and the ```awesome-typescript-loader``` together. A miracle! Example here (since I am using Angular 5 not, it is not AOT + JIT anymore, but if you are on Angular 4, you can do it): [More info about AOT + JIT]( --> ### Size If you want very small bundle, use ```gzip```. [//]: #@corifeus-footer --- 🙏 This is an open-source project. Star this repository, if you like it, or even donate to maintain the servers and the development. Thank you so much! Possible, this server, rarely, is down, please, hang on for 15-30 minutes and the server will be back up. All my domains ([]( and []( could have minor errors, since I am developing in my free time. However, it is usually stable. **Note about versioning:** Versions are cut in Major.Minor.Patch schema. Major is always the current year. Minor is either 4 (January - June) or 10 (July - December). Patch is incremental by every build. If there is a breaking change, it should be noted in the readme. --- [**P3X-ANGULAR-COMPILE**]( Build v2020.10.142 [![Donate for Corifeus / P3X](]( [![Contact Corifeus / P3X](]( [![Like Corifeus @ Facebook](]( ## P3X Sponsor [IntelliJ - The most intelligent Java IDE]( [![JetBrains](]( [//]: #@corifeus-footer:end