truly-ui
Version:
Web Components for Desktop Applications.
92 lines • 15.3 kB
JavaScript
import { Injectable } from '@angular/core';
import { Subject } from 'rxjs';
import * as i0 from "@angular/core";
import * as i1 from "@angular/platform-browser";
export class EditorService {
constructor(domSanitizer) {
this.domSanitizer = domSanitizer;
this.compileSuject = new Subject();
}
decompile(html, tagsContent, fieldsContent) {
const htmlParsed = new DOMParser().parseFromString(html, 'text/html');
return new Promise((resolve) => {
const tagsDom = [];
const fieldsDom = [];
tagsContent.forEach((item) => {
tagsDom.push({
id: item.tag,
value: item.value,
element: htmlParsed.getElementById(item.tag),
});
});
fieldsContent.forEach((item) => {
fieldsDom.push({
id: item.field,
value: item.value,
element: htmlParsed.getElementById(item.field),
});
});
for (let i = 0; i < tagsDom.length; i++) {
if (tagsDom[i].element) {
const element = new DOMParser()
.parseFromString(`<span id="${tagsDom[i].id}" class="ui-hashtag">${tagsDom[i].id}</span>`, 'text/html').body.firstChild;
tagsDom[i].element.insertAdjacentElement('afterend', element);
tagsDom[i].element.remove();
}
}
for (let i = 0; i < fieldsDom.length; i++) {
if (fieldsDom[i].element) {
const element = new DOMParser()
.parseFromString(`<input id="${fieldsDom[i].id}" class="ui-field" value="${this.getFieldValue(fieldsDom[i])}">`, 'text/html').body.firstChild;
fieldsDom[i].element.insertAdjacentElement('afterend', element);
fieldsDom[i].element.remove();
}
}
resolve(this.domSanitizer.bypassSecurityTrustHtml(htmlParsed.body.innerHTML));
});
}
getFieldValue(field) {
if (field.element.innerText) {
return field.element.innerText;
}
return field.value || ' ';
}
compile(html, tagsContent, fieldsContent) {
const htmlParsed = new DOMParser().parseFromString(html, 'text/html').body;
return new Promise((resolve) => {
const tags = htmlParsed.querySelectorAll('.ui-hashtag');
for (let i = 0; i < tags.length; i++) {
const tagSelected = tagsContent.find(item => item.tag === this.getAttributeValue(tags[i].attributes, 'id'));
if (tagSelected) {
const element = new DOMParser()
.parseFromString(`<strong id="${tagSelected.tag}">${tagSelected.value}</strong>`, 'text/html').body.firstChild;
tags[i].insertAdjacentElement('afterend', element);
tags[i].remove();
}
}
const fields = htmlParsed.querySelectorAll('.ui-field');
for (let i = 0; i < fields.length; i++) {
const fieldSelected = fieldsContent.find(item => item.field === this.getAttributeValue(fields[i].attributes, 'id'));
const fieldValue = this.getAttributeValue(fields[i].attributes, 'value') || ' ';
const element = new DOMParser()
.parseFromString(`<strong id="${fieldSelected.field}">${fieldValue}</strong>`, 'text/html').body.firstChild;
fields[i].insertAdjacentElement('afterend', element);
fields[i].remove();
}
resolve(this.domSanitizer.bypassSecurityTrustHtml(htmlParsed.innerHTML));
});
}
getAttributeValue(attributes, name) {
for (let i = 0; i < attributes.length; i++) {
if (attributes[i].name === name) {
return attributes[i].value;
}
}
}
}
/** @nocollapse */ EditorService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: EditorService, deps: [{ token: i1.DomSanitizer }], target: i0.ɵɵFactoryTarget.Injectable });
/** @nocollapse */ EditorService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: EditorService });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: EditorService, decorators: [{
type: Injectable
}], ctorParameters: function () { return [{ type: i1.DomSanitizer }]; } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.service.js","sourceRoot":"","sources":["../../../../../projects/truly-ui/src/components/editor/services/editor.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable} from '@angular/core';\nimport {Subject} from 'rxjs';\nimport {DomSanitizer} from '@angular/platform-browser';\nimport {TagContent} from '../interfaces/tag-content';\nimport {FieldContent} from '../interfaces/field-content';\n\n@Injectable()\nexport class EditorService {\n\n  public compileSuject = new Subject();\n\n  constructor(private domSanitizer: DomSanitizer) {\n  }\n\n  decompile(html: string, tagsContent: TagContent[], fieldsContent: FieldContent[]) {\n    const htmlParsed = new DOMParser().parseFromString(html, 'text/html');\n    return new Promise((resolve) => {\n      const tagsDom = [];\n      const fieldsDom = [];\n      tagsContent.forEach((item) => {\n        tagsDom.push({\n          id: item.tag,\n          value: item.value,\n          element: htmlParsed.getElementById(item.tag),\n        });\n      });\n      fieldsContent.forEach((item) => {\n        fieldsDom.push({\n          id: item.field,\n          value: item.value,\n          element: htmlParsed.getElementById(item.field),\n        });\n      });\n      for (let i = 0; i < tagsDom.length; i++) {\n        if (tagsDom[i].element) {\n          const element = new DOMParser()\n            .parseFromString(`<span id=\"${tagsDom[i].id}\" class=\"ui-hashtag\">${tagsDom[i].id}</span>`, 'text/html').body.firstChild;\n          tagsDom[i].element.insertAdjacentElement('afterend', <Element>element);\n          tagsDom[i].element.remove();\n        }\n      }\n      for (let i = 0; i < fieldsDom.length; i++) {\n        if (fieldsDom[i].element) {\n          const element = new DOMParser()\n            .parseFromString(`<input id=\"${fieldsDom[i].id}\" class=\"ui-field\" value=\"${this.getFieldValue(fieldsDom[i])}\">`,\n              'text/html').body.firstChild;\n          fieldsDom[i].element.insertAdjacentElement('afterend', <Element>element);\n          fieldsDom[i].element.remove();\n        }\n      }\n      resolve(this.domSanitizer.bypassSecurityTrustHtml(htmlParsed.body.innerHTML));\n    });\n  }\n\n  private getFieldValue( field ) {\n    if ( field.element.innerText ) {\n      return field.element.innerText;\n    }\n    return field.value || ' ';\n  }\n\n  compile(html: string, tagsContent: TagContent[], fieldsContent: FieldContent[]) {\n    const htmlParsed = new DOMParser().parseFromString(html, 'text/html').body;\n    return new Promise((resolve) => {\n\n      const tags = htmlParsed.querySelectorAll('.ui-hashtag');\n      for (let i = 0; i < tags.length; i++) {\n        const tagSelected = tagsContent.find(item => item.tag === this.getAttributeValue(tags[i].attributes, 'id'));\n        if (tagSelected) {\n          const element = new DOMParser()\n            .parseFromString(`<strong id=\"${tagSelected.tag}\">${tagSelected.value}</strong>`, 'text/html').body.firstChild;\n          tags[i].insertAdjacentElement('afterend', <Element>element);\n          tags[i].remove();\n        }\n      }\n\n      const fields = htmlParsed.querySelectorAll('.ui-field');\n      for (let i = 0; i < fields.length; i++) {\n        const fieldSelected = fieldsContent.find(item => item.field === this.getAttributeValue(fields[i].attributes, 'id'));\n        const fieldValue = this.getAttributeValue(fields[i].attributes, 'value') || ' ';\n        const element = new DOMParser()\n          .parseFromString(`<strong id=\"${fieldSelected.field}\">${fieldValue}</strong>`, 'text/html').body.firstChild;\n        fields[i].insertAdjacentElement('afterend', <Element>element);\n        fields[i].remove();\n      }\n\n      resolve(this.domSanitizer.bypassSecurityTrustHtml(htmlParsed.innerHTML));\n    });\n  }\n\n  private getAttributeValue(attributes, name) {\n    for (let i = 0; i < attributes.length; i++) {\n      if (attributes[i].name === name) {\n        return attributes[i].value;\n      }\n    }\n  }\n}\n\n"]}