Skip to content

giscafer/ngx-ace-tern

Repository files navigation

ngx-ace-tern

npm package

Tern plugin for Ace Editor, base on Angular8.x.

Online Demo

default options

      enableBasicAutocompletion: true,
      enableLiveAutocompletion: true

default mode: javascript

default theme: chrome

Install

npm i ngx-ace-tern -S

Sample Usage

add scripts ace-builds in your index.html or angular-cli.json.

you also can use brace instead of ace-builds.

eg

First

<script src="./assets/ace-builds/src-noconflict/ace.js"></script>

or use brace to cleaning angular.json:

import 'brace/index';
import 'brace/mode/markdown';
import 'brace/theme/github';
import 'brace/theme/monokai';

Second

import { Component } from '@angular/core';

import { AceEditorDirective } from 'ngx-ace-tern';

@Component({
  directives: [AceEditorDirective],
  template: `
    <div
      ace-editor
      [text]="text"
      [mode]="'sql'"
      [theme]="'clouds'"
      [options]="options"
      [readOnly]="false"
      (textChanged)="onChange($event)"
      style="display:block; height: 80vh; width:100%"
    ></div>
  `,
})
export class MyComponent {
  constructor() {
    this.text = 'test';
    this.options = { printMargin: false };
    this.onChange = (data) => {
      console.log(data);
    };
  }
}

Important pieces to note in the HTML template: [ace-editor] attribute, [text], [theme], [mode], [readOnly], [options] inputs, (textChanged) ,(editorRef) output. As per Ace, you must also make it a display: block; and give it a width and height.

Related

License

MIT


giscafer.com  ·  GitHub @giscafer  ·  Twitter @nickbinglao  ·  Weibo @Nickbing_Lao