Socket
Socket
Sign inDemoInstall

ng-gpt

Package Overview
Dependencies
5
Maintainers
1
Versions
10
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 0.0.4 to 0.0.5

LICENSE

26

bundles/ng-gpt.umd.js

@@ -856,2 +856,5 @@ (function (global, factory) {

this.config = config;
this.sizes = "fluid";
this.sizeMapping = [];
this.targetingArguments = {};
this.afterRefresh = new i0.EventEmitter();

@@ -863,3 +866,3 @@ this.scripts = [];

if (slot === _this.slot) {
_this.afterRefresh.emit({ type: 'refresh', slot: slot });
_this.afterRefresh.emit({ type: "refresh", slot: slot });
}

@@ -873,3 +876,3 @@ });

!_this.refresh &&
_this.config.onSameNavigation === 'refresh') {
_this.config.onSameNavigation === "refresh") {
_this.refreshContent.call(_this);

@@ -882,3 +885,4 @@ }

GptAdDirective.prototype.ngOnInit = function () {
if (common.isPlatformBrowser(this.platformID)) {
this.checkRequiredFields(this.adUnit, "adUnit");
if (common.isPlatformBrowser(this.platformID) && !this.id) {
this.gptIDGenerator.gptIDGenerator(this.elementRef.nativeElement);

@@ -931,6 +935,6 @@ }

}
googletag.pubads().addEventListener('slotRenderEnded', function (event) {
googletag.pubads().addEventListener("slotRenderEnded", function (event) {
if (event.slot === _this.slot) {
_this.afterRefresh.emit({
type: 'renderEnded',
type: "renderEnded",
slot: _this.slot,

@@ -960,3 +964,3 @@ data: event,

this.gptRefresh.slotRefresh(this.slot, this.refresh, true).then(function (slot) {
_this.afterRefresh.emit({ type: 'init', slot: slot });
_this.afterRefresh.emit({ type: "init", slot: slot });
});

@@ -972,7 +976,4 @@ };

GptAdDirective.prototype.getState = function () {
this.checkRequiredFields(this.id, 'id');
this.checkRequiredFields(this.adUnit, 'path');
this.checkRequiredFields(this.sizes, 'sizes');
return Object.freeze({
sizes: this.sizes,
sizes: typeof this.sizes === "string" ? [this.sizes] : this.sizes,
sizeMapping: this.sizeMapping,

@@ -995,5 +996,2 @@ targetingArguments: this.targetingArguments,

};
GptAdDirective.prototype.addSize = function (size) {
this.sizes.push(size);
};
GptAdDirective.prototype.addExclusion = function (exclusion) {

@@ -1011,3 +1009,3 @@ this.exclusions.push(exclusion);

type: i0.Directive,
args: [{ selector: 'gpt-ad' }]
args: [{ selector: "gpt-ad" }]
}], ctorParameters: function () {

@@ -1014,0 +1012,0 @@ return [{ type: Object, decorators: [{

@@ -5,2 +5,2 @@ import { InjectionToken } from '@angular/core';

export const GPT_CONFIG = new InjectionToken('gptConfig');
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3B0LmNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25nLWdwdC9zcmMvbGliL2dwdC5jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUcvQyxNQUFNLE9BQU8sU0FBUztDQWdCckI7QUFFRCxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUcsSUFBSSxjQUFjLENBQVksV0FBVyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTGF6eUxvYWRPcHRpb25zQ29uZmlnLCBTYWZlRnJhbWVDb25maWcgfSBmcm9tICcuL2dwdC5pbnRlcmZhY2UnO1xuXG5leHBvcnQgY2xhc3MgR3B0Q29uZmlnIHtcbiAgaWRsZUxvYWQ/OiBib29sZWFuO1xuICBvblNhbWVOYXZpZ2F0aW9uPzogJ3JlZnJlc2gnIHwgJ2lnbm9yZSc7XG4gIHNpbmdsZVJlcXVlc3RNb2RlPzogYm9vbGVhbjtcbiAgZW5hYmxlVmlkZW9BZHM/OiBib29sZWFuO1xuICBwZXJzb25hbGl6ZWRBZHM/OiBib29sZWFuO1xuICBjb2xsYXBzZUVtcHR5RGl2cz86IGJvb2xlYW47XG4gIGNlbnRlcmluZz86IGJvb2xlYW47XG4gIGFkZHJlc3M/OiBzdHJpbmc7XG4gIGNvb2tpZXM/OiBib29sZWFuO1xuICBmb3JjZVNhZmVGcmFtZT86IGJvb2xlYW47XG4gIHBwaWQ/OiBzdHJpbmc7XG4gIGdsb2JhbFRhcmdldGluZzogb2JqZWN0O1xuICBzYWZlRnJhbWVDb25maWc/OiBTYWZlRnJhbWVDb25maWc7XG4gIGVuYWJsZUxhenlMb2FkPzogTGF6eUxvYWRPcHRpb25zQ29uZmlnO1xuICBsb2FkR1BUPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGNvbnN0IEdQVF9DT05GSUcgPSBuZXcgSW5qZWN0aW9uVG9rZW48R3B0Q29uZmlnPignZ3B0Q29uZmlnJyk7XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3B0LmNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL25nLWdwdC9zcmMvbGliL2dwdC5jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUcvQyxNQUFNLE9BQU8sU0FBUztDQWdCckI7QUFFRCxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUcsSUFBSSxjQUFjLENBQVksV0FBVyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTGF6eUxvYWRPcHRpb25zQ29uZmlnLCBTYWZlRnJhbWVDb25maWcgfSBmcm9tICcuL2dwdC5pbnRlcmZhY2UnO1xuXG5leHBvcnQgY2xhc3MgR3B0Q29uZmlnIHtcbiAgaWRsZUxvYWQ/OiBib29sZWFuO1xuICBvblNhbWVOYXZpZ2F0aW9uPzogJ3JlZnJlc2gnIHwgJ2lnbm9yZSc7XG4gIHNpbmdsZVJlcXVlc3RNb2RlPzogYm9vbGVhbjtcbiAgZW5hYmxlVmlkZW9BZHM/OiBib29sZWFuO1xuICBwZXJzb25hbGl6ZWRBZHM/OiBib29sZWFuO1xuICBjb2xsYXBzZUVtcHR5RGl2cz86IGJvb2xlYW47XG4gIGNlbnRlcmluZz86IGJvb2xlYW47XG4gIGFkZHJlc3M/OiBzdHJpbmc7XG4gIGNvb2tpZXM/OiBib29sZWFuO1xuICBmb3JjZVNhZmVGcmFtZT86IGJvb2xlYW47XG4gIHBwaWQ/OiBzdHJpbmc7XG4gIGdsb2JhbFRhcmdldGluZz86IG9iamVjdDtcbiAgc2FmZUZyYW1lQ29uZmlnPzogU2FmZUZyYW1lQ29uZmlnO1xuICBlbmFibGVMYXp5TG9hZD86IExhenlMb2FkT3B0aW9uc0NvbmZpZztcbiAgbG9hZEdQVD86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBjb25zdCBHUFRfQ09ORklHID0gbmV3IEluamVjdGlvblRva2VuPEdwdENvbmZpZz4oJ2dwdENvbmZpZycpO1xuIl19
export const GPT_URL = '//www.googletagservices.com/tag/js/gpt.js';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3B0LmNvbnRhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZ3B0L3NyYy9saWIvZ3B0LmNvbnRhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRywyQ0FBMkMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBHUFRfVVJMID0gJy8vd3d3Lmdvb2dsZXRhZ3NlcnZpY2VzLmNvbS90YWcvanMvZ3B0LmpzJztcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3B0LmNvbnRhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbmctZ3B0L3NyYy9saWIvZ3B0LmNvbnRhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRywyQ0FBMkMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBHUFRfVVJMID0gJy8vd3d3Lmdvb2dsZXRhZ3NlcnZpY2VzLmNvbS90YWcvanMvZ3B0LmpzJztcbiJdfQ==

@@ -1,6 +0,6 @@

import { isPlatformBrowser } from '@angular/common';
import { Directive, EventEmitter, Inject, Input, Optional, Output, PLATFORM_ID, } from '@angular/core';
import { NavigationEnd } from '@angular/router';
import { filter } from 'rxjs/operators';
import { GPT_CONFIG } from './gpt.config';
import { isPlatformBrowser } from "@angular/common";
import { Directive, EventEmitter, Inject, Input, Optional, Output, PLATFORM_ID, } from "@angular/core";
import { NavigationEnd } from "@angular/router";
import { filter } from "rxjs/operators";
import { GPT_CONFIG } from "./gpt.config";
import * as i0 from "@angular/core";

@@ -22,2 +22,5 @@ import * as i1 from "./gpt.service";

this.config = config;
this.sizes = "fluid";
this.sizeMapping = [];
this.targetingArguments = {};
this.afterRefresh = new EventEmitter();

@@ -29,3 +32,3 @@ this.scripts = [];

if (slot === this.slot) {
this.afterRefresh.emit({ type: 'refresh', slot: slot });
this.afterRefresh.emit({ type: "refresh", slot: slot });
}

@@ -39,3 +42,3 @@ });

!this.refresh &&
this.config.onSameNavigation === 'refresh') {
this.config.onSameNavigation === "refresh") {
this.refreshContent.call(this);

@@ -48,3 +51,4 @@ }

ngOnInit() {
if (isPlatformBrowser(this.platformID)) {
this.checkRequiredFields(this.adUnit, "adUnit");
if (isPlatformBrowser(this.platformID) && !this.id) {
this.gptIDGenerator.gptIDGenerator(this.elementRef.nativeElement);

@@ -95,6 +99,6 @@ }

}
googletag.pubads().addEventListener('slotRenderEnded', (event) => {
googletag.pubads().addEventListener("slotRenderEnded", (event) => {
if (event.slot === this.slot) {
this.afterRefresh.emit({
type: 'renderEnded',
type: "renderEnded",
slot: this.slot,

@@ -123,3 +127,3 @@ data: event,

this.gptRefresh.slotRefresh(this.slot, this.refresh, true).then((slot) => {
this.afterRefresh.emit({ type: 'init', slot: slot });
this.afterRefresh.emit({ type: "init", slot: slot });
});

@@ -131,7 +135,4 @@ }

getState() {
this.checkRequiredFields(this.id, 'id');
this.checkRequiredFields(this.adUnit, 'path');
this.checkRequiredFields(this.sizes, 'sizes');
return Object.freeze({
sizes: this.sizes,
sizes: typeof this.sizes === "string" ? [this.sizes] : this.sizes,
sizeMapping: this.sizeMapping,

@@ -154,5 +155,2 @@ targetingArguments: this.targetingArguments,

}
addSize(size) {
this.sizes.push(size);
}
addExclusion(exclusion) {

@@ -169,3 +167,3 @@ this.exclusions.push(exclusion);

type: Directive,
args: [{ selector: 'gpt-ad' }]
args: [{ selector: "gpt-ad" }]
}], ctorParameters: function () { return [{ type: Object, decorators: [{

@@ -200,2 +198,2 @@ type: Inject,

}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gpt.directive.js","sourceRoot":"","sources":["../../../../projects/ng-gpt/src/lib/gpt.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformBrowser } from '@angular/common';\nimport {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnDestroy,\n  Optional,\n  Output,\n  PLATFORM_ID,\n} from '@angular/core';\nimport { Router, NavigationEnd } from '@angular/router';\nimport { Subscription } from 'rxjs';\nimport { filter } from 'rxjs/operators';\nimport { GptConfig, GPT_CONFIG } from './gpt.config';\nimport { Googletag, Slot } from './gpt.interface';\nimport { GptService } from './gpt.service';\nimport { GptRefreshService } from './services';\nimport { GptIDGeneratorService } from './services/gpt-idGenerator.service';\n\ndeclare var googletag: Googletag;\n\nexport class GptRefreshEvent {\n  type: string;\n  slot: any;\n  data?: any;\n}\n\ninterface SizeMapping {\n  viewport: [number, number];\n  sizes: [number, number][];\n}\n\ninterface TargetingArguments {\n  [key: string]: any;\n}\n\n@Directive({ selector: 'gpt-ad' })\nexport class GptAdDirective implements AfterViewInit, OnDestroy {\n  @Input() id: string;\n  @Input() adUnit: string;\n  @Input() sizes: [number, number][];\n  @Input() sizeMapping: SizeMapping[];\n  @Input() forceSafeFrame: boolean;\n  @Input() safeFrameConfig: string;\n  @Input() refresh: number;\n  @Input() collapseEmptyDivs: boolean;\n  @Input() targetingArguments: TargetingArguments;\n\n  @Output() afterRefresh: EventEmitter<GptRefreshEvent> = new EventEmitter();\n\n  private slot: Slot;\n  private onSameNavigation: Subscription;\n  private scripts: any[] = [];\n  private exclusions: any[] = [];\n\n  constructor(\n    @Inject(PLATFORM_ID) private platformID: Object,\n    private elementRef: ElementRef,\n    private gpt: GptService,\n    private gptRefresh: GptRefreshService,\n    private gptIDGenerator: GptIDGeneratorService,\n    @Inject(GPT_CONFIG) private config: GptConfig,\n    @Optional() router: Router\n  ) {\n    if (isPlatformBrowser(this.platformID)) {\n      this.gptRefresh.refreshEvent.subscribe((slot) => {\n        if (slot === this.slot) {\n          this.afterRefresh.emit({ type: 'refresh', slot: slot });\n        }\n      });\n      if (router) {\n        this.onSameNavigation = router.events\n          .pipe(filter((event) => event instanceof NavigationEnd))\n          .subscribe((event: any) => {\n            if (\n              this.slot &&\n              !this.refresh &&\n              this.config.onSameNavigation === 'refresh'\n            ) {\n              this.refreshContent.call(this);\n            }\n          });\n      }\n    }\n  }\n\n  ngOnInit() {\n    if (isPlatformBrowser(this.platformID)) {\n      this.gptIDGenerator.gptIDGenerator(this.elementRef.nativeElement);\n    }\n  }\n\n  ngAfterViewInit() {\n    if (isPlatformBrowser(this.platformID)) {\n      this.gpt.defineTask(() => {\n        this.defineSlot();\n      });\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.slot) {\n      googletag.destroySlots([this.slot]);\n    }\n    if (this.onSameNavigation) {\n      this.onSameNavigation.unsubscribe();\n    }\n  }\n\n  private setSizeMapping(slot) {\n    const ad = this.getState();\n\n    if (ad.sizeMapping.length === 0) {\n      return;\n    }\n\n    const sizeMapping = googletag.sizeMapping();\n\n    ad.sizeMapping.forEach((mapping) => {\n      sizeMapping.addSize(mapping.viewport, mapping.sizes);\n    });\n\n    slot.defineSizeMapping(sizeMapping.build());\n  }\n\n  private defineSlot() {\n    const ad = this.getState(),\n      element = this.elementRef.nativeElement;\n\n    this.slot = googletag.defineSlot(ad.adUnit, ad.sizes, element.id);\n\n    if (\n      this.forceSafeFrame !== undefined &&\n      ad.forceSafeFrame === !this.config.forceSafeFrame\n    ) {\n      this.slot.setForceSafeFrame(ad.forceSafeFrame);\n    }\n\n    // if (ad.clickUrl) {\n    //   this.slot.setClickUrl(ad.clickUrl);\n    // }\n\n    if (ad.collapseEmptyDivs) {\n      this.slot.setCollapseEmptyDiv(true, true);\n    }\n\n    if (ad.safeFrameConfig) {\n      this.slot.setSafeFrameConfig(JSON.parse(ad.safeFrameConfig));\n    }\n\n    googletag.pubads().addEventListener('slotRenderEnded', (event) => {\n      if (event.slot === this.slot) {\n        this.afterRefresh.emit({\n          type: 'renderEnded',\n          slot: this.slot,\n          data: event,\n        });\n      }\n    });\n\n    this.setSizeMapping(this.slot);\n\n    Object.keys(ad.targetingArguments).forEach((arg) => {\n      this.slot.setTargeting(arg, ad.targetingArguments[arg]);\n    });\n\n    ad.exclusions.forEach((exclusion) => {\n      this.slot.setCategoryExclusion(exclusion);\n    });\n\n    ad.scripts.forEach((script) => {\n      script(this.slot);\n    });\n\n    if (this.config.enableVideoAds) {\n      this.slot.addService(googletag.companionAds());\n    }\n\n    this.slot.addService(googletag.pubads());\n\n    this.refreshContent();\n  }\n\n  private refreshContent() {\n    this.gptRefresh.slotRefresh(this.slot, this.refresh, true).then((slot) => {\n      this.afterRefresh.emit({ type: 'init', slot: slot });\n    });\n  }\n\n  get isHidden() {\n    return this.gptRefresh.hiddenCheck(this.elementRef.nativeElement);\n  }\n\n  getState() {\n    this.checkRequiredFields(this.id, 'id');\n    this.checkRequiredFields(this.adUnit, 'path');\n    this.checkRequiredFields(this.sizes, 'sizes');\n\n    return Object.freeze({\n      sizes: this.sizes,\n      sizeMapping: this.sizeMapping,\n      targetingArguments: this.targetingArguments,\n      exclusions: this.exclusions,\n      adUnit: this.adUnit,\n      forceSafeFrame: this.forceSafeFrame === true,\n      safeFrameConfig: this.safeFrameConfig,\n      // clickUrl: this.clickUrl,\n      refresh: this.refresh,\n      scripts: this.scripts,\n      collapseEmptyDivs: this.collapseEmptyDivs === true,\n    });\n  }\n\n  checkRequiredFields(input: any, name: string) {\n    if (input === null) {\n      throw new Error(`Attribute ${name} is required`);\n    }\n  }\n\n  addSize(size) {\n    this.sizes.push(size);\n  }\n\n  addExclusion(exclusion) {\n    this.exclusions.push(exclusion);\n  }\n\n  addScript(script) {\n    this.scripts.push(script);\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gpt.directive.js","sourceRoot":"","sources":["../../../../ng-gpt/src/lib/gpt.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformBrowser } from \"@angular/common\";\nimport {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  PLATFORM_ID,\n} from \"@angular/core\";\nimport { Router, NavigationEnd } from \"@angular/router\";\nimport { Subscription } from \"rxjs\";\nimport { filter } from \"rxjs/operators\";\nimport { GptConfig, GPT_CONFIG } from \"./gpt.config\";\nimport { Googletag, Slot } from \"./gpt.interface\";\nimport { GptService } from \"./gpt.service\";\nimport { GptRefreshService } from \"./services\";\nimport { GptIDGeneratorService } from \"./services/gpt-idGenerator.service\";\n\ndeclare var googletag: Googletag;\n\nexport class GptRefreshEvent {\n  type: string;\n  slot: any;\n  data?: any;\n}\n\ninterface SizeMapping {\n  viewport: [number, number];\n  sizes: [number, number][];\n}\n\ninterface TargetingArguments {\n  [key: string]: any;\n}\n\n@Directive({ selector: \"gpt-ad\" })\nexport class GptAdDirective implements OnInit, AfterViewInit, OnDestroy {\n  @Input() id: string;\n  @Input() adUnit: string;\n  @Input() sizes: [number, number][] | string = \"fluid\";\n  @Input() sizeMapping: SizeMapping[] = [];\n  @Input() forceSafeFrame: boolean;\n  @Input() safeFrameConfig: string;\n  @Input() refresh: number;\n  @Input() collapseEmptyDivs: boolean;\n  @Input() targetingArguments: TargetingArguments = {};\n\n  @Output() afterRefresh: EventEmitter<GptRefreshEvent> = new EventEmitter();\n\n  private slot: Slot;\n  private onSameNavigation: Subscription;\n  private scripts: any[] = [];\n  private exclusions: any[] = [];\n\n  constructor(\n    @Inject(PLATFORM_ID) private platformID: Object,\n    private elementRef: ElementRef,\n    private gpt: GptService,\n    private gptRefresh: GptRefreshService,\n    private gptIDGenerator: GptIDGeneratorService,\n    @Inject(GPT_CONFIG) private config: GptConfig,\n    @Optional() router: Router\n  ) {\n    if (isPlatformBrowser(this.platformID)) {\n      this.gptRefresh.refreshEvent.subscribe((slot) => {\n        if (slot === this.slot) {\n          this.afterRefresh.emit({ type: \"refresh\", slot: slot });\n        }\n      });\n      if (router) {\n        this.onSameNavigation = router.events\n          .pipe(filter((event) => event instanceof NavigationEnd))\n          .subscribe((event: any) => {\n            if (\n              this.slot &&\n              !this.refresh &&\n              this.config.onSameNavigation === \"refresh\"\n            ) {\n              this.refreshContent.call(this);\n            }\n          });\n      }\n    }\n  }\n\n  ngOnInit() {\n    this.checkRequiredFields(this.adUnit, \"adUnit\");\n    if (isPlatformBrowser(this.platformID) && !this.id) {\n      this.gptIDGenerator.gptIDGenerator(this.elementRef.nativeElement);\n    }\n  }\n\n  ngAfterViewInit() {\n    if (isPlatformBrowser(this.platformID)) {\n      this.gpt.defineTask(() => {\n        this.defineSlot();\n      });\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.slot) {\n      googletag.destroySlots([this.slot]);\n    }\n    if (this.onSameNavigation) {\n      this.onSameNavigation.unsubscribe();\n    }\n  }\n\n  private setSizeMapping(slot) {\n    const ad = this.getState();\n\n    if (ad.sizeMapping.length === 0) {\n      return;\n    }\n\n    const sizeMapping = googletag.sizeMapping();\n\n    ad.sizeMapping.forEach((mapping) => {\n      sizeMapping.addSize(mapping.viewport, mapping.sizes);\n    });\n\n    slot.defineSizeMapping(sizeMapping.build());\n  }\n\n  private defineSlot() {\n    const ad = this.getState(),\n      element = this.elementRef.nativeElement;\n\n    this.slot = googletag.defineSlot(ad.adUnit, ad.sizes, element.id);\n\n    if (\n      this.forceSafeFrame !== undefined &&\n      ad.forceSafeFrame === !this.config.forceSafeFrame\n    ) {\n      this.slot.setForceSafeFrame(ad.forceSafeFrame);\n    }\n\n    // if (ad.clickUrl) {\n    //   this.slot.setClickUrl(ad.clickUrl);\n    // }\n\n    if (ad.collapseEmptyDivs) {\n      this.slot.setCollapseEmptyDiv(true, true);\n    }\n\n    if (ad.safeFrameConfig) {\n      this.slot.setSafeFrameConfig(JSON.parse(ad.safeFrameConfig));\n    }\n\n    googletag.pubads().addEventListener(\"slotRenderEnded\", (event) => {\n      if (event.slot === this.slot) {\n        this.afterRefresh.emit({\n          type: \"renderEnded\",\n          slot: this.slot,\n          data: event,\n        });\n      }\n    });\n\n    this.setSizeMapping(this.slot);\n\n    Object.keys(ad.targetingArguments).forEach((arg) => {\n      this.slot.setTargeting(arg, ad.targetingArguments[arg]);\n    });\n\n    ad.exclusions.forEach((exclusion) => {\n      this.slot.setCategoryExclusion(exclusion);\n    });\n\n    ad.scripts.forEach((script) => {\n      script(this.slot);\n    });\n\n    if (this.config.enableVideoAds) {\n      this.slot.addService(googletag.companionAds());\n    }\n\n    this.slot.addService(googletag.pubads());\n\n    this.refreshContent();\n  }\n\n  private refreshContent() {\n    this.gptRefresh.slotRefresh(this.slot, this.refresh, true).then((slot) => {\n      this.afterRefresh.emit({ type: \"init\", slot: slot });\n    });\n  }\n\n  get isHidden() {\n    return this.gptRefresh.hiddenCheck(this.elementRef.nativeElement);\n  }\n\n  getState() {\n    return Object.freeze({\n      sizes: typeof this.sizes === \"string\" ? [this.sizes] : this.sizes,\n      sizeMapping: this.sizeMapping,\n      targetingArguments: this.targetingArguments,\n      exclusions: this.exclusions,\n      adUnit: this.adUnit,\n      forceSafeFrame: this.forceSafeFrame === true,\n      safeFrameConfig: this.safeFrameConfig,\n      // clickUrl: this.clickUrl,\n      refresh: this.refresh,\n      scripts: this.scripts,\n      collapseEmptyDivs: this.collapseEmptyDivs === true,\n    });\n  }\n\n  checkRequiredFields(input: any, name: string) {\n    if (input === null) {\n      throw new Error(`Attribute ${name} is required`);\n    }\n  }\n\n  addExclusion(exclusion) {\n    this.exclusions.push(exclusion);\n  }\n\n  addScript(script) {\n    this.scripts.push(script);\n  }\n}\n"]}
export {};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gpt.interface.js","sourceRoot":"","sources":["../../../../projects/ng-gpt/src/lib/gpt.interface.ts"],"names":[],"mappings":"","sourcesContent":["import { GeneralSize, SingleSizeArray, SizeMappingArray } from './gpt.type';\n\ninterface ResponseInformation {\n  advertiserId: string;\n  campaignId: string;\n  creativeId?: number | undefined;\n  creativeTemplateId?: number | undefined;\n  lineItemId?: number | undefined;\n}\n\nexport interface SafeFrameConfig {\n  allowOverlayExpansion?: boolean | undefined;\n  allowPushExpansion?: boolean | undefined;\n  sandbox?: boolean | undefined;\n  useUniqueDomain?: boolean | null | undefined;\n}\n\nexport interface LazyLoadOptionsConfig {\n  fetchMarginPercent?: number | undefined;\n  renderMarginPercent?: number | undefined;\n  mobileScaling?: number | undefined;\n}\n\ninterface PrivacySettingsConfig {\n  childDirectedTreatment?: boolean | null | undefined;\n  limitedAds?: boolean | null | undefined;\n  restrictDataProcessing?: boolean | null | undefined;\n  underAgeOfConsent?: boolean | null | undefined;\n}\n\ninterface CommandArray {\n  push(f: () => void): number;\n}\n\nexport interface Service {\n  addEventListener(\n    eventType: 'slotRenderEnded',\n    listener: (event: SlotRenderEndedEvent) => void\n  ): Service;\n  addEventListener(\n    eventType: 'slotRequested',\n    listener: (event: SlotRequestedEvent) => void\n  ): Service;\n  addEventListener(\n    eventType: 'slotResponseReceived',\n    listener: (event: SlotResponseReceived) => void\n  ): Service;\n  addEventListener(\n    eventType: 'slotVisibilityChanged',\n    listener: (event: SlotVisibilityChangedEvent) => void\n  ): Service;\n  addEventListener(\n    eventType: string,\n    listener: (event: Event) => void\n  ): Service;\n  getSlots(): Slot[];\n}\n\ninterface CompanionAdsService extends Service {\n  enableSyncLoading(): void;\n  setRefreshUnfilledSlots(value: boolean): void;\n}\n\ninterface ContentService extends Service {\n  setContent(slot: Slot, content: string): void;\n}\n\nexport interface PubAdsService extends Service {\n  /**\n   * Removes the ads from the given slots and replaces them with blank content.\n   *\n   * @param opt_slots The array of slots to clear. Array is optional; all slots will be cleared if it is unspecified.\n   */\n  clear(opt_slots?: Slot[]): boolean;\n\n  /**\n   * Clears all page-level ad category exclusion labels.\n   */\n  clearCategoryExclusions(): PubAdsService;\n\n  /**\n   * Clears custom targeting parameters for a specific key or for all keys.\n   *\n   * @param opt_key Targeting parameter key. The key is optional; all targeting parameters will be cleared if it is unspecified.\n   */\n  clearTargeting(opt_key?: string): PubAdsService;\n\n  /**\n   * Enables collapsing of slot divs so that they don't take up any space on the page when there is no ad content to display.\n   *\n   * @param opt_collapseBeforeAdFetch Whether to collapse the slots even before the ads are fetched. This parameter is optional; if not provided, false will be used as the default value.\n   */\n  collapseEmptyDivs(opt_collapseBeforeAdFetch?: boolean): boolean;\n\n  /**\n   * Disables requests for ads on page load, but allows ads to be requested with a `googletag.pubads().refresh()` call.\n   */\n  disableInitialLoad(): void;\n\n  /**\n   * Constructs and displays an ad slot with the given ad unit path and size.\n   *\n   * @param adUnitPath The ad unit path of slot to be rendered.\n   * @param size Width and height of the slot.\n   * @param opt_div Either the ID of the div containing the slot or the div element itself.\n   * @param opt_clickUrl The click URL to use on this slot.\n   */\n  display(\n    adUnitPath: string,\n    size: GeneralSize,\n    opt_div?: string | Element,\n    opt_clickUrl?: string\n  ): Slot;\n\n  /**\n   * Enables lazy loading in GPT as defined by the config object.\n   *\n   * @param opt_config Configuration object allows customization of lazy loading behavior. Any omitted configurations will use a default set by Google that will be tuned over time. To disable a particular setting, such as a fetching margin, set the value to -1.\n   *\n   * fetchMarginPercent is the minimum distance from the current viewport a slot must be before we fetch the ad as a percentage of viewport size. 0 means \"when the slot enters the viewport\", 100 means \"when the ad is 1 viewport away\", and so on.\n   *\n   * renderMarginPercent is the minimum distance from the current viewport a slot must be before we render an ad. This allows for prefetching the ad, but waiting to render and download other subresources. The value works just like fetchMarginPercent as a percentage of viewport.\n   *\n   * mobileScaling is a multiplier applied to margins on mobile devices. This allows varying margins on mobile vs. desktop. For example, a mobileScaling of 2.0 will multiply all margins by 2 on mobile devices, increasing the minimum distance a slot can be before fetching and rendering.\n   */\n  enableLazyLoad(opt_config?: LazyLoadOptionsConfig): void;\n\n  /**\n   * Enables single request mode for fetching multiple ads at the same time.\n   */\n  enableSingleRequest(): boolean;\n\n  /**\n   * Signals to GPT that video ads will be present on the page.\n   */\n  enableVideoAds(): void;\n\n  /**\n   * Returns the value for the AdSense attribute associated with the given key.\n   *\n   * @param key Name of the attribute to look for.\n   */\n  get(key: string): string | null;\n\n  /**\n   * Returns the attribute keys that have been set on this service.\n   */\n  getAttributeKeys(): string[];\n\n  /**\n   * Returns a specific custom service-level targeting parameter that has been set.\n   *\n   * @param key The targeting key to look for.\n   */\n  getTargeting(key: string): string[];\n\n  /**\n   * Returns the list of all custom service-level targeting keys that have been set.\n   */\n  getTargetingKeys(): string[];\n\n  /**\n   * Returns whether or not initial requests for ads was successfully disabled by a previous disableInitialLoad call.\n   */\n  isInitialLoadDisabled(): boolean;\n\n  /**\n   * Fetches and displays new ads for specific or all slots on the page.\n   *\n   * @param opt_slots The slots to refresh. Array is optional; all slots will be refreshed if it is unspecified.\n   * @param opt_options Configuration options associated with this refresh call. changeCorrelator specifies whether or not a new correlator is to be generated for fetching ads. Our ad servers maintain this correlator value briefly (currently for 30 seconds, but subject to change), such that requests with the same correlator received close together will be considered a single page view. By default a new correlator is generated for every refresh. Note that this option has no effect on GPT's long-lived pageview, which automatically reflects the ads currently on the page and has no expiration time.\n   */\n  refresh(\n    opt_slots?: Slot[],\n    opt_options?: { changeCorrelator: boolean }\n  ): void;\n\n  /**\n   * Sets values for AdSense attributes that apply to all ad slots under the publisher ads service.\n   *\n   * @param key The name of the attribute.\n   * @param value Attribute value.\n   */\n  set(key: string, value: string): PubAdsService;\n\n  /**\n   * Sets a page-level ad category exclusion for the given label name.\n   *\n   * @param categoryExclusion The ad category exclusion label to add.\n   */\n  setCategoryExclusion(categoryExclusion: string): PubAdsService;\n\n  /**\n   * Enables and disables horizontal centering of ads.\n   *\n   * @param centerAds true to center ads, false to left-align them.\n   */\n  setCentering(centerAds: boolean): void;\n\n  /**\n   * Sets options for ignoring Google Ad Manager cookies on the current page.\n   *\n   * @param cookieOptions The cookie options to set. Possible values are:\n   *\n   * 0: Enables Google Ad Manager cookies on ad requests on the page. This option is set by default.\n   *\n   * 1: Ignores Google Ad Manager cookies on subsequent ad requests and prevents cookies from being created on the page. Note that cookies will not be ignored on certain pingbacks and that this option will disable features that rely on cookies, such as dynamic allocation.\n   */\n  setCookieOptions(cookieOptions: number): PubAdsService;\n\n  /**\n   * Configures whether all ads on the page should be forced to be rendered using a SafeFrame container.\n   *\n   * @param forceSafeFrame true to force all ads on the page to be rendered in SafeFrames and false to change the previous setting to false. Setting this to false when unspecified earlier, won't change anything.\n   */\n  setForceSafeFrame(forceSafeFrame: boolean): PubAdsService;\n\n  /**\n   * Passes location information from websites so you can geo-target line items to specific locations.\n   *\n   * @param address Freeform address.\n   */\n  setLocation(address: string): PubAdsService;\n\n  /**\n   * Allows configuration of all privacy settings from a single API using a config object.\n   * @param privacySettings\n   */\n  setPrivacySettings(privacySettings: PrivacySettingsConfig): Slot;\n\n  /**\n   * Sets the value for the publisher-provided ID.\n   *\n   * @param ppid An alphanumeric ID provided by the publisher with a recommended maximum of 150 characters.\n   */\n  setPublisherProvidedId(ppid: string): PubAdsService;\n\n  /**\n   * Configures whether the page should request personalized or non-personalized ads.\n   *\n   * @param nonPersonalizedAds 0 for personalized ads, 1 for non-personalized ads.\n   */\n  setRequestNonPersonalizedAds(nonPersonalizedAds: 0 | 1): PubAdsService;\n\n  /**\n   * Sets the page-level preferences for SafeFrame configuration.\n   *\n   * @param config The configuration object.\n   */\n  setSafeFrameConfig(config: SafeFrameConfig): PubAdsService;\n\n  /**\n   * Sets a custom targeting parameter for this slot.\n   *\n   * @param key Targeting parameter key.\n   * @param value Targeting parameter value or array of values.\n   */\n  setTargeting(key: string, value: string | string[]): PubAdsService;\n\n  /**\n   * Sets the video content information to be sent along with the ad requests for targeting and content exclusion purposes.\n   *\n   * @param videoContentId The video content ID.\n   * @param videoCmsId The video CMS ID.\n   */\n  setVideoContent(videoContentId: string, videoCmsId: string): void;\n\n  /**\n   * Changes the correlator that is sent with ad requests, effectively starting a new page view.\n   */\n  updateCorrelator(): PubAdsService;\n}\n\ninterface SizeMappingBuilder {\n  /**\n   * Adds a mapping from a single-size array representing the viewport to either a single-size array or a multi-size array representing the slot.\n   *\n   * @param viewportSize The size of the viewport for this mapping entry.\n   * @param slotSize The sizes of the slot for this mapping entry.\n   */\n  addSize(\n    viewportSize: SingleSizeArray,\n    slotSize: GeneralSize\n  ): SizeMappingBuilder;\n\n  /**\n   * Builds a size map specification from the mappings added to this builder.\n   */\n  build(): SizeMappingArray;\n}\n\ninterface Event {\n  serviceName: string;\n  slot: Slot;\n}\n\ninterface SlotRenderEndedEvent extends Event {\n  advertiserId?: number | undefined;\n  campaignId?: number | undefined;\n  creativeId?: number | undefined;\n  isEmpty: boolean;\n  lineItemId?: number | undefined;\n  size: number[] | string;\n  sourceAgnosticCreativeId?: number | undefined;\n  sourceAgnosticLineItemId?: number | undefined;\n}\n\n// tslint:disable-next-line:no-empty-interface\ninterface SlotRequestedEvent extends Event {}\n\n// tslint:disable-next-line:no-empty-interface\ninterface SlotResponseReceived extends Event {}\n\ninterface SlotVisibilityChangedEvent extends Event {\n  inViewPercentage: number;\n}\n\nexport interface Slot {\n  /**\n   * Adds a service to this slot.\n   *\n   * @param service The service to be added.\n   */\n  addService(service: Service): Slot;\n\n  /**\n   * Clears all slot-level ad category exclusion labels for this slot.\n   */\n  clearCategoryExclusions(): Slot;\n\n  /**\n   * Clears specific or all custom slot-level targeting parameters for this slot.\n   *\n   * @param opt_key Targeting parameter key. The key is optional; all targeting parameters will be cleared if it is unspecified.\n   */\n  clearTargeting(opt_key?: string): Slot;\n\n  /**\n   * Sets an array of mappings from a minimum viewport size to slot size for this slot.\n   *\n   * @param sizeMapping Array of size mappings. You can use `googletag.SizeMappingBuilder` to create it. Each size mapping is an array of two elements: `googletag.SingleSizeArray` and `googletag.GeneralSize`.\n   */\n  defineSizeMapping(sizeMapping: SizeMappingArray): Slot;\n\n  /**\n   * Returns the value for the AdSense attribute associated with the given key.\n   *\n   * @param key Name of the attribute to look for.\n   */\n  get(key: string): string | null;\n\n  /**\n   * Returns the full path of the ad unit, with the network code and ad unit path.\n   */\n  getAdUnitPath(): string;\n\n  /**\n   * Returns the list of attribute keys set on this slot.\n   */\n  getAttributeKeys(): string[];\n\n  /**\n   * Returns the ad category exclusion labels for this slot.\n   */\n  getCategoryExclusions(): string[];\n\n  /**\n   * Returns the ad response information.\n   */\n  getResponseInformation(): ResponseInformation;\n\n  /**\n   * Returns the id of the slot element provided when the slot was defined.\n   */\n  getSlotElementId(): string;\n\n  /**\n   * Returns a specific custom targeting parameter set on this slot.\n   *\n   * @param key The targeting key to look for.\n   */\n  getTargeting(key: string): string[];\n\n  /**\n   * Returns the list of all custom targeting keys set on this slot.\n   */\n  getTargetingKeys(): string[];\n\n  /**\n   * Sets a value for an AdSense attribute on a particular ad slot.\n   *\n   * @param key The name of the attribute.\n   * @param value Attribute value.\n   */\n  set(key: string, value: string): Slot;\n\n  /**\n   * Sets a slot-level ad category exclusion label on this slot.\n   *\n   * @param categoryExclusion The ad category exclusion label to add.\n   */\n  setCategoryExclusion(categoryExclusion: string): Slot;\n\n  /**\n   * Sets the click URL to which users will be redirected after clicking on the ad.\n   *\n   * @param value The click URL to set.\n   */\n  setClickUrl(value: string): Slot;\n\n  /**\n   * Sets whether the slot div should be hidden when there is no ad in the slot.\n   *\n   * @param collapse Whether to collapse the slot if no ad is returned.\n   * @param opt_collapseBeforeAdFetch Whether to collapse the slot even before an ad is fetched. Ignored if collapse is not true.\n   */\n  setCollapseEmptyDiv(\n    collapse: boolean,\n    opt_collapseBeforeAdFetch?: boolean\n  ): Slot;\n\n  /**\n   * Configures whether ads in this slot should be forced to be rendered using a SafeFrame container.\n   *\n   * @param forceSafeFrame true to force all ads in this slot to be rendered in SafeFrames and false to opt-out of a page-level setting (if present). Setting this to false when not specified at page-level, won't change anything.\n   */\n  setForceSafeFrame(forceSafeFrame: boolean): Slot;\n\n  /**\n   * Sets the slot-level preferences for SafeFrame configuration.\n   *\n   * @param config The configuration object.\n   */\n  setSafeFrameConfig(config: SafeFrameConfig): Slot;\n\n  /**\n   * Sets a custom targeting parameter for this slot.\n   *\n   * @param key Targeting parameter key.\n   * @param value Targeting parameter value or array of values.\n   */\n  setTargeting(key: string, value: string | string[]): Slot;\n\n  /**\n   * Sets custom targeting parameters for this slot, from a key:value map in a JSON object.\n   *\n   * @param map Targeting parameter key:value map.\n   */\n  updateTargetingFromMap(map: object): Slot;\n}\n\nexport interface Googletag {\n  /**\n   * Flag indicating that GPT API is loaded and ready to be called.\n   */\n  apiReady: boolean;\n\n  /**\n   * Reference to the global command queue for asynchronous execution of GPT-related calls.\n   */\n  cmd: CommandArray;\n\n  /**\n   * Returns a reference to the companion ads service.\n   */\n  companionAds(): CompanionAdsService;\n\n  /**\n   * Returns a reference to the content service.\n   */\n  content(): ContentService;\n\n  /**\n   * Constructs an out-of-page (interstitial) ad slot with the given ad unit path.\n   *\n   * @param adUnitPath Full ad unit path with the network code and ad unit code.\n   * @param opt_div ID of the div that will contain this ad unit or OutOfPageFormat.\n   */\n  defineOutOfPageSlot(adUnitPath: string, opt_div?: string): Slot;\n\n  /**\n   * Constructs an ad slot with a given ad unit path and size and associates it with the ID of a div element on the page that will contain the ad.\n   *\n   * @param adUnitPath Full ad unit path with the network code and unit code.\n   * @param size Width and height of the added slot. This is the size that is used in the ad request if no responsive size mapping is provided or the size of the viewport is smaller than the smallest size provided in the mapping.\n   * @param opt_div ID of the div that will contain this ad unit.\n   */\n  defineSlot(adUnitPath: string, size: GeneralSize, opt_div?: string): Slot;\n\n  /**\n   * Destroys the given slots, removing all related objects and references of those slots from GPT.\n   * @param opt_slots The array of slots to destroy. Array is optional; all slots will be destroyed if it is unspecified.\n   */\n  destroySlots(opt_slots?: Slot[]): boolean;\n\n  /**\n   * Disables the Google Publisher Console.\n   */\n  disablePublisherConsole(): void;\n\n  /**\n   * Instructs slot services to render the slot.\n   *\n   * @param divOrSlot Either the ID of the div element containing the ad slot or the div element, or the slot object. If a div element is provided, it must have an 'id' attribute which matches the ID passed into `googletag.defineSlot()`.\n   */\n  display(divOrSlot?: string | Element | Slot): void;\n\n  /**\n   * Enables all GPT services that have been defined for ad slots on the page.\n   */\n  enableServices(): void;\n\n  /**\n   * Returns the current version of GPT.\n   */\n  getVersion(): string;\n\n  /**\n   * Opens the Google Publisher Console.\n   *\n   * @param opt_div ID of the div element containing the ad slot.\n   */\n  openConsole(opt_div?: string): void;\n\n  /**\n   * Returns a reference to the pubads service.\n   */\n  pubads(): PubAdsService;\n\n  /**\n   * Flag indicating that Pubads service is enabled, loaded and fully operational.\n   */\n  pubadsReady: boolean;\n\n  /**\n   * Sets that title for all ad container iframes created by pubads service, from this point onwards.\n   *\n   * @param title The title to set.\n   */\n  setAdIframeTitle(title: string): void;\n\n  /**\n   * Creates a new SizeMappingBuilder.\n   */\n  sizeMapping(): SizeMappingBuilder;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gpt.interface.js","sourceRoot":"","sources":["../../../../ng-gpt/src/lib/gpt.interface.ts"],"names":[],"mappings":"","sourcesContent":["import { GeneralSize, SingleSizeArray, SizeMappingArray } from './gpt.type';\n\ninterface ResponseInformation {\n  advertiserId: string;\n  campaignId: string;\n  creativeId?: number | undefined;\n  creativeTemplateId?: number | undefined;\n  lineItemId?: number | undefined;\n}\n\nexport interface SafeFrameConfig {\n  allowOverlayExpansion?: boolean | undefined;\n  allowPushExpansion?: boolean | undefined;\n  sandbox?: boolean | undefined;\n  useUniqueDomain?: boolean | null | undefined;\n}\n\nexport interface LazyLoadOptionsConfig {\n  fetchMarginPercent?: number | undefined;\n  renderMarginPercent?: number | undefined;\n  mobileScaling?: number | undefined;\n}\n\ninterface PrivacySettingsConfig {\n  childDirectedTreatment?: boolean | null | undefined;\n  limitedAds?: boolean | null | undefined;\n  restrictDataProcessing?: boolean | null | undefined;\n  underAgeOfConsent?: boolean | null | undefined;\n}\n\ninterface CommandArray {\n  push(f: () => void): number;\n}\n\nexport interface Service {\n  addEventListener(\n    eventType: 'slotRenderEnded',\n    listener: (event: SlotRenderEndedEvent) => void\n  ): Service;\n  addEventListener(\n    eventType: 'slotRequested',\n    listener: (event: SlotRequestedEvent) => void\n  ): Service;\n  addEventListener(\n    eventType: 'slotResponseReceived',\n    listener: (event: SlotResponseReceived) => void\n  ): Service;\n  addEventListener(\n    eventType: 'slotVisibilityChanged',\n    listener: (event: SlotVisibilityChangedEvent) => void\n  ): Service;\n  addEventListener(\n    eventType: string,\n    listener: (event: Event) => void\n  ): Service;\n  getSlots(): Slot[];\n}\n\ninterface CompanionAdsService extends Service {\n  enableSyncLoading(): void;\n  setRefreshUnfilledSlots(value: boolean): void;\n}\n\ninterface ContentService extends Service {\n  setContent(slot: Slot, content: string): void;\n}\n\nexport interface PubAdsService extends Service {\n  /**\n   * Removes the ads from the given slots and replaces them with blank content.\n   *\n   * @param opt_slots The array of slots to clear. Array is optional; all slots will be cleared if it is unspecified.\n   */\n  clear(opt_slots?: Slot[]): boolean;\n\n  /**\n   * Clears all page-level ad category exclusion labels.\n   */\n  clearCategoryExclusions(): PubAdsService;\n\n  /**\n   * Clears custom targeting parameters for a specific key or for all keys.\n   *\n   * @param opt_key Targeting parameter key. The key is optional; all targeting parameters will be cleared if it is unspecified.\n   */\n  clearTargeting(opt_key?: string): PubAdsService;\n\n  /**\n   * Enables collapsing of slot divs so that they don't take up any space on the page when there is no ad content to display.\n   *\n   * @param opt_collapseBeforeAdFetch Whether to collapse the slots even before the ads are fetched. This parameter is optional; if not provided, false will be used as the default value.\n   */\n  collapseEmptyDivs(opt_collapseBeforeAdFetch?: boolean): boolean;\n\n  /**\n   * Disables requests for ads on page load, but allows ads to be requested with a `googletag.pubads().refresh()` call.\n   */\n  disableInitialLoad(): void;\n\n  /**\n   * Constructs and displays an ad slot with the given ad unit path and size.\n   *\n   * @param adUnitPath The ad unit path of slot to be rendered.\n   * @param size Width and height of the slot.\n   * @param opt_div Either the ID of the div containing the slot or the div element itself.\n   * @param opt_clickUrl The click URL to use on this slot.\n   */\n  display(\n    adUnitPath: string,\n    size: GeneralSize,\n    opt_div?: string | Element,\n    opt_clickUrl?: string\n  ): Slot;\n\n  /**\n   * Enables lazy loading in GPT as defined by the config object.\n   *\n   * @param opt_config Configuration object allows customization of lazy loading behavior. Any omitted configurations will use a default set by Google that will be tuned over time. To disable a particular setting, such as a fetching margin, set the value to -1.\n   *\n   * fetchMarginPercent is the minimum distance from the current viewport a slot must be before we fetch the ad as a percentage of viewport size. 0 means \"when the slot enters the viewport\", 100 means \"when the ad is 1 viewport away\", and so on.\n   *\n   * renderMarginPercent is the minimum distance from the current viewport a slot must be before we render an ad. This allows for prefetching the ad, but waiting to render and download other subresources. The value works just like fetchMarginPercent as a percentage of viewport.\n   *\n   * mobileScaling is a multiplier applied to margins on mobile devices. This allows varying margins on mobile vs. desktop. For example, a mobileScaling of 2.0 will multiply all margins by 2 on mobile devices, increasing the minimum distance a slot can be before fetching and rendering.\n   */\n  enableLazyLoad(opt_config?: LazyLoadOptionsConfig): void;\n\n  /**\n   * Enables single request mode for fetching multiple ads at the same time.\n   */\n  enableSingleRequest(): boolean;\n\n  /**\n   * Signals to GPT that video ads will be present on the page.\n   */\n  enableVideoAds(): void;\n\n  /**\n   * Returns the value for the AdSense attribute associated with the given key.\n   *\n   * @param key Name of the attribute to look for.\n   */\n  get(key: string): string | null;\n\n  /**\n   * Returns the attribute keys that have been set on this service.\n   */\n  getAttributeKeys(): string[];\n\n  /**\n   * Returns a specific custom service-level targeting parameter that has been set.\n   *\n   * @param key The targeting key to look for.\n   */\n  getTargeting(key: string): string[];\n\n  /**\n   * Returns the list of all custom service-level targeting keys that have been set.\n   */\n  getTargetingKeys(): string[];\n\n  /**\n   * Returns whether or not initial requests for ads was successfully disabled by a previous disableInitialLoad call.\n   */\n  isInitialLoadDisabled(): boolean;\n\n  /**\n   * Fetches and displays new ads for specific or all slots on the page.\n   *\n   * @param opt_slots The slots to refresh. Array is optional; all slots will be refreshed if it is unspecified.\n   * @param opt_options Configuration options associated with this refresh call. changeCorrelator specifies whether or not a new correlator is to be generated for fetching ads. Our ad servers maintain this correlator value briefly (currently for 30 seconds, but subject to change), such that requests with the same correlator received close together will be considered a single page view. By default a new correlator is generated for every refresh. Note that this option has no effect on GPT's long-lived pageview, which automatically reflects the ads currently on the page and has no expiration time.\n   */\n  refresh(\n    opt_slots?: Slot[],\n    opt_options?: { changeCorrelator: boolean }\n  ): void;\n\n  /**\n   * Sets values for AdSense attributes that apply to all ad slots under the publisher ads service.\n   *\n   * @param key The name of the attribute.\n   * @param value Attribute value.\n   */\n  set(key: string, value: string): PubAdsService;\n\n  /**\n   * Sets a page-level ad category exclusion for the given label name.\n   *\n   * @param categoryExclusion The ad category exclusion label to add.\n   */\n  setCategoryExclusion(categoryExclusion: string): PubAdsService;\n\n  /**\n   * Enables and disables horizontal centering of ads.\n   *\n   * @param centerAds true to center ads, false to left-align them.\n   */\n  setCentering(centerAds: boolean): void;\n\n  /**\n   * Sets options for ignoring Google Ad Manager cookies on the current page.\n   *\n   * @param cookieOptions The cookie options to set. Possible values are:\n   *\n   * 0: Enables Google Ad Manager cookies on ad requests on the page. This option is set by default.\n   *\n   * 1: Ignores Google Ad Manager cookies on subsequent ad requests and prevents cookies from being created on the page. Note that cookies will not be ignored on certain pingbacks and that this option will disable features that rely on cookies, such as dynamic allocation.\n   */\n  setCookieOptions(cookieOptions: number): PubAdsService;\n\n  /**\n   * Configures whether all ads on the page should be forced to be rendered using a SafeFrame container.\n   *\n   * @param forceSafeFrame true to force all ads on the page to be rendered in SafeFrames and false to change the previous setting to false. Setting this to false when unspecified earlier, won't change anything.\n   */\n  setForceSafeFrame(forceSafeFrame: boolean): PubAdsService;\n\n  /**\n   * Passes location information from websites so you can geo-target line items to specific locations.\n   *\n   * @param address Freeform address.\n   */\n  setLocation(address: string): PubAdsService;\n\n  /**\n   * Allows configuration of all privacy settings from a single API using a config object.\n   * @param privacySettings\n   */\n  setPrivacySettings(privacySettings: PrivacySettingsConfig): Slot;\n\n  /**\n   * Sets the value for the publisher-provided ID.\n   *\n   * @param ppid An alphanumeric ID provided by the publisher with a recommended maximum of 150 characters.\n   */\n  setPublisherProvidedId(ppid: string): PubAdsService;\n\n  /**\n   * Configures whether the page should request personalized or non-personalized ads.\n   *\n   * @param nonPersonalizedAds 0 for personalized ads, 1 for non-personalized ads.\n   */\n  setRequestNonPersonalizedAds(nonPersonalizedAds: 0 | 1): PubAdsService;\n\n  /**\n   * Sets the page-level preferences for SafeFrame configuration.\n   *\n   * @param config The configuration object.\n   */\n  setSafeFrameConfig(config: SafeFrameConfig): PubAdsService;\n\n  /**\n   * Sets a custom targeting parameter for this slot.\n   *\n   * @param key Targeting parameter key.\n   * @param value Targeting parameter value or array of values.\n   */\n  setTargeting(key: string, value: string | string[]): PubAdsService;\n\n  /**\n   * Sets the video content information to be sent along with the ad requests for targeting and content exclusion purposes.\n   *\n   * @param videoContentId The video content ID.\n   * @param videoCmsId The video CMS ID.\n   */\n  setVideoContent(videoContentId: string, videoCmsId: string): void;\n\n  /**\n   * Changes the correlator that is sent with ad requests, effectively starting a new page view.\n   */\n  updateCorrelator(): PubAdsService;\n}\n\ninterface SizeMappingBuilder {\n  /**\n   * Adds a mapping from a single-size array representing the viewport to either a single-size array or a multi-size array representing the slot.\n   *\n   * @param viewportSize The size of the viewport for this mapping entry.\n   * @param slotSize The sizes of the slot for this mapping entry.\n   */\n  addSize(\n    viewportSize: SingleSizeArray,\n    slotSize: GeneralSize\n  ): SizeMappingBuilder;\n\n  /**\n   * Builds a size map specification from the mappings added to this builder.\n   */\n  build(): SizeMappingArray;\n}\n\ninterface Event {\n  serviceName: string;\n  slot: Slot;\n}\n\ninterface SlotRenderEndedEvent extends Event {\n  advertiserId?: number | undefined;\n  campaignId?: number | undefined;\n  creativeId?: number | undefined;\n  isEmpty: boolean;\n  lineItemId?: number | undefined;\n  size: number[] | string;\n  sourceAgnosticCreativeId?: number | undefined;\n  sourceAgnosticLineItemId?: number | undefined;\n}\n\n// tslint:disable-next-line:no-empty-interface\ninterface SlotRequestedEvent extends Event {}\n\n// tslint:disable-next-line:no-empty-interface\ninterface SlotResponseReceived extends Event {}\n\ninterface SlotVisibilityChangedEvent extends Event {\n  inViewPercentage: number;\n}\n\nexport interface Slot {\n  /**\n   * Adds a service to this slot.\n   *\n   * @param service The service to be added.\n   */\n  addService(service: Service): Slot;\n\n  /**\n   * Clears all slot-level ad category exclusion labels for this slot.\n   */\n  clearCategoryExclusions(): Slot;\n\n  /**\n   * Clears specific or all custom slot-level targeting parameters for this slot.\n   *\n   * @param opt_key Targeting parameter key. The key is optional; all targeting parameters will be cleared if it is unspecified.\n   */\n  clearTargeting(opt_key?: string): Slot;\n\n  /**\n   * Sets an array of mappings from a minimum viewport size to slot size for this slot.\n   *\n   * @param sizeMapping Array of size mappings. You can use `googletag.SizeMappingBuilder` to create it. Each size mapping is an array of two elements: `googletag.SingleSizeArray` and `googletag.GeneralSize`.\n   */\n  defineSizeMapping(sizeMapping: SizeMappingArray): Slot;\n\n  /**\n   * Returns the value for the AdSense attribute associated with the given key.\n   *\n   * @param key Name of the attribute to look for.\n   */\n  get(key: string): string | null;\n\n  /**\n   * Returns the full path of the ad unit, with the network code and ad unit path.\n   */\n  getAdUnitPath(): string;\n\n  /**\n   * Returns the list of attribute keys set on this slot.\n   */\n  getAttributeKeys(): string[];\n\n  /**\n   * Returns the ad category exclusion labels for this slot.\n   */\n  getCategoryExclusions(): string[];\n\n  /**\n   * Returns the ad response information.\n   */\n  getResponseInformation(): ResponseInformation;\n\n  /**\n   * Returns the id of the slot element provided when the slot was defined.\n   */\n  getSlotElementId(): string;\n\n  /**\n   * Returns a specific custom targeting parameter set on this slot.\n   *\n   * @param key The targeting key to look for.\n   */\n  getTargeting(key: string): string[];\n\n  /**\n   * Returns the list of all custom targeting keys set on this slot.\n   */\n  getTargetingKeys(): string[];\n\n  /**\n   * Sets a value for an AdSense attribute on a particular ad slot.\n   *\n   * @param key The name of the attribute.\n   * @param value Attribute value.\n   */\n  set(key: string, value: string): Slot;\n\n  /**\n   * Sets a slot-level ad category exclusion label on this slot.\n   *\n   * @param categoryExclusion The ad category exclusion label to add.\n   */\n  setCategoryExclusion(categoryExclusion: string): Slot;\n\n  /**\n   * Sets the click URL to which users will be redirected after clicking on the ad.\n   *\n   * @param value The click URL to set.\n   */\n  setClickUrl(value: string): Slot;\n\n  /**\n   * Sets whether the slot div should be hidden when there is no ad in the slot.\n   *\n   * @param collapse Whether to collapse the slot if no ad is returned.\n   * @param opt_collapseBeforeAdFetch Whether to collapse the slot even before an ad is fetched. Ignored if collapse is not true.\n   */\n  setCollapseEmptyDiv(\n    collapse: boolean,\n    opt_collapseBeforeAdFetch?: boolean\n  ): Slot;\n\n  /**\n   * Configures whether ads in this slot should be forced to be rendered using a SafeFrame container.\n   *\n   * @param forceSafeFrame true to force all ads in this slot to be rendered in SafeFrames and false to opt-out of a page-level setting (if present). Setting this to false when not specified at page-level, won't change anything.\n   */\n  setForceSafeFrame(forceSafeFrame: boolean): Slot;\n\n  /**\n   * Sets the slot-level preferences for SafeFrame configuration.\n   *\n   * @param config The configuration object.\n   */\n  setSafeFrameConfig(config: SafeFrameConfig): Slot;\n\n  /**\n   * Sets a custom targeting parameter for this slot.\n   *\n   * @param key Targeting parameter key.\n   * @param value Targeting parameter value or array of values.\n   */\n  setTargeting(key: string, value: string | string[]): Slot;\n\n  /**\n   * Sets custom targeting parameters for this slot, from a key:value map in a JSON object.\n   *\n   * @param map Targeting parameter key:value map.\n   */\n  updateTargetingFromMap(map: object): Slot;\n}\n\nexport interface Googletag {\n  /**\n   * Flag indicating that GPT API is loaded and ready to be called.\n   */\n  apiReady: boolean;\n\n  /**\n   * Reference to the global command queue for asynchronous execution of GPT-related calls.\n   */\n  cmd: CommandArray;\n\n  /**\n   * Returns a reference to the companion ads service.\n   */\n  companionAds(): CompanionAdsService;\n\n  /**\n   * Returns a reference to the content service.\n   */\n  content(): ContentService;\n\n  /**\n   * Constructs an out-of-page (interstitial) ad slot with the given ad unit path.\n   *\n   * @param adUnitPath Full ad unit path with the network code and ad unit code.\n   * @param opt_div ID of the div that will contain this ad unit or OutOfPageFormat.\n   */\n  defineOutOfPageSlot(adUnitPath: string, opt_div?: string): Slot;\n\n  /**\n   * Constructs an ad slot with a given ad unit path and size and associates it with the ID of a div element on the page that will contain the ad.\n   *\n   * @param adUnitPath Full ad unit path with the network code and unit code.\n   * @param size Width and height of the added slot. This is the size that is used in the ad request if no responsive size mapping is provided or the size of the viewport is smaller than the smallest size provided in the mapping.\n   * @param opt_div ID of the div that will contain this ad unit.\n   */\n  defineSlot(adUnitPath: string, size: GeneralSize, opt_div?: string): Slot;\n\n  /**\n   * Destroys the given slots, removing all related objects and references of those slots from GPT.\n   * @param opt_slots The array of slots to destroy. Array is optional; all slots will be destroyed if it is unspecified.\n   */\n  destroySlots(opt_slots?: Slot[]): boolean;\n\n  /**\n   * Disables the Google Publisher Console.\n   */\n  disablePublisherConsole(): void;\n\n  /**\n   * Instructs slot services to render the slot.\n   *\n   * @param divOrSlot Either the ID of the div element containing the ad slot or the div element, or the slot object. If a div element is provided, it must have an 'id' attribute which matches the ID passed into `googletag.defineSlot()`.\n   */\n  display(divOrSlot?: string | Element | Slot): void;\n\n  /**\n   * Enables all GPT services that have been defined for ad slots on the page.\n   */\n  enableServices(): void;\n\n  /**\n   * Returns the current version of GPT.\n   */\n  getVersion(): string;\n\n  /**\n   * Opens the Google Publisher Console.\n   *\n   * @param opt_div ID of the div element containing the ad slot.\n   */\n  openConsole(opt_div?: string): void;\n\n  /**\n   * Returns a reference to the pubads service.\n   */\n  pubads(): PubAdsService;\n\n  /**\n   * Flag indicating that Pubads service is enabled, loaded and fully operational.\n   */\n  pubadsReady: boolean;\n\n  /**\n   * Sets that title for all ad container iframes created by pubads service, from this point onwards.\n   *\n   * @param title The title to set.\n   */\n  setAdIframeTitle(title: string): void;\n\n  /**\n   * Creates a new SizeMappingBuilder.\n   */\n  sizeMapping(): SizeMappingBuilder;\n}\n"]}

@@ -46,2 +46,2 @@ import { NgModule } from '@angular/core';

}] });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3B0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25nLWdwdC9zcmMvbGliL2dwdC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUF1QixRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDOUQsT0FBTyxFQUFhLFVBQVUsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUNyRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDakQsT0FBTyxFQUNMLGdCQUFnQixFQUNoQixxQkFBcUIsRUFDckIsV0FBVyxFQUNYLHNCQUFzQixFQUN0QixpQkFBaUIsRUFDakIsb0JBQW9CLEdBQ3JCLE1BQU0sWUFBWSxDQUFDO0FBQ3BCLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDOztBQWdCM0UsTUFBTSxPQUFPLFNBQVM7SUFDcEIsTUFBTSxDQUFDLE9BQU8sQ0FBQyxNQUFrQjtRQUMvQixPQUFPO1lBQ0wsUUFBUSxFQUFFLFNBQVM7WUFDbkIsU0FBUyxFQUFFO2dCQUNULEdBQUcsQ0FBQyxNQUFNLElBQUksTUFBTSxDQUFDLFFBQVEsS0FBSyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztnQkFDNUQsRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLFFBQVEsRUFBRSxNQUFNLElBQUksRUFBRSxFQUFFO2FBQ2hEO1NBQ0YsQ0FBQztJQUNKLENBQUM7O3NHQVRVLFNBQVM7dUdBQVQsU0FBUyxpQkFiTCxjQUFjLGFBV25CLGNBQWM7dUdBRWIsU0FBUyxhQVhUO1FBQ1QsZ0JBQWdCO1FBQ2hCLHFCQUFxQjtRQUNyQixXQUFXO1FBQ1gsc0JBQXNCO1FBQ3RCLGlCQUFpQjtRQUNqQixvQkFBb0I7UUFDcEIscUJBQXFCO0tBQ3RCLFlBVFEsRUFBRTsyRkFZQSxTQUFTO2tCQWRyQixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLGNBQWMsQ0FBQztvQkFDOUIsT0FBTyxFQUFFLEVBQUU7b0JBQ1gsU0FBUyxFQUFFO3dCQUNULGdCQUFnQjt3QkFDaEIscUJBQXFCO3dCQUNyQixXQUFXO3dCQUNYLHNCQUFzQjt3QkFDdEIsaUJBQWlCO3dCQUNqQixvQkFBb0I7d0JBQ3BCLHFCQUFxQjtxQkFDdEI7b0JBQ0QsT0FBTyxFQUFFLENBQUMsY0FBYyxDQUFDO2lCQUMxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1vZHVsZVdpdGhQcm92aWRlcnMsIE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBHcHRDb25maWcsIEdQVF9DT05GSUcgfSBmcm9tICcuL2dwdC5jb25maWcnO1xuaW1wb3J0IHsgR3B0QWREaXJlY3RpdmUgfSBmcm9tICcuL2dwdC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtcbiAgSHR0cEVycm9yU2VydmljZSxcbiAgU2NyaXB0SW5qZWN0b3JTZXJ2aWNlLFxuICBJZGxlU2VydmljZSxcbiAgUHViYWRzU2V0Q29uZmlnU2VydmljZSxcbiAgR3B0UmVmcmVzaFNlcnZpY2UsXG4gIFBhcnNlRHVyYXRpb25TZXJ2aWNlLFxufSBmcm9tICcuL3NlcnZpY2VzJztcbmltcG9ydCB7IEdwdElER2VuZXJhdG9yU2VydmljZSB9IGZyb20gJy4vc2VydmljZXMvZ3B0LWlkR2VuZXJhdG9yLnNlcnZpY2UnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtHcHRBZERpcmVjdGl2ZV0sXG4gIGltcG9ydHM6IFtdLFxuICBwcm92aWRlcnM6IFtcbiAgICBIdHRwRXJyb3JTZXJ2aWNlLFxuICAgIFNjcmlwdEluamVjdG9yU2VydmljZSxcbiAgICBJZGxlU2VydmljZSxcbiAgICBQdWJhZHNTZXRDb25maWdTZXJ2aWNlLFxuICAgIEdwdFJlZnJlc2hTZXJ2aWNlLFxuICAgIFBhcnNlRHVyYXRpb25TZXJ2aWNlLFxuICAgIEdwdElER2VuZXJhdG9yU2VydmljZSxcbiAgXSxcbiAgZXhwb3J0czogW0dwdEFkRGlyZWN0aXZlXSxcbn0pXG5leHBvcnQgY2xhc3MgR3B0TW9kdWxlIHtcbiAgc3RhdGljIGZvclJvb3QoY29uZmlnPzogR3B0Q29uZmlnKTogTW9kdWxlV2l0aFByb3ZpZGVyczxHcHRNb2R1bGU+IHtcbiAgICByZXR1cm4ge1xuICAgICAgbmdNb2R1bGU6IEdwdE1vZHVsZSxcbiAgICAgIHByb3ZpZGVyczogW1xuICAgICAgICAuLi4oY29uZmlnICYmIGNvbmZpZy5pZGxlTG9hZCA9PT0gdHJ1ZSA/IFtJZGxlU2VydmljZV0gOiBbXSksXG4gICAgICAgIHsgcHJvdmlkZTogR1BUX0NPTkZJRywgdXNlVmFsdWU6IGNvbmZpZyB8fCB7fSB9LFxuICAgICAgXSxcbiAgICB9O1xuICB9XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3B0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL25nLWdwdC9zcmMvbGliL2dwdC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUF1QixRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDOUQsT0FBTyxFQUFhLFVBQVUsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUNyRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDakQsT0FBTyxFQUNMLGdCQUFnQixFQUNoQixxQkFBcUIsRUFDckIsV0FBVyxFQUNYLHNCQUFzQixFQUN0QixpQkFBaUIsRUFDakIsb0JBQW9CLEdBQ3JCLE1BQU0sWUFBWSxDQUFDO0FBQ3BCLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDOztBQWdCM0UsTUFBTSxPQUFPLFNBQVM7SUFDcEIsTUFBTSxDQUFDLE9BQU8sQ0FBQyxNQUFrQjtRQUMvQixPQUFPO1lBQ0wsUUFBUSxFQUFFLFNBQVM7WUFDbkIsU0FBUyxFQUFFO2dCQUNULEdBQUcsQ0FBQyxNQUFNLElBQUksTUFBTSxDQUFDLFFBQVEsS0FBSyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztnQkFDNUQsRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLFFBQVEsRUFBRSxNQUFNLElBQUksRUFBRSxFQUFFO2FBQ2hEO1NBQ0YsQ0FBQztJQUNKLENBQUM7O3NHQVRVLFNBQVM7dUdBQVQsU0FBUyxpQkFiTCxjQUFjLGFBV25CLGNBQWM7dUdBRWIsU0FBUyxhQVhUO1FBQ1QsZ0JBQWdCO1FBQ2hCLHFCQUFxQjtRQUNyQixXQUFXO1FBQ1gsc0JBQXNCO1FBQ3RCLGlCQUFpQjtRQUNqQixvQkFBb0I7UUFDcEIscUJBQXFCO0tBQ3RCLFlBVFEsRUFBRTsyRkFZQSxTQUFTO2tCQWRyQixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLGNBQWMsQ0FBQztvQkFDOUIsT0FBTyxFQUFFLEVBQUU7b0JBQ1gsU0FBUyxFQUFFO3dCQUNULGdCQUFnQjt3QkFDaEIscUJBQXFCO3dCQUNyQixXQUFXO3dCQUNYLHNCQUFzQjt3QkFDdEIsaUJBQWlCO3dCQUNqQixvQkFBb0I7d0JBQ3BCLHFCQUFxQjtxQkFDdEI7b0JBQ0QsT0FBTyxFQUFFLENBQUMsY0FBYyxDQUFDO2lCQUMxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1vZHVsZVdpdGhQcm92aWRlcnMsIE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBHcHRDb25maWcsIEdQVF9DT05GSUcgfSBmcm9tICcuL2dwdC5jb25maWcnO1xuaW1wb3J0IHsgR3B0QWREaXJlY3RpdmUgfSBmcm9tICcuL2dwdC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtcbiAgSHR0cEVycm9yU2VydmljZSxcbiAgU2NyaXB0SW5qZWN0b3JTZXJ2aWNlLFxuICBJZGxlU2VydmljZSxcbiAgUHViYWRzU2V0Q29uZmlnU2VydmljZSxcbiAgR3B0UmVmcmVzaFNlcnZpY2UsXG4gIFBhcnNlRHVyYXRpb25TZXJ2aWNlLFxufSBmcm9tICcuL3NlcnZpY2VzJztcbmltcG9ydCB7IEdwdElER2VuZXJhdG9yU2VydmljZSB9IGZyb20gJy4vc2VydmljZXMvZ3B0LWlkR2VuZXJhdG9yLnNlcnZpY2UnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtHcHRBZERpcmVjdGl2ZV0sXG4gIGltcG9ydHM6IFtdLFxuICBwcm92aWRlcnM6IFtcbiAgICBIdHRwRXJyb3JTZXJ2aWNlLFxuICAgIFNjcmlwdEluamVjdG9yU2VydmljZSxcbiAgICBJZGxlU2VydmljZSxcbiAgICBQdWJhZHNTZXRDb25maWdTZXJ2aWNlLFxuICAgIEdwdFJlZnJlc2hTZXJ2aWNlLFxuICAgIFBhcnNlRHVyYXRpb25TZXJ2aWNlLFxuICAgIEdwdElER2VuZXJhdG9yU2VydmljZSxcbiAgXSxcbiAgZXhwb3J0czogW0dwdEFkRGlyZWN0aXZlXSxcbn0pXG5leHBvcnQgY2xhc3MgR3B0TW9kdWxlIHtcbiAgc3RhdGljIGZvclJvb3QoY29uZmlnPzogR3B0Q29uZmlnKTogTW9kdWxlV2l0aFByb3ZpZGVyczxHcHRNb2R1bGU+IHtcbiAgICByZXR1cm4ge1xuICAgICAgbmdNb2R1bGU6IEdwdE1vZHVsZSxcbiAgICAgIHByb3ZpZGVyczogW1xuICAgICAgICAuLi4oY29uZmlnICYmIGNvbmZpZy5pZGxlTG9hZCA9PT0gdHJ1ZSA/IFtJZGxlU2VydmljZV0gOiBbXSksXG4gICAgICAgIHsgcHJvdmlkZTogR1BUX0NPTkZJRywgdXNlVmFsdWU6IGNvbmZpZyB8fCB7fSB9LFxuICAgICAgXSxcbiAgICB9O1xuICB9XG59XG4iXX0=

@@ -109,2 +109,2 @@ import { isPlatformBrowser } from '@angular/common';

}] }, { type: i2.PubadsSetConfigService }, { type: i2.ScriptInjectorService }]; } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gpt.service.js","sourceRoot":"","sources":["../../../../projects/ng-gpt/src/lib/gpt.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformBrowser } from '@angular/common';\nimport { Inject, Injectable, Optional, PLATFORM_ID } from '@angular/core';\nimport { PubadsSetConfigService, ScriptInjectorService } from './services';\nimport { GptConfig, GPT_CONFIG } from './gpt.config';\nimport { GPT_URL } from './gpt.contants';\nimport {\n  Googletag,\n  LazyLoadOptionsConfig,\n  SafeFrameConfig,\n} from './gpt.interface';\nimport { IdleService } from './services/idle.service';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class GptService {\n  private collapseEmptyDivs = true;\n  private enableVideoAds = false;\n  private enableLazyLoad: LazyLoadOptionsConfig = {};\n  private centering = false;\n  private personalizedAds = true;\n  private cookies = true;\n  private forceSafeFrame = false;\n  private address: string = '';\n  private ppid: string = '';\n  private globalTargeting: object = {};\n  private safeFrameConfig: SafeFrameConfig = {};\n  private loadGPT = true;\n  private loaded = false;\n\n  constructor(\n    @Inject(PLATFORM_ID) private platformID: Object,\n    @Inject(GPT_CONFIG) private config: GptConfig,\n    @Optional() idleLoad: IdleService,\n    private pubadsSetConfig: PubadsSetConfigService,\n    private scriptInjector: ScriptInjectorService\n  ) {\n    if (isPlatformBrowser(this.platformID)) {\n      const w: any = window,\n        googletag: Googletag = w.googletag || {};\n\n      this.gptConfig();\n\n      googletag.cmd = googletag.cmd || [];\n      googletag.cmd.push(() => {\n        this.setup();\n      });\n      w.googletag = googletag;\n\n      if (this.loadGPT) {\n        const loadScript = () => {\n          this.scriptInjector.scriptInjector(GPT_URL).then((script: any) => {\n            this.loaded = true;\n          });\n        };\n        if (idleLoad) {\n          idleLoad.request(loadScript);\n        } else {\n          loadScript();\n        }\n      }\n    }\n  }\n\n  private gptConfig() {\n    for (const key in this.config) {\n      if (this.hasOwnProperty(key)) {\n        this[key] = this.config[key];\n      }\n    }\n  }\n\n  private setup() {\n    const w: any = window,\n      googletag: Googletag = w.googletag,\n      pubads = googletag.pubads();\n\n    if (this.enableVideoAds) pubads.enableVideoAds();\n    if (this.collapseEmptyDivs) pubads.collapseEmptyDivs();\n\n    pubads.disableInitialLoad();\n    pubads.setForceSafeFrame(this.forceSafeFrame);\n    pubads.setCentering(this.centering);\n    pubads.setRequestNonPersonalizedAds(this.personalizedAds ? 0 : 1);\n\n    this.pubadsSetConfig.addLocation(this.address, pubads);\n    this.pubadsSetConfig.addPPID(this.ppid, pubads);\n    this.pubadsSetConfig.addTargeting(this.globalTargeting, pubads);\n    this.pubadsSetConfig.addSafeFrameConfig(this.safeFrameConfig, pubads);\n\n    pubads.setCookieOptions(this.cookies ? 0 : 1);\n\n    if (this.config.singleRequestMode !== true) {\n      if (this.config.enableVideoAds) {\n        pubads.enableVideoAds();\n      }\n      googletag.enableServices();\n    }\n\n    if (Object.keys(this.enableLazyLoad).length) {\n      pubads.enableLazyLoad(this.enableLazyLoad);\n    }\n  }\n\n  hasLoaded(): boolean {\n    return this.loaded;\n  }\n\n  defineTask(task: any): void {\n    if (isPlatformBrowser(this.platformID)) {\n      const w: any = window,\n        googletag: Googletag = w.googletag;\n\n      googletag.cmd.push(task);\n    }\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gpt.service.js","sourceRoot":"","sources":["../../../../ng-gpt/src/lib/gpt.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformBrowser } from '@angular/common';\nimport { Inject, Injectable, Optional, PLATFORM_ID } from '@angular/core';\nimport { PubadsSetConfigService, ScriptInjectorService } from './services';\nimport { GptConfig, GPT_CONFIG } from './gpt.config';\nimport { GPT_URL } from './gpt.contants';\nimport {\n  Googletag,\n  LazyLoadOptionsConfig,\n  SafeFrameConfig,\n} from './gpt.interface';\nimport { IdleService } from './services/idle.service';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class GptService {\n  private collapseEmptyDivs = true;\n  private enableVideoAds = false;\n  private enableLazyLoad: LazyLoadOptionsConfig = {};\n  private centering = false;\n  private personalizedAds = true;\n  private cookies = true;\n  private forceSafeFrame = false;\n  private address: string = '';\n  private ppid: string = '';\n  private globalTargeting: object = {};\n  private safeFrameConfig: SafeFrameConfig = {};\n  private loadGPT = true;\n  private loaded = false;\n\n  constructor(\n    @Inject(PLATFORM_ID) private platformID: Object,\n    @Inject(GPT_CONFIG) private config: GptConfig,\n    @Optional() idleLoad: IdleService,\n    private pubadsSetConfig: PubadsSetConfigService,\n    private scriptInjector: ScriptInjectorService\n  ) {\n    if (isPlatformBrowser(this.platformID)) {\n      const w: any = window,\n        googletag: Googletag = w.googletag || {};\n\n      this.gptConfig();\n\n      googletag.cmd = googletag.cmd || [];\n      googletag.cmd.push(() => {\n        this.setup();\n      });\n      w.googletag = googletag;\n\n      if (this.loadGPT) {\n        const loadScript = () => {\n          this.scriptInjector.scriptInjector(GPT_URL).then((script: any) => {\n            this.loaded = true;\n          });\n        };\n        if (idleLoad) {\n          idleLoad.request(loadScript);\n        } else {\n          loadScript();\n        }\n      }\n    }\n  }\n\n  private gptConfig() {\n    for (const key in this.config) {\n      if (this.hasOwnProperty(key)) {\n        this[key] = this.config[key];\n      }\n    }\n  }\n\n  private setup() {\n    const w: any = window,\n      googletag: Googletag = w.googletag,\n      pubads = googletag.pubads();\n\n    if (this.enableVideoAds) pubads.enableVideoAds();\n    if (this.collapseEmptyDivs) pubads.collapseEmptyDivs();\n\n    pubads.disableInitialLoad();\n    pubads.setForceSafeFrame(this.forceSafeFrame);\n    pubads.setCentering(this.centering);\n    pubads.setRequestNonPersonalizedAds(this.personalizedAds ? 0 : 1);\n\n    this.pubadsSetConfig.addLocation(this.address, pubads);\n    this.pubadsSetConfig.addPPID(this.ppid, pubads);\n    this.pubadsSetConfig.addTargeting(this.globalTargeting, pubads);\n    this.pubadsSetConfig.addSafeFrameConfig(this.safeFrameConfig, pubads);\n\n    pubads.setCookieOptions(this.cookies ? 0 : 1);\n\n    if (this.config.singleRequestMode !== true) {\n      if (this.config.enableVideoAds) {\n        pubads.enableVideoAds();\n      }\n      googletag.enableServices();\n    }\n\n    if (Object.keys(this.enableLazyLoad).length) {\n      pubads.enableLazyLoad(this.enableLazyLoad);\n    }\n  }\n\n  hasLoaded(): boolean {\n    return this.loaded;\n  }\n\n  defineTask(task: any): void {\n    if (isPlatformBrowser(this.platformID)) {\n      const w: any = window,\n        googletag: Googletag = w.googletag;\n\n      googletag.cmd.push(task);\n    }\n  }\n}\n"]}
export {};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3B0LnR5cGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1ncHQvc3JjL2xpYi9ncHQudHlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgU2luZ2xlU2l6ZUFycmF5ID0gbnVtYmVyW107XG5leHBvcnQgdHlwZSBOYW1lZFNpemUgPSBzdHJpbmcgfCBzdHJpbmdbXTtcbmV4cG9ydCB0eXBlIFNpbmdsZVNpemUgPSBTaW5nbGVTaXplQXJyYXkgfCBOYW1lZFNpemU7XG5leHBvcnQgdHlwZSBNdWx0aVNpemUgPSBTaW5nbGVTaXplW107XG5leHBvcnQgdHlwZSBHZW5lcmFsU2l6ZSA9IFNpbmdsZVNpemUgfCBNdWx0aVNpemU7XG5leHBvcnQgdHlwZSBTaXplTWFwcGluZyA9IEdlbmVyYWxTaXplW107XG5leHBvcnQgdHlwZSBTaXplTWFwcGluZ0FycmF5ID0gU2l6ZU1hcHBpbmdbXTtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3B0LnR5cGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9uZy1ncHQvc3JjL2xpYi9ncHQudHlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgU2luZ2xlU2l6ZUFycmF5ID0gbnVtYmVyW107XG5leHBvcnQgdHlwZSBOYW1lZFNpemUgPSBzdHJpbmcgfCBzdHJpbmdbXTtcbmV4cG9ydCB0eXBlIFNpbmdsZVNpemUgPSBTaW5nbGVTaXplQXJyYXkgfCBOYW1lZFNpemU7XG5leHBvcnQgdHlwZSBNdWx0aVNpemUgPSBTaW5nbGVTaXplW107XG5leHBvcnQgdHlwZSBHZW5lcmFsU2l6ZSA9IFNpbmdsZVNpemUgfCBNdWx0aVNpemU7XG5leHBvcnQgdHlwZSBTaXplTWFwcGluZyA9IEdlbmVyYWxTaXplW107XG5leHBvcnQgdHlwZSBTaXplTWFwcGluZ0FycmF5ID0gU2l6ZU1hcHBpbmdbXTtcbiJdfQ==

@@ -38,2 +38,2 @@ import { Injectable } from '@angular/core';

}] });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3B0LWlkR2VuZXJhdG9yLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1ncHQvc3JjL2xpYi9zZXJ2aWNlcy9ncHQtaWRHZW5lcmF0b3Iuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUczQyxNQUFNLE9BQU8scUJBQXFCO0lBRGxDO1FBRVUsaUJBQVksR0FBRyxFQUFFLENBQUM7S0FtQzNCO0lBakNDLFVBQVUsQ0FBQyxJQUFJLEdBQUcsUUFBUTtRQUN4QixJQUFJLEVBQUUsR0FBRyxFQUFFLENBQUM7UUFFWixHQUFHO1lBQ0QsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDLFFBQVEsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNqRCxFQUFFLEdBQUcsSUFBSSxHQUFHLEdBQUcsR0FBRyxNQUFNLENBQUM7U0FDMUIsUUFBUSxFQUFFLElBQUksSUFBSSxDQUFDLFlBQVksRUFBRTtRQUVsQyxJQUFJLENBQUMsWUFBWSxDQUFDLEVBQUUsQ0FBQyxHQUFHLElBQUksQ0FBQztRQUU3QixPQUFPLEVBQUUsQ0FBQztJQUNaLENBQUM7SUFFRCxjQUFjLENBQUMsT0FBb0I7UUFDakMsSUFBSSxPQUFPLElBQUksT0FBTyxDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUMsT0FBTyxDQUFDLEVBQUUsSUFBSSxJQUFJLENBQUMsWUFBWSxDQUFDLEVBQUU7WUFDL0QsT0FBTyxPQUFPLENBQUMsRUFBRSxDQUFDO1NBQ25CO1FBRUQsTUFBTSxFQUFFLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7UUFDMUQsSUFBSSxPQUFPLEVBQUU7WUFDWCxPQUFPLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQztTQUNqQjtRQUVELE9BQU8sRUFBRSxDQUFDO0lBQ1osQ0FBQztJQUVELE9BQU8sQ0FBQyxFQUFVO1FBQ2hCLE9BQU8sRUFBRSxJQUFJLElBQUksQ0FBQyxZQUFZLENBQUM7SUFDakMsQ0FBQztJQUVELFFBQVEsQ0FBQyxFQUFVO1FBQ2pCLE9BQU8sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQzNCLENBQUM7O2tIQW5DVSxxQkFBcUI7c0hBQXJCLHFCQUFxQjsyRkFBckIscUJBQXFCO2tCQURqQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgR3B0SURHZW5lcmF0b3JTZXJ2aWNlIHtcbiAgcHJpdmF0ZSBnZW5lcmF0ZWRJRHMgPSB7fTtcblxuICBnZW5lcmF0ZUlEKHR5cGUgPSAnZ3B0LWFkJyk6IHN0cmluZyB7XG4gICAgbGV0IGlkID0gJyc7XG5cbiAgICBkbyB7XG4gICAgICBjb25zdCBudW1iZXIgPSBNYXRoLnJhbmRvbSgpLnRvU3RyaW5nKCkuc2xpY2UoMik7XG4gICAgICBpZCA9IHR5cGUgKyAnLScgKyBudW1iZXI7XG4gICAgfSB3aGlsZSAoaWQgaW4gdGhpcy5nZW5lcmF0ZWRJRHMpO1xuXG4gICAgdGhpcy5nZW5lcmF0ZWRJRHNbaWRdID0gdHJ1ZTtcblxuICAgIHJldHVybiBpZDtcbiAgfVxuXG4gIGdwdElER2VuZXJhdG9yKGVsZW1lbnQ6IEhUTUxFbGVtZW50KTogc3RyaW5nIHtcbiAgICBpZiAoZWxlbWVudCAmJiBlbGVtZW50LmlkICYmICEoZWxlbWVudC5pZCBpbiB0aGlzLmdlbmVyYXRlZElEcykpIHtcbiAgICAgIHJldHVybiBlbGVtZW50LmlkO1xuICAgIH1cblxuICAgIGNvbnN0IGlkID0gdGhpcy5nZW5lcmF0ZUlEKGVsZW1lbnQudGFnTmFtZS50b0xvd2VyQ2FzZSgpKTtcbiAgICBpZiAoZWxlbWVudCkge1xuICAgICAgZWxlbWVudC5pZCA9IGlkO1xuICAgIH1cblxuICAgIHJldHVybiBpZDtcbiAgfVxuXG4gIGlzVGFrZW4oaWQ6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgIHJldHVybiBpZCBpbiB0aGlzLmdlbmVyYXRlZElEcztcbiAgfVxuXG4gIGlzVW5pcXVlKGlkOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICByZXR1cm4gIXRoaXMuaXNUYWtlbihpZCk7XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3B0LWlkR2VuZXJhdG9yLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9uZy1ncHQvc3JjL2xpYi9zZXJ2aWNlcy9ncHQtaWRHZW5lcmF0b3Iuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUczQyxNQUFNLE9BQU8scUJBQXFCO0lBRGxDO1FBRVUsaUJBQVksR0FBRyxFQUFFLENBQUM7S0FtQzNCO0lBakNDLFVBQVUsQ0FBQyxJQUFJLEdBQUcsUUFBUTtRQUN4QixJQUFJLEVBQUUsR0FBRyxFQUFFLENBQUM7UUFFWixHQUFHO1lBQ0QsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDLFFBQVEsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNqRCxFQUFFLEdBQUcsSUFBSSxHQUFHLEdBQUcsR0FBRyxNQUFNLENBQUM7U0FDMUIsUUFBUSxFQUFFLElBQUksSUFBSSxDQUFDLFlBQVksRUFBRTtRQUVsQyxJQUFJLENBQUMsWUFBWSxDQUFDLEVBQUUsQ0FBQyxHQUFHLElBQUksQ0FBQztRQUU3QixPQUFPLEVBQUUsQ0FBQztJQUNaLENBQUM7SUFFRCxjQUFjLENBQUMsT0FBb0I7UUFDakMsSUFBSSxPQUFPLElBQUksT0FBTyxDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUMsT0FBTyxDQUFDLEVBQUUsSUFBSSxJQUFJLENBQUMsWUFBWSxDQUFDLEVBQUU7WUFDL0QsT0FBTyxPQUFPLENBQUMsRUFBRSxDQUFDO1NBQ25CO1FBRUQsTUFBTSxFQUFFLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7UUFDMUQsSUFBSSxPQUFPLEVBQUU7WUFDWCxPQUFPLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQztTQUNqQjtRQUVELE9BQU8sRUFBRSxDQUFDO0lBQ1osQ0FBQztJQUVELE9BQU8sQ0FBQyxFQUFVO1FBQ2hCLE9BQU8sRUFBRSxJQUFJLElBQUksQ0FBQyxZQUFZLENBQUM7SUFDakMsQ0FBQztJQUVELFFBQVEsQ0FBQyxFQUFVO1FBQ2pCLE9BQU8sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQzNCLENBQUM7O2tIQW5DVSxxQkFBcUI7c0hBQXJCLHFCQUFxQjsyRkFBckIscUJBQXFCO2tCQURqQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgR3B0SURHZW5lcmF0b3JTZXJ2aWNlIHtcbiAgcHJpdmF0ZSBnZW5lcmF0ZWRJRHMgPSB7fTtcblxuICBnZW5lcmF0ZUlEKHR5cGUgPSAnZ3B0LWFkJyk6IHN0cmluZyB7XG4gICAgbGV0IGlkID0gJyc7XG5cbiAgICBkbyB7XG4gICAgICBjb25zdCBudW1iZXIgPSBNYXRoLnJhbmRvbSgpLnRvU3RyaW5nKCkuc2xpY2UoMik7XG4gICAgICBpZCA9IHR5cGUgKyAnLScgKyBudW1iZXI7XG4gICAgfSB3aGlsZSAoaWQgaW4gdGhpcy5nZW5lcmF0ZWRJRHMpO1xuXG4gICAgdGhpcy5nZW5lcmF0ZWRJRHNbaWRdID0gdHJ1ZTtcblxuICAgIHJldHVybiBpZDtcbiAgfVxuXG4gIGdwdElER2VuZXJhdG9yKGVsZW1lbnQ6IEhUTUxFbGVtZW50KTogc3RyaW5nIHtcbiAgICBpZiAoZWxlbWVudCAmJiBlbGVtZW50LmlkICYmICEoZWxlbWVudC5pZCBpbiB0aGlzLmdlbmVyYXRlZElEcykpIHtcbiAgICAgIHJldHVybiBlbGVtZW50LmlkO1xuICAgIH1cblxuICAgIGNvbnN0IGlkID0gdGhpcy5nZW5lcmF0ZUlEKGVsZW1lbnQudGFnTmFtZS50b0xvd2VyQ2FzZSgpKTtcbiAgICBpZiAoZWxlbWVudCkge1xuICAgICAgZWxlbWVudC5pZCA9IGlkO1xuICAgIH1cblxuICAgIHJldHVybiBpZDtcbiAgfVxuXG4gIGlzVGFrZW4oaWQ6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgIHJldHVybiBpZCBpbiB0aGlzLmdlbmVyYXRlZElEcztcbiAgfVxuXG4gIGlzVW5pcXVlKGlkOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICByZXR1cm4gIXRoaXMuaXNUYWtlbihpZCk7XG4gIH1cbn1cbiJdfQ==

@@ -126,2 +126,2 @@ import { Injectable, EventEmitter, Optional, Inject, } from '@angular/core';

}] }, { type: i0.Injector }, { type: i1.ParseDurationService }]; } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gpt-refresh.service.js","sourceRoot":"","sources":["../../../../../projects/ng-gpt/src/lib/services/gpt-refresh.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Injectable,\n  EventEmitter,\n  Optional,\n  Injector,\n  Inject,\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\n\nimport { Subscription, timer, from } from 'rxjs';\n\nimport { GptConfig, GPT_CONFIG } from '../gpt.config';\nimport { ParseDurationService } from '.';\n\nclass GPTRefreshError extends Error {}\n\ndeclare var googletag;\n\n@Injectable()\nexport class GptRefreshService {\n  refreshEvent: EventEmitter<any> = new EventEmitter();\n  private refreshSlots: any[] = [];\n  private singleRequest: Subscription;\n  private intervals = {};\n\n  constructor(\n    @Optional()\n    @Inject(GPT_CONFIG)\n    private config: GptConfig,\n    private inject: Injector,\n    private parseDuration: ParseDurationService\n  ) {}\n\n  slotRefresh(slot, refreshInterval?, initRefresh = false) {\n    const deferred: Promise<any> = from([slot]).toPromise(),\n      task = { slot: slot, deferred: deferred };\n\n    deferred.then(() => {\n      if (this.hasSlotInterval(slot)) {\n        this.cancelInterval(slot);\n      }\n      if (refreshInterval) {\n        this.addSlotInterval(task, refreshInterval);\n      }\n    });\n\n    if (this.config.singleRequestMode === true && initRefresh) {\n      // Use a timer to handle refresh of a single request mode\n      this.refreshSlots.push(slot);\n      if (this.singleRequest && !this.singleRequest.closed) {\n        this.singleRequest.unsubscribe();\n      }\n      this.singleRequest = timer(100).subscribe(() => {\n        const pubads = googletag.pubads();\n        pubads.enableSingleRequest();\n        googletag.enableServices();\n        this.refreshSlots.forEach((s: any) => {\n          googletag.display(s.getSlotElementId());\n        });\n        pubads.refresh(this.refreshSlots);\n        this.refreshSlots = [];\n      });\n    } else {\n      googletag.display(slot.getSlotElementId());\n      this.refresh([task]);\n    }\n\n    return deferred;\n  }\n\n  cancelInterval(slot) {\n    if (!this.hasSlotInterval(slot)) {\n      throw new GPTRefreshError('No interval for given slot');\n    }\n\n    const interval: Subscription = this.intervals[this.slotIntervalKey(slot)];\n    interval.unsubscribe();\n    delete this.intervals[slot];\n\n    return this;\n  }\n\n  private hasSlotInterval(slot) {\n    return this.slotIntervalKey(slot) in this.intervals;\n  }\n\n  private refresh(tasks?) {\n    if (tasks === undefined) {\n      googletag.cmd.push(() => {\n        googletag.pubads().refresh();\n      });\n      return;\n    }\n\n    if (tasks.length === 0) {\n      return false;\n    }\n\n    googletag.cmd.push(() => {\n      googletag.pubads().refresh(tasks.map((task) => task.slot));\n      tasks.forEach((task) => {\n        Promise.resolve(task.slot);\n      });\n    });\n\n    return true;\n  }\n\n  private addSlotInterval(task, interval) {\n    const parsedInterval = this.parseDuration.parseDuration(interval);\n    this.validateInterval(parsedInterval, interval);\n\n    const refresh = timer(parsedInterval, parsedInterval).subscribe(() => {\n      const doc = this.inject.get(DOCUMENT);\n      if (!this.hiddenCheck(doc.getElementById(task.slot.getSlotElementId()))) {\n        this.refresh([task]);\n        this.refreshEvent.emit(task.slot);\n      }\n    });\n\n    this.intervals[this.slotIntervalKey(task.slot)] = refresh;\n\n    return refresh;\n  }\n\n  private slotIntervalKey(slot) {\n    return slot.getSlotId().getDomId();\n  }\n\n  private validateInterval(milliseconds, beforeParsing) {\n    if (milliseconds < 1000) {\n      console.warn('Careful: ${beforeParsing} is quite a low interval!');\n    }\n  }\n\n  hiddenCheck(element: any) {\n    if (typeof window !== 'undefined') {\n      const css = window.getComputedStyle(element);\n      if (css.display === 'none') {\n        return true;\n      } else if (element.parentElement) {\n        return this.hiddenCheck(element.parentElement);\n      }\n    }\n    return false;\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gpt-refresh.service.js","sourceRoot":"","sources":["../../../../../ng-gpt/src/lib/services/gpt-refresh.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Injectable,\n  EventEmitter,\n  Optional,\n  Injector,\n  Inject,\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\n\nimport { Subscription, timer, from } from 'rxjs';\n\nimport { GptConfig, GPT_CONFIG } from '../gpt.config';\nimport { ParseDurationService } from '.';\n\nclass GPTRefreshError extends Error {}\n\ndeclare var googletag;\n\n@Injectable()\nexport class GptRefreshService {\n  refreshEvent: EventEmitter<any> = new EventEmitter();\n  private refreshSlots: any[] = [];\n  private singleRequest: Subscription;\n  private intervals = {};\n\n  constructor(\n    @Optional()\n    @Inject(GPT_CONFIG)\n    private config: GptConfig,\n    private inject: Injector,\n    private parseDuration: ParseDurationService\n  ) {}\n\n  slotRefresh(slot, refreshInterval?, initRefresh = false) {\n    const deferred: Promise<any> = from([slot]).toPromise(),\n      task = { slot: slot, deferred: deferred };\n\n    deferred.then(() => {\n      if (this.hasSlotInterval(slot)) {\n        this.cancelInterval(slot);\n      }\n      if (refreshInterval) {\n        this.addSlotInterval(task, refreshInterval);\n      }\n    });\n\n    if (this.config.singleRequestMode === true && initRefresh) {\n      // Use a timer to handle refresh of a single request mode\n      this.refreshSlots.push(slot);\n      if (this.singleRequest && !this.singleRequest.closed) {\n        this.singleRequest.unsubscribe();\n      }\n      this.singleRequest = timer(100).subscribe(() => {\n        const pubads = googletag.pubads();\n        pubads.enableSingleRequest();\n        googletag.enableServices();\n        this.refreshSlots.forEach((s: any) => {\n          googletag.display(s.getSlotElementId());\n        });\n        pubads.refresh(this.refreshSlots);\n        this.refreshSlots = [];\n      });\n    } else {\n      googletag.display(slot.getSlotElementId());\n      this.refresh([task]);\n    }\n\n    return deferred;\n  }\n\n  cancelInterval(slot) {\n    if (!this.hasSlotInterval(slot)) {\n      throw new GPTRefreshError('No interval for given slot');\n    }\n\n    const interval: Subscription = this.intervals[this.slotIntervalKey(slot)];\n    interval.unsubscribe();\n    delete this.intervals[slot];\n\n    return this;\n  }\n\n  private hasSlotInterval(slot) {\n    return this.slotIntervalKey(slot) in this.intervals;\n  }\n\n  private refresh(tasks?) {\n    if (tasks === undefined) {\n      googletag.cmd.push(() => {\n        googletag.pubads().refresh();\n      });\n      return;\n    }\n\n    if (tasks.length === 0) {\n      return false;\n    }\n\n    googletag.cmd.push(() => {\n      googletag.pubads().refresh(tasks.map((task) => task.slot));\n      tasks.forEach((task) => {\n        Promise.resolve(task.slot);\n      });\n    });\n\n    return true;\n  }\n\n  private addSlotInterval(task, interval) {\n    const parsedInterval = this.parseDuration.parseDuration(interval);\n    this.validateInterval(parsedInterval, interval);\n\n    const refresh = timer(parsedInterval, parsedInterval).subscribe(() => {\n      const doc = this.inject.get(DOCUMENT);\n      if (!this.hiddenCheck(doc.getElementById(task.slot.getSlotElementId()))) {\n        this.refresh([task]);\n        this.refreshEvent.emit(task.slot);\n      }\n    });\n\n    this.intervals[this.slotIntervalKey(task.slot)] = refresh;\n\n    return refresh;\n  }\n\n  private slotIntervalKey(slot) {\n    return slot.getSlotId().getDomId();\n  }\n\n  private validateInterval(milliseconds, beforeParsing) {\n    if (milliseconds < 1000) {\n      console.warn('Careful: ${beforeParsing} is quite a low interval!');\n    }\n  }\n\n  hiddenCheck(element: any) {\n    if (typeof window !== 'undefined') {\n      const css = window.getComputedStyle(element);\n      if (css.display === 'none') {\n        return true;\n      } else if (element.parentElement) {\n        return this.hiddenCheck(element.parentElement);\n      }\n    }\n    return false;\n  }\n}\n"]}

@@ -21,2 +21,2 @@ import { Injectable } from '@angular/core';

}] });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cC1lcnJvci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZ3B0L3NyYy9saWIvc2VydmljZXMvaHR0cC1lcnJvci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRzNDLE1BQU0sT0FBTyxnQkFBZ0I7SUFEN0I7UUFNRSxnQkFBVyxHQUFHLFVBQVUsSUFBSTtZQUMxQixJQUFJLE9BQU8sSUFBSSxLQUFLLFFBQVEsRUFBRTtnQkFDNUIsT0FBTyxDQUFDLENBQUMsSUFBSSxJQUFJLEdBQUcsSUFBSSxJQUFJLEdBQUcsR0FBRyxDQUFDLENBQUM7YUFDckM7WUFDRCxPQUFPLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxHQUFHLENBQUM7UUFDekIsQ0FBQyxDQUFDO0tBQ0g7SUFWQyxTQUFTLENBQUMsUUFBYSxFQUFFLE9BQWU7UUFDdEMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxVQUFVLFFBQVEsQ0FBQyxNQUFNLEtBQUssT0FBTyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDdEUsQ0FBQzs7NkdBSFUsZ0JBQWdCO2lIQUFoQixnQkFBZ0I7MkZBQWhCLGdCQUFnQjtrQkFENUIsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIEh0dHBFcnJvclNlcnZpY2Uge1xuICBodHRwRXJyb3IocmVzcG9uc2U6IGFueSwgbWVzc2FnZTogc3RyaW5nKSB7XG4gICAgY29uc29sZS5sb2coYEVycm9yICgke3Jlc3BvbnNlLnN0YXR1c30pICR7bWVzc2FnZSA/IG1lc3NhZ2UgOiAnJ31gKTtcbiAgfVxuXG4gIGlzRXJyb3JDb2RlID0gZnVuY3Rpb24gKGNvZGUpIHtcbiAgICBpZiAodHlwZW9mIGNvZGUgPT09ICdudW1iZXInKSB7XG4gICAgICByZXR1cm4gIShjb2RlID49IDIwMCAmJiBjb2RlIDwgMzAwKTtcbiAgICB9XG4gICAgcmV0dXJuIGNvZGVbMF0gIT09ICcyJztcbiAgfTtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cC1lcnJvci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbmctZ3B0L3NyYy9saWIvc2VydmljZXMvaHR0cC1lcnJvci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRzNDLE1BQU0sT0FBTyxnQkFBZ0I7SUFEN0I7UUFNRSxnQkFBVyxHQUFHLFVBQVUsSUFBSTtZQUMxQixJQUFJLE9BQU8sSUFBSSxLQUFLLFFBQVEsRUFBRTtnQkFDNUIsT0FBTyxDQUFDLENBQUMsSUFBSSxJQUFJLEdBQUcsSUFBSSxJQUFJLEdBQUcsR0FBRyxDQUFDLENBQUM7YUFDckM7WUFDRCxPQUFPLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxHQUFHLENBQUM7UUFDekIsQ0FBQyxDQUFDO0tBQ0g7SUFWQyxTQUFTLENBQUMsUUFBYSxFQUFFLE9BQWU7UUFDdEMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxVQUFVLFFBQVEsQ0FBQyxNQUFNLEtBQUssT0FBTyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDdEUsQ0FBQzs7NkdBSFUsZ0JBQWdCO2lIQUFoQixnQkFBZ0I7MkZBQWhCLGdCQUFnQjtrQkFENUIsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIEh0dHBFcnJvclNlcnZpY2Uge1xuICBodHRwRXJyb3IocmVzcG9uc2U6IGFueSwgbWVzc2FnZTogc3RyaW5nKSB7XG4gICAgY29uc29sZS5sb2coYEVycm9yICgke3Jlc3BvbnNlLnN0YXR1c30pICR7bWVzc2FnZSA/IG1lc3NhZ2UgOiAnJ31gKTtcbiAgfVxuXG4gIGlzRXJyb3JDb2RlID0gZnVuY3Rpb24gKGNvZGUpIHtcbiAgICBpZiAodHlwZW9mIGNvZGUgPT09ICdudW1iZXInKSB7XG4gICAgICByZXR1cm4gIShjb2RlID49IDIwMCAmJiBjb2RlIDwgMzAwKTtcbiAgICB9XG4gICAgcmV0dXJuIGNvZGVbMF0gIT09ICcyJztcbiAgfTtcbn1cbiJdfQ==

@@ -30,2 +30,2 @@ import { isPlatformBrowser } from '@angular/common';

}] }, { type: i0.NgZone }]; } });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWRsZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZ3B0L3NyYy9saWIvc2VydmljZXMvaWRsZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFVLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFHeEUsTUFBTSxPQUFPLFdBQVc7SUFHdEIsWUFBaUMsVUFBa0IsRUFBRSxJQUFZO1FBQy9ELE1BQU0sQ0FBQyxHQUFRLGlCQUFpQixDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUMzRCxJQUFJLENBQUMsQ0FBQyxtQkFBbUIsRUFBRTtZQUN6QixJQUFJLENBQUMsbUJBQW1CLEdBQUcsQ0FBQyxHQUFhLEVBQUUsRUFBRTtnQkFDM0MsT0FBTyxDQUFDLENBQUMsbUJBQW1CLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDcEMsQ0FBQyxDQUFDO1NBQ0g7YUFBTTtZQUNMLElBQUksQ0FBQyxtQkFBbUIsR0FBRyxDQUFDLEdBQWEsRUFBRSxFQUFFO2dCQUMzQyxPQUFPLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUMsVUFBVSxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDO1lBQzdELENBQUMsQ0FBQztTQUNIO0lBQ0gsQ0FBQztJQUVELE9BQU8sQ0FBQyxHQUFhO1FBQ25CLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNoQyxDQUFDOzt3R0FsQlUsV0FBVyxrQkFHRixXQUFXOzRHQUhwQixXQUFXOzJGQUFYLFdBQVc7a0JBRHZCLFVBQVU7MERBSW9DLE1BQU07MEJBQXRDLE1BQU07MkJBQUMsV0FBVyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGlzUGxhdGZvcm1Ccm93c2VyIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSwgTmdab25lLCBQTEFURk9STV9JRCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgSWRsZVNlcnZpY2Uge1xuICBwcml2YXRlIHJlcXVlc3RJZGxlQ2FsbGJhY2s6IGFueTtcblxuICBjb25zdHJ1Y3RvcihASW5qZWN0KFBMQVRGT1JNX0lEKSBwbGF0Zm9ybUlkOiBPYmplY3QsIHpvbmU6IE5nWm9uZSkge1xuICAgIGNvbnN0IHc6IGFueSA9IGlzUGxhdGZvcm1Ccm93c2VyKHBsYXRmb3JtSWQpID8gd2luZG93IDoge307XG4gICAgaWYgKHcucmVxdWVzdElkbGVDYWxsYmFjaykge1xuICAgICAgdGhpcy5yZXF1ZXN0SWRsZUNhbGxiYWNrID0gKGZ1bjogRnVuY3Rpb24pID0+IHtcbiAgICAgICAgcmV0dXJuIHcucmVxdWVzdElkbGVDYWxsYmFjayhmdW4pO1xuICAgICAgfTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5yZXF1ZXN0SWRsZUNhbGxiYWNrID0gKGZ1bjogRnVuY3Rpb24pID0+IHtcbiAgICAgICAgcmV0dXJuIHpvbmUucnVuT3V0c2lkZUFuZ3VsYXIoKCkgPT4gdy5zZXRUaW1lb3V0KGZ1biwgNTApKTtcbiAgICAgIH07XG4gICAgfVxuICB9XG5cbiAgcmVxdWVzdChmdW46IEZ1bmN0aW9uKSB7XG4gICAgdGhpcy5yZXF1ZXN0SWRsZUNhbGxiYWNrKGZ1bik7XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWRsZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbmctZ3B0L3NyYy9saWIvc2VydmljZXMvaWRsZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFVLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFHeEUsTUFBTSxPQUFPLFdBQVc7SUFHdEIsWUFBaUMsVUFBa0IsRUFBRSxJQUFZO1FBQy9ELE1BQU0sQ0FBQyxHQUFRLGlCQUFpQixDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUMzRCxJQUFJLENBQUMsQ0FBQyxtQkFBbUIsRUFBRTtZQUN6QixJQUFJLENBQUMsbUJBQW1CLEdBQUcsQ0FBQyxHQUFhLEVBQUUsRUFBRTtnQkFDM0MsT0FBTyxDQUFDLENBQUMsbUJBQW1CLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDcEMsQ0FBQyxDQUFDO1NBQ0g7YUFBTTtZQUNMLElBQUksQ0FBQyxtQkFBbUIsR0FBRyxDQUFDLEdBQWEsRUFBRSxFQUFFO2dCQUMzQyxPQUFPLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUMsVUFBVSxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDO1lBQzdELENBQUMsQ0FBQztTQUNIO0lBQ0gsQ0FBQztJQUVELE9BQU8sQ0FBQyxHQUFhO1FBQ25CLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNoQyxDQUFDOzt3R0FsQlUsV0FBVyxrQkFHRixXQUFXOzRHQUhwQixXQUFXOzJGQUFYLFdBQVc7a0JBRHZCLFVBQVU7MERBSW9DLE1BQU07MEJBQXRDLE1BQU07MkJBQUMsV0FBVyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGlzUGxhdGZvcm1Ccm93c2VyIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSwgTmdab25lLCBQTEFURk9STV9JRCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgSWRsZVNlcnZpY2Uge1xuICBwcml2YXRlIHJlcXVlc3RJZGxlQ2FsbGJhY2s6IGFueTtcblxuICBjb25zdHJ1Y3RvcihASW5qZWN0KFBMQVRGT1JNX0lEKSBwbGF0Zm9ybUlkOiBPYmplY3QsIHpvbmU6IE5nWm9uZSkge1xuICAgIGNvbnN0IHc6IGFueSA9IGlzUGxhdGZvcm1Ccm93c2VyKHBsYXRmb3JtSWQpID8gd2luZG93IDoge307XG4gICAgaWYgKHcucmVxdWVzdElkbGVDYWxsYmFjaykge1xuICAgICAgdGhpcy5yZXF1ZXN0SWRsZUNhbGxiYWNrID0gKGZ1bjogRnVuY3Rpb24pID0+IHtcbiAgICAgICAgcmV0dXJuIHcucmVxdWVzdElkbGVDYWxsYmFjayhmdW4pO1xuICAgICAgfTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5yZXF1ZXN0SWRsZUNhbGxiYWNrID0gKGZ1bjogRnVuY3Rpb24pID0+IHtcbiAgICAgICAgcmV0dXJuIHpvbmUucnVuT3V0c2lkZUFuZ3VsYXIoKCkgPT4gdy5zZXRUaW1lb3V0KGZ1biwgNTApKTtcbiAgICAgIH07XG4gICAgfVxuICB9XG5cbiAgcmVxdWVzdChmdW46IEZ1bmN0aW9uKSB7XG4gICAgdGhpcy5yZXF1ZXN0SWRsZUNhbGxiYWNrKGZ1bik7XG4gIH1cbn1cbiJdfQ==

