Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

angular-monaco-editor

Package Overview
Dependencies
Maintainers
1
Versions
16
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

angular-monaco-editor - npm Package Compare versions

Comparing version 1.2.0 to 1.3.0

4

bundles/angular-monaco-editor.umd.js

@@ -183,3 +183,3 @@ (function (global, factory) {

var /** @type {?} */ loaderScript = document.createElement('script');
loaderScript.type = 'application/javascript';
loaderScript.type = 'text/javascript';
loaderScript.src = baseUrl + "/monaco/vs/loader.js";

@@ -436,2 +436,2 @@ loaderScript.addEventListener('load', onGotAmdLoader);

//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"angular-monaco-editor.umd.js.map","sources":["ng://angular-monaco-editor/lib/editor/config.ts","ng://angular-monaco-editor/lib/editor/constants/events.ts","ng://angular-monaco-editor/lib/editor/services/code-editor.event.service.ts","ng://angular-monaco-editor/lib/editor/angular-monaco-editor/angular-monaco-editor.component.ts","ng://angular-monaco-editor/lib/editor/editor.module.ts"],"sourcesContent":["import { InjectionToken } from '@angular/core';\n\n// injectionTokenä½ç¨è¯´æ\n// https://segmentfault.com/a/1190000008626348\nexport const ANGULAR_MONACO_EDITOR_CONFIG = new InjectionToken('ANGULAR_MONACO_EDITOR_CONFIG');\n\nexport interface AngularMonacoEditorConfig {\n  baseUrl?: string;\n  defaultOptions?: { [key: string]: any; },\n  onMonacoLoad?: Function;\n}","export const CODE_EDITOR_EVENTS = {\r\n    onInit: 'onInit',\r\n    onChange: 'onChange',\r\n    onTouched: 'onTouched'\r\n}","import { EventEmitter, Injectable } from '@angular/core';\r\n\r\nimport { assign } from 'lodash';\r\nimport { pick } from 'lodash';\r\n\r\nimport { CODE_EDITOR_EVENTS } from '../constants/events';\r\n\r\n@Injectable()\r\nexport class CodeEditorEventService {\r\n    public eventNames = Object.keys(CODE_EDITOR_EVENTS);\r\n    private _events: any = {}; // ä½¿ç¨äºä»¶\r\n\r\n    /**\r\n     * è®¾ç½®å¯ç¨äºä»¶\r\n     * @param  äºä»¶\r\n     */\r\n    addEvent(event){\r\n        assign(this._events, event);\r\n        // console.log(this.events);\r\n    }\r\n\r\n    fireEvent(event) {\r\n        this._events[event.eventName].emit(event);\r\n        // console.log(\"Emit Event:\" + event);\r\n    }\r\n}\r\n","import { Component, OnInit, AfterViewInit, ElementRef, EventEmitter, Input, OnDestroy, Output, ViewChild } from '@angular/core';\nimport { forwardRef, Inject, NgZone } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { pick } from 'lodash';\n\nimport { ANGULAR_MONACO_EDITOR_CONFIG, AngularMonacoEditorConfig } from '../config';\nimport { CodeEditorEventService } from '../services/code-editor.event.service';\nimport { CODE_EDITOR_EVENTS } from '../constants/events';\n\ndeclare const monaco: any;\n\nlet loadedMonaco: boolean = false;\nlet loadPromise: Promise<void>;\n\n// èªå®ä¹è¾å¥æ§ä»¶:1.å°è£ControlValueAccessor\n// https://code-examples.net/zh-CN/q/2154761\nexport const CODE_EDITOR_INPUT_VALUE_ACCESSOR: any = {\n  // https://blog.csdn.net/wangdan_2013/article/details/81314959\n  provide: NG_VALUE_ACCESSOR,//\n  useExisting: forwardRef(() => AngularMonacoEditorComponent),//\n  multi: true//\n};\n\n@Component({\n  selector: 'angular-monaco-editor',\n  template: `<div class=\"editor\" #codeEditor></div>`,\n  styles: [`:host{display:block;height:200px}.editor{width:100%;height:98%}`],\n  // èªå®ä¹è¾å¥æ§ä»¶:2.å¼å¥ä¾èµæå¡ControlValueAccessor\n  providers: [CODE_EDITOR_INPUT_VALUE_ACCESSOR, CodeEditorEventService]\n})\n\n// èªå®ä¹è¾å¥æ§ä»¶ <-> Monaco Edtor\n\n// èªå®ä¹è¾å¥æ§ä»¶:3.1 implements ControlValueAccessor \nexport class AngularMonacoEditorComponent implements AfterViewInit, ControlValueAccessor, OnDestroy{\n\n  protected _editor: any;\n  private _options: any;\n  // protected _windowResizeSubscription: Subscription;\n\n  @ViewChild('codeEditor') _editorComponent: ElementRef; //å¨ææ·»å ä»£ç ç¼è¾å¨\n  \n  @Output() onInit;\n  @Output() onChange;\n  @Output() onTouched;\n\n  @Input('options')\n  set options(options: any) {\n    // é»è®¤options(this.config.defaultOptions) + èªå®ä¹options(options)\n    this._options = Object.assign({}, this.config.defaultOptions, options);\n    if (this._editor) {\n      this._editor.dispose();\n      this.initMonaco(options);\n    }\n  }\n  get options(): any {\n    return this._options;\n  }\n\n  // @Input('model')\n  // set model(model: AngularEditorModel) {\n  //   this.options.model = model;\n  //   if (this._editor) {\n  //     this._editor.dispose();\n  //     this.initMonaco(this.options);\n  //   }\n  // }\n\n  // æ³¨å¥AngularMonacoEditorConfigï¼å¨åå»ºEditorå®ä¾æ¶è®¾ç½®config\n  constructor(private zone: NgZone, @Inject(ANGULAR_MONACO_EDITOR_CONFIG) private config: AngularMonacoEditorConfig, private codeEditorEventService: CodeEditorEventService) {\n\n    // åå§åèªå®ä¹äºä»¶\n    const self = this;\n    codeEditorEventService.eventNames.forEach((name) => {\n      // åå»ºèªå®ä¹äºä»¶ï¼æ­¤å¤ä½ç¨ç­æäº: @Output() onInit = new EventEmitter<any>() \n      self[name] = new EventEmitter<any>();\n      const eventPair = pick(self, name);\n      codeEditorEventService.addEvent(eventPair);\n    });\n\n  }\n\n  ngAfterViewInit(): void {\n    if (loadedMonaco) {\n      // Wait until monaco editor is available\n      loadPromise.then(() => {\n        this.initMonaco(this.options);\n      });\n    } else {\n      loadedMonaco = true;\n      loadPromise = new Promise<void>((resolve: any) => {\n        const baseUrl = this.config.baseUrl || '/assets';\n        // if (typeof((<any>window).monaco) === 'object') {\n        //   resolve();\n        //   return;\n        // }\n        const onGotAmdLoader: any = () => {\n          // Load monaco\n          (<any>window).require.config({ paths: { 'vs': `${baseUrl}/monaco/vs` } });\n          (<any>window).require(['vs/editor/editor.main'], () => {\n            if (typeof this.config.onMonacoLoad === 'function') {\n              this.config.onMonacoLoad();\n            }\n            this.initMonaco(this.options);\n            resolve();\n          });\n        };\n\n        // Load AMD loader if necessary\n        if (!(<any>window).require) {\n          const loaderScript: HTMLScriptElement = document.createElement('script');\n          loaderScript.type = 'application/javascript';\n          loaderScript.src = `${baseUrl}/monaco/vs/loader.js`;\n          loaderScript.addEventListener('load', onGotAmdLoader);\n          document.body.appendChild(loaderScript);\n        } else {\n          onGotAmdLoader();\n        }\n      });\n    }\n  }\n\n  ngOnDestroy() {\n    // if (this._windowResizeSubscription) {\n    //   this._windowResizeSubscription.unsubscribe();\n    // }\n    if (this._editor) {\n      this._editor.dispose();\n      this._editor = undefined;\n    }\n  }\n\n  protected initMonaco(options: any): void {\n    console.log(\"Init the custom monaco code editor.\");\n\n    // const hasModel = !!options.model;\n    const hasModel = false;\n\n    // if (hasModel) {\n    //   options.model = monaco.editor.createModel(options.model.value, options.model.language, options.model.uri);\n    // }\n    \n    this._editor = monaco.editor.create(this._editorComponent.nativeElement, options);\n\n    if (!hasModel) {\n      this._editor.setValue(this._value);\n    }\n\n    // monaco editor -> outside component\n    this._editor.onDidChangeModelContent((e: any) => this.onChangeModelContentHandler(e));\n\n    this._editor.onDidBlurEditorText((e: any) => this.onBlurEditorTextHandler(e));\n\n    // refresh layout on resize event.\n    // if (this._windowResizeSubscription) {\n    //   this._windowResizeSubscription.unsubscribe();\n    // }\n    // this._windowResizeSubscription = fromEvent(window, 'resize').subscribe(() => this._editor.layout());\n\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onInit,\n      target: this,\n      editor: this._editor\n    });\n  }\n\n  onChangeModelContentHandler(e){\n    const _value = this._editor.getValue();\n    \n    // monaco editor -> outside component\n    // https://github.com/JTangming/tm/issues/4 ngZoneè¯¦è§£\n    this.zone.run(() => this.value = _value);// value is not propagated to parent when executing outside zone.\n    // console.log(\"write from the monaco:\" + this._value);\n  }\n\n  onBlurEditorTextHandler(e){\n\n    this.onTouchedHandler();\n  }\n\n  private _value: string = '';\n\n  //get accessor\n  get value(): any {\n      return this._value;\n  };\n\n  //set accessor including call the onchange callback\n  set value(v: any) {\n    if (v !== this.value) {// æ³¨æè¿ç§åæ³ï¼å¼å¾å­¦ä¹ \n      this._value = v;\n    }\n\n    this.onChangeHandler(this.value);//å¨å±æ§ä¿®é¥°å¨éè°ç¨onchangeHandleræ¹æ³\n  }\n\n  localEditor(){//Demo: outside component -> monaco editor\n    this.writeValue('test');\n  }\n\n  // èªå®ä¹è¾å¥æ§ä»¶:3.2 implements ControlValueAccesso\n\n  // outside component -> monaco editor\n  \n  //From ControlValueAccessor interface\n  writeValue(value: any) {\n    this.value = value || '';\n\n    // Fix for value change while dispose in process.\n    setTimeout(() => {\n      if (this._editor /*&& !this.options.model*/) {\n        this._editor.setValue(this._value);\n        // console.log(\"write to the editor:\" + this._value);\n      }\n    });\n  }\n\n  //From ControlValueAccessor interface\n  registerOnChange(fn: any) {\n    this.onChangeHandler(this);\n  }\n\n  //From ControlValueAccessor interface\n  registerOnTouched(fn: any) {\n    this.onTouchedHandler();\n  }\n  \n  //ControlValueAccessoræä¾çäºä»¶åè°\n  onChangeHandler = (_: any) => { //Propagate Change to outside\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onChange,\n      target: this,\n      data: _\n    });\n  };\n\n  //ControlValueAccessoræä¾çäºä»¶åè°\n  onTouchedHandler = () => {\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onTouched,\n      target: this\n    });\n  };\n}","import { CommonModule } from '@angular/common';\n\nimport { ModuleWithProviders, NgModule } from '@angular/core';\nimport { ANGULAR_MONACO_EDITOR_CONFIG, AngularMonacoEditorConfig } from './config';\nimport { AngularMonacoEditorComponent } from './angular-monaco-editor/angular-monaco-editor.component';\n\n@NgModule({\n  imports: [\n    CommonModule\n  ],\n  declarations: [\n    AngularMonacoEditorComponent\n  ],\n  exports: [\n    AngularMonacoEditorComponent\n  ],\n  providers: [\n  ]\n})\n\nexport class AngularMonacoEditorModule {\n  public static forRoot(config: AngularMonacoEditorConfig = {}): ModuleWithProviders {\n    return {\n      ngModule: AngularMonacoEditorModule,\n      providers: [\n        { provide: ANGULAR_MONACO_EDITOR_CONFIG, useValue: config }\n      ]\n    };\n  }\n}\n"],"names":["InjectionToken","assign","Injectable","NG_VALUE_ACCESSOR","forwardRef","EventEmitter","pick","Component","NgZone","Inject","ViewChild","Output","Input","NgModule","CommonModule"],"mappings":"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"}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"angular-monaco-editor.umd.js.map","sources":["ng://angular-monaco-editor/lib/editor/config.ts","ng://angular-monaco-editor/lib/editor/constants/events.ts","ng://angular-monaco-editor/lib/editor/services/code-editor.event.service.ts","ng://angular-monaco-editor/lib/editor/angular-monaco-editor/angular-monaco-editor.component.ts","ng://angular-monaco-editor/lib/editor/editor.module.ts"],"sourcesContent":["import { InjectionToken } from '@angular/core';\n\n// injectionTokenä½ç¨è¯´æ\n// https://segmentfault.com/a/1190000008626348\nexport const ANGULAR_MONACO_EDITOR_CONFIG = new InjectionToken('ANGULAR_MONACO_EDITOR_CONFIG');\n\nexport interface AngularMonacoEditorConfig {\n  baseUrl?: string;\n  defaultOptions?: { [key: string]: any; },\n  onMonacoLoad?: Function;\n}","export const CODE_EDITOR_EVENTS = {\r\n    onInit: 'onInit',\r\n    onChange: 'onChange',\r\n    onTouched: 'onTouched'\r\n}","import { EventEmitter, Injectable } from '@angular/core';\r\n\r\nimport { assign } from 'lodash';\r\nimport { pick } from 'lodash';\r\n\r\nimport { CODE_EDITOR_EVENTS } from '../constants/events';\r\n\r\n@Injectable()\r\nexport class CodeEditorEventService {\r\n    public eventNames = Object.keys(CODE_EDITOR_EVENTS);\r\n    private _events: any = {}; // ä½¿ç¨äºä»¶\r\n\r\n    /**\r\n     * è®¾ç½®å¯ç¨äºä»¶\r\n     * @param  äºä»¶\r\n     */\r\n    addEvent(event){\r\n        assign(this._events, event);\r\n        // console.log(this.events);\r\n    }\r\n\r\n    fireEvent(event) {\r\n        this._events[event.eventName].emit(event);\r\n        // console.log(\"Emit Event:\" + event);\r\n    }\r\n}\r\n","import { Component, OnInit, AfterViewInit, ElementRef, EventEmitter, Input, OnDestroy, Output, ViewChild } from '@angular/core';\nimport { forwardRef, Inject, NgZone } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { pick } from 'lodash';\n\nimport { ANGULAR_MONACO_EDITOR_CONFIG, AngularMonacoEditorConfig } from '../config';\nimport { CodeEditorEventService } from '../services/code-editor.event.service';\nimport { CODE_EDITOR_EVENTS } from '../constants/events';\n\ndeclare const monaco: any;\n\nlet loadedMonaco: boolean = false;\nlet loadPromise: Promise<void>;\n\n// èªå®ä¹è¾å¥æ§ä»¶:1.å°è£ControlValueAccessor\n// https://code-examples.net/zh-CN/q/2154761\nexport const CODE_EDITOR_INPUT_VALUE_ACCESSOR: any = {\n  // https://blog.csdn.net/wangdan_2013/article/details/81314959\n  provide: NG_VALUE_ACCESSOR,//\n  useExisting: forwardRef(() => AngularMonacoEditorComponent),//\n  multi: true//\n};\n\n@Component({\n  selector: 'angular-monaco-editor',\n  template: `<div class=\"editor\" #codeEditor></div>`,\n  styles: [`:host{display:block;height:200px}.editor{width:100%;height:98%}`],\n  // èªå®ä¹è¾å¥æ§ä»¶:2.å¼å¥ä¾èµæå¡ControlValueAccessor\n  providers: [CODE_EDITOR_INPUT_VALUE_ACCESSOR, CodeEditorEventService]\n})\n\n// èªå®ä¹è¾å¥æ§ä»¶ <-> Monaco Edtor\n\n// èªå®ä¹è¾å¥æ§ä»¶:3.1 implements ControlValueAccessor \nexport class AngularMonacoEditorComponent implements AfterViewInit, ControlValueAccessor, OnDestroy{\n\n  protected _editor: any;\n  private _options: any;\n  // protected _windowResizeSubscription: Subscription;\n\n  @ViewChild('codeEditor') _editorComponent: ElementRef; //å¨ææ·»å ä»£ç ç¼è¾å¨\n  \n  @Output() onInit;\n  @Output() onChange;\n  @Output() onTouched;\n\n  @Input('options')\n  set options(options: any) {\n    // é»è®¤options(this.config.defaultOptions) + èªå®ä¹options(options)\n    this._options = Object.assign({}, this.config.defaultOptions, options);\n    if (this._editor) {\n      this._editor.dispose();\n      this.initMonaco(options);\n    }\n  }\n  get options(): any {\n    return this._options;\n  }\n\n  // @Input('model')\n  // set model(model: AngularEditorModel) {\n  //   this.options.model = model;\n  //   if (this._editor) {\n  //     this._editor.dispose();\n  //     this.initMonaco(this.options);\n  //   }\n  // }\n\n  // æ³¨å¥AngularMonacoEditorConfigï¼å¨åå»ºEditorå®ä¾æ¶è®¾ç½®config\n  constructor(private zone: NgZone, @Inject(ANGULAR_MONACO_EDITOR_CONFIG) private config: AngularMonacoEditorConfig, private codeEditorEventService: CodeEditorEventService) {\n\n    // åå§åèªå®ä¹äºä»¶\n    const self = this;\n    codeEditorEventService.eventNames.forEach((name) => {\n      // åå»ºèªå®ä¹äºä»¶ï¼æ­¤å¤ä½ç¨ç­æäº: @Output() onInit = new EventEmitter<any>() \n      self[name] = new EventEmitter<any>();\n      const eventPair = pick(self, name);\n      codeEditorEventService.addEvent(eventPair);\n    });\n\n  }\n\n  ngAfterViewInit(): void {\n    if (loadedMonaco) {\n      // Wait until monaco editor is available\n      loadPromise.then(() => {\n        this.initMonaco(this.options);\n      });\n    } else {\n      loadedMonaco = true;\n      loadPromise = new Promise<void>((resolve: any) => {\n        const baseUrl = this.config.baseUrl || '/assets';\n        // if (typeof((<any>window).monaco) === 'object') {\n        //   resolve();\n        //   return;\n        // }\n        const onGotAmdLoader: any = () => {\n          // Load monaco\n          (<any>window).require.config({ paths: { 'vs': `${baseUrl}/monaco/vs` } });\n          (<any>window).require(['vs/editor/editor.main'], () => {\n            if (typeof this.config.onMonacoLoad === 'function') {\n              this.config.onMonacoLoad();\n            }\n            this.initMonaco(this.options);\n            resolve();\n          });\n        };\n\n        // Load AMD loader if necessary\n        if (!(<any>window).require) {\n          const loaderScript: HTMLScriptElement = document.createElement('script');\n          loaderScript.type = 'text/javascript';\n          loaderScript.src = `${baseUrl}/monaco/vs/loader.js`;\n          loaderScript.addEventListener('load', onGotAmdLoader);\n          document.body.appendChild(loaderScript);\n        } else {\n          onGotAmdLoader();\n        }\n      });\n    }\n  }\n\n  ngOnDestroy() {\n    // if (this._windowResizeSubscription) {\n    //   this._windowResizeSubscription.unsubscribe();\n    // }\n    if (this._editor) {\n      this._editor.dispose();\n      this._editor = undefined;\n    }\n  }\n\n  protected initMonaco(options: any): void {\n    console.log(\"Init the custom monaco code editor.\");\n\n    // const hasModel = !!options.model;\n    const hasModel = false;\n\n    // if (hasModel) {\n    //   options.model = monaco.editor.createModel(options.model.value, options.model.language, options.model.uri);\n    // }\n    \n    this._editor = monaco.editor.create(this._editorComponent.nativeElement, options);\n\n    if (!hasModel) {\n      this._editor.setValue(this._value);\n    }\n\n    // monaco editor -> outside component\n    this._editor.onDidChangeModelContent((e: any) => this.onChangeModelContentHandler(e));\n\n    this._editor.onDidBlurEditorText((e: any) => this.onBlurEditorTextHandler(e));\n\n    // refresh layout on resize event.\n    // if (this._windowResizeSubscription) {\n    //   this._windowResizeSubscription.unsubscribe();\n    // }\n    // this._windowResizeSubscription = fromEvent(window, 'resize').subscribe(() => this._editor.layout());\n\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onInit,\n      target: this,\n      editor: this._editor\n    });\n  }\n\n  onChangeModelContentHandler(e){\n    const _value = this._editor.getValue();\n    \n    // monaco editor -> outside component\n    // https://github.com/JTangming/tm/issues/4 ngZoneè¯¦è§£\n    this.zone.run(() => this.value = _value);// value is not propagated to parent when executing outside zone.\n    // console.log(\"write from the monaco:\" + this._value);\n  }\n\n  onBlurEditorTextHandler(e){\n\n    this.onTouchedHandler();\n  }\n\n  private _value: string = '';\n\n  //get accessor\n  get value(): any {\n      return this._value;\n  };\n\n  //set accessor including call the onchange callback\n  set value(v: any) {\n    if (v !== this.value) {// æ³¨æè¿ç§åæ³ï¼å¼å¾å­¦ä¹ \n      this._value = v;\n    }\n\n    this.onChangeHandler(this.value);//å¨å±æ§ä¿®é¥°å¨éè°ç¨onchangeHandleræ¹æ³\n  }\n\n  localEditor(){//Demo: outside component -> monaco editor\n    this.writeValue('test');\n  }\n\n  // èªå®ä¹è¾å¥æ§ä»¶:3.2 implements ControlValueAccesso\n\n  // outside component -> monaco editor\n  \n  //From ControlValueAccessor interface\n  writeValue(value: any) {\n    this.value = value || '';\n\n    // Fix for value change while dispose in process.\n    setTimeout(() => {\n      if (this._editor /*&& !this.options.model*/) {\n        this._editor.setValue(this._value);\n        // console.log(\"write to the editor:\" + this._value);\n      }\n    });\n  }\n\n  //From ControlValueAccessor interface\n  registerOnChange(fn: any) {\n    this.onChangeHandler(this);\n  }\n\n  //From ControlValueAccessor interface\n  registerOnTouched(fn: any) {\n    this.onTouchedHandler();\n  }\n  \n  //ControlValueAccessoræä¾çäºä»¶åè°\n  onChangeHandler = (_: any) => { //Propagate Change to outside\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onChange,\n      target: this,\n      data: _\n    });\n  };\n\n  //ControlValueAccessoræä¾çäºä»¶åè°\n  onTouchedHandler = () => {\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onTouched,\n      target: this\n    });\n  };\n}","import { CommonModule } from '@angular/common';\n\nimport { ModuleWithProviders, NgModule } from '@angular/core';\nimport { ANGULAR_MONACO_EDITOR_CONFIG, AngularMonacoEditorConfig } from './config';\nimport { AngularMonacoEditorComponent } from './angular-monaco-editor/angular-monaco-editor.component';\n\n@NgModule({\n  imports: [\n    CommonModule\n  ],\n  declarations: [\n    AngularMonacoEditorComponent\n  ],\n  exports: [\n    AngularMonacoEditorComponent\n  ],\n  providers: [\n  ]\n})\n\nexport class AngularMonacoEditorModule {\n  public static forRoot(config: AngularMonacoEditorConfig = {}): ModuleWithProviders {\n    return {\n      ngModule: AngularMonacoEditorModule,\n      providers: [\n        { provide: ANGULAR_MONACO_EDITOR_CONFIG, useValue: config }\n      ]\n    };\n  }\n}\n"],"names":["InjectionToken","assign","Injectable","NG_VALUE_ACCESSOR","forwardRef","EventEmitter","pick","Component","NgZone","Inject","ViewChild","Output","Input","NgModule","CommonModule"],"mappings":"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"}

@@ -1,2 +0,2 @@

!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("lodash"),require("@angular/forms"),require("@angular/common")):"function"==typeof define&&define.amd?define("angular-monaco-editor",["exports","@angular/core","lodash","@angular/forms","@angular/common"],t):t(e["angular-monaco-editor"]={},e.ng.core,null,e.ng.forms,e.ng.common)}(this,function(e,r,a,t,o){"use strict";var n,i=new r.InjectionToken("ANGULAR_MONACO_EDITOR_CONFIG"),s={onInit:"onInit",onChange:"onChange",onTouched:"onTouched"},d=function(){function e(){this.eventNames=Object.keys(s),this._events={}}return e.prototype.addEvent=function(e){a.assign(this._events,e)},e.prototype.fireEvent=function(e){this._events[e.eventName].emit(e)},e.decorators=[{type:r.Injectable}],e}(),u=!1,c={provide:t.NG_VALUE_ACCESSOR,useExisting:r.forwardRef(function(){return p}),multi:!0},p=function(){function e(e,t,o){var n=this;this.zone=e,this.config=t,this.codeEditorEventService=o,this._value="",this.onChangeHandler=function(e){n.codeEditorEventService.fireEvent({eventName:s.onChange,target:n,data:e})},this.onTouchedHandler=function(){n.codeEditorEventService.fireEvent({eventName:s.onTouched,target:n})};var i=this;o.eventNames.forEach(function(e){i[e]=new r.EventEmitter;var t=a.pick(i,e);o.addEvent(t)})}return Object.defineProperty(e.prototype,"options",{get:function(){return this._options},set:function(e){this._options=Object.assign({},this.config.defaultOptions,e),this._editor&&(this._editor.dispose(),this.initMonaco(e))},enumerable:!0,configurable:!0}),e.prototype.ngAfterViewInit=function(){var i=this;u?n.then(function(){i.initMonaco(i.options)}):(u=!0,n=new Promise(function(e){var t=i.config.baseUrl||"/assets",o=function(){window.require.config({paths:{vs:t+"/monaco/vs"}}),window.require(["vs/editor/editor.main"],function(){"function"==typeof i.config.onMonacoLoad&&i.config.onMonacoLoad(),i.initMonaco(i.options),e()})};if(window.require)o();else{var n=document.createElement("script");n.type="application/javascript",n.src=t+"/monaco/vs/loader.js",n.addEventListener("load",o),document.body.appendChild(n)}}))},e.prototype.ngOnDestroy=function(){this._editor&&(this._editor.dispose(),this._editor=undefined)},e.prototype.initMonaco=function(e){var t=this;console.log("Init the custom monaco code editor."),this._editor=monaco.editor.create(this._editorComponent.nativeElement,e),this._editor.setValue(this._value),this._editor.onDidChangeModelContent(function(e){return t.onChangeModelContentHandler(e)}),this._editor.onDidBlurEditorText(function(e){return t.onBlurEditorTextHandler(e)}),this.codeEditorEventService.fireEvent({eventName:s.onInit,target:this,editor:this._editor})},e.prototype.onChangeModelContentHandler=function(e){var t=this,o=this._editor.getValue();this.zone.run(function(){return t.value=o})},e.prototype.onBlurEditorTextHandler=function(e){this.onTouchedHandler()},Object.defineProperty(e.prototype,"value",{get:function(){return this._value},set:function(e){e!==this.value&&(this._value=e),this.onChangeHandler(this.value)},enumerable:!0,configurable:!0}),e.prototype.localEditor=function(){this.writeValue("test")},e.prototype.writeValue=function(e){var t=this;this.value=e||"",setTimeout(function(){t._editor&&t._editor.setValue(t._value)})},e.prototype.registerOnChange=function(e){this.onChangeHandler(this)},e.prototype.registerOnTouched=function(e){this.onTouchedHandler()},e.decorators=[{type:r.Component,args:[{selector:"angular-monaco-editor",template:'<div class="editor" #codeEditor></div>',styles:[":host{display:block;height:200px}.editor{width:100%;height:98%}"],providers:[c,d]}]}],e.ctorParameters=function(){return[{type:r.NgZone},{type:undefined,decorators:[{type:r.Inject,args:[i]}]},{type:d}]},e.propDecorators={_editorComponent:[{type:r.ViewChild,args:["codeEditor"]}],onInit:[{type:r.Output}],onChange:[{type:r.Output}],onTouched:[{type:r.Output}],options:[{type:r.Input,args:["options"]}]},e}(),h=function(){function t(){}return t.forRoot=function(e){return void 0===e&&(e={}),{ngModule:t,providers:[{provide:i,useValue:e}]}},t.decorators=[{type:r.NgModule,args:[{imports:[o.CommonModule],declarations:[p],exports:[p],providers:[]}]}],t}();e.AngularMonacoEditorModule=h,e.ANGULAR_MONACO_EDITOR_CONFIG=i,e.ɵb=p,e.ɵa=c,e.ɵc=d,Object.defineProperty(e,"__esModule",{value:!0})});
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("lodash"),require("@angular/forms"),require("@angular/common")):"function"==typeof define&&define.amd?define("angular-monaco-editor",["exports","@angular/core","lodash","@angular/forms","@angular/common"],t):t(e["angular-monaco-editor"]={},e.ng.core,null,e.ng.forms,e.ng.common)}(this,function(e,r,a,t,o){"use strict";var n,i=new r.InjectionToken("ANGULAR_MONACO_EDITOR_CONFIG"),s={onInit:"onInit",onChange:"onChange",onTouched:"onTouched"},d=function(){function e(){this.eventNames=Object.keys(s),this._events={}}return e.prototype.addEvent=function(e){a.assign(this._events,e)},e.prototype.fireEvent=function(e){this._events[e.eventName].emit(e)},e.decorators=[{type:r.Injectable}],e}(),u=!1,c={provide:t.NG_VALUE_ACCESSOR,useExisting:r.forwardRef(function(){return p}),multi:!0},p=function(){function e(e,t,o){var n=this;this.zone=e,this.config=t,this.codeEditorEventService=o,this._value="",this.onChangeHandler=function(e){n.codeEditorEventService.fireEvent({eventName:s.onChange,target:n,data:e})},this.onTouchedHandler=function(){n.codeEditorEventService.fireEvent({eventName:s.onTouched,target:n})};var i=this;o.eventNames.forEach(function(e){i[e]=new r.EventEmitter;var t=a.pick(i,e);o.addEvent(t)})}return Object.defineProperty(e.prototype,"options",{get:function(){return this._options},set:function(e){this._options=Object.assign({},this.config.defaultOptions,e),this._editor&&(this._editor.dispose(),this.initMonaco(e))},enumerable:!0,configurable:!0}),e.prototype.ngAfterViewInit=function(){var i=this;u?n.then(function(){i.initMonaco(i.options)}):(u=!0,n=new Promise(function(e){var t=i.config.baseUrl||"/assets",o=function(){window.require.config({paths:{vs:t+"/monaco/vs"}}),window.require(["vs/editor/editor.main"],function(){"function"==typeof i.config.onMonacoLoad&&i.config.onMonacoLoad(),i.initMonaco(i.options),e()})};if(window.require)o();else{var n=document.createElement("script");n.type="text/javascript",n.src=t+"/monaco/vs/loader.js",n.addEventListener("load",o),document.body.appendChild(n)}}))},e.prototype.ngOnDestroy=function(){this._editor&&(this._editor.dispose(),this._editor=undefined)},e.prototype.initMonaco=function(e){var t=this;console.log("Init the custom monaco code editor."),this._editor=monaco.editor.create(this._editorComponent.nativeElement,e),this._editor.setValue(this._value),this._editor.onDidChangeModelContent(function(e){return t.onChangeModelContentHandler(e)}),this._editor.onDidBlurEditorText(function(e){return t.onBlurEditorTextHandler(e)}),this.codeEditorEventService.fireEvent({eventName:s.onInit,target:this,editor:this._editor})},e.prototype.onChangeModelContentHandler=function(e){var t=this,o=this._editor.getValue();this.zone.run(function(){return t.value=o})},e.prototype.onBlurEditorTextHandler=function(e){this.onTouchedHandler()},Object.defineProperty(e.prototype,"value",{get:function(){return this._value},set:function(e){e!==this.value&&(this._value=e),this.onChangeHandler(this.value)},enumerable:!0,configurable:!0}),e.prototype.localEditor=function(){this.writeValue("test")},e.prototype.writeValue=function(e){var t=this;this.value=e||"",setTimeout(function(){t._editor&&t._editor.setValue(t._value)})},e.prototype.registerOnChange=function(e){this.onChangeHandler(this)},e.prototype.registerOnTouched=function(e){this.onTouchedHandler()},e.decorators=[{type:r.Component,args:[{selector:"angular-monaco-editor",template:'<div class="editor" #codeEditor></div>',styles:[":host{display:block;height:200px}.editor{width:100%;height:98%}"],providers:[c,d]}]}],e.ctorParameters=function(){return[{type:r.NgZone},{type:undefined,decorators:[{type:r.Inject,args:[i]}]},{type:d}]},e.propDecorators={_editorComponent:[{type:r.ViewChild,args:["codeEditor"]}],onInit:[{type:r.Output}],onChange:[{type:r.Output}],onTouched:[{type:r.Output}],options:[{type:r.Input,args:["options"]}]},e}(),h=function(){function t(){}return t.forRoot=function(e){return void 0===e&&(e={}),{ngModule:t,providers:[{provide:i,useValue:e}]}},t.decorators=[{type:r.NgModule,args:[{imports:[o.CommonModule],declarations:[p],exports:[p],providers:[]}]}],t}();e.AngularMonacoEditorModule=h,e.ANGULAR_MONACO_EDITOR_CONFIG=i,e.ɵb=p,e.ɵa=c,e.ɵc=d,Object.defineProperty(e,"__esModule",{value:!0})});
//# sourceMappingURL=angular-monaco-editor.umd.min.js.map

