UNPKG

ngx-fastcomments

Version:

This is an Angular library for FastComments, a live embedded commenting library.

111 lines 13.4 kB
import { ChangeDetectionStrategy, Component, Input, ViewChild } from '@angular/core'; import * as i0 from "@angular/core"; var LoadStatus; (function (LoadStatus) { LoadStatus[LoadStatus["Started"] = 0] = "Started"; LoadStatus[LoadStatus["ScriptLoaded"] = 1] = "ScriptLoaded"; LoadStatus[LoadStatus["Done"] = 2] = "Done"; LoadStatus[LoadStatus["Error"] = 3] = "Error"; })(LoadStatus || (LoadStatus = {})); export class FastCommentsComponent { constructor() { this.state = { status: LoadStatus.Started }; } ngOnInit() { if (!this.config) { throw new Error('Configuration is required!Like: <lib-fastcomments [config]="myConfigObject"></lib-fastcomments>' + ' or <lib-fastcomments [config]="{ tenantId: \'demo\' }"></lib-fastcomments>'); } if (this.state.status === LoadStatus.ScriptLoaded) { return this.reset(); } else { return this.loadInstance(); } } ngOnChanges() { if (this.state.status === LoadStatus.ScriptLoaded) { return this.reset(); } } async insertScript(src, id, parentElement) { return new Promise((resolve, reject) => { const script = window.document.createElement('script'); script.async = true; script.src = src; script.id = id; parentElement.appendChild(script); script.addEventListener('load', resolve); script.addEventListener('error', reject); }); } async loadInstance() { return new Promise(async (resolve, reject) => { switch (this.state.status) { case LoadStatus.Started: try { // @ts-ignore if (window && !window.FastCommentsUI) { const src = this.config.region === 'eu' ? 'https://cdn-eu.fastcomments.com/js/embed-v2.min.js' : 'https://cdn.fastcomments.com/js/embed-v2.min.js'; await this.insertScript(src, 'fastcomments-widget-script', window.document.body); } this.state.status = LoadStatus.ScriptLoaded; await this.loadInstance(); resolve(); } catch (e) { console.error('FastComments Script Load Failure', e); this.state.status = LoadStatus.Error; reject(); } break; case LoadStatus.ScriptLoaded: this.instantiateWidget(); this.state.status = LoadStatus.Done; resolve(); break; default: resolve(); break; } }); } reset() { if (!this.config) { return; } if (this.lastWidgetInstance) { this.lastWidgetInstance.update(this.config); } else { this.instantiateWidget(); } } instantiateWidget() { const element = this.fastCommentsElement.nativeElement; if (element) { // @ts-ignore this.lastWidgetInstance = window.FastCommentsUI(element, this.config); } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FastCommentsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FastCommentsComponent, selector: "lib-fastcomments", inputs: { config: "config" }, viewQueries: [{ propertyName: "fastCommentsElement", first: true, predicate: ["fastCommentsElement"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: ` <div #fastCommentsElement></div> `, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FastCommentsComponent, decorators: [{ type: Component, args: [{ selector: 'lib-fastcomments', template: ` <div #fastCommentsElement></div> `, changeDetection: ChangeDetectionStrategy.OnPush }] }], ctorParameters: () => [], propDecorators: { config: [{ type: Input }], fastCommentsElement: [{ type: ViewChild, args: ['fastCommentsElement', { static: true, }] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fast-comments.component.js","sourceRoot":"","sources":["../../../../projects/fastcomments-angular/src/lib/fast-comments.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, ElementRef, Input, OnChanges, OnInit, ViewChild} from '@angular/core';\nimport {FastCommentsCommentWidgetConfig} from 'fastcomments-typescript';\n\nenum LoadStatus {\n  Started,\n  ScriptLoaded,\n  Done,\n  Error\n}\n\ninterface FastCommentsState {\n  status: LoadStatus;\n}\n\ninterface WidgetInstance {\n  destroy: () => void;\n  update: (FastCommentsCommentWidgetConfig) => void;\n}\n\n@Component({\n  selector: 'lib-fastcomments',\n  template: `\n    <div #fastCommentsElement></div>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  styles: []\n})\nexport class FastCommentsComponent implements OnInit, OnChanges {\n\n  @Input() config: FastCommentsCommentWidgetConfig;\n  @ViewChild('fastCommentsElement', {\n    static: true,\n  })\n  fastCommentsElement: ElementRef;\n  lastWidgetInstance: WidgetInstance | null;\n  state: FastCommentsState;\n\n  constructor() {\n    this.state = {\n      status: LoadStatus.Started\n    };\n  }\n\n  ngOnInit() {\n    if (!this.config) {\n      throw new Error('Configuration is required!Like: <lib-fastcomments [config]=\"myConfigObject\"></lib-fastcomments>' +\n        ' or <lib-fastcomments [config]=\"{ tenantId: \\'demo\\' }\"></lib-fastcomments>');\n    }\n    if (this.state.status === LoadStatus.ScriptLoaded) {\n      return this.reset();\n    } else {\n      return this.loadInstance();\n    }\n  }\n\n  ngOnChanges() {\n    if (this.state.status === LoadStatus.ScriptLoaded) {\n      return this.reset();\n    }\n  }\n\n  async insertScript(src: string, id: string, parentElement: Element) {\n    return new Promise((resolve, reject) => {\n      const script = window.document.createElement('script');\n      script.async = true;\n      script.src = src;\n      script.id = id;\n      parentElement.appendChild(script);\n\n      script.addEventListener('load', resolve);\n      script.addEventListener('error', reject);\n    });\n  }\n\n  async loadInstance() {\n    return new Promise<void>(async (resolve, reject) => {\n      switch (this.state.status) {\n        case LoadStatus.Started:\n          try {\n            // @ts-ignore\n            if (window && !window.FastCommentsUI) {\n              const src = this.config.region === 'eu' ? 'https://cdn-eu.fastcomments.com/js/embed-v2.min.js' : 'https://cdn.fastcomments.com/js/embed-v2.min.js';\n              await this.insertScript(src, 'fastcomments-widget-script', window.document.body);\n            }\n            this.state.status = LoadStatus.ScriptLoaded;\n            await this.loadInstance();\n            resolve();\n          } catch (e) {\n            console.error('FastComments Script Load Failure', e);\n            this.state.status = LoadStatus.Error;\n            reject();\n          }\n          break;\n        case LoadStatus.ScriptLoaded:\n          this.instantiateWidget();\n          this.state.status = LoadStatus.Done;\n          resolve();\n          break;\n        default:\n          resolve();\n          break;\n      }\n    });\n  }\n\n  reset() {\n    if (!this.config) {\n      return;\n    }\n    if (this.lastWidgetInstance) {\n      this.lastWidgetInstance.update(this.config);\n    } else {\n      this.instantiateWidget();\n    }\n  }\n\n  instantiateWidget() {\n    const element = this.fastCommentsElement.nativeElement;\n    if (element) {\n      // @ts-ignore\n      this.lastWidgetInstance = window.FastCommentsUI(element, this.config);\n    }\n  }\n\n}\n"]}