@@ -7,2 +7,2 @@ export { ScriptInjectorService } from './script-injector.service';

export { GptRefreshService } from './gpt-refresh.service';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1ncHQvc3JjL2xpYi9zZXJ2aWNlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUNwRSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDaEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBTY3JpcHRJbmplY3RvclNlcnZpY2UgfSBmcm9tICcuL3NjcmlwdC1pbmplY3Rvci5zZXJ2aWNlJztcbmV4cG9ydCB7IEh0dHBFcnJvclNlcnZpY2UgfSBmcm9tICcuL2h0dHAtZXJyb3Iuc2VydmljZSc7XG5leHBvcnQgeyBQdWJhZHNTZXRDb25maWdTZXJ2aWNlIH0gZnJvbSAnLi9wdWJhZHMuc2V0Q29uZmlnLnNlcnZpY2UnO1xuZXhwb3J0IHsgSWRsZVNlcnZpY2UgfSBmcm9tICcuL2lkbGUuc2VydmljZSc7XG5leHBvcnQgeyBQYXJzZUR1cmF0aW9uU2VydmljZSB9IGZyb20gJy4vcGFyc2UtZHVyYXRpb24uc2VydmljZSc7XG5leHBvcnQgeyBHcHRSZWZyZXNoU2VydmljZSB9IGZyb20gJy4vZ3B0LXJlZnJlc2guc2VydmljZSc7XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9uZy1ncHQvc3JjL2xpYi9zZXJ2aWNlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUNwRSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDaEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBTY3JpcHRJbmplY3RvclNlcnZpY2UgfSBmcm9tICcuL3NjcmlwdC1pbmplY3Rvci5zZXJ2aWNlJztcbmV4cG9ydCB7IEh0dHBFcnJvclNlcnZpY2UgfSBmcm9tICcuL2h0dHAtZXJyb3Iuc2VydmljZSc7XG5leHBvcnQgeyBQdWJhZHNTZXRDb25maWdTZXJ2aWNlIH0gZnJvbSAnLi9wdWJhZHMuc2V0Q29uZmlnLnNlcnZpY2UnO1xuZXhwb3J0IHsgSWRsZVNlcnZpY2UgfSBmcm9tICcuL2lkbGUuc2VydmljZSc7XG5leHBvcnQgeyBQYXJzZUR1cmF0aW9uU2VydmljZSB9IGZyb20gJy4vcGFyc2UtZHVyYXRpb24uc2VydmljZSc7XG5leHBvcnQgeyBHcHRSZWZyZXNoU2VydmljZSB9IGZyb20gJy4vZ3B0LXJlZnJlc2guc2VydmljZSc7XG4iXX0=