@@ -112,3 +112,3 @@ /**

const /** @type {?} */ loaderScript = document.createElement('script');
loaderScript.type = 'application/javascript';
loaderScript.type = 'text/javascript';
loaderScript.src = `${baseUrl}/monaco/vs/loader.js`;

@@ -295,2 +295,2 @@ loaderScript.addEventListener('load', onGotAmdLoader);

//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-monaco-editor.component.js","sourceRoot":"ng://angular-monaco-editor/","sources":["lib/editor/angular-monaco-editor/angular-monaco-editor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, AfterViewInit, ElementRef, EventEmitter, Input, OnDestroy, Output, ViewChild } from '@angular/core';\nimport { forwardRef, Inject, NgZone } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { pick } from 'lodash';\n\nimport { ANGULAR_MONACO_EDITOR_CONFIG, AngularMonacoEditorConfig } from '../config';\nimport { CodeEditorEventService } from '../services/code-editor.event.service';\nimport { CODE_EDITOR_EVENTS } from '../constants/events';\n\ndeclare const monaco: any;\n\nlet loadedMonaco: boolean = false;\nlet loadPromise: Promise<void>;\n\n// 自定义输入控件:1.封装ControlValueAccessor\n// https://code-examples.net/zh-CN/q/2154761\nexport const CODE_EDITOR_INPUT_VALUE_ACCESSOR: any = {\n  // https://blog.csdn.net/wangdan_2013/article/details/81314959\n  provide: NG_VALUE_ACCESSOR,//\n  useExisting: forwardRef(() => AngularMonacoEditorComponent),//\n  multi: true//\n};\n\n@Component({\n  selector: 'angular-monaco-editor',\n  template: `<div class=\"editor\" #codeEditor></div>`,\n  styles: [`:host{display:block;height:200px}.editor{width:100%;height:98%}`],\n  // 自定义输入控件:2.引入依赖服务ControlValueAccessor\n  providers: [CODE_EDITOR_INPUT_VALUE_ACCESSOR, CodeEditorEventService]\n})\n\n// 自定义输入控件 <-> Monaco Edtor\n\n// 自定义输入控件:3.1 implements ControlValueAccessor \nexport class AngularMonacoEditorComponent implements AfterViewInit, ControlValueAccessor, OnDestroy{\n\n  protected _editor: any;\n  private _options: any;\n  // protected _windowResizeSubscription: Subscription;\n\n  @ViewChild('codeEditor') _editorComponent: ElementRef; //动态添加代码编辑器\n  \n  @Output() onInit;\n  @Output() onChange;\n  @Output() onTouched;\n\n  @Input('options')\n  set options(options: any) {\n    // 默认options(this.config.defaultOptions) + 自定义options(options)\n    this._options = Object.assign({}, this.config.defaultOptions, options);\n    if (this._editor) {\n      this._editor.dispose();\n      this.initMonaco(options);\n    }\n  }\n  get options(): any {\n    return this._options;\n  }\n\n  // @Input('model')\n  // set model(model: AngularEditorModel) {\n  //   this.options.model = model;\n  //   if (this._editor) {\n  //     this._editor.dispose();\n  //     this.initMonaco(this.options);\n  //   }\n  // }\n\n  // 注入AngularMonacoEditorConfig，在创建Editor实例时设置config\n  constructor(private zone: NgZone, @Inject(ANGULAR_MONACO_EDITOR_CONFIG) private config: AngularMonacoEditorConfig, private codeEditorEventService: CodeEditorEventService) {\n\n    // 初始化自定义事件\n    const self = this;\n    codeEditorEventService.eventNames.forEach((name) => {\n      // 创建自定义事件，此处作用等效于: @Output() onInit = new EventEmitter<any>() \n      self[name] = new EventEmitter<any>();\n      const eventPair = pick(self, name);\n      codeEditorEventService.addEvent(eventPair);\n    });\n\n  }\n\n  ngAfterViewInit(): void {\n    if (loadedMonaco) {\n      // Wait until monaco editor is available\n      loadPromise.then(() => {\n        this.initMonaco(this.options);\n      });\n    } else {\n      loadedMonaco = true;\n      loadPromise = new Promise<void>((resolve: any) => {\n        const baseUrl = this.config.baseUrl || '/assets';\n        // if (typeof((<any>window).monaco) === 'object') {\n        //   resolve();\n        //   return;\n        // }\n        const onGotAmdLoader: any = () => {\n          // Load monaco\n          (<any>window).require.config({ paths: { 'vs': `${baseUrl}/monaco/vs` } });\n          (<any>window).require(['vs/editor/editor.main'], () => {\n            if (typeof this.config.onMonacoLoad === 'function') {\n              this.config.onMonacoLoad();\n            }\n            this.initMonaco(this.options);\n            resolve();\n          });\n        };\n\n        // Load AMD loader if necessary\n        if (!(<any>window).require) {\n          const loaderScript: HTMLScriptElement = document.createElement('script');\n          loaderScript.type = 'application/javascript';\n          loaderScript.src = `${baseUrl}/monaco/vs/loader.js`;\n          loaderScript.addEventListener('load', onGotAmdLoader);\n          document.body.appendChild(loaderScript);\n        } else {\n          onGotAmdLoader();\n        }\n      });\n    }\n  }\n\n  ngOnDestroy() {\n    // if (this._windowResizeSubscription) {\n    //   this._windowResizeSubscription.unsubscribe();\n    // }\n    if (this._editor) {\n      this._editor.dispose();\n      this._editor = undefined;\n    }\n  }\n\n  protected initMonaco(options: any): void {\n    console.log(\"Init the custom monaco code editor.\");\n\n    // const hasModel = !!options.model;\n    const hasModel = false;\n\n    // if (hasModel) {\n    //   options.model = monaco.editor.createModel(options.model.value, options.model.language, options.model.uri);\n    // }\n    \n    this._editor = monaco.editor.create(this._editorComponent.nativeElement, options);\n\n    if (!hasModel) {\n      this._editor.setValue(this._value);\n    }\n\n    // monaco editor -> outside component\n    this._editor.onDidChangeModelContent((e: any) => this.onChangeModelContentHandler(e));\n\n    this._editor.onDidBlurEditorText((e: any) => this.onBlurEditorTextHandler(e));\n\n    // refresh layout on resize event.\n    // if (this._windowResizeSubscription) {\n    //   this._windowResizeSubscription.unsubscribe();\n    // }\n    // this._windowResizeSubscription = fromEvent(window, 'resize').subscribe(() => this._editor.layout());\n\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onInit,\n      target: this,\n      editor: this._editor\n    });\n  }\n\n  onChangeModelContentHandler(e){\n    const _value = this._editor.getValue();\n    \n    // monaco editor -> outside component\n    // https://github.com/JTangming/tm/issues/4 ngZone详解\n    this.zone.run(() => this.value = _value);// value is not propagated to parent when executing outside zone.\n    // console.log(\"write from the monaco:\" + this._value);\n  }\n\n  onBlurEditorTextHandler(e){\n\n    this.onTouchedHandler();\n  }\n\n  private _value: string = '';\n\n  //get accessor\n  get value(): any {\n      return this._value;\n  };\n\n  //set accessor including call the onchange callback\n  set value(v: any) {\n    if (v !== this.value) {// 注意这种写法，值得学习\n      this._value = v;\n    }\n\n    this.onChangeHandler(this.value);//在属性修饰器里调用onchangeHandler方法\n  }\n\n  localEditor(){//Demo: outside component -> monaco editor\n    this.writeValue('test');\n  }\n\n  // 自定义输入控件:3.2 implements ControlValueAccesso\n\n  // outside component -> monaco editor\n  \n  //From ControlValueAccessor interface\n  writeValue(value: any) {\n    this.value = value || '';\n\n    // Fix for value change while dispose in process.\n    setTimeout(() => {\n      if (this._editor /*&& !this.options.model*/) {\n        this._editor.setValue(this._value);\n        // console.log(\"write to the editor:\" + this._value);\n      }\n    });\n  }\n\n  //From ControlValueAccessor interface\n  registerOnChange(fn: any) {\n    this.onChangeHandler(this);\n  }\n\n  //From ControlValueAccessor interface\n  registerOnTouched(fn: any) {\n    this.onTouchedHandler();\n  }\n  \n  //ControlValueAccessor提供的事件回调\n  onChangeHandler = (_: any) => { //Propagate Change to outside\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onChange,\n      target: this,\n      data: _\n    });\n  };\n\n  //ControlValueAccessor提供的事件回调\n  onTouchedHandler = () => {\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onTouched,\n      target: this\n    });\n  };\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-monaco-editor.component.js","sourceRoot":"ng://angular-monaco-editor/","sources":["lib/editor/angular-monaco-editor/angular-monaco-editor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, AfterViewInit, ElementRef, EventEmitter, Input, OnDestroy, Output, ViewChild } from '@angular/core';\nimport { forwardRef, Inject, NgZone } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { pick } from 'lodash';\n\nimport { ANGULAR_MONACO_EDITOR_CONFIG, AngularMonacoEditorConfig } from '../config';\nimport { CodeEditorEventService } from '../services/code-editor.event.service';\nimport { CODE_EDITOR_EVENTS } from '../constants/events';\n\ndeclare const monaco: any;\n\nlet loadedMonaco: boolean = false;\nlet loadPromise: Promise<void>;\n\n// 自定义输入控件:1.封装ControlValueAccessor\n// https://code-examples.net/zh-CN/q/2154761\nexport const CODE_EDITOR_INPUT_VALUE_ACCESSOR: any = {\n  // https://blog.csdn.net/wangdan_2013/article/details/81314959\n  provide: NG_VALUE_ACCESSOR,//\n  useExisting: forwardRef(() => AngularMonacoEditorComponent),//\n  multi: true//\n};\n\n@Component({\n  selector: 'angular-monaco-editor',\n  template: `<div class=\"editor\" #codeEditor></div>`,\n  styles: [`:host{display:block;height:200px}.editor{width:100%;height:98%}`],\n  // 自定义输入控件:2.引入依赖服务ControlValueAccessor\n  providers: [CODE_EDITOR_INPUT_VALUE_ACCESSOR, CodeEditorEventService]\n})\n\n// 自定义输入控件 <-> Monaco Edtor\n\n// 自定义输入控件:3.1 implements ControlValueAccessor \nexport class AngularMonacoEditorComponent implements AfterViewInit, ControlValueAccessor, OnDestroy{\n\n  protected _editor: any;\n  private _options: any;\n  // protected _windowResizeSubscription: Subscription;\n\n  @ViewChild('codeEditor') _editorComponent: ElementRef; //动态添加代码编辑器\n  \n  @Output() onInit;\n  @Output() onChange;\n  @Output() onTouched;\n\n  @Input('options')\n  set options(options: any) {\n    // 默认options(this.config.defaultOptions) + 自定义options(options)\n    this._options = Object.assign({}, this.config.defaultOptions, options);\n    if (this._editor) {\n      this._editor.dispose();\n      this.initMonaco(options);\n    }\n  }\n  get options(): any {\n    return this._options;\n  }\n\n  // @Input('model')\n  // set model(model: AngularEditorModel) {\n  //   this.options.model = model;\n  //   if (this._editor) {\n  //     this._editor.dispose();\n  //     this.initMonaco(this.options);\n  //   }\n  // }\n\n  // 注入AngularMonacoEditorConfig，在创建Editor实例时设置config\n  constructor(private zone: NgZone, @Inject(ANGULAR_MONACO_EDITOR_CONFIG) private config: AngularMonacoEditorConfig, private codeEditorEventService: CodeEditorEventService) {\n\n    // 初始化自定义事件\n    const self = this;\n    codeEditorEventService.eventNames.forEach((name) => {\n      // 创建自定义事件，此处作用等效于: @Output() onInit = new EventEmitter<any>() \n      self[name] = new EventEmitter<any>();\n      const eventPair = pick(self, name);\n      codeEditorEventService.addEvent(eventPair);\n    });\n\n  }\n\n  ngAfterViewInit(): void {\n    if (loadedMonaco) {\n      // Wait until monaco editor is available\n      loadPromise.then(() => {\n        this.initMonaco(this.options);\n      });\n    } else {\n      loadedMonaco = true;\n      loadPromise = new Promise<void>((resolve: any) => {\n        const baseUrl = this.config.baseUrl || '/assets';\n        // if (typeof((<any>window).monaco) === 'object') {\n        //   resolve();\n        //   return;\n        // }\n        const onGotAmdLoader: any = () => {\n          // Load monaco\n          (<any>window).require.config({ paths: { 'vs': `${baseUrl}/monaco/vs` } });\n          (<any>window).require(['vs/editor/editor.main'], () => {\n            if (typeof this.config.onMonacoLoad === 'function') {\n              this.config.onMonacoLoad();\n            }\n            this.initMonaco(this.options);\n            resolve();\n          });\n        };\n\n        // Load AMD loader if necessary\n        if (!(<any>window).require) {\n          const loaderScript: HTMLScriptElement = document.createElement('script');\n          loaderScript.type = 'text/javascript';\n          loaderScript.src = `${baseUrl}/monaco/vs/loader.js`;\n          loaderScript.addEventListener('load', onGotAmdLoader);\n          document.body.appendChild(loaderScript);\n        } else {\n          onGotAmdLoader();\n        }\n      });\n    }\n  }\n\n  ngOnDestroy() {\n    // if (this._windowResizeSubscription) {\n    //   this._windowResizeSubscription.unsubscribe();\n    // }\n    if (this._editor) {\n      this._editor.dispose();\n      this._editor = undefined;\n    }\n  }\n\n  protected initMonaco(options: any): void {\n    console.log(\"Init the custom monaco code editor.\");\n\n    // const hasModel = !!options.model;\n    const hasModel = false;\n\n    // if (hasModel) {\n    //   options.model = monaco.editor.createModel(options.model.value, options.model.language, options.model.uri);\n    // }\n    \n    this._editor = monaco.editor.create(this._editorComponent.nativeElement, options);\n\n    if (!hasModel) {\n      this._editor.setValue(this._value);\n    }\n\n    // monaco editor -> outside component\n    this._editor.onDidChangeModelContent((e: any) => this.onChangeModelContentHandler(e));\n\n    this._editor.onDidBlurEditorText((e: any) => this.onBlurEditorTextHandler(e));\n\n    // refresh layout on resize event.\n    // if (this._windowResizeSubscription) {\n    //   this._windowResizeSubscription.unsubscribe();\n    // }\n    // this._windowResizeSubscription = fromEvent(window, 'resize').subscribe(() => this._editor.layout());\n\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onInit,\n      target: this,\n      editor: this._editor\n    });\n  }\n\n  onChangeModelContentHandler(e){\n    const _value = this._editor.getValue();\n    \n    // monaco editor -> outside component\n    // https://github.com/JTangming/tm/issues/4 ngZone详解\n    this.zone.run(() => this.value = _value);// value is not propagated to parent when executing outside zone.\n    // console.log(\"write from the monaco:\" + this._value);\n  }\n\n  onBlurEditorTextHandler(e){\n\n    this.onTouchedHandler();\n  }\n\n  private _value: string = '';\n\n  //get accessor\n  get value(): any {\n      return this._value;\n  };\n\n  //set accessor including call the onchange callback\n  set value(v: any) {\n    if (v !== this.value) {// 注意这种写法，值得学习\n      this._value = v;\n    }\n\n    this.onChangeHandler(this.value);//在属性修饰器里调用onchangeHandler方法\n  }\n\n  localEditor(){//Demo: outside component -> monaco editor\n    this.writeValue('test');\n  }\n\n  // 自定义输入控件:3.2 implements ControlValueAccesso\n\n  // outside component -> monaco editor\n  \n  //From ControlValueAccessor interface\n  writeValue(value: any) {\n    this.value = value || '';\n\n    // Fix for value change while dispose in process.\n    setTimeout(() => {\n      if (this._editor /*&& !this.options.model*/) {\n        this._editor.setValue(this._value);\n        // console.log(\"write to the editor:\" + this._value);\n      }\n    });\n  }\n\n  //From ControlValueAccessor interface\n  registerOnChange(fn: any) {\n    this.onChangeHandler(this);\n  }\n\n  //From ControlValueAccessor interface\n  registerOnTouched(fn: any) {\n    this.onTouchedHandler();\n  }\n  \n  //ControlValueAccessor提供的事件回调\n  onChangeHandler = (_: any) => { //Propagate Change to outside\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onChange,\n      target: this,\n      data: _\n    });\n  };\n\n  //ControlValueAccessor提供的事件回调\n  onTouchedHandler = () => {\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onTouched,\n      target: this\n    });\n  };\n}"]}

