1 import { Component, ElementRef, Input, OnChanges, ViewChild } from '@angular/core'
2 import { CustomMarkupService } from './custom-markup.service'
5 selector: 'my-custom-markup-container',
6 templateUrl: './custom-markup-container.component.html'
8 export class CustomMarkupContainerComponent implements OnChanges {
9 @ViewChild('contentWrapper') contentWrapper: ElementRef<HTMLInputElement>
11 @Input() content: string
16 private customMarkupService: CustomMarkupService
19 async ngOnChanges () {
20 await this.buildElement()
23 private async buildElement () {
24 if (!this.content) return
26 const { rootElement, componentsLoaded } = await this.customMarkupService.buildElement(this.content)
27 this.contentWrapper.nativeElement.appendChild(rootElement)
29 await componentsLoaded