angular-xml-editor
Version:
XML editor component for Angular
259 lines (258 loc) • 27.2 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { XMLCursorPositions } from './code/cursor/xmlCursorPos.class';
import { DomDummyNodeManager } from './code/dummyNodes/domDummyNodeManager.class';
import { Component, Input, ViewChild, Output, EventEmitter, Renderer2, forwardRef, ViewEncapsulation, ElementRef } from '@angular/core';
import { AngularXmlEditorService } from './angular-xml-editor.service';
import { Xml2html } from './code/xml-html-converter/xml2html.class';
import { Html2xml } from './code/xml-html-converter/html2xml.class';
export class AngularXmlEditorComponent {
/**
* @param {?} _renderer
* @param {?} editorService
*/
constructor(_renderer, editorService) {
this._renderer = _renderer;
this.editorService = editorService;
this.isDebugMode = false;
this.valueChange = new EventEmitter();
// actualXmlCursor: XmlCursor = new XmlCursor();
this.domDummyNodeManager = new DomDummyNodeManager();
}
/**
* @return {?}
*/
get config() {
if (this.editorContext !== undefined && this.editorContext.config !== undefined) {
return this.editorContext && this.editorContext.config;
}
return undefined;
}
/**
* @param {?} value
* @return {?}
*/
set editorContextId(value) {
if (!value) {
return;
}
this.editorContext = this.editorService.getEditorContext(value);
}
/**
* @param {?} value
* @return {?}
*/
set debugMode(value) {
this.isDebugMode = value;
}
/**
* @return {?}
*/
ngOnChanges() { }
/**
* @return {?}
*/
ngOnDestroy() { }
/**
* @return {?}
*/
onLostFocus() {
this.editorContext.saveSelection(); // save selection on lost focus
if (typeof this.onTouchedFunction === 'function') {
this.onTouchedFunction();
}
return;
}
/**
* @return {?}
*/
onGotFocus() {
this.editorContext.restoreSelection();
this.textArea.nativeElement.focus(); // set focus to the text area
}
/**
* @return {?}
*/
clicked() { }
/**
* @return {?}
*/
mousedown() { }
/**
* @param {?} mouseEvent
* @return {?}
*/
mouseup(mouseEvent) {
return this.editorContext.mouseUp(mouseEvent);
}
/**
* @param {?} text
* @return {?}
*/
pasted(text) {
return this.editorContext.pasted(text);
}
/**
* @return {?}
*/
copied() {
return this.editorContext.copied();
}
/**
* @param {?} event
* @return {?}
*/
keyDown(event) {
return this.editorContext.keyDown(event);
}
/**
* @param {?} event
* @return {?}
*/
keyUp(event) {
return this.editorContext.keyUp(event);
}
/**
* @param {?} xml
* @return {?}
*/
showXml(xml) {
if (this.textArea && this.editorContext && this.editorContext.config && this.editorContext.config.rules) {
if (xml === undefined) {
return;
}
/** @type {?} */
const xml2html = new Xml2html(this.editorContext.config.rules);
/** @type {?} */
const html = xml2html.ToHtml(xml);
/** @type {?} */
const normalizedValue = xml === null ? '' : html;
this._renderer.setProperty(this.textArea.nativeElement, 'innerHTML', normalizedValue);
}
}
/**
* Sets the function called when the control gets a change event
* @param {?} func
* @return {?}
*/
registerOnChange(func) {
this.onChangeFunction = func;
}
/**
* Sets the function called when the control gets a touch event
* @param {?} func
* @return {?}
*/
registerOnTouched(func) {
this.onTouchedFunction = func;
}
/**
* Write the new value to the element
* @param {?} value
* @return {?}
*/
writeValue(value) {
if (this.editorContext && this.editorContext.config) {
if (value === null || value === undefined || value === '') {
value = undefined;
}
this.showXml(value);
if (value === undefined) {
this.editorContext.actualCursor.xmlDocumentRootNode = undefined;
}
else {
/** @type {?} */
const el = /** @type {?} */ (this.textArea.nativeElement);
/** @type {?} */
const node = /** @type {?} */ (el.firstChild);
this.editorContext.actualCursor.xmlDocumentRootNode = node;
this.editorContext.actualCursor.StartPos.SetCursor(this.editorContext.actualCursor.xmlDocumentRootNode, XMLCursorPositions.CursorOnCompleteNode);
this.domDummyNodeManager.UpdateDummyNodes(this.editorContext.actualCursor.xmlDocumentRootNode);
}
}
}
/**
* Executed from the contenteditable section while the input property changes
* @param {?} html html string from contenteditable
* @return {?}
*/
onContentChange(html) {
if (typeof this.onChangeFunction === 'function') {
/** @type {?} */
const html2xml = new Html2xml(this.editorContext.config.rules);
/** @type {?} */
const xml = html2xml.ToXml(html);
/** @type {?} */
const normalizedValue = xml === null ? '' : xml;
this.onChangeFunction(normalizedValue);
}
return;
}
/**
* sets the disabled state for this element
* @param {?} isDisabled
* @return {?}
*/
setDisabledState(isDisabled) {
/** @type {?} */
const div = this.textArea.nativeElement;
/** @type {?} */
const action = isDisabled ? 'addClass' : 'removeClass';
this._renderer[action](div, 'disabled');
}
}
AngularXmlEditorComponent.decorators = [
{ type: Component, args: [{
selector: 'axed-editor',
template: "<div\r\n *ngIf=\"config\"\r\n #editor\r\n class=\"axed axed-textarea showtags debugOff\"\r\n (focus)=\"onGotFocus()\"\r\n [attr.contenteditable]=\"true\"\r\n [style.height]=\"config.height\"\r\n [style.width]=\"config.width\"\r\n (input)=\"onContentChange($event.target.innerHTML)\"\r\n (blur)=\"onLostFocus()\"\r\n (click)=\"clicked()\"\r\n (mousedown)=\"mousedown()\"\r\n (mouseup)=\"mouseup($event)\"\r\n (keyup)=\"keyUp($event)\"\r\n (keydown)=\"keyDown($event)\"\r\n (copy)=\"copied()\"\r\n (paste)=\"pasted($event.clipboardData.getData('text/plain'))\"\r\n></div>\r\n",
encapsulation: ViewEncapsulation.None,
// to prevent the scss to rename the class names and not match the new generated xml dom
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => AngularXmlEditorComponent),
multi: true
}
],
styles: ["a{cursor:pointer}.axed-textarea{min-height:150px;overflow:auto;margin-top:5px;resize:vertical;outline:0;--font-size:15px;--topBottomTagPadding:2px;--tagIndent:20px;font-size:var(--font-size);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Oxygen,Ubuntu,Cantarell,'Open Sans','Helvetica Neue',sans-serif}.axed-textarea.showtags{line-height:calc(var(--font-size) + (var(--topBottomTagPadding) * 2) + 10px)}.axed-textarea.showtags div::after,.axed-textarea.showtags div::before{background:orange;white-space:pre-wrap;border:1px solid #778899}.axed-textarea.showtags div::after,.axed-textarea.showtags div:not(.xmlTagNoClosing)::before{content:\" \" attr(data-tagname) \" \";padding:var(--topBottomTagPadding) 0 var(--topBottomTagPadding);margin:0 2px 2px}.axed-textarea.showtags div:not(.xmlTagNoClosing)::after{content:\" \" attr(data-tagname);padding-right:7px;border-radius:10px 0 0 10px}.axed-textarea.showtags div:not(.xmlTagNoClosing)::before{border-radius:0 10px 10px 0}.axed-textarea.showtags div[data-attributes].xmlTagNoClosing:not([data-attributes=''])::after,.axed-textarea.showtags div[data-attributes]:not([data-attributes='']):not(.xmlTagNoClosing)::before{content:\" \" attr(data-tagname) \" \" attr(data-attributes) \" \"}.axed-textarea.showtags div.comment::after,.axed-textarea.showtags div.comment::before{content:' ' 'comment' ' ';background-color:#d3d3d3}.axed-textarea div div:not(.floating){margin-left:var(--tagIndent)}.tagElement>.dummyNode.parent{color:red}div.floating{display:inline}span.dummyNode.beforefirstTag{float:left;width:0}.axed-textarea.debug span.dummyNode{background-color:red;width:inherit}.axed-textarea.debug span.dummyNode.beforefirstTag{background-color:violet;width:inherit}.axed-textarea.showtags div.selected,.axed-textarea.showtags div.selected::after,.axed-textarea.showtags div.selected::before{background:#add8e6!important;color:#fff}[data-tagname=parsererror],[data-tagname=parsererror] div,[data-tagname=parsererror] div ::after,[data-tagname=parsererror] div::before,[data-tagname=parsererror]::after,[data-tagname=parsererror]::before{background:red!important;color:#fff!important;font-weight:700!important;font-size:20px!important;line-height:32px!important}.angular-editor{position:relative}.angular-editor ::ng-deep [contenteditable=true]:empty:before{content:attr(placeholder);display:block;color:#868e96;opacity:1}.angular-editor .axed-wrapper{position:relative}.angular-editor .axed-wrapper .axed-textarea{min-height:5rem;padding:.5rem .8rem 1rem;border:1px solid #ddd;background-color:transparent;overflow-x:hidden;overflow-y:auto;z-index:2;position:relative}.angular-editor .axed-wrapper .axed-textarea.focus,.angular-editor .axed-wrapper .axed-textarea:focus{outline:0}.angular-editor .axed-wrapper .axed-textarea ::ng-deep blockquote{margin-left:1rem;border-left:.2em solid #dfe2e5;padding-left:.5rem}.angular-editor .axed-wrapper ::ng-deep p{margin-bottom:0}.angular-editor .axed-wrapper .axed-placeholder{display:none;position:absolute;top:0;padding:.5rem .8rem 1rem .9rem;z-index:1;color:#6c757d;opacity:.75}.angular-editor .axed-wrapper.show-placeholder .angular-editor-placeholder{display:block}.angular-editor .axed-wrapper.disabled{cursor:not-allowed;opacity:.5;pointer-events:none}.axed-attribute-editor-toolbar{min-height:100px;font:100 .8rem/15px Roboto,Arial,sans-serif;background-color:#f5f5f5;padding:15px;border:1px solid #ddd;margin:0}.axed-attribute-editor-toolbar input,.axed-attribute-editor-toolbar select{width:100%}"]
}] }
];
/** @nocollapse */
AngularXmlEditorComponent.ctorParameters = () => [
{ type: Renderer2 },
{ type: AngularXmlEditorService }
];
AngularXmlEditorComponent.propDecorators = {
config: [{ type: Input, args: ['config',] }],
editorContextId: [{ type: Input, args: ['editorContextId',] }],
debugMode: [{ type: Input, args: ['debugMode',] }],
textArea: [{ type: ViewChild, args: ['editor',] }],
editorWrapper: [{ type: ViewChild, args: ['editorWrapper',] }],
valueChange: [{ type: Output }]
};
if (false) {
/** @type {?} */
AngularXmlEditorComponent.prototype.editorContext;
/** @type {?} */
AngularXmlEditorComponent.prototype.isDebugMode;
/** @type {?} */
AngularXmlEditorComponent.prototype.textArea;
/** @type {?} */
AngularXmlEditorComponent.prototype.editorWrapper;
/** @type {?} */
AngularXmlEditorComponent.prototype.valueChange;
/** @type {?} */
AngularXmlEditorComponent.prototype.domDummyNodeManager;
/** @type {?} */
AngularXmlEditorComponent.prototype.onTouchedFunction;
/** @type {?} */
AngularXmlEditorComponent.prototype.onChangeFunction;
/** @type {?} */
AngularXmlEditorComponent.prototype._renderer;
/** @type {?} */
AngularXmlEditorComponent.prototype.editorService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-xml-editor.component.js","sourceRoot":"ng://angular-xml-editor/","sources":["lib/angular-xml-editor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { XmlEditorConfig } from './code/xmlEditorConfig';\r\nimport { XMLCursorPositions } from './code/cursor/xmlCursorPos.class';\r\nimport { DomDummyNodeManager } from './code/dummyNodes/domDummyNodeManager.class';\r\nimport { Component, OnChanges, Input, ViewChild, Output, EventEmitter, Renderer2, forwardRef, ViewEncapsulation, OnDestroy, ElementRef } from '@angular/core';\r\nimport { AngularXmlEditorService } from './angular-xml-editor.service';\r\nimport { XmlEditorContext } from './code/xmlEditorContext.class';\r\nimport { Xml2html } from './code/xml-html-converter/xml2html.class';\r\nimport { Html2xml } from './code/xml-html-converter/html2xml.class';\r\nimport { DebugContext } from '@angular/core/src/view';\r\n\r\n@Component({\r\n  selector: 'axed-editor',\r\n  templateUrl: './angular-xml-editor.component.html',\r\n  styleUrls: ['./angular-xml-editor.component.scss'],\r\n  encapsulation: ViewEncapsulation.None, // to prevent the scss to rename the class names and not match the new generated xml dom\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => AngularXmlEditorComponent),\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class AngularXmlEditorComponent implements ControlValueAccessor, OnChanges, OnDestroy {\r\n  private editorContext: XmlEditorContext;\r\n  isDebugMode = false;\r\n\r\n  @Input('config')\r\n  get config(): XmlEditorConfig {\r\n    if (this.editorContext !== undefined && this.editorContext.config !== undefined) {\r\n      return this.editorContext && this.editorContext.config;\r\n    }\r\n    return undefined;\r\n  }\r\n\r\n  @Input('editorContextId')\r\n  set editorContextId(value: string) {\r\n    if (!value) {\r\n      return;\r\n    }\r\n    this.editorContext = this.editorService.getEditorContext(value);\r\n  }\r\n\r\n  @Input('debugMode')\r\n  set debugMode(value: boolean) {\r\n    this.isDebugMode = value;\r\n  }\r\n\r\n  @ViewChild('editor')\r\n  textArea: ElementRef;\r\n  @ViewChild('editorWrapper')\r\n  editorWrapper: ElementRef;\r\n\r\n  @Output()\r\n  public valueChange = new EventEmitter();\r\n\r\n  // actualXmlCursor: XmlCursor = new XmlCursor();\r\n  domDummyNodeManager = new DomDummyNodeManager();\r\n\r\n  private onTouchedFunction: () => void;\r\n  private onChangeFunction: (value: string) => void;\r\n\r\n  constructor(private _renderer: Renderer2, private editorService: AngularXmlEditorService) {}\r\n\r\n  ngOnChanges() {}\r\n\r\n  ngOnDestroy(): void {}\r\n\r\n  onLostFocus() {\r\n    this.editorContext.saveSelection(); // save selection on lost focus\r\n    if (typeof this.onTouchedFunction === 'function') {\r\n      this.onTouchedFunction();\r\n    }\r\n    return;\r\n  }\r\n\r\n  onGotFocus() {\r\n    this.editorContext.restoreSelection();\r\n    this.textArea.nativeElement.focus(); // set focus to the text area\r\n  }\r\n\r\n  clicked() {}\r\n\r\n  mousedown() {}\r\n\r\n  mouseup(mouseEvent: MouseEvent) {\r\n    return this.editorContext.mouseUp(mouseEvent);\r\n  }\r\n\r\n  pasted(text: string): boolean {\r\n    return this.editorContext.pasted(text);\r\n  }\r\n\r\n  copied(): boolean {\r\n    return this.editorContext.copied();\r\n  }\r\n\r\n  keyDown(event: KeyboardEvent): boolean {\r\n    return this.editorContext.keyDown(event);\r\n  }\r\n\r\n  keyUp(event: KeyboardEvent): boolean {\r\n    return this.editorContext.keyUp(event);\r\n  }\r\n\r\n  // exec(): boolean {\r\n  //   let userSelection: Selection;\r\n  //   if (window.getSelection) {\r\n  //     userSelection = window.getSelection();\r\n  //     this.editorBreadCrumb.showSelection(userSelection);\r\n  //     this.actualXmlCursor.StartPos.SetCursor(userSelection.anchorNode, XMLCursorPositionen.CursorInsideTextNode, userSelection.anchorOffset);\r\n  //     this.commander.setCursorPos(this.actualXmlCursor.StartPos);\r\n  //   }\r\n\r\n  //   this.domDummyNodeManager.UpdateDummyNodes(this.actualXmlCursor.xmlDocumentRootNode, false);\r\n\r\n  //   return false;\r\n  // }\r\n\r\n  showXml(xml: string): void {\r\n    if (this.textArea && this.editorContext && this.editorContext.config && this.editorContext.config.rules) {\r\n      if (xml === undefined) {\r\n        return;\r\n      }\r\n\r\n      const xml2html = new Xml2html(this.editorContext.config.rules);\r\n      const html = xml2html.ToHtml(xml);\r\n      const normalizedValue = xml === null ? '' : html;\r\n      this._renderer.setProperty(this.textArea.nativeElement, 'innerHTML', normalizedValue);\r\n    }\r\n  }\r\n\r\n  /* START OF ControlValueAccessor  (see https://angular.io/api/forms/ControlValueAccessor ) */\r\n\r\n  /**\r\n   * Sets the function called when the control gets a change event\r\n   */\r\n  registerOnChange(func: any): void {\r\n    this.onChangeFunction = func;\r\n  }\r\n\r\n  /**\r\n   * Sets the function called when the control gets a touch event\r\n   */\r\n  registerOnTouched(func: any): void {\r\n    this.onTouchedFunction = func;\r\n  }\r\n\r\n  /**\r\n   * Write the new value to the element\r\n   */\r\n  writeValue(value: any): void {\r\n    if (this.editorContext && this.editorContext.config) {\r\n      if (value === null || value === undefined || value === '') {\r\n        value = undefined;\r\n      }\r\n\r\n      this.showXml(value);\r\n\r\n      if (value === undefined) {\r\n        this.editorContext.actualCursor.xmlDocumentRootNode = undefined;\r\n      } else {\r\n        const el = this.textArea.nativeElement as Element;\r\n        const node = el.firstChild as Element;\r\n        this.editorContext.actualCursor.xmlDocumentRootNode = node;\r\n        this.editorContext.actualCursor.StartPos.SetCursor(this.editorContext.actualCursor.xmlDocumentRootNode, XMLCursorPositions.CursorOnCompleteNode);\r\n        this.domDummyNodeManager.UpdateDummyNodes(this.editorContext.actualCursor.xmlDocumentRootNode);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Executed from the contenteditable section while the input property changes\r\n   * @param html html string from contenteditable\r\n   */\r\n  onContentChange(html: string): void {\r\n    if (typeof this.onChangeFunction === 'function') {\r\n      const html2xml = new Html2xml(this.editorContext.config.rules);\r\n      const xml = html2xml.ToXml(html);\r\n      const normalizedValue = xml === null ? '' : xml;\r\n      this.onChangeFunction(normalizedValue);\r\n    }\r\n    return;\r\n  }\r\n\r\n  /**\r\n   * sets the disabled state for this element\r\n   */\r\n  setDisabledState(isDisabled: boolean): void {\r\n    const div = this.textArea.nativeElement;\r\n    const action = isDisabled ? 'addClass' : 'removeClass';\r\n    this._renderer[action](div, 'disabled');\r\n  }\r\n\r\n  /* END OF ControlValueAccessor */\r\n}\r\n"]}