UNPKG

truly-ui

Version:

Web Components for Desktop Applications.

92 lines 15.3 kB
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"]}