@@ -123,3 +123,3 @@ /**

var /** @type {?} */ loaderScript = document.createElement('script');
loaderScript.type = 'application/javascript';
loaderScript.type = 'text/javascript';
loaderScript.src = baseUrl + "/monaco/vs/loader.js";

@@ -352,2 +352,2 @@ loaderScript.addEventListener('load', onGotAmdLoader);

//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-monaco-editor.component.js","sourceRoot":"ng://angular-monaco-editor/","sources":["lib/editor/angular-monaco-editor/angular-monaco-editor.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAAE,SAAS,EAAyB,UAAU,EAAE,YAAY,EAAE,KAAK,EAAa,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAChI,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC3D,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAEzE,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAE9B,OAAO,EAAE,4BAA4B,EAA6B,MAAM,WAAW,CAAC;AACpF,OAAO,EAAE,sBAAsB,EAAE,MAAM,uCAAuC,CAAC;AAC/E,OAAO,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAIzD,qBAAI,YAAY,GAAY,KAAK,CAAC;AAClC,qBAAI,WAA0B,CAAC;;;AAI/B,MAAM,CAAC,qBAAM,gCAAgC,GAAQ;;IAEnD,OAAO,EAAE,iBAAiB;;IAC1B,WAAW,EAAE,UAAU,CAAC,cAAM,OAAA,4BAA4B,EAA5B,CAA4B,CAAC;;IAC3D,KAAK,EAAE,IAAI;CACZ,CAAC;;IAsCA,kBAAkB;IAClB,yCAAyC;IACzC,gCAAgC;IAChC,wBAAwB;IACxB,8BAA8B;IAC9B,qCAAqC;IACrC,MAAM;IACN,IAAI;IAEJ,mDAAmD;IACnD,sCAAoB,IAAY,EAAgD,QAA2C,sBAA8C;QAAzK,iBAWC;QAXmB,SAAI,GAAJ,IAAI,CAAQ;QAAgD,WAAM,GAAN,MAAM;QAAqC,2BAAsB,GAAtB,sBAAsB,CAAwB;sBA+GhJ,EAAE;;+BAgDT,UAAC,CAAM;;YACvB,KAAI,CAAC,sBAAsB,CAAC,SAAS,CAAC;gBACpC,SAAS,EAAE,kBAAkB,CAAC,QAAQ;gBACtC,MAAM,EAAE,KAAI;gBACZ,IAAI,EAAE,CAAC;aACR,CAAC,CAAC;SACJ;;gCAGkB;YACjB,KAAI,CAAC,sBAAsB,CAAC,SAAS,CAAC;gBACpC,SAAS,EAAE,kBAAkB,CAAC,SAAS;gBACvC,MAAM,EAAE,KAAI;aACb,CAAC,CAAC;SACJ;;QA1KC,qBAAM,IAAI,GAAG,IAAI,CAAC;QAClB,sBAAsB,CAAC,UAAU,CAAC,OAAO,CAAC,UAAC,IAAI;;YAE7C,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,YAAY,EAAO,CAAC;YACrC,qBAAM,SAAS,GAAG,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YACnC,sBAAsB,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;SAC5C,CAAC,CAAC;KAEJ;0BAjCG,iDAAO;;;;QAQX;YACE,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC;SACtB;;;;;kBAVW,OAAY;;YAEtB,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC;YACvE,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;gBACjB,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;gBACvB,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;aAC1B;;;;;;;;IA6BH,sDAAe;;;IAAf;QAAA,iBAsCC;QArCC,EAAE,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC;;YAEjB,WAAW,CAAC,IAAI,CAAC;gBACf,KAAI,CAAC,UAAU,CAAC,KAAI,CAAC,OAAO,CAAC,CAAC;aAC/B,CAAC,CAAC;SACJ;QAAC,IAAI,CAAC,CAAC;YACN,YAAY,GAAG,IAAI,CAAC;YACpB,WAAW,GAAG,IAAI,OAAO,CAAO,UAAC,OAAY;gBAC3C,qBAAM,OAAO,GAAG,KAAI,CAAC,MAAM,CAAC,OAAO,IAAI,SAAS,CAAC;;;;;gBAKjD,qBAAM,cAAc,GAAQ;;oBAE1B,mBAAM,MAAM,EAAC,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAK,OAAO,eAAY,EAAE,EAAE,CAAC,CAAC;oBAC1E,mBAAM,MAAM,EAAC,CAAC,OAAO,CAAC,CAAC,uBAAuB,CAAC,EAAE;wBAC/C,EAAE,CAAC,CAAC,OAAO,KAAI,CAAC,MAAM,CAAC,YAAY,KAAK,UAAU,CAAC,CAAC,CAAC;4BACnD,KAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;yBAC5B;wBACD,KAAI,CAAC,UAAU,CAAC,KAAI,CAAC,OAAO,CAAC,CAAC;wBAC9B,OAAO,EAAE,CAAC;qBACX,CAAC,CAAC;iBACJ,CAAC;;gBAGF,EAAE,CAAC,CAAC,CAAC,mBAAM,MAAM,EAAC,CAAC,OAAO,CAAC,CAAC,CAAC;oBAC3B,qBAAM,YAAY,GAAsB,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;oBACzE,YAAY,CAAC,IAAI,GAAG,wBAAwB,CAAC;oBAC7C,YAAY,CAAC,GAAG,GAAM,OAAO,yBAAsB,CAAC;oBACpD,YAAY,CAAC,gBAAgB,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;oBACtD,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;iBACzC;gBAAC,IAAI,CAAC,CAAC;oBACN,cAAc,EAAE,CAAC;iBAClB;aACF,CAAC,CAAC;SACJ;KACF;;;;IAED,kDAAW;;;IAAX;;;;QAIE,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;YACjB,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;YACvB,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;SAC1B;KACF;;;;;IAES,iDAAU;;;;IAApB,UAAqB,OAAY;QAAjC,iBAgCC;QA/BC,OAAO,CAAC,GAAG,CAAC,qCAAqC,CAAC,CAAC;;QAGnD,qBAAM,QAAQ,GAAG,KAAK,CAAC;;;;QAMvB,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QAElF,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;YACd,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SACpC;;QAGD,IAAI,CAAC,OAAO,CAAC,uBAAuB,CAAC,UAAC,CAAM,IAAK,OAAA,KAAI,CAAC,2BAA2B,CAAC,CAAC,CAAC,EAAnC,CAAmC,CAAC,CAAC;QAEtF,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,UAAC,CAAM,IAAK,OAAA,KAAI,CAAC,uBAAuB,CAAC,CAAC,CAAC,EAA/B,CAA+B,CAAC,CAAC;;;;;;QAQ9E,IAAI,CAAC,sBAAsB,CAAC,SAAS,CAAC;YACpC,SAAS,EAAE,kBAAkB,CAAC,MAAM;YACpC,MAAM,EAAE,IAAI;YACZ,MAAM,EAAE,IAAI,CAAC,OAAO;SACrB,CAAC,CAAC;KACJ;;;;;IAED,kEAA2B;;;;IAA3B,UAA4B,CAAC;QAA7B,iBAOC;QANC,qBAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;;;QAIvC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,cAAM,OAAA,KAAI,CAAC,KAAK,GAAG,MAAM,EAAnB,CAAmB,CAAC,CAAC;;KAE1C;;;;;IAED,8DAAuB;;;;IAAvB,UAAwB,CAAC;QAEvB,IAAI,CAAC,gBAAgB,EAAE,CAAC;KACzB;IAKD,sBAAI,+CAAK;QADT,cAAc;;;;QACd;YACI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC;SACtB;QAED,mDAAmD;;;;;QACnD,UAAU,CAAM;YACd,EAAE,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;;gBACrB,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;aACjB;YAED,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAClC;;;OATA;IAAA,CAAC;;;;IAWF,kDAAW;;;IAAX;;QACE,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;KACzB;IAED,6CAA6C;IAE7C,qCAAqC;IAErC,qCAAqC;;;;;IACrC,iDAAU;;;;IAAV,UAAW,KAAU;QAArB,iBAUC;QATC,IAAI,CAAC,KAAK,GAAG,KAAK,IAAI,EAAE,CAAC;;QAGzB,UAAU,CAAC;YACT,EAAE,CAAC,CAAC,KAAI,CAAC,OAAO,2BAA2B,CAAC,CAAC,CAAC;gBAC5C,KAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAI,CAAC,MAAM,CAAC,CAAC;;aAEpC;SACF,CAAC,CAAC;KACJ;IAED,qCAAqC;;;;;IACrC,uDAAgB;;;;IAAhB,UAAiB,EAAO;QACtB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;KAC5B;IAED,qCAAqC;;;;;IACrC,wDAAiB;;;;IAAjB,UAAkB,EAAO;QACvB,IAAI,CAAC,gBAAgB,EAAE,CAAC;KACzB;;gBA1MF,SAAS,SAAC;oBACT,QAAQ,EAAE,uBAAuB;oBACjC,QAAQ,EAAE,0CAAwC;oBAClD,MAAM,EAAE,CAAC,iEAAiE,CAAC;;oBAE3E,SAAS,EAAE,CAAC,gCAAgC,EAAE,sBAAsB,CAAC;iBACtE;;;;gBA7B4B,MAAM;gDAqEE,MAAM,SAAC,4BAA4B;gBA/D/D,sBAAsB;;;qCAkC5B,SAAS,SAAC,YAAY;2BAEtB,MAAM;6BACN,MAAM;8BACN,MAAM;4BAEN,KAAK,SAAC,SAAS;;uCA/ClB;;SAmCa,4BAA4B","sourcesContent":["import { Component, OnInit, AfterViewInit, ElementRef, EventEmitter, Input, OnDestroy, Output, ViewChild } from '@angular/core';\nimport { forwardRef, Inject, NgZone } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { pick } from 'lodash';\n\nimport { ANGULAR_MONACO_EDITOR_CONFIG, AngularMonacoEditorConfig } from '../config';\nimport { CodeEditorEventService } from '../services/code-editor.event.service';\nimport { CODE_EDITOR_EVENTS } from '../constants/events';\n\ndeclare const monaco: any;\n\nlet loadedMonaco: boolean = false;\nlet loadPromise: Promise<void>;\n\n// 自定义输入控件:1.封装ControlValueAccessor\n// https://code-examples.net/zh-CN/q/2154761\nexport const CODE_EDITOR_INPUT_VALUE_ACCESSOR: any = {\n  // https://blog.csdn.net/wangdan_2013/article/details/81314959\n  provide: NG_VALUE_ACCESSOR,//\n  useExisting: forwardRef(() => AngularMonacoEditorComponent),//\n  multi: true//\n};\n\n@Component({\n  selector: 'angular-monaco-editor',\n  template: `<div class=\"editor\" #codeEditor></div>`,\n  styles: [`:host{display:block;height:200px}.editor{width:100%;height:98%}`],\n  // 自定义输入控件:2.引入依赖服务ControlValueAccessor\n  providers: [CODE_EDITOR_INPUT_VALUE_ACCESSOR, CodeEditorEventService]\n})\n\n// 自定义输入控件 <-> Monaco Edtor\n\n// 自定义输入控件:3.1 implements ControlValueAccessor \nexport class AngularMonacoEditorComponent implements AfterViewInit, ControlValueAccessor, OnDestroy{\n\n  protected _editor: any;\n  private _options: any;\n  // protected _windowResizeSubscription: Subscription;\n\n  @ViewChild('codeEditor') _editorComponent: ElementRef; //动态添加代码编辑器\n  \n  @Output() onInit;\n  @Output() onChange;\n  @Output() onTouched;\n\n  @Input('options')\n  set options(options: any) {\n    // 默认options(this.config.defaultOptions) + 自定义options(options)\n    this._options = Object.assign({}, this.config.defaultOptions, options);\n    if (this._editor) {\n      this._editor.dispose();\n      this.initMonaco(options);\n    }\n  }\n  get options(): any {\n    return this._options;\n  }\n\n  // @Input('model')\n  // set model(model: AngularEditorModel) {\n  //   this.options.model = model;\n  //   if (this._editor) {\n  //     this._editor.dispose();\n  //     this.initMonaco(this.options);\n  //   }\n  // }\n\n  // 注入AngularMonacoEditorConfig，在创建Editor实例时设置config\n  constructor(private zone: NgZone, @Inject(ANGULAR_MONACO_EDITOR_CONFIG) private config: AngularMonacoEditorConfig, private codeEditorEventService: CodeEditorEventService) {\n\n    // 初始化自定义事件\n    const self = this;\n    codeEditorEventService.eventNames.forEach((name) => {\n      // 创建自定义事件，此处作用等效于: @Output() onInit = new EventEmitter<any>() \n      self[name] = new EventEmitter<any>();\n      const eventPair = pick(self, name);\n      codeEditorEventService.addEvent(eventPair);\n    });\n\n  }\n\n  ngAfterViewInit(): void {\n    if (loadedMonaco) {\n      // Wait until monaco editor is available\n      loadPromise.then(() => {\n        this.initMonaco(this.options);\n      });\n    } else {\n      loadedMonaco = true;\n      loadPromise = new Promise<void>((resolve: any) => {\n        const baseUrl = this.config.baseUrl || '/assets';\n        // if (typeof((<any>window).monaco) === 'object') {\n        //   resolve();\n        //   return;\n        // }\n        const onGotAmdLoader: any = () => {\n          // Load monaco\n          (<any>window).require.config({ paths: { 'vs': `${baseUrl}/monaco/vs` } });\n          (<any>window).require(['vs/editor/editor.main'], () => {\n            if (typeof this.config.onMonacoLoad === 'function') {\n              this.config.onMonacoLoad();\n            }\n            this.initMonaco(this.options);\n            resolve();\n          });\n        };\n\n        // Load AMD loader if necessary\n        if (!(<any>window).require) {\n          const loaderScript: HTMLScriptElement = document.createElement('script');\n          loaderScript.type = 'application/javascript';\n          loaderScript.src = `${baseUrl}/monaco/vs/loader.js`;\n          loaderScript.addEventListener('load', onGotAmdLoader);\n          document.body.appendChild(loaderScript);\n        } else {\n          onGotAmdLoader();\n        }\n      });\n    }\n  }\n\n  ngOnDestroy() {\n    // if (this._windowResizeSubscription) {\n    //   this._windowResizeSubscription.unsubscribe();\n    // }\n    if (this._editor) {\n      this._editor.dispose();\n      this._editor = undefined;\n    }\n  }\n\n  protected initMonaco(options: any): void {\n    console.log(\"Init the custom monaco code editor.\");\n\n    // const hasModel = !!options.model;\n    const hasModel = false;\n\n    // if (hasModel) {\n    //   options.model = monaco.editor.createModel(options.model.value, options.model.language, options.model.uri);\n    // }\n    \n    this._editor = monaco.editor.create(this._editorComponent.nativeElement, options);\n\n    if (!hasModel) {\n      this._editor.setValue(this._value);\n    }\n\n    // monaco editor -> outside component\n    this._editor.onDidChangeModelContent((e: any) => this.onChangeModelContentHandler(e));\n\n    this._editor.onDidBlurEditorText((e: any) => this.onBlurEditorTextHandler(e));\n\n    // refresh layout on resize event.\n    // if (this._windowResizeSubscription) {\n    //   this._windowResizeSubscription.unsubscribe();\n    // }\n    // this._windowResizeSubscription = fromEvent(window, 'resize').subscribe(() => this._editor.layout());\n\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onInit,\n      target: this,\n      editor: this._editor\n    });\n  }\n\n  onChangeModelContentHandler(e){\n    const _value = this._editor.getValue();\n    \n    // monaco editor -> outside component\n    // https://github.com/JTangming/tm/issues/4 ngZone详解\n    this.zone.run(() => this.value = _value);// value is not propagated to parent when executing outside zone.\n    // console.log(\"write from the monaco:\" + this._value);\n  }\n\n  onBlurEditorTextHandler(e){\n\n    this.onTouchedHandler();\n  }\n\n  private _value: string = '';\n\n  //get accessor\n  get value(): any {\n      return this._value;\n  };\n\n  //set accessor including call the onchange callback\n  set value(v: any) {\n    if (v !== this.value) {// 注意这种写法，值得学习\n      this._value = v;\n    }\n\n    this.onChangeHandler(this.value);//在属性修饰器里调用onchangeHandler方法\n  }\n\n  localEditor(){//Demo: outside component -> monaco editor\n    this.writeValue('test');\n  }\n\n  // 自定义输入控件:3.2 implements ControlValueAccesso\n\n  // outside component -> monaco editor\n  \n  //From ControlValueAccessor interface\n  writeValue(value: any) {\n    this.value = value || '';\n\n    // Fix for value change while dispose in process.\n    setTimeout(() => {\n      if (this._editor /*&& !this.options.model*/) {\n        this._editor.setValue(this._value);\n        // console.log(\"write to the editor:\" + this._value);\n      }\n    });\n  }\n\n  //From ControlValueAccessor interface\n  registerOnChange(fn: any) {\n    this.onChangeHandler(this);\n  }\n\n  //From ControlValueAccessor interface\n  registerOnTouched(fn: any) {\n    this.onTouchedHandler();\n  }\n  \n  //ControlValueAccessor提供的事件回调\n  onChangeHandler = (_: any) => { //Propagate Change to outside\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onChange,\n      target: this,\n      data: _\n    });\n  };\n\n  //ControlValueAccessor提供的事件回调\n  onTouchedHandler = () => {\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onTouched,\n      target: this\n    });\n  };\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-monaco-editor.component.js","sourceRoot":"ng://angular-monaco-editor/","sources":["lib/editor/angular-monaco-editor/angular-monaco-editor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, AfterViewInit, ElementRef, EventEmitter, Input, OnDestroy, Output, ViewChild } from '@angular/core';\nimport { forwardRef, Inject, NgZone } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { pick } from 'lodash';\n\nimport { ANGULAR_MONACO_EDITOR_CONFIG, AngularMonacoEditorConfig } from '../config';\nimport { CodeEditorEventService } from '../services/code-editor.event.service';\nimport { CODE_EDITOR_EVENTS } from '../constants/events';\n\ndeclare const monaco: any;\n\nlet loadedMonaco: boolean = false;\nlet loadPromise: Promise<void>;\n\n// 自定义输入控件:1.封装ControlValueAccessor\n// https://code-examples.net/zh-CN/q/2154761\nexport const CODE_EDITOR_INPUT_VALUE_ACCESSOR: any = {\n  // https://blog.csdn.net/wangdan_2013/article/details/81314959\n  provide: NG_VALUE_ACCESSOR,//\n  useExisting: forwardRef(() => AngularMonacoEditorComponent),//\n  multi: true//\n};\n\n@Component({\n  selector: 'angular-monaco-editor',\n  template: `<div class=\"editor\" #codeEditor></div>`,\n  styles: [`:host{display:block;height:200px}.editor{width:100%;height:98%}`],\n  // 自定义输入控件:2.引入依赖服务ControlValueAccessor\n  providers: [CODE_EDITOR_INPUT_VALUE_ACCESSOR, CodeEditorEventService]\n})\n\n// 自定义输入控件 <-> Monaco Edtor\n\n// 自定义输入控件:3.1 implements ControlValueAccessor \nexport class AngularMonacoEditorComponent implements AfterViewInit, ControlValueAccessor, OnDestroy{\n\n  protected _editor: any;\n  private _options: any;\n  // protected _windowResizeSubscription: Subscription;\n\n  @ViewChild('codeEditor') _editorComponent: ElementRef; //动态添加代码编辑器\n  \n  @Output() onInit;\n  @Output() onChange;\n  @Output() onTouched;\n\n  @Input('options')\n  set options(options: any) {\n    // 默认options(this.config.defaultOptions) + 自定义options(options)\n    this._options = Object.assign({}, this.config.defaultOptions, options);\n    if (this._editor) {\n      this._editor.dispose();\n      this.initMonaco(options);\n    }\n  }\n  get options(): any {\n    return this._options;\n  }\n\n  // @Input('model')\n  // set model(model: AngularEditorModel) {\n  //   this.options.model = model;\n  //   if (this._editor) {\n  //     this._editor.dispose();\n  //     this.initMonaco(this.options);\n  //   }\n  // }\n\n  // 注入AngularMonacoEditorConfig，在创建Editor实例时设置config\n  constructor(private zone: NgZone, @Inject(ANGULAR_MONACO_EDITOR_CONFIG) private config: AngularMonacoEditorConfig, private codeEditorEventService: CodeEditorEventService) {\n\n    // 初始化自定义事件\n    const self = this;\n    codeEditorEventService.eventNames.forEach((name) => {\n      // 创建自定义事件，此处作用等效于: @Output() onInit = new EventEmitter<any>() \n      self[name] = new EventEmitter<any>();\n      const eventPair = pick(self, name);\n      codeEditorEventService.addEvent(eventPair);\n    });\n\n  }\n\n  ngAfterViewInit(): void {\n    if (loadedMonaco) {\n      // Wait until monaco editor is available\n      loadPromise.then(() => {\n        this.initMonaco(this.options);\n      });\n    } else {\n      loadedMonaco = true;\n      loadPromise = new Promise<void>((resolve: any) => {\n        const baseUrl = this.config.baseUrl || '/assets';\n        // if (typeof((<any>window).monaco) === 'object') {\n        //   resolve();\n        //   return;\n        // }\n        const onGotAmdLoader: any = () => {\n          // Load monaco\n          (<any>window).require.config({ paths: { 'vs': `${baseUrl}/monaco/vs` } });\n          (<any>window).require(['vs/editor/editor.main'], () => {\n            if (typeof this.config.onMonacoLoad === 'function') {\n              this.config.onMonacoLoad();\n            }\n            this.initMonaco(this.options);\n            resolve();\n          });\n        };\n\n        // Load AMD loader if necessary\n        if (!(<any>window).require) {\n          const loaderScript: HTMLScriptElement = document.createElement('script');\n          loaderScript.type = 'text/javascript';\n          loaderScript.src = `${baseUrl}/monaco/vs/loader.js`;\n          loaderScript.addEventListener('load', onGotAmdLoader);\n          document.body.appendChild(loaderScript);\n        } else {\n          onGotAmdLoader();\n        }\n      });\n    }\n  }\n\n  ngOnDestroy() {\n    // if (this._windowResizeSubscription) {\n    //   this._windowResizeSubscription.unsubscribe();\n    // }\n    if (this._editor) {\n      this._editor.dispose();\n      this._editor = undefined;\n    }\n  }\n\n  protected initMonaco(options: any): void {\n    console.log(\"Init the custom monaco code editor.\");\n\n    // const hasModel = !!options.model;\n    const hasModel = false;\n\n    // if (hasModel) {\n    //   options.model = monaco.editor.createModel(options.model.value, options.model.language, options.model.uri);\n    // }\n    \n    this._editor = monaco.editor.create(this._editorComponent.nativeElement, options);\n\n    if (!hasModel) {\n      this._editor.setValue(this._value);\n    }\n\n    // monaco editor -> outside component\n    this._editor.onDidChangeModelContent((e: any) => this.onChangeModelContentHandler(e));\n\n    this._editor.onDidBlurEditorText((e: any) => this.onBlurEditorTextHandler(e));\n\n    // refresh layout on resize event.\n    // if (this._windowResizeSubscription) {\n    //   this._windowResizeSubscription.unsubscribe();\n    // }\n    // this._windowResizeSubscription = fromEvent(window, 'resize').subscribe(() => this._editor.layout());\n\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onInit,\n      target: this,\n      editor: this._editor\n    });\n  }\n\n  onChangeModelContentHandler(e){\n    const _value = this._editor.getValue();\n    \n    // monaco editor -> outside component\n    // https://github.com/JTangming/tm/issues/4 ngZone详解\n    this.zone.run(() => this.value = _value);// value is not propagated to parent when executing outside zone.\n    // console.log(\"write from the monaco:\" + this._value);\n  }\n\n  onBlurEditorTextHandler(e){\n\n    this.onTouchedHandler();\n  }\n\n  private _value: string = '';\n\n  //get accessor\n  get value(): any {\n      return this._value;\n  };\n\n  //set accessor including call the onchange callback\n  set value(v: any) {\n    if (v !== this.value) {// 注意这种写法，值得学习\n      this._value = v;\n    }\n\n    this.onChangeHandler(this.value);//在属性修饰器里调用onchangeHandler方法\n  }\n\n  localEditor(){//Demo: outside component -> monaco editor\n    this.writeValue('test');\n  }\n\n  // 自定义输入控件:3.2 implements ControlValueAccesso\n\n  // outside component -> monaco editor\n  \n  //From ControlValueAccessor interface\n  writeValue(value: any) {\n    this.value = value || '';\n\n    // Fix for value change while dispose in process.\n    setTimeout(() => {\n      if (this._editor /*&& !this.options.model*/) {\n        this._editor.setValue(this._value);\n        // console.log(\"write to the editor:\" + this._value);\n      }\n    });\n  }\n\n  //From ControlValueAccessor interface\n  registerOnChange(fn: any) {\n    this.onChangeHandler(this);\n  }\n\n  //From ControlValueAccessor interface\n  registerOnTouched(fn: any) {\n    this.onTouchedHandler();\n  }\n  \n  //ControlValueAccessor提供的事件回调\n  onChangeHandler = (_: any) => { //Propagate Change to outside\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onChange,\n      target: this,\n      data: _\n    });\n  };\n\n  //ControlValueAccessor提供的事件回调\n  onTouchedHandler = () => {\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onTouched,\n      target: this\n    });\n  };\n}"]}

