/Angular-2-Console-Simulator

An Angular 2+ module that creates a simple console in the browser. Developers can add custom functions to the console and call them via text.

Primary LanguageTypeScriptMIT LicenseMIT

Angular 2+ Console Simulator

This library was generated with Angular CLI version 7.2.0.

Pull requests welcome! https://github.com/Mikkal24/Angular-2-Console-Simulator

Description

The idea behind this project is to simulate a normal command line environment within the web-browser using Angular. The console is also customizable so developers can add their own commands (functions) to their console simulator

Demo

https://testproj12142017.firebaseapp.com/

Demo

Getting Started

npm i angular2-console-simulator --save

Example

Step 1. Add the module

// app.module.ts
.
.
.
import { Angular2ConsoleSimulatorModule } from "angular2-console-simulator";

@NgModule({
  declarations: [...],
  imports: [..., Angular2ConsoleSimulatorModule, ...],
  providers: [...],
  bootstrap: [...]
})
export class AppModule {}

Step 2. Add configuration to the component you want to add the simulator too.

// example.component.ts
import { Component, OnInit } from "@angular/core";

@Component({
  selector: "app-example",
  templateUrl: "./example.component.html",
  styleUrls: ["./example.component.scss"]
})
export class ExampleComponent implements OnInit {
  consoleConfig;
  bgColor;
  constructor() {}

  ngOnInit() {
    this.consoleConfig = {
      commands: [
        {
          alias: "test",
          function: this.test.bind(this), //note that you need to bind the context to the function in order for it to have access to the required properties.
          description: "this is a test function"
        },
        {
          alias: "color",
          function: this.color.bind(this),
          description: `
          this functions changes the color of the page provided a valid color value as an argument \n
          example: "color red"
          `
        }
      ]
    };
  }

  test() {
    // the simulator overrides the browser console.log so that any console.log called within these functions is output inside the simulators log.
    console.log("test");
  }

  color(arg) {
    if (arg) {
      this.bgColor = arg[0];
    }
  }
}

and then inside the template...

<div [ngStyle]="{ backgroundColor: bgColor }">
  <console-simulator [config]="consoleConfig"></console-simulator>
</div>

And that's it!