@@ -51,2 +51,2 @@ import { Injectable } from '@angular/core';

}] });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyc2UtZHVyYXRpb24uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLWdwdC9zcmMvbGliL3NlcnZpY2VzL3BhcnNlLWR1cmF0aW9uLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFM0MsTUFBTSxnQkFBaUIsU0FBUSxLQUFLO0lBQ2xDLFlBQVksUUFBUTtRQUNsQixLQUFLLENBQUMsc0JBQXNCLFFBQVEsS0FBSyxDQUFDLENBQUM7SUFDN0MsQ0FBQztDQUNGO0FBR0QsTUFBTSxPQUFPLG9CQUFvQjtJQUMvQixxQkFBcUIsQ0FBQyxJQUFJLEVBQUUsSUFBSTtRQUM5QixPQUFPLENBQUMsTUFBTSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1FBRTVDLElBQUksSUFBSSxLQUFLLElBQUksRUFBRTtZQUNqQixPQUFPLElBQUksQ0FBQztTQUNiO1FBQ0QsSUFBSSxJQUFJLEtBQUssR0FBRyxFQUFFO1lBQ2hCLE9BQU8sSUFBSSxHQUFHLElBQUksQ0FBQztTQUNwQjtRQUNELElBQUksSUFBSSxLQUFLLEtBQUssRUFBRTtZQUNsQixPQUFPLElBQUksR0FBRyxFQUFFLEdBQUcsSUFBSSxDQUFDO1NBQ3pCO1FBRUQsT0FBTyxJQUFJLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUM7SUFDL0IsQ0FBQztJQUVELE9BQU8sQ0FBQyxLQUFLO1FBQ1gsTUFBTSxJQUFJLEdBQUcsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBRWxDLElBQUksS0FBSyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7WUFDdEIsT0FBTyxJQUFJLENBQUM7U0FDYjtRQUVELE9BQU8sSUFBSSxDQUFDLHFCQUFxQixDQUFDLElBQUksRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNwRCxDQUFDO0lBRUQsYUFBYSxDQUFDLFFBQVE7UUFDcEIsSUFBSSxRQUFRLEtBQUssU0FBUyxJQUFJLFFBQVEsS0FBSyxJQUFJLEVBQUU7WUFDL0MsTUFBTSxJQUFJLGdCQUFnQixDQUFDLFFBQVEsQ0FBQyxDQUFDO1NBQ3RDO1FBRUQsSUFBSSxPQUFPLFFBQVEsS0FBSyxRQUFRLEVBQUU7WUFDaEMsT0FBTyxRQUFRLENBQUM7U0FDakI7UUFFRCxJQUFJLE9BQU8sUUFBUSxLQUFLLFFBQVEsRUFBRTtZQUNoQyxNQUFNLElBQUksU0FBUyxDQUFDLElBQUksUUFBUSxvQ0FBb0MsQ0FBQyxDQUFDO1NBQ3ZFO1FBRUQsTUFBTSxLQUFLLEdBQUcsUUFBUSxDQUFDLEtBQUssQ0FBQyw2QkFBNkIsQ0FBQyxDQUFDO1FBRTVELElBQUksQ0FBQyxLQUFLLEVBQUU7WUFDVixNQUFNLElBQUksZ0JBQWdCLENBQUMsUUFBUSxDQUFDLENBQUM7U0FDdEM7UUFFRCxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDN0IsQ0FBQzs7aUhBL0NVLG9CQUFvQjtxSEFBcEIsb0JBQW9COzJGQUFwQixvQkFBb0I7a0JBRGhDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmNsYXNzIEdQVER1cmF0aW9uRXJyb3IgZXh0ZW5kcyBFcnJvciB7XG4gIGNvbnN0cnVjdG9yKGludGVydmFsKSB7XG4gICAgc3VwZXIoYEludmFsaWQgaW50ZXJ2YWw6ICcke2ludGVydmFsfSdsc2ApO1xuICB9XG59XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBQYXJzZUR1cmF0aW9uU2VydmljZSB7XG4gIGNvbnZlcnRUb01pbGxpc2Vjb25kcyh0aW1lLCB1bml0KSB7XG4gICAgY29uc29sZS5hc3NlcnQoL14obT9zfG1pbnxoKSQvZy50ZXN0KHVuaXQpKTtcblxuICAgIGlmICh1bml0ID09PSAnbXMnKSB7XG4gICAgICByZXR1cm4gdGltZTtcbiAgICB9XG4gICAgaWYgKHVuaXQgPT09ICdzJykge1xuICAgICAgcmV0dXJuIHRpbWUgKiAxMDAwO1xuICAgIH1cbiAgICBpZiAodW5pdCA9PT0gJ21pbicpIHtcbiAgICAgIHJldHVybiB0aW1lICogNjAgKiAxMDAwO1xuICAgIH1cblxuICAgIHJldHVybiB0aW1lICogNjAgKiA2MCAqIDEwMDA7XG4gIH1cblxuICBjb252ZXJ0KG1hdGNoKSB7XG4gICAgY29uc3QgdGltZSA9IHBhcnNlRmxvYXQobWF0Y2hbMV0pO1xuXG4gICAgaWYgKG1hdGNoLmxlbmd0aCA9PT0gMikge1xuICAgICAgcmV0dXJuIHRpbWU7XG4gICAgfVxuXG4gICAgcmV0dXJuIHRoaXMuY29udmVydFRvTWlsbGlzZWNvbmRzKHRpbWUsIG1hdGNoWzJdKTtcbiAgfVxuXG4gIHBhcnNlRHVyYXRpb24oaW50ZXJ2YWwpIHtcbiAgICBpZiAoaW50ZXJ2YWwgPT09IHVuZGVmaW5lZCB8fCBpbnRlcnZhbCA9PT0gbnVsbCkge1xuICAgICAgdGhyb3cgbmV3IEdQVER1cmF0aW9uRXJyb3IoaW50ZXJ2YWwpO1xuICAgIH1cblxuICAgIGlmICh0eXBlb2YgaW50ZXJ2YWwgPT09ICdudW1iZXInKSB7XG4gICAgICByZXR1cm4gaW50ZXJ2YWw7XG4gICAgfVxuXG4gICAgaWYgKHR5cGVvZiBpbnRlcnZhbCAhPT0gJ3N0cmluZycpIHtcbiAgICAgIHRocm93IG5ldyBUeXBlRXJyb3IoYCcke2ludGVydmFsfScgbXVzdCBiZSBvZiBudW1iZXIgb3Igc3RyaW5nIHR5cGVgKTtcbiAgICB9XG5cbiAgICBjb25zdCBtYXRjaCA9IGludGVydmFsLm1hdGNoKC8oKD86XFxkKyk/Lj9cXGQrKShtP3N8bWlufGgpPy8pO1xuXG4gICAgaWYgKCFtYXRjaCkge1xuICAgICAgdGhyb3cgbmV3IEdQVER1cmF0aW9uRXJyb3IoaW50ZXJ2YWwpO1xuICAgIH1cblxuICAgIHJldHVybiB0aGlzLmNvbnZlcnQobWF0Y2gpO1xuICB9XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyc2UtZHVyYXRpb24uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL25nLWdwdC9zcmMvbGliL3NlcnZpY2VzL3BhcnNlLWR1cmF0aW9uLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFM0MsTUFBTSxnQkFBaUIsU0FBUSxLQUFLO0lBQ2xDLFlBQVksUUFBUTtRQUNsQixLQUFLLENBQUMsc0JBQXNCLFFBQVEsS0FBSyxDQUFDLENBQUM7SUFDN0MsQ0FBQztDQUNGO0FBR0QsTUFBTSxPQUFPLG9CQUFvQjtJQUMvQixxQkFBcUIsQ0FBQyxJQUFJLEVBQUUsSUFBSTtRQUM5QixPQUFPLENBQUMsTUFBTSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1FBRTVDLElBQUksSUFBSSxLQUFLLElBQUksRUFBRTtZQUNqQixPQUFPLElBQUksQ0FBQztTQUNiO1FBQ0QsSUFBSSxJQUFJLEtBQUssR0FBRyxFQUFFO1lBQ2hCLE9BQU8sSUFBSSxHQUFHLElBQUksQ0FBQztTQUNwQjtRQUNELElBQUksSUFBSSxLQUFLLEtBQUssRUFBRTtZQUNsQixPQUFPLElBQUksR0FBRyxFQUFFLEdBQUcsSUFBSSxDQUFDO1NBQ3pCO1FBRUQsT0FBTyxJQUFJLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUM7SUFDL0IsQ0FBQztJQUVELE9BQU8sQ0FBQyxLQUFLO1FBQ1gsTUFBTSxJQUFJLEdBQUcsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBRWxDLElBQUksS0FBSyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7WUFDdEIsT0FBTyxJQUFJLENBQUM7U0FDYjtRQUVELE9BQU8sSUFBSSxDQUFDLHFCQUFxQixDQUFDLElBQUksRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNwRCxDQUFDO0lBRUQsYUFBYSxDQUFDLFFBQVE7UUFDcEIsSUFBSSxRQUFRLEtBQUssU0FBUyxJQUFJLFFBQVEsS0FBSyxJQUFJLEVBQUU7WUFDL0MsTUFBTSxJQUFJLGdCQUFnQixDQUFDLFFBQVEsQ0FBQyxDQUFDO1NBQ3RDO1FBRUQsSUFBSSxPQUFPLFFBQVEsS0FBSyxRQUFRLEVBQUU7WUFDaEMsT0FBTyxRQUFRLENBQUM7U0FDakI7UUFFRCxJQUFJLE9BQU8sUUFBUSxLQUFLLFFBQVEsRUFBRTtZQUNoQyxNQUFNLElBQUksU0FBUyxDQUFDLElBQUksUUFBUSxvQ0FBb0MsQ0FBQyxDQUFDO1NBQ3ZFO1FBRUQsTUFBTSxLQUFLLEdBQUcsUUFBUSxDQUFDLEtBQUssQ0FBQyw2QkFBNkIsQ0FBQyxDQUFDO1FBRTVELElBQUksQ0FBQyxLQUFLLEVBQUU7WUFDVixNQUFNLElBQUksZ0JBQWdCLENBQUMsUUFBUSxDQUFDLENBQUM7U0FDdEM7UUFFRCxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDN0IsQ0FBQzs7aUhBL0NVLG9CQUFvQjtxSEFBcEIsb0JBQW9COzJGQUFwQixvQkFBb0I7a0JBRGhDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmNsYXNzIEdQVER1cmF0aW9uRXJyb3IgZXh0ZW5kcyBFcnJvciB7XG4gIGNvbnN0cnVjdG9yKGludGVydmFsKSB7XG4gICAgc3VwZXIoYEludmFsaWQgaW50ZXJ2YWw6ICcke2ludGVydmFsfSdsc2ApO1xuICB9XG59XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBQYXJzZUR1cmF0aW9uU2VydmljZSB7XG4gIGNvbnZlcnRUb01pbGxpc2Vjb25kcyh0aW1lLCB1bml0KSB7XG4gICAgY29uc29sZS5hc3NlcnQoL14obT9zfG1pbnxoKSQvZy50ZXN0KHVuaXQpKTtcblxuICAgIGlmICh1bml0ID09PSAnbXMnKSB7XG4gICAgICByZXR1cm4gdGltZTtcbiAgICB9XG4gICAgaWYgKHVuaXQgPT09ICdzJykge1xuICAgICAgcmV0dXJuIHRpbWUgKiAxMDAwO1xuICAgIH1cbiAgICBpZiAodW5pdCA9PT0gJ21pbicpIHtcbiAgICAgIHJldHVybiB0aW1lICogNjAgKiAxMDAwO1xuICAgIH1cblxuICAgIHJldHVybiB0aW1lICogNjAgKiA2MCAqIDEwMDA7XG4gIH1cblxuICBjb252ZXJ0KG1hdGNoKSB7XG4gICAgY29uc3QgdGltZSA9IHBhcnNlRmxvYXQobWF0Y2hbMV0pO1xuXG4gICAgaWYgKG1hdGNoLmxlbmd0aCA9PT0gMikge1xuICAgICAgcmV0dXJuIHRpbWU7XG4gICAgfVxuXG4gICAgcmV0dXJuIHRoaXMuY29udmVydFRvTWlsbGlzZWNvbmRzKHRpbWUsIG1hdGNoWzJdKTtcbiAgfVxuXG4gIHBhcnNlRHVyYXRpb24oaW50ZXJ2YWwpIHtcbiAgICBpZiAoaW50ZXJ2YWwgPT09IHVuZGVmaW5lZCB8fCBpbnRlcnZhbCA9PT0gbnVsbCkge1xuICAgICAgdGhyb3cgbmV3IEdQVER1cmF0aW9uRXJyb3IoaW50ZXJ2YWwpO1xuICAgIH1cblxuICAgIGlmICh0eXBlb2YgaW50ZXJ2YWwgPT09ICdudW1iZXInKSB7XG4gICAgICByZXR1cm4gaW50ZXJ2YWw7XG4gICAgfVxuXG4gICAgaWYgKHR5cGVvZiBpbnRlcnZhbCAhPT0gJ3N0cmluZycpIHtcbiAgICAgIHRocm93IG5ldyBUeXBlRXJyb3IoYCcke2ludGVydmFsfScgbXVzdCBiZSBvZiBudW1iZXIgb3Igc3RyaW5nIHR5cGVgKTtcbiAgICB9XG5cbiAgICBjb25zdCBtYXRjaCA9IGludGVydmFsLm1hdGNoKC8oKD86XFxkKyk/Lj9cXGQrKShtP3N8bWlufGgpPy8pO1xuXG4gICAgaWYgKCFtYXRjaCkge1xuICAgICAgdGhyb3cgbmV3IEdQVER1cmF0aW9uRXJyb3IoaW50ZXJ2YWwpO1xuICAgIH1cblxuICAgIHJldHVybiB0aGlzLmNvbnZlcnQobWF0Y2gpO1xuICB9XG59XG4iXX0=