@@ -159,3 +159,3 @@ import { InjectionToken, Injectable, Component, EventEmitter, Input, Output, ViewChild, forwardRef, Inject, NgZone, NgModule } from '@angular/core';

const /** @type {?} */ loaderScript = document.createElement('script');
loaderScript.type = 'application/javascript';
loaderScript.type = 'text/javascript';
loaderScript.src = `${baseUrl}/monaco/vs/loader.js`;

@@ -350,2 +350,2 @@ loaderScript.addEventListener('load', onGotAmdLoader);

//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"angular-monaco-editor.js.map","sources":["ng://angular-monaco-editor/lib/editor/config.ts","ng://angular-monaco-editor/lib/editor/constants/events.ts","ng://angular-monaco-editor/lib/editor/services/code-editor.event.service.ts","ng://angular-monaco-editor/lib/editor/angular-monaco-editor/angular-monaco-editor.component.ts","ng://angular-monaco-editor/lib/editor/editor.module.ts"],"sourcesContent":["import { InjectionToken } from '@angular/core';\n\n// injectionTokenä½ç¨è¯´æ\n// https://segmentfault.com/a/1190000008626348\nexport const ANGULAR_MONACO_EDITOR_CONFIG = new InjectionToken('ANGULAR_MONACO_EDITOR_CONFIG');\n\nexport interface AngularMonacoEditorConfig {\n  baseUrl?: string;\n  defaultOptions?: { [key: string]: any; },\n  onMonacoLoad?: Function;\n}","export const CODE_EDITOR_EVENTS = {\r\n    onInit: 'onInit',\r\n    onChange: 'onChange',\r\n    onTouched: 'onTouched'\r\n}","import { EventEmitter, Injectable } from '@angular/core';\r\n\r\nimport { assign } from 'lodash';\r\nimport { pick } from 'lodash';\r\n\r\nimport { CODE_EDITOR_EVENTS } from '../constants/events';\r\n\r\n@Injectable()\r\nexport class CodeEditorEventService {\r\n    public eventNames = Object.keys(CODE_EDITOR_EVENTS);\r\n    private _events: any = {}; // ä½¿ç¨äºä»¶\r\n\r\n    /**\r\n     * è®¾ç½®å¯ç¨äºä»¶\r\n     * @param  äºä»¶\r\n     */\r\n    addEvent(event){\r\n        assign(this._events, event);\r\n        // console.log(this.events);\r\n    }\r\n\r\n    fireEvent(event) {\r\n        this._events[event.eventName].emit(event);\r\n        // console.log(\"Emit Event:\" + event);\r\n    }\r\n}\r\n","import { Component, OnInit, AfterViewInit, ElementRef, EventEmitter, Input, OnDestroy, Output, ViewChild } from '@angular/core';\nimport { forwardRef, Inject, NgZone } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { pick } from 'lodash';\n\nimport { ANGULAR_MONACO_EDITOR_CONFIG, AngularMonacoEditorConfig } from '../config';\nimport { CodeEditorEventService } from '../services/code-editor.event.service';\nimport { CODE_EDITOR_EVENTS } from '../constants/events';\n\ndeclare const monaco: any;\n\nlet loadedMonaco: boolean = false;\nlet loadPromise: Promise<void>;\n\n// èªå®ä¹è¾å¥æ§ä»¶:1.å°è£ControlValueAccessor\n// https://code-examples.net/zh-CN/q/2154761\nexport const CODE_EDITOR_INPUT_VALUE_ACCESSOR: any = {\n  // https://blog.csdn.net/wangdan_2013/article/details/81314959\n  provide: NG_VALUE_ACCESSOR,//\n  useExisting: forwardRef(() => AngularMonacoEditorComponent),//\n  multi: true//\n};\n\n@Component({\n  selector: 'angular-monaco-editor',\n  template: `<div class=\"editor\" #codeEditor></div>`,\n  styles: [`:host{display:block;height:200px}.editor{width:100%;height:98%}`],\n  // èªå®ä¹è¾å¥æ§ä»¶:2.å¼å¥ä¾èµæå¡ControlValueAccessor\n  providers: [CODE_EDITOR_INPUT_VALUE_ACCESSOR, CodeEditorEventService]\n})\n\n// èªå®ä¹è¾å¥æ§ä»¶ <-> Monaco Edtor\n\n// èªå®ä¹è¾å¥æ§ä»¶:3.1 implements ControlValueAccessor \nexport class AngularMonacoEditorComponent implements AfterViewInit, ControlValueAccessor, OnDestroy{\n\n  protected _editor: any;\n  private _options: any;\n  // protected _windowResizeSubscription: Subscription;\n\n  @ViewChild('codeEditor') _editorComponent: ElementRef; //å¨ææ·»å ä»£ç ç¼è¾å¨\n  \n  @Output() onInit;\n  @Output() onChange;\n  @Output() onTouched;\n\n  @Input('options')\n  set options(options: any) {\n    // é»è®¤options(this.config.defaultOptions) + èªå®ä¹options(options)\n    this._options = Object.assign({}, this.config.defaultOptions, options);\n    if (this._editor) {\n      this._editor.dispose();\n      this.initMonaco(options);\n    }\n  }\n  get options(): any {\n    return this._options;\n  }\n\n  // @Input('model')\n  // set model(model: AngularEditorModel) {\n  //   this.options.model = model;\n  //   if (this._editor) {\n  //     this._editor.dispose();\n  //     this.initMonaco(this.options);\n  //   }\n  // }\n\n  // æ³¨å¥AngularMonacoEditorConfigï¼å¨åå»ºEditorå®ä¾æ¶è®¾ç½®config\n  constructor(private zone: NgZone, @Inject(ANGULAR_MONACO_EDITOR_CONFIG) private config: AngularMonacoEditorConfig, private codeEditorEventService: CodeEditorEventService) {\n\n    // åå§åèªå®ä¹äºä»¶\n    const self = this;\n    codeEditorEventService.eventNames.forEach((name) => {\n      // åå»ºèªå®ä¹äºä»¶ï¼æ­¤å¤ä½ç¨ç­æäº: @Output() onInit = new EventEmitter<any>() \n      self[name] = new EventEmitter<any>();\n      const eventPair = pick(self, name);\n      codeEditorEventService.addEvent(eventPair);\n    });\n\n  }\n\n  ngAfterViewInit(): void {\n    if (loadedMonaco) {\n      // Wait until monaco editor is available\n      loadPromise.then(() => {\n        this.initMonaco(this.options);\n      });\n    } else {\n      loadedMonaco = true;\n      loadPromise = new Promise<void>((resolve: any) => {\n        const baseUrl = this.config.baseUrl || '/assets';\n        // if (typeof((<any>window).monaco) === 'object') {\n        //   resolve();\n        //   return;\n        // }\n        const onGotAmdLoader: any = () => {\n          // Load monaco\n          (<any>window).require.config({ paths: { 'vs': `${baseUrl}/monaco/vs` } });\n          (<any>window).require(['vs/editor/editor.main'], () => {\n            if (typeof this.config.onMonacoLoad === 'function') {\n              this.config.onMonacoLoad();\n            }\n            this.initMonaco(this.options);\n            resolve();\n          });\n        };\n\n        // Load AMD loader if necessary\n        if (!(<any>window).require) {\n          const loaderScript: HTMLScriptElement = document.createElement('script');\n          loaderScript.type = 'application/javascript';\n          loaderScript.src = `${baseUrl}/monaco/vs/loader.js`;\n          loaderScript.addEventListener('load', onGotAmdLoader);\n          document.body.appendChild(loaderScript);\n        } else {\n          onGotAmdLoader();\n        }\n      });\n    }\n  }\n\n  ngOnDestroy() {\n    // if (this._windowResizeSubscription) {\n    //   this._windowResizeSubscription.unsubscribe();\n    // }\n    if (this._editor) {\n      this._editor.dispose();\n      this._editor = undefined;\n    }\n  }\n\n  protected initMonaco(options: any): void {\n    console.log(\"Init the custom monaco code editor.\");\n\n    // const hasModel = !!options.model;\n    const hasModel = false;\n\n    // if (hasModel) {\n    //   options.model = monaco.editor.createModel(options.model.value, options.model.language, options.model.uri);\n    // }\n    \n    this._editor = monaco.editor.create(this._editorComponent.nativeElement, options);\n\n    if (!hasModel) {\n      this._editor.setValue(this._value);\n    }\n\n    // monaco editor -> outside component\n    this._editor.onDidChangeModelContent((e: any) => this.onChangeModelContentHandler(e));\n\n    this._editor.onDidBlurEditorText((e: any) => this.onBlurEditorTextHandler(e));\n\n    // refresh layout on resize event.\n    // if (this._windowResizeSubscription) {\n    //   this._windowResizeSubscription.unsubscribe();\n    // }\n    // this._windowResizeSubscription = fromEvent(window, 'resize').subscribe(() => this._editor.layout());\n\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onInit,\n      target: this,\n      editor: this._editor\n    });\n  }\n\n  onChangeModelContentHandler(e){\n    const _value = this._editor.getValue();\n    \n    // monaco editor -> outside component\n    // https://github.com/JTangming/tm/issues/4 ngZoneè¯¦è§£\n    this.zone.run(() => this.value = _value);// value is not propagated to parent when executing outside zone.\n    // console.log(\"write from the monaco:\" + this._value);\n  }\n\n  onBlurEditorTextHandler(e){\n\n    this.onTouchedHandler();\n  }\n\n  private _value: string = '';\n\n  //get accessor\n  get value(): any {\n      return this._value;\n  };\n\n  //set accessor including call the onchange callback\n  set value(v: any) {\n    if (v !== this.value) {// æ³¨æè¿ç§åæ³ï¼å¼å¾å­¦ä¹ \n      this._value = v;\n    }\n\n    this.onChangeHandler(this.value);//å¨å±æ§ä¿®é¥°å¨éè°ç¨onchangeHandleræ¹æ³\n  }\n\n  localEditor(){//Demo: outside component -> monaco editor\n    this.writeValue('test');\n  }\n\n  // èªå®ä¹è¾å¥æ§ä»¶:3.2 implements ControlValueAccesso\n\n  // outside component -> monaco editor\n  \n  //From ControlValueAccessor interface\n  writeValue(value: any) {\n    this.value = value || '';\n\n    // Fix for value change while dispose in process.\n    setTimeout(() => {\n      if (this._editor /*&& !this.options.model*/) {\n        this._editor.setValue(this._value);\n        // console.log(\"write to the editor:\" + this._value);\n      }\n    });\n  }\n\n  //From ControlValueAccessor interface\n  registerOnChange(fn: any) {\n    this.onChangeHandler(this);\n  }\n\n  //From ControlValueAccessor interface\n  registerOnTouched(fn: any) {\n    this.onTouchedHandler();\n  }\n  \n  //ControlValueAccessoræä¾çäºä»¶åè°\n  onChangeHandler = (_: any) => { //Propagate Change to outside\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onChange,\n      target: this,\n      data: _\n    });\n  };\n\n  //ControlValueAccessoræä¾çäºä»¶åè°\n  onTouchedHandler = () => {\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onTouched,\n      target: this\n    });\n  };\n}","import { CommonModule } from '@angular/common';\n\nimport { ModuleWithProviders, NgModule } from '@angular/core';\nimport { ANGULAR_MONACO_EDITOR_CONFIG, AngularMonacoEditorConfig } from './config';\nimport { AngularMonacoEditorComponent } from './angular-monaco-editor/angular-monaco-editor.component';\n\n@NgModule({\n  imports: [\n    CommonModule\n  ],\n  declarations: [\n    AngularMonacoEditorComponent\n  ],\n  exports: [\n    AngularMonacoEditorComponent\n  ],\n  providers: [\n  ]\n})\n\nexport class AngularMonacoEditorModule {\n  public static forRoot(config: AngularMonacoEditorConfig = {}): ModuleWithProviders {\n    return {\n      ngModule: AngularMonacoEditorModule,\n      providers: [\n        { provide: ANGULAR_MONACO_EDITOR_CONFIG, useValue: config }\n      ]\n    };\n  }\n}\n"],"names":[],"mappings":"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"}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"angular-monaco-editor.js.map","sources":["ng://angular-monaco-editor/lib/editor/config.ts","ng://angular-monaco-editor/lib/editor/constants/events.ts","ng://angular-monaco-editor/lib/editor/services/code-editor.event.service.ts","ng://angular-monaco-editor/lib/editor/angular-monaco-editor/angular-monaco-editor.component.ts","ng://angular-monaco-editor/lib/editor/editor.module.ts"],"sourcesContent":["import { InjectionToken } from '@angular/core';\n\n// injectionTokenä½ç¨è¯´æ\n// https://segmentfault.com/a/1190000008626348\nexport const ANGULAR_MONACO_EDITOR_CONFIG = new InjectionToken('ANGULAR_MONACO_EDITOR_CONFIG');\n\nexport interface AngularMonacoEditorConfig {\n  baseUrl?: string;\n  defaultOptions?: { [key: string]: any; },\n  onMonacoLoad?: Function;\n}","export const CODE_EDITOR_EVENTS = {\r\n    onInit: 'onInit',\r\n    onChange: 'onChange',\r\n    onTouched: 'onTouched'\r\n}","import { EventEmitter, Injectable } from '@angular/core';\r\n\r\nimport { assign } from 'lodash';\r\nimport { pick } from 'lodash';\r\n\r\nimport { CODE_EDITOR_EVENTS } from '../constants/events';\r\n\r\n@Injectable()\r\nexport class CodeEditorEventService {\r\n    public eventNames = Object.keys(CODE_EDITOR_EVENTS);\r\n    private _events: any = {}; // ä½¿ç¨äºä»¶\r\n\r\n    /**\r\n     * è®¾ç½®å¯ç¨äºä»¶\r\n     * @param  äºä»¶\r\n     */\r\n    addEvent(event){\r\n        assign(this._events, event);\r\n        // console.log(this.events);\r\n    }\r\n\r\n    fireEvent(event) {\r\n        this._events[event.eventName].emit(event);\r\n        // console.log(\"Emit Event:\" + event);\r\n    }\r\n}\r\n","import { Component, OnInit, AfterViewInit, ElementRef, EventEmitter, Input, OnDestroy, Output, ViewChild } from '@angular/core';\nimport { forwardRef, Inject, NgZone } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { pick } from 'lodash';\n\nimport { ANGULAR_MONACO_EDITOR_CONFIG, AngularMonacoEditorConfig } from '../config';\nimport { CodeEditorEventService } from '../services/code-editor.event.service';\nimport { CODE_EDITOR_EVENTS } from '../constants/events';\n\ndeclare const monaco: any;\n\nlet loadedMonaco: boolean = false;\nlet loadPromise: Promise<void>;\n\n// èªå®ä¹è¾å¥æ§ä»¶:1.å°è£ControlValueAccessor\n// https://code-examples.net/zh-CN/q/2154761\nexport const CODE_EDITOR_INPUT_VALUE_ACCESSOR: any = {\n  // https://blog.csdn.net/wangdan_2013/article/details/81314959\n  provide: NG_VALUE_ACCESSOR,//\n  useExisting: forwardRef(() => AngularMonacoEditorComponent),//\n  multi: true//\n};\n\n@Component({\n  selector: 'angular-monaco-editor',\n  template: `<div class=\"editor\" #codeEditor></div>`,\n  styles: [`:host{display:block;height:200px}.editor{width:100%;height:98%}`],\n  // èªå®ä¹è¾å¥æ§ä»¶:2.å¼å¥ä¾èµæå¡ControlValueAccessor\n  providers: [CODE_EDITOR_INPUT_VALUE_ACCESSOR, CodeEditorEventService]\n})\n\n// èªå®ä¹è¾å¥æ§ä»¶ <-> Monaco Edtor\n\n// èªå®ä¹è¾å¥æ§ä»¶:3.1 implements ControlValueAccessor \nexport class AngularMonacoEditorComponent implements AfterViewInit, ControlValueAccessor, OnDestroy{\n\n  protected _editor: any;\n  private _options: any;\n  // protected _windowResizeSubscription: Subscription;\n\n  @ViewChild('codeEditor') _editorComponent: ElementRef; //å¨ææ·»å ä»£ç ç¼è¾å¨\n  \n  @Output() onInit;\n  @Output() onChange;\n  @Output() onTouched;\n\n  @Input('options')\n  set options(options: any) {\n    // é»è®¤options(this.config.defaultOptions) + èªå®ä¹options(options)\n    this._options = Object.assign({}, this.config.defaultOptions, options);\n    if (this._editor) {\n      this._editor.dispose();\n      this.initMonaco(options);\n    }\n  }\n  get options(): any {\n    return this._options;\n  }\n\n  // @Input('model')\n  // set model(model: AngularEditorModel) {\n  //   this.options.model = model;\n  //   if (this._editor) {\n  //     this._editor.dispose();\n  //     this.initMonaco(this.options);\n  //   }\n  // }\n\n  // æ³¨å¥AngularMonacoEditorConfigï¼å¨åå»ºEditorå®ä¾æ¶è®¾ç½®config\n  constructor(private zone: NgZone, @Inject(ANGULAR_MONACO_EDITOR_CONFIG) private config: AngularMonacoEditorConfig, private codeEditorEventService: CodeEditorEventService) {\n\n    // åå§åèªå®ä¹äºä»¶\n    const self = this;\n    codeEditorEventService.eventNames.forEach((name) => {\n      // åå»ºèªå®ä¹äºä»¶ï¼æ­¤å¤ä½ç¨ç­æäº: @Output() onInit = new EventEmitter<any>() \n      self[name] = new EventEmitter<any>();\n      const eventPair = pick(self, name);\n      codeEditorEventService.addEvent(eventPair);\n    });\n\n  }\n\n  ngAfterViewInit(): void {\n    if (loadedMonaco) {\n      // Wait until monaco editor is available\n      loadPromise.then(() => {\n        this.initMonaco(this.options);\n      });\n    } else {\n      loadedMonaco = true;\n      loadPromise = new Promise<void>((resolve: any) => {\n        const baseUrl = this.config.baseUrl || '/assets';\n        // if (typeof((<any>window).monaco) === 'object') {\n        //   resolve();\n        //   return;\n        // }\n        const onGotAmdLoader: any = () => {\n          // Load monaco\n          (<any>window).require.config({ paths: { 'vs': `${baseUrl}/monaco/vs` } });\n          (<any>window).require(['vs/editor/editor.main'], () => {\n            if (typeof this.config.onMonacoLoad === 'function') {\n              this.config.onMonacoLoad();\n            }\n            this.initMonaco(this.options);\n            resolve();\n          });\n        };\n\n        // Load AMD loader if necessary\n        if (!(<any>window).require) {\n          const loaderScript: HTMLScriptElement = document.createElement('script');\n          loaderScript.type = 'text/javascript';\n          loaderScript.src = `${baseUrl}/monaco/vs/loader.js`;\n          loaderScript.addEventListener('load', onGotAmdLoader);\n          document.body.appendChild(loaderScript);\n        } else {\n          onGotAmdLoader();\n        }\n      });\n    }\n  }\n\n  ngOnDestroy() {\n    // if (this._windowResizeSubscription) {\n    //   this._windowResizeSubscription.unsubscribe();\n    // }\n    if (this._editor) {\n      this._editor.dispose();\n      this._editor = undefined;\n    }\n  }\n\n  protected initMonaco(options: any): void {\n    console.log(\"Init the custom monaco code editor.\");\n\n    // const hasModel = !!options.model;\n    const hasModel = false;\n\n    // if (hasModel) {\n    //   options.model = monaco.editor.createModel(options.model.value, options.model.language, options.model.uri);\n    // }\n    \n    this._editor = monaco.editor.create(this._editorComponent.nativeElement, options);\n\n    if (!hasModel) {\n      this._editor.setValue(this._value);\n    }\n\n    // monaco editor -> outside component\n    this._editor.onDidChangeModelContent((e: any) => this.onChangeModelContentHandler(e));\n\n    this._editor.onDidBlurEditorText((e: any) => this.onBlurEditorTextHandler(e));\n\n    // refresh layout on resize event.\n    // if (this._windowResizeSubscription) {\n    //   this._windowResizeSubscription.unsubscribe();\n    // }\n    // this._windowResizeSubscription = fromEvent(window, 'resize').subscribe(() => this._editor.layout());\n\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onInit,\n      target: this,\n      editor: this._editor\n    });\n  }\n\n  onChangeModelContentHandler(e){\n    const _value = this._editor.getValue();\n    \n    // monaco editor -> outside component\n    // https://github.com/JTangming/tm/issues/4 ngZoneè¯¦è§£\n    this.zone.run(() => this.value = _value);// value is not propagated to parent when executing outside zone.\n    // console.log(\"write from the monaco:\" + this._value);\n  }\n\n  onBlurEditorTextHandler(e){\n\n    this.onTouchedHandler();\n  }\n\n  private _value: string = '';\n\n  //get accessor\n  get value(): any {\n      return this._value;\n  };\n\n  //set accessor including call the onchange callback\n  set value(v: any) {\n    if (v !== this.value) {// æ³¨æè¿ç§åæ³ï¼å¼å¾å­¦ä¹ \n      this._value = v;\n    }\n\n    this.onChangeHandler(this.value);//å¨å±æ§ä¿®é¥°å¨éè°ç¨onchangeHandleræ¹æ³\n  }\n\n  localEditor(){//Demo: outside component -> monaco editor\n    this.writeValue('test');\n  }\n\n  // èªå®ä¹è¾å¥æ§ä»¶:3.2 implements ControlValueAccesso\n\n  // outside component -> monaco editor\n  \n  //From ControlValueAccessor interface\n  writeValue(value: any) {\n    this.value = value || '';\n\n    // Fix for value change while dispose in process.\n    setTimeout(() => {\n      if (this._editor /*&& !this.options.model*/) {\n        this._editor.setValue(this._value);\n        // console.log(\"write to the editor:\" + this._value);\n      }\n    });\n  }\n\n  //From ControlValueAccessor interface\n  registerOnChange(fn: any) {\n    this.onChangeHandler(this);\n  }\n\n  //From ControlValueAccessor interface\n  registerOnTouched(fn: any) {\n    this.onTouchedHandler();\n  }\n  \n  //ControlValueAccessoræä¾çäºä»¶åè°\n  onChangeHandler = (_: any) => { //Propagate Change to outside\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onChange,\n      target: this,\n      data: _\n    });\n  };\n\n  //ControlValueAccessoræä¾çäºä»¶åè°\n  onTouchedHandler = () => {\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onTouched,\n      target: this\n    });\n  };\n}","import { CommonModule } from '@angular/common';\n\nimport { ModuleWithProviders, NgModule } from '@angular/core';\nimport { ANGULAR_MONACO_EDITOR_CONFIG, AngularMonacoEditorConfig } from './config';\nimport { AngularMonacoEditorComponent } from './angular-monaco-editor/angular-monaco-editor.component';\n\n@NgModule({\n  imports: [\n    CommonModule\n  ],\n  declarations: [\n    AngularMonacoEditorComponent\n  ],\n  exports: [\n    AngularMonacoEditorComponent\n  ],\n  providers: [\n  ]\n})\n\nexport class AngularMonacoEditorModule {\n  public static forRoot(config: AngularMonacoEditorConfig = {}): ModuleWithProviders {\n    return {\n      ngModule: AngularMonacoEditorModule,\n      providers: [\n        { provide: ANGULAR_MONACO_EDITOR_CONFIG, useValue: config }\n      ]\n    };\n  }\n}\n"],"names":[],"mappings":"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"}

