angular-monaco-editor
Advanced tools
Comparing version 1.2.0 to 1.3.0
@@ -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":";;;;;;;;;AAAA;;AAIA,uBAAa,4BAA4B,GAAG,IAAI,cAAc,CAAC,8BAA8B,CAAC;;;;;;ACJ9F,AAAO,uBAAM,kBAAkB,GAAG;IAC9B,MAAM,EAAE,QAAQ;IAChB,QAAQ,EAAE,UAAU;IACpB,SAAS,EAAE,WAAW;CACzB,CAAA;;;;;;ACJD;;0BASwB,MAAM,CAAC,IAAI,CAAC,kBAAkB,CAAC;uBAC5B,EAAE;;;;;;;IAMzB,QAAQ,CAAC,KAAK;QACV,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;;KAE/B;;;;;IAED,SAAS,CAAC,KAAK;QACX,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;;KAE7C;;;YAjBJ,UAAU;;;;;;;ACPX,AAYA,qBAAI,YAAY,GAAY,KAAK,CAAC;AAClC,qBAAI,WAA0B,CAAC;;;AAI/B,uBAAa,gCAAgC,GAAQ;;IAEnD,OAAO,EAAE,iBAAiB;;IAC1B,WAAW,EAAE,UAAU,CAAC,MAAM,4BAA4B,CAAC;;IAC3D,KAAK,EAAE,IAAI;CACZ,CAAC;;;AAaF;;;;;;IAmCE,YAAoB,IAAY,EAAgD,QAA2C,sBAA8C;QAArJ,SAAI,GAAJ,IAAI,CAAQ;QAAgD,WAAM,GAAN,MAAM;QAAqC,2BAAsB,GAAtB,sBAAsB,CAAwB;sBA+GhJ,EAAE;;+BAgDT,CAAC,CAAM;;YACvB,IAAI,CAAC,sBAAsB,CAAC,SAAS,CAAC;gBACpC,SAAS,EAAE,kBAAkB,CAAC,QAAQ;gBACtC,MAAM,EAAE,IAAI;gBACZ,IAAI,EAAE,CAAC;aACR,CAAC,CAAC;SACJ;;gCAGkB;YACjB,IAAI,CAAC,sBAAsB,CAAC,SAAS,CAAC;gBACpC,SAAS,EAAE,kBAAkB,CAAC,SAAS;gBACvC,MAAM,EAAE,IAAI;aACb,CAAC,CAAC;SACJ;;QA1KC,uBAAM,IAAI,GAAG,IAAI,CAAC;QAClB,sBAAsB,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,IAAI;;YAE7C,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,YAAY,EAAO,CAAC;YACrC,uBAAM,SAAS,GAAG,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YACnC,sBAAsB,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;SAC5C,CAAC,CAAC;KAEJ;;;;;QAjCG,OAAO,CAAC,OAAY;;QAEtB,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC;QACvE,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;YACvB,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;SAC1B;;;;;IAEH,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC;KACtB;;;;IAyBD,eAAe;QACb,IAAI,YAAY,EAAE;;YAEhB,WAAW,CAAC,IAAI,CAAC;gBACf,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;aAC/B,CAAC,CAAC;SACJ;aAAM;YACL,YAAY,GAAG,IAAI,CAAC;YACpB,WAAW,GAAG,IAAI,OAAO,CAAO,CAAC,OAAY;gBAC3C,uBAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,SAAS,CAAC;;;;;gBAKjD,uBAAM,cAAc,GAAQ;;oBAE1B,mBAAM,MAAM,GAAE,OAAO,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,GAAG,OAAO,YAAY,EAAE,EAAE,CAAC,CAAC;oBAC1E,mBAAM,MAAM,GAAE,OAAO,CAAC,CAAC,uBAAuB,CAAC,EAAE;wBAC/C,IAAI,OAAO,IAAI,CAAC,MAAM,CAAC,YAAY,KAAK,UAAU,EAAE;4BAClD,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;yBAC5B;wBACD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;wBAC9B,OAAO,EAAE,CAAC;qBACX,CAAC,CAAC;iBACJ,CAAC;;gBAGF,IAAI,CAAC,mBAAM,MAAM,GAAE,OAAO,EAAE;oBAC1B,uBAAM,YAAY,GAAsB,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;oBACzE,YAAY,CAAC,IAAI,GAAG,iBAAiB,CAAC;oBACtC,YAAY,CAAC,GAAG,GAAG,GAAG,OAAO,sBAAsB,CAAC;oBACpD,YAAY,CAAC,gBAAgB,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;oBACtD,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;iBACzC;qBAAM;oBACL,cAAc,EAAE,CAAC;iBAClB;aACF,CAAC,CAAC;SACJ;KACF;;;;IAED,WAAW;;;;QAIT,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;YACvB,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;SAC1B;KACF;;;;;IAES,UAAU,CAAC,OAAY;QAC/B,OAAO,CAAC,GAAG,CAAC,qCAAqC,CAAC,CAAC;;;;QASnD,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QAElF,AAAe;YACb,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SACpC;;QAGD,IAAI,CAAC,OAAO,CAAC,uBAAuB,CAAC,CAAC,CAAM,KAAK,IAAI,CAAC,2BAA2B,CAAC,CAAC,CAAC,CAAC,CAAC;QAEtF,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,CAAC,CAAM,KAAK,IAAI,CAAC,uBAAuB,CAAC,CAAC,CAAC,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,2BAA2B,CAAC,CAAC;QAC3B,uBAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;;;QAIvC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,CAAC;;KAE1C;;;;;IAED,uBAAuB,CAAC,CAAC;QAEvB,IAAI,CAAC,gBAAgB,EAAE,CAAC;KACzB;;;;IAKD,IAAI,KAAK;QACL,OAAO,IAAI,CAAC,MAAM,CAAC;KACtB;;;;;;IAGD,IAAI,KAAK,CAAC,CAAM;QACd,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,EAAE;;YACpB,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;SACjB;QAED,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;KAClC;;;;IAED,WAAW;;QACT,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;KACzB;;;;;IAOD,UAAU,CAAC,KAAU;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,IAAI,EAAE,CAAC;;QAGzB,UAAU,CAAC;YACT,IAAI,IAAI,CAAC,OAAO,6BAA6B;gBAC3C,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;;aAEpC;SACF,CAAC,CAAC;KACJ;;;;;IAGD,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;KAC5B;;;;;IAGD,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,gBAAgB,EAAE,CAAC;KACzB;;;YA1MF,SAAS,SAAC;gBACT,QAAQ,EAAE,uBAAuB;gBACjC,QAAQ,EAAE,wCAAwC;gBAClD,MAAM,EAAE,CAAC,iEAAiE,CAAC;;gBAE3E,SAAS,EAAE,CAAC,gCAAgC,EAAE,sBAAsB,CAAC;aACtE;;;;YA7B4B,MAAM;4CAqEE,MAAM,SAAC,4BAA4B;YA/D/D,sBAAsB;;;iCAkC5B,SAAS,SAAC,YAAY;uBAEtB,MAAM;yBACN,MAAM;0BACN,MAAM;wBAEN,KAAK,SAAC,SAAS;;;;;;;AC/ClB;;;;;IAqBS,OAAO,OAAO,CAAC,SAAoC,EAAE;QAC1D,OAAO;YACL,QAAQ,EAAE,yBAAyB;YACnC,SAAS,EAAE;gBACT,EAAE,OAAO,EAAE,4BAA4B,EAAE,QAAQ,EAAE,MAAM,EAAE;aAC5D;SACF,CAAC;;;;YArBL,QAAQ,SAAC;gBACR,OAAO,EAAE;oBACP,YAAY;iBACb;gBACD,YAAY,EAAE;oBACZ,4BAA4B;iBAC7B;gBACD,OAAO,EAAE;oBACP,4BAA4B;iBAC7B;gBACD,SAAS,EAAE,EACV;aACF;;;;;;;;;;;;;;;"} |
@@ -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":";;;;;;;;;AAAA;;AAIA,qBAAa,4BAA4B,GAAG,IAAI,cAAc,CAAC,8BAA8B,CAAC;;;;;;ACJ9F,AAAO,qBAAM,kBAAkB,GAAG;IAC9B,MAAM,EAAE,QAAQ;IAChB,QAAQ,EAAE,UAAU;IACpB,SAAS,EAAE,WAAW;CACzB,CAAA;;;;;;ACJD;;0BASwB,MAAM,CAAC,IAAI,CAAC,kBAAkB,CAAC;uBAC5B,EAAE;;;;;;;;;;;IAMzB,yCAAQ;;;;;IAAR,UAAS,KAAK;QACV,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;;KAE/B;;;;;IAED,0CAAS;;;;IAAT,UAAU,KAAK;QACX,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;;KAE7C;;gBAjBJ,UAAU;;iCAPX;;;;;;;ACAA,AAYA,qBAAI,YAAY,GAAY,KAAK,CAAC;AAClC,qBAAI,WAA0B,CAAC;;;AAI/B,qBAAa,gCAAgC,GAAQ;;IAEnD,OAAO,EAAE,iBAAiB;;IAC1B,WAAW,EAAE,UAAU,CAAC,cAAM,OAAA,4BAA4B,GAAA,CAAC;;IAC3D,KAAK,EAAE,IAAI;CACZ,CAAC;;;;;;;;;;;IAgDA,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,OAAO,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,IAAI,IAAI,CAAC,OAAO,EAAE;gBAChB,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;gBACvB,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;aAC1B;;;;;;;;IA6BH,sDAAe;;;IAAf;QAAA,iBAsCC;QArCC,IAAI,YAAY,EAAE;;YAEhB,WAAW,CAAC,IAAI,CAAC;gBACf,KAAI,CAAC,UAAU,CAAC,KAAI,CAAC,OAAO,CAAC,CAAC;aAC/B,CAAC,CAAC;SACJ;aAAM;YACL,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,GAAE,OAAO,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAK,OAAO,eAAY,EAAE,EAAE,CAAC,CAAC;oBAC1E,mBAAM,MAAM,GAAE,OAAO,CAAC,CAAC,uBAAuB,CAAC,EAAE;wBAC/C,IAAI,OAAO,KAAI,CAAC,MAAM,CAAC,YAAY,KAAK,UAAU,EAAE;4BAClD,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,IAAI,CAAC,mBAAM,MAAM,GAAE,OAAO,EAAE;oBAC1B,qBAAM,YAAY,GAAsB,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;oBACzE,YAAY,CAAC,IAAI,GAAG,iBAAiB,CAAC;oBACtC,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;qBAAM;oBACL,cAAc,EAAE,CAAC;iBAClB;aACF,CAAC,CAAC;SACJ;KACF;;;;IAED,kDAAW;;;IAAX;;;;QAIE,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,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;;;;QASnD,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QAElF,AAAe;YACb,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,GAAA,CAAC,CAAC;QAEtF,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,UAAC,CAAM,IAAK,OAAA,KAAI,CAAC,uBAAuB,CAAC,CAAC,CAAC,GAAA,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,GAAA,CAAC,CAAC;;KAE1C;;;;;IAED,8DAAuB;;;;IAAvB,UAAwB,CAAC;QAEvB,IAAI,CAAC,gBAAgB,EAAE,CAAC;KACzB;IAKD,sBAAI,+CAAK;;;;;QAAT;YACI,OAAO,IAAI,CAAC,MAAM,CAAC;SACtB;;;;;;QAGD,UAAU,CAAM;YACd,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,EAAE;;gBACpB,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;aACjB;YAED,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAClC;;;OATA;;;;IAWD,kDAAW;;;IAAX;;QACE,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;KACzB;;;;;;;;IAOD,iDAAU;;;;IAAV,UAAW,KAAU;QAArB,iBAUC;QATC,IAAI,CAAC,KAAK,GAAG,KAAK,IAAI,EAAE,CAAC;;QAGzB,UAAU,CAAC;YACT,IAAI,KAAI,CAAC,OAAO,6BAA6B;gBAC3C,KAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAI,CAAC,MAAM,CAAC,CAAC;;aAEpC;SACF,CAAC,CAAC;KACJ;;;;;;IAGD,uDAAgB;;;;IAAhB,UAAiB,EAAO;QACtB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;KAC5B;;;;;;IAGD,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;;;;;;;ACAA;;;;;;;IAqBgB,iCAAO;;;;cAAC,MAAsC;QAAtC,uBAAA,EAAA,WAAsC;QAC1D,OAAO;YACL,QAAQ,EAAE,yBAAyB;YACnC,SAAS,EAAE;gBACT,EAAE,OAAO,EAAE,4BAA4B,EAAE,QAAQ,EAAE,MAAM,EAAE;aAC5D;SACF,CAAC;;;gBArBL,QAAQ,SAAC;oBACR,OAAO,EAAE;wBACP,YAAY;qBACb;oBACD,YAAY,EAAE;wBACZ,4BAA4B;qBAC7B;oBACD,OAAO,EAAE;wBACP,4BAA4B;qBAC7B;oBACD,SAAS,EAAE,EACV;iBACF;;oCAlBD;;;;;;;;;;;;;;;"} |
{ | ||
"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
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
274143