@@ -57,2 +57,2 @@ import { Injectable } from '@angular/core';

}] });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHViYWRzLnNldENvbmZpZy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZ3B0L3NyYy9saWIvc2VydmljZXMvcHViYWRzLnNldENvbmZpZy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBSTNDLE1BQU0sT0FBTyxzQkFBc0I7SUFDakM7Ozs7O09BS0c7SUFDSSxXQUFXLENBQUMsT0FBZSxFQUFFLE1BQXFCO1FBQ3ZELElBQUksT0FBTyxFQUFFO1lBQ1gsTUFBTSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQztTQUM3QjtJQUNILENBQUM7SUFFRDs7Ozs7T0FLRztJQUNJLE9BQU8sQ0FBQyxJQUFZLEVBQUUsTUFBcUI7UUFDaEQsSUFBSSxJQUFJLEVBQUU7WUFDUixNQUFNLENBQUMsc0JBQXNCLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDckM7SUFDSCxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSSxZQUFZLENBQUMsZUFBdUIsRUFBRSxNQUFxQjtRQUNoRSxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLENBQUMsTUFBTSxFQUFFO1lBQ3ZDLEtBQUssTUFBTSxHQUFHLElBQUksZUFBZSxFQUFFO2dCQUNqQyxJQUFJLGVBQWUsQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUFDLEVBQUU7b0JBQ3ZDLE1BQU0sQ0FBQyxZQUFZLENBQUMsR0FBRyxFQUFFLGVBQWUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO2lCQUNoRDthQUNGO1NBQ0Y7SUFDSCxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSSxrQkFBa0IsQ0FDdkIsZUFBZ0MsRUFDaEMsTUFBcUI7UUFFckIsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDLE1BQU07WUFDckMsTUFBTSxDQUFDLGtCQUFrQixDQUFDLGVBQWUsQ0FBQyxDQUFDO0lBQy9DLENBQUM7O21IQXJEVSxzQkFBc0I7dUhBQXRCLHNCQUFzQjsyRkFBdEIsc0JBQXNCO2tCQURsQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUHViQWRzU2VydmljZSwgU2FmZUZyYW1lQ29uZmlnIH0gZnJvbSAnLi4vZ3B0LmludGVyZmFjZSc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBQdWJhZHNTZXRDb25maWdTZXJ2aWNlIHtcbiAgLyoqXG4gICAqIFBhc3NlcyBsb2NhdGlvbiBpbmZvcm1hdGlvbiBmcm9tIHdlYnNpdGVzIHNvIHlvdSBjYW4gZ2VvLXRhcmdldCBsaW5lIGl0ZW1zIHRvIHNwZWNpZmljIGxvY2F0aW9ucy5cbiAgICpcbiAgICogQHBhcmFtIGFkZHJlc3MgRnJlZWZvcm0gYWRkcmVzcy5cbiAgICogQHBhcmFtIHB1YmFkcyBQdWJsaXNoZXIgQWRzIHNlcnZpY2UuIFRoaXMgc2VydmljZSBpcyB1c2VkIHRvIGZldGNoIGFuZCBzaG93IGFkcyBmcm9tIHlvdXIgR29vZ2xlIEFkIE1hbmFnZXIgYWNjb3VudC5cbiAgICovXG4gIHB1YmxpYyBhZGRMb2NhdGlvbihhZGRyZXNzOiBzdHJpbmcsIHB1YmFkczogUHViQWRzU2VydmljZSk6IHZvaWQge1xuICAgIGlmIChhZGRyZXNzKSB7XG4gICAgICBwdWJhZHMuc2V0TG9jYXRpb24oYWRkcmVzcyk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFNldHMgdGhlIHZhbHVlIGZvciB0aGUgcHVibGlzaGVyLXByb3ZpZGVkIElELlxuICAgKlxuICAgKiBAcGFyYW0gcHBpZCBBbiBhbHBoYW51bWVyaWMgSUQgcHJvdmlkZWQgYnkgdGhlIHB1Ymxpc2hlciB3aXRoIGEgcmVjb21tZW5kZWQgbWF4aW11bSBvZiAxNTAgY2hhcmFjdGVycy5cbiAgICogQHBhcmFtIHB1YmFkcyBQdWJsaXNoZXIgQWRzIHNlcnZpY2UuIFRoaXMgc2VydmljZSBpcyB1c2VkIHRvIGZldGNoIGFuZCBzaG93IGFkcyBmcm9tIHlvdXIgR29vZ2xlIEFkIE1hbmFnZXIgYWNjb3VudC5cbiAgICovXG4gIHB1YmxpYyBhZGRQUElEKHBwaWQ6IHN0cmluZywgcHViYWRzOiBQdWJBZHNTZXJ2aWNlKTogdm9pZCB7XG4gICAgaWYgKHBwaWQpIHtcbiAgICAgIHB1YmFkcy5zZXRQdWJsaXNoZXJQcm92aWRlZElkKHBwaWQpO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBTZXRzIGEgY3VzdG9tIHRhcmdldGluZyBwYXJhbWV0ZXIgZm9yIHRoaXMgc2xvdC5cbiAgICpcbiAgICogQHBhcmFtIGdsb2JhbFRhcmdldGluZ1xuICAgKiBAcGFyYW0gcHViYWRzIFB1Ymxpc2hlciBBZHMgc2VydmljZS4gVGhpcyBzZXJ2aWNlIGlzIHVzZWQgdG8gZmV0Y2ggYW5kIHNob3cgYWRzIGZyb20geW91ciBHb29nbGUgQWQgTWFuYWdlciBhY2NvdW50LlxuICAgKi9cbiAgcHVibGljIGFkZFRhcmdldGluZyhnbG9iYWxUYXJnZXRpbmc6IG9iamVjdCwgcHViYWRzOiBQdWJBZHNTZXJ2aWNlKTogdm9pZCB7XG4gICAgaWYgKE9iamVjdC5rZXlzKGdsb2JhbFRhcmdldGluZykubGVuZ3RoKSB7XG4gICAgICBmb3IgKGNvbnN0IGtleSBpbiBnbG9iYWxUYXJnZXRpbmcpIHtcbiAgICAgICAgaWYgKGdsb2JhbFRhcmdldGluZy5oYXNPd25Qcm9wZXJ0eShrZXkpKSB7XG4gICAgICAgICAgcHViYWRzLnNldFRhcmdldGluZyhrZXksIGdsb2JhbFRhcmdldGluZ1trZXldKTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBTZXRzIHRoZSBwYWdlLWxldmVsIHByZWZlcmVuY2VzIGZvciBTYWZlRnJhbWUgY29uZmlndXJhdGlvbi5cbiAgICpcbiAgICogQHBhcmFtIHNhZmVGcmFtZUNvbmZpZyBUaGUgY29uZmlndXJhdGlvbiBvYmplY3QuXG4gICAqIEBwYXJhbSBwdWJhZHMgUHVibGlzaGVyIEFkcyBzZXJ2aWNlLiBUaGlzIHNlcnZpY2UgaXMgdXNlZCB0byBmZXRjaCBhbmQgc2hvdyBhZHMgZnJvbSB5b3VyIEdvb2dsZSBBZCBNYW5hZ2VyIGFjY291bnQuXG4gICAqL1xuICBwdWJsaWMgYWRkU2FmZUZyYW1lQ29uZmlnKFxuICAgIHNhZmVGcmFtZUNvbmZpZzogU2FmZUZyYW1lQ29uZmlnLFxuICAgIHB1YmFkczogUHViQWRzU2VydmljZVxuICApOiB2b2lkIHtcbiAgICBpZiAoT2JqZWN0LmtleXMoc2FmZUZyYW1lQ29uZmlnKS5sZW5ndGgpXG4gICAgICBwdWJhZHMuc2V0U2FmZUZyYW1lQ29uZmlnKHNhZmVGcmFtZUNvbmZpZyk7XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHViYWRzLnNldENvbmZpZy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbmctZ3B0L3NyYy9saWIvc2VydmljZXMvcHViYWRzLnNldENvbmZpZy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBSTNDLE1BQU0sT0FBTyxzQkFBc0I7SUFDakM7Ozs7O09BS0c7SUFDSSxXQUFXLENBQUMsT0FBZSxFQUFFLE1BQXFCO1FBQ3ZELElBQUksT0FBTyxFQUFFO1lBQ1gsTUFBTSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQztTQUM3QjtJQUNILENBQUM7SUFFRDs7Ozs7T0FLRztJQUNJLE9BQU8sQ0FBQyxJQUFZLEVBQUUsTUFBcUI7UUFDaEQsSUFBSSxJQUFJLEVBQUU7WUFDUixNQUFNLENBQUMsc0JBQXNCLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDckM7SUFDSCxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSSxZQUFZLENBQUMsZUFBdUIsRUFBRSxNQUFxQjtRQUNoRSxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLENBQUMsTUFBTSxFQUFFO1lBQ3ZDLEtBQUssTUFBTSxHQUFHLElBQUksZUFBZSxFQUFFO2dCQUNqQyxJQUFJLGVBQWUsQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUFDLEVBQUU7b0JBQ3ZDLE1BQU0sQ0FBQyxZQUFZLENBQUMsR0FBRyxFQUFFLGVBQWUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO2lCQUNoRDthQUNGO1NBQ0Y7SUFDSCxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSSxrQkFBa0IsQ0FDdkIsZUFBZ0MsRUFDaEMsTUFBcUI7UUFFckIsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDLE1BQU07WUFDckMsTUFBTSxDQUFDLGtCQUFrQixDQUFDLGVBQWUsQ0FBQyxDQUFDO0lBQy9DLENBQUM7O21IQXJEVSxzQkFBc0I7dUhBQXRCLHNCQUFzQjsyRkFBdEIsc0JBQXNCO2tCQURsQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUHViQWRzU2VydmljZSwgU2FmZUZyYW1lQ29uZmlnIH0gZnJvbSAnLi4vZ3B0LmludGVyZmFjZSc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBQdWJhZHNTZXRDb25maWdTZXJ2aWNlIHtcbiAgLyoqXG4gICAqIFBhc3NlcyBsb2NhdGlvbiBpbmZvcm1hdGlvbiBmcm9tIHdlYnNpdGVzIHNvIHlvdSBjYW4gZ2VvLXRhcmdldCBsaW5lIGl0ZW1zIHRvIHNwZWNpZmljIGxvY2F0aW9ucy5cbiAgICpcbiAgICogQHBhcmFtIGFkZHJlc3MgRnJlZWZvcm0gYWRkcmVzcy5cbiAgICogQHBhcmFtIHB1YmFkcyBQdWJsaXNoZXIgQWRzIHNlcnZpY2UuIFRoaXMgc2VydmljZSBpcyB1c2VkIHRvIGZldGNoIGFuZCBzaG93IGFkcyBmcm9tIHlvdXIgR29vZ2xlIEFkIE1hbmFnZXIgYWNjb3VudC5cbiAgICovXG4gIHB1YmxpYyBhZGRMb2NhdGlvbihhZGRyZXNzOiBzdHJpbmcsIHB1YmFkczogUHViQWRzU2VydmljZSk6IHZvaWQge1xuICAgIGlmIChhZGRyZXNzKSB7XG4gICAgICBwdWJhZHMuc2V0TG9jYXRpb24oYWRkcmVzcyk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFNldHMgdGhlIHZhbHVlIGZvciB0aGUgcHVibGlzaGVyLXByb3ZpZGVkIElELlxuICAgKlxuICAgKiBAcGFyYW0gcHBpZCBBbiBhbHBoYW51bWVyaWMgSUQgcHJvdmlkZWQgYnkgdGhlIHB1Ymxpc2hlciB3aXRoIGEgcmVjb21tZW5kZWQgbWF4aW11bSBvZiAxNTAgY2hhcmFjdGVycy5cbiAgICogQHBhcmFtIHB1YmFkcyBQdWJsaXNoZXIgQWRzIHNlcnZpY2UuIFRoaXMgc2VydmljZSBpcyB1c2VkIHRvIGZldGNoIGFuZCBzaG93IGFkcyBmcm9tIHlvdXIgR29vZ2xlIEFkIE1hbmFnZXIgYWNjb3VudC5cbiAgICovXG4gIHB1YmxpYyBhZGRQUElEKHBwaWQ6IHN0cmluZywgcHViYWRzOiBQdWJBZHNTZXJ2aWNlKTogdm9pZCB7XG4gICAgaWYgKHBwaWQpIHtcbiAgICAgIHB1YmFkcy5zZXRQdWJsaXNoZXJQcm92aWRlZElkKHBwaWQpO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBTZXRzIGEgY3VzdG9tIHRhcmdldGluZyBwYXJhbWV0ZXIgZm9yIHRoaXMgc2xvdC5cbiAgICpcbiAgICogQHBhcmFtIGdsb2JhbFRhcmdldGluZ1xuICAgKiBAcGFyYW0gcHViYWRzIFB1Ymxpc2hlciBBZHMgc2VydmljZS4gVGhpcyBzZXJ2aWNlIGlzIHVzZWQgdG8gZmV0Y2ggYW5kIHNob3cgYWRzIGZyb20geW91ciBHb29nbGUgQWQgTWFuYWdlciBhY2NvdW50LlxuICAgKi9cbiAgcHVibGljIGFkZFRhcmdldGluZyhnbG9iYWxUYXJnZXRpbmc6IG9iamVjdCwgcHViYWRzOiBQdWJBZHNTZXJ2aWNlKTogdm9pZCB7XG4gICAgaWYgKE9iamVjdC5rZXlzKGdsb2JhbFRhcmdldGluZykubGVuZ3RoKSB7XG4gICAgICBmb3IgKGNvbnN0IGtleSBpbiBnbG9iYWxUYXJnZXRpbmcpIHtcbiAgICAgICAgaWYgKGdsb2JhbFRhcmdldGluZy5oYXNPd25Qcm9wZXJ0eShrZXkpKSB7XG4gICAgICAgICAgcHViYWRzLnNldFRhcmdldGluZyhrZXksIGdsb2JhbFRhcmdldGluZ1trZXldKTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBTZXRzIHRoZSBwYWdlLWxldmVsIHByZWZlcmVuY2VzIGZvciBTYWZlRnJhbWUgY29uZmlndXJhdGlvbi5cbiAgICpcbiAgICogQHBhcmFtIHNhZmVGcmFtZUNvbmZpZyBUaGUgY29uZmlndXJhdGlvbiBvYmplY3QuXG4gICAqIEBwYXJhbSBwdWJhZHMgUHVibGlzaGVyIEFkcyBzZXJ2aWNlLiBUaGlzIHNlcnZpY2UgaXMgdXNlZCB0byBmZXRjaCBhbmQgc2hvdyBhZHMgZnJvbSB5b3VyIEdvb2dsZSBBZCBNYW5hZ2VyIGFjY291bnQuXG4gICAqL1xuICBwdWJsaWMgYWRkU2FmZUZyYW1lQ29uZmlnKFxuICAgIHNhZmVGcmFtZUNvbmZpZzogU2FmZUZyYW1lQ29uZmlnLFxuICAgIHB1YmFkczogUHViQWRzU2VydmljZVxuICApOiB2b2lkIHtcbiAgICBpZiAoT2JqZWN0LmtleXMoc2FmZUZyYW1lQ29uZmlnKS5sZW5ndGgpXG4gICAgICBwdWJhZHMuc2V0U2FmZUZyYW1lQ29uZmlnKHNhZmVGcmFtZUNvbmZpZyk7XG4gIH1cbn1cbiJdfQ==

