import {Component, EventEmitter, Inject, OnInit, Output, RendererFactory2, ViewEncapsulation} from '@angular/core'; import {ActivatedRoute} from '@angular/router'; import {DOCUMENT} from "@angular/common"; import {Subscriber} from "rxjs"; interface addthis { layers: Refresh; init: Function; toolbox: Function; } interface Refresh { refresh: Function; } declare var addthis: addthis; @Component({ selector: 'addThis', template: `
Do the share buttons not appear? Please make sure, any blocking addon is disabled, and then reload the page.
` }) export class AddThisComponent implements OnInit { subs=[]; showWarning = false; constructor(private route: ActivatedRoute, @Inject(DOCUMENT) private document, private rendererFactory: RendererFactory2) {} public ngOnDestroy() { for(let value of this.subs){ if (value instanceof Subscriber) { value.unsubscribe(); } else if (value instanceof Function) { value(); } } } ngOnInit() { this.subs.push(this.route.queryParams.subscribe(data => { this.showWarning = false; try { if (!this.document.getElementById('addThisScript') && typeof document !== 'undefined') { // console.log(" create script AddThis"); const renderer = this.rendererFactory.createRenderer(this.document, { id: '-1', encapsulation: ViewEncapsulation.None, styles: [], data: {} }); const head = this.document.body; if (head === null) { throw new Error(' not found within DOCUMENT.'); } const script = renderer.createElement('script'); renderer.setAttribute(script, "id", "addThisScript"); renderer.setAttribute(script, "src", "https://s7.addthis.com/js/300/addthis_widget.js#pubid=ra-559d24521cd8c080"); renderer.setAttribute(script, "type", "text/javascript"); renderer.appendChild(head, script); } if (typeof document !== 'undefined') { if(typeof addthis !== 'undefined' && addthis.layers && addthis.layers.refresh) { // console.log("Add This: Call Refresh") addthis.layers.refresh(); } } this.subs.push(setTimeout(() => { if(this.document.getElementById('addThis') && this.document.getElementById('addThis').innerText.length ==0){ this.showWarning = true; } }, 2000)); }catch (e) { // console.error(e) } })); } }