RSS Git Download  Clone
Raw Blame History
Markdown rendered
[//]: #@corifeus-header


[![Donate for Corifeus / P3X](]( [![Contact Corifeus / P3X](]( [![Corifeus @ Facebook](](  [![Build Status](](
[![Uptime Robot ratio (30 days)](](

# 🆖 Angular Dynamic Compile - Convert strings to Angular components v2021.10.115

**Bugs are evident™ - MATRIX️**

### Version requirement

### Built on NodeJs

# Built on Angular


# Description

[//]: #@corifeus-header:end

# Use case
Dynamically compile standard strings to fully functional Angular components. Supports imports, exports, and standard context.

## Install

npm install --save p3x-angular-compile
# or
yarn add p3x-angular-compile

## Check out how it works and code


Make sure AOT is disabled in the `angular.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": "",

            // make sure it is false
            "aot": false,

            "assets": [
            "styles": [
            "scripts": []

#### Minimum build requirement arguments

ng build --aot=false --build-optimizer=false

## Usage

import { CompileModule} from "p3x-angular-compile"

// the module settings
    imports: [
        CorifeusWebMaterialModule, // Optional
        CompileModule, // Required
    declarations: [
    providers: [
    bootstrap: [ Page ]
export class Module { };

#### Template

 <!--- Not required -->

 <!--- Required -->

 <!--- Required -->

 <!--- Not required, will just throw the component's exception if not provided -->

 <!--- Not required -->

#### Code
// A page example
export class Page {

    isEnabled: boolean = true;

    dataModule : any =  {
        //schemas: [CUSTOM_ELEMENTS_SCHEMA],
        //declarations: [],
        imports: [
        exports: [

    template: string = "<button mat-button mat-raised-button (click)="context.alert()">Dynamic template</button>";

    handleCompileErrorHandler(error: Error) {

    alert() {


#### 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](

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

npm install -g yarn
git clone
cd angular-compile
npm install
npm run start


# 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:
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 v2021.10.115

[![Donate for Corifeus / P3X](](  [![Contact Corifeus / P3X](]( [![Like Corifeus @ Facebook](](

## P3X Sponsor

[IntelliJ - The most intelligent Java IDE](


[//]: #@corifeus-footer:end