@@ -51,2 +51,2 @@ import { Injectable } from '@angular/core';

}], ctorParameters: function () { return [{ type: i1.HttpErrorService }]; } });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NyaXB0LWluamVjdG9yLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1ncHQvc3JjL2xpYi9zZXJ2aWNlcy9zY3JpcHQtaW5qZWN0b3Iuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFJM0MsTUFBTSxPQUFPLHFCQUFxQjtJQUNoQyxZQUFvQixTQUEyQjtRQUEzQixjQUFTLEdBQVQsU0FBUyxDQUFrQjtJQUFHLENBQUM7SUFFM0MsV0FBVyxDQUFDLEdBQVc7UUFDN0IsTUFBTSxHQUFHLEdBQUcsUUFBUSxDQUFDLFFBQVEsQ0FBQyxRQUFRLEtBQUssUUFBUSxDQUFDO1FBQ3BELE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLEdBQUcsR0FBRyxDQUFDO0lBQzFDLENBQUM7SUFFTyxZQUFZLENBQUMsR0FBVztRQUM5QixNQUFNLE1BQU0sR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRWhELE1BQU0sQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO1FBQ3BCLE1BQU0sQ0FBQyxJQUFJLEdBQUcsaUJBQWlCLENBQUM7UUFDaEMsTUFBTSxDQUFDLEdBQUcsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBRW5DLE9BQU8sTUFBTSxDQUFDO0lBQ2hCLENBQUM7SUFFTyxhQUFhLENBQUMsTUFBVyxFQUFFLEdBQVc7UUFDNUMsTUFBTSxPQUFPLEdBQUcsSUFBSSxPQUFPLENBQUMsQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLEVBQUU7WUFDOUMsTUFBTSxDQUFDLE1BQU0sR0FBRyxHQUFHLEVBQUU7Z0JBQ25CLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUNsQixDQUFDLENBQUM7WUFDRixNQUFNLENBQUMsT0FBTyxHQUFHLEdBQUcsRUFBRTtnQkFDcEIsTUFBTSxDQUFDO29CQUNMLElBQUksRUFBRSxHQUFHO29CQUNULE1BQU0sRUFBRSxLQUFLO2lCQUNkLENBQUMsQ0FBQztZQUNMLENBQUMsQ0FBQztRQUNKLENBQUMsQ0FBQyxDQUFDO1FBRUgsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLFFBQWEsRUFBRSxFQUFFO1lBQzlCLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLEVBQUUsTUFBTSxFQUFFLEdBQUcsRUFBRSxFQUFFLG1CQUFtQixHQUFHLEdBQUcsQ0FBQyxDQUFDO1FBQ3ZFLENBQUMsQ0FBQyxDQUFDO1FBRUgsT0FBTyxPQUFPLENBQUM7SUFDakIsQ0FBQztJQUVELFlBQVksQ0FBQyxNQUFXO1FBQ3RCLE1BQU0sSUFBSSxHQUFHLFFBQVEsQ0FBQyxJQUFJLElBQUksUUFBUSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUM3RCxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzNCLENBQUM7SUFFRCxjQUFjLENBQUMsR0FBVztRQUN4QixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3RDLElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDMUIsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU0sRUFBRSxHQUFHLENBQUMsQ0FBQztJQUN6QyxDQUFDOztrSEEvQ1UscUJBQXFCO3NIQUFyQixxQkFBcUI7MkZBQXJCLHFCQUFxQjtrQkFEakMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEh0dHBFcnJvclNlcnZpY2UgfSBmcm9tICcuJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIFNjcmlwdEluamVjdG9yU2VydmljZSB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgaHR0cEVycm9yOiBIdHRwRXJyb3JTZXJ2aWNlKSB7fVxuXG4gIHByaXZhdGUgY29tcGxldGVVUkwodXJsOiBzdHJpbmcpIHtcbiAgICBjb25zdCBzc2wgPSBkb2N1bWVudC5sb2NhdGlvbi5wcm90b2NvbCA9PT0gJ2h0dHBzOic7XG4gICAgcmV0dXJuIChzc2wgPyAnaHR0cHM6JyA6ICdodHRwOicpICsgdXJsO1xuICB9XG5cbiAgcHJpdmF0ZSBjcmVhdGVTY3JpcHQodXJsOiBzdHJpbmcpIHtcbiAgICBjb25zdCBzY3JpcHQgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KCdzY3JpcHQnKTtcblxuICAgIHNjcmlwdC5hc3luYyA9IHRydWU7XG4gICAgc2NyaXB0LnR5cGUgPSAndGV4dC9qYXZhc2NyaXB0JztcbiAgICBzY3JpcHQuc3JjID0gdGhpcy5jb21wbGV0ZVVSTCh1cmwpO1xuXG4gICAgcmV0dXJuIHNjcmlwdDtcbiAgfVxuXG4gIHByaXZhdGUgcHJvbWlzZVNjcmlwdChzY3JpcHQ6IGFueSwgdXJsOiBzdHJpbmcpIHtcbiAgICBjb25zdCBwcm9taXNlID0gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgc2NyaXB0Lm9ubG9hZCA9ICgpID0+IHtcbiAgICAgICAgcmVzb2x2ZShzY3JpcHQpO1xuICAgICAgfTtcbiAgICAgIHNjcmlwdC5vbmVycm9yID0gKCkgPT4ge1xuICAgICAgICByZWplY3Qoe1xuICAgICAgICAgIHBhdGg6IHVybCxcbiAgICAgICAgICBsb2FkZWQ6IGZhbHNlLFxuICAgICAgICB9KTtcbiAgICAgIH07XG4gICAgfSk7XG5cbiAgICBwcm9taXNlLmNhdGNoKChyZXNwb25zZTogYW55KSA9PiB7XG4gICAgICB0aGlzLmh0dHBFcnJvci5odHRwRXJyb3IoeyBzdGF0dXM6IDQwMCB9LCBgbG9hZGluZyBzY3JpcHQgXCIke3VybH1cImApO1xuICAgIH0pO1xuXG4gICAgcmV0dXJuIHByb21pc2U7XG4gIH1cblxuICBpbmplY3RTY3JpcHQoc2NyaXB0OiBhbnkpIHtcbiAgICBjb25zdCBoZWFkID0gZG9jdW1lbnQuaGVhZCB8fCBkb2N1bWVudC5xdWVyeVNlbGVjdG9yKCdoZWFkJyk7XG4gICAgaGVhZC5hcHBlbmRDaGlsZChzY3JpcHQpO1xuICB9XG5cbiAgc2NyaXB0SW5qZWN0b3IodXJsOiBzdHJpbmcpIHtcbiAgICBjb25zdCBzY3JpcHQgPSB0aGlzLmNyZWF0ZVNjcmlwdCh1cmwpO1xuICAgIHRoaXMuaW5qZWN0U2NyaXB0KHNjcmlwdCk7XG4gICAgcmV0dXJuIHRoaXMucHJvbWlzZVNjcmlwdChzY3JpcHQsIHVybCk7XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NyaXB0LWluamVjdG9yLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9uZy1ncHQvc3JjL2xpYi9zZXJ2aWNlcy9zY3JpcHQtaW5qZWN0b3Iuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFJM0MsTUFBTSxPQUFPLHFCQUFxQjtJQUNoQyxZQUFvQixTQUEyQjtRQUEzQixjQUFTLEdBQVQsU0FBUyxDQUFrQjtJQUFHLENBQUM7SUFFM0MsV0FBVyxDQUFDLEdBQVc7UUFDN0IsTUFBTSxHQUFHLEdBQUcsUUFBUSxDQUFDLFFBQVEsQ0FBQyxRQUFRLEtBQUssUUFBUSxDQUFDO1FBQ3BELE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLEdBQUcsR0FBRyxDQUFDO0lBQzFDLENBQUM7SUFFTyxZQUFZLENBQUMsR0FBVztRQUM5QixNQUFNLE1BQU0sR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRWhELE1BQU0sQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO1FBQ3BCLE1BQU0sQ0FBQyxJQUFJLEdBQUcsaUJBQWlCLENBQUM7UUFDaEMsTUFBTSxDQUFDLEdBQUcsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBRW5DLE9BQU8sTUFBTSxDQUFDO0lBQ2hCLENBQUM7SUFFTyxhQUFhLENBQUMsTUFBVyxFQUFFLEdBQVc7UUFDNUMsTUFBTSxPQUFPLEdBQUcsSUFBSSxPQUFPLENBQUMsQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLEVBQUU7WUFDOUMsTUFBTSxDQUFDLE1BQU0sR0FBRyxHQUFHLEVBQUU7Z0JBQ25CLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUNsQixDQUFDLENBQUM7WUFDRixNQUFNLENBQUMsT0FBTyxHQUFHLEdBQUcsRUFBRTtnQkFDcEIsTUFBTSxDQUFDO29CQUNMLElBQUksRUFBRSxHQUFHO29CQUNULE1BQU0sRUFBRSxLQUFLO2lCQUNkLENBQUMsQ0FBQztZQUNMLENBQUMsQ0FBQztRQUNKLENBQUMsQ0FBQyxDQUFDO1FBRUgsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLFFBQWEsRUFBRSxFQUFFO1lBQzlCLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLEVBQUUsTUFBTSxFQUFFLEdBQUcsRUFBRSxFQUFFLG1CQUFtQixHQUFHLEdBQUcsQ0FBQyxDQUFDO1FBQ3ZFLENBQUMsQ0FBQyxDQUFDO1FBRUgsT0FBTyxPQUFPLENBQUM7SUFDakIsQ0FBQztJQUVELFlBQVksQ0FBQyxNQUFXO1FBQ3RCLE1BQU0sSUFBSSxHQUFHLFFBQVEsQ0FBQyxJQUFJLElBQUksUUFBUSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUM3RCxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzNCLENBQUM7SUFFRCxjQUFjLENBQUMsR0FBVztRQUN4QixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3RDLElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDMUIsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU0sRUFBRSxHQUFHLENBQUMsQ0FBQztJQUN6QyxDQUFDOztrSEEvQ1UscUJBQXFCO3NIQUFyQixxQkFBcUI7MkZBQXJCLHFCQUFxQjtrQkFEakMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEh0dHBFcnJvclNlcnZpY2UgfSBmcm9tICcuJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIFNjcmlwdEluamVjdG9yU2VydmljZSB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgaHR0cEVycm9yOiBIdHRwRXJyb3JTZXJ2aWNlKSB7fVxuXG4gIHByaXZhdGUgY29tcGxldGVVUkwodXJsOiBzdHJpbmcpIHtcbiAgICBjb25zdCBzc2wgPSBkb2N1bWVudC5sb2NhdGlvbi5wcm90b2NvbCA9PT0gJ2h0dHBzOic7XG4gICAgcmV0dXJuIChzc2wgPyAnaHR0cHM6JyA6ICdodHRwOicpICsgdXJsO1xuICB9XG5cbiAgcHJpdmF0ZSBjcmVhdGVTY3JpcHQodXJsOiBzdHJpbmcpIHtcbiAgICBjb25zdCBzY3JpcHQgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KCdzY3JpcHQnKTtcblxuICAgIHNjcmlwdC5hc3luYyA9IHRydWU7XG4gICAgc2NyaXB0LnR5cGUgPSAndGV4dC9qYXZhc2NyaXB0JztcbiAgICBzY3JpcHQuc3JjID0gdGhpcy5jb21wbGV0ZVVSTCh1cmwpO1xuXG4gICAgcmV0dXJuIHNjcmlwdDtcbiAgfVxuXG4gIHByaXZhdGUgcHJvbWlzZVNjcmlwdChzY3JpcHQ6IGFueSwgdXJsOiBzdHJpbmcpIHtcbiAgICBjb25zdCBwcm9taXNlID0gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgc2NyaXB0Lm9ubG9hZCA9ICgpID0+IHtcbiAgICAgICAgcmVzb2x2ZShzY3JpcHQpO1xuICAgICAgfTtcbiAgICAgIHNjcmlwdC5vbmVycm9yID0gKCkgPT4ge1xuICAgICAgICByZWplY3Qoe1xuICAgICAgICAgIHBhdGg6IHVybCxcbiAgICAgICAgICBsb2FkZWQ6IGZhbHNlLFxuICAgICAgICB9KTtcbiAgICAgIH07XG4gICAgfSk7XG5cbiAgICBwcm9taXNlLmNhdGNoKChyZXNwb25zZTogYW55KSA9PiB7XG4gICAgICB0aGlzLmh0dHBFcnJvci5odHRwRXJyb3IoeyBzdGF0dXM6IDQwMCB9LCBgbG9hZGluZyBzY3JpcHQgXCIke3VybH1cImApO1xuICAgIH0pO1xuXG4gICAgcmV0dXJuIHByb21pc2U7XG4gIH1cblxuICBpbmplY3RTY3JpcHQoc2NyaXB0OiBhbnkpIHtcbiAgICBjb25zdCBoZWFkID0gZG9jdW1lbnQuaGVhZCB8fCBkb2N1bWVudC5xdWVyeVNlbGVjdG9yKCdoZWFkJyk7XG4gICAgaGVhZC5hcHBlbmRDaGlsZChzY3JpcHQpO1xuICB9XG5cbiAgc2NyaXB0SW5qZWN0b3IodXJsOiBzdHJpbmcpIHtcbiAgICBjb25zdCBzY3JpcHQgPSB0aGlzLmNyZWF0ZVNjcmlwdCh1cmwpO1xuICAgIHRoaXMuaW5qZWN0U2NyaXB0KHNjcmlwdCk7XG4gICAgcmV0dXJuIHRoaXMucHJvbWlzZVNjcmlwdChzY3JpcHQsIHVybCk7XG4gIH1cbn1cbiJdfQ==