@@ -184,3 +184,3 @@ import { InjectionToken, Injectable, Component, EventEmitter, Input, Output, ViewChild, forwardRef, Inject, NgZone, NgModule } from '@angular/core';

var /** @type {?} */ loaderScript = document.createElement('script');
loaderScript.type = 'application/javascript';
loaderScript.type = 'text/javascript';
loaderScript.src = baseUrl + "/monaco/vs/loader.js";

@@ -427,2 +427,2 @@ loaderScript.addEventListener('load', onGotAmdLoader);

//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"angular-monaco-editor.js.map","sources":["ng://angular-monaco-editor/lib/editor/config.ts","ng://angular-monaco-editor/lib/editor/constants/events.ts","ng://angular-monaco-editor/lib/editor/services/code-editor.event.service.ts","ng://angular-monaco-editor/lib/editor/angular-monaco-editor/angular-monaco-editor.component.ts","ng://angular-monaco-editor/lib/editor/editor.module.ts"],"sourcesContent":["import { InjectionToken } from '@angular/core';\n\n// injectionTokenä½ç¨è¯´æ\n// https://segmentfault.com/a/1190000008626348\nexport const ANGULAR_MONACO_EDITOR_CONFIG = new InjectionToken('ANGULAR_MONACO_EDITOR_CONFIG');\n\nexport interface AngularMonacoEditorConfig {\n  baseUrl?: string;\n  defaultOptions?: { [key: string]: any; },\n  onMonacoLoad?: Function;\n}","export const CODE_EDITOR_EVENTS = {\r\n    onInit: 'onInit',\r\n    onChange: 'onChange',\r\n    onTouched: 'onTouched'\r\n}","import { EventEmitter, Injectable } from '@angular/core';\r\n\r\nimport { assign } from 'lodash';\r\nimport { pick } from 'lodash';\r\n\r\nimport { CODE_EDITOR_EVENTS } from '../constants/events';\r\n\r\n@Injectable()\r\nexport class CodeEditorEventService {\r\n    public eventNames = Object.keys(CODE_EDITOR_EVENTS);\r\n    private _events: any = {}; // ä½¿ç¨äºä»¶\r\n\r\n    /**\r\n     * è®¾ç½®å¯ç¨äºä»¶\r\n     * @param  äºä»¶\r\n     */\r\n    addEvent(event){\r\n        assign(this._events, event);\r\n        // console.log(this.events);\r\n    }\r\n\r\n    fireEvent(event) {\r\n        this._events[event.eventName].emit(event);\r\n        // console.log(\"Emit Event:\" + event);\r\n    }\r\n}\r\n","import { Component, OnInit, AfterViewInit, ElementRef, EventEmitter, Input, OnDestroy, Output, ViewChild } from '@angular/core';\nimport { forwardRef, Inject, NgZone } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { pick } from 'lodash';\n\nimport { ANGULAR_MONACO_EDITOR_CONFIG, AngularMonacoEditorConfig } from '../config';\nimport { CodeEditorEventService } from '../services/code-editor.event.service';\nimport { CODE_EDITOR_EVENTS } from '../constants/events';\n\ndeclare const monaco: any;\n\nlet loadedMonaco: boolean = false;\nlet loadPromise: Promise<void>;\n\n// èªå®ä¹è¾å¥æ§ä»¶:1.å°è£ControlValueAccessor\n// https://code-examples.net/zh-CN/q/2154761\nexport const CODE_EDITOR_INPUT_VALUE_ACCESSOR: any = {\n  // https://blog.csdn.net/wangdan_2013/article/details/81314959\n  provide: NG_VALUE_ACCESSOR,//\n  useExisting: forwardRef(() => AngularMonacoEditorComponent),//\n  multi: true//\n};\n\n@Component({\n  selector: 'angular-monaco-editor',\n  template: `<div class=\"editor\" #codeEditor></div>`,\n  styles: [`:host{display:block;height:200px}.editor{width:100%;height:98%}`],\n  // èªå®ä¹è¾å¥æ§ä»¶:2.å¼å¥ä¾èµæå¡ControlValueAccessor\n  providers: [CODE_EDITOR_INPUT_VALUE_ACCESSOR, CodeEditorEventService]\n})\n\n// èªå®ä¹è¾å¥æ§ä»¶ <-> Monaco Edtor\n\n// èªå®ä¹è¾å¥æ§ä»¶:3.1 implements ControlValueAccessor \nexport class AngularMonacoEditorComponent implements AfterViewInit, ControlValueAccessor, OnDestroy{\n\n  protected _editor: any;\n  private _options: any;\n  // protected _windowResizeSubscription: Subscription;\n\n  @ViewChild('codeEditor') _editorComponent: ElementRef; //å¨ææ·»å ä»£ç ç¼è¾å¨\n  \n  @Output() onInit;\n  @Output() onChange;\n  @Output() onTouched;\n\n  @Input('options')\n  set options(options: any) {\n    // é»è®¤options(this.config.defaultOptions) + èªå®ä¹options(options)\n    this._options = Object.assign({}, this.config.defaultOptions, options);\n    if (this._editor) {\n      this._editor.dispose();\n      this.initMonaco(options);\n    }\n  }\n  get options(): any {\n    return this._options;\n  }\n\n  // @Input('model')\n  // set model(model: AngularEditorModel) {\n  //   this.options.model = model;\n  //   if (this._editor) {\n  //     this._editor.dispose();\n  //     this.initMonaco(this.options);\n  //   }\n  // }\n\n  // æ³¨å¥AngularMonacoEditorConfigï¼å¨åå»ºEditorå®ä¾æ¶è®¾ç½®config\n  constructor(private zone: NgZone, @Inject(ANGULAR_MONACO_EDITOR_CONFIG) private config: AngularMonacoEditorConfig, private codeEditorEventService: CodeEditorEventService) {\n\n    // åå§åèªå®ä¹äºä»¶\n    const self = this;\n    codeEditorEventService.eventNames.forEach((name) => {\n      // åå»ºèªå®ä¹äºä»¶ï¼æ­¤å¤ä½ç¨ç­æäº: @Output() onInit = new EventEmitter<any>() \n      self[name] = new EventEmitter<any>();\n      const eventPair = pick(self, name);\n      codeEditorEventService.addEvent(eventPair);\n    });\n\n  }\n\n  ngAfterViewInit(): void {\n    if (loadedMonaco) {\n      // Wait until monaco editor is available\n      loadPromise.then(() => {\n        this.initMonaco(this.options);\n      });\n    } else {\n      loadedMonaco = true;\n      loadPromise = new Promise<void>((resolve: any) => {\n        const baseUrl = this.config.baseUrl || '/assets';\n        // if (typeof((<any>window).monaco) === 'object') {\n        //   resolve();\n        //   return;\n        // }\n        const onGotAmdLoader: any = () => {\n          // Load monaco\n          (<any>window).require.config({ paths: { 'vs': `${baseUrl}/monaco/vs` } });\n          (<any>window).require(['vs/editor/editor.main'], () => {\n            if (typeof this.config.onMonacoLoad === 'function') {\n              this.config.onMonacoLoad();\n            }\n            this.initMonaco(this.options);\n            resolve();\n          });\n        };\n\n        // Load AMD loader if necessary\n        if (!(<any>window).require) {\n          const loaderScript: HTMLScriptElement = document.createElement('script');\n          loaderScript.type = 'application/javascript';\n          loaderScript.src = `${baseUrl}/monaco/vs/loader.js`;\n          loaderScript.addEventListener('load', onGotAmdLoader);\n          document.body.appendChild(loaderScript);\n        } else {\n          onGotAmdLoader();\n        }\n      });\n    }\n  }\n\n  ngOnDestroy() {\n    // if (this._windowResizeSubscription) {\n    //   this._windowResizeSubscription.unsubscribe();\n    // }\n    if (this._editor) {\n      this._editor.dispose();\n      this._editor = undefined;\n    }\n  }\n\n  protected initMonaco(options: any): void {\n    console.log(\"Init the custom monaco code editor.\");\n\n    // const hasModel = !!options.model;\n    const hasModel = false;\n\n    // if (hasModel) {\n    //   options.model = monaco.editor.createModel(options.model.value, options.model.language, options.model.uri);\n    // }\n    \n    this._editor = monaco.editor.create(this._editorComponent.nativeElement, options);\n\n    if (!hasModel) {\n      this._editor.setValue(this._value);\n    }\n\n    // monaco editor -> outside component\n    this._editor.onDidChangeModelContent((e: any) => this.onChangeModelContentHandler(e));\n\n    this._editor.onDidBlurEditorText((e: any) => this.onBlurEditorTextHandler(e));\n\n    // refresh layout on resize event.\n    // if (this._windowResizeSubscription) {\n    //   this._windowResizeSubscription.unsubscribe();\n    // }\n    // this._windowResizeSubscription = fromEvent(window, 'resize').subscribe(() => this._editor.layout());\n\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onInit,\n      target: this,\n      editor: this._editor\n    });\n  }\n\n  onChangeModelContentHandler(e){\n    const _value = this._editor.getValue();\n    \n    // monaco editor -> outside component\n    // https://github.com/JTangming/tm/issues/4 ngZoneè¯¦è§£\n    this.zone.run(() => this.value = _value);// value is not propagated to parent when executing outside zone.\n    // console.log(\"write from the monaco:\" + this._value);\n  }\n\n  onBlurEditorTextHandler(e){\n\n    this.onTouchedHandler();\n  }\n\n  private _value: string = '';\n\n  //get accessor\n  get value(): any {\n      return this._value;\n  };\n\n  //set accessor including call the onchange callback\n  set value(v: any) {\n    if (v !== this.value) {// æ³¨æè¿ç§åæ³ï¼å¼å¾å­¦ä¹ \n      this._value = v;\n    }\n\n    this.onChangeHandler(this.value);//å¨å±æ§ä¿®é¥°å¨éè°ç¨onchangeHandleræ¹æ³\n  }\n\n  localEditor(){//Demo: outside component -> monaco editor\n    this.writeValue('test');\n  }\n\n  // èªå®ä¹è¾å¥æ§ä»¶:3.2 implements ControlValueAccesso\n\n  // outside component -> monaco editor\n  \n  //From ControlValueAccessor interface\n  writeValue(value: any) {\n    this.value = value || '';\n\n    // Fix for value change while dispose in process.\n    setTimeout(() => {\n      if (this._editor /*&& !this.options.model*/) {\n        this._editor.setValue(this._value);\n        // console.log(\"write to the editor:\" + this._value);\n      }\n    });\n  }\n\n  //From ControlValueAccessor interface\n  registerOnChange(fn: any) {\n    this.onChangeHandler(this);\n  }\n\n  //From ControlValueAccessor interface\n  registerOnTouched(fn: any) {\n    this.onTouchedHandler();\n  }\n  \n  //ControlValueAccessoræä¾çäºä»¶åè°\n  onChangeHandler = (_: any) => { //Propagate Change to outside\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onChange,\n      target: this,\n      data: _\n    });\n  };\n\n  //ControlValueAccessoræä¾çäºä»¶åè°\n  onTouchedHandler = () => {\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onTouched,\n      target: this\n    });\n  };\n}","import { CommonModule } from '@angular/common';\n\nimport { ModuleWithProviders, NgModule } from '@angular/core';\nimport { ANGULAR_MONACO_EDITOR_CONFIG, AngularMonacoEditorConfig } from './config';\nimport { AngularMonacoEditorComponent } from './angular-monaco-editor/angular-monaco-editor.component';\n\n@NgModule({\n  imports: [\n    CommonModule\n  ],\n  declarations: [\n    AngularMonacoEditorComponent\n  ],\n  exports: [\n    AngularMonacoEditorComponent\n  ],\n  providers: [\n  ]\n})\n\nexport class AngularMonacoEditorModule {\n  public static forRoot(config: AngularMonacoEditorConfig = {}): ModuleWithProviders {\n    return {\n      ngModule: AngularMonacoEditorModule,\n      providers: [\n        { provide: ANGULAR_MONACO_EDITOR_CONFIG, useValue: config }\n      ]\n    };\n  }\n}\n"],"names":[],"mappings":"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"}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"angular-monaco-editor.js.map","sources":["ng://angular-monaco-editor/lib/editor/config.ts","ng://angular-monaco-editor/lib/editor/constants/events.ts","ng://angular-monaco-editor/lib/editor/services/code-editor.event.service.ts","ng://angular-monaco-editor/lib/editor/angular-monaco-editor/angular-monaco-editor.component.ts","ng://angular-monaco-editor/lib/editor/editor.module.ts"],"sourcesContent":["import { InjectionToken } from '@angular/core';\n\n// injectionTokenä½ç¨è¯´æ\n// https://segmentfault.com/a/1190000008626348\nexport const ANGULAR_MONACO_EDITOR_CONFIG = new InjectionToken('ANGULAR_MONACO_EDITOR_CONFIG');\n\nexport interface AngularMonacoEditorConfig {\n  baseUrl?: string;\n  defaultOptions?: { [key: string]: any; },\n  onMonacoLoad?: Function;\n}","export const CODE_EDITOR_EVENTS = {\r\n    onInit: 'onInit',\r\n    onChange: 'onChange',\r\n    onTouched: 'onTouched'\r\n}","import { EventEmitter, Injectable } from '@angular/core';\r\n\r\nimport { assign } from 'lodash';\r\nimport { pick } from 'lodash';\r\n\r\nimport { CODE_EDITOR_EVENTS } from '../constants/events';\r\n\r\n@Injectable()\r\nexport class CodeEditorEventService {\r\n    public eventNames = Object.keys(CODE_EDITOR_EVENTS);\r\n    private _events: any = {}; // ä½¿ç¨äºä»¶\r\n\r\n    /**\r\n     * è®¾ç½®å¯ç¨äºä»¶\r\n     * @param  äºä»¶\r\n     */\r\n    addEvent(event){\r\n        assign(this._events, event);\r\n        // console.log(this.events);\r\n    }\r\n\r\n    fireEvent(event) {\r\n        this._events[event.eventName].emit(event);\r\n        // console.log(\"Emit Event:\" + event);\r\n    }\r\n}\r\n","import { Component, OnInit, AfterViewInit, ElementRef, EventEmitter, Input, OnDestroy, Output, ViewChild } from '@angular/core';\nimport { forwardRef, Inject, NgZone } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { pick } from 'lodash';\n\nimport { ANGULAR_MONACO_EDITOR_CONFIG, AngularMonacoEditorConfig } from '../config';\nimport { CodeEditorEventService } from '../services/code-editor.event.service';\nimport { CODE_EDITOR_EVENTS } from '../constants/events';\n\ndeclare const monaco: any;\n\nlet loadedMonaco: boolean = false;\nlet loadPromise: Promise<void>;\n\n// èªå®ä¹è¾å¥æ§ä»¶:1.å°è£ControlValueAccessor\n// https://code-examples.net/zh-CN/q/2154761\nexport const CODE_EDITOR_INPUT_VALUE_ACCESSOR: any = {\n  // https://blog.csdn.net/wangdan_2013/article/details/81314959\n  provide: NG_VALUE_ACCESSOR,//\n  useExisting: forwardRef(() => AngularMonacoEditorComponent),//\n  multi: true//\n};\n\n@Component({\n  selector: 'angular-monaco-editor',\n  template: `<div class=\"editor\" #codeEditor></div>`,\n  styles: [`:host{display:block;height:200px}.editor{width:100%;height:98%}`],\n  // èªå®ä¹è¾å¥æ§ä»¶:2.å¼å¥ä¾èµæå¡ControlValueAccessor\n  providers: [CODE_EDITOR_INPUT_VALUE_ACCESSOR, CodeEditorEventService]\n})\n\n// èªå®ä¹è¾å¥æ§ä»¶ <-> Monaco Edtor\n\n// èªå®ä¹è¾å¥æ§ä»¶:3.1 implements ControlValueAccessor \nexport class AngularMonacoEditorComponent implements AfterViewInit, ControlValueAccessor, OnDestroy{\n\n  protected _editor: any;\n  private _options: any;\n  // protected _windowResizeSubscription: Subscription;\n\n  @ViewChild('codeEditor') _editorComponent: ElementRef; //å¨ææ·»å ä»£ç ç¼è¾å¨\n  \n  @Output() onInit;\n  @Output() onChange;\n  @Output() onTouched;\n\n  @Input('options')\n  set options(options: any) {\n    // é»è®¤options(this.config.defaultOptions) + èªå®ä¹options(options)\n    this._options = Object.assign({}, this.config.defaultOptions, options);\n    if (this._editor) {\n      this._editor.dispose();\n      this.initMonaco(options);\n    }\n  }\n  get options(): any {\n    return this._options;\n  }\n\n  // @Input('model')\n  // set model(model: AngularEditorModel) {\n  //   this.options.model = model;\n  //   if (this._editor) {\n  //     this._editor.dispose();\n  //     this.initMonaco(this.options);\n  //   }\n  // }\n\n  // æ³¨å¥AngularMonacoEditorConfigï¼å¨åå»ºEditorå®ä¾æ¶è®¾ç½®config\n  constructor(private zone: NgZone, @Inject(ANGULAR_MONACO_EDITOR_CONFIG) private config: AngularMonacoEditorConfig, private codeEditorEventService: CodeEditorEventService) {\n\n    // åå§åèªå®ä¹äºä»¶\n    const self = this;\n    codeEditorEventService.eventNames.forEach((name) => {\n      // åå»ºèªå®ä¹äºä»¶ï¼æ­¤å¤ä½ç¨ç­æäº: @Output() onInit = new EventEmitter<any>() \n      self[name] = new EventEmitter<any>();\n      const eventPair = pick(self, name);\n      codeEditorEventService.addEvent(eventPair);\n    });\n\n  }\n\n  ngAfterViewInit(): void {\n    if (loadedMonaco) {\n      // Wait until monaco editor is available\n      loadPromise.then(() => {\n        this.initMonaco(this.options);\n      });\n    } else {\n      loadedMonaco = true;\n      loadPromise = new Promise<void>((resolve: any) => {\n        const baseUrl = this.config.baseUrl || '/assets';\n        // if (typeof((<any>window).monaco) === 'object') {\n        //   resolve();\n        //   return;\n        // }\n        const onGotAmdLoader: any = () => {\n          // Load monaco\n          (<any>window).require.config({ paths: { 'vs': `${baseUrl}/monaco/vs` } });\n          (<any>window).require(['vs/editor/editor.main'], () => {\n            if (typeof this.config.onMonacoLoad === 'function') {\n              this.config.onMonacoLoad();\n            }\n            this.initMonaco(this.options);\n            resolve();\n          });\n        };\n\n        // Load AMD loader if necessary\n        if (!(<any>window).require) {\n          const loaderScript: HTMLScriptElement = document.createElement('script');\n          loaderScript.type = 'text/javascript';\n          loaderScript.src = `${baseUrl}/monaco/vs/loader.js`;\n          loaderScript.addEventListener('load', onGotAmdLoader);\n          document.body.appendChild(loaderScript);\n        } else {\n          onGotAmdLoader();\n        }\n      });\n    }\n  }\n\n  ngOnDestroy() {\n    // if (this._windowResizeSubscription) {\n    //   this._windowResizeSubscription.unsubscribe();\n    // }\n    if (this._editor) {\n      this._editor.dispose();\n      this._editor = undefined;\n    }\n  }\n\n  protected initMonaco(options: any): void {\n    console.log(\"Init the custom monaco code editor.\");\n\n    // const hasModel = !!options.model;\n    const hasModel = false;\n\n    // if (hasModel) {\n    //   options.model = monaco.editor.createModel(options.model.value, options.model.language, options.model.uri);\n    // }\n    \n    this._editor = monaco.editor.create(this._editorComponent.nativeElement, options);\n\n    if (!hasModel) {\n      this._editor.setValue(this._value);\n    }\n\n    // monaco editor -> outside component\n    this._editor.onDidChangeModelContent((e: any) => this.onChangeModelContentHandler(e));\n\n    this._editor.onDidBlurEditorText((e: any) => this.onBlurEditorTextHandler(e));\n\n    // refresh layout on resize event.\n    // if (this._windowResizeSubscription) {\n    //   this._windowResizeSubscription.unsubscribe();\n    // }\n    // this._windowResizeSubscription = fromEvent(window, 'resize').subscribe(() => this._editor.layout());\n\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onInit,\n      target: this,\n      editor: this._editor\n    });\n  }\n\n  onChangeModelContentHandler(e){\n    const _value = this._editor.getValue();\n    \n    // monaco editor -> outside component\n    // https://github.com/JTangming/tm/issues/4 ngZoneè¯¦è§£\n    this.zone.run(() => this.value = _value);// value is not propagated to parent when executing outside zone.\n    // console.log(\"write from the monaco:\" + this._value);\n  }\n\n  onBlurEditorTextHandler(e){\n\n    this.onTouchedHandler();\n  }\n\n  private _value: string = '';\n\n  //get accessor\n  get value(): any {\n      return this._value;\n  };\n\n  //set accessor including call the onchange callback\n  set value(v: any) {\n    if (v !== this.value) {// æ³¨æè¿ç§åæ³ï¼å¼å¾å­¦ä¹ \n      this._value = v;\n    }\n\n    this.onChangeHandler(this.value);//å¨å±æ§ä¿®é¥°å¨éè°ç¨onchangeHandleræ¹æ³\n  }\n\n  localEditor(){//Demo: outside component -> monaco editor\n    this.writeValue('test');\n  }\n\n  // èªå®ä¹è¾å¥æ§ä»¶:3.2 implements ControlValueAccesso\n\n  // outside component -> monaco editor\n  \n  //From ControlValueAccessor interface\n  writeValue(value: any) {\n    this.value = value || '';\n\n    // Fix for value change while dispose in process.\n    setTimeout(() => {\n      if (this._editor /*&& !this.options.model*/) {\n        this._editor.setValue(this._value);\n        // console.log(\"write to the editor:\" + this._value);\n      }\n    });\n  }\n\n  //From ControlValueAccessor interface\n  registerOnChange(fn: any) {\n    this.onChangeHandler(this);\n  }\n\n  //From ControlValueAccessor interface\n  registerOnTouched(fn: any) {\n    this.onTouchedHandler();\n  }\n  \n  //ControlValueAccessoræä¾çäºä»¶åè°\n  onChangeHandler = (_: any) => { //Propagate Change to outside\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onChange,\n      target: this,\n      data: _\n    });\n  };\n\n  //ControlValueAccessoræä¾çäºä»¶åè°\n  onTouchedHandler = () => {\n    this.codeEditorEventService.fireEvent({ \n      eventName: CODE_EDITOR_EVENTS.onTouched,\n      target: this\n    });\n  };\n}","import { CommonModule } from '@angular/common';\n\nimport { ModuleWithProviders, NgModule } from '@angular/core';\nimport { ANGULAR_MONACO_EDITOR_CONFIG, AngularMonacoEditorConfig } from './config';\nimport { AngularMonacoEditorComponent } from './angular-monaco-editor/angular-monaco-editor.component';\n\n@NgModule({\n  imports: [\n    CommonModule\n  ],\n  declarations: [\n    AngularMonacoEditorComponent\n  ],\n  exports: [\n    AngularMonacoEditorComponent\n  ],\n  providers: [\n  ]\n})\n\nexport class AngularMonacoEditorModule {\n  public static forRoot(config: AngularMonacoEditorConfig = {}): ModuleWithProviders {\n    return {\n      ngModule: AngularMonacoEditorModule,\n      providers: [\n        { provide: ANGULAR_MONACO_EDITOR_CONFIG, useValue: config }\n      ]\n    };\n  }\n}\n"],"names":[],"mappings":"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"}
{
"name": "angular-monaco-editor",
"version": "1.2.0",
"version": "1.3.0",
"description": "To utilize the Monaco Code Editor as an Angular Component.",

@@ -5,0 +5,0 @@ "author": "courage007 <wang_xufa@163.com>",

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc