@ng-doc/app
Version:
<!-- PROJECT LOGO --> <br /> <div align="center"> <a href="https://github.com/ng-doc/ng-doc"> <img src="https://ng-doc.com/assets/images/ng-doc.svg?raw=true" alt="Logo" height="150px"> </a>
1 lines • 16.9 kB
Source Map (JSON)
{"version":3,"file":"ng-doc-app-processors-page-processor.mjs","sources":["../tmp-esm2022/processors/page-processor/page-processor.component.js","../tmp-esm2022/processors/page-processor/ng-doc-app-processors-page-processor.js"],"sourcesContent":["import { ApplicationRef, ChangeDetectionStrategy, Component, ElementRef, EventEmitter, HostBinding, inject, Injector, Input, Output, Renderer2, ViewContainerRef, } from '@angular/core';\nimport { NG_DOC_PAGE_CUSTOM_PROCESSOR, NG_DOC_PAGE_PROCESSOR } from '@ng-doc/app/tokens';\nimport { asArray } from '@ng-doc/core/helpers/as-array';\nimport { objectKeys } from '@ng-doc/core/helpers/object-keys';\nimport * as i0 from \"@angular/core\";\n/**\n * Base processor class to create a processor directive that will be used to replace\n * html nodes with an Angular component.\n */\nexport class NgDocPageProcessorComponent {\n constructor() {\n this.html = '';\n this.afterRender = new EventEmitter();\n this.processors = inject(NG_DOC_PAGE_PROCESSOR, { optional: true }) ?? [];\n this.customProcessors = inject(NG_DOC_PAGE_CUSTOM_PROCESSOR, { optional: true }) ??\n [];\n this.elementRef = inject(ElementRef);\n this.viewContainerRef = inject(ViewContainerRef);\n this.applicationRef = inject(ApplicationRef);\n this.injector = inject(Injector);\n this.renderer = inject(Renderer2);\n }\n ngOnChanges({ html }) {\n if (html) {\n Promise.resolve().then(() => {\n asArray(this.processors, this.customProcessors).forEach(this.process.bind(this));\n this.applicationRef.tick();\n this.afterRender.emit();\n });\n }\n }\n process(processor) {\n Array.from(this.elementRef.nativeElement.querySelectorAll(processor.selector)).forEach((elementNode) => {\n // check if element node has a parent node because it can be removed by another processor\n if (elementNode.parentNode) {\n const replaceElement = (processor.nodeToReplace && processor.nodeToReplace(elementNode, this.injector)) ??\n elementNode;\n const options = processor.extractOptions(elementNode, this.elementRef.nativeElement);\n // create component\n const componentRef = this.viewContainerRef.createComponent(processor.component, {\n projectableNodes: options.content,\n injector: this.injector,\n });\n // set component options\n if (options.inputs) {\n objectKeys(options.inputs).forEach((key) => options.inputs && componentRef.setInput(key, options.inputs[key]));\n }\n // replace element node with component node\n replaceElement.parentNode?.replaceChild(componentRef.location.nativeElement, replaceElement);\n componentRef.changeDetectorRef.markForCheck();\n }\n });\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.0.3\", ngImport: i0, type: NgDocPageProcessorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }\n static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: \"14.0.0\", version: \"20.0.3\", type: NgDocPageProcessorComponent, isStandalone: true, selector: \"[ngDocPageProcessor]\", inputs: { html: [\"ngDocPageProcessor\", \"html\"] }, outputs: { afterRender: \"afterRender\" }, host: { properties: { \"innerHTML\": \"this.html\" } }, usesOnChanges: true, ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.0.3\", ngImport: i0, type: NgDocPageProcessorComponent, decorators: [{\n type: Component,\n args: [{\n selector: '[ngDocPageProcessor]',\n standalone: true,\n template: '<ng-content></ng-content>',\n changeDetection: ChangeDetectionStrategy.OnPush,\n }]\n }], propDecorators: { html: [{\n type: Input,\n args: [{ required: true, alias: 'ngDocPageProcessor' }]\n }, {\n type: HostBinding,\n args: ['innerHTML']\n }], afterRender: [{\n type: Output\n }] } });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-processor.component.js","sourceRoot":"","sources":["../../../../../../libs/app/processors/page-processor/page-processor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ApplicationRef,\n  ChangeDetectionStrategy,\n  Component,\n  ComponentRef,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  inject,\n  Injector,\n  Input,\n  OnChanges,\n  Output,\n  Renderer2,\n  SimpleChanges,\n  ViewContainerRef,\n} from '@angular/core';\nimport { SafeHtml } from '@angular/platform-browser';\nimport { NgDocPageProcessor, NgDocProcessorOptions } from '@ng-doc/app/interfaces';\nimport { NG_DOC_PAGE_CUSTOM_PROCESSOR, NG_DOC_PAGE_PROCESSOR } from '@ng-doc/app/tokens';\nimport { asArray } from '@ng-doc/core/helpers/as-array';\nimport { objectKeys } from '@ng-doc/core/helpers/object-keys';\n\n/**\n * Base processor class to create a processor directive that will be used to replace\n * html nodes with an Angular component.\n */\n@Component({\n  selector: '[ngDocPageProcessor]',\n  standalone: true,\n  template: '<ng-content></ng-content>',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgDocPageProcessorComponent implements OnChanges {\n  @Input({ required: true, alias: 'ngDocPageProcessor' })\n  @HostBinding('innerHTML')\n  html: SafeHtml = '';\n\n  @Output()\n  afterRender: EventEmitter<void> = new EventEmitter<void>();\n\n  processors: Array<NgDocPageProcessor<unknown>> =\n    inject<Array<NgDocPageProcessor<unknown>>>(NG_DOC_PAGE_PROCESSOR, { optional: true }) ?? [];\n  customProcessors: Array<NgDocPageProcessor<unknown>> =\n    inject<Array<NgDocPageProcessor<unknown>>>(NG_DOC_PAGE_CUSTOM_PROCESSOR, { optional: true }) ??\n    [];\n\n  protected readonly elementRef: ElementRef<HTMLElement> = inject(ElementRef);\n  protected readonly viewContainerRef: ViewContainerRef = inject(ViewContainerRef);\n  protected readonly applicationRef = inject(ApplicationRef);\n  protected readonly injector: Injector = inject(Injector);\n  protected readonly renderer: Renderer2 = inject(Renderer2);\n\n  ngOnChanges({ html }: SimpleChanges): void {\n    if (html) {\n      Promise.resolve().then(() => {\n        asArray(this.processors, this.customProcessors).forEach(this.process.bind(this));\n        this.applicationRef.tick();\n        this.afterRender.emit();\n      });\n    }\n  }\n\n  private process<T>(processor: NgDocPageProcessor<T>): void {\n    Array.from(this.elementRef.nativeElement.querySelectorAll(processor.selector)).forEach(\n      (elementNode: Element) => {\n        // check if element node has a parent node because it can be removed by another processor\n        if (elementNode.parentNode) {\n          const replaceElement: Element =\n            (processor.nodeToReplace && processor.nodeToReplace(elementNode, this.injector)) ??\n            elementNode;\n          const options: NgDocProcessorOptions<T> = processor.extractOptions(\n            elementNode,\n            this.elementRef.nativeElement,\n          );\n\n          // create component\n          const componentRef: ComponentRef<T> = this.viewContainerRef.createComponent(\n            processor.component,\n            {\n              projectableNodes: options.content,\n              injector: this.injector,\n            },\n          );\n\n          // set component options\n          if (options.inputs) {\n            objectKeys(options.inputs).forEach(\n              (key: keyof T) =>\n                options.inputs && componentRef.setInput(key as string, options.inputs[key]),\n            );\n          }\n\n          // replace element node with component node\n          replaceElement.parentNode?.replaceChild(\n            componentRef.location.nativeElement,\n            replaceElement,\n          );\n\n          componentRef.changeDetectorRef.markForCheck();\n        }\n      },\n    );\n  }\n}\n"]}","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctZG9jLWFwcC1wcm9jZXNzb3JzLXBhZ2UtcHJvY2Vzc29yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hcHAvcHJvY2Vzc29ycy9wYWdlLXByb2Nlc3Nvci9uZy1kb2MtYXBwLXByb2Nlc3NvcnMtcGFnZS1wcm9jZXNzb3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0="],"names":[],"mappings":"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"}