@@ -5,2 +5,2 @@ /**

export * from './public-api';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctZ3B0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvbmctZ3B0L3NyYy9uZy1ncHQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctZ3B0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vbmctZ3B0L3NyYy9uZy1ncHQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==

@@ -7,2 +7,2 @@ /*

export * from "./lib/gpt.module";
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25nLWdwdC9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLGtCQUFrQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBhbmd1bGFyLWdwdFxuICovXG5cbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9ncHQuc2VydmljZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2dwdC5kaXJlY3RpdmVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9ncHQubW9kdWxlXCI7XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL25nLWdwdC9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLGtCQUFrQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBhbmd1bGFyLWdwdFxuICovXG5cbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9ncHQuc2VydmljZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2dwdC5kaXJlY3RpdmVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9ncHQubW9kdWxlXCI7XG4iXX0=

@@ -479,2 +479,5 @@ import { isPlatformBrowser, DOCUMENT } from '@angular/common';

this.config = config;
this.sizes = "fluid";
this.sizeMapping = [];
this.targetingArguments = {};
this.afterRefresh = new EventEmitter();

@@ -486,3 +489,3 @@ this.scripts = [];

if (slot === this.slot) {
this.afterRefresh.emit({ type: 'refresh', slot: slot });
this.afterRefresh.emit({ type: "refresh", slot: slot });
}

@@ -496,3 +499,3 @@ });

!this.refresh &&
this.config.onSameNavigation === 'refresh') {
this.config.onSameNavigation === "refresh") {
this.refreshContent.call(this);

@@ -505,3 +508,4 @@ }

ngOnInit() {
if (isPlatformBrowser(this.platformID)) {
this.checkRequiredFields(this.adUnit, "adUnit");
if (isPlatformBrowser(this.platformID) && !this.id) {
this.gptIDGenerator.gptIDGenerator(this.elementRef.nativeElement);

@@ -552,6 +556,6 @@ }

}
googletag.pubads().addEventListener('slotRenderEnded', (event) => {
googletag.pubads().addEventListener("slotRenderEnded", (event) => {
if (event.slot === this.slot) {
this.afterRefresh.emit({
type: 'renderEnded',
type: "renderEnded",
slot: this.slot,

@@ -580,3 +584,3 @@ data: event,

this.gptRefresh.slotRefresh(this.slot, this.refresh, true).then((slot) => {
this.afterRefresh.emit({ type: 'init', slot: slot });
this.afterRefresh.emit({ type: "init", slot: slot });
});

@@ -588,7 +592,4 @@ }

getState() {
this.checkRequiredFields(this.id, 'id');
this.checkRequiredFields(this.adUnit, 'path');
this.checkRequiredFields(this.sizes, 'sizes');
return Object.freeze({
sizes: this.sizes,
sizes: typeof this.sizes === "string" ? [this.sizes] : this.sizes,
sizeMapping: this.sizeMapping,

@@ -611,5 +612,2 @@ targetingArguments: this.targetingArguments,

}
addSize(size) {
this.sizes.push(size);
}
addExclusion(exclusion) {

@@ -626,3 +624,3 @@ this.exclusions.push(exclusion);

type: Directive,
args: [{ selector: 'gpt-ad' }]
args: [{ selector: "gpt-ad" }]
}], ctorParameters: function () { return [{ type: Object, decorators: [{

@@ -629,0 +627,0 @@ type: Inject,

@@ -15,3 +15,3 @@ import { InjectionToken } from '@angular/core';

ppid?: string;
globalTargeting: object;
globalTargeting?: object;
safeFrameConfig?: SafeFrameConfig;

@@ -18,0 +18,0 @@ enableLazyLoad?: LazyLoadOptionsConfig;

@@ -1,7 +0,7 @@

import { AfterViewInit, ElementRef, EventEmitter, OnDestroy } from '@angular/core';
import { Router } from '@angular/router';
import { GptConfig } from './gpt.config';
import { GptService } from './gpt.service';
import { GptRefreshService } from './services';
import { GptIDGeneratorService } from './services/gpt-idGenerator.service';
import { AfterViewInit, ElementRef, EventEmitter, OnDestroy, OnInit } from "@angular/core";
import { Router } from "@angular/router";
import { GptConfig } from "./gpt.config";
import { GptService } from "./gpt.service";
import { GptRefreshService } from "./services";
import { GptIDGeneratorService } from "./services/gpt-idGenerator.service";
import * as i0 from "@angular/core";

@@ -20,3 +20,3 @@ export declare class GptRefreshEvent {

}
export declare class GptAdDirective implements AfterViewInit, OnDestroy {
export declare class GptAdDirective implements OnInit, AfterViewInit, OnDestroy {
private platformID;

@@ -30,3 +30,3 @@ private elementRef;

adUnit: string;
sizes: [number, number][];
sizes: [number, number][] | string;
sizeMapping: SizeMapping[];

@@ -52,3 +52,3 @@ forceSafeFrame: boolean;

getState(): Readonly<{
sizes: [number, number][];
sizes: string[] | [number, number][];
sizeMapping: SizeMapping[];

@@ -65,3 +65,2 @@ targetingArguments: TargetingArguments;

checkRequiredFields(input: any, name: string): void;
addSize(size: any): void;
addExclusion(exclusion: any): void;

@@ -68,0 +67,0 @@ addScript(script: any): void;

{
"name": "ng-gpt",
"version": "0.0.4",
"version": "0.0.5",
"description": "A Angular implementation of the google GPT API.",

@@ -5,0 +5,0 @@ "keywords": [

@@ -65,1 +65,13 @@ # Angular GPT

```
### Parameters
- **`adUnit`** [`string`] - **required** Full ad unit path with the network code and unit code.
- **`id`** [`string`] - ID of the div that will contain this ad unit.
- **`size`** [`[number, number][] | string`] - Width and height of the added slot. This is the size that is used in the ad request if no responsive size mapping is provided or the size of the viewport is smaller than the smallest size provided in the mapping. Default `fluid`.
- **`sizeMapping`** [`{viewport: [number, number]; sizes: [number, number][]}[]`] - Array of size mappings. Each size mapping is an array of two elements.
- **`forceSafeFrame`** [`boolean`] - true to force all ads in this slot to be rendered in SafeFrames and false to opt-out of a page-level setting (if present). Setting this to false when not specified at page-level, won't change anything.
- **`safeFrameConfig`** [`string`] - slot-level preferences for SafeFrame configuration. Any unrecognized keys in the config object will be ignored. The entire config will be ignored if an invalid value is passed for a recognized key.
- **`refresh`** [`number`] - refresh interval.
- **`collapseEmptyDivs`** [`boolean`] - Sets whether the slot div should be hidden when there is no ad in the slot.
- **`targetingArguments`** [`[key: string]: any`] - custom targeting parameters for a given key that apply to all pubads service ad slots.

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc